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

# List Custom Tools

> Returns cursor-paginated custom code tools for a workspace.



## OpenAPI

````yaml GET /v1/custom-tools
openapi: 3.0.0
info:
  title: Conduit API
  version: 1.0.0
  description: Public API for Conduit.
servers:
  - url: https://api.conduit.ai
    description: Production
security: []
tags:
  - name: meta
    description: Discovery and API metadata endpoints.
  - name: agents
    description: >-
      V2 chat agent configuration, including instructions, skills, triggers, and
      automation behavior.
  - name: contacts
    description: >-
      Contact profile and contact-scoped related resources such as tickets and
      calls.
  - name: workspaces
    description: Workspaces accessible to the current API token.
  - name: escalations
    description: >-
      Chat escalations that require operator review, including message, proposed
      response, and disposition context when available.
  - name: conversations
    description: >-
      Canonical message threads. Use these endpoints to list threads, inspect
      conversation state, read transcripts, and send replies.
  - name: tickets
    description: >-
      Operational queue items tied to conversations, including ticket-scoped
      transcripts and replies.
  - name: calls
    description: Phone call records, transcripts, summaries, and recordings when available.
  - name: reservations
    description: >-
      PMS reservations synced from the workspace's integrations (Hostaway,
      Guesty, Airbnb, etc.), including guest identity, payment status, and stay
      dates.
  - name: appointments
    description: >-
      Scheduled appointments (bookings) backed by the Conduit booking service.
      Exposes allocation context and the upstream booking-service `external_id`.
  - name: helpdesk_tickets
    description: >-
      Helpdesk tickets mirrored from external helpdesk integrations (Zendesk,
      Pylon, Plain), including requester identity and upstream metadata.
  - name: kb
    description: >-
      Knowledge base search and node management. Nodes represent knowledge base
      entries (files or directories), chunks are the indexed retrieval units
      used by search.
  - name: skills
    description: >-
      Workspace agent skills that can be attached to V2 chat agents.
      Sidebar/global-assistant skills are intentionally excluded.
  - name: custom_tools
    description: >-
      Custom code tools: user-authored Python/JavaScript functions executed in a
      sandbox when an agent calls them. Includes a runtimes endpoint describing
      the entrypoint signature, return shape, and available dependencies per
      language.
paths:
  /v1/custom-tools:
    get:
      tags:
        - custom_tools
      summary: List custom code tools
      description: Returns cursor-paginated custom code tools for a workspace.
      operationId: listCustomTools
      parameters:
        - schema:
            type: string
            example: j57demo8f8x7c9v0n2q4r6t8y1u3i5o
            description: Workspace to query.
          required: true
          name: workspace_id
          in: query
        - schema:
            type: integer
            minimum: 1
            maximum: 100
          required: false
          name: limit
          in: query
        - schema:
            type: string
          required: false
          name: cursor
          in: query
      responses:
        '200':
          description: Workspace custom tools
          content:
            application/json:
              schema:
                type: object
                properties:
                  data:
                    type: array
                    items:
                      type: object
                      properties:
                        id:
                          type: string
                        workspace_id:
                          type: string
                        name:
                          type: string
                        description:
                          type: string
                        language:
                          type: string
                          enum:
                            - python
                            - javascript
                          description: >-
                            Runtime the tool's code is executed in. Determines
                            the entrypoint signature and which dependencies are
                            available (see GET /v1/custom-tools/runtimes).
                        code:
                          type: string
                        parameters:
                          type: object
                          additionalProperties:
                            type: object
                            properties:
                              type:
                                type: string
                                description: >-
                                  JSON-schema-style parameter type, e.g.
                                  `string`, `number`, `boolean`, `object`,
                                  `array`.
                              required:
                                type: boolean
                                description: Whether the agent must supply this parameter.
                              description:
                                type: string
                                description: >-
                                  What this parameter is. Shown to the model to
                                  help it fill the value correctly.
                              execution_message_description:
                                type: string
                                description: >-
                                  Optional per-parameter note surfaced while the
                                  tool is running.
                              enum_values:
                                type: array
                                items:
                                  type: string
                                description: Optional closed set of allowed string values.
                            required:
                              - type
                              - required
                              - description
                          description: >-
                            Parameters the tool accepts, keyed by parameter
                            name. Each becomes a key in the `params` object/dict
                            passed to `main`.
                        execution_message_description:
                          type: string
                          nullable: true
                        enable_globally:
                          type: boolean
                        validated:
                          type: boolean
                        version:
                          type: number
                        created_at:
                          type: string
                      required:
                        - id
                        - workspace_id
                        - name
                        - description
                        - language
                        - code
                        - parameters
                        - execution_message_description
                        - enable_globally
                        - validated
                        - version
                        - created_at
                  next_cursor:
                    type: string
                    nullable: true
                  has_more:
                    type: boolean
                required:
                  - data
                  - next_cursor
                  - has_more
                description: Cursor-paginated custom code tools response.
                example:
                  data:
                    - id: kg77c0dy0mgdpzmqz6tesry8w184002s
                      workspace_id: j57demo8f8x7c9v0n2q4r6t8y1u3i5o
                      name: lookup-order-status
                      description: Look up the fulfillment status of an order by id.
                      language: python
                      code: |-
                        def main(**params):
                            order_id = params["order_id"]
                            # ... fetch status ...
                            return {
                                "message": f"Order {order_id} is shipped",
                                "rawData": {"status": "shipped"},
                            }
                      parameters:
                        order_id:
                          type: string
                          required: true
                          description: The order id to look up.
                      execution_message_description: Looking up order status
                      enable_globally: false
                      validated: true
                      version: 1
                      created_at: '2026-04-01T17:22:10.000Z'
                  next_cursor: page-token
                  has_more: true
        '400':
          description: Invalid request
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                required:
                  - error
                description: Standard error response.
                example:
                  error: Invalid workspace id
        '401':
          description: Unauthorized
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                required:
                  - error
                description: Standard error response.
                example:
                  error: Invalid workspace id
        '403':
          description: Forbidden
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                required:
                  - error
                description: Standard error response.
                example:
                  error: Invalid workspace id
        '429':
          description: Rate limit exceeded
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                required:
                  - error
                description: Standard error response.
                example:
                  error: Invalid workspace id
      security:
        - bearerAuth: []
components:
  securitySchemes:
    bearerAuth:
      type: http
      scheme: bearer
      bearerFormat: API Token
      description: >-
        Conduit API token. Use `Authorization: Bearer <token>`. Read/write
        endpoints require a token with write access.

````