> ## Documentation Index
> Fetch the complete documentation index at: https://docs.kombo.dev/llms.txt
> Use this file to discover all available pages before exploring further.

# Get interviews

> Retrieve all interviews.

<Accordion title="Supported integrations" icon="list-check">
  This feature is currently available for the following integrations:

  <ul>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/workday/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/workday">Workday</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/successfactors/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/successfactors">SAP SuccessFactors</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/smartrecruiters/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/smartrecruiters">SmartRecruiters</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/lever/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/lever">Lever</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/recruitee/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/recruitee">Recruitee</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/greenhouse/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/greenhouse">Greenhouse (V1)</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/greenhousev3/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/greenhousev3">Greenhouse (V3)</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/ashby/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/ashby">Ashby</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/workable/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/workable">Workable</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/pinpoint/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/pinpoint">Pinpoint</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/zohorecruit/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/zohorecruit">Zoho Recruit</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/jobadder/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/jobadder">JobAdder</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/gem/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/gem">Gem</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/crelate/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/crelate">Crelate</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/breezyhr/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/breezyhr">Breezy HR</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/sandbox/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/sandbox">Kombo Sandbox</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/kula/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/ats/connectors/kula">Kula</a></li>
  </ul>

  You'd like to see this feature for another integration? Please reach out!
  We're always happy to discuss extending our coverage.
</Accordion>

Top level filters use AND, while individual filters use OR if they accept multiple arguments. That means filters will be resolved like this: `(id IN ids) AND (remote_id IN remote_ids)`


## OpenAPI

````yaml GET /ats/interviews
openapi: 3.1.0
info:
  title: Kombo API
  version: 1.0.0
servers:
  - url: https://api.kombo.dev/v1
    description: Kombo EU API
  - url: https://api.us.kombo.dev/v1
    description: Kombo US API
security:
  - ApiKey: []
tags:
  - name: General
  - name: Kombo Connect
    description: >-
      Endpoints for Kombo Connect, our end-user-facing flow for setting up new
      integrations.
  - name: Unified HRIS API
    description: Unified endpoints to access all the HR concepts you might need.
  - name: Unified ATS API
    description: Unified endpoints to access all the ATS concepts you might need.
  - name: Unified ATS (Assessment & Background Check) API
    description: >-
      Unified endpoints to operate Assessments and Background Checks for many
      applicant tracking systems.
  - name: Unified LMS API
    description: Unified endpoints to access all the LMS concepts you might need.
  - name: AI Apply
    description: Endpoints for AI-powered job application features.
  - name: Custom Endpoints
    description: Custom integration-specific endpoints.
paths:
  /ats/interviews:
    get:
      tags:
        - Unified ATS API
      summary: Get interviews
      description: >-
        Retrieve all interviews.


        <Accordion title="Supported integrations" icon="list-check">

        This feature is currently available for the following integrations:


        <ul>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/workday/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/workday">Workday</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/successfactors/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/successfactors">SAP SuccessFactors</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/smartrecruiters/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/smartrecruiters">SmartRecruiters</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/lever/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/lever">Lever</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/recruitee/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/recruitee">Recruitee</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/greenhouse/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/greenhouse">Greenhouse (V1)</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/greenhousev3/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/greenhousev3">Greenhouse (V3)</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/ashby/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/ashby">Ashby</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/workable/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/workable">Workable</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/pinpoint/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/pinpoint">Pinpoint</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/zohorecruit/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/zohorecruit">Zoho Recruit</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/jobadder/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/jobadder">JobAdder</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/gem/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/gem">Gem</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/crelate/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/crelate">Crelate</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/breezyhr/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/breezyhr">Breezy HR</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/sandbox/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/sandbox">Kombo Sandbox</a></li>

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/kula/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/ats/connectors/kula">Kula</a></li>

        </ul>


        You'd like to see this feature for another integration? Please reach
        out!

        We're always happy to discuss extending our coverage.

        </Accordion>



        Top level filters use AND, while individual filters use OR if they
        accept multiple arguments. That means filters will be resolved like
        this: `(id IN ids) AND (remote_id IN remote_ids)`
      operationId: GetAtsInterviews
      parameters:
        - in: header
          name: X-Integration-Id
          schema:
            type: string
          description: ID of the integration you want to interact with.
          example: join:HWUTwvyx2wLoSUHphiWVrp28
          required: true
        - name: cursor
          in: query
          required: false
          description: >-
            An optional cursor string used for pagination. This can be retrieved
            from the `next` property of the previous page response.
          schema:
            $ref: '#/components/schemas/GetAtsInterviewsParameterCursor'
        - name: page_size
          in: query
          required: false
          description: The number of results to return per page. Maximum is 250.
          schema:
            $ref: '#/components/schemas/GetAtsInterviewsParameterPageSize'
        - name: updated_after
          in: query
          required: false
          description: >-
            Filter the entries based on the modification date in format
            `YYYY-MM-DDTHH:mm:ss.sssZ`. Returns records where either the record
            itself **OR** its nested data has been updated since this timestamp,
            even if the record's own `changed_at` field remains unchanged.


            If you want to track entry deletion, also set the
            `include_deleted=true` query parameter, because otherwise, deleted
            entries will be hidden.


            For more details, see [Understanding changed_at vs updated_after
            Behavior](https://docs.kombo.dev/ats/getting-started/fetching-data#understanding-changed_at-vs-updated_after-behavior).


            For this endpoint, `updated_after` matches when the returned record
            changed, or when related data changed as described below.


            | Path | Added/Removed | Linked Record |

            | --- | --- | --- |

            | `interviewers` | ✓ Yes | ✗ No |

            | `application` | n/a | ✓ Yes |

            | `application` → `candidate` | ✗ No | ✗ No |

            | `application` → `job` | ✗ No | ✗ No |


            _**Added/Removed**: Whether adding or removing entries from this
            list triggers an update (n/a for single records). **Linked Record**:
            Whether changes to the linked record itself trigger an update._
          schema:
            $ref: '#/components/schemas/GetAtsInterviewsParameterUpdatedAfter'
        - name: include_deleted
          in: query
          required: false
          description: >-
            By default, deleted entries are not returned. Use the
            `include_deleted` query param to include deleted entries too.
          schema:
            $ref: '#/components/schemas/GetAtsInterviewsParameterIncludeDeleted'
        - name: ignore_unsupported_filters
          in: query
          required: false
          description: >-
            When set to `true`, filters targeting fields not supported by this
            integration will be ignored instead of filtering out all results.
          schema:
            $ref: >-
              #/components/schemas/GetAtsInterviewsParameterIgnoreUnsupportedFilters
        - name: ids
          in: query
          required: false
          description: >-
            Filter by a comma-separated list of IDs such as
            `222k7eCGyUdgt2JWZDNnkDs3,B5DVmypWENfU6eMe6gYDyJG3`.
          schema:
            $ref: '#/components/schemas/GetAtsInterviewsParameterIds'
        - name: remote_ids
          in: query
          required: false
          description: Filter by a comma-separated list of remote IDs.
          schema:
            $ref: '#/components/schemas/GetAtsInterviewsParameterRemoteIds'
        - name: job_ids
          in: query
          required: false
          description: >-
            Filter by a comma-separated list of job IDs. We will only return
            interviews for applications associated with any of these jobs.
          schema:
            $ref: '#/components/schemas/GetAtsInterviewsParameterJobIds'
      responses:
        '200':
          description: GET /ats/interviews Positive response
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/GetAtsInterviewsPositiveResponse'
              examples:
                example1:
                  value:
                    status: success
                    data:
                      next: >-
                        eyJwYWdlIjoxMiwibm90ZSI6InRoaXMgaXMganVzdCBhbiBleGFtcGxlIGFuZCBub3QgcmVwcmVzZW50YXRpdmUgZm9yIGEgcmVhbCBjdXJzb3IhIn0=
                      results:
                        - id: 26vafvWSRmbhNcxJYqjCzuJg
                          remote_id: '32'
                          title: Interview with John Doe
                          starting_at: '2023-06-26T14:30:00.000Z'
                          ending_at: '2023-06-26T15:30:00.000Z'
                          location:
                            city: Berlin
                            country: DE
                            raw: Berlin, Germany
                            state: Berlin
                            street_1: Lohmühlenstraße 65
                            street_2: null
                            zip_code: '12435'
                          video_conferencing_url: https://meet.example.com/interview-abc123
                          application_id: H77fDF8uvEzGNPRubiz5DvQ7
                          stage_id: H5daSm8e85Dmvmne3wLeCPhX
                          canceled: false
                          remote_created_at: '2022-08-07T14:01:29.196Z'
                          remote_updated_at: '2022-08-07T14:01:29.196Z'
                          remote_data: null
                          changed_at: '2022-08-07T14:01:29.196Z'
                          remote_deleted_at: null
                          users:
                            - id: 26vafvWSRmbhNcxJYqjCzuJg
                              remote_id: '32'
                              first_name: John
                              last_name: Doe
                              email: john.doe@kombo.dev
                          application:
                            id: H77fDF8uvEzGNPRubiz5DvQ7
                            remote_id: '32'
                            outcome: HIRED
                            rejection_reason_name: null
                            candidate:
                              id: 26vafvWSRmbhNcxJYqjCzuJg
                              remote_id: '32'
                              first_name: John
                              last_name: Doe
                              email_addresses:
                                - email_address: john.doe@example.com
                                  type: PRIVATE
                            job:
                              id: H5daSm8e85Dmvmne3wLeCPhX
                              remote_id: '32'
                              name: Backend Engineer
        default:
          $ref: '#/components/responses/ErrorResponseATS'
      x-codeSamples:
        - lang: python
          label: GetAtsInterviews
          source: |-
            from kombo import Kombo


            with Kombo(
                integration_id="workday:HWUTwvyx2wLoSUHphiWVrp28",
                api_key="<YOUR_BEARER_TOKEN_HERE>",
            ) as k_client:

                res = k_client.ats.get_interviews(page_size=100, include_deleted=False, ignore_unsupported_filters=False)

                while res is not None:
                    # Handle items

                    res = res.next()
        - lang: typescript
          label: GetAtsInterviews
          source: |-
            import { Kombo } from "@kombo-api/sdk";

            const kombo = new Kombo({
              integration_id: "workday:HWUTwvyx2wLoSUHphiWVrp28",
              api_key: "<YOUR_BEARER_TOKEN_HERE>",
            });

            async function run() {
              const result = await kombo.ats.getInterviews({});

              for await (const page of result) {
                console.log(page);
              }
            }

            run();
        - lang: ruby
          label: GetAtsInterviews
          source: >-
            require 'kombo'


            Models = ::Kombo::Models

            s = ::Kombo::Kombo.new(
              integration_id: 'workday:HWUTwvyx2wLoSUHphiWVrp28',
              security: Models::Shared::Security.new(
                api_key: '<YOUR_BEARER_TOKEN_HERE>'
              )
            )

            res = s.ats.get_interviews(page_size: 100, include_deleted: false,
            ignore_unsupported_filters: false)


            unless res.get_ats_interviews_positive_response.nil?
              # handle response
            end
components:
  schemas:
    GetAtsInterviewsParameterCursor:
      type: string
      description: >-
        An optional cursor string used for pagination. This can be retrieved
        from the `next` property of the previous page response.
    GetAtsInterviewsParameterPageSize:
      type: integer
      format: int64
      minimum: 1
      maximum: 250
      default: 100
      description: The number of results to return per page. Maximum is 250.
    GetAtsInterviewsParameterUpdatedAfter:
      description: >-
        Filter the entries based on the modification date in format
        `YYYY-MM-DDTHH:mm:ss.sssZ`. Returns records where either the record
        itself **OR** its nested data has been updated since this timestamp,
        even if the record's own `changed_at` field remains unchanged.


        If you want to track entry deletion, also set the `include_deleted=true`
        query parameter, because otherwise, deleted entries will be hidden.


        For more details, see [Understanding changed_at vs updated_after
        Behavior](https://docs.kombo.dev/ats/getting-started/fetching-data#understanding-changed_at-vs-updated_after-behavior).


        For this endpoint, `updated_after` matches when the returned record
        changed, or when related data changed as described below.


        | Path | Added/Removed | Linked Record |

        | --- | --- | --- |

        | `interviewers` | ✓ Yes | ✗ No |

        | `application` | n/a | ✓ Yes |

        | `application` → `candidate` | ✗ No | ✗ No |

        | `application` → `job` | ✗ No | ✗ No |


        _**Added/Removed**: Whether adding or removing entries from this list
        triggers an update (n/a for single records). **Linked Record**: Whether
        changes to the linked record itself trigger an update._
      type: string
      format: date-time
      pattern: ^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d+)?)?Z?$
      externalDocs:
        url: >-
          https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
    GetAtsInterviewsParameterIncludeDeleted:
      type: string
      enum:
        - 'true'
        - 'false'
      default: 'false'
      description: >-
        By default, deleted entries are not returned. Use the `include_deleted`
        query param to include deleted entries too.
    GetAtsInterviewsParameterIgnoreUnsupportedFilters:
      type: string
      enum:
        - 'true'
        - 'false'
      default: 'false'
      description: >-
        When set to `true`, filters targeting fields not supported by this
        integration will be ignored instead of filtering out all results.
    GetAtsInterviewsParameterIds:
      type: string
      description: >-
        Filter by a comma-separated list of IDs such as
        `222k7eCGyUdgt2JWZDNnkDs3,B5DVmypWENfU6eMe6gYDyJG3`.
    GetAtsInterviewsParameterRemoteIds:
      type: string
      description: Filter by a comma-separated list of remote IDs.
    GetAtsInterviewsParameterJobIds:
      type: string
      description: >-
        Filter by a comma-separated list of job IDs. We will only return
        interviews for applications associated with any of these jobs.
    GetAtsInterviewsPositiveResponse:
      type: object
      properties:
        status:
          type: string
          const: success
        data:
          type: object
          properties:
            next:
              type:
                - string
                - 'null'
              description: >-
                Cursor string that can be passed to the `cursor` query parameter
                to get the next page. If this is `null`, then there are no more
                pages.
            results:
              type: array
              items:
                type: object
                properties:
                  id:
                    type: string
                    description: >-
                      The globally unique ID of this object generated by Kombo.
                      We recommend using this as a stable primary key for
                      syncing.
                  remote_id:
                    type:
                      - string
                      - 'null'
                    description: >-
                      The raw ID of the object in the remote system. We don't
                      recommend using this as a primary key on your side as it
                      might sometimes be compromised of multiple identifiers if
                      a system doesn't provide a clear primary key.
                  title:
                    type:
                      - string
                      - 'null'
                    description: The title of the interview.
                  starting_at:
                    description: The start time of the interview.
                    type:
                      - string
                      - 'null'
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  ending_at:
                    description: The end time of the interview.
                    type:
                      - string
                      - 'null'
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  location:
                    type:
                      - object
                      - 'null'
                    properties:
                      city:
                        type:
                          - string
                          - 'null'
                      country:
                        type:
                          - string
                          - 'null'
                        description: >-
                          Contains the ISO2 country code if possible. If not, it
                          contains the original value.
                      raw:
                        type:
                          - string
                          - 'null'
                        description: >-
                          If we have address data, this is filled with the raw
                          address string.
                      state:
                        type:
                          - string
                          - 'null'
                      street_1:
                        type:
                          - string
                          - 'null'
                        description: >-
                          If we can parse the address data, this field contains
                          the first part of the street information.
                      street_2:
                        type:
                          - string
                          - 'null'
                      zip_code:
                        type:
                          - string
                          - 'null'
                    description: Location of the interview.
                  video_conferencing_url:
                    type:
                      - string
                      - 'null'
                    description: >-
                      The URL of the video conferencing platform used for the
                      interview.
                  application_id:
                    type:
                      - string
                      - 'null'
                    description: >-
                      The Kombo ID of the application this interview belongs to.
                      The ID can be used to retrieve the application from the
                      `get applications` endpoint.
                  stage_id:
                    type:
                      - string
                      - 'null'
                    description: >-
                      If a system specifies to which stage this interview
                      belongs to, this field will be the Kombo ID of the
                      application stage. The ID can be used to retrieve the
                      stage from the `get application stages` endpoint.
                  canceled:
                    type:
                      - boolean
                      - 'null'
                    description: >-
                      Whether the interview was canceled or not. If we have no
                      information, this field will be `null`.
                  remote_created_at:
                    description: >-
                      The date and time the object was created in the remote
                      system.
                    type:
                      - string
                      - 'null'
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  remote_updated_at:
                    description: >-
                      A timestamp retrieved from the remote system, describing
                      when the resource was last updated.
                    type:
                      - string
                      - 'null'
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  remote_data:
                    type:
                      - object
                      - 'null'
                    additionalProperties: true
                    description: >-
                      Includes the data fetched from the remote system.

                      Please be aware that including this in you scope config
                      might violate other

                      scopes that are set.


                      Remote data always has the endpoint path that we got the
                      data from as the

                      top level key. For example, it could look like: `{
                      "/companies": { ... }}`


                      This is not available on all plans. Reach out to Kombo if
                      you need it.
                  changed_at:
                    description: >-
                      The timestamp when this specific record was last modified.
                      This field only updates when properties directly on this
                      record change, NOT when related or nested models change.
                      For filtering that considers nested data changes, use the
                      `updated_after` parameter which will return records when
                      either the record itself OR its related models have been
                      updated.
                    type: string
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  remote_deleted_at:
                    description: >-
                      The date and time the object was deleted in the remote
                      system. Objects are automatically marked as deleted when
                      Kombo can't retrieve them from the remote system anymore.
                      Kombo will also anonymize entries 14 days after they
                      disappear.
                    type:
                      - string
                      - 'null'
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  users:
                    type: array
                    items:
                      type: object
                      properties:
                        id:
                          type: string
                          description: >-
                            The globally unique ID of this object generated by
                            Kombo. We recommend using this as a stable primary
                            key for syncing.
                        remote_id:
                          type:
                            - string
                            - 'null'
                          description: >-
                            The raw ID of the object in the remote system. We
                            don't recommend using this as a primary key on your
                            side as it might sometimes be compromised of
                            multiple identifiers if a system doesn't provide a
                            clear primary key.
                        first_name:
                          type:
                            - string
                            - 'null'
                          description: First name of the user.
                        last_name:
                          type:
                            - string
                            - 'null'
                          description: Last name of the user.
                        email:
                          type:
                            - string
                            - 'null'
                          pattern: >-
                            ^(?!\.)(?!.*\.\.)([\w'+-.]*)[\w+-]@([\da-z][\da-z-]*\.)+[a-z]{2,}$
                          description: >-
                            Email of the user. If the email address is invalid,
                            it will be set to null.
                      required:
                        - id
                        - remote_id
                        - first_name
                        - last_name
                      examples:
                        - id: 26vafvWSRmbhNcxJYqjCzuJg
                          remote_id: '32'
                          first_name: John
                          last_name: Doe
                          email: john.doe@kombo.dev
                  application:
                    type:
                      - object
                      - 'null'
                    properties:
                      id:
                        type: string
                        description: >-
                          The globally unique ID of this object generated by
                          Kombo. We recommend using this as a stable primary key
                          for syncing.
                      remote_id:
                        type:
                          - string
                          - 'null'
                        description: >-
                          The raw ID of the object in the remote system. We
                          don't recommend using this as a primary key on your
                          side as it might sometimes be compromised of multiple
                          identifiers if a system doesn't provide a clear
                          primary key.
                      outcome:
                        type:
                          - string
                          - 'null'
                        enum:
                          - PENDING
                          - HIRED
                          - DECLINED
                        description: >-
                          Parsed status of the application. If Kombo identifies
                          that the application was accepted and the candidate
                          hired, it will be `HIRED`. If the application was
                          rejected or the candidate declined, it will be
                          `DECLINED`. If the application is still in process, it
                          will be `PENDING`.

                          Kombo will always try to deliver this information as
                          reliably as possible.
                      rejection_reason_name:
                        type:
                          - string
                          - 'null'
                        description: Reason for the rejection of the candidate.
                      candidate:
                        type:
                          - object
                          - 'null'
                        properties:
                          id:
                            type: string
                            description: >-
                              The globally unique ID of this object generated by
                              Kombo. We recommend using this as a stable primary
                              key for syncing.
                          remote_id:
                            type: string
                            description: >-
                              The raw ID of the object in the remote system. We
                              don't recommend using this as a primary key on
                              your side as it might sometimes be compromised of
                              multiple identifiers if a system doesn't provide a
                              clear primary key.
                          first_name:
                            type:
                              - string
                              - 'null'
                            description: First name of the candidate.
                          last_name:
                            type:
                              - string
                              - 'null'
                            description: Last name of the candidate.
                          email_addresses:
                            type:
                              - array
                              - 'null'
                            items:
                              type: object
                              properties:
                                email_address:
                                  type:
                                    - string
                                    - 'null'
                                  pattern: >-
                                    ^(?!\.)(?!.*\.\.)([\w'+-.]*)[\w+-]@([\da-z][\da-z-]*\.)+[a-z]{2,}$
                                type:
                                  type:
                                    - string
                                    - 'null'
                                  description: >-
                                    Kombo exposes type information through this
                                    field. If we don't get any information from
                                    the tool, we will set this to `null`.
                              required:
                                - type
                            default: []
                            description: >-
                              A list of email addresses of the candidate with an
                              optional type. If an email address is invalid, it
                              will be filtered out.
                        required:
                          - id
                          - remote_id
                          - first_name
                          - last_name
                        examples:
                          - id: 26vafvWSRmbhNcxJYqjCzuJg
                            remote_id: '32'
                            first_name: John
                            last_name: Doe
                            email_addresses:
                              - email_address: john.doe@example.com
                                type: PRIVATE
                      job:
                        type:
                          - object
                          - 'null'
                        properties:
                          id:
                            type: string
                            description: >-
                              The globally unique ID of this object generated by
                              Kombo. We recommend using this as a stable primary
                              key for syncing.
                          remote_id:
                            type: string
                            description: >-
                              The raw ID of the object in the remote system. We
                              don't recommend using this as a primary key on
                              your side as it might sometimes be compromised of
                              multiple identifiers if a system doesn't provide a
                              clear primary key.
                          name:
                            type:
                              - string
                              - 'null'
                            description: Title of the job.
                        required:
                          - id
                          - remote_id
                          - name
                        examples:
                          - id: H5daSm8e85Dmvmne3wLeCPhX
                            remote_id: '32'
                            name: Backend Engineer
                    required:
                      - id
                      - remote_id
                      - outcome
                      - rejection_reason_name
                      - candidate
                      - job
                required:
                  - id
                  - remote_id
                  - title
                  - starting_at
                  - ending_at
                  - video_conferencing_url
                  - application_id
                  - stage_id
                  - canceled
                  - remote_created_at
                  - remote_updated_at
                  - remote_data
                  - changed_at
                  - remote_deleted_at
                  - users
                  - application
          required:
            - next
            - results
          examples:
            - next: >-
                eyJwYWdlIjoxMiwibm90ZSI6InRoaXMgaXMganVzdCBhbiBleGFtcGxlIGFuZCBub3QgcmVwcmVzZW50YXRpdmUgZm9yIGEgcmVhbCBjdXJzb3IhIn0=
              results:
                - id: 26vafvWSRmbhNcxJYqjCzuJg
                  remote_id: '32'
                  title: Interview with John Doe
                  starting_at: '2023-06-26T14:30:00.000Z'
                  ending_at: '2023-06-26T15:30:00.000Z'
                  location:
                    city: Berlin
                    country: DE
                    raw: Berlin, Germany
                    state: Berlin
                    street_1: Lohmühlenstraße 65
                    street_2: null
                    zip_code: '12435'
                  video_conferencing_url: https://meet.example.com/interview-abc123
                  application_id: H77fDF8uvEzGNPRubiz5DvQ7
                  stage_id: H5daSm8e85Dmvmne3wLeCPhX
                  canceled: false
                  remote_created_at: '2022-08-07T14:01:29.196Z'
                  remote_updated_at: '2022-08-07T14:01:29.196Z'
                  remote_data: null
                  changed_at: '2022-08-07T14:01:29.196Z'
                  remote_deleted_at: null
                  users:
                    - id: 26vafvWSRmbhNcxJYqjCzuJg
                      remote_id: '32'
                      first_name: John
                      last_name: Doe
                      email: john.doe@kombo.dev
                  application:
                    id: H77fDF8uvEzGNPRubiz5DvQ7
                    remote_id: '32'
                    outcome: HIRED
                    rejection_reason_name: null
                    candidate:
                      id: 26vafvWSRmbhNcxJYqjCzuJg
                      remote_id: '32'
                      first_name: John
                      last_name: Doe
                      email_addresses:
                        - email_address: john.doe@example.com
                          type: PRIVATE
                    job:
                      id: H5daSm8e85Dmvmne3wLeCPhX
                      remote_id: '32'
                      name: Backend Engineer
      required:
        - status
        - data
  responses:
    ErrorResponseATS:
      description: The standard error response with the error codes for the ATS use case.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: string
                enum:
                  - error
              error:
                type: object
                properties:
                  code:
                    type:
                      - string
                      - 'null'
                    enum:
                      - PLATFORM.RATE_LIMIT_EXCEEDED
                      - PLATFORM.CONCURRENCY_LIMIT_EXCEEDED
                      - PLATFORM.INTEGRATION_NOT_FOUND
                      - PLATFORM.INPUT_INVALID
                      - PLATFORM.UNKNOWN_ERROR
                      - PLATFORM.IP_NOT_WHITELISTED
                      - PLATFORM.AUTHENTICATION_INVALID
                      - PLATFORM.TASK_TIMED_OUT
                      - INTEGRATION.PERMISSION_MISSING
                      - INTEGRATION.AUTHENTICATION_INVALID
                      - INTEGRATION.QA_FAILED
                      - INTEGRATION.SETUP_SYNC_PENDING
                      - INTEGRATION.SETUP_INCOMPLETE
                      - INTEGRATION.INACTIVE
                      - INTEGRATION.MODEL_NOT_AVAILABLE
                      - INTEGRATION.MODEL_DISABLED
                      - INTEGRATION.ACTION_NOT_AVAILABLE
                      - INTEGRATION.ACTION_DISABLED
                      - REMOTE.SERVICE_UNAVAILABLE
                      - REMOTE.RATE_LIMIT_EXCEEDED
                      - REMOTE.INPUT_INVALID
                      - REMOTE.UNKNOWN_HTTP_ERROR
                      - ATS.JOB_CLOSED
                      - ATS.APPLICATION_ALREADY_EXISTS
                    example: ATS.JOB_CLOSED
                    description: >-
                      Some errors include an error code that can be used to
                      identify their cause. See the [Error Handling
                      Docs](https://docs.kombo.dev/guides/errors) for more
                      information. For your error handling logic please use the
                      error `code` instead of other properties (e.g. message,
                      http status code, ...).
                  title:
                    type:
                      - string
                      - 'null'
                    description: A static, human-readable label.
                  message:
                    type: string
                    description: >-
                      A dynamic, detailed description of what went wrong in this
                      specific instance.
                  log_url:
                    type:
                      - string
                      - 'null'
                    format: uri
                    description: >-
                      The log page in the Kombo UI lists every interaction with
                      full details. If you need assistance, share that link with
                      our support team.
                required:
                  - code
                  - title
                  - message
                  - log_url
                description: Error details with structured code for programmatic handling.
            required:
              - status
              - error
          examples:
            Error Response:
              description: >-
                When building error handling logic, always use the `code` field
                to identify specific error types programmatically. See the
                complete list of error codes in the
                [docs](https://docs.kombo.dev/guides/errors).
              value:
                status: error
                error:
                  code: INTEGRATION.MODEL_NOT_AVAILABLE
                  title: >-
                    This data model isn't supported for the selected
                    integration.
                  message: >-
                    The "employees" model is not yet available for Greenhouse.
                    Please reach out to Kombo if you need this functionality.
                  log_url: https://app.kombo.dev/my-prod/logs?interactionId=123456
            Minimal Error Response:
              description: >-
                The "message" is always required while other fields can also be
                `null`. See the [docs](https://docs.kombo.dev/guides/errors) for
                more information.
              value:
                status: error
                error:
                  code: null
                  title: null
                  message: The message is always in the response.
                  log_url: null
  securitySchemes:
    ApiKey:
      type: http
      scheme: bearer
      description: >-
        Create an API key on the [Secrets](https://app.kombo.dev/secrets) page
        in the Kombo dashboard.

````