> ## 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 course progressions

> Get course progressions

<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/successfactors/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/lms/connectors/successfactors">SAP SuccessFactors</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/cornerstoneondemand/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/lms/connectors/cornerstoneondemand">Cornerstone OnDemand</a></li>
    <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="/lms/connectors/workday">Workday</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="/lms/connectors/sandbox">Kombo Sandbox</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/360learning/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/lms/connectors/360learning">360Learning</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/talentlms/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/lms/connectors/talentlms">TalentLMS</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/udemy/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/lms/connectors/udemy">Udemy Business</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/linkedinlearning/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/lms/connectors/linkedinlearning">LinkedIn Learning</a></li>
    <li class="flex items-center"><img src="https://storage.googleapis.com/kombo-assets/integrations/moodle/icon.svg" height="16px" width="16px" class="m-0 mr-2" /><a href="/lms/connectors/moodle">Moodle</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>

Retrieve all course progressions from the LMS system. Course progressions track users enrollment and completion status in courses.

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 /lms/course-progressions
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:
  /lms/course-progressions:
    get:
      tags:
        - Unified LMS API
      summary: Get course progressions
      description: >-
        Get course progressions


        <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/successfactors/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/lms/connectors/successfactors">SAP SuccessFactors</a></li>

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

        <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="/lms/connectors/workday">Workday</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="/lms/connectors/sandbox">Kombo Sandbox</a></li>

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

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

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

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

        <li class="flex items-center"><img
          src="https://storage.googleapis.com/kombo-assets/integrations/moodle/icon.svg"
          height="16px"
          width="16px"
          class="m-0 mr-2"
        /><a href="/lms/connectors/moodle">Moodle</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>



        Retrieve all course progressions from the LMS system. Course
        progressions track users enrollment and completion status in courses.


        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: GetLmsCourseProgressions
      parameters:
        - in: header
          name: X-Integration-Id
          schema:
            type: string
          description: ID of the integration you want to interact with.
          example: bombohr: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/GetLmsCourseProgressionsParameterCursor'
        - name: page_size
          in: query
          required: false
          description: The number of results to return per page. Maximum is 250.
          schema:
            $ref: '#/components/schemas/GetLmsCourseProgressionsParameterPageSize'
        - 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 |

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

            | `user` | ✗ No | ✗ No |

            | `course_revision` | ✗ 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/GetLmsCourseProgressionsParameterUpdatedAfter'
        - 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/GetLmsCourseProgressionsParameterIncludeDeleted
        - 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/GetLmsCourseProgressionsParameterIgnoreUnsupportedFilters
        - name: ids
          in: query
          required: false
          description: >-
            Filter by a comma-separated list of IDs such as
            `222k7eCGyUdgt2JWZDNnkDs3,B5DVmypWENfU6eMe6gYDyJG3`.
          schema:
            $ref: '#/components/schemas/GetLmsCourseProgressionsParameterIds'
        - name: remote_ids
          in: query
          required: false
          description: Filter by a comma-separated list of remote IDs.
          schema:
            $ref: '#/components/schemas/GetLmsCourseProgressionsParameterRemoteIds'
        - name: user_ids
          in: query
          required: false
          description: >-
            Filter by a comma-separated list of user IDs. We will only return
            progressions that are related to _any_ of the users.
          schema:
            $ref: '#/components/schemas/GetLmsCourseProgressionsParameterUserIds'
        - name: course_ids
          in: query
          required: false
          description: >-
            Filter by a comma-separated list of course IDs. We will only return
            progressions for revisions that belong to _any_ of the courses.
          schema:
            $ref: '#/components/schemas/GetLmsCourseProgressionsParameterCourseIds'
      responses:
        '200':
          description: GET /lms/course-progressions Positive response
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/GetLmsCourseProgressionsPositiveResponse'
              examples:
                example1:
                  value:
                    status: success
                    data:
                      next: >-
                        eyJwYWdlIjoxMiwibm90ZSI6InRoaXMgaXMganVzdCBhbiBleGFtcGxlIGFuZCBub3QgcmVwcmVzZW50YXRpdmUgZm9yIGEgcmVhbCBjdXJzb3IhIn0=
                      results:
                        - id: 26vafvWSRmbhNcxJYqjCzuJg
                          remote_id: progress-12345
                          user_id: 7xPdr68N8kG9EzLwjsN9xyz
                          course_revision_id: 3KMdr68N8kG9EzLwjsN9aoz
                          status: COMPLETED
                          enrolled_at: '2022-08-07T14:01:29.196Z'
                          completed_at: '2022-08-07T14:01:29.196Z'
                          changed_at: '2022-08-07T14:01:29.196Z'
                          remote_deleted_at: null
                          remote_data: null
                          user:
                            id: 26vafvWSRmbhNcxJYqjCzuJg
                            remote_id: '32'
                            first_name: Sarah
                            last_name: Johnson
                            work_email: sarah.johnson@example.com
                          course_revision:
                            id: 3KMdr68N8kG9EzLwjsN9aoz
                            remote_id: revision-12345
                            title: Building LMS integrations with Kombo
                            course:
                              id: 26vafvWSRmbhNcxJYqjCzuJg
                              remote_id: '32'
        default:
          $ref: '#/components/responses/ErrorResponseGeneral'
components:
  schemas:
    GetLmsCourseProgressionsParameterCursor:
      type: string
      description: >-
        An optional cursor string used for pagination. This can be retrieved
        from the `next` property of the previous page response.
    GetLmsCourseProgressionsParameterPageSize:
      type: integer
      format: int64
      minimum: 1
      maximum: 250
      default: 100
      description: The number of results to return per page. Maximum is 250.
    GetLmsCourseProgressionsParameterUpdatedAfter:
      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 |

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

        | `user` | ✗ No | ✗ No |

        | `course_revision` | ✗ 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
    GetLmsCourseProgressionsParameterIncludeDeleted:
      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.
    GetLmsCourseProgressionsParameterIgnoreUnsupportedFilters:
      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.
    GetLmsCourseProgressionsParameterIds:
      type: string
      description: >-
        Filter by a comma-separated list of IDs such as
        `222k7eCGyUdgt2JWZDNnkDs3,B5DVmypWENfU6eMe6gYDyJG3`.
    GetLmsCourseProgressionsParameterRemoteIds:
      type: string
      description: Filter by a comma-separated list of remote IDs.
    GetLmsCourseProgressionsParameterUserIds:
      type: string
      description: >-
        Filter by a comma-separated list of user IDs. We will only return
        progressions that are related to _any_ of the users.
    GetLmsCourseProgressionsParameterCourseIds:
      type: string
      description: >-
        Filter by a comma-separated list of course IDs. We will only return
        progressions for revisions that belong to _any_ of the courses.
    GetLmsCourseProgressionsPositiveResponse:
      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
                    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.
                  user_id:
                    type: string
                    description: >-
                      The Kombo ID of the user this progression relates to. The
                      ID can be used to retrieve the user from the `get users`
                      endpoint.
                  course_revision_id:
                    type: string
                    description: >-
                      The Kombo ID of the revision this progression relates to.
                      The ID can be used to retrieve the revision from the `get
                      courses` endpoint.
                  status:
                    type:
                      - string
                      - 'null'
                    enum:
                      - ENROLLED
                      - IN_PROGRESS
                      - COMPLETED
                      - DROPPED
                    description: Current status of the learner in this course revision.
                  enrolled_at:
                    description: Date when the user enrolled in the course revision.
                    type:
                      - string
                      - 'null'
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  completed_at:
                    description: Date when the user completed the course revision.
                    type:
                      - string
                      - 'null'
                    format: date-time
                    externalDocs:
                      url: >-
                        https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
                  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
                  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.
                  user:
                    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
                        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: The user's first name.
                      last_name:
                        type:
                          - string
                          - 'null'
                        description: The user's last name.
                      work_email:
                        type:
                          - string
                          - 'null'
                        description: The user's work email address.
                    required:
                      - id
                      - remote_id
                      - first_name
                      - last_name
                      - work_email
                    examples:
                      - id: 26vafvWSRmbhNcxJYqjCzuJg
                        remote_id: '32'
                        first_name: Sarah
                        last_name: Johnson
                        work_email: sarah.johnson@example.com
                  course_revision:
                    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
                        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 course revision.
                      course:
                        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.
                        required:
                          - id
                          - remote_id
                    required:
                      - id
                      - remote_id
                      - title
                      - course
                required:
                  - id
                  - remote_id
                  - user_id
                  - course_revision_id
                  - status
                  - enrolled_at
                  - completed_at
                  - changed_at
                  - remote_deleted_at
                  - remote_data
                  - user
                  - course_revision
                examples:
                  - id: 26vafvWSRmbhNcxJYqjCzuJg
                    remote_id: progress-12345
                    user_id: 7xPdr68N8kG9EzLwjsN9xyz
                    course_revision_id: 3KMdr68N8kG9EzLwjsN9aoz
                    status: COMPLETED
                    enrolled_at: '2022-08-07T14:01:29.196Z'
                    completed_at: '2022-08-07T14:01:29.196Z'
                    changed_at: '2022-08-07T14:01:29.196Z'
                    remote_deleted_at: null
                    remote_data: null
                    user:
                      id: 26vafvWSRmbhNcxJYqjCzuJg
                      remote_id: '32'
                      first_name: Sarah
                      last_name: Johnson
                      work_email: sarah.johnson@example.com
                    course_revision:
                      id: 3KMdr68N8kG9EzLwjsN9aoz
                      remote_id: revision-12345
                      title: Building LMS integrations with Kombo
                      course:
                        id: 26vafvWSRmbhNcxJYqjCzuJg
                        remote_id: '32'
          required:
            - next
            - results
          examples:
            - next: >-
                eyJwYWdlIjoxMiwibm90ZSI6InRoaXMgaXMganVzdCBhbiBleGFtcGxlIGFuZCBub3QgcmVwcmVzZW50YXRpdmUgZm9yIGEgcmVhbCBjdXJzb3IhIn0=
              results:
                - id: 26vafvWSRmbhNcxJYqjCzuJg
                  remote_id: progress-12345
                  user_id: 7xPdr68N8kG9EzLwjsN9xyz
                  course_revision_id: 3KMdr68N8kG9EzLwjsN9aoz
                  status: COMPLETED
                  enrolled_at: '2022-08-07T14:01:29.196Z'
                  completed_at: '2022-08-07T14:01:29.196Z'
                  changed_at: '2022-08-07T14:01:29.196Z'
                  remote_deleted_at: null
                  remote_data: null
                  user:
                    id: 26vafvWSRmbhNcxJYqjCzuJg
                    remote_id: '32'
                    first_name: Sarah
                    last_name: Johnson
                    work_email: sarah.johnson@example.com
                  course_revision:
                    id: 3KMdr68N8kG9EzLwjsN9aoz
                    remote_id: revision-12345
                    title: Building LMS integrations with Kombo
                    course:
                      id: 26vafvWSRmbhNcxJYqjCzuJg
                      remote_id: '32'
      required:
        - status
        - data
  responses:
    ErrorResponseGeneral:
      description: The standard error response with just the platform error codes.
      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
                    example: PLATFORM.RATE_LIMIT_EXCEEDED
                    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.

````