Grand Shooting API Documentation (3.0.0)

Download OpenAPI specification:Download

Handle HTTP status

We respect HTTP standard and REST architecture.

Most of cases you will receive a success response contained in this table:

HTTP code Description
102 PENDING. The request is threated and takes some time.
200 OK, The request is threated with success.
201 Created, The request is threated with success and a content is created (e.g. for a POST request)
204 No Content, The request is threated with success but return no content in the response.

Please refer to the following table for identify your problem if you receive an HTTP error:

HTTP code Description
400 Bad request, in the response, you will see which field is missing or invalid.
401 Unauthorized, check if you passed the Authorization Header
404 Not found, the ressource is missing (e.g A user who have been deleted)
405 Method not allowed, the server know the endpoint used but don't permit this method
500 Internal server error, bad news it seems we have a problem

If you have an unidentified response, don't hesitate to contact our support.

Now you are be able to request all of our endpoints.

Rate limiting

Rate limiting is on account basis, or more accurately described, per authentication key. There is a limit on the number of simultaneous requests: you can call up to 5 requests per second.

When you exceed this rate limit for any endpoint of our API, the API will return a HTTP 429 “Too Many Requests” response code, and the following error will be returned in the response body:

{ "errors": [ { "message": "Rate limit exceeded" } ] }

The model

If you start coding with our API, you may be interested in having a first global overview of the main concepts behind Grand Shooting.

Note: The platform supports images and videos. This documentation is equally applicable to both and we may use indifferently the two words (images or videos). So, keep in mind that when we describe a feature, it is always applicable to both images and videos.

Productions and Benches

A production is a bunch of images that is processed according to a declared workflow. Every step of the workflow is called a bench.

A classic production is composed of 3 benches:

  1. Capture (corresponds to the “LIVE” feature of the web application)
  2. Retouching (often called “Phase 1”)
  3. Exports (see below) / Validation

You can have 2 retouching benches within the same production. It can be useful for instance if you want a first stage to clean up images with basic operations then a second stage with more in-depth retouching.

Retouching is optional: you can create a production with no retouching bench. On the contrary Capture, Exports and Validation are mandatory.

Be careful: you can update benches and delete retouching benches as long as no files has been loaded. If you delete a bench that contains files, they will be immediately deleted, and you won’t have the possibility to recover them.

To distinguish the benches within a production, the API includes a parameter called benchsetptype wich can take these values:

  • 10 – Capture
  • 20 – Retouching (phase 1)
  • 30 – Retouching (phase 2)
  • 40 – Exports / Validation

Exports and Validation

Exports refers to a specific bench of the production: the one before the validation bench.

The way you interact with images inside export and validation benches differs from the interactions within the first benches of the production: you load images to capture and retouching benches, but you just trigger exports to process retouched images. And the processed images are automatically dropped to the validation bench.

So, you never load images either to export benches nor to validation benches.

Be careful: don’t delete retouching benches if they already contain files. Otherwise you would not be able to trigger exports for this production anymore and you would have to start again with a new production.

Templates

Using the web application, you can create new productions from scratch then set up all the parameters by hand: the number of benches, user accesses on every bench, the settings for the export bench, and so on.

It doesn’t really have sense to give this level of precision from our API because the purpose of the API is to automate repetitive workflows.

That’s why you first create templates with predefined settings from the web application. Then, from the API, you instance new productions giving in parameters the Id of the template.

Shooting methods

Photo shoot sessions can be differentiated thanks to shooting methods.

Basically, a shooting method represents a specific way to get pictures of products: it can be products wared on models or it can be still life. You may also use different shooting methods to distinguish photos produced with different machines or technologies.

Therefore, shooting methods give you full control on how you want to monitor the productions: they appear on almost all reports and you will be able to filter for the values they can take.

Note: if you have questions about the best shooting method values for your organization, feel free to ask the support team for advice.

Shooting methods are set up from the web application with admin credentials. From the API, you can list them.

The catalog and its references

It is one of the big features of Grand Shooting: every image or video can be linked to a catalog. Thus, you will be able to organize image production by product references.

There is only one catalog. But you can combine products from different brands within the same catalog. The attributes stored in Grand Shooting are quite classic:

  • Up to 3 levels of categories (univers, gamme, family)
  • Brand Model
  • reference (product_ref)
  • Color
  • Size
  • Description,
  • collection,
  • gender
  • SKU
  • EAN

Every item in the catalog is identified in Grand Shooting by another attribute called 'ref' (for product reference). This 'ref' attribute can be a unique id, but it is commonly generated from other attributes.

For example, in the ready to wear market we need to take pictures not only of all product models but also of all color declinations. Then the ref attribute will be constructed from the model reference attribute concatenated with the color attribute.

Example: Model: S18BOHEMIAN
Color: 110
Ref: SS18BOHEMIAN_110

Important: keep in mind that 'ref' values should be unique in the catalog and that they refer to the product that need to be taken in photo.

The 'EAN' attribute is usefull if the samples do have barcodes. In the web application, typing the ref attribute of a product or scanning is barcode is strictly the same. That’s why 'EAN' values should also be unique.

Note: even if the attribute’s name is 'EAN', you don’t have to comply with 'EAN' standard (we don’t check the parity byte)

Note: sometimes you have multiple sizes of the same product references and you don’t know in advance which samples will be shot. Then you don’t know which 'EAN' have to be stored in you catalog. Don’t worry we already faced this issue many times, the support team will help you to find the solution.

Shotlist : list of products to be shot

From Grand Shooting’s web application, the guidelines define per product category how many images are attempted and what are the technical specifications of these images (in terms of size, resolution, ICC profile, …).

Shotlists make an inventory of existing images for every product in your catalog. They explicit the status of the images in your workflow and reveal alerts if an image does not comply with the guidelines.

More generally shotlists can be seen as the cockpit where you can see the work in progress from the point of view of the catalog.

Looks : group of references visible on the same images

This feature is useful especially for the ready to ware market.

Imagine a model wearing clothes: shoes, a pant, a shirt, a coat, … All these clothes make something up called a look.

In this case the looks are mostly composed before starting the photo shoot session. That’s why it makes sense to link images directly to the look and not to product references.

Be careful: the name of the looks have be different of the names of product references in the catalog.

Getting started

Our first production

So, let’s start with the API. We will stay simple and create a basic production. To do this, simply send the following request:

POST https://api.grand-shooting.com/v3/production

With the body:

    {  
    "smalltext": "My first production",  
    "startdate": "2017-03-27T07:00:00.000Z",
    "enddate": "2017-03-27T16:00:00.000Z",
    "timezone": "Europe/Paris",
    "tzoffset": 60,
    "shooting_method_id": 1,  
    "bench_template_id": 1  
    }

The 2 main parameters are 'shooting_method_id' and 'bench_template_id'. They refer to the shooting method and to the template. They are the only parameters that cannot be changed once the production is created.

We set a smalltext “'My first production'” that will be viewable on the web application as the title of the production.

The 'startdate' parameter gives information about the day the first images shall be uploaded to this production. Usually it is the date of the photo shoot session. The time zone is explicitly set.

'enddate', 'timezone' and 'tzoffset' are optional. In this example the parameters are set to a capture session starting at 7.00 am and ending at 4.00 pm. If omitted, the timezone is set to "Europe/Paris".

List the benches of a production

Now to list all the productions call this request:

GET /production

It will return an array with all the productions, like this one:

    [ 
        [
            {
            "smalltext": "My first production",
            "startdate": "2017-03-27T07:00:00.000Z",
            "enddate": null,
            "timezone": "Europe/Paris",
            "tzoffset": 60,
            "shooting_method_id": 1,
            "bench_id": 1,
            "parent_id": null,
            "root_id": 1,
            "benchsteptype": 10
            },
            {
            "smalltext": "My first production (Retouching)",
            "startdate": "2017-03-27T07:00:00.000Z",
            "enddate": null,
            "timezone": "Europe/Paris",
            "tzoffset": 60,
            "shooting_method_id": 1,
            "bench_id": 2,
            "parent_id": 1,
            "root_id": 1,
            "benchsteptype": 20
            },
            {
            "smalltext": "My first production (Export)",
            "startdate": "2017-03-27T07:00:00.000Z",
            "enddate": null,
            "timezone": "Europe/Paris",
            "tzoffset": 60,
            "shooting_method_id": 1,
            "bench_id": 3,
            "parent_id": 2,
            "root_id": 1,
            "benchsteptype": 40
            }
        ]
    ]

You can see that the previously created production contains 3 benches: Capture ('benchsteptype' = 10), Retouching ('benchsteptype' = 20) and validation ('benchsteptype' = 40).

Benches are chained:

  • The first bench of a production has no 'parent_id'.
  • The 'root_id' is the id of the first bench for all benches of the production.
  • From one bench to the next one you can see that the 'parent_id' changed.

Note : By convention, the 'smalltext' attribute of the first bench of a production is repeated for all benches ("My first production" in this example). Then, the specific name of a bench is set between parenthesis ("Retouching" and "Export" in this example). The first bench of a production can't have any specific name as it is always set as "Live".

If you want to list all productions but not all benches of production, you can filter the benches with null as parent_id.

Load bench of a production

If you need the details about a specific bench, you can call this endpoint:

GET /production/{bench_root_id}/bench/{bench_id}

You will get just the bench:

{
"smalltext": "My first production (Export)",
"startdate": "2017-03-27T07:00:00.000Z",
"enddate": null,
"timezone": "Europe/Paris",
"tzoffset": 60,
"shooting_method_id": 1,
"bench_id": 3,
"parent_id": 2,
"root_id": 1,
"benchsteptype": 40
}

List the pictures of a bench

Once you created a production and you know there are some pictures, you may want to list them. Super easy, just send this request:

GET https://api.grand-shooting.com/v3/picture?bench_id=3

In this example we list images from the third bench. The body of the response is an array of picture objects like this one:

{
"picture_id": 3,
"bench_id": 3,
"bench_root_id": 1,
"ref": "3596654282833",
"path": "4c76bb10-d028-4988-b008-01a97c38a232/3596654282833_3.jpg",
"smalltext": "3596654282833_3.jpg",
"picturestatus": 50,
"filesize": 503637,
"reference_id": 1,
"child_ids": [],
"parent_id": 2
}

File name and path

Basically you can consider that a bench is a secured folder in which files are stored. Files can be organized in subfolders and the path attribute indicates the exact location of a file inside the bench.

So, there might be 2 images with the same filename "3596654282833_3.jpg" in this bench. But there can be just one image with this path ""4c76bb10-d028-4988-b008-01a97c38a232/3596654282833_3.jpg".

Picture status

'picturestatus' attribute refers to the status of an image (or video) inside a production. It can take one of these values :

HTTP code Description
5 RESHOOT, Image to be shot again.
10 NOT SELECTED, Image in the Live with default status
30 SELECTED, Image in the Live selected for retouching
31 REFUSED, Image refused, need some more work
35 REFUSED, Image refused by the retouchers
40 FOR APPROVAL, Image submitted for approval
50 VALIDATED, Image validated
52 ERROR, Error during the tranfer to the DAM
55 RELEASED, Image transferred to the DAM

Head's up ! : the status of a picture and the type of its bench are correlated. For instance a bench that corresponds to a Live ('benchsteptype' = 10) should only have pictures with status 5, 10 or 30. And a bench that corresponds to a validation step should only have pictures with status above than 40, except for the refused image ('picturestatus' = 31).

Note : Even if an image is not selected (in the Live bench), it can be retouched in the retouching benches then exported for approval. And of course a refused image can be retouched again and exported again for approval.

If Grand Shooting is integrated with a PIM, a DAM or Amazon S3, images will automatically take these status after having been transferred. In most cases, only validated images are transferred.

What is the difference between the 2 REFUSED status ? The common way to refuse an image is in the export bench : the status value of the image is 31. But an image can also be refused by a retoucher in the bench for retouching : in this case the status value is 35.

Upload images

We learned how to list the productions and their benches. Now let's try to upload images.

POST /production/{bench_root_id}/bench/{bench_id}/upload

With a multipart body:

As you can see, it is very simple to integrate our API and manage image productions from your own applications: with few lines of code, you instantiate new productions then load / download images to / from the benches.

Keep in mind that the way you manage images within benches for capture and retouching differs from the interactions you can have with images within benches for export and validation.

Webhooks

Webhook is a pattern that allows external systems to be notified of events occuring in a Sass plaform.

Contribution

You can contribute urls in the administration console that will be notified of picture modifications events. You reference your url to be called for certain types of events :

  • picture creation
  • picture modification
  • picture deletion
  • reference creation
  • reference modification

Note : you can reference the same url for different types of events.

Process

When a picture is modified in Grand Shooting, the system stores the event in a queue. Every 10 seconds, events are read from the queue and sent to the external url in a "POST" http call with a JSON body containing modified data Example :

    {
      "account_id": 10229487,
      "topic": "pictures/update",
      "type": "picture",
      "ids": [
        175,
        176
      ],
      "picture_id": [ //Deprecated
        175,
        176
      ],
      "data": {
        "175": {
          "picture_id": 175,
          "bench_id": 19,
          "bench_root_id": 19,
          ...
        },
        "176": {
          "picture_id": 176,
          "bench_id": 19,
          "bench_root_id": 19,
          ...
        }
      }
    }
  • A message contains at most 50 data elements. (If there are more than 50 data elements modified, a second http call will be processed)
  • A message is concidered in success the url returns a http response code of 200
  • If a timeout occurs when calling the url or if it returns something else than a code 200, the message is concidered not delivered.
    • The system will retry twice to send the message (after 10 seconds, and after 1 minute)
    • The system won't send any other message to the url for the same topic until it gets a code 200 response or all 3 tries are sent.
  • Deprecation : picture_id array field is deprecated and will be removed in next major version. You should use ids field instead

Authentication

Bearer

You can obtain a token from Grand Shooting administration pages.

You can use it by sending the header "Authorization" with value "Bearer (your token)"

Security Scheme Type API Key
Header parameter name: Authorization

ping

notes

Authorizations:

Responses

Response samples

Content type
application/json
"string"

picture

List pictures

Return an array of pictures with a pagination of 100.

You can filter by giving query parameters with the following logic :

  • picturestatus=50 : filter pictures with picturestatus = 50
  • picturestatus=50&picturestatus=40 : filter pictures with picturestatus = 50 OR picturestatus = 40
  • picturestatus=gte:50 : filter pictures with picturestatus greater than or equal to 50 (available options are gt gte lt lte)

You can set the offset of pagination with the header 'offset'. Response headers:

  • 'X-Total-Count': Total number of items
  • 'X-Offset': Offset of the result
  • 'X-Count': Size of the result
Authorizations:
query Parameters
picture_id
string

id of the picture

sort_by
string

Sort search

bench_id
string

id of the bench the picture belongs to

bench_root_id
string

id of the bench the picture belongs to

benchsteptype
string

workflow step of production

ref
string

ref extracted from picture

path
string

path of the picture in the repository

smalltext
string

picture filename

picturestatus
string
Worlflow step of the picture.
    1 : ignored
    5 : to reshoot
    10 : not selected
    30 : selected
    31 : refused
    35 : refused
    40 : submited for approval
    50 : validated
    51 : ready to broadcast (in case of manual broadcast)
    52 : error during broadcast
    55 : broadcast (once validated a picture can be broadcast on )
    80 : archived
filesize
string

filesize

width
string

width

height
string

height

reference_id
string

reference_id

parent_id
string

parent picture

icc_profile
string

icc profile of image

thumbnail
string

url of thumbnail

hash
string

hash computed from image content

file_id
string

identifier of file content

view_type_code
string

view type code

transfer_date
string

transfert date of the picture (in Grand Shooting)

date_cre
string

creation date of the picture (in Grand Shooting)

date_mod
string

last modification date of the picture (in Grand Shooting)

validation_date
string

Validation date

export
string

name of the export

exportpicturestatus
string

status of export

shootingmethod
string

name of the shooting method

header Parameters
offset
number >= 0

offset for pagination

Responses

Response samples

Content type
application/json
[
  • {
    }
]

Get picture

Load a picture by its id

Authorizations:
path Parameters
picture_id
required
number

the id for the picture item

Responses

Response samples

Content type
application/json
{
  • "picture_id": 1023,
  • "bench_id": 2,
  • "bench_root_id": 1,
  • "benchsteptype": 20,
  • "ref": "FW19_ALDA_PINK",
  • "path": "f33cdd25-b8b0-48dd-abac-cf8a29529f89/JPG/FW19_ALDA_PINK-1.jpg",
  • "smalltext": "FW19_ALDA_PINK_1.jpg",
  • "picturestatus": 30,
  • "filesize": 520000,
  • "reference_id": 10,
  • "reference_ids": [
    ],
  • "parent_id": 151,
  • "child_ids": [
    ],
  • "export": "WEB",
  • "frame": {
    },
  • "icc_profile": "sRGB IEC61966-2.1",
  • "hash": "5ef7fcb04a5c2e90a0f490e92a3260c50a259a5c",
  • "shootingmethod": "Packshot"
}

Delete a picture

Delete a picture from Grand Shooting (logicaly, file is prefixed with __TRASH and invisible in Grand Shooting). You can't delete a picture in validation stage (benchsteptype 40), you have to delete it through the export process.

Authorizations:
path Parameters
picture_id
required
number

the id for the picture item

Responses

Response samples

Content type
application/json
"string"

Get specifications

Get specifications the picture should conform to

Authorizations:
path Parameters
picture_id
required
number

the picture id

Responses

Response samples

Content type
application/json
"string"

Download

Download a picture

Authorizations:
path Parameters
picture_id
required
number

the id for the picture item

Responses

Response samples

Content type
application/json
"string"

Get tags

List picture tags.

Tagging information are extracted from picture metadata.

Color label and ratings are commonly used tagging information used in photo edition software like Photoshop, Capture One and Lightroom.

Other metadata are extracted from deep leaning categorisation models

Authorizations:
path Parameters
picture_id
required
number

the id for the picture item

Responses

Response samples

Content type
application/json
{
  • "rating": 2,
  • "label": "red",
  • "tags": {
    }
}

Set tags

Modify or add tagging information to pictures.

You can override color label or rating defined in picture EXIF metadata.

Picture's file internal EXIF metadata is not modified. New tag information will be available in Grand Shooting production filters

Authorizations:
path Parameters
picture_id
required
number

the id for the picture item

Request Body schema: application/json
rating
number [ 0 .. 5 ]

rating of picture, between 0 and 5

label
string
Enum: "transparent" "white" "yellow" "orange" "red" "pink" "purple" "blue" "green"

color tag of picture

object

Meta tag of picture

Responses

Request samples

Content type
application/json
{
  • "rating": 2,
  • "label": "red",
  • "tags": {
    }
}

Response samples

Content type
application/json
{
  • "rating": 2,
  • "label": "red",
  • "tags": {
    }
}

Send picture to edit

You can edit a picture only if an edit bench exist.

Authorizations:
Request Body schema: application/json
picture_ids
required
Array of numbers (picture_ids) [ items ]

The id of pictures to edit

transfer_id
required
number

The id of FTP transfer

get_path
string

Set path to get picture from the FTP

put_path
string

Set path to put picture to FTP

provision_code
string

Set the edit code

account_id
number

Account id of picture to retouch

Responses

Request samples

Content type
application/json
{
  • "picture_ids": [
    ],
  • "transfer_id": 0,
  • "get_path": "string",
  • "put_path": "string",
  • "provision_code": "string",
  • "account_id": 0
}

Response samples

Content type
application/json
"string"

Send picture to edit

You can edit a picture only if an edit bench exist.

Authorizations:
path Parameters
picture_id
required
number

The id for the picture item

Request Body schema: application/json
transfer_id
required
number

The id of FTP transfer

get_path
string

Set path to get picture from the FTP

put_path
string

Set path to put picture to FTP

provision_code
string

Set the edit code

account_id
number

Account id of picture to retouch

Responses

Request samples

Content type
application/json
{
  • "transfer_id": 0,
  • "get_path": "string",
  • "put_path": "string",
  • "provision_code": "string",
  • "account_id": 0
}

Response samples

Content type
application/json
"string"

Get picture public url

Build a public url for the picture that won't need an auth token. The link is only available for a certain time (max 1 week). When the link is used, you can optinally trigger a picturestatus change and comment on the picture. (The trigger will be run every time the link is used).

Authorizations:
path Parameters
picture_id
required
number

the id for the picture item

Request Body schema: application/json
picturestatus
number

picturestatus to apply on picture when the link is used

comment
string

comment to add to picture when the link is used

validity
number <= 604800
Default: 3600

Validity of the link in seconds

Responses

Request samples

Content type
application/json
{
  • "picturestatus": 0,
  • "comment": "string",
  • "validity": 3600
}

Response samples

Content type
application/json
"string"

Set picturestatus

Change picture status in the production workflow.

Depending on the woflow step (benchsteptype of the picture's bench), available status for pictures are different: * Live: 5, 10, 30 * Phase 1: 30, 35 * Phase 2: 30, 35 * Valdation: 31, 40, 50, 51, 52, 55, 80

Authorizations:
path Parameters
picture_id
required
number

The id for the picture item

Request Body schema: application/json
picturestatus
required
number

The new picture status

comment
string

Add comment with the status

Responses

Request samples

Content type
application/json
{
  • "picturestatus": 0,
  • "comment": "string"
}

Response samples

Content type
application/json
"string"

Set a frame

Set a frame on the image for custom processing (only for images, not yet for videos)

Authorizations:
Request Body schema: application/json
x1
required
number

start x pixel

y1
required
number

start y pixel

x2
required
number

end x pixel

y2
required
number

end y pixel

smalltext
string

Optional name for the frame

Responses

Request samples

Content type
application/json
{
  • "x1": 500,
  • "y1": 500,
  • "x2": 1500,
  • "y2": 1000
}

Response samples

Content type
application/json
"string"

production

List productions

List all productions.

Authorizations:

Responses

Response samples

Content type
application/json
[
  • [
    ]
]

Create production

Create a production in which you can load images. A production is built on a workflow with different steps. Each step is a bench in which you can load images. If you wan't a specific workflow, you can apply a template. The default workflow is :

  • live (benchsteptype : 10)
  • post production step (benchsteptype : 20) optional
  • post production step (benchsteptype : 30) optional
  • export (benchsteptype : 40)
Authorizations:
Request Body schema: application/json
smalltext
required
string

Bench label

startdate
required
string <date>

Start date

enddate
string <date>

End date

timezone
string
Default: "Europe/Paris"

Timezone

tzoffset
number
Default: 60

Timezone offset in minutes

shooting_method_id
required
number >= 1

Shooting method ID

bench_template_id
number >= 1

Id of a template to configure bench

briefing
string

Url of a briefing giving information on production procedures

info
object (info)
Array of objects (info_model) [ items ]

Description of what that can be stored in "info" field

Responses

Request samples

Content type
application/json
{
  • "smalltext": "RTW_2019 DAY1 packshot",
  • "startdate": "2018-12-25T22:45:00",
  • "enddate": "2018-12-26T22:45:00",
  • "timezone": "Europe/Paris",
  • "tzoffset": 60,
  • "shooting_method_id": 1,
  • "bench_template_id": 1,
  • "info": {
    },
  • "info_model": [
    ]
}

Response samples

Content type
application/json
"string"

List exports

List exports availables.

Authorizations:

Responses

Response samples

Content type
application/json
[
  • {
    }
]

Create export

Create export.

Authorizations:
Request Body schema: application/json
export_id
integer >= 1
smalltext
string
object (config)
archived
boolean
format_ids
Array of integers (format_ids) [ items >= 1 ]

Responses

Request samples

Content type
application/json
{
  • "export_id": 1,
  • "smalltext": "string",
  • "config": {
    },
  • "archived": true,
  • "format_ids": [
    ]
}

Response samples

Content type
application/json
{
  • "export_id": 2,
  • "smalltext": "HD",
  • "config": {
    },
  • "archived": false,
  • "format_ids": [
    ]
}

List templates

List templates availables. They can be used during a production creation.

Authorizations:

Responses

Response samples

Content type
application/json
[
  • {
    }
]

Create template

Create template. It can be used during a production creation.

Authorizations:
Request Body schema: application/json
template_id
integer >= 1
smalltext
string
object (production)
object (live)
object (edit1)
object (edit1)
object (validation)

Responses

Request samples

Content type
application/json
{
  • "template_id": 1,
  • "smalltext": "string",
  • "production": {
    },
  • "live": {
    },
  • "edit1": {
    },
  • "edit2": {
    },
  • "validation": {
    }
}

Response samples

Content type
application/json
{
  • "template_id": 3,
  • "smalltext": "test",
  • "production": {
    },
  • "live": {
    },
  • "edit1": {
    },
  • "edit2": {
    },
  • "validation": {
    }
}

Load export

Load export.

Authorizations:
path Parameters
export_id
required
number

the export id

Responses

Response samples

Content type
application/json
{
  • "export_id": 2,
  • "smalltext": "HD",
  • "config": {
    },
  • "archived": false,
  • "format_ids": [
    ]
}

Replace export

Replace export.

Authorizations:
path Parameters
export_id
required
integer >= 2

the export id

Request Body schema: application/json
export_id
integer >= 1
smalltext
string
object (config)
archived
boolean
format_ids
Array of integers (format_ids) [ items >= 1 ]

Responses

Request samples

Content type
application/json
{
  • "export_id": 1,
  • "smalltext": "string",
  • "config": {
    },
  • "archived": true,
  • "format_ids": [
    ]
}

Response samples

Content type
application/json
{
  • "export_id": 2,
  • "smalltext": "HD",
  • "config": {
    },
  • "archived": false,
  • "format_ids": [
    ]
}

Update export

Update export.

Authorizations:
path Parameters
export_id
required
integer >= 2

the export id

Request Body schema: application/json
export_id
integer >= 1
smalltext
string
object (config)
archived
boolean
format_ids
Array of integers (format_ids) [ items >= 1 ]

Responses

Request samples

Content type
application/json
{
  • "export_id": 1,
  • "smalltext": "string",
  • "config": {
    },
  • "archived": true,
  • "format_ids": [
    ]
}

Response samples

Content type
application/json
{
  • "export_id": 2,
  • "smalltext": "HD",
  • "config": {
    },
  • "archived": false,
  • "format_ids": [
    ]
}

Archive export

Archive export.

Authorizations:
path Parameters
export_id
required
integer >= 2

the export id

Responses

Response samples

Content type
application/json
{
  • "export_id": 2,
  • "smalltext": "HD",
  • "config": {
    },
  • "archived": false,
  • "format_ids": [
    ]
}

Load template

Load template. It can be used during a production creation.

Authorizations:
path Parameters
template_id
required
number

the template id

Responses

Response samples

Content type
application/json
{
  • "template_id": 3,
  • "smalltext": "test",
  • "production": {
    },
  • "live": {
    },
  • "edit1": {
    },
  • "edit2": {
    },
  • "validation": {
    }
}

Replate template

Replate template. It can be used during a production creation.

Authorizations:
path Parameters
template_id
required
number

the template id

Request Body schema: application/json
template_id
integer >= 1
smalltext
string
object (production)
object (live)
object (edit1)
object (edit1)
object (validation)

Responses

Request samples

Content type
application/json
{
  • "template_id": 1,
  • "smalltext": "string",
  • "production": {
    },
  • "live": {
    },
  • "edit1": {
    },
  • "edit2": {
    },
  • "validation": {
    }
}

Response samples

Content type
application/json
{
  • "template_id": 3,
  • "smalltext": "test",
  • "production": {
    },
  • "live": {
    },
  • "edit1": {
    },
  • "edit2": {
    },
  • "validation": {
    }
}

Update template

Update template. It can be used during a production creation.

Authorizations:
path Parameters
bench_template_id
required
number

the template id

Request Body schema: application/json
template_id
integer >= 1
smalltext
string
object (production)
object (live)
object (edit1)
object (edit1)
object (validation)

Responses

Request samples

Content type
application/json
{
  • "template_id": 1,
  • "smalltext": "string",
  • "production": {
    },
  • "live": {
    },
  • "edit1": {
    },
  • "edit2": {
    },
  • "validation": {
    }
}

Response samples

Content type
application/json
{
  • "template_id": 3,
  • "smalltext": "test",
  • "production": {
    },
  • "live": {
    },
  • "edit1": {
    },
  • "edit2": {
    },
  • "validation": {
    }
}

Delete template

Delete template.

Authorizations:
path Parameters
bench_template_id
required
number

the template id

Responses

Response samples

Content type
application/json
"string"

Get benches

List benches in a production.

Authorizations:
path Parameters
bench_root_id
required
number

the production id

Responses

Response samples

Content type
application/json
[
  • {
    }
]

List references

List references that should be shot during production.

Authorizations:

Responses

Response samples

Content type
application/json
[
  • {
    }
]

Add references

Define wich references should be shot during a production.

Authorizations:
Request Body schema: application/json
Array
ref
string

Responses

Request samples

Content type
application/json
[
  • {
    }
]

Response samples

Content type
application/json
"string"

Get bench

Load a bench by its id

Authorizations:
path Parameters
bench_id
required
number

the bench id

bench_root_id
required
number

the production id

Responses

Response samples

Content type
application/json
{
  • "account_id": 1,
  • "bench_id": 3,
  • "parent_id": 2,
  • "root_id": 1,
  • "ext_lib_id": "1",
  • "smalltext": "RTW_2019 DAY1 packshot",
  • "startdate": "2018-12-25T22:45:00",
  • "enddate": "2018-12-26T22:45:00",
  • "timezone": "Europe/Paris",
  • "tzoffset": 60,
  • "shooting_method_id": 1,
  • "benchsteptype": 40,
  • "benchaccess": 40,
  • "info": {
    },
  • "info_model": [
    ],
  • "step_label": "Validation"
}

Trigger export

Start an export, i.e. process automatic renaming and modifications on pictures to add them to validation step.

Authorizations:
path Parameters
bench_root_id
required
number

the production id

Responses

Response samples

Content type
application/json
"string"

Upload pictures on a bench

Return a status code

Authorizations:
path Parameters
bench_root_id
required
number

the production id

bench_id
required
number

the bench id

Request Body schema: multipart/form-data
file
required
string <binary>

picture file

wait
boolean
Default: true

wait end of upload to return

path
string
Default: "/"

path to upload picture

transfer_id
number

id of a transfer the files uploaded are linked to. Only for plugins purpose

Responses

Response samples

Content type
application/json
"string"

Upload pictures on a bench by providing urls instead of files

Return a status code

Authorizations:
path Parameters
bench_root_id
required
number

the production id

bench_id
required
number

the bench id

Request Body schema: application/json
wait
boolean
Default: true

wait end of upload to return

path
string
Default: "/"

path to upload picture

Array of objects (urls) [ items ]

list of urls

allowed_type
string
Default: "images and videos"
Enum: "all" "images" "images and videos"

types of files that are allowed to be uploaded

transfer_id
number

id of a transfer the files uploaded are linked to. Only for plugins purpose

Responses

Request samples

Content type
application/json
{
  • "wait": true,
  • "path": "/",
  • "urls": [
    ],
  • "allowed_type": "all",
  • "transfer_id": 0
}

Response samples

Content type
application/json
[
  • {
    }
]

Update production

Update a production, basicaly to modify production's name and dates.

Authorizations:
path Parameters
bench_root_id
required
number

the production id

Request Body schema: application/json
smalltext
string

Bench label

startdate
string <date>

Start date

enddate
string <date>

End date

timezone
string
Default: "Europe/Paris"

Timezone

tzoffset
number
Default: 60

Timezone offset in minutes

shooting_method_id
number >= 1

Shooting method ID

bench_template_id
number >= 1

Id of a template to configure bench

info
object (info)
Array of objects (info_model) [ items ]

Description of what that can be stored in "info" field

Responses

Request samples

Content type
application/json
{
  • "smalltext": "RTW_2019 DAY1 packshot",
  • "startdate": "2018-12-25T22:45:00",
  • "enddate": "2018-12-26T22:45:00",
  • "timezone": "Europe/Paris",
  • "tzoffset": 60,
  • "shooting_method_id": 1,
  • "bench_template_id": 1,
  • "info": {
    },
  • "info_model": [
    ]
}

Response samples

Content type
application/json
{
  • "account_id": 1,
  • "bench_id": 3,
  • "parent_id": 2,
  • "root_id": 1,
  • "ext_lib_id": "1",
  • "smalltext": "RTW_2019 DAY1 packshot",
  • "startdate": "2018-12-25T22:45:00",
  • "enddate": "2018-12-26T22:45:00",
  • "timezone": "Europe/Paris",
  • "tzoffset": 60,
  • "shooting_method_id": 1,
  • "benchsteptype": 40,
  • "benchaccess": 40,
  • "info": {
    },
  • "info_model": [
    ],
  • "step_label": "Validation"
}

reference

List references

Return an array of references with a pagination of 100. You can set the offset of pagination with the header 'offset'. Response headers: 'X-Total-Count': Total number of items 'X-Offset': Offset of the result 'X-Count': Size of the result

Authorizations:
query Parameters
reference_id
string

id of the reference

ref
string

reference label identifier

ean
string

main ean

eans
string

alternatives ean

univers
string

univers, level 1 in catalog hierarchy

gamme
string

gamme, level 2 in catalog hierarchy

family
string

family, level 3 in catalog hierarchy

sku
string

sku

brand
string

brand

smalltext
string

reference label

product_ref
string

product identifier

product_smalltext
string

product label

gender
string

gender

gender_smalltext
string

gender

color
string

color

hexa_color
string

Code couleur RGB en hexa décimal

size
string

size

collection
string

collection

comment
string

comment

tags
string

tags

extra
string

Extra data

shotlist_id
string

id of a shotlist to add reference to

shotlist
string

name of a shotlist to add reference to (shotlist will be created if it doesnt exists)

online
string

online date

Responses

Response samples

Content type
application/json
[
  • {
    }
]

Create / update a reference.

If a reference already exists with the same "ref", this reference will be updated. Otherwise, a new reference is created. Return the corresponding reference item with the generated id

Authorizations:
Request Body schema: application/json
reference_id
number >= 1

id of the reference

ref
string

reference label identifier

ean
string

main ean

eans
Array of strings (eans)

alternatives ean

univers
string

univers, level 1 in catalog hierarchy

gamme
string

gamme, level 2 in catalog hierarchy

family
string

family, level 3 in catalog hierarchy

sku
string

sku

brand
string

brand

smalltext
string

reference label

product_ref
string

product identifier

product_smalltext
string

product label

gender
string

gender

gender_smalltext
string

gender

color
string

color

hexa_color
string

Code couleur RGB en hexa décimal

size
string

size

collection
string

collection

comment
string

comment

tags
Array of strings (tags)

tags

extra
object (info)
shotlist_id
number >= 1

id of a shotlist to add reference to

shotlist
string

name of a shotlist to add reference to (shotlist will be created if it doesnt exists)

online
string

online date

Responses

Request samples

Content type
application/json
{
  • "reference_id": 12,
  • "ref": "FW19_ALDA_PINK",
  • "ean": "2309309834098",
  • "eans": [
    ],
  • "univers": "RTW",
  • "gamme": "Accessories",
  • "family": "Handbags",
  • "sku": "EPOIAPOIJKLH109384",
  • "brand": "BATCHEMON",
  • "smalltext": "Pink leather handbag Alda",
  • "product_ref": "FW19_ALDA",
  • "product_smalltext": "Leather handbag Alda",
  • "gender": "Woman",
  • "color": "PINK",
  • "hexa_color": "#FFC0CB",
  • "size": "L",
  • "collection": "FW19",
  • "comment": "Closeup on zip",
  • "tags": [
    ],
  • "online": "20/12/2019",
  • "extra": {
    }
}

Response samples

Content type
application/json
{
  • "reference_id": 12,
  • "ref": "FW19_ALDA_PINK",
  • "ean": "2309309834098",
  • "eans": [
    ],
  • "univers": "RTW",
  • "gamme": "Accessories",
  • "family": "Handbags",
  • "sku": "EPOIAPOIJKLH109384",
  • "brand": "BATCHEMON",
  • "smalltext": "Pink leather handbag Alda",
  • "product_ref": "FW19_ALDA",
  • "product_smalltext": "Leather handbag Alda",
  • "gender": "Woman",
  • "color": "PINK",
  • "hexa_color": "#FFC0CB",
  • "size": "L",
  • "collection": "FW19",
  • "comment": "Closeup on zip",
  • "tags": [
    ],
  • "online": "20/12/2019",
  • "extra": {
    }
}

Get reference

Return a reference item

Authorizations:
path Parameters
id
required
number

the id for the reference item

Responses

Response samples

Content type
application/json
{
  • "reference_id": 12,
  • "ref": "FW19_ALDA_PINK",
  • "ean": "2309309834098",
  • "eans": [
    ],
  • "univers": "RTW",
  • "gamme": "Accessories",
  • "family": "Handbags",
  • "sku": "EPOIAPOIJKLH109384",
  • "brand": "BATCHEMON",
  • "smalltext": "Pink leather handbag Alda",
  • "product_ref": "FW19_ALDA",
  • "product_smalltext": "Leather handbag Alda",
  • "gender": "Woman",
  • "color": "PINK",
  • "hexa_color": "#FFC0CB",
  • "size": "L",
  • "collection": "FW19",
  • "comment": "Closeup on zip",
  • "tags": [
    ],
  • "online": "20/12/2019",
  • "extra": {
    }
}

Create / update multiple references

Returns the list of corresponding reference items

Authorizations:
Request Body schema: application/json
Array
reference_id
number >= 1

id of the reference

ref
string

reference label identifier

ean
string

main ean

eans
Array of strings (eans)

alternatives ean

univers
string

univers, level 1 in catalog hierarchy

gamme
string

gamme, level 2 in catalog hierarchy

family
string

family, level 3 in catalog hierarchy

sku
string

sku

brand
string

brand

smalltext
string

reference label

product_ref
string

product identifier

product_smalltext
string

product label

gender
string

gender

gender_smalltext
string

gender

color
string

color

hexa_color
string

Code couleur RGB en hexa décimal

size
string

size

collection
string

collection

comment
string

comment

tags
Array of strings (tags)

tags

extra
object (info)
shotlist_id
number >= 1

id of a shotlist to add reference to

shotlist
string

name of a shotlist to add reference to (shotlist will be created if it doesnt exists)

online
string

online date

Responses

Request samples

Content type
application/json
[
  • {
    }
]

Response samples

Content type
application/json
[
  • {
    }
]

Add / Modify column of extra field

Returns columns

Authorizations:
Request Body schema: application/json
Array
key
required
string

used to identify column in import and export files

label
required
string

used for display in screens

type
required
string

the type of the column

Responses

Request samples

Content type
application/json
[
  • {
    }
]

Response samples

Content type
application/json
"string"

shootingmethod

List shooting methods

List all shooting methods

Authorizations:

Responses

Response samples

Content type
application/json
[
  • {
    }
]

Set shooting methos

Set shooting method

Authorizations:
Request Body schema: application/json
shootingmethod
string

Name of shooting method

Responses

Request samples

Content type
application/json
{
  • "shootingmethod": "string"
}

Response samples

Content type
application/json
[
  • {
    }
]

stock

Stock positions

List all stock information

Authorizations:

Responses

Response samples

Content type
application/json
"string"

add to stock

Add a reference in stock

Authorizations:
Request Body schema: application/json
batch_id
required
number

batch id

reference_id
required
number

reference id

batchrefstatus
required
number

Status of the stock object

Responses

Request samples

Content type
application/json
{
  • "batch_id": 0,
  • "reference_id": 0,
  • "batchrefstatus": 0
}

Response samples

Content type
application/json
"string"

zones

List zones

Authorizations:

Responses

Response samples

Content type
application/json
[
  • {
    }
]

Create a batch

Create a batch

Authorizations:
Request Body schema: application/json
smalltext
string

Name of the batch

batch_type
number

Type of the batch

batch_zone_id
number

Zone where the batch is located

Responses

Request samples

Content type
application/json
{
  • "smalltext": "string",
  • "batch_type": 0,
  • "batch_zone_id": 0
}

Response samples

Content type
application/json
"string"

webhook

List webhooks

Return webhook

Authorizations:

Responses

Response samples

Content type
application/json
[]

Create a webhook

Return webhook

Authorizations:
Request Body schema: application/json
address
required
string

URI where the webhook subscription should send the POST request when the event occurs.

topic
required
string
Enum: "pictures/create" "pictures/update"

Event that triggers the webhook.

Responses

Request samples

Content type
application/json
{}

Response samples

Content type
application/json
{}

Update a webhook

Return webhook

Authorizations:
Request Body schema: application/json
address
required
string

URI where the webhook subscription should send the POST request when the event occurs.

topic
required
string
Enum: "pictures/create" "pictures/update"

Event that triggers the webhook.

Responses

Request samples

Content type
application/json
{}

Response samples

Content type
application/json
{}

Delete a webhook

Delete a webhook.

Authorizations:

Responses

Response samples

Content type
application/json
"string"

specification

List categories

List specification categories

Authorizations:

Responses

Response samples

Content type
application/json
"string"

List formats

List specification available formats

Authorizations:

Responses

Response samples

Content type
application/json
"string"

Create format

Create format.

Authorizations:
Request Body schema: application/json
smalltext
string

Name of format

format_id
number

ID of format

background_color
string

Color or hexa

description
string

Desciption of format

file_format
string
Enum: "JPG" "PNG" {"value":{"allowUnknown":true}}
sample_filename
string
height
number

px

width
number

px

icc_profile
string
Enum: "sRGB IEC61966-2.1" "Adobe RGB (1998)" {"value":{"allowUnknown":true}}
max_file_size
number

kb

position
string
Default: "Center"
Enum: "NorthWest" "North" "NorthEast" "West" "Center" "East" "SouthWest" "South" "SouthEast"

Position with border

resolution
number

dpi

object (border_strategy)

Responses

Request samples

Content type
application/json
{
  • "smalltext": "string",
  • "format_id": 0,
  • "background_color": "string",
  • "description": "string",
  • "file_format": "JPG",
  • "sample_filename": "string",
  • "height": 0,
  • "width": 0,
  • "icc_profile": "sRGB IEC61966-2.1",
  • "max_file_size": 0,
  • "position": "NorthWest",
  • "resolution": 0,
  • "border_strategy": {
    }
}

Response samples

Content type
application/json
"string"

Load format

Load specification available format

Authorizations:
path Parameters
format_id
required
number

ID of format

Responses

Response samples

Content type
application/json
"string"

Replace format

Replace format.

Authorizations:
path Parameters
format_id
required
number

ID of format

Request Body schema: application/json
smalltext
string

Name of format

format_id
number

ID of format

background_color
string

Color or hexa

description
string

Desciption of format

file_format
string
Enum: "JPG" "PNG" {"value":{"allowUnknown":true}}
sample_filename
string
height
number

px

width
number

px

icc_profile
string
Enum: "sRGB IEC61966-2.1" "Adobe RGB (1998)" {"value":{"allowUnknown":true}}
max_file_size
number

kb

position
string
Default: "Center"
Enum: "NorthWest" "North" "NorthEast" "West" "Center" "East" "SouthWest" "South" "SouthEast"

Position with border

resolution
number

dpi

object (border_strategy)

Responses

Request samples

Content type
application/json
{
  • "smalltext": "string",
  • "format_id": 0,
  • "background_color": "string",
  • "description": "string",
  • "file_format": "JPG",
  • "sample_filename": "string",
  • "height": 0,
  • "width": 0,
  • "icc_profile": "sRGB IEC61966-2.1",
  • "max_file_size": 0,
  • "position": "NorthWest",
  • "resolution": 0,
  • "border_strategy": {
    }
}

Response samples

Content type
application/json
"string"

Update format

Update formats.

Authorizations:
path Parameters
format_id
required
number

ID of format

Request Body schema: application/json
smalltext
string

Name of format

format_id
number

ID of format

background_color
string

Color or hexa

description
string

Desciption of format

file_format
string
Enum: "JPG" "PNG" {"value":{"allowUnknown":true}}
sample_filename
string
height
number

px

width
number

px

icc_profile
string
Enum: "sRGB IEC61966-2.1" "Adobe RGB (1998)" {"value":{"allowUnknown":true}}
max_file_size
number

kb

position
string
Default: "Center"
Enum: "NorthWest" "North" "NorthEast" "West" "Center" "East" "SouthWest" "South" "SouthEast"

Position with border

resolution
number

dpi

object (border_strategy)

Responses

Request samples

Content type
application/json
{
  • "smalltext": "string",
  • "format_id": 0,
  • "background_color": "string",
  • "description": "string",
  • "file_format": "JPG",
  • "sample_filename": "string",
  • "height": 0,
  • "width": 0,
  • "icc_profile": "sRGB IEC61966-2.1",
  • "max_file_size": 0,
  • "position": "NorthWest",
  • "resolution": 0,
  • "border_strategy": {
    }
}

Response samples

Content type
application/json
"string"

Delete format

Delete format.

Authorizations:
path Parameters
format_id
required
number

ID of format

Request Body schema: application/json
smalltext
string

Name of format

format_id
number

ID of format

background_color
string

Color or hexa

description
string

Desciption of format

file_format
string
Enum: "JPG" "PNG" {"value":{"allowUnknown":true}}
sample_filename
string
height
number

px

width
number

px

icc_profile
string
Enum: "sRGB IEC61966-2.1" "Adobe RGB (1998)" {"value":{"allowUnknown":true}}
max_file_size
number

kb

position
string
Default: "Center"
Enum: "NorthWest" "North" "NorthEast" "West" "Center" "East" "SouthWest" "South" "SouthEast"

Position with border

resolution
number

dpi

object (border_strategy)

Responses

Request samples

Content type
application/json
{
  • "smalltext": "string",
  • "format_id": 0,
  • "background_color": "string",
  • "description": "string",
  • "file_format": "JPG",
  • "sample_filename": "string",
  • "height": 0,
  • "width": 0,
  • "icc_profile": "sRGB IEC61966-2.1",
  • "max_file_size": 0,
  • "position": "NorthWest",
  • "resolution": 0,
  • "border_strategy": {
    }
}

Response samples

Content type
application/json
"string"

Get expected specification for reference

Get expected specification for reference

Authorizations:
path Parameters
reference_id
required
number

Responses

Response samples

Content type
application/json
"string"

transfer

Load transfer

Load transfer informations : files and share information

Authorizations:

Responses

Response samples

Content type
application/json
{
  • "account_id": 0,
  • "transfer_id": "string",
  • "email": "string",
  • "recipients": [
    ],
  • "repo_id": "string",
  • "files": [
    ],
  • "transferstatus": 10
}

Sends files to sourcing

Sends transfer content to a sourcing project sourcing

Authorizations:
path Parameters
transfer_id
required
string

uuid identifying transfer

process_id
required
string

id of the process to check

Responses

Response samples

Content type
application/json
{
  • "status": "string",
  • "desc": "string"
}

Create a transfer

Create a new transfer container

Authorizations:

Responses

Response samples

Content type
application/json
{
  • "account_id": 0,
  • "transfer_id": "string",
  • "email": "string",
  • "recipients": [
    ],
  • "repo_id": "string",
  • "files": [
    ],
  • "transferstatus": 10
}

Sends files to sourcing

Sends transfer content to a sourcing project sourcing

Authorizations:
path Parameters
transfer_id
required
string

uuid identifying transfer

Request Body schema: application/json
files
Array of strings (Model26)

list of files to send to sourcing, if not specified, all files will be sent

import_id
number

Sourcing import id

append
boolean

Add images to project or delete/insert images to projet (default true)

Responses

Request samples

Content type
application/json
{
  • "files": [
    ],
  • "import_id": 0,
  • "append": true
}

Response samples

Content type
application/json
{
  • "process_id": "string"
}

Share a transfer

Sends an email to transfer recipients

Authorizations:
Request Body schema: application/json
email
string

email of the transfer creator (if different from the autenticated user)

recipients
Array of strings (recipients)

emails of transfer recipients

verification_code
string

validation code sent to the transfer creator email (only necessary when providing an email transfer creator)

Responses

Request samples

Content type
application/json
{
  • "email": "string",
  • "recipients": [
    ],
  • "verification_code": "string"
}

Response samples

Content type
application/json
{
  • "account_id": 0,
  • "transfer_id": "string",
  • "email": "string",
  • "recipients": [
    ],
  • "repo_id": "string",
  • "files": [
    ],
  • "transferstatus": 10
}