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

# List tickets

> Retrieves a list of tickets in a workspace.


<Warning>
  **Deprecated:** This is a **v1** endpoint. It will continue to work, but we
  recommend migrating to the [v2 equivalent](/api-reference) for improved REST
  compliance (correct HTTP status codes, consistent response envelopes, and
  hyphenated URLs).
</Warning>

<Info>Replace `{your-subdomain}` with your workspace's subdomain. <br /> Learn how to find your subdomain in [Workspace subdomain](/getting-started/workspace-subdomain).</Info>


## OpenAPI

````yaml /bundled-v1/tickets.yaml GET /tickets
openapi: 3.0.3
info:
  title: NeetoDesk APIs
  version: 1.0.0
servers:
  - description: NeetoDesk APIs
    url: https://{your-subdomain}.neetodesk.com/api/v1/public
    variables:
      your-subdomain:
        default: spinkart
        description: >-
          Replace **spinkart** with your [workspace's
          subdomain](/getting-started/workspace-subdomain).
security: []
paths:
  /tickets:
    get:
      summary: List all tickets
      description: |
        Retrieves a list of tickets in a workspace.
      parameters:
        - $ref: '#/components/parameters/page_number_param'
        - $ref: '#/components/parameters/page_size_param'
        - $ref: '#/components/parameters/api_key_header'
        - in: query
          name: status
          schema:
            type: string
            example: open
          description: >
            Filter tickets by their status. Accepts comma-separated values for
            multiple statuses. Default statuses include: `new`, `open`,
            `waiting_on_customer`, `on_hold`, `closed`, `spam`, `trash`. Custom
            statuses created in your organization are also supported. If
            omitted, tickets of all statuses are returned.
      responses:
        '200':
          description: OK - Request succeeded
          content:
            application/json:
              schema:
                type: object
                properties:
                  tickets:
                    type: array
                    items:
                      $ref: '#/components/schemas/Ticket'
                  pagination:
                    $ref: '#/components/schemas/Pagination'
components:
  parameters:
    page_number_param:
      in: query
      name: page_number
      description: >-
        Retrieve paginated results by specifying the desired page number. If
        this parameter is absent, all results will be returned.
      required: false
      schema:
        type: integer
    page_size_param:
      in: query
      name: page_size
      description: >-
        Set the number of results returned in the response. Defaulting to 30
        when omitted.
      required: false
      schema:
        type: integer
    api_key_header:
      in: header
      name: X-Api-Key
      description: >-
        Use the X-Api-Key header to provide your workspace API key. Refer to
        [Authentication](/getting-started/authentication) for more information.
      required: true
      schema:
        type: string
        default: your-api-key
  schemas:
    Ticket:
      type: object
      properties:
        id:
          type: string
          example: aaaabbbb-cccc-dddd-eeee-ffff00003333
        number:
          type: integer
          example: 42
        subject:
          type: string
          example: How to resolve the pending payments
        description:
          type: string
          example: I need your help in resolving the pending payments.
        priority:
          type: string
          example: medium
        status:
          type: string
          example: open
        category:
          type: string
          nullable: true
          example: Questions
        sub_category_one:
          type: string
          nullable: true
          example: Billing
        sub_category_two:
          type: string
          nullable: true
          example: Refund
        group:
          type: string
          nullable: true
          description: Name of the assigned group.
          example: Sales
        tags:
          type: array
          items:
            type: string
          example:
            - refund
            - urgent
        assignee:
          $ref: '#/components/schemas/Assignee'
          nullable: true
          description: The assigned team member. Absent if unassigned.
        customer:
          $ref: '#/components/schemas/Customer'
          nullable: true
        fields:
          type: array
          description: Custom ticket field values.
          items:
            $ref: '#/components/schemas/TicketField'
    Pagination:
      type: object
      properties:
        total_records:
          type: integer
          example: 95
        total_pages:
          type: integer
          example: 4
        current_page_number:
          type: integer
          example: 1
        page_size:
          type: integer
          example: 30
    Assignee:
      type: object
      properties:
        id:
          type: string
          example: aaaabbbb-cccc-dddd-eeee-ffff00001111
        name:
          type: string
          example: Oliver Smith
        email:
          type: string
          example: oliver@example.com
    Customer:
      type: object
      properties:
        id:
          type: string
          example: aaaabbbb-cccc-dddd-eeee-ffff00002222
        name:
          type: string
          example: John Luther
        email:
          type: string
          example: john@example.com
        phone_numbers:
          type: array
          items:
            type: string
          example:
            - '+1234567890'
    TicketField:
      type: object
      properties:
        field_name:
          type: string
          example: Country
        field_value:
          type: string
          example: USA

````