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

# Clone Dashboard

> Creates a deep copy of an existing dashboard including all of its charts. The cloned dashboard can be placed in the same or a different workspace. Authenticate with a tenant JWT or an API key.



## OpenAPI

````yaml post /v1/api/dashboard/clone
openapi: 3.1.0
info:
  title: Upsolve API
  version: 1.4.1
servers:
  - url: https://api.upsolve.ai
security: []
tags: []
paths:
  /v1/api/dashboard/clone:
    post:
      summary: Clone a dashboard
      description: >-
        Creates a deep copy of an existing dashboard including all of its
        charts. The cloned dashboard can be placed in the same or a different
        workspace. Authenticate with a tenant JWT or an API key.
      operationId: PostV1ApiDashboardClone
      requestBody:
        description: POST /v1/api/dashboard/clone Request body
        content:
          application/json:
            schema:
              type: object
              properties:
                apiKey:
                  description: >-
                    Upsolve API key, generated under Account → Developer
                    settings in the Upsolve Hub. Keys are user-scoped: pass
                    organizationId alongside the key to select which org to act
                    on.
                  type: string
                  minLength: 1
                organizationId:
                  type: string
                  description: >-
                    The ID of the organization. Required when using Supabase JWT
                    authentication.
                connectionId:
                  type: string
                  description: The ID of the connection a guest has access to
                sourceDashboardId:
                  type: string
                  format: uuid
                  pattern: >-
                    ^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})$
                  description: ID of the dashboard to clone
                targetWorkspaceId:
                  description: >-
                    Workspace to clone into. If omitted, clones into the same
                    workspace as the source.
                  type: string
                  format: uuid
                  pattern: >-
                    ^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})$
                name:
                  description: >-
                    Name for the cloned dashboard. Defaults to '[original name]
                    (Copy)'.
                  type: string
              required:
                - sourceDashboardId
        required: true
      responses:
        '200':
          description: POST /v1/api/dashboard/clone Positive response
          content:
            application/json:
              schema:
                type: object
                properties:
                  status:
                    type: string
                    const: success
                  data:
                    type: object
                    properties:
                      dashboardId:
                        type: string
                        description: ID of the newly cloned dashboard
                      name:
                        type: string
                        description: Name of the cloned dashboard
                    required:
                      - dashboardId
                      - name
                    additionalProperties: false
                required:
                  - status
                  - data
                additionalProperties: false
        '400':
          description: POST /v1/api/dashboard/clone Negative response
          content:
            application/json:
              schema:
                type: object
                properties:
                  status:
                    type: string
                    const: error
                  error:
                    type: object
                    properties:
                      message:
                        type: string
                      code:
                        type: string
                      details:
                        type: object
                        propertyNames:
                          type: string
                        additionalProperties: {}
                    required:
                      - message
                    additionalProperties: false
                required:
                  - status
                  - error
                additionalProperties: false
      security:
        - APIKEY_2: []
components:
  securitySchemes:
    APIKEY_2:
      type: apiKey
      in: header
      name: authorization

````