OpenApi

You can find spec for the Events service in the html document.

openapi: 3.0.0
info:
  version: 'v.4.8.4'
  title: 'Luna events API'
  description: |
    VisionLabs Luna Events API.

    Introduction

    This service is intended for searching events according to the specified filters and getting some statistics parameters of events. You can receive the following parameters:

    1) event count,
    2) average, max, min value numeric parameters.

    Events can be grouped by the creation time. Grouping is possible in two ways: grouping by time intervals and the frequency grouping (by day of month).

    The service store some fields in compressed state for query optimization and database size decrease.

      Mapping ethnicities to ID:

      | Group name | Group ID |
      | ---------- | -------- |
      | african_american  | 1 |
      | indian            | 2 |
      | asian             | 3 |
      | caucasian         | 4 |

      Mapping emotions to ID:

      | Group name | Group ID |
      | ---------- | -------- |
      | anger             | 1 |
      | disgust           | 2 |
      | fear              | 3 |
      | happiness         | 4 |
      | neutral           | 5 |
      | sadness           | 6 |
      | surprise          | 7 |

      Mapping masks to ID:

      | Group name | Group ID |
      | ---------- | -------- |
      | missing           | 1 |
      | medical_mask      | 2 |
      | occluded          | 3 |

      Mapping liveness to ID:

      | liveness | value |
      |--------------|---|
      | spoof        | 0 |
      | real         | 1 |
      | unknown      | 2 |


    OpenAPI specification is the only valid document providing up-to-date information about the service API.

    The specification can be used:

    - By documentation generation tools to visualize the API.
    - By code generation tools.

    All the documents and code generated using this specification can include inaccuracies and should be carefully checked.

    OpenAPI specification can be received using the "/docs/spec" resource. The "Accept" header should be set to "application/x-yaml".

components:
  headers:
    application_json:
      schema:
        type: string
        enum:
        - application/json
      required: true
      description: Content type is application/json.

    application_json_or_xbinary:
      schema:
        type: string
        enum:
          - application/json
          - application/x-sdk-descriptor
      required: true
      description: Content type is application/json or application/x-sdk-descriptor.

    text_plain:
      schema:
        type: string
        enum:
        - text/plain
      required: true
      description: Content type is text/plain.

    image_jpeg:
      schema:
        type: string
        enum:
        - image/jpeg
      description: Content type is image/jpeg.
      required: true

    luna_request_id:
      schema:
        type: string
        format: timestamp,uuid
        example: 1536751345,8b8b5937-2e9c-4e8b-a7a7-5caf86621b5a
        pattern: ^[0-9]{10},[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$
      description: Request ID. Helps to uniquely identify messages that correspond to particular requests, in system logs.
      required: true

    application_zip:
      schema:
        type: string
        enum:
        - application/zip
      required: true
      description: Content type is application/zip.

    content_disposition:
      schema:
        type: string
      example: 'attachment; filename=task_146.zip'
      required: true
      description: Content disposition with filename.

    docs_content_type:
      schema:
        type: string
        enum:
          - application/x-yaml
          - text/html
      required: true
      description: Type of receiving data.

    text_html:
      schema:
        type: string
        enum:
          - text/html
      required: true
      description: Content type is text/html.

    config_accept_content_type:
      schema:
        type: string
        enum:
          - application/json
          - text/plain
      required: false
      description: The content type of the response body.
  parameters:
    page:
      in: query
      name: page
      schema:
        type: integer
        minimum: 1
        default: 1
      description: Page number.

    accept:
      in: header
      schema:
        type: string
        example: "application/x-sdk-descriptor"
      description: Content type which is acceptable for the response. If 'application/x-sdk-descriptor' is specified, the binary descriptor will be returned in the response body, otherwise 'application/json' content type will be applied.
      required: false
      name: Accept

    luna_request_id:
      in: header
      schema:
        type: string
        format: timestamp,uuid
        example: "1536751345,8b8b5937-2e9c-4e8b-a7a7-5caf86621b5a"
        pattern: ^[0-9]{10},[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$
      description: |
        External request ID. Helps to uniquely identify messages that correspond to particular requests, in system logs.
        If it was not set, system will set it in default format ("timestamp,UUID"). It will be returned with response.
      name: Luna-Request-Id

    wait_events_saving:
      in: query
      name: wait_events_saving
      schema:
        $ref: '#/components/schemas/int01'
      description: |
        Whether to wait for events saving.

        If "0" is specified, the 202 status code will be expected in response to a successful request. This status code is returned after events are validated and added to the buffer. The system does not wait until the events are saved to the database. The events will be stored in the database after the response is sent.

        If "1" is specified, the 204 status code will be expected in response to a successful request. This status code is returned only after events are stored in the database.

    page_size:
      in: query
      name: page_size
      schema:
        type: integer
        minimum: 1
        maximum: 1000
        default: 10
      description: Number of items on page.

    limit:
      in: query
      name: limit
      schema:
        type: integer
        minimum: 1
        maximum: 1000000
        default: 5
      description: Event limit in a match response.

    threshold:
      in: query
      name: threshold
      schema:
        type: number
        minimum: 0.0
        maximum: 1.0
        default: 0.0
      description: Event similarity threshold in a match response - events with a similarity lower than this parameter will not be returned.

    search_order:
      in: query
      name: order
      schema:
        type: string
        enum: ["asc", "desc"]
      description: |
        The sort order.

        By default, the results will be sorted by event creation time.
        If "desc" is set, the newest events will be shown first. If "asc" is set, the oldest events will be shown first.

        But if some event ID range filters specified (`event_id__gte` or `event_id__lt`), the results will be sorted by event ID.

    match_order:
      in: query
      name: order
      schema:
        type: string
        enum: [ "asc", "desc" ]
      description: |
        The sort order.
        If "desc" is set, the most similar events will be shown first. If "asc" is set, the least similar events will be shown first.

    gender:
      in: query
      name: gender
      schema:
        oneOf:
          - type: integer
            enum: [0, 1]
          - $ref: '#/components/schemas/null_filter'
      description: Gender. 1 - male, 0 - female, "null" - null value .
      example: 1

    emotions:
      in: query
      name: emotions
      schema:
        type: string
        format: list of integer and null (1, 2, 3, 4, 5, 6, 7, null)
      description: |
        Comma-separated list of predominant emotions or null. Each event from result will contain one of the given emotions.

        | emotions    | value |
        |-----------------|---|
        | anger           | 1 |
        | disgust         | 2 |
        | fear            | 3 |
        | happiness       | 4 |
        | neutral         | 5 |
        | sadness         | 6 |
        | surprise        | 7 |
      example: "1,2,3,null"

    masks:
      in: query
      name: masks
      schema:
        type: string
        format: list of integer and null (1, 2, 3, null)
      description: |
        Comma-separated list of predominant masks or null. Each event from result will contain one of the given mask state.

        | mask        | value |
        |-----------------|---|
        | missing         | 1 |
        | medical_mask    | 2 |
        | occluded        | 3 |
      example: "1,2,3,null"

    ethnic_groups:
      in: query
      name: ethnic_groups
      schema:
        type: string
        format: list of integer and null (1, 2, 3, 4, null)
      description: |
        Comma-separated list of dominant ethnic group or null. Each event from result will contain one of the given ethnic groups.

        | ethnicity    | value |
        |------------------|---|
        | African american | 1 |
        | Indian           | 2 |
        | Asian            | 3 |
        | Caucasian        | 4 |

      example: "1,2,null"

    liveness:
      in: query
      name: liveness
      schema:
        type: string
        format: list of integer and null (0, 1 ,2, null)
      description: |
        Comma-separated list of dominant liveness or null. Each event from result will contain one of the given liveness.

        | liveness | value |
        |--------------|---|
        | spoof        | 0 |
        | real         | 1 |
        | unknown      | 2 |

      example: "1,2,null"

    tags:
      in: query
      name: tags
      schema:
        type: array
        items:
          $ref: '#/components/schemas/tag'
        minItems: 0
      explode: false
      description: Comma-separated list of tags. Each event from result will contain all of the given tags.
      example:
        - tag_1
        - tag_2

    age__lt:
      in: query
      name: age__lt
      schema:
        type: integer
        minimum: 0
        maximum: 100
      description: Age upper excluded bound.
      example: 50

    age__gte:
      in: query
      name: age__gte
      schema:
        type: integer
        minimum: 0
        maximum: 100
      description: Age lower included bound.
      example: 50

    account_id:
      in: query
      name: account_id
      schema:
        $ref: '#/components/schemas/uuid'
      description: Account ID.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb'

    face_ids:
      in: query
      name: face_ids
      schema:
        type: string
        format: list of uuid
      description: List of comma-separated face IDs.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb,346a5645-ec89-4806-820a-dbcb6e0dc38'

    event_ids:
      in: query
      name: event_ids
      schema:
        type: string
        format: list of uuid.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb,346a5645-ec89-4806-820a-dbcb6e0dc38'
      description: List of comma-separated event IDs.

    event_id__gte:
      in: query
      name: event_id__gte
      schema:
        type: string
        format: uuid.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb'
      description: Lower including event ID boundary.

    event_id__gte_sorting:
      in: query
      name: event_id__gte
      schema:
        type: string
        format: uuid.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb'
      description: Lower including event ID boundary. Events in response will be sorted by their ids. If neither *event_id__lt* or *event_id__gte* is specified, the faces will be sorted by creation time.

    event_id__lt:
      in: query
      name: event_id__lt
      schema:
        type: string
        format: uuid.
      example: '346a5645-ec89-4806-820a-dbcb6e0dc38'
      description: Upper excluding event ID boundary.

    event_id__lt_sorting:
      in: query
      name: event_id__lt
      schema:
        type: string
        format: uuid.
      example: '346a5645-ec89-4806-820a-dbcb6e0dc38'
      description: Upper excluding event ID boundary. Events in response will be sorted by their ids. If neither *event_id__lt* or *event_id__gte* is specified, the faces will be sorted by creation time.

    handler_id:
      in: query
      name: handler_id
      schema:
        type: string
        format: uuid.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb'
      description: Handler ID.

    handler_ids:
      in: query
      name: handler_ids
      schema:
        type: string
        format: list of uuid.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb,346a5645-ec89-4806-820a-dbcb6e0dc38'
      description: List of comma-separated handler IDs.

    external_id:
      in: query
      name: external_id
      schema:
        type: string
        maxLength: 36
      description: External ID.

    external_ids:
      in: query
      name: external_ids
      schema:
        type: string
        format: list of strings.
      example: '8950722f-3fd4-4223-b48f-03f95f0e8dfb,346a5645-ec89-4806-820a-dbcb6e0dc38'
      description: List of comma-separated external IDs.

    user_data:
      in: query
      name: user_data
      schema:
        type: string
      description: Find all objects with user_data that is similar to this parameter.
      example: "user_data"

    sources:
      in: query
      name: sources
      schema:
        type: string
      description: Comma-separated list of sources or null. Each event from result will contain one of the given sources.
      example: "cam1,cam2,null"

    cities:
      in: query
      name: cities
      schema:
        type: string
      description: Comma-separated list of cities or null. Each event from result will contain one of the given cities in location.
      example: "moscow,New-York,null"

    areas:
      in: query
      name: areas
      schema:
        type: string
      description: Comma-separated list of areas or null. Each event from result will contain one of the given areas in location.
      example: "CAO,central park,null"

    districts:
      in: query
      name: districts
      schema:
        type: string
      description: Comma-separated list of districts or null. Each event from result will contain one of the given districts in location.
      example: "mitino,central park,null"

    streets:
      in: query
      name: streets
      schema:
        type: string
      description: |
        Comma-separated list of streets or null. Each event from result will contain one of the given streets  in location.
      example: "arbat,schepkina,null"

    house_numbers:
      in: query
      name: house_numbers
      schema:
        type: string
      description: |
        Comma-separated list of house numbers or null. Each event from result will contain one of the given house numbers
        in location.
      example: "1,1/2str3,null"

    origin_longitude:
      in: query
      name: origin_longitude
      schema:
        oneOf:
          - $ref: '#/components/schemas/longitude'
          - $ref: '#/components/schemas/null_filter'
      description: |
        Longitude origin in degrees, a part of composite geo position filter or null for undefined geo position.
                Geo position filter is a bounding box specified by coordinates of its center (origin) and some delta.
                Geo position filter is considered as properly specified if both *origin_longitude* and
                *origin_latitude* are set, and considered as properly empty if neither of *origin_longitude*,
                *origin_latitude*, *longitude_delta*, *latitude_delta* is set.
                Null filter applied only if *origin_longitude* or *origin_latitude* is set to 'null', and
                *longitude_delta* and *latitude_delta* is not set.
      example: "36.616"

    origin_latitude:
      in: query
      name: origin_latitude
      schema:
        oneOf:
          - $ref: '#/components/schemas/latitude'
          - $ref: '#/components/schemas/null_filter'
      description: |
        Latitude origin in degrees, a part of composite geo position filter or null for undefined geo position.
                Geo position filter is a bounding box specified by coordinates of its center (origin) and some delta.
                Geo position filter is considered as properly specified if both *origin_longitude* and
                *origin_latitude* are set, and considered as properly empty if neither of *origin_longitude*,
                *origin_latitude*, *longitude_delta*, *latitude_delta* is set.
                Null filter applied only if *origin_longitude* or *origin_latitude* is set to 'null', and
                *longitude_delta* and *latitude_delta* is not set.
      example: "55.752"

    longitude_delta:
      in: query
      name: longitude_delta
      schema:
        type: number
        minimum: 0
        maximum: 90
        default: 0.01
      description: |
        Longitude delta in degrees, a part of composite geo position filter.
                Geo position filter is a bounding box specified by coordinates of its center (origin) and some delta.
                Geo position filter is considered as properly specified if both *origin_longitude* and
                *origin_latitude* are set, and considered as properly empty if neither of *origin_longitude*,
                *origin_latitude*, *longitude_delta*, *latitude_delta* is set. If both *origin_longitude* and
                *origin_latitude* are set and *longitude_delta* is not set - default is applied.
                WARNING: boxes with a vertex or border on the International Date Line (IDL) or the North or South pole
                are not fully supported due to features of database spatial index - filter result may be unexpected.
                Box edges more than 180 degrees long are not allowed. Boundaries of valid range are **exclusive**.
                NOTE: highly recommended for citywide use only.
      example: "0.01"

    latitude_delta:
      in: query
      name: latitude_delta
      schema:
        type: number
        minimum: 0
        maximum: 90
        default: 0.01
      description: |
        Latitude delta in degrees, a part of composite geo position filter.
                Geo position filter is a bounding box specified by coordinates of its center (origin) and some delta.
                Geo position filter is considered as properly specified if both *origin_longitude* and
                *origin_latitude* are set, and considered as properly empty if neither of *origin_longitude*,
                *origin_latitude*, *longitude_delta*, *latitude_delta* is set. If both *origin_longitude* and
                *origin_latitude* are set and *latitude_delta* is not set - default is applied.
                WARNING: boxes with a vertex or border on the International Date Line (IDL) or the North or South pole
                are not fully supported due to features of database spatial index - filter result may be unexpected.
                Box edges more than 180 degrees long are not allowed. Boundaries of valid range are **exclusive**.
                NOTE: highly recommended for citywide use only.
      example: "0.01"

    top_matching_candidates_label:
      in: query
      name: top_matching_candidates_label
      schema:
        type: string
      description: Top matching candidates label. Each event from result will contain the given label.
      example: "matching_label"

    top_similar_object_ids:
      in: query
      name: top_similar_object_ids
      schema:
        type: array
        items:
          $ref: '#/components/schemas/uuid'
      description: Comma-separated list of top similar object IDs. Each event from result will contain one of the given top similar object IDs.

    top_similar_external_ids:
      in: query
      name: top_similar_external_ids
      schema:
        type: array
        items:
          $ref: '#/components/schemas/external_id'
      description: Comma-separated list of top similar external IDs. Each event from result will contain one of the given top similar external IDs.

    top_similar_object_similarity__gte:
      in: query
      name: top_similar_object_similarity__gte
      schema:
        type: number
      description: Top similar object similarity lower included bound.
      example: 0.5

    top_similar_object_similarity__lt:
      in: query
      name: top_similar_object_similarity__lt
      schema:
        type: number
      description: Top similar object similarity upper excluded bound.
      example: 0.5

    get_event_target:
      in: query
      name: target
      schema:
        type: string
        enum: ["account_id", "create_time", "end_time", "event_id", "handler_id", "external_id", "source", "top_match",
               "match_result", "face_detections", "face_id", "attach_result", "gender", "age", "emotion",
               "ethnic_group", "liveness", "body_detections", "body_basic_attributes", "upper_body", "lower_body", "accessories",
               "tags", "user_data", "location", "mask", "track_id", "meta",
        ]
      description: |
        Comma-separated list of event fields.
        If set, each event from result will contain only specified fields, otherwise, events with all fields will be returned.
      example: "extract_result"

    post_event_match_target:
      in: query
      name: target
      schema:
        type: string
        enum: ["account_id", "create_time", "end_time", "event_id", "handler_id", "external_id", "source", "top_match",
               "match_result", "face_detections", "face_id", "attach_result", "gender", "age", "emotion",
               "ethnic_group", "liveness", "body_detections", "body_basic_attributes", "upper_body", "lower_body", "accessories",
               "tags", "user_data", "location", "mask", "track_id",
               "similarity", "meta",
        ]
      description: |
        Comma-separated list of event fields.
        If set, each event from result will contain only specified fields, otherwise, events with the "event_id" and "similarity" fields will be returned.
      example: "extract_result,similarity"

    list_id:
      in: query
      name: list_id
      schema:
        $ref: '#/components/schemas/uuid'
      description: ID of a list that contains faces.

    applicationJsonContent:
      in: header
      name: Content-Type
      schema:
        type: string
        enum:
        - application/json
      description: Content type is application/json.

    insert_time__lt:
      in: query
      name: insert_time__lt
      schema:
        type: string
        format: date-time
      description: The upper insert time excluding boundary.
      example: "2018-08-11T09:11:41.674Z"

    insert_time__gte:
      in: query
      name: insert_time__gte
      schema:
        type: string
        format: date-time
      description: The lower insert time including boundary.
      example: "2018-08-11T09:11:41.674Z"

    create_time__lt:
      in: query
      name: create_time__lt
      schema:
        type: string
        format: date-time
      description: Upper bound for object create_time.
      example: "2018-08-11T09:11:41.674Z"

    create_time__gte:
      in: query
      name: create_time__gte
      schema:
        type: string
        format: date-time
      description: The lower create time including boundary.
      example: "2018-08-11T09:11:41.674Z"

    end_time__lt:
      in: query
      name: end_time__lt
      schema:
        type: string
        format: date-time
      description: Upper bound for object end_time.
      example: "2018-08-11T09:11:41.674Z"

    end_time__gte:
      in: query
      name: end_time__gte
      schema:
        type: string
        format: date-time
      description: The lower end time including boundary.
      example: "2018-08-11T09:11:41.674Z"

    accept_docs_handler:
      in: header
      name: Accept
      schema:
        $ref: '#/components/schemas/accept_docs_handler'
      required: true
      description: Acceptable type of receiving data.

    descriptor_version:
      in: query
      name: descriptor_version
      schema:
        type: integer
        minimum: 0
        maximum: 110
        # Fake boundaries, used to prevent schematesis from sending huge integers.
      description: Event descriptor version. By default used the platform default descriptor version.
      example: 56

    descriptor_version_required:
      in: query
      name: version
      schema:
        type: integer
        minimum: 0
        maximum: 1000
        # Fake boundaries, used to prevent schematesis from sending huge integers.
      description: Event descriptor version.
      required: true
      example: 56

    event_id:
      in: path
      name: event_id
      schema:
        $ref: '#/components/schemas/uuid'
      required: true
      description: Event ID.

    descriptor_type:
      in: query
      name: descriptor_type
      schema:
        type: string
        enum: [face, body]
      description: The type of the event's descriptor.
      example: face

    descriptor_type_required:
      in: query
      name: descriptor_type
      schema:
        type: string
        enum: [face, body]
      description: The type of the event's descriptor.
      required: true
      example: face

    track_ids:
      in: query
      name: track_ids
      schema:
        oneOf:
          - type: string
            format: list of track ids
          - $ref: '#/components/schemas/null_filter'
      example: 'track_id1,track_id_2, null'
      description: List of comma-separated track IDs.

    kind:
      in: query
      name: kind
      schema:
        type: string
        enum: [basic_attributes, face_descriptor, body_descriptor]
      description: |
          Kind of missing attributes to look for.

          Only 1 value at time is supported because the response doesn't
          contain information required to distinguish kinds of the events.
      required: true
      example: basic_attributes

    missing_version:
      in: query
      name: missing_version
      schema:
        type: integer
      description: Event descriptor version. By default used the platform default descriptor version.
      example: 56

    application_json_or_msgpack_content:
      in: header
      name: Content-Type
      schema:
        type: string
        enum:
          - application/json
          - application/msgpack
      description: The response content type header.

    accept_config_handler:
      in: header
      name: Accept
      schema:
        type: string
        enum:
          - application/json
          - text/plain
        description: One of application/json, text/plain.
      required: false
      description: Acceptable type of receiving data

    delete_event_target:
      in: query
      name: target
      schema:
        type: array
        items:
          type: string
          enum: [ face_samples, body_samples, image_origins ]
        default: [ face_samples, body_samples, image_origins ]
      explode: false
      description: |
        Comma-separated list of event deletion info attributes.
        If set, each item from the result will contain only specified attributes in addition to the event ID, otherwise, all the deletion info attributes will be returned.
        If empty value set, each item from the result will contain only event ID.
      example: image_origins

    apparent_gender:
      in: query
      name: apparent_gender
      schema:
        type: array
        items:
          oneOf:
            - type: integer
              enum: [ 0, 1, 2 ]
            - $ref: '#/components/schemas/null_filter'
      explode: false
      description: |
        Comma-separated list of apparent gender: 0 - female, 1 - male, 2 - undefined, "null" - null value. Each event from result will contain one of the given states.
      example: 1

    apparent_age__lt:
      in: query
      name: apparent_age__lt
      schema:
        type: integer
        minimum: 0
        maximum: 100
      description: Apparent age upper excluded bound.
      example: 50

    apparent_age__gte:
      in: query
      name: apparent_age__gte
      schema:
        type: integer
        minimum: 0
        maximum: 100
      description: Apparent age lower included bound.
      example: 50

    headwear_states:
      in: query
      name: headwear_states
      schema:
        type: array
        items:
          oneOf:
            - type: integer
              enum: [ 0, 1, 2 ]
            - $ref: '#/components/schemas/null_filter'
      explode: false
      description: |
        Comma-separated list of headwear states: 0 - absent, 1 - present, 2 - undefined, "null" - null value. Each event from result will contain one of the given states.
      example: 1

    headwear_colors:
      in: query
      name: headwear_apparent_colors
      schema:
        type: array
        items:
          oneOf:
            - $ref: '#/components/schemas/headwear_color'
            - $ref: '#/components/schemas/null_filter'
      explode: false
      description: |
        Comma-separated list of headwear apparent colors or null value. Each event from result will contain one of the given states.
      example: white,undefined,null

    sleeve_lengths:
      in: query
      name: sleeve_lengths
      schema:
        type: array
        items:
          type: string
          enum: [ short, long, undefined, null]
      explode: false
      description: |
        Comma-separated list of sleeve length states or null value. Each event from result will contain one of the given states.
      example: short,null

    upper_clothing_colors:
      in: query
      name: upper_clothing_colors
      schema:
        oneOf:
          - type: array
            items:
              $ref: '#/components/schemas/clothing_color'
          - $ref: '#/components/schemas/null_filter'
      explode: false
      description: |
        Comma-separated list of upper clothing colors or null for not specified colors. Each event from result will contain at least one of the given clothing colors.
      example: black,white

    lower_garment_types:
      in: query
      name: lower_garment_types
      schema:
        type: array
        items:
          type: string
          enum: [ undefined, trousers, shorts, skirt, null ]
      explode: false
      description: |
        Comma-separated list of lower garment types or null value. Each event from result will contain one of the given types.
      example: trousers,undefined,null

    lower_garment_colors:
      in: query
      name: lower_garment_colors
      schema:
        oneOf:
          - type: array
            items:
              $ref: '#/components/schemas/clothing_color'
          - $ref: '#/components/schemas/null_filter'
      explode: false
      description: |
        Comma-separated list of lower garment colors. Each event from result will contain at least one of the given clothing colors.
      example: black,white

    shoes_colors:
      in: query
      name: shoes_apparent_colors
      schema:
        type: array
        items:
          oneOf:
            - $ref: '#/components/schemas/shoes_color'
            - $ref: '#/components/schemas/null_filter'
      explode: false
      description: |
        Comma-separated list of shoes apparent colors or null value. Each event from result will contain one of the given states.
      example: white,undefined,null

    backpack_states:
      in: query
      name: backpack_states
      schema:
        type: array
        items:
          oneOf:
          - type: integer
            enum: [ 0, 1, 2 ]
          - $ref: '#/components/schemas/null_filter'
      explode: false
      description: |
        Comma-separated list of backpack states: 0 - absent, 1 - present, 2 - undefined, "null" - not specified. Each event from result will contain one of the given states.
      example: 1

    luna_account_id_required:
      name: Luna-Account-Id
      in: header
      schema:
        type: string
        format: uuid
        example: 8b8b5937-2e9c-4e8b-a7a7-5caf86621b5a
        pattern: ^[a-f0-9]{8}-?[a-f0-9]{4}-?4[a-f0-9]{3}-?[89ab][a-f0-9]{3}-?[a-f0-9]{12}$
      description: Luna account Id. Designed to identify the created object.
      required: true

    meta:
      in: query
      name: '* (meta.path.to.field__operator:type)'
      schema:
        oneOf:
          - type: string
          - $ref: '#/components/schemas/null_filter'
      description: |
        User-defined event meta's filters.
        
        Parameter name pattern: `meta.<path.to.field>__<operator>:<type>`
        
        Path to field is an event meta's json field path. To navigate through nested objects the dot (.) is used.
        
        Field comparison **operator** is optional one of `eq` (default), `neq`, `like`, `nlike`, `in`, `nin`, `gt`, `gte`, `lt`, `lte`.
        
        Field data **type** is optional one of `string` (default), `integer`, `numeric`.
        
        Allowed usage of filters is:

        |  operator  | type |        |         |         |
        |------------|------|--------|---------|---------|
        |            | none | string | integer | numeric |
        | eq         | +    | +      | +       | +       |
        | neq        | +    | +      | +       | +       |
        | like       | -    | +      | -       | -       |
        | nlike      | -    | +      | -       | -       |
        | in         | +    | +      | +       | +       |
        | nin        | +    | +      | +       | +       |
        | gt         | -    | +      | +       | +       |
        | gte        | -    | +      | +       | +       |
        | lt         | -    | +      | +       | +       |
        | lte        | -    | +      | +       | +       |

      example:
        meta.field_1__gt:numeric: 36.6
        meta.field_2.field_3__in: value,none
        meta.field_4:integer: 5
        meta: null
  schemas:
    Error:
      type: object
      properties:
        error_code:
          type: integer
          description: Error code.
        desc:
          type: string
          description: Short error description.
        detail:
          type: string
          description: Error details.
        link:
          type: string
          description: Link to the documentation website with the error description.
      required:
      - error_code
      - detail
      - desc
      - link
      example:
        error_code: 1
        detail: "Internal server error"
        desc: "Internal server error"
        link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-1"

    uuid:
      type: string
      format: uuid
      pattern: '^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$'
      example: "557d54ec-29ad-4f3c-93b4-c9092ef12515"

    account_id:
      allOf:
        - $ref: '#/components/schemas/uuid'
      description: account id.
      example: "b668c4a5-2191-476e-a261-3b4f9ce2e25e"

    sample_id:
      allOf:
        - $ref: '#/components/schemas/uuid'
      description: Sample ID.
      nullable: true
      example: "b668c4a5-2191-476e-a261-3b4f9ce2e25e"

    external_id:
      description: user-defined external id for face
      type: string
      pattern: "^[^\\x00]*$"
      example: "external id"
      maxLength: 36

    track_id:
      description: Event track ID.
      type: string
      pattern: '^[a-zA-Z0-9_\-]{1,36}$'
      example: "useful_track_id_number_1"

    face_id:
      allOf:
        - $ref: '#/components/schemas/uuid'
      description: Face ID.
      example: "b668c4a5-2191-476e-a261-3b4f9ce2e25e"

    list_id:
      allOf:
        - $ref: '#/components/schemas/uuid'
      description: List ID.
      example: "b668c4a5-2191-476e-a261-3b4f9ce2e25e"

    event_id:
      allOf:
        - $ref: '#/components/schemas/uuid'
      description: Event ID.
      example: "b668c4a5-2191-476e-a261-3b4f9ce2e25e"

    handler_id:
      allOf:
        - $ref: '#/components/schemas/uuid'
      description: Handler ID.
      example: "b668c4a5-2191-476e-a261-3b4f9ce2e25e"

    count:
      type: integer
      minimum: 0
      description: object count.
      example: 100

    int01:
      type: integer
      default: 0
      enum:
      - 0
      - 1

    int0100:
      type: integer
      minimum: 0
      maximum: 100

    int0180:
      type: integer
      default: 180
      minimum: 0
      maximum: 180

    number01:
      type: number
      minimum: 0
      maximum: 1

    estimation_not_nullable:
      type: number
      format: double
      maximum: 1
      minimum: 0
      nullable: false

    null_filter:
      type: string
      enum: [null]

    time:
      type: string
      format: date-time
      example: "2018-08-11T09:11:41.674Z"
      description: time in format RFC 3339

    detect_time:
      allOf:
        - $ref: "#/components/schemas/time"
        - description: Detection time.
      example: "2018-08-11T09:11:41.674Z"

    detect_ts:
      type: number
      minimum: 0.0
      maximum: 158731466399.999
      description: User-defined timestamp relative to something, such as the start of a video.
      example: 123.456
      nullable: true

    image_origin:
      type: string
      maxLength: 256
      description: Image URL - source of the detection.
      nullable: true
      example: "/6/images/b668c4a5-2191-476e-a261-3b4f9ce2e25e"

    column:
      type: string
      enum: [event_id, external_id, handler_id, source, top_similar_object_id, top_similar_external_id, create_time,
             end_time, liveness, top_matching_candidates_label, top_similar_object_similarity, face_id, gender, age,
             emotion, ethnic_group, user_data, tags, city, area, district, street, house_number, geo_position, mask,
             track_id, apparent_age, apparent_gender, sleeve_length, headwear_state, upper_clothing_colors,
             backpack_state, lower_garment_colors, headwear_apparent_color lower_garment_type, shoes_apparent_color, 'meta.*']
      description: Fields to aggregate.
      example: "meta.profile.age"

    gender:
      allOf:
        - $ref: '#/components/schemas/int01'
        - description: Gender. 0 - female, 1 - male.

    age:
      allOf:
        - $ref: '#/components/schemas/int0100'
        - description: Age.

    aggregator:
      type: string
      enum: [count, max, min, avg, group_by]
      example: "count"
      description: Aggregation function for column.
      default: count

    operator_filter:
      type: string
      enum: [eq, neq, in, nin, like, nlike, gt, gte, lt, lte, covered]
      description: |
        Filter operator. For tags it is required to be like/nlike only.
        For geo position filter it is required to be covered only.
      example: "gt"

    operator_period:
      type: string
      enum: [gt, gte, lt, lte]
      description: Filter operator for event creation time.
      example: "gt"

    value_period:
      type: string
      format: date-time
      example: "2018-01-01T00:00:00Z"
      pattern: (^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}Z$|^now-\d+(y|M|w|d|h|m|s)$)
      description: Filter value for event creation time. In ISO or now-time format.

    longitude:
      type: number
      minimum: -180
      maximum: 180
      example: 36.616

    latitude:
      type: number
      minimum: -90
      maximum: 90
      example: 55.752

    geo_position:
      type: object
      description: Geo position specified by geographic coordinates - longitude and latitude.
      properties:
        longitude:
          allOf:
            - $ref: '#/components/schemas/longitude'
            - description: Longitude in degrees.
        latitude:
          allOf:
            - $ref: '#/components/schemas/latitude'
            - description: Latitude in degrees.
      required: [longitude, latitude]

    geo_position_bbox:
      description: |
          Geo position filter is a bounding box specified by coordinates of its center (origin) and some delta.
          WARNING: boxes with a vertex or border on the International Date Line (IDL) or the North or South pole are
          not fully supported due to features of database spatial index - filter result may be unexpected.
      properties:
        origin_longitude:
          allOf:
            - $ref: '#/components/schemas/longitude'
            - description: Origin longitude in degrees.
        origin_latitude:
          allOf:
            - $ref: '#/components/schemas/latitude'
            - description: Origin latitude in degrees.
        longitude_delta:
          description: |
              Longitude delta in degrees. Box edges more than 180 degrees long are not allowed.
              Boundaries of valid range are **exclusive**. NOTE: highly recommended for citywide use only.
          type: number
          minimum: 0
          maximum: 90
          default: 0.01
          example: 0.01
        latitude_delta:
          description: |
              Latitude delta in degrees. Box edges more than 180 degrees long are not allowed.
              Boundaries of valid range are **exclusive**. NOTE: highly recommended for citywide use only.
          type: number
          minimum: 0
          maximum: 90
          default: 0.01
          example: 0.01
      required: [origin_longitude, origin_latitude]

    value_filter:
      oneOf:
        - type: string
        - type: number
        - type: array
          items:
            oneOf:
              - type: string
              - type: number
        - $ref: '#/components/schemas/geo_position_bbox'
      description: |
        Filter value. It is required to be string, integer, float or its array
        or object with specific properties in case of geo position filter -
        geo position filter is bounding box specified by coordinates of its center (origin) and some delta.
      example: "London"

    user_data:
      description: user data.
      type: string
      pattern: "^[^\\x00]*$"
      maxLength: 128
      default: ""

    face_user_data:
      allOf:
        - $ref: '#/components/schemas/user_data'
      description: User data associated with face.
      example: "face of person"

    location_str:
      type: string
      pattern: "^[^\\x00]*$"
      maxLength: 36
      nullable: true

    location:
      type: object
      description: Information about a place where event is incidented.
      properties:
        city:
          allOf:
            - $ref: '#/components/schemas/location_str'
            - description: City where event is incidented.
        area:
          allOf:
            - $ref: '#/components/schemas/location_str'
            - description: Area where event is incidented.
        district:
          allOf:
            - $ref: '#/components/schemas/location_str'
            - description: District where event is incidented.
        street:
          allOf:
            - $ref: '#/components/schemas/location_str'
            - description: Street where event is incidented.
        house_number:
          allOf:
            - $ref: '#/components/schemas/location_str'
            - description: House number where event is incidented.
        geo_position:
          allOf:
            - $ref: '#/components/schemas/geo_position'
            - nullable: true
      required: [city, area, district, street, house_number, geo_position]

      example:
        city: "Moscow"
        area: "CAO"
        district: "Arbat"
        street: "Arbat"
        house_number: "3"
        geo_position:
          longitude: 36.616
          latitude: 55.752

    target:
      type: object
      properties:
        column:
          $ref: '#/components/schemas/column'
        aggregator:
          $ref: '#/components/schemas/aggregator'
      required: [column , aggregator]

    targets:
      type: array
      description: |
        Fields and functions to aggregate.

        Allowed usage of aggregators is:

        | Column                        | Aggregator |     |     |     |          |
        |-------------------------------|------------|-----|-----|-----|----------|
        |                               | count      | max | min | avg | group_by |
        | event_id                      | +          | -   | -   | -   | +        |
        | external_id                   | +          | -   | -   | -   | +        |
        | handler_id                    | +          | -   | -   | -   | +        |
        | source                        | +          | -   | -   | -   | +        |
        | top_similar_object_id         | +          | -   | -   | -   | +        |
        | top_similar_external_id       | +          | -   | -   | -   | +        |
        | top_matching_candidates_label | +          | -   | -   | -   | +        |
        | create_time                   | +          | +   | +   | -   | -        |
        | end_time                      | +          | +   | +   | -   | -        |
        | top_similar_object_similarity | +          | +   | +   | +   | -        |
        | face_id                       | +          | -   | -   | -   | +        |
        | gender                        | +          | +   | +   | +   | +        |
        | age                           | +          | +   | +   | +   | +        |
        | emotion                       | +          | +   | +   | +   | +        |
        | mask                          | +          | +   | +   | +   | +        |
        | ethnic_group                  | +          | +   | +   | +   | +        |
        | liveness                      | +          | +   | +   | +   | +        |
        | user_data                     | +          | -   | -   | -   | +        |
        | tags                          | +          | +   | +   | -   | -        |
        | city                          | +          | -   | -   | -   | +        |
        | area                          | +          | -   | -   | -   | +        |
        | district                      | +          | -   | -   | -   | +        |
        | street                        | +          | -   | -   | -   | +        |
        | house_number                  | +          | -   | -   | -   | +        |
        | geo_position                  | +          | -   | -   | -   | -        |
        | track_id                      | +          | -   | -   | -   | +        |
        | apparent_age                  | +          | +   | +   | +   | +        |
        | apparent_gender               | +          | +   | +   | +   | +        |
        | sleeve_length                 | +          | -   | -   | -   | +        |
        | headwear_state                | +          | +   | +   | +   | +        |
        | upper_clothing_colors         | +          | -   | -   | -   | -        |
        | backpack_state                | +          | +   | +   | +   | +        |
        | lower_garment_colors          | +          | -   | -   | -   | -        |
        | headwear_apparent_color       | +          | -   | -   | -   | +        |
        | lower_garment_type            | +          | -   | -   | -   | +        |
        | shoes_apparent_color          | +          | -   | -   | -   | +        |
        | meta.*                        | +          | +   | +   | +   | -        |
      items:
        $ref: '#/components/schemas/target'
      minItems: 1
      default:
        - {'column': 'event_id', 'aggregator': 'count'}

    filter:
      type: object
      description: Filter for sample restriction.
      properties:
        column:
          $ref: '#/components/schemas/column'
        operator:
          $ref: '#/components/schemas/operator_filter'
        value:
          $ref: '#/components/schemas/value_filter'
      required: [column , operator, value]

    filters:
      type: array
      description: |
        Set of filters for sample restriction.

        Allowed usage of filters is:

        | Filter                        | Operator    |         |         |                  |         |         |
        |-------------------------------|-------------|---------|---------|------------------|---------|---------|
        |                               | like, nlike | in, nin | eq, neq | gt, gte, lt, lte | covered | eq null |
        | tags                          | +           | -       | -       | -                | -       | -       |
        | source                        | -           | +       | +       | -                | -       | +       |
        | user_data                     | -           | +       | +       | -                | -       | -       |
        | account_id                    | -           | +       | +       | +                | -       | -       |
        | event_id                      | -           | +       | +       | +                | -       | -       |
        | external_id                   | -           | +       | +       | +                | -       | -       |
        | handler_id                    | -           | +       | +       | +                | -       | -       |
        | top_similar_object_id         | -           | +       | +       | +                | -       | -       |
        | top_similar_external_id       | -           | +       | +       | +                | -       | -       |
        | top_matching_candidates_label | -           | +       | +       | -                | -       | -       |
        | top_similar_object_similarity | -           | -       | -       | +                | -       | -       |
        | face_id                       | -           | +       | +       | +                | -       | -       |
        | gender                        | -           | +       | +       | +                | -       | +       |
        | age                           | -           | +       | +       | +                | -       | +       |
        | emotion                       | -           | +       | +       | +                | -       | +       |
        | mask                          | -           | +       | +       | +                | -       | +       |
        | ethnic_group                  | -           | +       | +       | +                | -       | +       |
        | liveness                      | -           | +       | +       | +                | -       | +       |
        | city                          | -           | +       | +       | -                | -       | +       |
        | area                          | -           | +       | +       | -                | -       | +       |
        | district                      | -           | +       | +       | -                | -       | +       |
        | street                        | -           | +       | +       | -                | -       | +       |
        | house_number                  | -           | +       | +       | -                | -       | +       |
        | geo_position                  | -           | -       | -       | -                | +       | +       |
        | track_id                      | -           | +       | +       | -                | -       | +       |
        | apparent_age                  | -           | +       | +       | +                | -       | +       |
        | apparent_gender               | -           | +       | +       | +                | -       | +       |
        | sleeve_length                 | -           | +       | +       | -                | -       | +       |
        | headwear_state                | -           | +       | +       | +                | -       | +       |
        | upper_clothing_colors         | -           | +       | -       | -                | -       | +       |
        | backpack_state                | -           | +       | +       | +                | -       | +       |
        | lower_garment_colors          | -           | +       | -       | -                | -       | +       |
        | headwear_apparent_color       | -           | +       | +       | -                | -       | +       |
        | lower_garment_type            | -           | +       | +       | -                | -       | +       |
        | shoes_apparent_color          | -           | +       | +       | -                | -       | +       |
        | meta.*                        | +           | +       | +       | +                | -       | +       |

        Warning: must be at least one aggregator different with 'group_by' in request

      items:
        $ref: '#/components/schemas/filter'
      minItems: 0

    period:
      description: Min and max of event creation time for sample restriction.
      type: object
      properties:
        operator:
          $ref: '#/components/schemas/operator_period'
        value:
          $ref: '#/components/schemas/value_period'
      required: [operator, value]

    periods:
      type: array
      description: It is possible to set start and end of period.
      items:
        $ref: '#/components/schemas/period'
      minItems: 0

    group_by:
      type: string
      description: |
        Event for grouping by creation time.

        Grouping is possible in two ways

        1) Grouping by time intervals - number and dimension

        | The parameter value | Description  |
        |---------------------|--------------|
        | `1m`                | one minute   |
        | `2h`                | two hours    |
        | `7d`                | seven days   |
        | `5w`                | five weeks   |
        | `3M`                | three months |
        | `10y`               | ten years    |

        2) The frequency grouping - one of the following

        | The parameter value | Description        |
        |---------------------|--------------------|
        | `monthOfYear`       | by month of year   |
        | `weekOfYear`        | by week of year    |
        | `dayOfYear`         | by day of year     |
        | `dayOfMonth`        | by day of month    |
        | `dayOfWeek`         | by day of week     |
        | `hourOfDay`         | by hours of day    |
        | `minuteOfHour`      | by minutes of hour |

      example: "dayOfWeek"

    ethnicities_enum:
      type: integer
      enum: [1, 2, 3, 4]
      description: |
        Reference ethnicity

        | ethnicity    | value |
        |------------------|---|
        | African american | 1 |
        | Indian           | 2 |
        | Asian            | 3 |
        | Caucasian        | 4 |

    predominant_ethnicity:
      type: string
      description: Most likely ethnicity of a human from the event.
      enum: ["african_american", "indian", "caucasian", "asian"]

    emotion_enum:
      description: |
        predominant emotion.

        | emotions    | value |
        |-----------------|---|
        | anger           | 1 |
        | disgust         | 2 |
        | fear            | 3 |
        | happiness       | 4 |
        | neutral         | 5 |
        | sadness         | 6 |
        | surprise        | 7 |

      type: integer
      enum: [1, 2, 3, 4, 5, 6, 7]

    mask_enum:
      description: |
        Predominant mask.

        | masks      | value |
        |----------------|---|
        | missing        | 1 |
        | medical_mask   | 2 |
        | occluded       | 3 |

      type: integer
      enum: [1, 2, 3]

    liveness_enum:
      description: |
        Predominant liveness.

        | liveness | value |
        |--------------|---|
        | spoof        | 0 |
        | real         | 1 |
        | unknown      | 2 |

      type: integer
      enum: [0, 1, 2]

    int_version:
      type: integer
      minimum: 0

    version:
      type: object
      properties:
        Version:
          type: object
          properties:
            api:
              allOf:
                - $ref: '#/components/schemas/int_version'
                - description: API version of service.
            major:
              allOf:
                - $ref: '#/components/schemas/int_version'
                - description: Major version of service.
            minor:
              allOf:
                - $ref: '#/components/schemas/int_version'
                - description: Minor version of service.
            patch:
              allOf:
                - $ref: '#/components/schemas/int_version'
                - description: Patch version of service.
          required: [api, major, minor, patch]
      required: [Version]

      example:
        Version:
          api: 1
          major: 0
          minor: 0
          patch: 0

    accept_docs_handler:
      type: string
      enum: [application/x-yaml, text/html]
      description: One of application/x-yaml, text/html.

    avatar:
      type: string
      format: uri-reference
      default: ""
      nullable: true
      description: Avatar for the face, references to a sample or a user-defined reference.

    lists:
      type: array
      items:
        $ref: '#/components/schemas/list_id'
      minItems: 0
      description: List of luna lists, which contain the face.

    url:
      type: string
      description: Face URL.
      nullable: true

    face:
      type: object
      properties:
        face_id:
          $ref: '#/components/schemas/face_id'
        lists:
          type: array
          items:
            $ref: '#/components/schemas/list_id'
          minItems: 0
          description: List of luna lists, which contain the face.
      required: [face_id, lists]
      example:
        face_id: "426542d6-5509-4e5b-8a01-e2abd5c0a8c6"
        lists: ["429b0e78-4616-426a-b57f-02baa72d638d", "6d037c33-31ec-4d73-b3b3-ec80b09446c2"]

    face_candidate:
      type: object
      properties:
        face_id:
          $ref: '#/components/schemas/face_id'
        external_id:
          $ref: '#/components/schemas/external_id'
        user_data:
          $ref: '#/components/schemas/face_user_data'
        create_time:
          allOf:
            - $ref: "#/components/schemas/time"
            - description: Time of the face creation.

    face_candidate_reply:
      type: object
      properties:
        face_id:
          allOf:
          - $ref: '#/components/schemas/face_id'
          nullable: true
        external_id:
          allOf:
          - $ref: '#/components/schemas/external_id'
          nullable: true
        user_data:
          allOf:
          - $ref: '#/components/schemas/face_user_data'
          nullable: true
        create_time:
          allOf:
          - $ref: "#/components/schemas/time"
          - description: Time of the face creation.
          nullable: true
      required: [face_id, external_id, user_data, create_time]

    event_candidate:
      type: object
      properties:
        event_id:
          $ref: '#/components/schemas/event_id'
        external_id:
          $ref: '#/components/schemas/external_id'
        handler_id:
          $ref: '#/components/schemas/handler_id'
        source:
          allOf:
          - $ref: '#/components/schemas/source'
          nullable: true
        user_data:
          $ref: '#/components/schemas/face_user_data'
        create_time:
          allOf:
            - $ref: "#/components/schemas/time"
            - description: Time of the event creation.

    event_candidate_reply:
      type: object
      properties:
        event_id:
          allOf:
          - $ref: '#/components/schemas/event_id'
          nullable: true
        external_id:
          allOf:
          - $ref: '#/components/schemas/external_id'
          nullable: true
        handler_id:
          allOf:
          - $ref: '#/components/schemas/handler_id'
          nullable: true
        source:
          allOf:
          - $ref: '#/components/schemas/source'
          nullable: true
        user_data:
          allOf:
          - $ref: '#/components/schemas/face_user_data'
          nullable: true
        create_time:
          allOf:
          - $ref: "#/components/schemas/time"
          - description: Time of the event creation.
          nullable: true
      required: [event_id, external_id, handler_id, source, user_data, create_time]

    source:
      description: Additional information that user provides with event.
      type: string
      pattern: "^[^\\x00]*$"
      example: "3rd Avenue"

    tag:
      description: Tag. All characters allowed except *NUL*.
      type: string
      pattern: "^[^\\x00]+$"
      example: "good"
      maxLength: 36

    Tags:
      description: Tag array.
      type: array
      items:
        $ref: '#/components/schemas/tag'
      example: ["tag1", "tag2"]

    top_matching_candidates_label:
      description: Top matching candidates label.
      type: string
      pattern: "^[^\\x00]*$"
      maxLength: 36
      example: "good guys"

    top_match_face:
      type: object
      description: The most similar object is face.
      properties:
        face_id:
          allOf:
          - $ref: '#/components/schemas/face_id'
          nullable: true
        similarity:
          $ref: '#/components/schemas/face_similarity'
        label:
          $ref: '#/components/schemas/top_matching_candidates_label'
        external_id:
          allOf:
          - $ref: '#/components/schemas/external_id'
          nullable: true
      required: [face_id, similarity, label, external_id]

    top_match_event:
      type: object
      description: The most similar object is event.
      properties:
        event_id:
          allOf:
          - $ref: '#/components/schemas/event_id'
          nullable: true
        similarity:
          $ref: '#/components/schemas/event_similarity'
        label:
          $ref: '#/components/schemas/top_matching_candidates_label'
        external_id:
          allOf:
          - $ref: '#/components/schemas/external_id'
          nullable: true
      required: [event_id, similarity, label, external_id]

    Event:
      type: object
      description: Event.
      properties:
        create_time:
          allOf:
            - $ref: '#/components/schemas/time'
          description: Event creation time.
        end_time:
          allOf:
            - $ref: '#/components/schemas/time'
          description: Event end time.
        event_id:
          $ref: '#/components/schemas/event_id'
        handler_id:
          allOf:
            - $ref: '#/components/schemas/handler_id'
          description: ID of the handler, which gave birth to the event.
        account_id:
          $ref: '#/components/schemas/account_id'
        external_id:
          $ref: '#/components/schemas/external_id'
        source:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/source'
        top_match:
          nullable: true
          oneOf:
            - $ref: '#/components/schemas/top_match_face'
            - $ref: '#/components/schemas/top_match_event'
        match_result:
          description: Object that contains match result.
          type: array
          nullable: true
          items:
            $ref: '#/components/schemas/match_candidates_reply'
          example:
            [{
               "label": "good guys",
               "candidates": [{
                              "face":{
                                "face_id": "426542d6-5509-4e5b-8a01-e2abd5c0a8c6",
                                "external_id": "2xQ2gprbMUePw1s9gw9fvA==",
                                "user_data": "fox1991",
                                "create_time": "2018-08-11T09:11:41.674Z"
                              },
                              "similarity": 0.5
                            }]},
             {
               "label": "bad guys",
               "candidates": [{
                              "event":{
                                "event_id": "426542d6-5509-4e5b-8a01-e2abd5c0a8c7",
                                "external_id": "2xQ2gprbMUePw1s9gw9fvA==",
                                "user_data": "fox1991",
                                "create_time": "2018-08-11T09:11:41.674Z",
                                "handler_id": "426542d6-5509-4e5b-8a01-e2abd5c0a8c7",
                                "source": "426542d6-5509-4e5b-8a01-e2abd5c0a8c7"
                              },
                              "similarity": 0.3
                            }]}]
        face_detections:
          description: List of all face detection and corresponding sample IDs.
          type: array
          nullable: true
          items:
            type: object
            properties:
              sample_id:
                $ref: '#/components/schemas/sample_id'
              detection:
                type: object
                description: Detection.
                properties:
                  rect:
                    $ref: '#/components/schemas/rect'
                required: [rect]
              detect_time:
                $ref: '#/components/schemas/detect_time'
              detect_ts:
                $ref: '#/components/schemas/detect_ts'
              image_origin:
                $ref: '#/components/schemas/image_origin'
            required: [sample_id, detect_time, image_origin, detect_ts]
        body_detections:
          description: List of all body detection and corresponding sample IDs.
          type: array
          nullable: true
          items:
            type: object
            properties:
              sample_id:
                $ref: '#/components/schemas/sample_id'
              detection:
                type: object
                description: Detection.
                properties:
                  rect:
                    $ref: '#/components/schemas/rect'
              detect_time:
                $ref: '#/components/schemas/detect_time'
              detect_ts:
                $ref: '#/components/schemas/detect_ts'
              image_origin:
                $ref: '#/components/schemas/image_origin'
            required: [sample_id, detect_time, image_origin, detect_ts]

        body_basic_attributes:
          $ref: '#/components/schemas/body_basic_attributes'
        upper_body:
          allOf:
            - $ref: '#/components/schemas/upper_body_attributes'
            - properties:
                headwear:
                  properties:
                    apparent_color:
                      nullable: true
                  required: [ state, apparent_color ]
        lower_body:
          $ref: '#/components/schemas/lower_body_attributes'
        accessories:
          $ref: '#/components/schemas/body_accessories'
        face_id:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/face_id'
        attach_result:
          description: Contains attached lists IDs.
          type: array
          items:
            $ref: '#/components/schemas/list_id'
          minItems: 0
        gender:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/gender'
        age:
          description: Age.
          type: integer
          nullable: true
          maximum: 100
          minimum: 0
        emotion:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/emotion_enum'
        mask:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/mask_enum'
        ethnic_group:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/ethnicities_enum'
        liveness:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/liveness_enum'
        tags:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/Tags'
        user_data:
          $ref: '#/components/schemas/user_data'
        location:
          $ref: '#/components/schemas/location'
        track_id:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/track_id'
        meta:
          type: object
          nullable: true
          additionalProperties: true
          description: User defined metadata (json object). Size shouldn't exceed 2MB

    Events:
      type: array
      items:
        $ref: '#/components/schemas/Event'

    EventsWithoutCount:
      type: object
      properties:
        events:
          $ref: '#/components/schemas/Events'

    face_similarity:
      allOf:
        - $ref: '#/components/schemas/number01'
      description: Face similarity.

    event_similarity:
      allOf:
        - $ref: '#/components/schemas/number01'
      description: Event similarity.

    face_match_candidate:
      type: object
      properties:
        face:
          $ref: '#/components/schemas/face_candidate'
        similarity:
          $ref: '#/components/schemas/face_similarity'
      required: [face, similarity]

    face_match_candidate_reply:
      type: object
      properties:
        face:
          $ref: '#/components/schemas/face_candidate_reply'
        similarity:
          $ref: '#/components/schemas/face_similarity'
      required: [face, similarity]

    event_match_candidate:
      type: object
      properties:
        event:
          $ref: '#/components/schemas/event_candidate'
        similarity:
          $ref: '#/components/schemas/event_similarity'
      required: [event, similarity]

    event_match_candidate_reply:
      type: object
      properties:
        event:
          $ref: '#/components/schemas/event_candidate_reply'
        similarity:
          $ref: '#/components/schemas/event_similarity'
      required: [event, similarity]

    match_candidates_faces:
      type: array
      description: List of faces candidates.
      items:
        $ref: '#/components/schemas/face_match_candidate'

    match_candidates_faces_reply:
      type: object
      properties:
        label:
          $ref: '#/components/schemas/top_matching_candidates_label'
        candidates:
          type: array
          description: List of faces candidates.
          items:
            $ref: '#/components/schemas/face_match_candidate_reply'
      required: [label, candidates]

    match_candidates_events:
      type: array
      description: List of events candidates.
      items:
        $ref: '#/components/schemas/event_match_candidate'

    match_candidates_events_reply:
      type: object
      properties:
        label:
          $ref: '#/components/schemas/top_matching_candidates_label'
        candidates:
          type: array
          description: List of events candidates.
          items:
            $ref: '#/components/schemas/event_match_candidate_reply'
      required: [label, candidates]

    match_candidates_reply:
      anyOf:
        - $ref: '#/components/schemas/match_candidates_faces_reply'
        - $ref: '#/components/schemas/match_candidates_events_reply'

    match_candidates_new_event_faces:
      type: object
      minItems: 1
      properties:
        candidates:
          $ref: '#/components/schemas/match_candidates_faces'
        label:
          $ref: '#/components/schemas/top_matching_candidates_label'
      required: [candidates, label]

    match_candidates_new_event_events:
      type: object
      minItems: 1
      properties:
        candidates:
          $ref: '#/components/schemas/match_candidates_events'
        label:
          $ref: '#/components/schemas/top_matching_candidates_label'
      required: [candidates, label]

    match_candidates_new_event:
      oneOf:
        - $ref: '#/components/schemas/match_candidates_new_event_faces'
        - $ref: '#/components/schemas/match_candidates_new_event_events'

    rect:
      type: object
      description: Detection rectangle.
      properties:
        x:
          type: integer
          description: Detection rectangle x coordinate.
          maximum: 32767
          minimum: -32768
        y:
          type: integer
          description: Detection rectangle y coordinate.
          maximum: 32767
          minimum: -32768
        width:
          type: integer
          description: Detection rectangle width.
          maximum: 32767
          minimum: 0
        height:
          type: integer
          description: Detection rectangle height.
          maximum: 32767
          minimum: 0
      required: [x, y, width, height]

    basic_attributes:
      type: object
      description: Basic attributes.
      properties:
        age:
          $ref: '#/components/schemas/age'
        gender:
          $ref: '#/components/schemas/gender'
        ethnicities:
          $ref: '#/components/schemas/ethnic_estimations'

    face_attributes_json:
      type: object
      description: Face attributes.
      properties:
        basic_attributes:
          $ref: '#/components/schemas/basic_attributes'
        descriptor_data:
          $ref: '#/components/schemas/descriptor_base64_with_version'

    face_attributes_msgpack:
      type: object
      description: Face attributes.
      properties:
        basic_attributes:
          $ref: '#/components/schemas/basic_attributes'
        descriptor_data:
          $ref: '#/components/schemas/descriptor_binary_with_version'

    body_attributes_json:
      type: object
      description: Body attributes.
      properties:
        descriptor_data:
          $ref: '#/components/schemas/descriptor_base64_with_version'

    body_attributes_msgpack:
      type: object
      description: Body attributes.
      properties:
        descriptor_data:
          $ref: '#/components/schemas/descriptor_binary_with_version'

    body_basic_attributes:
      type: object
      description: Body basic attributes.
      nullable: true
      properties:
        apparent_age:
          type: integer
          maximum: 100
          minimum: 0
          description: Apparent age.
        apparent_gender:
          type: integer
          enum: [ 0, 1, 2 ]
          description: Apparent gender (0 - female, 1 - male, 2 - undefined).
      required: [ apparent_age, apparent_gender ]

    headwear_color:
      type: string
      enum: [ undefined, black, white, other ]
      description: Headwear apparent color.

    clothing_color:
      type: string
      enum: [ undefined, black, blue, green, gray, orange, purple, red, white, yellow, pink, brown, beige, khaki, multicolored ]
      description: Clothing color.

    shoes_color:
      type: string
      enum: [ undefined, black, white, other ]
      description: Shoes apparent color.

    upper_body_attributes:
      type: object
      description: Upper body attributes.
      nullable: true
      properties:
        headwear:
          type: object
          properties:
            state:
              type: integer
              enum: [ 0, 1, 2 ]
              description: Headwear state (0 - absent, 1 - present, 2 - undefined).
            apparent_color:
              $ref: '#/components/schemas/headwear_color'
          required: [ state ]
          description: Headwear attributes.
        sleeve:
          type: object
          properties:
            length:
              type: string
              enum: [ short, long, undefined ]
              description: Sleeve length.
          required: [ length ]
          description: Sleeve attributes.
        upper_clothing:
          type: object
          properties:
            colors:
              type: array
              items:
                $ref: '#/components/schemas/clothing_color'
              description: Upper clothing color set.
          required: [ colors ]
          description: Upper clothing attibutes.
      required: [ headwear, sleeve, upper_clothing ]

    lower_body_attributes:
      type: object
      description: Lower body attributes.
      nullable: true
      properties:
        lower_garment:
          type: object
          properties:
            type:
              type: string
              enum: [ undefined, trousers, shorts, skirt ]
            colors:
              type: array
              items:
                $ref: '#/components/schemas/clothing_color'
              description: Lower clothing color set.
          required: [ type, colors ]
          description: Lower clothing attibutes.
        shoes:
          type: object
          properties:
            apparent_color:
              $ref: '#/components/schemas/shoes_color'
          required: [ apparent_color ]
          description: Shoes attributes.
      required: [ lower_garment, shoes ]

    body_accessories:
      type: object
      description: Body accessories.
      nullable: true
      properties:
        backpack:
          type: object
          properties:
            state:
              type: integer
              enum: [ 0, 1, 2 ]
              description: Backpack state (0 - absent, 1 - present, 2 - undefined).
          description: Backpack attributes.
          required: [ state ]
      required: [ backpack ]

    base_new_event:
      type: object
      description: Event.
      properties:
        create_time:
          allOf:
            - type: string
              description: Event creation time.
            - $ref: '#/components/schemas/time'
        end_time:
          allOf:
            - type: string
              description: Event end time, if it was not set, the system will set it by the time of creation.
            - $ref: '#/components/schemas/time'
        event_id:
          allOf:
            - type: string
              description: Event ID.
            - $ref: '#/components/schemas/event_id'
        handler_id:
          allOf:
            - type: string
              description: ID of the handler, which gave birth to the event.
            - $ref: '#/components/schemas/handler_id'
        external_id:
          allOf:
          - $ref: '#/components/schemas/external_id'
          nullable: true
          default: ""
        user_data:
          nullable: true
          allOf:
            - $ref: '#/components/schemas/user_data'
        meta:
          type: object
          nullable: true
          additionalProperties: true
          description: User defined metadata (json object). Size shouldn't exceed 2MB.
          example:
            {
               "key": "value"
            }
        source:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/source'
        track_id:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/track_id'
        tags:
          allOf:
            - nullable: true
            - $ref: '#/components/schemas/Tags'
        face:
          allOf:
            - $ref: '#/components/schemas/face'
            - description: Face object.
            - nullable: true
        matches:
          type: array
          description: Matches list.
          nullable: true
          items:
            $ref: '#/components/schemas/match_candidates_new_event'
          example:
            [{
               "label": "good guys",
               "candidates": [{
                              "face": {
                                "face_id": "426542d6-5509-4e5b-8a01-e2abd5c0a8c6",
                                "external_id": "2xQ2gprbMUePw1s9gw9fvA==",
                                "user_data": "fox1991",
                                "create_time": "2018-08-11T09:11:41.674Z"
                              },
                            similarity: 0.5
                            }]},
             {
               "label": "bad guys",
               "candidates": [{
                              "event": {
                                "event_id": "426542d6-5509-4e5b-8a01-e2abd5c0a8c7",
                                "external_id": "2xQ2gprbMUePw1s9gw9fvA==",
                                "user_data": "fox1991",
                                "create_time": "2018-08-11T09:11:41.674Z",
                                "handler_id": "426542d6-5509-4e5b-8a01-e2abd5c0a8c7",
                                "source": "426542d6-5509-4e5b-8a01-e2abd5c0a8c7"
                              },
                            "similarity": 0.3
                            }]}]
        detections:
          type: array
          description: Detection list.
          items:
            type: object
            properties:
              filename:
                type: string
                description: samples filename
              samples:
                description: a couple of face and body samples - both refer to the same person
                type: object
                properties:
                  face:
                    description: Face detection.
                    type: object
                    nullable: true
                    properties:
                      sample_id:
                        $ref: '#/components/schemas/sample_id'
                      detection:
                        type: object
                        description: Detection.
                        properties:
                          rect:
                            $ref: '#/components/schemas/rect'
                    required: [sample_id]
                  body:
                    description: Body detection.
                    type: object
                    nullable: true
                    properties:
                      sample_id:
                        $ref: '#/components/schemas/sample_id'
                      detection:
                        type: object
                        description: Detection.
                        properties:
                          rect:
                            $ref: '#/components/schemas/rect'
                    required: [sample_id]
                required: [face, body]
              detect_time:
                $ref: '#/components/schemas/detect_time'
              detect_ts:
                $ref: '#/components/schemas/detect_ts'
              image_origin:
                $ref: '#/components/schemas/image_origin'
            required: [samples, filename, detect_time]
        location:
          $ref: '#/components/schemas/location'
        aggregate_estimations:
          type: object
          description: Aggregated estimations.
          properties:
            face:
              type: object
              nullable: true
              description: Aggregated face estimations.
              properties:
                attributes:
                  type: object
                  nullable: false
                  description: Aggregated face attributes.
                  properties:
                    liveness:
                      allOf:
                        - description: Aggregated liveness result.
                        - $ref: '#/components/schemas/liveness_result'
                    emotions:
                      allOf:
                        - description: Aggregated emotions result.
                        - $ref: '#/components/schemas/emotions'
                    mask:
                      allOf:
                        - description: Aggregated mask result.
                        - $ref: '#/components/schemas/mask'
              required: [attributes]
            body:
              type: object
              nullable: true
              description: Aggregated body estimations.
              properties:
                attributes:
                  type: object
                  description: Body extra attributes.
                  properties:
                    basic_attributes:
                      $ref: '#/components/schemas/body_basic_attributes'
                    upper_body:
                      $ref: '#/components/schemas/upper_body_attributes'
                    lower_body:
                      $ref: '#/components/schemas/lower_body_attributes'
                    accessories:
                      $ref: '#/components/schemas/body_accessories'
              required: [ attributes ]
      required: [create_time, event_id, handler_id]

    new_event_json:
      allOf:
        - $ref: '#/components/schemas/base_new_event'
        - properties:
            face_attributes:
              $ref: '#/components/schemas/face_attributes_json'
            body_attributes:
              $ref: '#/components/schemas/body_attributes_json'

    new_event_msgpack:
      allOf:
        - $ref: '#/components/schemas/base_new_event'
        - properties:
            face_attributes:
              $ref: '#/components/schemas/face_attributes_msgpack'
            body_attributes:
              $ref: '#/components/schemas/body_attributes_msgpack'

    event_for_update_json:
      type: object
      description: Event for update.
      properties:
        face_attributes:
          $ref: '#/components/schemas/face_attributes_json'
        body_attributes:
          $ref: '#/components/schemas/body_attributes_json'

    event_for_update_msgpack:
      type: object
      description: Event for update.
      properties:
        face_attributes:
          $ref: '#/components/schemas/face_attributes_msgpack'
        body_attributes:
          $ref: '#/components/schemas/body_attributes_msgpack'

    ethnicities_estimations:
      type: object
      description: Ethnicity classifier response.
      properties:
        asian:
          type: number
          format: double
          maximum: 1
          minimum: 0
          description: Asian ethnicity probability.
        indian:
          type: number
          format: double
          maximum: 1
          minimum: 0
          description: Indian ethnicity probability.
        caucasian:
          type: number
          format: double
          maximum: 1
          minimum: 0
          description: Caucasian ethnicity probability.
        african_american:
          type: number
          format: double
          maximum: 1
          minimum: 0
          description: African American ethnicity probability.

    ethnic_estimations:
      type: object
      description: Ethnicities estimations.
      properties:
        estimations:
          $ref: '#/components/schemas/ethnicities_estimations'
        predominant_ethnicity:
          $ref: '#/components/schemas/predominant_ethnicity'

    getEventStats:
      type: object
      properties:
        targets:
          $ref: '#/components/schemas/targets'
        filters:
          $ref: '#/components/schemas/filters'
        period:
          $ref: '#/components/schemas/periods'
        group_by:
          $ref: '#/components/schemas/group_by'

    emotions_estimations:
      type: object
      properties:
        anger:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          - description: Anger probability.
        disgust:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          - description: Disgust probability.
        fear:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          - description: Fear probability.
        happiness:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          - description: Happiness probability.
        neutral:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          - description: Neutral face probability.
        sadness:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          - description: Sadness probability.
        surprise:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          - description: Surprise probability.
      required: [surprise, sadness, neutral, happiness, fear, disgust, anger]
      description: emotion classifier response.
      example: {anger: 0.1, disgust: 0.2, fear: 0.3, happiness: 0.4, neutral: 0.5, sadness: 0.6, surprise: 0.7}

    predominant_emotion:
      type: string
      description: Name of predominant emotion.
      enum: [surprise, sadness, neutral, happiness, fear, disgust, anger]

    emotions:
      type: object
      description: emotion
      properties:
        estimations:
          allOf:
            - $ref: '#/components/schemas/emotions_estimations'
            - description: Emotion classifier response.
        predominant_emotion:
          $ref: '#/components/schemas/predominant_emotion'
      required: [predominant_emotion, estimations]

    liveness_score:
      allOf:
        - $ref: '#/components/schemas/number01'
      description: |
        The parameter shows the probability of a live person being present in the
        image, i.e. it is not a presentation attack.

        In general, the estimated probability must exceed the theoretical
        threshold of 50%. The value may be increased according to your business rules.
      example: 0.99

    liveness_quality:
      allOf:
        - $ref: '#/components/schemas/number01'
      description: |
        Quality value is a probability of "appropriate image".
        The parameter describes the integral value of image, facial and environmental characteristics.
      example: 1.0

    liveness_prediction:
      type: string
      enum: ["spoof", "real", "unknown"]
      description: Prediction that a person in the image is real (not a fake).
      example: "real"

    liveness_result:
      type: object
      description: liveness prediction result.
      properties:
        prediction:
          $ref: '#/components/schemas/liveness_prediction'
        estimations:
          type: object
          description: Liveness estimations result.
          properties:
            score:
              $ref: '#/components/schemas/liveness_score'
            quality:
              $ref: '#/components/schemas/liveness_quality'
          required: [score, quality]
      required: [prediction, estimations]

    mask_estimations:
      type: object
      description: Raw mask estimations.
      properties:
        medical_mask:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          description: The probability that the `medical mask` exists on the face and is worn properly.
        missing:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          description: The probability that the `medical mask` doesn't exist on the face.
        occluded:
          allOf:
          - $ref: '#/components/schemas/estimation_not_nullable'
          description: The probability that the face is occluded by other object (not by `medical mask`).
      required: [medical_mask, missing, occluded]
      example: {medical_mask: 0.1, missing: 0.2, occluded: 0.3}

    mask_predominant:
      type: string
      enum: [medical_mask, missing, occluded]
      description: Most likely mask state.

    mask:
      type: object
      description: Estimated face mask state.
      properties:
        estimations:
          $ref: '#/components/schemas/mask_estimations'
        predominant_mask:
          $ref: '#/components/schemas/mask_predominant'
      required: [estimations, predominant_mask]

    descriptor_base64_with_version:
      description: Descriptor with descriptor version in the json format.
      type: object
      properties:
        descriptor:
          description: Raw descriptor bytes encoded in base64.
          type: string
          format: base64
        descriptor_version:
          description: Descriptor version.
          type: integer
          example: 52
      required: [descriptor, descriptor_version]

    descriptor_binary_with_version:
      description: Raw descriptor with version.
      type: object
      properties:
        descriptor:
          description: Raw descriptor bytes.
          type: string
          format: binary
        descriptor_version:
          description: Descriptor version.
          type: integer
          example: 52
      required: [descriptor, descriptor_version]

    empty_string:
      type: string
      enum: [""]
      description: No descriptor found.

    event_deletion_info:
      type: array
      items:
        type: object
        properties:
          event_id:
            $ref: '#/components/schemas/event_id'
          face_samples:
            description: Array of face sample IDs.
            type: array
            items:
              $ref: '#/components/schemas/sample_id'
            minItems: 0
            uniqueItems: true
          body_samples:
            description: Array of body sample IDs.
            type: array
            items:
              $ref: '#/components/schemas/sample_id'
            minItems: 0
            uniqueItems: true
          image_origins:
            description: Array of image origins.
            type: array
            items:
              $ref: '#/components/schemas/image_origin'
            minItems: 0
            uniqueItems: true
        required: [ event_id ]
      minItems: 0
      maxItems: 10000

    removed_descriptors_event_list:
      type: object
      properties:
        event_ids:
          type: array
          description: Event IDs which descriptors were removed.
          items:
            $ref: '#/components/schemas/event_id'
          maxItems: 10000
      required: [event_ids]

    EventsWithMissingAttributes:
      type: object
      properties:
        events:
          type: array
          items:
            type: object
            properties:
              event_id:
                $ref: '#/components/schemas/event_id'
              samples:
                description: |
                    Either face sample IDs (for `basic_attributes` or `face_descriptor` kinds) or body sample IDs (for
                    `body_descriptor` kind).
                type: array
                items:
                  $ref: '#/components/schemas/sample_id'
            required: [event_id]
          minItems: 0
          maxItems: 1000
      required: [events]

    EventsWithMissingAttributesCount:
      type: object
      properties:
        events_count:
          type: integer
          description: Count of events.
          example: 55
      required: [events_count]

    health_ok:
      description: Successful healthcheck execution info.
      type: object
      properties:
        execution_time:
          type: number
          example: 0.123
          description: Request execution time in seconds.
      required: [ execution_time ]

    health_errors:
      type: object
      properties:
        errors:
          description: Failed healthcheck execution info.
          type: array
          items:
            type: object
            properties:
              component:
                description: Component name.
                type: string
              error:
                allOf:
                  - description: Healthcheck error.
                  - $ref: '#/components/schemas/Error'
              status:
                description: Component health status.
                type: integer
                enum: [ 0, 1 ]
            required: [ component, error, status ]
      required: [ errors ]
      example:
        errors:
          - component: events_db
            error:
              error_code: 0
              desc: Success
              detail: Success
              link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-0"
            status: 1
          - component: events_db_migration
            error:
              error_code: 10017
              desc: Database error
              detail: Database connection timeout error
              link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-10017"
            status: 0
  responses:
    internal_server_error:
      description: Internal server error.
      headers:
        Content-Type:
          $ref: '#/components/headers/application_json'
        Luna-Request-Id:
          $ref: '#/components/headers/luna_request_id'
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/Error'
paths:
  /version:
    get:
      tags:
      - version

      summary: get version
      description: Get version of service.
      operationId: getVersion

      parameters:
      - $ref: '#/components/parameters/luna_request_id'
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/version'
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/events/{event_id}:
    parameters:
      - $ref: '#/components/parameters/event_id'

    head:
      tags:
      - events
      parameters:
        - $ref: '#/components/parameters/luna_request_id'
        - $ref: '#/components/parameters/account_id'
      summary: check event
      description: Check event existence by ID.
      operationId: checkEvent
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
        '404':
          description: Event not found.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
        '500':
          $ref: '#/components/responses/internal_server_error'

    get:
      tags:
      - events
      parameters:
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/get_event_target'
      - $ref: '#/components/parameters/account_id'

      summary: get event
      description: |
        Get event by ID.
        If target is not set, reply will contain all event fields.
      operationId: getEvent
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Event'
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'target'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '404':
          description: Event not found.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              example:
                error_code: 23001
                desc: Object not found
                detail: Event with id '7acc35cf-a3b2-4f87-8d8b-5496a2782d37' not found
                link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-23001"
        '500':
          $ref: '#/components/responses/internal_server_error'

    patch:
      tags:
        - events
      parameters:
        - $ref: '#/components/parameters/luna_request_id'
        - $ref: '#/components/parameters/application_json_or_msgpack_content'
        - $ref: '#/components/parameters/account_id'

      summary: patch event
      description: Update event by ID.
      operationId: patchEvent
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/event_for_update_json'
          application/msgpack:
            schema:
              $ref: '#/components/schemas/event_for_update_msgpack'
        required: true
      responses:
        '204':
          description: Update success.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_json:
                  value:
                    error_code: 12022
                    desc: Bad/incomplete input data
                    detail: "Failed to validate input json. Path: 'face_attributes',  message: face_attributes must be object"
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12022"
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'account_id'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '404':
          description: Event not found.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              example:
                error_code: 23001
                desc: Object not found
                detail: Event with id '7acc35cf-a3b2-4f87-8d8b-5496a2782d37' not found
                link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-23001"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/events:
    get:
      tags:
      - events
      parameters:
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/get_event_target'
      - $ref: '#/components/parameters/account_id'
      - $ref: '#/components/parameters/create_time__gte'
      - $ref: '#/components/parameters/create_time__lt'
      - $ref: '#/components/parameters/end_time__gte'
      - $ref: '#/components/parameters/end_time__lt'
      - $ref: '#/components/parameters/sources'
      - $ref: '#/components/parameters/top_matching_candidates_label'
      - $ref: '#/components/parameters/top_similar_object_ids'
      - $ref: '#/components/parameters/top_similar_external_ids'
      - $ref: '#/components/parameters/top_similar_object_similarity__gte'
      - $ref: '#/components/parameters/top_similar_object_similarity__lt'
      - $ref: '#/components/parameters/age__lt'
      - $ref: '#/components/parameters/age__gte'
      - $ref: '#/components/parameters/gender'
      - $ref: '#/components/parameters/emotions'
      - $ref: '#/components/parameters/masks'
      - $ref: '#/components/parameters/ethnic_groups'
      - $ref: '#/components/parameters/liveness'
      - $ref: '#/components/parameters/apparent_gender'
      - $ref: '#/components/parameters/apparent_age__gte'
      - $ref: '#/components/parameters/apparent_age__lt'
      - $ref: '#/components/parameters/headwear_states'
      - $ref: '#/components/parameters/headwear_colors'
      - $ref: '#/components/parameters/sleeve_lengths'
      - $ref: '#/components/parameters/upper_clothing_colors'
      - $ref: '#/components/parameters/lower_garment_types'
      - $ref: '#/components/parameters/lower_garment_colors'
      - $ref: '#/components/parameters/shoes_colors'
      - $ref: '#/components/parameters/backpack_states'
      - $ref: '#/components/parameters/face_ids'
      - $ref: '#/components/parameters/event_ids'
      - $ref: '#/components/parameters/event_id__gte_sorting'
      - $ref: '#/components/parameters/event_id__lt_sorting'
      - $ref: '#/components/parameters/handler_ids'
      - $ref: '#/components/parameters/external_ids'
      - $ref: '#/components/parameters/user_data'
      - $ref: '#/components/parameters/tags'
      - $ref: '#/components/parameters/cities'
      - $ref: '#/components/parameters/areas'
      - $ref: '#/components/parameters/districts'
      - $ref: '#/components/parameters/streets'
      - $ref: '#/components/parameters/house_numbers'
      - $ref: '#/components/parameters/origin_longitude'
      - $ref: '#/components/parameters/origin_latitude'
      - $ref: '#/components/parameters/longitude_delta'
      - $ref: '#/components/parameters/latitude_delta'
      - $ref: '#/components/parameters/track_ids'
      - $ref: '#/components/parameters/meta'
      - $ref: '#/components/parameters/search_order'
      - $ref: '#/components/parameters/page'
      - $ref: '#/components/parameters/page_size'

      summary: get events
      description: |
        Get events that satisfy filters.

        Default filters for events:

          - `create_time__lt` - current datetime
          - `create_time__gte` - current datetime minus month

          > **Default filters are not used if any of the following parameters are defined**:

            - list of event IDs (`event_ids`)
            - lower event ID boundary (`event_id__gte`)
            - upper event ID boundary (`event_id__lt`)
            - lower create time boundary (`create_time__gte`)
            - upper create time boundary (`create_time__lt`)

        The `target` parameter determines field that will be shown for each event.
        If target is not set, the response will contain all the fields, except the descriptor data.

        To count events, use <a href="#tag/events-stats">"get statistics on events"</a> request.
      operationId: getEvents
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/EventsWithoutCount'
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'create_time__lt'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '422':
          description: Unprocessable.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                cannot_cast_jsonb:
                  value:
                    error_code: 10020
                    desc: Database error
                    detail: |
                      SQL request execution failed due to incompatible user-defined filters: cannot cast jsonb string to type integer
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-10020"
        '500':
          $ref: '#/components/responses/internal_server_error'

    post:
      tags:
      - events
      summary: create new events
      description: Creates new events.
      operationId: createEvents
      parameters:
        - $ref: '#/components/parameters/luna_account_id_required'
        - $ref: '#/components/parameters/luna_request_id'
        - $ref: '#/components/parameters/application_json_or_msgpack_content'
        - $ref: '#/components/parameters/wait_events_saving'
      requestBody:
        content:
          application/json:
            schema:
              type: array
              items:
                $ref: '#/components/schemas/new_event_json'
              minItems: 1
          application/msgpack:
            schema:
              type: array
              items:
                $ref: '#/components/schemas/new_event_msgpack'
              minItems: 1
        required: true
      responses:
        '202':
          description: Events data is received. Events will be saved to the database soon.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
        '204':
          description: Events were created and stored in the database.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
        '400':
          description: Bad request.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_json:
                  value:
                    error_code: 12022
                    desc: Bad/incomplete input data
                    detail: '[0].create_time,  message: ''incorrect time format'''
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12022"
                account_id_not_found:
                  value:
                    error_code: 11066
                    desc: Bad/incomplete input data
                    detail: Luna-Account-Id header not found
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-11066"
                bad_account_id:
                  value:
                    error_code: 11037
                    desc: Bad/incomplete input data
                    detail: "Luna-Account-Id header is not UUID, format: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-11037"
        '409':
          description: Event already exists.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                duplicated_id:
                  value:
                    error_code: 23003
                    desc: Unique constraint error
                    detail: "One or more event id from '1231531' already exist"
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-23003"
        '500':
          description: Internal server error.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                events_saving_error:
                  value:
                    error_code: 23010
                    desc: internal server error
                    detail: Unknown error
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-23010"
                save_events_timeout:
                  value:
                    error_code: 23007
                    desc: Internal server error
                    detail: Timeout (5 seconds) for save events into history database has been expired
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-23007"
                common_error:
                  value:
                    error_code: 1
                    detail: internal server error
                    desc: internal server error
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-1"

    delete:
      tags:
      - events
      parameters:
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/delete_event_target'
      - $ref: '#/components/parameters/account_id'
      - $ref: '#/components/parameters/handler_id'
      - $ref: '#/components/parameters/create_time__gte'
      - $ref: '#/components/parameters/create_time__lt'
      - $ref: '#/components/parameters/insert_time__gte'
      - $ref: '#/components/parameters/insert_time__lt'

      summary: delete events
      description: Delete oldest 10000 events that satisfy filters.
      operationId: deleteEvents
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/event_deletion_info'
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'handler_id'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/events/attributes/missing:
    get:
      tags:
      - administration
      parameters:
      - $ref: '#/components/parameters/account_id'
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/kind'
      - $ref: '#/components/parameters/insert_time__gte'
      - $ref: '#/components/parameters/insert_time__lt'
      - $ref: '#/components/parameters/event_id__gte'
      - $ref: '#/components/parameters/event_id__lt'
      - $ref: '#/components/parameters/handler_id'
      - $ref: '#/components/parameters/missing_version'
      - $ref: '#/components/parameters/page'
      - $ref: '#/components/parameters/page_size'

      summary: get events with missing attributes
      description: |
        Get events with samples and with missing attributes that satisfy filters.

      operationId: getEventsMissing
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/EventsWithMissingAttributes'
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'insert_time__lt'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/events/attributes/missing/count:
    get:
      tags:
      - administration
      parameters:
      - $ref: '#/components/parameters/account_id'
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/kind'
      - $ref: '#/components/parameters/insert_time__gte'
      - $ref: '#/components/parameters/insert_time__lt'
      - $ref: '#/components/parameters/event_id__gte'
      - $ref: '#/components/parameters/event_id__lt'
      - $ref: '#/components/parameters/handler_id'
      - $ref: '#/components/parameters/missing_version'

      summary: get count of events with missing attributes
      description: |
        Get count of events with samples and with missing attributes that satisfy filters.

      operationId: getEventsMissingCount
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/EventsWithMissingAttributesCount'
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'insert_time__lt'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/events/descriptors:
    delete:
      tags:
      - administration
      parameters:
      - $ref: '#/components/parameters/account_id'
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/event_id__gte'
      - $ref: '#/components/parameters/event_id__lt'
      - $ref: '#/components/parameters/descriptor_version_required'
      - $ref: '#/components/parameters/descriptor_type_required'

      summary: delete events descriptors
      description: Delete 10000 event descriptors that satisfy filters.

      operationId: deleteDescriptors
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/removed_descriptors_event_list'
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'event_id__lt'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/events/{event_id}/descriptor:
    parameters:
      - $ref: '#/components/parameters/event_id'

    get:
      tags:
      - event descriptor
      parameters:
      - $ref: '#/components/parameters/accept'
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/account_id'
      - $ref: '#/components/parameters/descriptor_version'
      - $ref: '#/components/parameters/descriptor_type'

      summary: get event descriptor
      description: Get event descriptor that corresponds to the specified parameters.
      operationId: getEventDescriptor
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json_or_xbinary'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/descriptor_base64_with_version'
            application/x-sdk-descriptor:
              schema:
                type: string
                format: binary
                description: Content type is application/x-sdk-descriptor, a binary descriptor is returned in the response body.
              example: "<a binary descriptor in the SDK format>"
        '400':
          description: Bad request.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_query_param:
                  value:
                    error_code: 12012
                    desc: Bad/incomplete input data
                    detail: Bad query parameters 'descriptor_version'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12012"
        '404':
          description: Object not found.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                event_not_found:
                  value:
                    error_code: 23001
                    desc: Object not found
                    detail: Event with id '7acc35cf-a3b2-4f87-8d8b-5496a2782d37' not found
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-23001"
                face_descriptor_not_found:
                  value:
                    error_code: 22018
                    desc: Object not found
                    detail: Face descriptor of version 7 is not found for object with id '7acc35cf-a3b2-4f87-8d8b-5496a2782d37'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-22018"
                human_descriptor_not_found:
                  value:
                    error_code: 23007
                    desc: Object not found
                    detail: Human descriptor of version 7 is not found for object with id '7acc35cf-a3b2-4f87-8d8b-5496a2782d37'
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-23007"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/events/stats:
    post:
      tags:
      - events stats
      summary: get statistics on events
      description: |
        Get event statistics by target(s) with applied filters.

        Event fields and/or functions (count, min, etc.) can be set as targets for aggregation of events.

        Grouping by frequency or grouping by time intervals is available.
      operationId: getEventStats
      parameters:
      - $ref: '#/components/parameters/luna_request_id'
      - $ref: '#/components/parameters/applicationJsonContent'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/getEventStats'
            example:
              targets:
                - column: event_id
                  aggregator: count
                - column: age
                  aggregator: group_by
                - column: gender
                  aggregator: group_by
              filters:
                - column: source
                  operator: eq
                  value: Main_hall_camera
                - column: geo_position
                  operator: covered
                  value:
                    origin_longitude: 37
                    origin_latitude: 55
                    longitude_delta: 0.04
                    latitude_delta: 0.04

              period:
                - operator: gt
                  value: 2020-02-04T00:00:00Z
                - operator: lt
                  value: 2020-02-06T00:00:00Z
              group_by: dayOfWeek
        required: true
      responses:
        '200':
          description: Created.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                type: object
                properties:
                  fields:
                    type: array
                    items:
                      type: string
                    description: |
                      Reply structure description includes is as follows:
                      - First element of a list is 'Group by time' section if request includes time or frequency grouping.
                      - Other elements are pairs of columns and aggregators for the columns.

                      List of columns and aggregators presents in the same order as in stats.
                  stats:
                    type: array
                    description: grouped values array.
                    items:
                      type: array
                      items:
                        description: |
                          grouped values. Value order is corresponding to order of request targets order.
                        nullable: true
                        anyOf:
                          - type: integer
                          - type: number
                          - type: string
                      minItems: 1
              examples:
                count_dayOfWeek:
                  value:
                    fields:
                      - "Group by time: dayOfWeek"
                      - "gender, aggregator 'group_by'"
                      - "age, aggregator 'group_by'"
                      - "event_id, aggregator 'count'"
                    stats:
                    - - Tuesday
                      - 0
                      - 22
                      - 45
                    - - Tuesday
                      - 0
                      - 27
                      - 23
                    - - Tuesday
                      - 1
                      - 27
                      - 45
                    - - Wednesday
                      - 0
                      - 25
                      - 34
                    - - Wednesday
                      - 1
                      - 33
                      - 345

        '400':
          description: Bad request.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                bad_json:
                  value:
                    error_code: 12022
                    desc: Bad/incomplete input data
                    detail: 'Failed to validate input json. Path: '''',  message: ''Additional properties are not allowed (''userdata'' was unexpected)'''
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12022"
        '422':
          description: Unprocessable.
          headers:
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
            Content-Type:
              $ref: '#/components/headers/application_json'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                cannot_cast_jsonb:
                  value:
                    error_code: 10020
                    desc: Database error
                    detail: |
                      SQL request execution failed due to incompatible user-defined filters: cannot cast jsonb string to type integer
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-10020"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/docs/spec:
    get:
      tags:
        - documents
      summary: get openapi documentation
      description: |
        Get service OpenApi documentation. If *Accept* request header is of type `application/x-yaml`,
        returns documentation in `yaml` format or returns `html` documentation, if *Accept-Type* is `text/html`.
      operationId: getSpec

      parameters:
        - $ref: '#/components/parameters/luna_request_id'
        - $ref: '#/components/parameters/accept_docs_handler'
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/docs_content_type'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/x-yaml:
              schema:
                type: string
                description: YAML format documentation.
            text/html:
              schema:
                type: string
                description: HTML format documentation.
        '415':
          description: Unsupported media type.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                unsupported_media_type:
                  value:
                    error_code: 12024
                    detail: 'Bad/incomplete input data'
                    desc: "Unsupported media type"
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12024"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/docs/dev:
    get:
      tags:
        - documents
      summary: get development manual
      description: |
        Get sphinx documentation - *Development Manual*. After the request you will be redirected to the page `/docs/dev/index.html`.
      operationId: getDevManual

      parameters:
        - $ref: '#/components/parameters/luna_request_id'
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/text_html'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            text/html:
              schema:
                type: string
                description: HTML format documentation.
        '500':
          $ref: '#/components/responses/internal_server_error'
  /2/config:
    get:
      tags:
        - config
      summary: get service configuration
      description: Get service configuration. Passwords and tokens will be hidden in the response.
      operationId: getConfig

      parameters:
        - $ref: '#/components/parameters/luna_request_id'
        - $ref: '#/components/parameters/accept_config_handler'
      responses:
        '200':
          description: OK
          headers:
            Content-Type:
              $ref: '#/components/headers/config_accept_content_type'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                type: object
                description: json format configuration
              example:
                INFLUX_MONITORING:
                  SEND_DATA_FOR_MONITORING: 0
                  VERSION: 2
                  ORGANIZATION: ORGANIZATION_NAME
                  TOKEN: '********'
                  BUCKET: luna_monitoring
                  HOST: 127.0.0.1
                  PORT: 8086
                  USE_SSL: 0
                  FLUSHING_PERIOD: 1.0
            text/plain:
              schema:
                type: string
                description: text format configuration
              example: |
                [INFLUX_MONITORING]
                SEND_DATA_FOR_MONITORING = 0
                VERSION = 2
                ORGANIZATION = ORGANIZATION_NAME
                TOKEN = ********
                BUCKET = luna_monitoring
                HOST = 127.0.0.1
                PORT = 8086
                USE_SSL = 0
                FLUSHING_PERIOD = 1.0
        '415':
          description: Unsupported Media Type
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Error'
              examples:
                unsupported_media_type:
                  value:
                    error_code: 12024
                    detail: 'Bad/incomplete input data'
                    desc: "Unsupported media type"
                    link: "https://docs.visionlabs.ai/info/luna/troubleshooting/errors-description/code-12024"
        '500':
          $ref: '#/components/responses/internal_server_error'
  /healthcheck:
    get:
      tags:
      - health
      summary: get health
      description: Get health of service.
      operationId: healthcheck
      parameters:
        - $ref: '#/components/parameters/luna_request_id'
      responses:
        '200':
          description: OK.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/health_ok'
        '500':
          $ref: '#/components/responses/internal_server_error'
        '502':
          description: Unhealthy.
          headers:
            Content-Type:
              $ref: '#/components/headers/application_json'
            Luna-Request-Id:
              $ref: '#/components/headers/luna_request_id'
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/health_errors'