openapi.yaml•332 kB
openapi: 3.1.0
info:
  title: Figma API
  version: 0.25.0
  description: |-
    This is the OpenAPI specification for the [Figma REST API](https://www.figma.com/developers/api).
    Note: we are releasing the OpenAPI specification as a beta given the large surface area and complexity of the REST API. If you notice any inaccuracies with the specification, please [file an issue](https://github.com/figma/rest-api-spec/issues).
  termsOfService: https://www.figma.com/developer-terms/
  contact:
    email: support@figma.com
servers:
  - url: https://api.figma.com
externalDocs:
  description: Figma REST API Documentation
  url: https://www.figma.com/developers/api
tags:
  - name: Files
    description: Get file JSON, images, and other file-related content.
    externalDocs:
      description: File endpoints documentation
      url: https://www.figma.com/developers/api#files
  - name: Comments
    description: Interact with file comments.
    externalDocs:
      description: Comment endpoints documentation
      url: https://www.figma.com/developers/api#comments
  - name: Comment Reactions
    description: Interact with reactions to file comments.
    externalDocs:
      description: Comment endpoints documentation
      url: https://www.figma.com/developers/api#comments
  - name: Projects
    description: Get information about projects and files in teams.
    externalDocs:
      description: Project endpoints documentation
      url: https://www.figma.com/developers/api#projects
  - name: Users
    description: Get information about the currently authenticated user.
    externalDocs:
      description: User endpoints documentation
      url: https://www.figma.com/developers/api#users
  - name: Components
    description: Get information about published components.
    externalDocs:
      description: Component and style endpoints documentation
      url: https://www.figma.com/developers/api#library-items
  - name: Component Sets
    description: Get information about published component sets.
    externalDocs:
      description: Component and style endpoints documentation
      url: https://www.figma.com/developers/api#library-items
  - name: Styles
    description: Get information about published styles.
    externalDocs:
      description: Component and style endpoints documentation
      url: https://www.figma.com/developers/api#library-items
  - name: Webhooks
    description: Interact with team webhooks as a team admin.
    externalDocs:
      description: Webhook endpoints documentation
      url: https://www.figma.com/developers/api#webhooks_v2
  - name: Activity Logs
    description: Get activity logs as an organization admin.
    externalDocs:
      description: Activity log endpoints documentation
      url: https://www.figma.com/developers/api#activity_logs
  - name: Payments
    description: Get purchase information for your Community resources.
    externalDocs:
      description: Payment endpoints documentation
      url: https://www.figma.com/developers/api#payments
  - name: Variables
    description: Interact with variables in an Enterprise organization.
    externalDocs:
      description: Variables endpoints documentation
      url: https://www.figma.com/developers/api#variables
  - name: Dev Resources
    description: Interact with dev resources in Figma Dev Mode.
    externalDocs:
      description: Dev resource endpoints documentation
      url: https://www.figma.com/developers/api#dev-resources
  - name: Library Analytics
    description: Get analytics data for your published libraries.
    externalDocs:
      description: Library analytics endpoints documentation
      url: https://www.figma.com/developers/api#library-analytics
paths:
  /v1/files/{file_key}:
    get:
      tags:
        - Files
      summary: Get file JSON
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: |-
        Returns the document identified by `file_key` as a JSON object. The file key can be parsed from any Figma file url: `https://www.figma.com/file/{file_key}/{title}`.
        The `document` property contains a node of type `DOCUMENT`.
        The `components` property contains a mapping from node IDs to component metadata. This is to help you determine which components each instance comes from.
      operationId: getFile
      parameters:
        - name: file_key
          in: path
          description: File to export JSON from. This can be a file key or branch key. Use
            `GET /v1/files/:key` with the `branch_data` query param to get the
            branch key.
          required: true
          schema:
            type: string
        - name: version
          in: query
          description: A specific version ID to get. Omitting this will get the current
            version of the file.
          schema:
            type: string
        - name: ids
          in: query
          description: |-
            Comma separated list of nodes that you care about in the document. If specified, only a subset of the document will be returned corresponding to the nodes listed, their children, and everything between the root node and the listed nodes.
            Note: There may be other nodes included in the returned JSON that are outside the ancestor chains of the desired nodes. The response may also include dependencies of anything in the nodes' subtrees. For example, if a node subtree contains an instance of a local component that lives elsewhere in that file, that component and its ancestor chain will also be included.
            For historical reasons, top-level canvas nodes are always returned, regardless of whether they are listed in the `ids` parameter. This quirk may be removed in a future version of the API.
          schema:
            type: string
        - name: depth
          in: query
          description: Positive integer representing how deep into the document tree to
            traverse. For example, setting this to 1 returns only Pages, setting
            it to 2 returns Pages and all top level objects on each page. Not
            setting this parameter returns all nodes.
          schema:
            type: number
        - name: geometry
          in: query
          description: Set to "paths" to export vector data.
          schema:
            type: string
        - name: plugin_data
          in: query
          description: A comma separated list of plugin IDs and/or the string "shared".
            Any data present in the document written by those plugins will be
            included in the result in the `pluginData` and `sharedPluginData`
            properties.
          schema:
            type: string
        - name: branch_data
          in: query
          description: "Returns branch metadata for the requested file. If the file is a
            branch, the main file's key will be included in the returned
            response. If the file has branches, their metadata will be included
            in the returned response. Default: false."
          schema:
            type: boolean
            default: false
      responses:
        "200":
          $ref: "#/components/responses/GetFileResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/nodes:
    get:
      tags:
        - Files
      summary: Get file JSON for specific nodes
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: |-
        Returns the nodes referenced to by `ids` as a JSON object. The nodes are retrieved from the Figma file referenced to by `file_key`.
        The node ID and file key can be parsed from any Figma node url: `https://www.figma.com/file/{file_key}/{title}?node-id={id}`
        The `name`, `lastModified`, `thumbnailUrl`, `editorType`, and `version` attributes are all metadata of the specified file.
        The `linkAccess` field describes the file link share permission level. There are 5 types of permissions a shared link can have: `"inherit"`, `"view"`, `"edit"`, `"org_view"`, and `"org_edit"`. `"inherit"` is the default permission applied to files created in a team project, and will inherit the project's permissions. `"org_view"` and `"org_edit"` restrict the link to org users.
        The `document` attribute contains a Node of type `DOCUMENT`.
        The `components` key contains a mapping from node IDs to component metadata. This is to help you determine which components each instance comes from.
        By default, no vector data is returned. To return vector data, pass the geometry=paths parameter to the endpoint.
        Each node can also inherit properties from applicable styles. The styles key contains a mapping from style IDs to style metadata.
        Important: the nodes map may contain values that are `null`. This may be due to the node id not existing within the specified file.
      operationId: getFileNodes
      parameters:
        - name: file_key
          in: path
          description: File to export JSON from. This can be a file key or branch key. Use
            `GET /v1/files/:key` with the `branch_data` query param to get the
            branch key.
          required: true
          schema:
            type: string
        - name: ids
          in: query
          description: A comma separated list of node IDs to retrieve and convert.
          required: true
          schema:
            type: string
        - name: version
          in: query
          description: A specific version ID to get. Omitting this will get the current
            version of the file.
          schema:
            type: string
        - name: depth
          in: query
          description: |-
            Positive integer representing how deep into the node tree to traverse. For example, setting this to 1 will return only the children directly underneath the desired nodes. Not setting this parameter returns all nodes.
            Note: this parameter behaves differently from the same parameter in the `GET /v1/files/:key` endpoint. In this endpoint, the depth will be counted starting from the desired node rather than the document root node.
          schema:
            type: number
        - name: geometry
          in: query
          description: Set to "paths" to export vector data.
          schema:
            type: string
        - name: plugin_data
          in: query
          description: A comma separated list of plugin IDs and/or the string "shared".
            Any data present in the document written by those plugins will be
            included in the result in the `pluginData` and `sharedPluginData`
            properties.
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetFileNodesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/images/{file_key}:
    get:
      tags:
        - Files
      summary: Render images of file nodes
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: |
        Renders images from a file.
        If no error occurs, `"images"` will be populated with a map from node IDs to URLs of the rendered images, and `"status"` will be omitted. The image assets will expire after 30 days. Images up to 32 megapixels can be exported. Any images that are larger will be scaled down.
        Important: the image map may contain values that are `null`. This indicates that rendering of that specific node has failed. This may be due to the node id not existing, or other reasons such has the node having no renderable components. It is guaranteed that any node that was requested for rendering will be represented in this map whether or not the render succeeded.
        To render multiple images from the same file, use the `ids` query parameter to specify multiple node ids.
        ```
        GET /v1/images/:key?ids=1:2,1:3,1:4
        ```
      operationId: getImages
      parameters:
        - name: file_key
          in: path
          description: File to export images from. This can be a file key or branch key.
            Use `GET /v1/files/:key` with the `branch_data` query param to get
            the branch key.
          required: true
          schema:
            type: string
        - name: ids
          in: query
          description: A comma separated list of node IDs to render.
          required: true
          schema:
            type: string
        - name: version
          in: query
          description: A specific version ID to get. Omitting this will get the current
            version of the file.
          schema:
            type: string
        - name: scale
          in: query
          description: A number between 0.01 and 4, the image scaling factor.
          schema:
            type: number
            minimum: 0.01
            maximum: 4
        - name: format
          in: query
          description: A string enum for the image output format.
          schema:
            type: string
            enum:
              - jpg
              - png
              - svg
              - pdf
            default: png
        - name: svg_outline_text
          in: query
          description: |-
            Whether text elements are rendered as outlines (vector paths) or as `<text>` elements in SVGs.
            Rendering text elements as outlines guarantees that the text looks exactly the same in the SVG as it does in the browser/inside Figma.
            Exporting as `<text>` allows text to be selectable inside SVGs and generally makes the SVG easier to read. However, this relies on the browser's rendering engine which can vary between browsers and/or operating systems. As such, visual accuracy is not guaranteed as the result could look different than in Figma.
          schema:
            type: boolean
            default: true
        - name: svg_include_id
          in: query
          description: Whether to include id attributes for all SVG elements. Adds the
            layer name to the `id` attribute of an svg element.
          schema:
            type: boolean
            default: false
        - name: svg_include_node_id
          in: query
          description: Whether to include node id attributes for all SVG elements. Adds
            the node id to a `data-node-id` attribute of an svg element.
          schema:
            type: boolean
            default: false
        - name: svg_simplify_stroke
          in: query
          description: Whether to simplify inside/outside strokes and use stroke attribute
            if possible instead of `<mask>`.
          schema:
            type: boolean
            default: true
        - name: contents_only
          in: query
          description: Whether content that overlaps the node should be excluded from
            rendering. Passing false (i.e., rendering overlaps) may increase
            processing time, since more of the document must be included in
            rendering.
          schema:
            type: boolean
            default: true
        - name: use_absolute_bounds
          in: query
          description: Use the full dimensions of the node regardless of whether or not it
            is cropped or the space around it is empty. Use this to export text
            nodes without cropping.
          schema:
            type: boolean
            default: false
      responses:
        "200":
          $ref: "#/components/responses/GetImagesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/images:
    get:
      tags:
        - Files
      summary: Get image fills
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: |-
        Returns download links for all images present in image fills in a document. Image fills are how Figma represents any user supplied images. When you drag an image into Figma, we create a rectangle with a single fill that represents the image, and the user is able to transform the rectangle (and properties on the fill) as they wish.
        This endpoint returns a mapping from image references to the URLs at which the images may be download. Image URLs will expire after no more than 14 days. Image references are located in the output of the GET files endpoint under the `imageRef` attribute in a `Paint`.
      operationId: getImageFills
      parameters:
        - name: file_key
          in: path
          description: File to get image URLs from. This can be a file key or branch key.
            Use `GET /v1/files/:key` with the `branch_data` query param to get
            the branch key.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetImageFillsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/teams/{team_id}/projects:
    get:
      tags:
        - Projects
      summary: Get projects in a team
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: "You can use this endpoint to get a list of all the Projects within
        the specified team. This will only return projects visible to the
        authenticated user or owner of the developer token. Note: it is not
        currently possible to programmatically obtain the team id of a user just
        from a token. To obtain a team id, navigate to a team page of a team you
        are a part of. The team id will be present in the URL after the word
        team and before your team name."
      operationId: getTeamProjects
      parameters:
        - name: team_id
          in: path
          description: ID of the team to list projects from
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetTeamProjectsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/projects/{project_id}/files:
    get:
      tags:
        - Projects
      summary: Get files in a project
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a list of all the Files within the specified project.
      operationId: getProjectFiles
      parameters:
        - name: project_id
          in: path
          description: ID of the project to list files from
          required: true
          schema:
            type: string
        - name: branch_data
          in: query
          description: Returns branch metadata in the response for each main file with a
            branch inside the project.
          schema:
            type: boolean
            default: false
      responses:
        "200":
          $ref: "#/components/responses/GetProjectFilesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/versions:
    get:
      tags:
        - Files
      summary: Get versions of a file
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: This endpoint fetches the version history of a file, allowing you
        to see the progression of a file over time. You can then use this
        information to render a specific version of the file, via another
        endpoint.
      operationId: getFileVersions
      parameters:
        - name: file_key
          in: path
          description: File to get version history from. This can be a file key or branch
            key. Use `GET /v1/files/:key` with the `branch_data` query param to
            get the branch key.
          required: true
          schema:
            type: string
        - name: page_size
          in: query
          description: The number of items returned in a page of the response. If not
            included, `page_size` is `30`.
          schema:
            type: number
            maximum: 50
        - name: before
          in: query
          description: A version ID for one of the versions in the history. Gets versions
            before this ID. Used for paginating. If the response is not
            paginated, this link returns the same data in the current response.
          schema:
            type: number
        - name: after
          in: query
          description: A version ID for one of the versions in the history. Gets versions
            after this ID. Used for paginating. If the response is not
            paginated, this property is not included.
          schema:
            type: number
      responses:
        "200":
          $ref: "#/components/responses/GetFileVersionsResponse"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/comments:
    get:
      tags:
        - Comments
      summary: Get comments in a file
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Gets a list of comments left on the file.
      operationId: getComments
      parameters:
        - name: file_key
          in: path
          description: File to get comments from. This can be a file key or branch key.
            Use `GET /v1/files/:key` with the `branch_data` query param to get
            the branch key.
          required: true
          schema:
            type: string
        - name: as_md
          in: query
          description: If enabled, will return comments as their markdown equivalents when
            applicable.
          schema:
            type: boolean
      responses:
        "200":
          $ref: "#/components/responses/GetCommentsResponse"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
    post:
      tags:
        - Comments
      summary: Add a comment to a file
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_comments:write
      description: Posts a new comment on the file.
      operationId: postComment
      parameters:
        - name: file_key
          in: path
          description: File to add comments in. This can be a file key or branch key. Use
            `GET /v1/files/:key` with the `branch_data` query param to get the
            branch key.
          required: true
          schema:
            type: string
      requestBody:
        description: Comment to post.
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                message:
                  type: string
                  description: The text contents of the comment to post.
                comment_id:
                  type: string
                  description: The ID of the comment to reply to, if any. This must be a root
                    comment. You cannot reply to other replies (a comment that
                    has a parent_id).
                client_meta:
                  description: The position where to place the comment.
                  oneOf:
                    - $ref: "#/components/schemas/Vector"
                    - $ref: "#/components/schemas/FrameOffset"
                    - $ref: "#/components/schemas/Region"
                    - $ref: "#/components/schemas/FrameOffsetRegion"
              required:
                - message
      responses:
        "200":
          $ref: "#/components/responses/PostCommentResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/comments/{comment_id}:
    delete:
      tags:
        - Comments
      summary: Delete a comment
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_comments:write
      description: Deletes a specific comment. Only the person who made the comment is
        allowed to delete it.
      operationId: deleteComment
      parameters:
        - name: file_key
          in: path
          description: File to delete comment from. This can be a file key or branch key.
            Use `GET /v1/files/:key` with the `branch_data` query param to get
            the branch key.
          required: true
          schema:
            type: string
        - name: comment_id
          in: path
          description: Comment id of comment to delete
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/DeleteCommentResponse"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/comments/{comment_id}/reactions:
    get:
      tags:
        - Comment Reactions
      summary: Get reactions for a comment
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Gets a paginated list of reactions left on the comment.
      operationId: getCommentReactions
      parameters:
        - name: file_key
          in: path
          description: File to get comment containing reactions from. This can be a file
            key or branch key. Use `GET /v1/files/:key` with the `branch_data`
            query param to get the branch key.
          required: true
          schema:
            type: string
        - name: comment_id
          in: path
          description: ID of comment to get reactions from.
          required: true
          schema:
            type: string
        - name: cursor
          in: query
          description: Cursor for pagination, retrieved from the response of the previous
            call.
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetCommentReactionsResponse"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
    post:
      tags:
        - Comment Reactions
      summary: Add a reaction to a comment
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_comments:write
      description: Posts a new comment reaction on a file comment.
      operationId: postCommentReaction
      parameters:
        - name: file_key
          in: path
          description: File to post comment reactions to. This can be a file key or branch
            key. Use `GET /v1/files/:key` with the `branch_data` query param to
            get the branch key.
          required: true
          schema:
            type: string
        - name: comment_id
          in: path
          description: ID of comment to react to.
          required: true
          schema:
            type: string
      requestBody:
        description: Reaction to post.
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                emoji:
                  $ref: "#/components/schemas/Emoji"
              required:
                - emoji
      responses:
        "200":
          $ref: "#/components/responses/PostCommentReactionResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
    delete:
      tags:
        - Comment Reactions
      summary: Delete a reaction
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_comments:write
      description: Deletes a specific comment reaction. Only the person who made the
        reaction is allowed to delete it.
      operationId: deleteCommentReaction
      parameters:
        - name: file_key
          in: path
          description: File to delete comment reaction from. This can be a file key or
            branch key. Use `GET /v1/files/:key` with the `branch_data` query
            param to get the branch key.
          required: true
          schema:
            type: string
        - name: comment_id
          in: path
          description: ID of comment to delete reaction from.
          required: true
          schema:
            type: string
        - name: emoji
          in: query
          required: true
          schema:
            $ref: "#/components/schemas/Emoji"
      responses:
        "200":
          $ref: "#/components/responses/DeleteCommentReactionResponse"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/me:
    get:
      tags:
        - Users
      summary: Get current user
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Returns the user information for the currently authenticated user.
      operationId: getMe
      responses:
        "200":
          $ref: "#/components/responses/GetMeResponse"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/teams/{team_id}/components:
    get:
      tags:
        - Components
      summary: Get team components
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a paginated list of published components within a team library.
      operationId: getTeamComponents
      parameters:
        - name: team_id
          in: path
          description: Id of the team to list components from.
          required: true
          schema:
            type: string
        - name: page_size
          in: query
          description: Number of items to return in a paged list of results. Defaults to 30.
          schema:
            type: number
            default: 30
        - name: after
          in: query
          description: Cursor indicating which id after which to start retrieving
            components for. Exclusive with before. The cursor value is an
            internally tracked integer that doesn't correspond to any Ids.
          schema:
            type: number
        - name: before
          in: query
          description: Cursor indicating which id before which to start retrieving
            components for. Exclusive with after. The cursor value is an
            internally tracked integer that doesn't correspond to any Ids.
          schema:
            type: number
      responses:
        "200":
          $ref: "#/components/responses/GetTeamComponentsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/components:
    get:
      tags:
        - Components
      summary: Get file components
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a list of published components within a file library.
      operationId: getFileComponents
      parameters:
        - name: file_key
          in: path
          description: File to list components from. This must be a main file key, not a
            branch key, as it is not possible to publish from branches.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetFileComponentsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/components/{key}:
    get:
      tags:
        - Components
      summary: Get component
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get metadata on a component by key.
      operationId: getComponent
      parameters:
        - name: key
          in: path
          description: The unique identifier of the component.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetComponentResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/teams/{team_id}/component_sets:
    get:
      tags:
        - Component Sets
      summary: Get team component sets
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a paginated list of published component sets within a team library.
      operationId: getTeamComponentSets
      parameters:
        - name: team_id
          in: path
          description: Id of the team to list component sets from.
          required: true
          schema:
            type: string
        - name: page_size
          in: query
          description: Number of items to return in a paged list of results. Defaults to 30.
          schema:
            type: number
            default: 30
        - name: after
          in: query
          description: Cursor indicating which id after which to start retrieving
            component sets for. Exclusive with before. The cursor value is an
            internally tracked integer that doesn't correspond to any Ids.
          schema:
            type: number
        - name: before
          in: query
          description: Cursor indicating which id before which to start retrieving
            component sets for. Exclusive with after. The cursor value is an
            internally tracked integer that doesn't correspond to any Ids.
          schema:
            type: number
      responses:
        "200":
          $ref: "#/components/responses/GetTeamComponentSetsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/component_sets:
    get:
      tags:
        - Component Sets
      summary: Get file component sets
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a list of published component sets within a file library.
      operationId: getFileComponentSets
      parameters:
        - name: file_key
          in: path
          description: File to list component sets from. This must be a main file key, not
            a branch key, as it is not possible to publish from branches.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetFileComponentSetsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/component_sets/{key}:
    get:
      tags:
        - Component Sets
      summary: Get component set
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get metadata on a published component set by key.
      operationId: getComponentSet
      parameters:
        - name: key
          in: path
          description: The unique identifier of the component set.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetComponentSetResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/teams/{team_id}/styles:
    get:
      tags:
        - Styles
      summary: Get team styles
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a paginated list of published styles within a team library.
      operationId: getTeamStyles
      parameters:
        - name: team_id
          in: path
          description: Id of the team to list styles from.
          required: true
          schema:
            type: string
        - name: page_size
          in: query
          description: Number of items to return in a paged list of results. Defaults to 30.
          schema:
            type: number
            default: 30
        - name: after
          in: query
          description: Cursor indicating which id after which to start retrieving styles
            for. Exclusive with before. The cursor value is an internally
            tracked integer that doesn't correspond to any Ids.
          schema:
            type: number
        - name: before
          in: query
          description: Cursor indicating which id before which to start retrieving styles
            for. Exclusive with after. The cursor value is an internally tracked
            integer that doesn't correspond to any Ids.
          schema:
            type: number
      responses:
        "200":
          $ref: "#/components/responses/GetTeamStylesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/files/{file_key}/styles:
    get:
      tags:
        - Styles
      summary: Get file styles
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a list of published styles within a file library.
      operationId: getFileStyles
      parameters:
        - name: file_key
          in: path
          description: File to list styles from. This must be a main file key, not a
            branch key, as it is not possible to publish from branches.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetFileStylesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v1/styles/{key}:
    get:
      tags:
        - Styles
      summary: Get style
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get metadata on a style by key.
      operationId: getStyle
      parameters:
        - name: key
          in: path
          description: The unique identifier of the style.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetStyleResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrMessage"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v2/webhooks:
    post:
      tags:
        - Webhooks
      summary: Create a webhook
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - webhooks:write
      description: Create a new webhook which will call the specified endpoint when
        the event triggers. By default, this webhook will automatically send a
        PING event to the endpoint when it is created. If this behavior is not
        desired, you can create the webhook and set the status to PAUSED and
        reactivate it later.
      operationId: postWebhook
      requestBody:
        description: The webhook to create.
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                event_type:
                  $ref: "#/components/schemas/WebhookV2Event"
                team_id:
                  type: string
                  description: Team id to receive updates about
                endpoint:
                  type: string
                  description: The HTTP endpoint that will receive a POST request when the event
                    triggers. Max length 2048 characters.
                passcode:
                  type: string
                  description: String that will be passed back to your webhook endpoint to verify
                    that it is being called by Figma. Max length 100 characters.
                status:
                  $ref: "#/components/schemas/WebhookV2Status"
                  description: State of the webhook, including any error state it may be in
                description:
                  type: string
                  description: User provided description or name for the webhook. Max length 150
                    characters.
              required:
                - event_type
                - team_id
                - endpoint
                - passcode
      callbacks:
        ping:
          "{$request.body#/endpoint}":
            post:
              summary: Ping event
              description: Triggers when a webhook is created. Used for debugging. Cannot be
                subscribed to, all webhooks will receive `PING` events.
              security:
                - PersonalAccessToken: []
                - OAuth2:
                    - webhooks:write
              requestBody:
                description: The webhook will send a PING event to the endpoint when it is
                  created.
                required: true
                content:
                  application/json:
                    schema:
                      $ref: "#/components/schemas/WebhookPingPayload"
              responses:
                "200":
                  description: |-
                    Your server implementation should return this HTTP status code
                                        if the data was received successfully
                "400":
                  description: If your server returns a non-200 status code, or takes too long,
                    the Figma API will treat this as an error. Figma retries
                    failed requests 3 times with an exponential backoff
                    strategy.
        fileUpdate:
          "{$request.body#/endpoint}":
            post:
              summary: File update event
              description: Triggers within 30 minutes of editing inactivity in a file.
              security:
                - PersonalAccessToken: []
                - OAuth2:
                    - webhooks:write
              requestBody:
                description: This is useful when you want to stay up-to-date with the contents
                  of a file. For example, you could generate a static website
                  from your Figma document and keep it always up-to-date with
                  this webhook.
                required: true
                content:
                  application/json:
                    schema:
                      $ref: "#/components/schemas/WebhookFileUpdatePayload"
              responses:
                "200":
                  description: |-
                    Your server implementation should return this HTTP status code
                                        if the data was received successfully
                "400":
                  description: If your server returns a non-200 status code, or takes too long,
                    the Figma API will treat this as an error. Figma retries
                    failed requests 3 times with an exponential backoff
                    strategy.
        fileVersionUpdate:
          "{$request.body#/endpoint}":
            post:
              summary: File version update event
              description: Triggers whenever a named version is created in the version history
                of a file.
              security:
                - PersonalAccessToken: []
                - OAuth2:
                    - webhooks:write
              requestBody:
                description: This is useful for workflow integrations. For example, suppose you
                  have a Figma document with icon assets. When the design for an
                  asset is updated and ready to publish, you can have a member
                  of the team tag that version in the version history and then
                  use this webhook event to generate and deploy your new asset
                  version.
                required: true
                content:
                  application/json:
                    schema:
                      $ref: "#/components/schemas/WebhookFileVersionUpdatePayload"
              responses:
                "200":
                  description: |-
                    Your server implementation should return this HTTP status code
                                        if the data was received successfully
                "400":
                  description: If your server returns a non-200 status code, or takes too long,
                    the Figma API will treat this as an error. Figma retries
                    failed requests 3 times with an exponential backoff
                    strategy.
        fileDelete:
          "{$request.body#/endpoint}":
            post:
              summary: File delete event
              description: Triggers whenever a file has been deleted. If you subscribe to
                `FILE_UPDATE`, you automatically get these notifications. Note
                that this does not trigger on all files within a folder, if the
                folder is deleted.
              security:
                - PersonalAccessToken: []
                - OAuth2:
                    - webhooks:write
              requestBody:
                description: Note if a folder is deleted, this event will not trigger for files
                  within the folder.
                required: true
                content:
                  application/json:
                    schema:
                      $ref: "#/components/schemas/WebhookFileDeletePayload"
              responses:
                "200":
                  description: |-
                    Your server implementation should return this HTTP status code
                                        if the data was received successfully
                "400":
                  description: If your server returns a non-200 status code, or takes too long,
                    the Figma API will treat this as an error. Figma retries
                    failed requests 3 times with an exponential backoff
                    strategy.
        libraryPublish:
          "{$request.body#/endpoint}":
            post:
              summary: Library publish event
              description: Triggers whenever a library file is published.
              security:
                - PersonalAccessToken: []
                - OAuth2:
                    - webhooks:write
              requestBody:
                description: |-
                  This is useful for workflow integrations. This webhook could integrate with Slack, Asana or Jira, notifying designers to modify their assets when new components are published.
                  Note: when a library is published, a separate `LIBRARY_PUBLISH` event will be triggered for each type of library asset (components, styles, and variables) that has changes.
                required: true
                content:
                  application/json:
                    schema:
                      $ref: "#/components/schemas/WebhookLibraryPublishPayload"
              responses:
                "200":
                  description: |-
                    Your server implementation should return this HTTP status code
                                        if the data was received successfully
                "400":
                  description: If your server returns a non-200 status code, or takes too long,
                    the Figma API will treat this as an error. Figma retries
                    failed requests 3 times with an exponential backoff
                    strategy.
        fileComment:
          "{$request.body#/endpoint}":
            post:
              summary: File comment event
              description: Triggers when someone comments on a file.
              security:
                - PersonalAccessToken: []
                - OAuth2:
                    - webhooks:write
              requestBody:
                description: This webhook could integrate with Asana or Jira and automatically
                  create tasks whenever a user comments. It could also integrate
                  with Slack and notify mentioned users.
                required: true
                content:
                  application/json:
                    schema:
                      $ref: "#/components/schemas/WebhookFileCommentPayload"
              responses:
                "200":
                  description: |-
                    Your server implementation should return this HTTP status code
                                        if the data was received successfully
                "400":
                  description: If your server returns a non-200 status code, or takes too long,
                    the Figma API will treat this as an error. Figma retries
                    failed requests 3 times with an exponential backoff
                    strategy.
      responses:
        "200":
          $ref: "#/components/responses/PostWebhookResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v2/webhooks/{webhook_id}:
    get:
      tags:
        - Webhooks
      summary: Get a webhook
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Get a webhook by ID.
      operationId: getWebhook
      parameters:
        - name: webhook_id
          in: path
          description: ID of webhook to get
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetWebhookResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
    put:
      tags:
        - Webhooks
      summary: Update a webhook
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - webhooks:write
      description: Update a webhook by ID.
      operationId: putWebhook
      parameters:
        - name: webhook_id
          in: path
          description: ID of webhook to update
          required: true
          schema:
            type: string
      requestBody:
        description: The webhook to update.
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                event_type:
                  $ref: "#/components/schemas/WebhookV2Event"
                endpoint:
                  type: string
                  description: The HTTP endpoint that will receive a POST request when the event
                    triggers. Max length 2048 characters.
                passcode:
                  type: string
                  description: String that will be passed back to your webhook endpoint to verify
                    that it is being called by Figma. Max length 100 characters.
                status:
                  $ref: "#/components/schemas/WebhookV2Status"
                  description: State of the webhook, including any error state it may be in
                description:
                  type: string
                  description: User provided description or name for the webhook. Max length 150
                    characters.
              required:
                - event_type
                - team_id
                - endpoint
                - passcode
      responses:
        "200":
          $ref: "#/components/responses/PutWebhookResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
    delete:
      tags:
        - Webhooks
      summary: Delete a webhook
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - webhooks:write
      description: Deletes the specified webhook. This operation cannot be reversed.
      operationId: deleteWebhook
      parameters:
        - name: webhook_id
          in: path
          description: ID of webhook to delete
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/DeleteWebhookResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v2/teams/{team_id}/webhooks:
    get:
      tags:
        - Webhooks
      summary: Get team webhooks
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Returns all webhooks registered under the specified team.
      operationId: getTeamWebhooks
      parameters:
        - name: team_id
          in: path
          description: ID of team to get webhooks for
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetTeamWebhooksResponse"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrMessage"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrMessage"
  /v2/webhooks/{webhook_id}/requests:
    get:
      tags:
        - Webhooks
      summary: Get webhook requests
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - files:read
      description: Returns all webhook requests sent within the last week. Useful for
        debugging.
      operationId: getWebhookRequests
      parameters:
        - name: webhook_id
          in: path
          description: The id of the webhook subscription you want to see events from
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetWebhookRequestsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrMessage"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrMessage"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/activity_logs:
    get:
      tags:
        - Activity Logs
      summary: Get activity logs
      security:
        - OrgOAuth2:
            - org:activity_log_read
      description: Returns a list of activity log events
      operationId: getActivityLogs
      parameters:
        - name: events
          description: Event type(s) to include in the response. Can have multiple values
            separated by comma. All events are returned by default.
          in: query
          schema:
            type: string
        - name: start_time
          description: Unix timestamp of the least recent event to include. This param
            defaults to one year ago if unspecified.
          in: query
          schema:
            type: number
        - name: end_time
          description: Unix timestamp of the most recent event to include. This param
            defaults to the current timestamp if unspecified.
          in: query
          schema:
            type: number
        - name: limit
          description: Maximum number of events to return. This param defaults to 1000 if
            unspecified.
          in: query
          schema:
            type: number
        - name: order
          description: Event order by timestamp. This param can be either "asc" (default)
            or "desc".
          in: query
          schema:
            type: string
            enum:
              - asc
              - desc
            default: asc
      responses:
        "200":
          $ref: "#/components/responses/GetActivityLogsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/payments:
    get:
      tags:
        - Payments
      summary: Get payments
      security:
        - PersonalAccessToken: []
      description: |-
        There are two methods to query for a user's payment information on a plugin, widget, or Community file. The first method, using plugin payment tokens, is typically used when making queries from a plugin's or widget's code. The second method, providing a user ID and resource ID, is typically used when making queries from anywhere else.
        Note that you can only query for resources that you own. In most cases, this means that you can only query resources that you originally created.
      operationId: getPayments
      parameters:
        - name: plugin_payment_token
          in: query
          description: Short-lived token returned from "getPluginPaymentTokenAsync" in the
            plugin payments API and used to authenticate to this endpoint. Read
            more about generating this token through "Calling the Payments REST
            API from a plugin or widget" below.
          schema:
            type: string
        - name: user_id
          in: query
          description: The ID of the user to query payment information about. You can get
            the user ID by having the user OAuth2 to the Figma REST API.
          schema:
            type: number
        - name: community_file_id
          in: query
          description: The ID of the Community file to query a user's payment information
            on. You can get the Community file ID from the file's Community page
            (look for the number after "file/" in the URL). Provide exactly one
            of "community_file_id", "plugin_id", or "widget_id".
          schema:
            type: number
        - name: plugin_id
          in: query
          description: The ID of the plugin to query a user's payment information on. You
            can get the plugin ID from the plugin's manifest, or from the
            plugin's Community page (look for the number after "plugin/" in the
            URL). Provide exactly one of "community_file_id", "plugin_id", or
            "widget_id".
          schema:
            type: number
        - name: widget_id
          in: query
          description: The ID of the widget to query a user's payment information on. You
            can get the widget ID from the widget's manifest, or from the
            widget's Community page (look for the number after "widget/" in the
            URL). Provide exactly one of "community_file_id", "plugin_id", or
            "widget_id".
          schema:
            type: number
      responses:
        "200":
          $ref: "#/components/responses/GetPaymentsResponse"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/files/{file_key}/variables/local:
    get:
      tags:
        - Variables
      summary: Get local variables
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_variables:read
      description: "**This API is available to full members of Enterprise orgs.**
        The `GET /v1/files/:file_key/variables/local` endpoint lets you
        enumerate local variables created in the file and remote variables used
        in the file. Remote variables are referenced by their `subscribed_id`.
        As a part of the Variables related API additions, the `GET
        /v1/files/:file_key` endpoint now returns a `boundVariables` property,
        containing the `variableId` of the bound variable. The `GET
        /v1/files/:file_key/variables/local` endpoint can be used to get the
        full variable or variable collection object.
        Note that `GET /v1/files/:file_key/variables/published` does not
        return modes. Instead, you will need to use the `GET
        /v1/files/:file_key/variables/local` endpoint, in the same file, to
        examine the mode values.
        \        "
      operationId: getLocalVariables
      parameters:
        - name: file_key
          in: path
          description: File to get variables from. This can be a file key or branch key.
            Use `GET /v1/files/:key` with the `branch_data` query param to get
            the branch key.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetLocalVariablesResponse"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/files/{file_key}/variables/published:
    get:
      tags:
        - Variables
      summary: Get published variables
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_variables:read
      description: |-
        **This API is available to full members of Enterprise orgs.**
        The `GET /v1/files/:file_key/variables/published` endpoint returns the variables that are published from the given file.
        The response for this endpoint contains some key differences compared to the `GET /v1/files/:file_key/variables/local` endpoint:
        - Each variable and variable collection contains a `subscribed_id`.
        - Modes are omitted for published variable collections
        Published variables have two ids: an id that is assigned in the file where it is created (`id`), and an id that is used by subscribing files (`subscribed_id`). The `id` and `key` are stable over the lifetime of the variable. The `subscribed_id` changes every time the variable is modified and published. The same is true for variable collections.
        The `updatedAt` fields are ISO 8601 timestamps that indicate the last time that a change to a variable was published. For variable collections, this timestamp will change any time a variable in the collection is changed.
      operationId: getPublishedVariables
      parameters:
        - name: file_key
          in: path
          description: File to get variables from. This must be a main file key, not a
            branch key, as it is not possible to publish from branches.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetPublishedVariablesResponse"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/files/{file_key}/variables:
    post:
      tags:
        - Variables
      summary: Create/modify/delete variables
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_variables:write
      description: |-
        **This API is available to full members of Enterprise orgs with Editor seats.**
        The `POST /v1/files/:file_key/variables` endpoint lets you bulk create, update, and delete variables and variable collections.
        The request body supports the following 4 top-level arrays. Changes from these arrays will be applied in the below order, and within each array, by array order.
        - **variableCollections**: For creating, updating, and deleting variable collections
        - **variableModes**: For creating, updating, and deleting modes within variable collections
          - Each collection can have a maximum of 40 modes
          - Mode names cannot be longer than 40 characters
        - **variables**: For creating, updating, and deleting variables
          - Each collection can have a maximum of 5000 variables
          - Variable names must be unique within a collection and cannot contain certain special characters such as `.{}`
        - **variableModeValues**: For setting a variable value under a specific mode.
          - When setting aliases, a variable cannot be aliased to itself or form an alias cycle
        Temporary ids can be used to reference an object later in the same POST request body. They can be used at create time in the `id` property of variable collections, modes, variables, and in the `initialModeId` property of variable collections. They are scoped to a single request body, and must be unique within the body. The mapping of temporary ids to real ids is returned in the response.
        This endpoint has the following key behaviors:
        - The request body must be 4MB or less.
        - Must include an `action` property for collections, modes, and variables to tell the API whether to create, update, or delete the object.
        - When creating a collection, mode, or variable, you can include a temporary `id` that can be referenced in dependent objects in the same request. For example, you can create a new collection with the id `"my_new_collection"`. You can then set `variableCollectionId` to `"my_new_collection"` in new modes or variables. Temporary ids must be unique in the request body.
        - New collections always come with one mode. You can reference this mode by setting `initialModeId` to a temporary id in the request body. This is useful if you want to set values for variables in the mode in the `variableModeValues` array.
          - The `tempIdToRealId` array returns a mapping of the temporary ids in the request, to the real ids of the newly created objects.
        - When adding new modes or variables, default variable values will be applied, consistent with what happens in the UI.
        - Everything to be created, updated, and deleted in the request body is treated as one atomic operation. If there is any validation failure, you will get a 400 status code response, and no changes will be persisted.
        - You will not be able to update remote variables or variable collections. You can only update variables in the file where they were originally created.
      operationId: postVariables
      parameters:
        - name: file_key
          in: path
          description: File to modify variables in. This can be a file key or branch key.
            Use `GET /v1/files/:key` with the `branch_data` query param to get
            the branch key.
          required: true
          schema:
            type: string
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              minProperties: 1
              properties:
                variableCollections:
                  type: array
                  description: For creating, updating, and deleting variable collections.
                  items:
                    $ref: "#/components/schemas/VariableCollectionChange"
                variableModes:
                  type: array
                  description: For creating, updating, and deleting modes within variable
                    collections.
                  items:
                    $ref: "#/components/schemas/VariableModeChange"
                variables:
                  type: array
                  description: For creating, updating, and deleting variables.
                  items:
                    $ref: "#/components/schemas/VariableChange"
                variableModeValues:
                  type: array
                  description: For setting a specific value, given a variable and a mode.
                  items:
                    $ref: "#/components/schemas/VariableModeValue"
      responses:
        "200":
          $ref: "#/components/responses/PostVariablesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/files/{file_key}/dev_resources:
    get:
      tags:
        - Dev Resources
      summary: Get dev resources
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_dev_resources:read
      description: Get dev resources in a file
      operationId: getDevResources
      parameters:
        - name: file_key
          in: path
          description: The file to get the dev resources from. This must be a main file
            key, not a branch key.
          required: true
          schema:
            type: string
        - name: node_ids
          in: query
          description: Comma separated list of nodes that you care about in the document.
            If specified, only dev resources attached to these nodes will be
            returned. If not specified, all dev resources in the file will be
            returned.
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetDevResourcesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/dev_resources:
    post:
      tags:
        - Dev Resources
      summary: Create dev resources
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_dev_resources:write
      description: |-
        Bulk create dev resources across multiple files.
        Dev resources that are successfully created will show up in the links_created array in the response.
        If there are any dev resources that cannot be created, you may still get a 200 response. These resources will show up in the errors array. Some reasons a dev resource cannot be created include:
        - Resource points to a `file_key` that cannot be found.
        - The node already has the maximum of 10 dev resources.
        - Another dev resource for the node has the same url.
      operationId: postDevResources
      requestBody:
        description: A list of dev resources that you want to create.
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                dev_resources:
                  type: array
                  description: An array of dev resources.
                  items:
                    type: object
                    properties:
                      name:
                        type: string
                        description: The name of the dev resource.
                      url:
                        type: string
                        description: The URL of the dev resource.
                      file_key:
                        type: string
                        description: The file key where the dev resource belongs.
                      node_id:
                        type: string
                        description: The target node to attach the dev resource to.
                    required:
                      - name
                      - url
                      - file_key
                      - node_id
              required:
                - dev_resources
      responses:
        "200":
          $ref: "#/components/responses/PostDevResourcesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
    put:
      tags:
        - Dev Resources
      summary: Update dev resources
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_dev_resources:write
      description: |-
        Bulk update dev resources across multiple files.
        Ids for dev resources that are successfully updated will show up in the `links_updated` array in the response.
        If there are any dev resources that cannot be updated, you may still get a 200 response. These resources will show up in the `errors` array.
      operationId: putDevResources
      requestBody:
        description: A list of dev resources that you want to update.
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                dev_resources:
                  type: array
                  description: An array of dev resources.
                  items:
                    type: object
                    properties:
                      id:
                        type: string
                        description: Unique identifier of the dev resource
                      name:
                        type: string
                        description: The name of the dev resource.
                      url:
                        type: string
                        description: The URL of the dev resource.
                    required:
                      - id
              required:
                - dev_resources
      responses:
        "200":
          $ref: "#/components/responses/PutDevResourcesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/files/{file_key}/dev_resources/{dev_resource_id}:
    delete:
      tags:
        - Dev Resources
      summary: Delete dev resource
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - file_dev_resources:write
      description: Delete a dev resource from a file
      operationId: deleteDevResource
      parameters:
        - name: file_key
          in: path
          description: The file to delete the dev resource from. This must be a main file
            key, not a branch key.
          required: true
          schema:
            type: string
        - name: dev_resource_id
          in: path
          description: The id of the dev resource to delete.
          required: true
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/DeleteDevResourceResponse"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "404":
          $ref: "#/components/responses/NotFoundErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/analytics/libraries/{file_key}/component/actions:
    get:
      tags:
        - Library Analytics
      summary: Get library analytics component action data.
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - library_analytics:read
      description: Returns a list of library analytics component actions data broken
        down by the requested dimension.
      operationId: getLibraryAnalyticsComponentActions
      parameters:
        - name: file_key
          in: path
          description: File key of the library to fetch analytics data for.
          required: true
          schema:
            type: string
        - name: cursor
          description: Cursor indicating what page of data to fetch. Obtained from prior
            API call.
          in: query
          schema:
            type: string
        - name: group_by
          description: A dimension to group returned analytics data by.
          required: true
          in: query
          schema:
            type: string
            enum:
              - component
              - team
        - name: start_date
          description: ISO 8601 date string (YYYY-MM-DD) of the earliest week to include.
            Dates are rounded back to the nearest start of a week. Defaults to
            one year prior.
          in: query
          schema:
            type: string
        - name: end_date
          description: ISO 8601 date string (YYYY-MM-DD) of the latest week to include.
            Dates are rounded forward to the nearest end of a week. Defaults to
            the latest computed week.
          in: query
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetLibraryAnalyticsComponentActionsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/analytics/libraries/{file_key}/component/usages:
    get:
      tags:
        - Library Analytics
      summary: Get library analytics component usage data.
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - library_analytics:read
      description: Returns a list of library analytics component usage data broken
        down by the requested dimension.
      operationId: getLibraryAnalyticsComponentUsages
      parameters:
        - name: file_key
          in: path
          description: File key of the library to fetch analytics data for.
          required: true
          schema:
            type: string
        - name: cursor
          description: Cursor indicating what page of data to fetch. Obtained from prior
            API call.
          in: query
          schema:
            type: string
        - name: group_by
          description: A dimension to group returned analytics data by.
          required: true
          in: query
          schema:
            type: string
            enum:
              - component
              - file
      responses:
        "200":
          $ref: "#/components/responses/GetLibraryAnalyticsComponentUsagesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/analytics/libraries/{file_key}/style/actions:
    get:
      tags:
        - Library Analytics
      summary: Get library analytics style action data.
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - library_analytics:read
      description: Returns a list of library analytics style actions data broken down
        by the requested dimension.
      operationId: getLibraryAnalyticsStyleActions
      parameters:
        - name: file_key
          in: path
          description: File key of the library to fetch analytics data for.
          required: true
          schema:
            type: string
        - name: cursor
          description: Cursor indicating what page of data to fetch. Obtained from prior
            API call.
          in: query
          schema:
            type: string
        - name: group_by
          description: A dimension to group returned analytics data by.
          required: true
          in: query
          schema:
            type: string
            enum:
              - style
              - team
        - name: start_date
          description: ISO 8601 date string (YYYY-MM-DD) of the earliest week to include.
            Dates are rounded back to the nearest start of a week. Defaults to
            one year prior.
          in: query
          schema:
            type: string
        - name: end_date
          description: ISO 8601 date string (YYYY-MM-DD) of the latest week to include.
            Dates are rounded forward to the nearest end of a week. Defaults to
            the latest computed week.
          in: query
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetLibraryAnalyticsStyleActionsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/analytics/libraries/{file_key}/style/usages:
    get:
      tags:
        - Library Analytics
      summary: Get library analytics style usage data.
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - library_analytics:read
      description: Returns a list of library analytics style usage data broken down by
        the requested dimension.
      operationId: getLibraryAnalyticsStyleUsages
      parameters:
        - name: file_key
          in: path
          description: File key of the library to fetch analytics data for.
          required: true
          schema:
            type: string
        - name: cursor
          description: Cursor indicating what page of data to fetch. Obtained from prior
            API call.
          in: query
          schema:
            type: string
        - name: group_by
          description: A dimension to group returned analytics data by.
          required: true
          in: query
          schema:
            type: string
            enum:
              - style
              - file
      responses:
        "200":
          $ref: "#/components/responses/GetLibraryAnalyticsStyleUsagesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/analytics/libraries/{file_key}/variable/actions:
    get:
      tags:
        - Library Analytics
      summary: Get library analytics variable action data.
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - library_analytics:read
      description: Returns a list of library analytics variable actions data broken
        down by the requested dimension.
      operationId: getLibraryAnalyticsVariableActions
      parameters:
        - name: file_key
          in: path
          description: File key of the library to fetch analytics data for.
          required: true
          schema:
            type: string
        - name: cursor
          description: Cursor indicating what page of data to fetch. Obtained from prior
            API call.
          in: query
          schema:
            type: string
        - name: group_by
          description: A dimension to group returned analytics data by.
          required: true
          in: query
          schema:
            type: string
            enum:
              - variable
              - team
        - name: start_date
          description: ISO 8601 date string (YYYY-MM-DD) of the earliest week to include.
            Dates are rounded back to the nearest start of a week. Defaults to
            one year prior.
          in: query
          schema:
            type: string
        - name: end_date
          description: ISO 8601 date string (YYYY-MM-DD) of the latest week to include.
            Dates are rounded forward to the nearest end of a week. Defaults to
            the latest computed week.
          in: query
          schema:
            type: string
      responses:
        "200":
          $ref: "#/components/responses/GetLibraryAnalyticsVariableActionsResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
  /v1/analytics/libraries/{file_key}/variable/usages:
    get:
      tags:
        - Library Analytics
      summary: Get library analytics variable usage data.
      security:
        - PersonalAccessToken: []
        - OAuth2:
            - library_analytics:read
      description: Returns a list of library analytics variable usage data broken down
        by the requested dimension.
      operationId: getLibraryAnalyticsVariableUsages
      parameters:
        - name: file_key
          in: path
          description: File key of the library to fetch analytics data for.
          required: true
          schema:
            type: string
        - name: cursor
          description: Cursor indicating what page of data to fetch. Obtained from prior
            API call.
          in: query
          schema:
            type: string
        - name: group_by
          description: A dimension to group returned analytics data by.
          required: true
          in: query
          schema:
            type: string
            enum:
              - variable
              - file
      responses:
        "200":
          $ref: "#/components/responses/GetLibraryAnalyticsVariableUsagesResponse"
        "400":
          $ref: "#/components/responses/BadRequestErrorResponseWithErrorBoolean"
        "401":
          $ref: "#/components/responses/UnauthorizedErrorResponseWithErrorBoolean"
        "403":
          $ref: "#/components/responses/ForbiddenErrorResponseWithErrorBoolean"
        "429":
          $ref: "#/components/responses/TooManyRequestsErrorResponseWithErrorBoolean"
        "500":
          $ref: "#/components/responses/InternalServerErrorResponseWithErrorBoolean"
components:
  securitySchemes:
    PersonalAccessToken:
      type: apiKey
      name: X-Figma-Token
      in: header
    OAuth2:
      type: oauth2
      flows:
        authorizationCode:
          authorizationUrl: https://www.figma.com/oauth
          tokenUrl: https://api.figma.com/v1/oauth/token
          refreshUrl: https://api.figma.com/v1/oauth/refresh
          scopes:
            files:read: Read files, projects, users, versions, comments, components &
              styles, and webhooks.
            file_variables:read: "Read variables in Figma file. Note: this is only available
              to members in Enterprise organizations."
            file_variables:write: "Write to variables in Figma file. Note: this is only
              available to members in Enterprise organizations."
            file_comments:write: Post and delete comments and comment reactions in files.
            file_dev_resources:read: Read dev resources in files.
            file_dev_resources:write: Write to dev resources in files.
            library_analytics:read: Read library analytics data.
            webhooks:write: Create and manage webhooks.
    OrgOAuth2:
      type: oauth2
      flows:
        authorizationCode:
          authorizationUrl: https://www.figma.com/oauth
          tokenUrl: https://api.figma.com/v1/oauth/token
          refreshUrl: https://api.figma.com/v1/oauth/refresh
          scopes:
            org:activity_log_read: Read activity logs in the organization.
  schemas:
    IsLayerTrait:
      type: object
      properties:
        id:
          type: string
          description: A string uniquely identifying this node within the document.
        name:
          type: string
          description: The name given to the node by the user in the tool.
        type:
          type: string
          description: The type of the node
        visible:
          type: boolean
          description: Whether or not the node is visible on the canvas.
          default: true
        locked:
          type: boolean
          description: If true, layer is locked and cannot be edited
          default: false
        isFixed:
          type: boolean
          description: Whether the layer is fixed while the parent is scrolling
          deprecated: true
          default: false
        scrollBehavior:
          type: string
          description: How layer should be treated when the frame is resized
          enum:
            - SCROLLS
            - FIXED
            - STICKY_SCROLLS
          default: SCROLLS
        rotation:
          type: number
          description: The rotation of the node, if not 0.
          default: 0
        componentPropertyReferences:
          type: object
          additionalProperties:
            type: string
          description: A mapping of a layer's property to component property name of
            component properties attached to this node. The component property
            name can be used to look up more information on the corresponding
            component's or component set's componentPropertyDefinitions.
        pluginData:
          description: Data written by plugins that is visible only to the plugin that
            wrote it. Requires the `pluginData` to include the ID of the plugin.
        sharedPluginData:
          description: Data written by plugins that is visible to all plugins. Requires
            the `pluginData` parameter to include the string "shared".
        boundVariables:
          type: object
          description: A mapping of field to the variables applied to this field. Most
            fields will only map to a single `VariableAlias`. However, for
            properties like `fills`, `strokes`, `size`, `componentProperties`,
            and `textRangeFills`, it is possible to have multiple variables
            bound to the field.
          properties:
            size:
              type: object
              properties:
                x:
                  $ref: "#/components/schemas/VariableAlias"
                y:
                  $ref: "#/components/schemas/VariableAlias"
            individualStrokeWeights:
              type: object
              properties:
                top:
                  $ref: "#/components/schemas/VariableAlias"
                bottom:
                  $ref: "#/components/schemas/VariableAlias"
                left:
                  $ref: "#/components/schemas/VariableAlias"
                right:
                  $ref: "#/components/schemas/VariableAlias"
            characters:
              $ref: "#/components/schemas/VariableAlias"
            itemSpacing:
              $ref: "#/components/schemas/VariableAlias"
            paddingLeft:
              $ref: "#/components/schemas/VariableAlias"
            paddingRight:
              $ref: "#/components/schemas/VariableAlias"
            paddingTop:
              $ref: "#/components/schemas/VariableAlias"
            paddingBottom:
              $ref: "#/components/schemas/VariableAlias"
            visible:
              $ref: "#/components/schemas/VariableAlias"
            topLeftRadius:
              $ref: "#/components/schemas/VariableAlias"
            topRightRadius:
              $ref: "#/components/schemas/VariableAlias"
            bottomLeftRadius:
              $ref: "#/components/schemas/VariableAlias"
            bottomRightRadius:
              $ref: "#/components/schemas/VariableAlias"
            minWidth:
              $ref: "#/components/schemas/VariableAlias"
            maxWidth:
              $ref: "#/components/schemas/VariableAlias"
            minHeight:
              $ref: "#/components/schemas/VariableAlias"
            maxHeight:
              $ref: "#/components/schemas/VariableAlias"
            counterAxisSpacing:
              $ref: "#/components/schemas/VariableAlias"
            opacity:
              $ref: "#/components/schemas/VariableAlias"
            fontFamily:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            fontSize:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            fontStyle:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            fontWeight:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            letterSpacing:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            lineHeight:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            paragraphSpacing:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            paragraphIndent:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            fills:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            strokes:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            componentProperties:
              type: object
              additionalProperties:
                $ref: "#/components/schemas/VariableAlias"
            textRangeFills:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            effects:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
            layoutGrids:
              type: array
              items:
                $ref: "#/components/schemas/VariableAlias"
        explicitVariableModes:
          type: object
          description: A mapping of variable collection ID to mode ID representing the
            explicitly set modes for this node.
          additionalProperties:
            type: string
      required:
        - id
        - name
        - type
        - scrollBehavior
    HasChildrenTrait:
      type: object
      properties:
        children:
          type: array
          description: An array of nodes that are direct children of this node
          items:
            $ref: "#/components/schemas/SubcanvasNode"
      required:
        - children
    HasLayoutTrait:
      type: object
      properties:
        absoluteBoundingBox:
          description: Bounding box of the node in absolute space coordinates.
          oneOf:
            - $ref: "#/components/schemas/Rectangle"
            - type: "null"
        absoluteRenderBounds:
          description: The actual bounds of a node accounting for drop shadows, thick
            strokes, and anything else that may fall outside the node's regular
            bounding box defined in `x`, `y`, `width`, and `height`. The `x` and
            `y` inside this property represent the absolute position of the node
            on the page. This value will be `null` if the node is invisible.
          oneOf:
            - $ref: "#/components/schemas/Rectangle"
            - type: "null"
        preserveRatio:
          type: boolean
          description: Keep height and width constrained to same ratio.
          default: false
        constraints:
          $ref: "#/components/schemas/LayoutConstraint"
          description: Horizontal and vertical layout constraints for node.
        relativeTransform:
          $ref: "#/components/schemas/Transform"
          description: The top two rows of a matrix that represents the 2D transform of
            this node relative to its parent. The bottom row of the matrix is
            implicitly always (0, 0, 1). Use to transform coordinates in
            geometry. Only present if `geometry=paths` is passed.
        size:
          $ref: "#/components/schemas/Vector"
          description: Width and height of element. This is different from the width and
            height of the bounding box in that the absolute bounding box
            represents the element after scaling and rotation. Only present if
            `geometry=paths` is passed.
        layoutAlign:
          type: string
          description: |-
            
            Determines if the layer should stretch along the parent's counter axis. This property is only provided for direct children of auto-layout frames.
            - `INHERIT`
            - `STRETCH`
            In previous versions of auto layout, determined how the layer is aligned inside an auto-layout frame. This property is only provided for direct children of auto-layout frames.
            - `MIN`
            - `CENTER`
            - `MAX`
            - `STRETCH`
            In horizontal auto-layout frames, "MIN" and "MAX" correspond to "TOP" and "BOTTOM". In vertical auto-layout frames, "MIN" and "MAX" correspond to "LEFT" and "RIGHT".
          enum:
            - INHERIT
            - STRETCH
            - MIN
            - CENTER
            - MAX
        layoutGrow:
          type: number
          description: This property is applicable only for direct children of auto-layout
            frames, ignored otherwise. Determines whether a layer should stretch
            along the parent's primary axis. A `0` corresponds to a fixed size
            and `1` corresponds to stretch.
          enum:
            - 0
            - 1
          default: 0
        layoutPositioning:
          type: string
          description: Determines whether a layer's size and position should be determined
            by auto-layout settings or manually adjustable.
          enum:
            - AUTO
            - ABSOLUTE
          default: AUTO
        minWidth:
          type: number
          description: The minimum width of the frame. This property is only applicable
            for auto-layout frames or direct children of auto-layout frames.
          default: 0
        maxWidth:
          type: number
          description: The maximum width of the frame. This property is only applicable
            for auto-layout frames or direct children of auto-layout frames.
          default: 0
        minHeight:
          type: number
          description: The minimum height of the frame. This property is only applicable
            for auto-layout frames or direct children of auto-layout frames.
          default: 0
        maxHeight:
          type: number
          description: The maximum height of the frame. This property is only applicable
            for auto-layout frames or direct children of auto-layout frames.
          default: 0
        layoutSizingHorizontal:
          type: string
          description: |-
            The horizontal sizing setting on this auto-layout frame or frame child.
            - `FIXED`
            - `HUG`: only valid on auto-layout frames and text nodes
            - `FILL`: only valid on auto-layout frame children
          enum:
            - FIXED
            - HUG
            - FILL
        layoutSizingVertical:
          type: string
          description: |-
            The vertical sizing setting on this auto-layout frame or frame child.
            - `FIXED`
            - `HUG`: only valid on auto-layout frames and text nodes
            - `FILL`: only valid on auto-layout frame children
          enum:
            - FIXED
            - HUG
            - FILL
      required:
        - absoluteBoundingBox
        - absoluteRenderBounds
    HasFramePropertiesTrait:
      type: object
      properties:
        clipsContent:
          type: boolean
          description: Whether or not this node clip content outside of its bounds
        background:
          type: array
          items:
            $ref: "#/components/schemas/Paint"
          description: Background of the node. This is deprecated, as backgrounds for
            frames are now in the `fills` field.
          deprecated: true
        backgroundColor:
          $ref: "#/components/schemas/RGBA"
          description: Background color of the node. This is deprecated, as frames now
            support more than a solid color as a background. Please use the
            `fills` field instead.
          deprecated: true
        layoutGrids:
          type: array
          description: An array of layout grids attached to this node (see layout grids
            section for more details). GROUP nodes do not have this attribute
          items:
            $ref: "#/components/schemas/LayoutGrid"
        overflowDirection:
          type: string
          description: Whether a node has primary axis scrolling, horizontal or vertical.
          enum:
            - HORIZONTAL_SCROLLING
            - VERTICAL_SCROLLING
            - HORIZONTAL_AND_VERTICAL_SCROLLING
            - NONE
          default: NONE
        layoutMode:
          type: string
          description: Whether this layer uses auto-layout to position its children.
          enum:
            - NONE
            - HORIZONTAL
            - VERTICAL
          default: NONE
        primaryAxisSizingMode:
          type: string
          description: Whether the primary axis has a fixed length (determined by the
            user) or an automatic length (determined by the layout engine). This
            property is only applicable for auto-layout frames.
          enum:
            - FIXED
            - AUTO
          default: AUTO
        counterAxisSizingMode:
          type: string
          description: Whether the counter axis has a fixed length (determined by the
            user) or an automatic length (determined by the layout engine). This
            property is only applicable for auto-layout frames.
          enum:
            - FIXED
            - AUTO
          default: AUTO
        primaryAxisAlignItems:
          type: string
          description: Determines how the auto-layout frame's children should be aligned
            in the primary axis direction. This property is only applicable for
            auto-layout frames.
          enum:
            - MIN
            - CENTER
            - MAX
            - SPACE_BETWEEN
          default: MIN
        counterAxisAlignItems:
          type: string
          description: Determines how the auto-layout frame's children should be aligned
            in the counter axis direction. This property is only applicable for
            auto-layout frames.
          enum:
            - MIN
            - CENTER
            - MAX
            - BASELINE
          default: MIN
        paddingLeft:
          type: number
          description: The padding between the left border of the frame and its children.
            This property is only applicable for auto-layout frames.
          default: 0
        paddingRight:
          type: number
          description: The padding between the right border of the frame and its children.
            This property is only applicable for auto-layout frames.
          default: 0
        paddingTop:
          type: number
          description: The padding between the top border of the frame and its children.
            This property is only applicable for auto-layout frames.
          default: 0
        paddingBottom:
          type: number
          description: The padding between the bottom border of the frame and its
            children. This property is only applicable for auto-layout frames.
          default: 0
        itemSpacing:
          type: number
          description: The distance between children of the frame. Can be negative. This
            property is only applicable for auto-layout frames.
          default: 0
        itemReverseZIndex:
          type: boolean
          description: Determines the canvas stacking order of layers in this frame. When
            true, the first layer will be draw on top. This property is only
            applicable for auto-layout frames.
          default: false
        strokesIncludedInLayout:
          type: boolean
          description: 'Determines whether strokes are included in layout calculations.
            When true, auto-layout frames behave like css "box-sizing:
            border-box". This property is only applicable for auto-layout
            frames.'
          default: false
        layoutWrap:
          type: string
          description: Whether this auto-layout frame has wrapping enabled.
          enum:
            - NO_WRAP
            - WRAP
        counterAxisSpacing:
          type: number
          description: 'The distance between wrapped tracks of an auto-layout frame. This
            property is only applicable for auto-layout frames with `layoutWrap:
            "WRAP"`'
        counterAxisAlignContent:
          type: string
          description: 'Determines how the auto-layout frame’s wrapped tracks should be
            aligned in the counter axis direction. This property is only
            applicable for auto-layout frames with `layoutWrap: "WRAP"`.'
          enum:
            - AUTO
            - SPACE_BETWEEN
          default: AUTO
      required:
        - clipsContent
    HasBlendModeAndOpacityTrait:
      type: object
      properties:
        blendMode:
          $ref: "#/components/schemas/BlendMode"
          description: How this node blends with nodes behind it in the scene (see blend
            mode section for more details)
        opacity:
          type: number
          description: Opacity of the node
          default: 1
          minimum: 0
          maximum: 1
      required:
        - blendMode
    HasExportSettingsTrait:
      type: object
      properties:
        exportSettings:
          type: array
          items:
            $ref: "#/components/schemas/ExportSetting"
          description: An array of export settings representing images to export from the
            node.
    HasGeometryTrait:
      allOf:
        - $ref: "#/components/schemas/MinimalFillsTrait"
        - $ref: "#/components/schemas/MinimalStrokesTrait"
        - type: object
          properties:
            fillOverrideTable:
              type: object
              additionalProperties:
                oneOf:
                  - $ref: "#/components/schemas/PaintOverride"
                  - type: "null"
              description: Map from ID to PaintOverride for looking up fill overrides. To see
                which regions are overriden, you must use the `geometry=paths`
                option. Each path returned may have an `overrideID` which maps
                to this table.
            fillGeometry:
              type: array
              items:
                $ref: "#/components/schemas/Path"
              description: Only specified if parameter `geometry=paths` is used. An array of
                paths representing the object fill.
            strokeGeometry:
              type: array
              items:
                $ref: "#/components/schemas/Path"
              description: Only specified if parameter `geometry=paths` is used. An array of
                paths representing the object stroke.
            strokeCap:
              type: string
              description: A string enum describing the end caps of vector paths.
              enum:
                - NONE
                - ROUND
                - SQUARE
                - LINE_ARROW
                - TRIANGLE_ARROW
                - DIAMOND_FILLED
                - CIRCLE_FILLED
                - TRIANGLE_FILLED
                - WASHI_TAPE_1
                - WASHI_TAPE_2
                - WASHI_TAPE_3
                - WASHI_TAPE_4
                - WASHI_TAPE_5
                - WASHI_TAPE_6
              default: NONE
            strokeMiterAngle:
              type: number
              description: Only valid if `strokeJoin` is "MITER". The corner angle, in
                degrees, below which `strokeJoin` will be set to "BEVEL" to
                avoid super sharp corners. By default this is 28.96 degrees.
              default: 28.96
    MinimalFillsTrait:
      type: object
      properties:
        fills:
          type: array
          items:
            $ref: "#/components/schemas/Paint"
          description: An array of fill paints applied to the node.
        styles:
          type: object
          additionalProperties:
            type: string
          description: A mapping of a StyleType to style ID (see Style) of styles present
            on this node. The style ID can be used to look up more information
            about the style in the top-level styles field.
      required:
        - fills
    MinimalStrokesTrait:
      type: object
      properties:
        strokes:
          type: array
          items:
            $ref: "#/components/schemas/Paint"
          description: An array of stroke paints applied to the node.
        strokeWeight:
          type: number
          description: The weight of strokes on the node.
          default: 1
        strokeAlign:
          type: string
          description: |-
            Position of stroke relative to vector outline, as a string enum
            - `INSIDE`: stroke drawn inside the shape boundary
            - `OUTSIDE`: stroke drawn outside the shape boundary
            - `CENTER`: stroke drawn centered along the shape boundary
          enum:
            - INSIDE
            - OUTSIDE
            - CENTER
        strokeJoin:
          type: string
          description: A string enum with value of "MITER", "BEVEL", or "ROUND",
            describing how corners in vector paths are rendered.
          enum:
            - MITER
            - BEVEL
            - ROUND
          default: MITER
        strokeDashes:
          type: array
          items:
            type: number
          description: |-
            An array of floating point numbers describing the pattern of dash length and gap lengths that the vector stroke will use when drawn.
            For example a value of [1, 2] indicates that the stroke will be drawn with a dash of length 1 followed by a gap of length 2, repeated.
    IndividualStrokesTrait:
      type: object
      properties:
        individualStrokeWeights:
          $ref: "#/components/schemas/StrokeWeights"
          description: An object including the top, bottom, left, and right stroke
            weights. Only returned if individual stroke weights are used.
    CornerTrait:
      type: object
      properties:
        cornerRadius:
          type: number
          description: Radius of each corner if a single radius is set for all corners
          default: 0
        cornerSmoothing:
          type: number
          description: A value that lets you control how "smooth" the corners are. Ranges
            from 0 to 1. 0 is the default and means that the corner is perfectly
            circular. A value of 0.6 means the corner matches the iOS 7
            "squircle" icon shape. Other values produce various other curves.
        rectangleCornerRadii:
          type: array
          items:
            type: number
          minItems: 4
          maxItems: 4
          description: |-
            Array of length 4 of the radius of each corner of the frame, starting in the top left and proceeding clockwise.
            Values are given in the order top-left, top-right, bottom-right, bottom-left.
    HasEffectsTrait:
      type: object
      properties:
        effects:
          type: array
          items:
            $ref: "#/components/schemas/Effect"
          description: An array of effects attached to this node (see effects section for
            more details)
      required:
        - effects
    HasMaskTrait:
      type: object
      properties:
        isMask:
          type: boolean
          description: Does this node mask sibling nodes in front of it?
          default: false
        maskType:
          type: string
          description: |-
            If this layer is a mask, this property describes the operation used to mask the layer's siblings. The value may be one of the following:
            - ALPHA: the mask node's alpha channel will be used to determine the opacity of each pixel in the masked result.
            - VECTOR: if the mask node has visible fill paints, every pixel inside the node's fill regions will be fully visible in the masked result. If the mask has visible stroke paints, every pixel inside the node's stroke regions will be fully visible in the masked result.
            - LUMINANCE: the luminance value of each pixel of the mask node will be used to determine the opacity of that pixel in the masked result.
          enum:
            - ALPHA
            - VECTOR
            - LUMINANCE
        isMaskOutline:
          type: boolean
          description: True if maskType is VECTOR. This field is deprecated; use maskType
            instead.
          default: false
          deprecated: true
    ComponentPropertiesTrait:
      type: object
      properties:
        componentPropertyDefinitions:
          type: object
          additionalProperties:
            $ref: "#/components/schemas/ComponentPropertyDefinition"
          description: A mapping of name to `ComponentPropertyDefinition` for every
            component property on this component. Each property has a type,
            defaultValue, and other optional values.
    TypePropertiesTrait:
      type: object
      properties:
        characters:
          type: string
          description: The raw characters in the text node.
        style:
          $ref: "#/components/schemas/TypeStyle"
          description: Style of text including font family and weight.
        characterStyleOverrides:
          type: array
          items:
            type: number
          description: The array corresponds to characters in the text box, where each
            element references the 'styleOverrideTable' to apply specific styles
            to each character. The array's length can be less than or equal to
            the number of characters due to the removal of trailing zeros.
            Elements with a value of 0 indicate characters that use the default
            type style. If the array is shorter than the total number of
            characters, the characters beyond the array's length also use the
            default style.
        layoutVersion:
          type: number
          description: Internal property, preserved for backward compatibility. Avoid
            using this value.
        styleOverrideTable:
          type: object
          additionalProperties:
            $ref: "#/components/schemas/TypeStyle"
          description: Map from ID to TypeStyle for looking up style overrides.
        lineTypes:
          type: array
          items:
            type: string
            enum:
              - NONE
              - ORDERED
              - UNORDERED
          description: |-
            An array with the same number of elements as lines in the text node, where lines are delimited by newline or paragraph separator characters. Each element in the array corresponds to the list type of a specific line. List types are represented as string enums with one of these possible values:
            - `NONE`: Not a list item.
            - `ORDERED`: Text is an ordered list (numbered).
            - `UNORDERED`: Text is an unordered list (bulleted).
        lineIndentations:
          type: array
          items:
            type: number
          description: An array with the same number of elements as lines in the text
            node, where lines are delimited by newline or paragraph separator
            characters. Each element in the array corresponds to the indentation
            level of a specific line.
      required:
        - characters
        - style
        - characterStyleOverrides
        - styleOverrideTable
        - lineTypes
        - lineIndentations
    HasTextSublayerTrait:
      type: object
      properties:
        characters:
          type: string
          description: Text contained within a text box.
      required:
        - characters
    TransitionSourceTrait:
      type: object
      properties:
        transitionNodeID:
          type: string
          description: Node ID of node to transition to in prototyping
        transitionDuration:
          type: number
          description: The duration of the prototyping transition on this node (in
            milliseconds). This will override the default transition duration on
            the prototype, for this node.
        transitionEasing:
          $ref: "#/components/schemas/EasingType"
          description: The easing curve used in the prototyping transition on this node.
        interactions:
          type: array
          items:
            $ref: "#/components/schemas/Interaction"
            description: An array of the interactions on this node, each containing a
              trigger and one or more actions.
    DevStatusTrait:
      type: object
      properties:
        devStatus:
          type: object
          description: Represents whether or not a node has a particular handoff (or dev)
            status applied to it.
          properties:
            type:
              type: string
              enum:
                - NONE
                - READY_FOR_DEV
                - COMPLETED
            description:
              type: string
              description: An optional field where the designer can add more information about
                the design and what has changed.
          required:
            - type
    AnnotationsTrait:
      type: object
      properties: {}
    FrameTraits:
      allOf:
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasBlendModeAndOpacityTrait"
        - $ref: "#/components/schemas/HasChildrenTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/HasFramePropertiesTrait"
        - $ref: "#/components/schemas/CornerTrait"
        - $ref: "#/components/schemas/HasGeometryTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
        - $ref: "#/components/schemas/HasEffectsTrait"
        - $ref: "#/components/schemas/HasMaskTrait"
        - $ref: "#/components/schemas/TransitionSourceTrait"
        - $ref: "#/components/schemas/IndividualStrokesTrait"
        - $ref: "#/components/schemas/DevStatusTrait"
        - $ref: "#/components/schemas/AnnotationsTrait"
    DefaultShapeTraits:
      allOf:
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasBlendModeAndOpacityTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/HasGeometryTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
        - $ref: "#/components/schemas/HasEffectsTrait"
        - $ref: "#/components/schemas/HasMaskTrait"
        - $ref: "#/components/schemas/TransitionSourceTrait"
    CornerRadiusShapeTraits:
      allOf:
        - $ref: "#/components/schemas/DefaultShapeTraits"
        - $ref: "#/components/schemas/CornerTrait"
    RectangularShapeTraits:
      allOf:
        - $ref: "#/components/schemas/DefaultShapeTraits"
        - $ref: "#/components/schemas/CornerTrait"
        - $ref: "#/components/schemas/IndividualStrokesTrait"
        - $ref: "#/components/schemas/AnnotationsTrait"
    Node:
      oneOf:
        - $ref: "#/components/schemas/BooleanOperationNode"
        - $ref: "#/components/schemas/ComponentNode"
        - $ref: "#/components/schemas/ComponentSetNode"
        - $ref: "#/components/schemas/ConnectorNode"
        - $ref: "#/components/schemas/EllipseNode"
        - $ref: "#/components/schemas/EmbedNode"
        - $ref: "#/components/schemas/FrameNode"
        - $ref: "#/components/schemas/GroupNode"
        - $ref: "#/components/schemas/InstanceNode"
        - $ref: "#/components/schemas/LineNode"
        - $ref: "#/components/schemas/LinkUnfurlNode"
        - $ref: "#/components/schemas/RectangleNode"
        - $ref: "#/components/schemas/RegularPolygonNode"
        - $ref: "#/components/schemas/SectionNode"
        - $ref: "#/components/schemas/ShapeWithTextNode"
        - $ref: "#/components/schemas/SliceNode"
        - $ref: "#/components/schemas/StarNode"
        - $ref: "#/components/schemas/StickyNode"
        - $ref: "#/components/schemas/TableNode"
        - $ref: "#/components/schemas/TableCellNode"
        - $ref: "#/components/schemas/TextNode"
        - $ref: "#/components/schemas/VectorNode"
        - $ref: "#/components/schemas/WashiTapeNode"
        - $ref: "#/components/schemas/WidgetNode"
        - $ref: "#/components/schemas/DocumentNode"
        - $ref: "#/components/schemas/CanvasNode"
      discriminator:
        propertyName: type
        mapping:
          BOOLEAN_OPERATION: "#/components/schemas/BooleanOperationNode"
          COMPONENT: "#/components/schemas/ComponentNode"
          COMPONENT_SET: "#/components/schemas/ComponentSetNode"
          CONNECTOR: "#/components/schemas/ConnectorNode"
          ELLIPSE: "#/components/schemas/EllipseNode"
          EMBED: "#/components/schemas/EmbedNode"
          FRAME: "#/components/schemas/FrameNode"
          GROUP: "#/components/schemas/GroupNode"
          INSTANCE: "#/components/schemas/InstanceNode"
          LINE: "#/components/schemas/LineNode"
          LINK_UNFURL: "#/components/schemas/LinkUnfurlNode"
          RECTANGLE: "#/components/schemas/RectangleNode"
          REGULAR_POLYGON: "#/components/schemas/RegularPolygonNode"
          SECTION: "#/components/schemas/SectionNode"
          SHAPE_WITH_TEXT: "#/components/schemas/ShapeWithTextNode"
          SLICE: "#/components/schemas/SliceNode"
          STAR: "#/components/schemas/StarNode"
          STICKY: "#/components/schemas/StickyNode"
          TABLE: "#/components/schemas/TableNode"
          TABLE_CELL: "#/components/schemas/TableCellNode"
          TEXT: "#/components/schemas/TextNode"
          VECTOR: "#/components/schemas/VectorNode"
          WASHI_TAPE: "#/components/schemas/WashiTapeNode"
          WIDGET: "#/components/schemas/WidgetNode"
          DOCUMENT: "#/components/schemas/DocumentNode"
          CANVAS: "#/components/schemas/CanvasNode"
    DocumentNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - DOCUMENT
            children:
              type: array
              items:
                $ref: "#/components/schemas/CanvasNode"
          required:
            - type
            - children
        - $ref: "#/components/schemas/IsLayerTrait"
    CanvasNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - CANVAS
            children:
              type: array
              items:
                $ref: "#/components/schemas/SubcanvasNode"
            backgroundColor:
              $ref: "#/components/schemas/RGBA"
              description: Background color of the canvas.
            prototypeStartNodeID:
              type:
                - string
                - "null"
              description: Node ID that corresponds to the start frame for prototypes. This is
                deprecated with the introduction of multiple flows. Please use
                the `flowStartingPoints` field.
              deprecated: true
            flowStartingPoints:
              type: array
              items:
                $ref: "#/components/schemas/FlowStartingPoint"
              description: An array of flow starting points sorted by its position in the
                prototype settings panel.
            prototypeDevice:
              $ref: "#/components/schemas/PrototypeDevice"
              description: The device used to view a prototype.
            measurements:
              type: array
              items:
                $ref: "#/components/schemas/Measurement"
          required:
            - type
            - children
            - backgroundColor
            - flowStartingPoints
            - prototypeDevice
            - prototypeStartNodeID
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
    SubcanvasNode:
      oneOf:
        - $ref: "#/components/schemas/BooleanOperationNode"
        - $ref: "#/components/schemas/ComponentNode"
        - $ref: "#/components/schemas/ComponentSetNode"
        - $ref: "#/components/schemas/ConnectorNode"
        - $ref: "#/components/schemas/EllipseNode"
        - $ref: "#/components/schemas/EmbedNode"
        - $ref: "#/components/schemas/FrameNode"
        - $ref: "#/components/schemas/GroupNode"
        - $ref: "#/components/schemas/InstanceNode"
        - $ref: "#/components/schemas/LineNode"
        - $ref: "#/components/schemas/LinkUnfurlNode"
        - $ref: "#/components/schemas/RectangleNode"
        - $ref: "#/components/schemas/RegularPolygonNode"
        - $ref: "#/components/schemas/SectionNode"
        - $ref: "#/components/schemas/ShapeWithTextNode"
        - $ref: "#/components/schemas/SliceNode"
        - $ref: "#/components/schemas/StarNode"
        - $ref: "#/components/schemas/StickyNode"
        - $ref: "#/components/schemas/TableNode"
        - $ref: "#/components/schemas/TableCellNode"
        - $ref: "#/components/schemas/TextNode"
        - $ref: "#/components/schemas/VectorNode"
        - $ref: "#/components/schemas/WashiTapeNode"
        - $ref: "#/components/schemas/WidgetNode"
      discriminator:
        propertyName: type
        mapping:
          BOOLEAN_OPERATION: "#/components/schemas/BooleanOperationNode"
          COMPONENT: "#/components/schemas/ComponentNode"
          COMPONENT_SET: "#/components/schemas/ComponentSetNode"
          CONNECTOR: "#/components/schemas/ConnectorNode"
          ELLIPSE: "#/components/schemas/EllipseNode"
          EMBED: "#/components/schemas/EmbedNode"
          FRAME: "#/components/schemas/FrameNode"
          GROUP: "#/components/schemas/GroupNode"
          INSTANCE: "#/components/schemas/InstanceNode"
          LINE: "#/components/schemas/LineNode"
          LINK_UNFURL: "#/components/schemas/LinkUnfurlNode"
          RECTANGLE: "#/components/schemas/RectangleNode"
          REGULAR_POLYGON: "#/components/schemas/RegularPolygonNode"
          SECTION: "#/components/schemas/SectionNode"
          SHAPE_WITH_TEXT: "#/components/schemas/ShapeWithTextNode"
          SLICE: "#/components/schemas/SliceNode"
          STAR: "#/components/schemas/StarNode"
          STICKY: "#/components/schemas/StickyNode"
          TABLE: "#/components/schemas/TableNode"
          TABLE_CELL: "#/components/schemas/TableCellNode"
          TEXT: "#/components/schemas/TextNode"
          VECTOR: "#/components/schemas/VectorNode"
          WASHI_TAPE: "#/components/schemas/WashiTapeNode"
          WIDGET: "#/components/schemas/WidgetNode"
    BooleanOperationNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - BOOLEAN_OPERATION
              description: The type of this node, represented by the string literal
                "BOOLEAN_OPERATION"
            booleanOperation:
              type: string
              description: A string enum indicating the type of boolean operation applied.
              enum:
                - UNION
                - INTERSECT
                - SUBTRACT
                - EXCLUDE
          required:
            - type
            - booleanOperation
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasBlendModeAndOpacityTrait"
        - $ref: "#/components/schemas/HasChildrenTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/HasGeometryTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
        - $ref: "#/components/schemas/HasEffectsTrait"
        - $ref: "#/components/schemas/HasMaskTrait"
        - $ref: "#/components/schemas/TransitionSourceTrait"
    SectionNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - SECTION
              description: The type of this node, represented by the string literal "SECTION"
            sectionContentsHidden:
              type: boolean
              description: Whether the contents of the section are visible
              default: false
          required:
            - type
            - sectionContentsHidden
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasGeometryTrait"
        - $ref: "#/components/schemas/HasChildrenTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/DevStatusTrait"
    FrameNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - FRAME
              description: The type of this node, represented by the string literal "FRAME"
          required:
            - type
        - $ref: "#/components/schemas/FrameTraits"
    GroupNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - GROUP
              description: The type of this node, represented by the string literal "GROUP"
          required:
            - type
        - $ref: "#/components/schemas/FrameTraits"
    ComponentNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - COMPONENT
              description: The type of this node, represented by the string literal
                "COMPONENT"
          required:
            - type
        - $ref: "#/components/schemas/FrameTraits"
        - $ref: "#/components/schemas/ComponentPropertiesTrait"
    ComponentSetNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - COMPONENT_SET
              description: The type of this node, represented by the string literal
                "COMPONENT_SET"
          required:
            - type
        - $ref: "#/components/schemas/FrameTraits"
        - $ref: "#/components/schemas/ComponentPropertiesTrait"
    VectorNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - VECTOR
              description: The type of this node, represented by the string literal "VECTOR"
          required:
            - type
        - $ref: "#/components/schemas/CornerRadiusShapeTraits"
        - $ref: "#/components/schemas/AnnotationsTrait"
    StarNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - STAR
              description: The type of this node, represented by the string literal "STAR"
          required:
            - type
        - $ref: "#/components/schemas/CornerRadiusShapeTraits"
        - $ref: "#/components/schemas/AnnotationsTrait"
    LineNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - LINE
              description: The type of this node, represented by the string literal "LINE"
          required:
            - type
        - $ref: "#/components/schemas/DefaultShapeTraits"
        - $ref: "#/components/schemas/AnnotationsTrait"
    EllipseNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - ELLIPSE
              description: The type of this node, represented by the string literal "ELLIPSE"
            arcData:
              $ref: "#/components/schemas/ArcData"
          required:
            - type
            - arcData
        - $ref: "#/components/schemas/DefaultShapeTraits"
        - $ref: "#/components/schemas/AnnotationsTrait"
    RegularPolygonNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - REGULAR_POLYGON
              description: The type of this node, represented by the string literal
                "REGULAR_POLYGON"
          required:
            - type
        - $ref: "#/components/schemas/CornerRadiusShapeTraits"
        - $ref: "#/components/schemas/AnnotationsTrait"
    RectangleNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - RECTANGLE
              description: The type of this node, represented by the string literal
                "RECTANGLE"
          required:
            - type
        - $ref: "#/components/schemas/RectangularShapeTraits"
    TextNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - TEXT
              description: The type of this node, represented by the string literal "TEXT"
          required:
            - type
        - $ref: "#/components/schemas/DefaultShapeTraits"
        - $ref: "#/components/schemas/TypePropertiesTrait"
        - $ref: "#/components/schemas/AnnotationsTrait"
    TableNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - TABLE
              description: The type of this node, represented by the string literal "TABLE"
          required:
            - type
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasChildrenTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/MinimalStrokesTrait"
        - $ref: "#/components/schemas/HasEffectsTrait"
        - $ref: "#/components/schemas/HasBlendModeAndOpacityTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
    TableCellNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - TABLE_CELL
              description: The type of this node, represented by the string literal
                "TABLE_CELL"
          required:
            - type
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/MinimalFillsTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/HasTextSublayerTrait"
    SliceNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - SLICE
              description: The type of this node, represented by the string literal "SLICE"
          required:
            - type
        - $ref: "#/components/schemas/IsLayerTrait"
    InstanceNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - INSTANCE
              description: The type of this node, represented by the string literal "INSTANCE"
            componentId:
              type: string
              description: ID of component that this instance came from.
            isExposedInstance:
              type: boolean
              description: If true, this node has been marked as exposed to its containing
                component or component set.
              default: false
            exposedInstances:
              type: array
              items:
                type: string
              description: IDs of instances that have been exposed to this node's level.
            componentProperties:
              type: object
              additionalProperties:
                $ref: "#/components/schemas/ComponentProperty"
              description: A mapping of name to `ComponentProperty` for all component
                properties on this instance. Each property has a type, value,
                and other optional values.
            overrides:
              type: array
              items:
                $ref: "#/components/schemas/Overrides"
              description: An array of all of the fields directly overridden on this instance.
                Inherited overrides are not included.
          required:
            - type
            - componentId
            - overrides
        - $ref: "#/components/schemas/FrameTraits"
    EmbedNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - EMBED
              description: The type of this node, represented by the string literal "EMBED"
          required:
            - type
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
    LinkUnfurlNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - LINK_UNFURL
              description: The type of this node, represented by the string literal
                "LINK_UNFURL"
          required:
            - type
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
    StickyNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - STICKY
              description: The type of this node, represented by the string literal "STICKY"
            authorVisible:
              type: boolean
              description: If true, author name is visible.
              default: false
          required:
            - type
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/HasBlendModeAndOpacityTrait"
        - $ref: "#/components/schemas/MinimalFillsTrait"
        - $ref: "#/components/schemas/HasMaskTrait"
        - $ref: "#/components/schemas/HasEffectsTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
        - $ref: "#/components/schemas/HasTextSublayerTrait"
    ShapeWithTextNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - SHAPE_WITH_TEXT
              description: The type of this node, represented by the string literal
                "SHAPE_WITH_TEXT"
            shapeType:
              $ref: "#/components/schemas/ShapeType"
              description: "Geometric shape type. Most shape types have the same name as their
                tooltip but there are a few exceptions. ENG_DATABASE: Cylinder,
                ENG_QUEUE: Horizontal cylinder, ENG_FILE: File, ENG_FOLDER:
                Folder."
          required:
            - type
            - shapeType
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/HasBlendModeAndOpacityTrait"
        - $ref: "#/components/schemas/MinimalFillsTrait"
        - $ref: "#/components/schemas/HasMaskTrait"
        - $ref: "#/components/schemas/HasEffectsTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
        - $ref: "#/components/schemas/HasTextSublayerTrait"
        - $ref: "#/components/schemas/CornerTrait"
        - $ref: "#/components/schemas/MinimalStrokesTrait"
    ConnectorNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - CONNECTOR
              description: The type of this node, represented by the string literal
                "CONNECTOR"
            connectorStart:
              $ref: "#/components/schemas/ConnectorEndpoint"
              description: The starting point of the connector.
            connectorEnd:
              $ref: "#/components/schemas/ConnectorEndpoint"
              description: The ending point of the connector.
            connectorStartStrokeCap:
              type: string
              description: A string enum describing the end cap of the start of the connector.
              enum:
                - NONE
                - LINE_ARROW
                - TRIANGLE_ARROW
                - DIAMOND_FILLED
                - CIRCLE_FILLED
                - TRIANGLE_FILLED
              default: NONE
            connectorEndStrokeCap:
              type: string
              description: A string enum describing the end cap of the end of the connector.
              enum:
                - NONE
                - LINE_ARROW
                - TRIANGLE_ARROW
                - DIAMOND_FILLED
                - CIRCLE_FILLED
                - TRIANGLE_FILLED
              default: NONE
            connectorLineType:
              $ref: "#/components/schemas/ConnectorLineType"
              description: Connector line type.
            textBackground:
              $ref: "#/components/schemas/ConnectorTextBackground"
              description: Connector text background.
          required:
            - type
            - connectorStart
            - connectorEnd
            - connectorStartStrokeCap
            - connectorEndStrokeCap
            - connectorLineType
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasLayoutTrait"
        - $ref: "#/components/schemas/HasBlendModeAndOpacityTrait"
        - $ref: "#/components/schemas/HasEffectsTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
        - $ref: "#/components/schemas/HasTextSublayerTrait"
        - $ref: "#/components/schemas/MinimalStrokesTrait"
    WashiTapeNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - WASHI_TAPE
              description: The type of this node, represented by the string literal
                "WASHI_TAPE"
          required:
            - type
        - $ref: "#/components/schemas/DefaultShapeTraits"
    WidgetNode:
      allOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - WIDGET
              description: The type of this node, represented by the string literal "WIDGET"
          required:
            - type
        - $ref: "#/components/schemas/IsLayerTrait"
        - $ref: "#/components/schemas/HasExportSettingsTrait"
        - $ref: "#/components/schemas/HasChildrenTrait"
    RGB:
      type: object
      description: An RGB color
      properties:
        r:
          type: number
          description: Red channel value, between 0 and 1.
          minimum: 0
          maximum: 1
        g:
          type: number
          description: Green channel value, between 0 and 1.
          minimum: 0
          maximum: 1
        b:
          type: number
          description: Blue channel value, between 0 and 1.
          minimum: 0
          maximum: 1
      required:
        - r
        - g
        - b
    RGBA:
      type: object
      description: An RGBA color
      properties:
        r:
          type: number
          description: Red channel value, between 0 and 1.
          minimum: 0
          maximum: 1
        g:
          type: number
          description: Green channel value, between 0 and 1.
          minimum: 0
          maximum: 1
        b:
          type: number
          description: Blue channel value, between 0 and 1.
          minimum: 0
          maximum: 1
        a:
          type: number
          description: Alpha channel value, between 0 and 1.
          minimum: 0
          maximum: 1
      required:
        - r
        - g
        - b
        - a
    FlowStartingPoint:
      type: object
      description: A flow starting point used when launching a prototype to enter
        Presentation view.
      properties:
        nodeId:
          type: string
          description: Unique identifier specifying the frame.
        name:
          type: string
          description: Name of flow.
      required:
        - nodeId
        - name
    Size:
      type: object
      description: A width and a height.
      properties:
        width:
          type: number
          description: The width of a size.
        height:
          type: number
          description: the height of a size.
      required:
        - width
        - height
    PrototypeDevice:
      type: object
      description: The device used to view a prototype.
      properties:
        type:
          type: string
          enum:
            - NONE
            - PRESET
            - CUSTOM
            - PRESENTATION
        size:
          $ref: "#/components/schemas/Size"
        presetIdentifier:
          type: string
        rotation:
          type: string
          enum:
            - NONE
            - CCW_90
      required:
        - type
        - rotation
    Constraint:
      type: object
      description: Sizing constraint for exports.
      properties:
        type:
          type: string
          description: |-
            Type of constraint to apply:
            - `SCALE`: Scale by `value`.
            - `WIDTH`: Scale proportionally and set width to `value`.
            - `HEIGHT`: Scale proportionally and set height to `value`.
          enum:
            - SCALE
            - WIDTH
            - HEIGHT
        value:
          type: number
          description: See type property for effect of this field.
      required:
        - type
        - value
    ExportSetting:
      type: object
      description: An export setting.
      properties:
        suffix:
          type: string
        format:
          type: string
          enum:
            - JPG
            - PNG
            - SVG
            - PDF
        constraint:
          $ref: "#/components/schemas/Constraint"
      required:
        - suffix
        - format
        - constraint
    BlendMode:
      type: string
      description: |-
        This type is a string enum with the following possible values
        Normal blends:
        - `PASS_THROUGH` (only applicable to objects with children)
        - `NORMAL`
        Darken:
        - `DARKEN`
        - `MULTIPLY`
        - `LINEAR_BURN`
        - `COLOR_BURN`
        Lighten:
        - `LIGHTEN`
        - `SCREEN`
        - `LINEAR_DODGE`
        - `COLOR_DODGE`
        Contrast:
        - `OVERLAY`
        - `SOFT_LIGHT`
        - `HARD_LIGHT`
        Inversion:
        - `DIFFERENCE`
        - `EXCLUSION`
        Component:
        - `HUE`
        - `SATURATION`
        - `COLOR`
        - `LUMINOSITY`
      enum:
        - PASS_THROUGH
        - NORMAL
        - DARKEN
        - MULTIPLY
        - LINEAR_BURN
        - COLOR_BURN
        - LIGHTEN
        - SCREEN
        - LINEAR_DODGE
        - COLOR_DODGE
        - OVERLAY
        - SOFT_LIGHT
        - HARD_LIGHT
        - DIFFERENCE
        - EXCLUSION
        - HUE
        - SATURATION
        - COLOR
        - LUMINOSITY
    Vector:
      type: object
      description: A 2d vector.
      properties:
        x:
          type: number
          description: X coordinate of the vector.
        y:
          type: number
          description: Y coordinate of the vector.
      required:
        - x
        - y
    ColorStop:
      type: object
      description: A single color stop with its position along the gradient axis,
        color, and bound variables if any
      properties:
        position:
          type: number
          description: Value between 0 and 1 representing position along gradient axis.
        color:
          $ref: "#/components/schemas/RGBA"
          description: Color attached to corresponding position.
        boundVariables:
          type: object
          description: The variables bound to a particular gradient stop
          properties:
            color:
              $ref: "#/components/schemas/VariableAlias"
      required:
        - position
        - color
    Transform:
      type: array
      items:
        type: array
        items:
          type: number
        maxItems: 3
        minItems: 3
      maxItems: 2
      minItems: 2
      description: |-
        A transformation matrix is standard way in computer graphics to represent translation and rotation. These are the top two rows of a 3x3 matrix. The bottom row of the matrix is assumed to be [0, 0, 1]. This is known as an affine transform and is enough to represent translation, rotation, and skew.
        The identity transform is [[1, 0, 0], [0, 1, 0]].
        A translation matrix will typically look like:
        ```
        [[1, 0, tx],
          [0, 1, ty]]
        ```
        and a rotation matrix will typically look like:
        ```
        [[cos(angle), sin(angle), 0],
          [-sin(angle), cos(angle), 0]]
        ```
        Another way to think about this transform is as three vectors:
        - The x axis (t[0][0], t[1][0])
        - The y axis (t[0][1], t[1][1])
        - The translation offset (t[0][2], t[1][2])
        The most common usage of the Transform matrix is the `relativeTransform property`. This particular usage of the matrix has a few additional restrictions. The translation offset can take on any value but we do enforce that the axis vectors are unit vectors (i.e. have length 1). The axes are not required to be at 90° angles to each other.
    ImageFilters:
      type: object
      description: Image filters to apply to the node.
      properties:
        exposure:
          type: number
          default: 0
        contrast:
          type: number
          default: 0
        saturation:
          type: number
          default: 0
        temperature:
          type: number
          default: 0
        tint:
          type: number
          default: 0
        highlights:
          type: number
          default: 0
        shadows:
          type: number
          default: 0
    BasePaint:
      type: object
      properties:
        visible:
          type: boolean
          description: Is the paint enabled?
          default: true
        opacity:
          type: number
          description: Overall opacity of paint (colors within the paint can also have
            opacity values which would blend with this)
          minimum: 0
          maximum: 1
          default: 1
        blendMode:
          $ref: "#/components/schemas/BlendMode"
          description: How this node blends with nodes behind it in the scene
      required:
        - blendMode
    SolidPaint:
      allOf:
        - type: object
          description: A solid color
          properties:
            type:
              type: string
              description: The string literal "SOLID" representing the paint's type. Always
                check the `type` before reading other properties.
              enum:
                - SOLID
            color:
              $ref: "#/components/schemas/RGBA"
              description: Solid color of the paint
            boundVariables:
              type: object
              description: The variables bound to a particular field on this paint
              properties:
                color:
                  $ref: "#/components/schemas/VariableAlias"
          required:
            - type
            - color
        - $ref: "#/components/schemas/BasePaint"
    GradientPaint:
      allOf:
        - type: object
          description: A gradient
          properties:
            type:
              type: string
              description: The string literal representing the paint's type. Always check the
                `type` before reading other properties.
              enum:
                - GRADIENT_LINEAR
                - GRADIENT_RADIAL
                - GRADIENT_ANGULAR
                - GRADIENT_DIAMOND
            gradientHandlePositions:
              type: array
              items:
                $ref: "#/components/schemas/Vector"
              description: This field contains three vectors, each of which are a position in
                normalized object space (normalized object space is if the top
                left corner of the bounding box of the object is (0, 0) and the
                bottom right is (1,1)). The first position corresponds to the
                start of the gradient (value 0 for the purposes of calculating
                gradient stops), the second position is the end of the gradient
                (value 1), and the third handle position determines the width of
                the gradient.
            gradientStops:
              type: array
              items:
                $ref: "#/components/schemas/ColorStop"
              description: Positions of key points along the gradient axis with the colors
                anchored there. Colors along the gradient are interpolated
                smoothly between neighboring gradient stops.
          required:
            - type
            - gradientHandlePositions
            - gradientStops
        - $ref: "#/components/schemas/BasePaint"
    ImagePaint:
      allOf:
        - type: object
          description: An image
          properties:
            type:
              type: string
              description: The string literal "IMAGE" representing the paint's type. Always
                check the `type` before reading other properties.
              enum:
                - IMAGE
            scaleMode:
              type: string
              description: Image scaling mode.
              enum:
                - FILL
                - FIT
                - TILE
                - STRETCH
            imageRef:
              type: string
              description: A reference to an image embedded in this node. To download the
                image using this reference, use the `GET file images` endpoint
                to retrieve the mapping from image references to image URLs.
            imageTransform:
              $ref: "#/components/schemas/Transform"
              description: Affine transform applied to the image, only present if `scaleMode`
                is `STRETCH`
            scalingFactor:
              type: number
              description: Amount image is scaled by in tiling, only present if scaleMode is
                `TILE`.
            filters:
              $ref: "#/components/schemas/ImageFilters"
              description: Defines what image filters have been applied to this paint, if any.
                If this property is not defined, no filters have been applied.
            rotation:
              type: number
              description: Image rotation, in degrees.
              default: 0
            gifRef:
              type: string
              description: A reference to an animated GIF embedded in this node. To download
                the image using this reference, use the `GET file images`
                endpoint to retrieve the mapping from image references to image
                URLs.
          required:
            - type
            - scaleMode
            - imageRef
        - $ref: "#/components/schemas/BasePaint"
    Paint:
      oneOf:
        - $ref: "#/components/schemas/SolidPaint"
        - $ref: "#/components/schemas/GradientPaint"
        - $ref: "#/components/schemas/ImagePaint"
    LayoutConstraint:
      type: object
      description: Layout constraint relative to containing Frame
      properties:
        vertical:
          type: string
          description: |-
            Vertical constraint (relative to containing frame) as an enum:
            - `TOP`: Node is laid out relative to top of the containing frame
            - `BOTTOM`: Node is laid out relative to bottom of the containing frame
            - `CENTER`: Node is vertically centered relative to containing frame
            - `TOP_BOTTOM`: Both top and bottom of node are constrained relative to containing frame (node stretches with frame)
            - `SCALE`: Node scales vertically with containing frame
          enum:
            - TOP
            - BOTTOM
            - CENTER
            - TOP_BOTTOM
            - SCALE
        horizontal:
          type: string
          description: |-
            Horizontal constraint (relative to containing frame) as an enum:
            - `LEFT`: Node is laid out relative to left of the containing frame
            - `RIGHT`: Node is laid out relative to right of the containing frame
            - `CENTER`: Node is horizontally centered relative to containing frame
            - `LEFT_RIGHT`: Both left and right of node are constrained relative to containing frame (node stretches with frame)
            - `SCALE`: Node scales horizontally with containing frame
          enum:
            - LEFT
            - RIGHT
            - CENTER
            - LEFT_RIGHT
            - SCALE
      required:
        - vertical
        - horizontal
    Rectangle:
      type: object
      description: A rectangle that expresses a bounding box in absolute coordinates.
      properties:
        x:
          type: number
          description: X coordinate of top left corner of the rectangle.
        y:
          type: number
          description: Y coordinate of top left corner of the rectangle.
        width:
          type: number
          description: Width of the rectangle.
        height:
          type: number
          description: Height of the rectangle.
      required:
        - x
        - y
        - width
        - height
    LayoutGrid:
      type: object
      description: Guides to align and place objects within a frames.
      properties:
        pattern:
          type: string
          description: |-
            Orientation of the grid as a string enum
            - `COLUMNS`: Vertical grid
            - `ROWS`: Horizontal grid
            - `GRID`: Square grid
          enum:
            - COLUMNS
            - ROWS
            - GRID
        sectionSize:
          type: number
          description: Width of column grid or height of row grid or square grid spacing.
        visible:
          type: boolean
          description: Is the grid currently visible?
        color:
          $ref: "#/components/schemas/RGBA"
          description: Color of the grid
        alignment:
          type: string
          description: |-
            Positioning of grid as a string enum
            - `MIN`: Grid starts at the left or top of the frame
            - `MAX`: Grid starts at the right or bottom of the frame
            - `STRETCH`: Grid is stretched to fit the frame
            - `CENTER`: Grid is center aligned
          enum:
            - MIN
            - MAX
            - STRETCH
            - CENTER
        gutterSize:
          type: number
          description: Spacing in between columns and rows
        offset:
          type: number
          description: Spacing before the first column or row
        count:
          type: number
          description: Number of columns or rows
        boundVariables:
          type: object
          description: The variables bound to a particular field on this layout grid
          properties:
            gutterSize:
              $ref: "#/components/schemas/VariableAlias"
            numSections:
              $ref: "#/components/schemas/VariableAlias"
            sectionSize:
              $ref: "#/components/schemas/VariableAlias"
            offset:
              $ref: "#/components/schemas/VariableAlias"
      required:
        - pattern
        - sectionSize
        - visible
        - color
        - alignment
        - gutterSize
        - offset
        - count
    BaseShadowEffect:
      type: object
      description: Base properties shared by all shadow effects
      properties:
        color:
          $ref: "#/components/schemas/RGBA"
          description: The color of the shadow
        blendMode:
          $ref: "#/components/schemas/BlendMode"
          description: Blend mode of the shadow
        offset:
          $ref: "#/components/schemas/Vector"
          description: How far the shadow is projected in the x and y directions
        radius:
          type: number
          description: Radius of the blur effect (applies to shadows as well)
          minimum: 0
        spread:
          type: number
          description: |-
            The distance by which to expand (or contract) the shadow.
            For drop shadows, a positive `spread` value creates a shadow larger than the node, whereas a negative value creates a shadow smaller than the node.
            For inner shadows, a positive `spread` value contracts the shadow. Spread values are only accepted on rectangles and ellipses, or on frames, components, and instances with visible fill paints and `clipsContent` enabled. When left unspecified, the default value is 0.
          default: 0
        visible:
          type: boolean
          description: Whether this shadow is visible.
        boundVariables:
          type: object
          description: The variables bound to a particular field on this shadow effect
          properties:
            radius:
              $ref: "#/components/schemas/VariableAlias"
            spread:
              $ref: "#/components/schemas/VariableAlias"
            color:
              $ref: "#/components/schemas/VariableAlias"
            offsetX:
              $ref: "#/components/schemas/VariableAlias"
            offsetY:
              $ref: "#/components/schemas/VariableAlias"
      required:
        - color
        - blendMode
        - offset
        - radius
        - visible
    DropShadowEffect:
      allOf:
        - type: object
          description: A drop shadow effect
          properties:
            type:
              type: string
              description: A string literal representing the effect's type. Always check the
                type before reading other properties.
              enum:
                - DROP_SHADOW
            showShadowBehindNode:
              type: boolean
              description: Whether to show the shadow behind translucent or transparent pixels
              default: false
          required:
            - type
            - showShadowBehindNode
        - $ref: "#/components/schemas/BaseShadowEffect"
    InnerShadowEffect:
      allOf:
        - type: object
          description: An inner shadow effect
          properties:
            type:
              type: string
              description: A string literal representing the effect's type. Always check the
                type before reading other properties.
              enum:
                - INNER_SHADOW
        - $ref: "#/components/schemas/BaseShadowEffect"
    BlurEffect:
      type: object
      description: A blur effect
      properties:
        type:
          type: string
          description: A string literal representing the effect's type. Always check the
            type before reading other properties.
          enum:
            - LAYER_BLUR
            - BACKGROUND_BLUR
        visible:
          type: boolean
          description: Whether this blur is active.
        radius:
          type: number
          description: Radius of the blur effect
          minimum: 0
        boundVariables:
          type: object
          description: The variables bound to a particular field on this blur effect
          properties:
            radius:
              $ref: "#/components/schemas/VariableAlias"
      required:
        - type
        - visible
        - radius
    Effect:
      oneOf:
        - $ref: "#/components/schemas/DropShadowEffect"
        - $ref: "#/components/schemas/InnerShadowEffect"
        - $ref: "#/components/schemas/BlurEffect"
      discriminator:
        propertyName: type
        mapping:
          DROP_SHADOW: "#/components/schemas/DropShadowEffect"
          INNER_SHADOW: "#/components/schemas/InnerShadowEffect"
          LAYER_BLUR: "#/components/schemas/BlurEffect"
          BACKGROUND_BLUR: "#/components/schemas/BlurEffect"
    Style:
      type: object
      description: A set of properties that can be applied to nodes and published.
        Styles for a property can be created in the corresponding property's
        panel while editing a file.
      properties:
        key:
          type: string
          description: The key of the style
        name:
          type: string
          description: Name of the style
        description:
          type: string
          description: Description of the style
        remote:
          type: boolean
          description: Whether this style is a remote style that doesn't live in this file
        styleType:
          $ref: "#/components/schemas/StyleType"
      required:
        - key
        - name
        - description
        - remote
        - styleType
    EasingType:
      type: string
      description: |-
        This type is a string enum with the following possible values:
        - `EASE_IN`: Ease in with an animation curve similar to CSS ease-in.
        - `EASE_OUT`: Ease out with an animation curve similar to CSS ease-out.
        - `EASE_IN_AND_OUT`: Ease in and then out with an animation curve similar to CSS ease-in-out.
        - `LINEAR`: No easing, similar to CSS linear.
        - `EASE_IN_BACK`: Ease in with an animation curve that moves past the initial keyframe's value and then accelerates as it reaches the end.
        - `EASE_OUT_BACK`: Ease out with an animation curve that starts fast, then slows and goes past the ending keyframe's value.
        - `EASE_IN_AND_OUT_BACK`: Ease in and then out with an animation curve that overshoots the initial keyframe's value, then accelerates quickly before it slows and overshoots the ending keyframes value.
        - `CUSTOM_CUBIC_BEZIER`: User-defined cubic bezier curve.
        - `GENTLE`: Gentle animation similar to react-spring.
        - `QUICK`: Quick spring animation, great for toasts and notifications.
        - `BOUNCY`: Bouncy spring, for delightful animations like a heart bounce.
        - `SLOW`: Slow spring, useful as a steady, natural way to scale up fullscreen content.
        - `CUSTOM_SPRING`: User-defined spring animation.
      enum:
        - EASE_IN
        - EASE_OUT
        - EASE_IN_AND_OUT
        - LINEAR
        - EASE_IN_BACK
        - EASE_OUT_BACK
        - EASE_IN_AND_OUT_BACK
        - CUSTOM_CUBIC_BEZIER
        - GENTLE
        - QUICK
        - BOUNCY
        - SLOW
        - CUSTOM_SPRING
    StrokeWeights:
      type: object
      description: Individual stroke weights
      properties:
        top:
          type: number
          description: The top stroke weight.
        right:
          type: number
          description: The right stroke weight.
        bottom:
          type: number
          description: The bottom stroke weight.
        left:
          type: number
          description: The left stroke weight.
      required:
        - top
        - right
        - bottom
        - left
    PaintOverride:
      type: object
      description: Paint metadata to override default paints.
      properties:
        fills:
          type: array
          items:
            $ref: "#/components/schemas/Paint"
          description: Paints applied to characters.
        inheritFillStyleId:
          type: string
          description: ID of style node, if any, that this inherits fill data from.
    Path:
      type: object
      description: Defines a single path
      properties:
        path:
          type: string
          description: A series of path commands that encodes how to draw the path.
        windingRule:
          type: string
          description: The winding rule for the path (same as in SVGs). This determines
            whether a given point in space is inside or outside the path.
          enum:
            - NONZERO
            - EVENODD
        overrideID:
          type: number
          description: If there is a per-region fill, this refers to an ID in the
            `fillOverrideTable`.
      required:
        - path
        - windingRule
    ArcData:
      type: object
      description: Information about the arc properties of an ellipse. 0° is the x
        axis and increasing angles rotate clockwise.
      properties:
        startingAngle:
          type: number
          description: Start of the sweep in radians.
          default: 0
        endingAngle:
          type: number
          description: End of the sweep in radians.
          default: 0
        innerRadius:
          type: number
          description: Inner radius value between 0 and 1
          default: 0
          minimum: 0
          maximum: 1
      required:
        - startingAngle
        - endingAngle
        - innerRadius
    Hyperlink:
      type: object
      description: A link to either a URL or another frame (node) in the document.
      properties:
        type:
          type: string
          description: The type of hyperlink. Can be either `URL` or `NODE`.
          enum:
            - URL
            - NODE
        url:
          type: string
          description: The URL that the hyperlink points to, if `type` is `URL`.
        nodeID:
          type: string
          description: The ID of the node that the hyperlink points to, if `type` is `NODE`.
      required:
        - type
    TypeStyle:
      type: object
      description: Metadata for character formatting.
      properties:
        fontFamily:
          type: string
          description: Font family of text (standard name).
        fontPostScriptName:
          type:
            - string
            - "null"
          description: PostScript font name.
        fontStyle:
          type: string
          description: Describes visual weight or emphasis, such as Bold or Italic.
        paragraphSpacing:
          type: number
          description: Space between paragraphs in px, 0 if not present.
          default: 0
        paragraphIndent:
          type: number
          description: Paragraph indentation in px, 0 if not present.
          default: 0
        listSpacing:
          type: number
          description: Space between list items in px, 0 if not present.
          default: 0
        italic:
          type: boolean
          description: Whether or not text is italicized.
          default: false
        fontWeight:
          type: number
          description: Numeric font weight.
        fontSize:
          type: number
          description: Font size in px.
        textCase:
          type: string
          description: Text casing applied to the node, default is the original casing.
          enum:
            - UPPER
            - LOWER
            - TITLE
            - SMALL_CAPS
            - SMALL_CAPS_FORCED
        textDecoration:
          type: string
          description: Text decoration applied to the node, default is none.
          enum:
            - NONE
            - STRIKETHROUGH
            - UNDERLINE
          default: NONE
        textAutoResize:
          type: string
          description: Dimensions along which text will auto resize, default is that the
            text does not auto-resize. TRUNCATE means that the text will be
            shortened and trailing text will be replaced with "…" if the text
            contents is larger than the bounds. `TRUNCATE` as a return value is
            deprecated and will be removed in a future version. Read from
            `textTruncation` instead.
          enum:
            - NONE
            - WIDTH_AND_HEIGHT
            - HEIGHT
            - TRUNCATE
          default: NONE
        textTruncation:
          type: string
          description: Whether this text node will truncate with an ellipsis when the text
            contents is larger than the text node.
          enum:
            - DISABLED
            - ENDING
          default: DISABLED
        maxLines:
          type: number
          description: 'When `textTruncation: "ENDING"` is set, `maxLines` determines how
            many lines a text node can grow to before it truncates.'
        textAlignHorizontal:
          type: string
          description: Horizontal text alignment as string enum.
          enum:
            - LEFT
            - RIGHT
            - CENTER
            - JUSTIFIED
        textAlignVertical:
          type: string
          description: Vertical text alignment as string enum.
          enum:
            - TOP
            - CENTER
            - BOTTOM
        letterSpacing:
          type: number
          description: Space between characters in px.
        fills:
          type: array
          items:
            $ref: "#/components/schemas/Paint"
          description: An array of fill paints applied to the characters.
        hyperlink:
          $ref: "#/components/schemas/Hyperlink"
          description: Link to a URL or frame.
        opentypeFlags:
          type: object
          additionalProperties:
            type: number
          description: A map of OpenType feature flags to 1 or 0, 1 if it is enabled and 0
            if it is disabled. Note that some flags aren't reflected here. For
            example, SMCP (small caps) is still represented by the `textCase`
            field.
        lineHeightPx:
          type: number
          description: Line height in px.
        lineHeightPercent:
          type: number
          default: 100
          description: Line height as a percentage of normal line height. This is
            deprecated; in a future version of the API only lineHeightPx and
            lineHeightPercentFontSize will be returned.
        lineHeightPercentFontSize:
          type: number
          description: Line height as a percentage of the font size. Only returned when
            `lineHeightPercent` (deprecated) is not 100.
        lineHeightUnit:
          type: string
          description: The unit of the line height value specified by the user.
          enum:
            - PIXELS
            - FONT_SIZE_%
            - INTRINSIC_%
        boundVariables:
          type: object
          description: The variables bound to a particular field on this style
          properties:
            fontFamily:
              $ref: "#/components/schemas/VariableAlias"
            fontSize:
              $ref: "#/components/schemas/VariableAlias"
            fontStyle:
              $ref: "#/components/schemas/VariableAlias"
            fontWeight:
              $ref: "#/components/schemas/VariableAlias"
            letterSpacing:
              $ref: "#/components/schemas/VariableAlias"
            lineHeight:
              $ref: "#/components/schemas/VariableAlias"
            paragraphSpacing:
              $ref: "#/components/schemas/VariableAlias"
            paragraphIndent:
              $ref: "#/components/schemas/VariableAlias"
        isOverrideOverTextStyle:
          type: boolean
          description: " Whether or not this style has overrides over a text style. The
            possible fields to override are semanticWeight, semanticItalic,
            hyperlink, and textDecoration. If this is true, then those fields
            are overrides if present."
        semanticWeight:
          type: string
          description: Indicates how the font weight was overridden when there is a text
            style override.
          enum:
            - BOLD
            - NORMAL
        semanticItalic:
          type: string
          description: Indicates how the font style was overridden when there is a text
            style override.
          enum:
            - ITALIC
            - NORMAL
    ComponentPropertyType:
      type: string
      description: Component property type.
      enum:
        - BOOLEAN
        - INSTANCE_SWAP
        - TEXT
        - VARIANT
    InstanceSwapPreferredValue:
      type: object
      description: Instance swap preferred value.
      properties:
        type:
          type: string
          description: Type of node for this preferred value.
          enum:
            - COMPONENT
            - COMPONENT_SET
        key:
          type: string
          description: Key of this component or component set.
      required:
        - type
        - key
    ComponentPropertyDefinition:
      type: object
      description: A property of a component.
      properties:
        type:
          $ref: "#/components/schemas/ComponentPropertyType"
          description: Type of this component property.
        defaultValue:
          oneOf:
            - type: boolean
            - type: string
          description: Initial value of this property for instances.
        variantOptions:
          type: array
          items:
            type: string
          description: All possible values for this property. Only exists on VARIANT
            properties.
        preferredValues:
          type: array
          items:
            $ref: "#/components/schemas/InstanceSwapPreferredValue"
          description: Preferred values for this property. Only applicable if type is
            `INSTANCE_SWAP`.
      required:
        - type
        - defaultValue
    ComponentProperty:
      type: object
      description: A property of a component.
      properties:
        type:
          $ref: "#/components/schemas/ComponentPropertyType"
          description: Type of this component property.
        value:
          oneOf:
            - type: boolean
            - type: string
          description: Value of the property for this component instance.
        preferredValues:
          type: array
          items:
            $ref: "#/components/schemas/InstanceSwapPreferredValue"
          description: Preferred values for this property. Only applicable if type is
            `INSTANCE_SWAP`.
        boundVariables:
          type: object
          description: The variables bound to a particular field on this component property
          properties:
            value:
              $ref: "#/components/schemas/VariableAlias"
      required:
        - type
        - value
    Overrides:
      type: object
      description: Fields directly overridden on an instance. Inherited overrides are
        not included.
      properties:
        id:
          type: string
          description: A unique ID for a node.
        overriddenFields:
          type: array
          items:
            type: string
          description: An array of properties.
      required:
        - id
        - overriddenFields
    ShapeType:
      type: string
      description: Geometric shape type.
      enum:
        - SQUARE
        - ELLIPSE
        - ROUNDED_RECTANGLE
        - DIAMOND
        - TRIANGLE_UP
        - TRIANGLE_DOWN
        - PARALLELOGRAM_RIGHT
        - PARALLELOGRAM_LEFT
        - ENG_DATABASE
        - ENG_QUEUE
        - ENG_FILE
        - ENG_FOLDER
        - TRAPEZOID
        - PREDEFINED_PROCESS
        - SHIELD
        - DOCUMENT_SINGLE
        - DOCUMENT_MULTIPLE
        - MANUAL_INPUT
        - HEXAGON
        - CHEVRON
        - PENTAGON
        - OCTAGON
        - STAR
        - PLUS
        - ARROW_LEFT
        - ARROW_RIGHT
        - SUMMING_JUNCTION
        - OR
        - SPEECH_BUBBLE
        - INTERNAL_STORAGE
    ConnectorEndpoint:
      description: Stores canvas location for a connector start/end point.
      oneOf:
        - type: object
          properties:
            endpointNodeId:
              type: string
              description: Node ID that this endpoint attaches to.
            position:
              $ref: "#/components/schemas/Vector"
              description: The position of the endpoint relative to the node.
        - type: object
          properties:
            endpointNodeId:
              type: string
              description: Node ID that this endpoint attaches to.
            magnet:
              type: string
              description: The magnet type is a string enum.
              enum:
                - AUTO
                - TOP
                - BOTTOM
                - LEFT
                - RIGHT
                - CENTER
    ConnectorLineType:
      type: string
      description: Connector line type.
      enum:
        - STRAIGHT
        - ELBOWED
    ConnectorTextBackground:
      allOf:
        - $ref: "#/components/schemas/CornerTrait"
        - $ref: "#/components/schemas/MinimalFillsTrait"
    Component:
      type: object
      description: A description of a main component. Helps you identify which
        component instances are attached to.
      properties:
        key:
          type: string
          description: The key of the component
        name:
          type: string
          description: Name of the component
        description:
          type: string
          description: The description of the component as entered in the editor
        componentSetId:
          type: string
          description: The ID of the component set if the component belongs to one
        documentationLinks:
          type: array
          items:
            $ref: "#/components/schemas/DocumentationLink"
          description: An array of documentation links attached to this component
        remote:
          type: boolean
          description: Whether this component is a remote component that doesn't live in
            this file
      required:
        - key
        - name
        - description
        - documentationLinks
        - remote
    ComponentSet:
      type: object
      description: A description of a component set, which is a node containing a set
        of variants of a component.
      properties:
        key:
          type: string
          description: The key of the component set
        name:
          type: string
          description: Name of the component set
        description:
          type: string
          description: The description of the component set as entered in the editor
        documentationLinks:
          type: array
          items:
            $ref: "#/components/schemas/DocumentationLink"
          description: An array of documentation links attached to this component set
        remote:
          type: boolean
          description: Whether this component set is a remote component set that doesn't
            live in this file
      required:
        - key
        - name
        - description
    DocumentationLink:
      type: object
      description: Represents a link to documentation for a component or component set.
      properties:
        uri:
          type: string
          description: Should be a valid URI (e.g. https://www.figma.com).
      required:
        - uri
    VariableAlias:
      type: object
      description: Contains a variable alias
      properties:
        type:
          type: string
          enum:
            - VARIABLE_ALIAS
        id:
          type: string
          description: The id of the variable that the current variable is aliased to.
            This variable can be a local or remote variable, and both can be
            retrieved via the GET /v1/files/:file_key/variables/local endpoint.
      required:
        - type
        - id
    Interaction:
      type: object
      description: An interaction in the Figma viewer, containing a trigger and one or
        more actions.
      properties:
        trigger:
          oneOf:
            - $ref: "#/components/schemas/Trigger"
            - type: "null"
          description: The user event that initiates the interaction.
        actions:
          type: array
          items:
            $ref: "#/components/schemas/Action"
          description: The actions that are performed when the trigger is activated.
      required:
        - trigger
    Trigger:
      type: object
      description: |-
        The `"ON_HOVER"` and `"ON_PRESS"` trigger types revert the navigation when the trigger is finished (the result is temporary). 
        `"MOUSE_ENTER"`, `"MOUSE_LEAVE"`, `"MOUSE_UP"` and `"MOUSE_DOWN"` are permanent, one-way navigation.
        The `delay` parameter requires the trigger to be held for a certain duration of time before the action occurs.
        Both `timeout` and `delay` values are in milliseconds.
        The `"ON_MEDIA_HIT"` and `"ON_MEDIA_END"` trigger types can only trigger from a video. 
        They fire when a video reaches a certain time or ends. The `timestamp` value is in seconds.
      oneOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - ON_CLICK
                - ON_HOVER
                - ON_PRESS
                - ON_DRAG
          required:
            - type
        - $ref: "#/components/schemas/AfterTimeoutTrigger"
        - type: object
          properties:
            type:
              type: string
              enum:
                - MOUSE_ENTER
                - MOUSE_LEAVE
                - MOUSE_UP
                - MOUSE_DOWN
            delay:
              type: number
            deprecatedVersion:
              description: |-
                Whether this is a [deprecated version](https://help.figma.com/hc/en-us/articles/360040035834-Prototype-triggers#h_01HHN04REHJNP168R26P1CMP0A) of the trigger that was left unchanged for backwards compatibility.
                If not present, the trigger is the latest version.
              type: boolean
          required:
            - type
            - delay
        - $ref: "#/components/schemas/OnKeyDownTrigger"
        - $ref: "#/components/schemas/OnMediaHitTrigger"
        - type: object
          properties:
            type:
              type: string
              enum:
                - ON_MEDIA_END
          required:
            - type
    AfterTimeoutTrigger:
      type: object
      properties:
        type:
          type: string
          enum:
            - AFTER_TIMEOUT
        timeout:
          type: number
      required:
        - type
        - timeout
    OnKeyDownTrigger:
      type: object
      properties:
        type:
          type: string
          enum:
            - ON_KEY_DOWN
        device:
          type: string
          enum:
            - KEYBOARD
            - XBOX_ONE
            - PS4
            - SWITCH_PRO
            - UNKNOWN_CONTROLLER
        keyCodes:
          type: array
          items:
            type: number
      required:
        - type
        - device
        - keyCodes
    OnMediaHitTrigger:
      type: object
      properties:
        type:
          type: string
          enum:
            - ON_MEDIA_HIT
        mediaHitTime:
          type: number
      required:
        - type
        - mediaHitTime
    Action:
      type: object
      description: An action that is performed when a trigger is activated.
      oneOf:
        - type: object
          properties:
            type:
              type: string
              enum:
                - BACK
                - CLOSE
          required:
            - type
        - $ref: "#/components/schemas/OpenURLAction"
        - $ref: "#/components/schemas/UpdateMediaRuntimeAction"
        - $ref: "#/components/schemas/SetVariableAction"
        - $ref: "#/components/schemas/SetVariableModeAction"
        - $ref: "#/components/schemas/ConditionalAction"
        - $ref: "#/components/schemas/NodeAction"
    OpenURLAction:
      type: object
      description: An action that opens a URL.
      properties:
        type:
          type: string
          enum:
            - URL
        url:
          type: string
      required:
        - type
        - url
    UpdateMediaRuntimeAction:
      type: object
      description: An action that affects a video node in the Figma viewer. For
        example, to play, pause, or skip.
      oneOf:
        - type: object
          description: |-
            An action that updates the runtime of a media node by playing, pausing, toggling play/pause, 
            muting, unmuting, or toggling mute/unmute.
            The `destinationId` is the node ID of the media node to update. If `destinationId` is `null`, the action will 
            update the media node that contains the action.
            The `mediaAction` is the action to perform on the media node.
          properties:
            type:
              type: string
              enum:
                - UPDATE_MEDIA_RUNTIME
            destinationId:
              type:
                - string
                - "null"
            mediaAction:
              type: string
              enum:
                - PLAY
                - PAUSE
                - TOGGLE_PLAY_PAUSE
                - MUTE
                - UNMUTE
                - TOGGLE_MUTE_UNMUTE
          required:
            - type
            - destinationId
            - mediaAction
        - type: object
          description: |-
            An action that updates the runtime of a media node by skipping forward or backward.
            The `destinationId` is the node ID of the media node to update. If `destinationId` is `null`, the action will 
            update the media node that contains the action.
            The `mediaAction` is the action to perform on the media node.
            The `amountToSkip` is the amount of time to skip in seconds.
          properties:
            type:
              type: string
              enum:
                - UPDATE_MEDIA_RUNTIME
            destinationId:
              type:
                - string
                - "null"
            mediaAction:
              type: string
              enum:
                - SKIP_FORWARD
                - SKIP_BACKWARD
            amountToSkip:
              type: number
          required:
            - type
            - mediaAction
            - amountToSkip
        - type: object
          description: |-
            An action that updates the runtime of a media node by skipping to a specific time.
            The `destinationId` is the node ID of the media node to update. If `destinationId` is `null`, the action will 
            update the media node that contains the action.
            The `mediaAction` is the action to perform on the media node.
            The `newTimestamp` is the new time to skip to in seconds.
          properties:
            type:
              type: string
              enum:
                - UPDATE_MEDIA_RUNTIME
            destinationId:
              type:
                - string
                - "null"
            mediaAction:
              type: string
              enum:
                - SKIP_TO
            newTimestamp:
              type: number
          required:
            - type
            - mediaAction
            - newTimestamp
    NodeAction:
      type: object
      description: An action that navigates to a specific node in the Figma viewer.
      properties:
        type:
          type: string
          enum:
            - NODE
        destinationId:
          type:
            - string
            - "null"
        navigation:
          $ref: "#/components/schemas/Navigation"
        transition:
          oneOf:
            - $ref: "#/components/schemas/Transition"
            - type: "null"
        preserveScrollPosition:
          type: boolean
          description: Whether the scroll offsets of any scrollable elements in the
            current screen or overlay are preserved when navigating to the
            destination. This is applicable only if the layout of both the
            current frame and its destination are the same.
        overlayRelativePosition:
          $ref: "#/components/schemas/Vector"
          description: Applicable only when `navigation` is `"OVERLAY"` and the
            destination is a frame with `overlayPosition` equal to `"MANUAL"`.
            This value represents the offset by which the overlay is opened
            relative to this node.
        resetVideoPosition:
          type: boolean
          description: When true, all videos within the destination frame will reset their
            memorized playback position to 00:00 before starting to play.
        resetScrollPosition:
          type: boolean
          description: Whether the scroll offsets of any scrollable elements in the
            current screen or overlay reset when navigating to the destination.
            This is applicable only if the layout of both the current frame and
            its destination are the same.
        resetInteractiveComponents:
          type: boolean
          description: Whether the state of any interactive components in the current
            screen or overlay reset when navigating to the destination. This is
            applicable if there are interactive components in the destination
            frame.
      required:
        - type
        - destinationId
        - navigation
        - transition
    Navigation:
      type: string
      description: |-
        The method of navigation. The possible values are:
        - `"NAVIGATE"`: Replaces the current screen with the destination, also closing all overlays.
        - `"OVERLAY"`: Opens the destination as an overlay on the current screen.
        - `"SWAP"`: On an overlay, replaces the current (topmost) overlay with the destination. On a top-level frame, 
          behaves the same as `"NAVIGATE"` except that no entry is added to the navigation history.
        - `"SCROLL_TO"`: Scrolls to the destination on the current screen.
        - `"CHANGE_TO"`: Changes the closest ancestor instance of source node to the specified variant.
      enum:
        - NAVIGATE
        - SWAP
        - OVERLAY
        - SCROLL_TO
        - CHANGE_TO
    Transition:
      oneOf:
        - $ref: "#/components/schemas/SimpleTransition"
        - $ref: "#/components/schemas/DirectionalTransition"
    SimpleTransition:
      type: object
      description: Describes an animation used when navigating in a prototype.
      properties:
        type:
          type: string
          enum:
            - DISSOLVE
            - SMART_ANIMATE
            - SCROLL_ANIMATE
        duration:
          type: number
          description: The duration of the transition in milliseconds.
        easing:
          $ref: "#/components/schemas/Easing"
          description: The easing curve of the transition.
      required:
        - type
        - duration
        - easing
    DirectionalTransition:
      type: object
      description: Describes an animation used when navigating in a prototype.
      properties:
        type:
          type: string
          enum:
            - MOVE_IN
            - MOVE_OUT
            - PUSH
            - SLIDE_IN
            - SLIDE_OUT
        direction:
          type: string
          enum:
            - LEFT
            - RIGHT
            - TOP
            - BOTTOM
        duration:
          type: number
          description: The duration of the transition in milliseconds.
        easing:
          $ref: "#/components/schemas/Easing"
          description: The easing curve of the transition.
        matchLayers:
          type: boolean
          description: When the transition `type` is `"SMART_ANIMATE"` or when
            `matchLayers` is `true`, then the transition will be performed using
            smart animate, which attempts to match corresponding layers an
            interpolate other properties during the animation.
      required:
        - type
        - direction
        - duration
        - easing
    Easing:
      type: object
      description: Describes an easing curve.
      properties:
        type:
          $ref: "#/components/schemas/EasingType"
          description: The type of easing curve.
        easingFunctionCubicBezier:
          type: object
          description: A cubic bezier curve that defines the easing.
          properties:
            x1:
              type: number
              description: The x component of the first control point.
            y1:
              type: number
              description: The y component of the first control point.
            x2:
              type: number
              description: The x component of the second control point.
            y2:
              type: number
              description: The y component of the second control point.
          required:
            - x1
            - y1
            - x2
            - y2
        easingFunctionSpring:
          type: object
          description: A spring function that defines the easing.
          properties:
            mass:
              type: number
            stiffness:
              type: number
            damping:
              type: number
          required:
            - mass
            - stiffness
            - damping
      required:
        - type
    SetVariableAction:
      type: object
      description: Sets a variable to a specific value.
      properties:
        type:
          type: string
          enum:
            - SET_VARIABLE
        variableId:
          type:
            - string
            - "null"
        variableValue:
          $ref: "#/components/schemas/VariableData"
      required:
        - type
        - variableId
    SetVariableModeAction:
      type: object
      description: Sets a variable to a specific mode.
      properties:
        type:
          type: string
          enum:
            - SET_VARIABLE_MODE
        variableCollectionId:
          type:
            - string
            - "null"
        variableModeId:
          type:
            - string
            - "null"
      required:
        - type
        - variableId
        - variableMode
    ConditionalAction:
      type: object
      description: Checks if a condition is met before performing certain actions by
        using an if/else conditional statement.
      properties:
        type:
          type: string
          enum:
            - CONDITIONAL
        conditionalBlocks:
          type: array
          items:
            $ref: "#/components/schemas/ConditionalBlock"
      required:
        - type
        - conditionalBlocks
    VariableData:
      type: object
      description: A value to set a variable to during prototyping.
      properties:
        type:
          $ref: "#/components/schemas/VariableDataType"
        resolvedType:
          $ref: "#/components/schemas/VariableResolvedDataType"
        value:
          oneOf:
            - type: boolean
            - type: number
            - type: string
            - $ref: "#/components/schemas/RGB"
            - $ref: "#/components/schemas/RGBA"
            - $ref: "#/components/schemas/VariableAlias"
            - $ref: "#/components/schemas/Expression"
    VariableDataType:
      type: string
      description: Defines the types of data a VariableData object can hold
      enum:
        - BOOLEAN
        - FLOAT
        - STRING
        - COLOR
        - VARIABLE_ALIAS
        - EXPRESSION
    VariableResolvedDataType:
      type: string
      description: Defines the types of data a VariableData object can eventually equal
      enum:
        - BOOLEAN
        - FLOAT
        - STRING
        - COLOR
    Expression:
      type: object
      description: Defines the
        [Expression](https://help.figma.com/hc/en-us/articles/15253194385943)
        object, which contains a list of `VariableData` objects strung together
        by operators (`ExpressionFunction`).
      properties:
        expressionFunction:
          $ref: "#/components/schemas/ExpressionFunction"
        expressionArguments:
          type: array
          items:
            $ref: "#/components/schemas/VariableData"
      required:
        - expressionFunction
        - expressionArguments
    ExpressionFunction:
      type: string
      description: Defines the list of operators available to use in an Expression.
      enum:
        - ADDITION
        - SUBTRACTION
        - MULTIPLICATION
        - DIVISION
        - EQUALS
        - NOT_EQUAL
        - LESS_THAN
        - LESS_THAN_OR_EQUAL
        - GREATER_THAN
        - GREATER_THAN_OR_EQUAL
        - AND
        - OR
        - VAR_MODE_LOOKUP
        - NEGATE
        - NOT
    ConditionalBlock:
      type: object
      description: Either the if or else conditional blocks. The if block contains a
        condition to check. If that condition is met then it will run those list
        of actions, else it will run the actions in the else block.
      properties:
        condition:
          $ref: "#/components/schemas/VariableData"
        actions:
          type: array
          items:
            $ref: "#/components/schemas/Action"
      required:
        - actions
    Measurement:
      type: object
      description: A pinned distance between two nodes in Dev Mode
      properties:
        id:
          type: string
        start:
          $ref: "#/components/schemas/MeasurementStartEnd"
        end:
          $ref: "#/components/schemas/MeasurementStartEnd"
        offset:
          oneOf:
            - $ref: "#/components/schemas/MeasurementOffsetInner"
            - $ref: "#/components/schemas/MeasurementOffsetOuter"
        freeText:
          type: string
          description: When manually overridden, the displayed value of the measurement
      required:
        - id
        - start
        - end
        - offset
    MeasurementStartEnd:
      type: object
      description: The node and side a measurement is pinned to
      properties:
        nodeId:
          type: string
        side:
          type: string
          enum:
            - TOP
            - RIGHT
            - BOTTOM
            - LEFT
      required:
        - nodeId
        - side
    MeasurementOffsetInner:
      type: object
      description: Measurement offset relative to the inside of the start node
      properties:
        type:
          type: string
          enum:
            - INNER
        relative:
          type: number
      required:
        - type
        - relative
    MeasurementOffsetOuter:
      type: object
      description: Measurement offset relative to the outside of the start node
      properties:
        type:
          type: string
          enum:
            - OUTER
        fixed:
          type: number
      required:
        - type
        - fixed
    FrameOffset:
      type: object
      description: Position of a comment relative to the frame to which it is attached.
      properties:
        node_id:
          type: string
          description: Unique id specifying the frame.
        node_offset:
          $ref: "#/components/schemas/Vector"
          description: 2D vector offset within the frame from the top-left corner.
      required:
        - node_id
        - node_offset
    Region:
      type: object
      description: Position of a region comment on the canvas.
      properties:
        x:
          type: number
          description: X coordinate of the position.
        y:
          type: number
          description: Y coordinate of the position.
        region_height:
          type: number
          description: The height of the comment region. Must be greater than 0.
        region_width:
          type: number
          description: The width of the comment region. Must be greater than 0.
        comment_pin_corner:
          type: string
          description: The corner of the comment region to pin to the node's corner as a
            string enum.
          enum:
            - top-left
            - top-right
            - bottom-left
            - bottom-right
          default: bottom-right
      required:
        - x
        - y
        - region_height
        - region_width
    FrameOffsetRegion:
      type: object
      description: Position of a region comment relative to the frame to which it is
        attached.
      properties:
        node_id:
          type: string
          description: Unique id specifying the frame.
        node_offset:
          $ref: "#/components/schemas/Vector"
          description: 2D vector offset within the frame from the top-left corner.
        region_height:
          type: number
          description: The height of the comment region. Must be greater than 0.
        region_width:
          type: number
          description: The width of the comment region. Must be greater than 0.
        comment_pin_corner:
          type: string
          description: The corner of the comment region to pin to the node's corner as a
            string enum.
          enum:
            - top-left
            - top-right
            - bottom-left
            - bottom-right
          default: bottom-right
      required:
        - node_id
        - node_offset
        - region_height
        - region_width
    Comment:
      type: object
      description: A comment or reply left by a user.
      properties:
        id:
          type: string
          description: Unique identifier for comment.
        client_meta:
          description: Positioning information of the comment. Includes information on the
            location of the comment pin, which is either the absolute
            coordinates on the canvas or a relative offset within a frame. If
            the comment is a region, it will also contain the region height,
            width, and position of the anchor in regards to the region.
          oneOf:
            - $ref: "#/components/schemas/Vector"
            - $ref: "#/components/schemas/FrameOffset"
            - $ref: "#/components/schemas/Region"
            - $ref: "#/components/schemas/FrameOffsetRegion"
        file_key:
          type: string
          description: The file in which the comment lives
        parent_id:
          type: string
          description: If present, the id of the comment to which this is the reply
        user:
          $ref: "#/components/schemas/User"
          description: The user who left the comment
        created_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time at which the comment was left
        resolved_at:
          type:
            - string
            - "null"
          format: date-time
          description: If set, the UTC ISO 8601 time the comment was resolved
        message:
          type: string
          description: The content of the comment
        order_id:
          type:
            - string
            - "null"
          description: Only set for top level comments. The number displayed with the
            comment in the UI
        reactions:
          type: array
          description: An array of reactions to the comment
          items:
            $ref: "#/components/schemas/Reaction"
      required:
        - id
        - client_meta
        - file_key
        - user
        - created_at
        - message
        - reactions
        - order_id
    Reaction:
      type: object
      description: A reaction left by a user.
      properties:
        user:
          $ref: "#/components/schemas/User"
          description: The user who left the reaction.
        emoji:
          $ref: "#/components/schemas/Emoji"
        created_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time at which the reaction was left.
      required:
        - user
        - emoji
        - created_at
    Emoji:
      type: string
      description: The emoji type of reaction as shortcode (e.g. `:heart:`,
        `:+1::skin-tone-2:`). The list of accepted emoji shortcodes can be found
        in [this
        file](https://raw.githubusercontent.com/missive/emoji-mart/main/packages/emoji-mart-data/sets/14/native.json)
        under the top-level emojis and aliases fields, with optional skin tone
        modifiers when applicable.
    User:
      type: object
      description: A description of a user.
      properties:
        id:
          type: string
          description: Unique stable id of the user.
        handle:
          type: string
          description: Name of the user.
        img_url:
          type: string
          description: URL link to the user's profile image.
      required:
        - id
        - handle
        - img_url
    FrameInfo:
      type: object
      description: Data on the frame a component resides in.
      properties:
        nodeId:
          type: string
          description: The ID of the frame node within the file.
        name:
          type: string
          description: The name of the frame node.
        backgroundColor:
          type: string
          description: The background color of the frame node.
        pageId:
          type: string
          description: The ID of the page containing the frame node.
        pageName:
          type: string
          description: The name of the page containing the frame node.
      required:
        - pageId
        - pageName
    PublishedComponent:
      type: object
      description: An arrangement of published UI elements that can be instantiated
        across figma files.
      properties:
        key:
          type: string
          description: The unique identifier for the component.
        file_key:
          type: string
          description: The unique identifier of the Figma file that contains the component.
        node_id:
          type: string
          description: The unique identifier of the component node within the Figma file.
        thumbnail_url:
          type: string
          description: A URL to a thumbnail image of the component.
        name:
          type: string
          description: The name of the component.
        description:
          type: string
          description: The description of the component as entered by the publisher.
        created_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time when the component was created.
        updated_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time when the component was last updated.
        user:
          $ref: "#/components/schemas/User"
          description: The user who last updated the component.
        containing_frame:
          $ref: "#/components/schemas/FrameInfo"
          description: The containing frame of the component.
      required:
        - key
        - file_key
        - node_id
        - name
        - description
        - created_at
        - updated_at
        - user
    PublishedComponentSet:
      type: object
      description: A node containing a set of variants of a component.
      properties:
        key:
          type: string
          description: The unique identifier for the component set.
        file_key:
          type: string
          description: The unique identifier of the Figma file that contains the component
            set.
        node_id:
          type: string
          description: The unique identifier of the component set node within the Figma
            file.
        thumbnail_url:
          type: string
          description: A URL to a thumbnail image of the component set.
        name:
          type: string
          description: The name of the component set.
        description:
          type: string
          description: The description of the component set as entered by the publisher.
        created_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time when the component set was created.
        updated_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time when the component set was last updated.
        user:
          $ref: "#/components/schemas/User"
          description: The user who last updated the component set.
        containing_frame:
          $ref: "#/components/schemas/FrameInfo"
          description: The containing frame of the component set.
      required:
        - key
        - file_key
        - node_id
        - name
        - description
        - created_at
        - updated_at
        - user
    StyleType:
      type: string
      description: The type of style
      enum:
        - FILL
        - TEXT
        - EFFECT
        - GRID
    PublishedStyle:
      type: object
      description: A set of published properties that can be applied to nodes.
      properties:
        key:
          type: string
          description: The unique identifier for the style
        file_key:
          type: string
          description: The unique identifier of the Figma file that contains the style.
        node_id:
          type: string
          description: ID of the style node within the figma file
        style_type:
          $ref: "#/components/schemas/StyleType"
        thumbnail_url:
          type: string
          description: A URL to a thumbnail image of the style.
        name:
          type: string
          description: The name of the style.
        description:
          type: string
          description: The description of the style as entered by the publisher.
        created_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time when the style was created.
        updated_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time when the style was last updated.
        user:
          $ref: "#/components/schemas/User"
          description: The user who last updated the style.
        sort_position:
          type: string
          description: A user specified order number by which the style can be sorted.
      required:
        - key
        - file_key
        - node_id
        - style_type
        - name
        - description
        - created_at
        - updated_at
        - user
        - sort_position
    Project:
      type: object
      description: A Project can be identified by both the Project name, and the Project ID.
      properties:
        id:
          type: string
          description: The ID of the project.
        name:
          type: string
          description: The name of the project.
      required:
        - id
        - name
    Version:
      type: object
      description: A version of a file
      properties:
        id:
          type: string
          description: Unique identifier for version
        created_at:
          type: string
          format: date-time
          description: The UTC ISO 8601 time at which the version was created
        label:
          type:
            - string
            - "null"
          description: The label given to the version in the editor
        description:
          type:
            - string
            - "null"
          description: The description of the version as entered in the editor
        user:
          $ref: "#/components/schemas/User"
          description: The user that created the version
        thumbnail_url:
          type: string
          description: A URL to a thumbnail image of the file version.
      required:
        - id
        - created_at
        - label
        - description
        - user
    WebhookV2:
      type: object
      description: A description of an HTTP webhook (from Figma back to your application)
      properties:
        id:
          type: string
          description: The ID of the webhook
        event_type:
          $ref: "#/components/schemas/WebhookV2Event"
          description: The event this webhook triggers on
        team_id:
          type: string
          description: The team id you are subscribed to for updates
        status:
          $ref: "#/components/schemas/WebhookV2Status"
          description: The current status of the webhook
        client_id:
          type:
            - string
            - "null"
          description: The client ID of the OAuth application that registered this
            webhook, if any
        passcode:
          type: string
          description: The passcode that will be passed back to the webhook endpoint
        endpoint:
          type: string
          description: The endpoint that will be hit when the webhook is triggered
        description:
          type:
            - string
            - "null"
          description: Optional user-provided description or name for the webhook. This is
            provided to help make maintaining a number of webhooks more
            convenient. Max length 140 characters.
      required:
        - id
        - event_type
        - team_id
        - status
        - client_id
        - passcode
        - endpoint
        - description
    WebhookV2Event:
      type: string
      description: An enum representing the possible events that a webhook can subscribe to
      enum:
        - PING
        - FILE_UPDATE
        - FILE_VERSION_UPDATE
        - FILE_DELETE
        - LIBRARY_PUBLISH
        - FILE_COMMENT
    WebhookV2Status:
      type: string
      description: |-
        An enum representing the possible statuses you can set a webhook to:
        - `ACTIVE`: The webhook is healthy and receive all events
        - `PAUSED`: The webhook is paused and will not receive any events
      enum:
        - ACTIVE
        - PAUSED
    WebhookV2Request:
      type: object
      description: Information regarding the most recent interactions sent to a
        webhook endpoint
      properties:
        webhook_id:
          type: string
          description: The ID of the webhook the requests were sent to
        request_info:
          $ref: "#/components/schemas/WebhookV2RequestInfo"
        response_info:
          $ref: "#/components/schemas/WebhookV2ResponseInfo"
        error_msg:
          type:
            - string
            - "null"
          description: Error message for this request. NULL if no error occurred
      required:
        - webhook_id
        - request_info
        - response_info
        - error_msg
    WebhookV2RequestInfo:
      type: object
      description: Information regarding the request sent to a webhook endpoint
      properties:
        id:
          type: string
          description: The ID of the webhook
        endpoint:
          type: string
          description: The actual endpoint the request was sent to
        payload:
          type: object
          description: The contents of the request that was sent to the endpoint
        sent_at:
          type: string
          format: date-time
          description: UTC ISO 8601 timestamp of when the request was sent
      required:
        - id
        - endpoint
        - payload
        - sent_at
    WebhookV2ResponseInfo:
      type:
        - object
        - "null"
      description: Information regarding the reply sent back from a webhook endpoint
      properties:
        status:
          type: string
          description: HTTP status code of the response
        received_at:
          type: string
          format: date-time
          description: UTC ISO 8601 timestamp of when the response was received
      required:
        - status
        - received_at
    LibraryItemData:
      type: object
      description: An object representing the library item information in the payload
        of the `LIBRARY_PUBLISH` event
      properties:
        key:
          type: string
          description: Unique identifier for the library item
        name:
          type: string
          description: Name of the library item
      required:
        - key
        - name
    CommentFragment:
      type: object
      description: An object representing a fragment of a comment left by a user, used
        in the payload of the `FILE_COMMENT` event. Note only ONE of the fields
        below will be set
      properties:
        text:
          type: string
          description: Comment text that is set if a fragment is text based
        mention:
          type: string
          description: User id that is set if a fragment refers to a user mention
    WebhookBasePayload:
      type: object
      properties:
        passcode:
          type: string
          description: The passcode specified when the webhook was created, should match
            what was initially provided
        timestamp:
          type: string
          format: date-time
          description: UTC ISO 8601 timestamp of when the event was triggered.
        webhook_id:
          type: string
          description: The id of the webhook that caused the callback
      required:
        - passcode
        - timestamp
        - webhook_id
    WebhookPingPayload:
      allOf:
        - $ref: "#/components/schemas/WebhookBasePayload"
        - type: object
          properties:
            event_type:
              type: string
              enum:
                - PING
          required:
            - event_type
    WebhookFileUpdatePayload:
      allOf:
        - $ref: "#/components/schemas/WebhookBasePayload"
        - type: object
          properties:
            event_type:
              type: string
              enum:
                - FILE_UPDATE
            file_key:
              type: string
              description: The key of the file that was updated
            file_name:
              type: string
              description: The name of the file that was updated
          required:
            - event_type
            - file_key
            - file_name
    WebhookFileDeletePayload:
      allOf:
        - $ref: "#/components/schemas/WebhookBasePayload"
        - type: object
          properties:
            event_type:
              type: string
              enum:
                - FILE_DELETE
            file_key:
              type: string
              description: The key of the file that was deleted
            file_name:
              type: string
              description: The name of the file that was deleted
            triggered_by:
              $ref: "#/components/schemas/User"
              description: The user that deleted the file and triggered this event
          required:
            - event_type
            - file_key
            - file_name
            - triggered_by
    WebhookFileVersionUpdatePayload:
      allOf:
        - $ref: "#/components/schemas/WebhookBasePayload"
        - type: object
          properties:
            event_type:
              type: string
              enum:
                - FILE_VERSION_UPDATE
            created_at:
              type: string
              format: date-time
              description: UTC ISO 8601 timestamp of when the version was created
            description:
              type: string
              description: Description of the version in the version history
            file_key:
              type: string
              description: The key of the file that was updated
            file_name:
              type: string
              description: The name of the file that was updated
            triggered_by:
              $ref: "#/components/schemas/User"
              description: The user that created the named version and triggered this event
            version_id:
              type: string
              description: ID of the published version
          required:
            - event_type
            - created_at
            - file_key
            - file_name
            - triggered_by
            - version_id
    WebhookLibraryPublishPayload:
      allOf:
        - $ref: "#/components/schemas/WebhookBasePayload"
        - type: object
          properties:
            event_type:
              type: string
              enum:
                - LIBRARY_PUBLISH
            created_components:
              type: array
              description: Components that were created by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            created_styles:
              type: array
              description: Styles that were created by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            created_variables:
              type: array
              description: Variables that were created by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            modified_components:
              type: array
              description: Components that were modified by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            modified_styles:
              type: array
              description: Styles that were modified by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            modified_variables:
              type: array
              description: Variables that were modified by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            deleted_components:
              type: array
              description: Components that were deleted by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            deleted_styles:
              type: array
              description: Styles that were deleted by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            deleted_variables:
              type: array
              description: Variables that were deleted by the library publish
              items:
                $ref: "#/components/schemas/LibraryItemData"
            description:
              type: string
              description: Description of the library publish
            file_key:
              type: string
              description: The key of the file that was published
            file_name:
              type: string
              description: The name of the file that was published
            library_item:
              $ref: "#/components/schemas/LibraryItemData"
              description: The library item that was published
            triggered_by:
              $ref: "#/components/schemas/User"
              description: The user that published the library and triggered this event
          required:
            - event_type
            - created_components
            - created_styles
            - created_variables
            - modified_components
            - modified_styles
            - modified_variables
            - deleted_components
            - deleted_styles
            - deleted_variables
            - file_key
            - file_name
            - library_item
            - triggered_by
    WebhookFileCommentPayload:
      allOf:
        - $ref: "#/components/schemas/WebhookBasePayload"
        - type: object
          properties:
            event_type:
              type: string
              enum:
                - FILE_COMMENT
            comment:
              type: array
              description: Contents of the comment itself
              items:
                $ref: "#/components/schemas/CommentFragment"
            comment_id:
              type: string
              description: Unique identifier for comment
            created_at:
              type: string
              format: date-time
              description: The UTC ISO 8601 time at which the comment was left
            file_key:
              type: string
              description: The key of the file that was commented on
            file_name:
              type: string
              description: The name of the file that was commented on
            mentions:
              type: array
              description: Users that were mentioned in the comment
              items:
                $ref: "#/components/schemas/User"
            triggered_by:
              $ref: "#/components/schemas/User"
              description: The user that made the comment and triggered this event
          required:
            - event_type
            - comment
            - comment_id
            - created_at
            - file_key
            - file_name
            - triggered_by
    ActivityLogUserEntity:
      type: object
      description: A Figma user
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - user
        id:
          type: string
          description: Unique stable id of the user.
        name:
          type: string
          description: Name of the user.
        email:
          type: string
          description: Email associated with the user's account.
      required:
        - type
        - id
        - name
        - email
    ActivityLogFileEntity:
      type: object
      description: A Figma Design or FigJam file
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - file
        key:
          type: string
          description: Unique identifier of the file.
        name:
          type: string
          description: Name of the file.
        editor_type:
          type: string
          description: Indicates if the object is a file on Figma Design or FigJam.
          enum:
            - figma
            - figjam
        link_access:
          type: string
          description: Access policy for users who have the link to the file.
          enum:
            - view
            - edit
            - org_view
            - org_edit
            - inherit
        proto_link_access:
          type: string
          description: Access policy for users who have the link to the file's prototype.
          enum:
            - view
            - org_view
            - inherit
      required:
        - type
        - key
        - name
        - editor_type
        - link_access
        - proto_link_access
    ActivityLogFileRepoEntity:
      type: object
      description: A file branch that diverges from and can be merged back into the
        main file
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - file_repo
        id:
          type: string
          description: Unique identifier of the file branch.
        name:
          type: string
          description: Name of the file.
        main_file_key:
          type: string
          description: Key of the main file.
      required:
        - type
        - id
        - name
        - main_file_key
    ActivityLogProjectEntity:
      type: object
      description: A project that a collection of Figma files are grouped under
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - project
        id:
          type: string
          description: Unique identifier of the project.
        name:
          type: string
          description: Name of the project.
      required:
        - type
        - id
        - name
    ActivityLogTeamEntity:
      type: object
      description: A Figma team that contains multiple users and projects
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - team
        id:
          type: string
          description: Unique identifier of the team.
        name:
          type: string
          description: Name of the team.
      required:
        - type
        - id
        - name
    ActivityLogWorkspaceEntity:
      type: object
      description: Part of the organizational hierarchy of managing files and users
        within Figma, only available on the Enterprise Plan
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - workspace
        id:
          type: string
          description: Unique identifier of the workspace.
        name:
          type: string
          description: Name of the workspace.
      required:
        - type
        - id
        - name
    ActivityLogOrgEntity:
      type: object
      description: A Figma organization
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - org
        id:
          type: string
          description: Unique identifier of the organization.
        name:
          type: string
          description: Name of the organization.
      required:
        - type
        - id
        - name
    ActivityLogPluginEntity:
      type: object
      description: A Figma plugin
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - plugin
        id:
          type: string
          description: Unique identifier of the plugin.
        name:
          type: string
          description: Name of the plugin.
        editor_type:
          type: string
          description: Indicates if the object is a plugin is available on Figma Design or
            FigJam.
          enum:
            - figma
            - figjam
      required:
        - type
        - id
        - name
        - editor_type
    ActivityLogWidgetEntity:
      type: object
      description: A Figma widget
      properties:
        type:
          type: string
          description: The type of entity.
          enum:
            - widget
        id:
          type: string
          description: Unique identifier of the widget.
        name:
          type: string
          description: Name of the widget.
        editor_type:
          type: string
          description: Indicates if the object is a widget available on Figma Design or
            FigJam.
          enum:
            - figma
            - figjam
      required:
        - type
        - id
        - name
        - editor_type
    ActivityLog:
      type: object
      description: An event returned by the Activity Logs API.
      properties:
        id:
          type: string
          description: The ID of the event.
        timestamp:
          type: number
          description: The timestamp of the event in seconds since the Unix epoch.
        actor:
          type:
            - object
            - "null"
          description: The user who performed the action.
          properties:
            type:
              type: string
              description: The type of the user.
              enum:
                - user
            id:
              type: string
              description: The ID of the user.
            name:
              type: string
              description: The name of the user. For SCIM events, the value is "SCIM
                Provider". For official support actions, the value is "Figma
                Support".
            email:
              type: string
              description: The email of the user.
          required:
            - name
        action:
          type: object
          description: The task or activity the actor performed.
          properties:
            type:
              type: string
              description: The type of the action.
            details:
              type:
                - object
                - "null"
              description: Metadata of the action. Each action type supports its own metadata
                attributes.
              additionalProperties: true
          required:
            - type
            - details
        entity:
          description: The resource the actor took the action on. It can be a user, file,
            project or other resource types.
          oneOf:
            - $ref: "#/components/schemas/ActivityLogUserEntity"
            - $ref: "#/components/schemas/ActivityLogFileEntity"
            - $ref: "#/components/schemas/ActivityLogFileRepoEntity"
            - $ref: "#/components/schemas/ActivityLogProjectEntity"
            - $ref: "#/components/schemas/ActivityLogTeamEntity"
            - $ref: "#/components/schemas/ActivityLogWorkspaceEntity"
            - $ref: "#/components/schemas/ActivityLogOrgEntity"
            - $ref: "#/components/schemas/ActivityLogPluginEntity"
            - $ref: "#/components/schemas/ActivityLogWidgetEntity"
          discriminator:
            propertyName: type
            mapping:
              user: "#/components/schemas/ActivityLogUserEntity"
              file: "#/components/schemas/ActivityLogFileEntity"
              file_repo: "#/components/schemas/ActivityLogFileRepoEntity"
              project: "#/components/schemas/ActivityLogProjectEntity"
              team: "#/components/schemas/ActivityLogTeamEntity"
              workspace: "#/components/schemas/ActivityLogWorkspaceEntity"
              org: "#/components/schemas/ActivityLogOrgEntity"
              plugin: "#/components/schemas/ActivityLogPluginEntity"
              widget: "#/components/schemas/ActivityLogWidgetEntity"
        context:
          type: object
          description: Contextual information about the event.
          properties:
            client_name:
              type:
                - string
                - "null"
              description: The third-party application that triggered the event, if
                applicable.
            ip_address:
              type: string
              description: The IP address from of the client that sent the event request.
            is_figma_support_team_action:
              type: boolean
              description: If Figma's Support team triggered the event. This is either true or
                false.
            org_id:
              type: string
              description: The id of the organization where the event took place.
            team_id:
              type:
                - string
                - "null"
              description: The id of the team where the event took place -- if this took place
                in a specific team.
          required:
            - client_name
            - ip_address
            - is_figma_support_team_action
            - org_id
            - team_id
      required:
        - id
        - timestamp
        - actor
        - action
        - entity
        - context
    PaymentStatus:
      type: object
      description: An object describing the user's payment status.
      properties:
        type:
          type: string
          description: |-
            The current payment status of the user on the resource, as a string enum:
              
            - `UNPAID`: user has not paid for the resource
            - `PAID`: user has an active purchase on the resource
            - `TRIAL`: user is in the trial period for a subscription resource
          enum:
            - UNPAID
            - PAID
            - TRIAL
    PaymentInformation:
      type: object
      description: An object describing a user's payment information for a plugin,
        widget, or Community file.
      properties:
        user_id:
          type: string
          description: The ID of the user whose payment information was queried. Can be
            used to verify the validity of a response.
        resource_id:
          type: string
          description: The ID of the plugin, widget, or Community file that was queried.
            Can be used to verify the validity of a response.
        resource_type:
          type: string
          description: The type of the resource.
          enum:
            - PLUGIN
            - WIDGET
            - COMMUNITY_FILE
        payment_status:
          $ref: "#/components/schemas/PaymentStatus"
        date_of_purchase:
          type: string
          format: date-time
          description: |-
            The UTC ISO 8601 timestamp indicating when the user purchased the resource. No value is given if the user has never purchased the resource.
              
            Note that a value will still be returned if the user had purchased the resource, but no longer has active access to it (e.g. purchase refunded, subscription ended).
      required:
        - user_id
        - resource_id
        - resource_type
        - payment_status
    VariableScope:
      type: string
      enum:
        - ALL_SCOPES
        - TEXT_CONTENT
        - CORNER_RADIUS
        - WIDTH_HEIGHT
        - GAP
        - ALL_FILLS
        - FRAME_FILL
        - SHAPE_FILL
        - TEXT_FILL
        - STROKE_COLOR
        - STROKE_FLOAT
        - EFFECT_FLOAT
        - EFFECT_COLOR
        - OPACITY
        - FONT_FAMILY
        - FONT_STYLE
        - FONT_WEIGHT
        - FONT_SIZE
        - LINE_HEIGHT
        - LETTER_SPACING
        - PARAGRAPH_SPACING
        - PARAGRAPH_INDENT
      description: |-
        Scopes allow a variable to be shown or hidden in the variable picker for various fields. This declutters the Figma UI if you have a large number of variables. Variable scopes are currently supported on `FLOAT`, `STRING`, and `COLOR` variables.
        `ALL_SCOPES` is a special scope that means that the variable will be shown in the variable picker for all variable fields. If `ALL_SCOPES` is set, no additional scopes can be set.
        `ALL_FILLS` is a special scope that means that the variable will be shown in the variable picker for all fill fields. If `ALL_FILLS` is set, no additional fill scopes can be set.
        Valid scopes for `FLOAT` variables:
        - `ALL_SCOPES`
        - `TEXT_CONTENT`
        - `WIDTH_HEIGHT`
        - `GAP`
        - `STROKE_FLOAT`
        - `EFFECT_FLOAT`
        - `OPACITY`
        - `FONT_WEIGHT`
        - `FONT_SIZE`
        - `LINE_HEIGHT`
        - `LETTER_SPACING`
        - `PARAGRAPH_SPACING`
        - `PARAGRAPH_INDENT`
        Valid scopes for `STRING` variables:
        - `ALL_SCOPES`
        - `TEXT_CONTENT`
        - `FONT_FAMILY`
        - `FONT_STYLE`
        Valid scopes for `COLOR` variables:
        - `ALL_SCOPES`
        - `ALL_FILLS`
        - `FRAME_FILL`
        - `SHAPE_FILL`
        - `TEXT_FILL`
        - `STROKE_COLOR`
        - `EFFECT_COLOR`
    VariableCodeSyntax:
      type: object
      description: An object containing platform-specific code syntax definitions for
        a variable. All platforms are optional.
      properties:
        WEB:
          type: string
        ANDROID:
          type: string
        iOS:
          type: string
    LocalVariableCollection:
      type: object
      description: A grouping of related Variable objects each with the same modes.
      properties:
        id:
          type: string
          description: The unique identifier of this variable collection.
        name:
          type: string
          description: The name of this variable collection.
        key:
          type: string
          description: The key of this variable collection.
        modes:
          type: array
          description: The modes of this variable collection.
          items:
            type: object
            properties:
              modeId:
                type: string
                description: The unique identifier of this mode.
              name:
                type: string
                description: The name of this mode.
            required:
              - modeId
              - name
        defaultModeId:
          type: string
          description: The id of the default mode.
        remote:
          type: boolean
          description: Whether this variable collection is remote.
        hiddenFromPublishing:
          type: boolean
          description: Whether this variable collection is hidden when publishing the
            current file as a library.
          default: false
        variableIds:
          type: array
          description: The ids of the variables in the collection. Note that the order of
            these variables is roughly the same as what is shown in Figma
            Design, however it does not account for groups. As a result, the
            order of these variables may not exactly reflect the exact ordering
            and grouping shown in the authoring UI.
          items:
            type: string
      required:
        - id
        - name
        - key
        - modes
        - defaultModeId
        - remote
        - hiddenFromPublishing
        - variableIds
    LocalVariable:
      type: object
      description: A Variable is a single design token that defines values for each of
        the modes in its VariableCollection. These values can be applied to
        various kinds of design properties.
      properties:
        id:
          type: string
          description: The unique identifier of this variable.
        name:
          type: string
          description: The name of this variable.
        key:
          type: string
          description: The key of this variable.
        variableCollectionId:
          type: string
          description: The id of the variable collection that contains this variable.
        resolvedType:
          type: string
          description: The resolved type of the variable.
          enum:
            - BOOLEAN
            - FLOAT
            - STRING
            - COLOR
        valuesByMode:
          type: object
          description: The values for each mode of this variable.
          additionalProperties:
            oneOf:
              - type: boolean
              - type: number
              - type: string
              - $ref: "#/components/schemas/RGBA"
              - $ref: "#/components/schemas/VariableAlias"
        remote:
          type: boolean
          description: Whether this variable is remote.
        description:
          type: string
          description: The description of this variable.
        hiddenFromPublishing:
          type: boolean
          description: |-
            Whether this variable is hidden when publishing the current file as a library.
            If the parent `VariableCollection` is marked as `hiddenFromPublishing`, then this variable will also be hidden from publishing via the UI. `hiddenFromPublishing` is independently toggled for a variable and collection. However, both must be true for a given variable to be publishable.
        scopes:
          type: array
          description: |-
            An array of scopes in the UI where this variable is shown. Setting this property will show/hide this variable in the variable picker UI for different fields.
            Setting scopes for a variable does not prevent that variable from being bound in other scopes (for example, via the Plugin API). This only limits the variables that are shown in pickers within the Figma UI.
          items:
            $ref: "#/components/schemas/VariableScope"
        codeSyntax:
          $ref: "#/components/schemas/VariableCodeSyntax"
        deletedButReferenced:
          type: boolean
          description: Indicates that the variable was deleted in the editor, but the
            document may still contain references to the variable. References to
            the variable may exist through bound values or variable aliases.
          default: false
      required:
        - id
        - name
        - key
        - variableCollectionId
        - resolvedType
        - valuesByMode
        - remote
        - description
        - hiddenFromPublishing
        - scopes
        - codeSyntax
    PublishedVariableCollection:
      type: object
      description: A grouping of related Variable objects each with the same modes.
      properties:
        id:
          type: string
          description: The unique identifier of this variable collection.
        subscribed_id:
          type: string
          description: The ID of the variable collection that is used by subscribing
            files. This ID changes every time the variable collection is
            modified and published.
        name:
          type: string
          description: The name of this variable collection.
        key:
          type: string
          description: The key of this variable collection.
        updatedAt:
          type: string
          format: date-time
          description: |-
            The UTC ISO 8601 time at which the variable collection was last updated.
            This timestamp will change any time a variable in the collection is changed.
      required:
        - id
        - subscribed_id
        - name
        - key
        - updatedAt
    PublishedVariable:
      type: object
      description: A Variable is a single design token that defines values for each of
        the modes in its VariableCollection. These values can be applied to
        various kinds of design properties.
      properties:
        id:
          type: string
          description: The unique identifier of this variable.
        subscribed_id:
          type: string
          description: The ID of the variable that is used by subscribing files. This ID
            changes every time the variable is modified and published.
        name:
          type: string
          description: The name of this variable.
        key:
          type: string
          description: The key of this variable.
        variableCollectionId:
          type: string
          description: The id of the variable collection that contains this variable.
        resolvedDataType:
          type: string
          description: The resolved type of the variable.
          enum:
            - BOOLEAN
            - FLOAT
            - STRING
            - COLOR
        updatedAt:
          type: string
          format: date-time
          description: The UTC ISO 8601 time at which the variable was last updated.
      required:
        - id
        - subscribed_id
        - name
        - key
        - variableCollectionId
        - resolvedDataType
        - updatedAt
    VariableCollectionCreate:
      type: object
      description: An object that contains details about creating a `VariableCollection`.
      properties:
        action:
          type: string
          description: The action to perform for the variable collection.
          enum:
            - CREATE
        id:
          type: string
          description: A temporary id for this variable collection.
        name:
          type: string
          description: The name of this variable collection.
        initialModeId:
          type: string
          description: The initial mode refers to the mode that is created by default. You
            can set a temporary id here, in order to reference this mode later
            in this request.
        hiddenFromPublishing:
          type: boolean
          description: Whether this variable collection is hidden when publishing the
            current file as a library.
          default: false
      required:
        - action
        - name
    VariableCollectionUpdate:
      type: object
      description: An object that contains details about updating a `VariableCollection`.
      properties:
        action:
          type: string
          description: The action to perform for the variable collection.
          enum:
            - UPDATE
        id:
          type: string
          description: The id of the variable collection to update.
        name:
          type: string
          description: The name of this variable collection.
        hiddenFromPublishing:
          type: boolean
          description: Whether this variable collection is hidden when publishing the
            current file as a library.
          default: false
      required:
        - action
        - id
    VariableCollectionDelete:
      type: object
      description: An object that contains details about deleting a `VariableCollection`.
      properties:
        action:
          type: string
          description: The action to perform for the variable collection.
          enum:
            - DELETE
        id:
          type: string
          description: The id of the variable collection to delete.
      required:
        - action
        - id
    VariableCollectionChange:
      oneOf:
        - $ref: "#/components/schemas/VariableCollectionCreate"
        - $ref: "#/components/schemas/VariableCollectionUpdate"
        - $ref: "#/components/schemas/VariableCollectionDelete"
      discriminator:
        propertyName: action
        mapping:
          CREATE: "#/components/schemas/VariableCollectionCreate"
          UPDATE: "#/components/schemas/VariableCollectionUpdate"
          DELETE: "#/components/schemas/VariableCollectionDelete"
    VariableModeCreate:
      type: object
      description: An object that contains details about creating a `VariableMode`.
      properties:
        action:
          type: string
          description: The action to perform for the variable mode.
          enum:
            - CREATE
        id:
          type: string
          description: A temporary id for this variable mode.
        name:
          type: string
          description: The name of this variable mode.
        variableCollectionId:
          type: string
          description: The variable collection that will contain the mode. You can use the
            temporary id of a variable collection.
      required:
        - action
        - name
        - variableCollectionId
    VariableModeUpdate:
      type: object
      description: An object that contains details about updating a `VariableMode`.
      properties:
        action:
          type: string
          description: The action to perform for the variable mode.
          enum:
            - UPDATE
        id:
          type: string
          description: The id of the variable mode to update.
        name:
          type: string
          description: The name of this variable mode.
        variableCollectionId:
          type: string
          description: The variable collection that contains the mode.
      required:
        - action
        - id
        - variableCollectionId
    VariableModeDelete:
      type: object
      description: An object that contains details about deleting a `VariableMode`.
      properties:
        action:
          type: string
          description: The action to perform for the variable mode.
          enum:
            - DELETE
        id:
          type: string
          description: The id of the variable mode to delete.
      required:
        - action
        - id
    VariableModeChange:
      oneOf:
        - $ref: "#/components/schemas/VariableModeCreate"
        - $ref: "#/components/schemas/VariableModeUpdate"
        - $ref: "#/components/schemas/VariableModeDelete"
      discriminator:
        propertyName: action
        mapping:
          CREATE: "#/components/schemas/VariableModeCreate"
          UPDATE: "#/components/schemas/VariableModeUpdate"
          DELETE: "#/components/schemas/VariableModeDelete"
    VariableCreate:
      type: object
      description: An object that contains details about creating a `Variable`.
      properties:
        action:
          type: string
          description: The action to perform for the variable.
          enum:
            - CREATE
        id:
          type: string
          description: A temporary id for this variable.
        name:
          type: string
          description: The name of this variable.
        variableCollectionId:
          type: string
          description: The variable collection that will contain the variable. You can use
            the temporary id of a variable collection.
        resolvedType:
          type: string
          description: The resolved type of the variable.
          enum:
            - BOOLEAN
            - FLOAT
            - STRING
            - COLOR
        description:
          type: string
          description: The description of this variable.
        hiddenFromPublishing:
          type: boolean
          description: Whether this variable is hidden when publishing the current file as
            a library.
          default: false
        scopes:
          type: array
          description: An array of scopes in the UI where this variable is shown. Setting
            this property will show/hide this variable in the variable picker UI
            for different fields.
          items:
            $ref: "#/components/schemas/VariableScope"
        codeSyntax:
          $ref: "#/components/schemas/VariableCodeSyntax"
      required:
        - action
        - name
        - variableCollectionId
        - resolvedType
    VariableUpdate:
      type: object
      description: An object that contains details about updating a `Variable`.
      properties:
        action:
          type: string
          description: The action to perform for the variable.
          enum:
            - UPDATE
        id:
          type: string
          description: The id of the variable to update.
        name:
          type: string
          description: The name of this variable.
        description:
          type: string
          description: The description of this variable.
        hiddenFromPublishing:
          type: boolean
          description: Whether this variable is hidden when publishing the current file as
            a library.
          default: false
        scopes:
          type: array
          description: An array of scopes in the UI where this variable is shown. Setting
            this property will show/hide this variable in the variable picker UI
            for different fields.
          items:
            $ref: "#/components/schemas/VariableScope"
        codeSyntax:
          $ref: "#/components/schemas/VariableCodeSyntax"
      required:
        - action
        - id
    VariableDelete:
      type: object
      description: An object that contains details about deleting a `Variable`.
      properties:
        action:
          type: string
          description: The action to perform for the variable.
          enum:
            - DELETE
        id:
          type: string
          description: The id of the variable to delete.
      required:
        - action
        - id
    VariableChange:
      oneOf:
        - $ref: "#/components/schemas/VariableCreate"
        - $ref: "#/components/schemas/VariableUpdate"
        - $ref: "#/components/schemas/VariableDelete"
      discriminator:
        propertyName: action
        mapping:
          CREATE: "#/components/schemas/VariableCreate"
          UPDATE: "#/components/schemas/VariableUpdate"
          DELETE: "#/components/schemas/VariableDelete"
    VariableModeValue:
      type: object
      description: An object that represents a value for a given mode of a variable.
        All properties are required.
      properties:
        variableId:
          type: string
          description: The target variable. You can use the temporary id of a variable.
        modeId:
          type: string
          description: Must correspond to a mode in the variable collection that contains
            the target variable.
        value:
          $ref: "#/components/schemas/VariableValue"
      required:
        - variableId
        - modeId
        - value
    VariableValue:
      description: The value for the variable. The value must match the variable's
        type. If setting to a variable alias, the alias must resolve to this
        type.
      oneOf:
        - type: boolean
        - type: number
        - type: string
        - $ref: "#/components/schemas/RGB"
        - $ref: "#/components/schemas/RGBA"
        - $ref: "#/components/schemas/VariableAlias"
    DevResource:
      type: object
      description: A dev resource in a file
      properties:
        id:
          type: string
          description: Unique identifier of the dev resource
        name:
          type: string
          description: The name of the dev resource.
        url:
          type: string
          description: The URL of the dev resource.
        file_key:
          type: string
          description: The file key where the dev resource belongs.
        node_id:
          type: string
          description: The target node to attach the dev resource to.
      required:
        - id
        - name
        - url
        - file_key
        - node_id
    LibraryAnalyticsComponentActionsByAsset:
      type: object
      description: Library analytics component actions data broken down by asset.
      properties:
        week:
          type: string
          description: The date in ISO 8601 format. e.g. 2023-12-13
        component_key:
          type: string
          description: Unique, stable id of the component.
        component_name:
          type: string
          description: Name of the component.
        component_set_key:
          type: string
          description: Unique, stable id of the component set that this component belongs
            to.
        component_set_name:
          type: string
          description: Name of the component set that this component belongs to.
        detachments:
          type: number
          description: The number of detach events for this period.
        insertions:
          type: number
          description: The number of insertion events for this period.
      required:
        - week
        - component_key
        - component_name
        - detachments
        - insertions
    LibraryAnalyticsComponentActionsByTeam:
      type: object
      description: Library analytics action data broken down by team.
      properties:
        week:
          type: string
          description: The date in ISO 8601 format. e.g. 2023-12-13
        team_name:
          type: string
          description: The name of the team using the library.
        workspace_name:
          type: string
          description: The name of the workspace that the team belongs to.
        detachments:
          type: number
          description: The number of detach events for this period.
        insertions:
          type: number
          description: The number of insertion events for this period.
      required:
        - week
        - team_name
        - detachments
        - insertions
    LibraryAnalyticsComponentUsagesByAsset:
      type: object
      description: Library analytics component usage data broken down by component.
      properties:
        component_key:
          type: string
          description: Unique, stable id of the component.
        component_name:
          type: string
          description: Name of the component.
        component_set_key:
          type: string
          description: Unique, stable id of the component set that this component belongs
            to.
        component_set_name:
          type: string
          description: Name of the component set that this component belongs to.
        usages:
          type: number
          description: The number of instances of the component within the organization.
        teams_using:
          type: number
          description: The number of teams using the component within the organization.
        files_using:
          type: number
          description: The number of files using the component within the organization.
      required:
        - component_key
        - component_name
        - usages
        - teams_using
        - files_using
    LibraryAnalyticsComponentUsagesByFile:
      type: object
      description: Library analytics component usage data broken down by file.
      properties:
        file_name:
          type: string
          description: The name of the file using the library.
        team_name:
          type: string
          description: The name of the team the file belongs to.
        workspace_name:
          type: string
          description: The name of the workspace that the file belongs to.
        usages:
          type: number
          description: The number of component instances from the library used within the
            file.
      required:
        - file_name
        - team_name
        - usages
    LibraryAnalyticsStyleActionsByAsset:
      type: object
      description: Library analytics style actions data broken down by asset.
      properties:
        week:
          type: string
          description: The date in ISO 8601 format. e.g. 2023-12-13
        style_key:
          type: string
          description: Unique, stable id of the style.
        style_name:
          type: string
          description: The name of the style.
        style_type:
          type: string
          description: The type of the style.
        detachments:
          type: number
          description: The number of detach events for this period.
        insertions:
          type: number
          description: The number of insertion events for this period.
      required:
        - week
        - style_key
        - style_name
        - style_type
        - detachments
        - insertions
    LibraryAnalyticsStyleActionsByTeam:
      type: object
      description: Library analytics style action data broken down by team.
      properties:
        week:
          type: string
          description: The date in ISO 8601 format. e.g. 2023-12-13
        team_name:
          type: string
          description: The name of the team using the library.
        workspace_name:
          type: string
          description: The name of the workspace that the team belongs to.
        detachments:
          type: number
          description: The number of detach events for this period.
        insertions:
          type: number
          description: The number of insertion events for this period.
      required:
        - week
        - team_name
        - detachments
        - insertions
    LibraryAnalyticsStyleUsagesByAsset:
      type: object
      description: Library analytics style usage data broken down by component.
      properties:
        style_key:
          type: string
          description: Unique, stable id of the style.
        style_name:
          type: string
          description: The name of the style.
        style_type:
          type: string
          description: The type of the style.
        usages:
          type: number
          description: The number of usages of the style within the organization.
        teams_using:
          type: number
          description: The number of teams using the style within the organization.
        files_using:
          type: number
          description: The number of files using the style within the organization.
      required:
        - style_key
        - style_name
        - style_type
        - usages
        - teams_using
        - files_using
    LibraryAnalyticsStyleUsagesByFile:
      type: object
      description: Library analytics style usage data broken down by file.
      properties:
        file_name:
          type: string
          description: The name of the file using the library.
        team_name:
          type: string
          description: The name of the team the file belongs to.
        workspace_name:
          type: string
          description: The name of the workspace that the file belongs to.
        usages:
          type: number
          description: The number of times styles from this library are used within the
            file.
      required:
        - file_name
        - team_name
        - usages
    LibraryAnalyticsVariableActionsByAsset:
      type: object
      description: Library analytics variable actions data broken down by asset.
      properties:
        week:
          type: string
          description: The date in ISO 8601 format. e.g. 2023-12-13
        variable_key:
          type: string
          description: Unique, stable id of the variable.
        variable_name:
          type: string
          description: The name of the variable.
        variable_type:
          type: string
          description: The type of the variable.
        collection_key:
          type: string
          description: Unique, stable id of the collection the variable belongs to.
        collection_name:
          type: string
          description: The name of the collection the variable belongs to.
        detachments:
          type: number
          description: The number of detach events for this period.
        insertions:
          type: number
          description: The number of insertion events for this period.
      required:
        - week
        - variable_key
        - variable_name
        - variable_type
        - collection_key
        - collection_name
        - detachments
        - insertions
    LibraryAnalyticsVariableActionsByTeam:
      type: object
      description: Library analytics variable action data broken down by team.
      properties:
        week:
          type: string
          description: The date in ISO 8601 format. e.g. 2023-12-13
        team_name:
          type: string
          description: The name of the team using the library.
        workspace_name:
          type: string
          description: The name of the workspace that the team belongs to.
        detachments:
          type: number
          description: The number of detach events for this period.
        insertions:
          type: number
          description: The number of insertion events for this period.
      required:
        - week
        - team_name
        - detachments
        - insertions
    LibraryAnalyticsVariableUsagesByAsset:
      type: object
      description: Library analytics variable usage data broken down by component.
      properties:
        variable_key:
          type: string
          description: Unique, stable id of the variable.
        variable_name:
          type: string
          description: The name of the variable.
        variable_type:
          type: string
          description: The type of the variable.
        collection_key:
          type: string
          description: Unique, stable id of the collection the variable belongs to.
        collection_name:
          type: string
          description: The name of the collection the variable belongs to.
        usages:
          type: number
          description: The number of usages of the variable within the organization.
        teams_using:
          type: number
          description: The number of teams using the variable within the organization.
        files_using:
          type: number
          description: The number of files using the variable within the organization.
      required:
        - variable_key
        - variable_name
        - variable_type
        - collection_key
        - collection_name
        - usages
        - teams_using
        - files_using
    LibraryAnalyticsVariableUsagesByFile:
      type: object
      description: Library analytics variable usage data broken down by file.
      properties:
        file_name:
          type: string
          description: The name of the file using the library.
        team_name:
          type: string
          description: The name of the team the file belongs to.
        workspace_name:
          type: string
          description: The name of the workspace that the file belongs to.
        usages:
          type: number
          description: The number of times variables from this library are used within the
            file.
      required:
        - file_name
        - team_name
        - usages
    ResponsePagination:
      type: object
      description: If pagination is needed due to the length of the response,
        identifies the next and previous pages.
      properties:
        prev_page:
          type: string
          description: A URL that calls the previous page of the response.
        next_page:
          type: string
          description: A URL that calls the next page of the response.
    ResponseCursor:
      type: object
      description: Pagination cursor
      properties:
        before:
          type: number
        after:
          type: number
    ErrorResponsePayloadWithErrMessage:
      type: object
      description: A response indicating an error occurred.
      properties:
        status:
          type: number
          description: Status code
        err:
          type: string
          description: A string describing the error
      required:
        - status
        - err
    ErrorResponsePayloadWithErrorBoolean:
      type: object
      description: A response indicating an error occurred.
      properties:
        error:
          type: boolean
          description: For erroneous requests, this value is always `true`.
          enum:
            - true
        status:
          type: number
          description: Status code
        message:
          type: string
          description: A string describing the error
      required:
        - error
        - status
        - message
  responses:
    GetFileResponse:
      description: Response from the GET /v1/files/{file_key} endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              name:
                type: string
                description: The name of the file as it appears in the editor.
              role:
                type: string
                enum:
                  - owner
                  - editor
                  - viewer
                description: The role of the user making the API request in relation to the
                  file.
              lastModified:
                type: string
                format: date-time
                description: The UTC ISO 8601 time at which the file was last modified.
              editorType:
                type: string
                enum:
                  - figma
                  - figjam
                description: The type of editor associated with this file.
              thumbnailUrl:
                type: string
                description: A URL to a thumbnail image of the file.
              version:
                type: string
                description: The version number of the file. This number is incremented when a
                  file is modified and can be used to check if the file has
                  changed between requests.
              document:
                $ref: "#/components/schemas/DocumentNode"
              components:
                type: object
                additionalProperties:
                  $ref: "#/components/schemas/Component"
                description: A mapping from component IDs to component metadata.
              componentSets:
                type: object
                additionalProperties:
                  $ref: "#/components/schemas/ComponentSet"
                description: A mapping from component set IDs to component set metadata.
              schemaVersion:
                type: number
                description: The version of the file schema that this file uses.
                default: 0
              styles:
                type: object
                additionalProperties:
                  $ref: "#/components/schemas/Style"
                description: A mapping from style IDs to style metadata.
              linkAccess:
                type: string
                description: The share permission level of the file link.
              mainFileKey:
                type: string
                description: The key of the main file for this file. If present, this file is a
                  component or component set.
              branches:
                type: array
                description: A list of branches for this file.
                items:
                  type: object
                  properties:
                    key:
                      type: string
                      description: The key of the branch.
                    name:
                      type: string
                      description: The name of the branch.
                    thumbnail_url:
                      type: string
                      description: A URL to a thumbnail image of the branch.
                    last_modified:
                      type: string
                      format: date-time
                      description: The UTC ISO 8601 time at which the branch was last modified.
                  required:
                    - key
                    - name
                    - thumbnail_url
                    - last_modified
            required:
              - name
              - role
              - lastModified
              - editorType
              - version
              - document
              - components
              - componentSets
              - schemaVersion
              - styles
    GetFileNodesResponse:
      description: Response from the GET /v1/files/{file_key}/nodes endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              name:
                type: string
                description: The name of the file as it appears in the editor.
              role:
                type: string
                enum:
                  - owner
                  - editor
                  - viewer
                description: The role of the user making the API request in relation to the
                  file.
              lastModified:
                type: string
                format: date-time
                description: The UTC ISO 8601 time at which the file was last modified.
              editorType:
                type: string
                enum:
                  - figma
                  - figjam
                description: The type of editor associated with this file.
              thumbnailUrl:
                type: string
                description: A URL to a thumbnail image of the file.
              version:
                type: string
                description: The version number of the file. This number is incremented when a
                  file is modified and can be used to check if the file has
                  changed between requests.
              nodes:
                type: object
                description: A mapping from node IDs to node metadata.
                additionalProperties:
                  type: object
                  properties:
                    document:
                      $ref: "#/components/schemas/Node"
                    components:
                      type: object
                      additionalProperties:
                        $ref: "#/components/schemas/Component"
                      description: A mapping from component IDs to component metadata.
                    componentSets:
                      type: object
                      additionalProperties:
                        $ref: "#/components/schemas/ComponentSet"
                      description: A mapping from component set IDs to component set metadata.
                    schemaVersion:
                      type: number
                      description: The version of the file schema that this file uses.
                      default: 0
                    styles:
                      type: object
                      additionalProperties:
                        $ref: "#/components/schemas/Style"
                      description: A mapping from style IDs to style metadata.
                  required:
                    - document
                    - components
                    - componentSets
                    - schemaVersion
                    - styles
            required:
              - name
              - role
              - lastModified
              - editorType
              - thumbnailUrl
              - version
              - nodes
    GetImagesResponse:
      description: Response from the GET /v1/images/{file_key} endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              err:
                type: "null"
                description: For successful requests, this value is always `null`.
              images:
                type: object
                description: A map from node IDs to URLs of the rendered images.
                additionalProperties:
                  type:
                    - string
                    - "null"
                  description: A URL to the requested image.
                  format: uri
            required:
              - err
              - images
    GetImageFillsResponse:
      description: Response from the GET /v1/files/{file_key}/images endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              status:
                type: number
                description: Status code
                enum:
                  - 200
              meta:
                type: object
                properties:
                  images:
                    type: object
                    description: A map of image references to URLs of the image fills.
                    additionalProperties:
                      type: string
                      description: A URL to the requested image fill.
                      format: uri
                required:
                  - images
            required:
              - error
              - status
              - meta
    GetTeamProjectsResponse:
      description: Response from the GET /v1/teams/{team_id}/projects endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              name:
                type: string
                description: The team's name.
              projects:
                type: array
                description: An array of projects.
                items:
                  $ref: "#/components/schemas/Project"
            required:
              - name
              - projects
    GetProjectFilesResponse:
      description: Response from the GET /v1/projects/{project_id}/files endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              name:
                type: string
                description: The project's name.
              files:
                type: array
                description: An array of files.
                items:
                  type: object
                  properties:
                    key:
                      type: string
                      description: The file's key.
                    name:
                      type: string
                      description: The file's name.
                    thumbnail_url:
                      type: string
                      description: The file's thumbnail URL.
                    last_modified:
                      type: string
                      format: date-time
                      description: The UTC ISO 8601 time at which the file was last modified.
                  required:
                    - key
                    - name
                    - last_modified
            required:
              - name
              - files
    GetFileVersionsResponse:
      description: Response from the GET /v1/files/{file_key}/versions endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              versions:
                type: array
                description: An array of versions.
                items:
                  $ref: "#/components/schemas/Version"
              pagination:
                $ref: "#/components/schemas/ResponsePagination"
            required:
              - versions
              - pagination
    GetCommentsResponse:
      description: Response from the GET /v1/files/{file_key}/comments endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              comments:
                type: array
                description: An array of comments.
                items:
                  $ref: "#/components/schemas/Comment"
            required:
              - comments
    PostCommentResponse:
      description: Response from the POST /v1/files/{file_key}/comments endpoint.
      content:
        application/json:
          schema:
            $ref: "#/components/schemas/Comment"
    DeleteCommentResponse:
      description: Response from the DELETE /v1/files/{file_key}/comments/{comment_id}
        endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
            required:
              - status
              - error
    GetCommentReactionsResponse:
      description: Response from the GET
        /v1/files/{file_key}/comments/{comment_id}/reactions endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              reactions:
                type: array
                description: An array of reactions.
                items:
                  $ref: "#/components/schemas/Reaction"
              pagination:
                $ref: "#/components/schemas/ResponsePagination"
            required:
              - reactions
              - pagination
    PostCommentReactionResponse:
      description: Response from the POST
        /v1/files/{file_key}/comments/{comment_id}/reactions endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
            required:
              - status
              - error
    DeleteCommentReactionResponse:
      description: Response from the DELETE
        /v1/files/{file_key}/comments/{comment_id}/reactions endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
            required:
              - status
              - error
    GetMeResponse:
      description: Response from the GET /v1/me endpoint.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/User"
              - type: object
                properties:
                  email:
                    type: string
                    description: Email associated with the user's account. This property is only
                      present on the /v1/me endpoint.
                required:
                  - email
    GetTeamComponentsResponse:
      description: Response from the GET /v1/teams/{team_id}/components endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                type: object
                properties:
                  components:
                    type: array
                    items:
                      $ref: "#/components/schemas/PublishedComponent"
                  cursor:
                    $ref: "#/components/schemas/ResponseCursor"
                required:
                  - components
            required:
              - status
              - error
              - meta
    GetFileComponentsResponse:
      description: Response from the GET /v1/files/{file_key}/components endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                type: object
                properties:
                  components:
                    type: array
                    items:
                      $ref: "#/components/schemas/PublishedComponent"
                required:
                  - components
            required:
              - status
              - error
              - meta
    GetComponentResponse:
      description: Response from the GET /v1/components/{key} endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                $ref: "#/components/schemas/PublishedComponent"
            required:
              - status
              - error
              - meta
    GetTeamComponentSetsResponse:
      description: Response from the GET /v1/teams/{team_id}/component_sets endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                type: object
                properties:
                  component_sets:
                    type: array
                    items:
                      $ref: "#/components/schemas/PublishedComponentSet"
                  cursor:
                    $ref: "#/components/schemas/ResponseCursor"
                required:
                  - component_sets
            required:
              - status
              - error
              - meta
    GetFileComponentSetsResponse:
      description: Response from the GET /v1/files/{file_key}/component_sets endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                type: object
                properties:
                  component_sets:
                    type: array
                    items:
                      $ref: "#/components/schemas/PublishedComponentSet"
                required:
                  - component_sets
            required:
              - status
              - error
              - meta
    GetComponentSetResponse:
      description: Response from the GET /v1/component_sets/{key} endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                $ref: "#/components/schemas/PublishedComponentSet"
            required:
              - status
              - error
              - meta
    GetTeamStylesResponse:
      description: Response from the GET /v1/teams/{team_id}/styles endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                type: object
                properties:
                  styles:
                    type: array
                    items:
                      $ref: "#/components/schemas/PublishedStyle"
                  cursor:
                    $ref: "#/components/schemas/ResponseCursor"
                required:
                  - styles
            required:
              - status
              - error
              - meta
    GetFileStylesResponse:
      description: Response from the GET /v1/files/{file_key}/styles endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                type: object
                properties:
                  styles:
                    type: array
                    items:
                      $ref: "#/components/schemas/PublishedStyle"
                required:
                  - styles
            required:
              - status
              - error
              - meta
    GetStyleResponse:
      description: Response from the GET /v1/styles/{key} endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                description: The status of the request.
                enum:
                  - 200
              error:
                type: boolean
                description: For successful requests, this value is always `false`.
                enum:
                  - false
              meta:
                $ref: "#/components/schemas/PublishedStyle"
            required:
              - status
              - error
              - meta
    PostWebhookResponse:
      description: Response from the POST /v2/webhooks endpoint.
      content:
        application/json:
          schema:
            $ref: "#/components/schemas/WebhookV2"
    GetWebhookResponse:
      description: Response from the GET /v2/webhooks/{webhook_id} endpoint.
      content:
        application/json:
          schema:
            $ref: "#/components/schemas/WebhookV2"
    PutWebhookResponse:
      description: Response from the PUT /v2/webhooks/{webhook_id} endpoint.
      content:
        application/json:
          schema:
            $ref: "#/components/schemas/WebhookV2"
    DeleteWebhookResponse:
      description: Response from the DELETE /v2/webhooks/{webhook_id} endpoint.
      content:
        application/json:
          schema:
            $ref: "#/components/schemas/WebhookV2"
    GetTeamWebhooksResponse:
      description: Response from the GET /v2/teams/{team_id}/webhooks endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              webhooks:
                type: array
                description: An array of webhooks.
                items:
                  $ref: "#/components/schemas/WebhookV2"
            required:
              - webhooks
    GetWebhookRequestsResponse:
      description: Response from the GET /v2/webhooks/{webhook_id}/requests endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              requests:
                type: array
                description: An array of webhook requests.
                items:
                  $ref: "#/components/schemas/WebhookV2Request"
            required:
              - requests
    GetActivityLogsResponse:
      description: Response from the GET /v1/activity_logs endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                enum:
                  - 200
                description: The response status code.
              error:
                type: boolean
                enum:
                  - false
                description: For successful requests, this value is always `false`.
              meta:
                type: object
                properties:
                  activity_logs:
                    type: array
                    description: An array of activity logs sorted by timestamp in ascending order by
                      default.
                    items:
                      $ref: "#/components/schemas/ActivityLog"
                  cursor:
                    type: string
                    description: Encodes the last event (the most recent event)
                  next_page:
                    type: boolean
                    description: Whether there is a next page of events
    GetPaymentsResponse:
      description: Response from the GET /v1/payments endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                enum:
                  - 200
                description: The response status code.
              error:
                type: boolean
                enum:
                  - false
                description: For successful requests, this value is always `false`.
              meta:
                $ref: "#/components/schemas/PaymentInformation"
            required:
              - status
              - error
              - meta
    GetLocalVariablesResponse:
      description: Response from the GET /v1/files/{file_key}/variables/local endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                enum:
                  - 200
                description: The response status code.
              error:
                type: boolean
                enum:
                  - false
                description: For successful requests, this value is always `false`.
              meta:
                type: object
                properties:
                  variables:
                    type: object
                    description: A map of variable ids to variables
                    additionalProperties:
                      $ref: "#/components/schemas/LocalVariable"
                  variableCollections:
                    type: object
                    description: A map of variable collection ids to variable collections
                    additionalProperties:
                      $ref: "#/components/schemas/LocalVariableCollection"
                required:
                  - variables
                  - variableCollections
            required:
              - status
              - error
              - meta
    GetPublishedVariablesResponse:
      description: Response from the GET /v1/files/{file_key}/variables/published endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                enum:
                  - 200
                description: The response status code.
              error:
                type: boolean
                enum:
                  - false
                description: For successful requests, this value is always `false`.
              meta:
                type: object
                properties:
                  variables:
                    type: object
                    description: A map of variable ids to variables
                    additionalProperties:
                      $ref: "#/components/schemas/PublishedVariable"
                  variableCollections:
                    type: object
                    description: A map of variable collection ids to variable collections
                    additionalProperties:
                      $ref: "#/components/schemas/PublishedVariableCollection"
                required:
                  - variables
                  - variableCollections
            required:
              - status
              - error
              - meta
    PostVariablesResponse:
      description: Response from the POST /v1/files/{file_key}/variables endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              status:
                type: number
                enum:
                  - 200
                description: The response status code.
              error:
                type: boolean
                enum:
                  - false
                description: For successful requests, this value is always `false`.
              meta:
                type: object
                properties:
                  tempIdToRealId:
                    type: object
                    description: A map of temporary ids in the request to the real ids of the newly
                      created objects
                    additionalProperties:
                      type: string
                required:
                  - tempIdToRealId
            required:
              - status
              - error
              - meta
    GetDevResourcesResponse:
      description: Response from the GET /v1/files/{file_key}/dev_resources endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              dev_resources:
                type: array
                description: An array of dev resources.
                items:
                  $ref: "#/components/schemas/DevResource"
            required:
              - dev_resources
    PostDevResourcesResponse:
      description: Response from the POST /v1/dev_resources endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              links_created:
                type: array
                description: An array of links created.
                items:
                  $ref: "#/components/schemas/DevResource"
              errors:
                type: array
                description: An array of errors.
                items:
                  type: object
                  properties:
                    file_key:
                      type:
                        - string
                        - "null"
                      description: The file key.
                    node_id:
                      type:
                        - string
                        - "null"
                      description: The node id.
                    error:
                      type: string
                      description: The error message.
                  required:
                    - error
            required:
              - links_created
    PutDevResourcesResponse:
      description: Response from the PUT /v1/dev_resources endpoint.
      content:
        application/json:
          schema:
            type: object
            properties:
              links_updated:
                type: array
                description: An array of links updated.
                items:
                  $ref: "#/components/schemas/DevResource"
              errors:
                type: array
                description: An array of errors.
                items:
                  type: object
                  properties:
                    id:
                      type: string
                      description: The id of the dev resource.
                    error:
                      type: string
                      description: The error message.
                  required:
                    - error
            required:
              - links_created
    DeleteDevResourceResponse:
      description: Response from the DELETE
        /v1/files/{file_key}/dev_resources/{dev_resource_id} endpoint.
    GetLibraryAnalyticsComponentActionsResponse:
      description: Response from the GET
        /v1/analytics/libraries/{file_key}/component/actions.
      content:
        application/json:
          schema:
            type: object
            properties:
              rows:
                description: An array of analytics data.
                oneOf:
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsComponentActionsByAsset"
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsComponentActionsByTeam"
              next_page:
                type: boolean
                description: Whether there is a next page of data that can be fetched.
              cursor:
                type: string
                description: The cursor to use to fetch the next page of data. Not present if
                  next_page is false.
            required:
              - rows
              - next_page
    GetLibraryAnalyticsComponentUsagesResponse:
      description: Response from the PUT
        /v1/analytics/libraries/{file_key}/component/usages.
      content:
        application/json:
          schema:
            type: object
            properties:
              rows:
                description: An array of analytics data.
                oneOf:
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsComponentUsagesByAsset"
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsComponentUsagesByFile"
              next_page:
                type: boolean
                description: Whether there is a next page of data that can be fetched.
              cursor:
                type: string
                description: The cursor to use to fetch the next page of data. Not present if
                  next_page is false.
            required:
              - rows
              - next_page
    GetLibraryAnalyticsStyleActionsResponse:
      description: Response from the GET /v1/analytics/libraries/{file_key}/style/actions.
      content:
        application/json:
          schema:
            type: object
            properties:
              rows:
                description: An array of analytics data.
                oneOf:
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsStyleActionsByAsset"
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsStyleActionsByTeam"
              next_page:
                type: boolean
                description: Whether there is a next page of data that can be fetched.
              cursor:
                type: string
                description: The cursor to use to fetch the next page of data. Not present if
                  next_page is false.
            required:
              - rows
              - next_page
    GetLibraryAnalyticsStyleUsagesResponse:
      description: Response from the PUT /v1/analytics/libraries/{file_key}/style/usages.
      content:
        application/json:
          schema:
            type: object
            properties:
              rows:
                description: An array of analytics data.
                oneOf:
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsStyleUsagesByAsset"
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsStyleUsagesByFile"
              next_page:
                type: boolean
                description: Whether there is a next page of data that can be fetched.
              cursor:
                type: string
                description: The cursor to use to fetch the next page of data. Not present if
                  next_page is false.
            required:
              - rows
              - next_page
    GetLibraryAnalyticsVariableActionsResponse:
      description: Response from the GET
        /v1/analytics/libraries/{file_key}/variable/actions.
      content:
        application/json:
          schema:
            type: object
            properties:
              rows:
                description: An array of analytics data.
                oneOf:
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsVariableActionsByAsset"
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsVariableActionsByTeam"
              next_page:
                type: boolean
                description: Whether there is a next page of data that can be fetched.
              cursor:
                type: string
                description: The cursor to use to fetch the next page of data. Not present if
                  next_page is false.
            required:
              - rows
              - next_page
    GetLibraryAnalyticsVariableUsagesResponse:
      description: Response from the PUT /v1/analytics/libraries/{file_key}/variable/usages.
      content:
        application/json:
          schema:
            type: object
            properties:
              rows:
                description: An array of analytics data.
                oneOf:
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsVariableUsagesByAsset"
                  - type: array
                    items:
                      $ref: "#/components/schemas/LibraryAnalyticsVariableUsagesByFile"
              next_page:
                type: boolean
                description: Whether there is a next page of data that can be fetched.
              cursor:
                type: string
                description: The cursor to use to fetch the next page of data. Not present if
                  next_page is false.
            required:
              - rows
              - next_page
    BadRequestErrorResponseWithErrMessage:
      description: Bad request. Parameters are invalid or malformed. Please check the
        input formats. This error can also happen if the requested resources are
        too large to complete the request, which results in a timeout. Please
        reduce the number and size of objects requested.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrMessage"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 400
                required:
                  - status
    BadRequestErrorResponseWithErrorBoolean:
      description: Bad request. Parameters are invalid or malformed. Please check the
        input formats. This error can also happen if the requested resources are
        too large to complete the request, which results in a timeout. Please
        reduce the number and size of objects requested.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrorBoolean"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 400
                required:
                  - status
    UnauthorizedErrorResponseWithErrorBoolean:
      description: Token is missing or incorrect.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrorBoolean"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 401
                required:
                  - status
    ForbiddenErrorResponseWithErrMessage:
      description: The request was valid, but the server is refusing action. The user
        might not have the necessary permissions for a resource, or may need an
        account of some sort.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrMessage"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 403
                required:
                  - status
    ForbiddenErrorResponseWithErrorBoolean:
      description: The request was valid, but the server is refusing action. The user
        might not have the necessary permissions for a resource, or may need an
        account of some sort.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrorBoolean"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 403
                required:
                  - status
    NotFoundErrorResponseWithErrMessage:
      description: The requested file or resource was not found.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrMessage"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 404
                required:
                  - status
    NotFoundErrorResponseWithErrorBoolean:
      description: The requested file or resource was not found.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrorBoolean"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 404
                required:
                  - status
    TooManyRequestsErrorResponseWithErrMessage:
      description: In some cases API requests may be throttled or rate limited. Please
        wait a while before attempting the request again (typically a minute).
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrMessage"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 429
                required:
                  - status
    TooManyRequestsErrorResponseWithErrorBoolean:
      description: In some cases API requests may be throttled or rate limited. Please
        wait a while before attempting the request again (typically a minute).
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrorBoolean"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 429
                required:
                  - status
    InternalServerErrorResponseWithErrMessage:
      description: An internal server error occurred.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrMessage"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 500
                required:
                  - status
    InternalServerErrorResponseWithErrorBoolean:
      description: An internal server error occurred.
      content:
        application/json:
          schema:
            allOf:
              - $ref: "#/components/schemas/ErrorResponsePayloadWithErrorBoolean"
              - type: object
                properties:
                  status:
                    type: number
                    description: Status code
                    enum:
                      - 500
                required:
                  - status