Daytona · API Governance Rules

Daytona API Rules

Spectral linting rules defining API design standards and conventions for Daytona.

10 Rules error 6 warn 4
View Rules File View on GitHub

Rule Categories

daytona

Rules

error
daytona-paths-kebab-case
Path segments MUST be lowercase kebab-case (matching Daytona's docker-registry, object-storage, api-keys conventions).
$.paths.*~
warn
daytona-tags-lowercase-kebab
Tag names MUST be lowercase kebab-case (matching Daytona's convention).
$.tags[*].name
error
daytona-operation-has-operationId
Every operation MUST declare an operationId for SDK code generation.
$.paths[*][get,post,put,patch,delete,head,options]
warn
daytona-operationId-camelCase
operationId MUST be camelCase verbNoun (e.g., createSandbox, listSnapshots).
$.paths[*][get,post,put,patch,delete].operationId
error
daytona-operation-has-tag
Every operation MUST be tagged so it can be grouped in the API reference (Sandbox, Snapshots, Toolbox, etc.).
$.paths[*][get,post,put,patch,delete]
error
daytona-operation-has-summary
Every operation MUST declare a summary for the Scalar API reference.
$.paths[*][get,post,put,patch,delete]
error
daytona-security-bearer-required
A bearer auth scheme MUST be declared in components.securitySchemes.
$.components.securitySchemes
error
daytona-servers-required
Specs MUST declare at least one server. Use https://app.daytona.io/api for the control plane or https://proxy.app.daytona.io/toolbox for the in-sandbox Toolbox.
$.servers
warn
daytona-contact-info
info.contact MUST be set with Daytona's support contact ([email protected]).
$.info
warn
daytona-schema-descriptions
Components schemas SHOULD have a description so SDK comments are populated.
$.components.schemas[*]

Spectral Ruleset

Raw ↑
extends:
  - spectral:oas

rules:
  # Daytona uses /v1-style resource collections with kebab-case path segments
  daytona-paths-kebab-case:
    description: Path segments MUST be lowercase kebab-case (matching Daytona's docker-registry, object-storage, api-keys conventions).
    severity: error
    given: $.paths.*~
    then:
      function: pattern
      functionOptions:
        match: "^(/[a-z0-9]+([-/][a-z0-9]+)*|/\\{[a-zA-Z0-9_]+\\})+$"

  # Daytona tags are lowercase or kebab-case nouns (sandbox, snapshots, api-keys, docker-registry)
  daytona-tags-lowercase-kebab:
    description: Tag names MUST be lowercase kebab-case (matching Daytona's convention).
    severity: warn
    given: $.tags[*].name
    then:
      function: pattern
      functionOptions:
        match: "^[a-z]+(-[a-z]+)*$"

  # Every operation has an operationId
  daytona-operation-has-operationId:
    description: Every operation MUST declare an operationId for SDK code generation.
    severity: error
    given: $.paths[*][get,post,put,patch,delete,head,options]
    then:
      field: operationId
      function: truthy

  # operationId follows verbResource camelCase, matching Daytona NestJS controllers
  daytona-operationId-camelCase:
    description: operationId MUST be camelCase verbNoun (e.g., createSandbox, listSnapshots).
    severity: warn
    given: $.paths[*][get,post,put,patch,delete].operationId
    then:
      function: pattern
      functionOptions:
        match: "^[a-z][a-zA-Z0-9]*$"

  # Every operation is tagged
  daytona-operation-has-tag:
    description: Every operation MUST be tagged so it can be grouped in the API reference (Sandbox, Snapshots, Toolbox, etc.).
    severity: error
    given: $.paths[*][get,post,put,patch,delete]
    then:
      field: tags
      function: truthy

  # Every operation has a summary
  daytona-operation-has-summary:
    description: Every operation MUST declare a summary for the Scalar API reference.
    severity: error
    given: $.paths[*][get,post,put,patch,delete]
    then:
      field: summary
      function: truthy

  # Bearer auth via JWT API key is the canonical scheme
  daytona-security-bearer-required:
    description: A bearer auth scheme MUST be declared in components.securitySchemes.
    severity: error
    given: $.components.securitySchemes
    then:
      function: truthy

  # Servers must point to the production app.daytona.io host (or proxy.app.daytona.io for the Toolbox)
  daytona-servers-required:
    description: Specs MUST declare at least one server. Use https://app.daytona.io/api for the control plane or https://proxy.app.daytona.io/toolbox for the in-sandbox Toolbox.
    severity: error
    given: $.servers
    then:
      function: truthy

  # Provider contact must be set
  daytona-contact-info:
    description: info.contact MUST be set with Daytona's support contact ([email protected]).
    severity: warn
    given: $.info
    then:
      field: contact
      function: truthy

  # All schemas have descriptions for downstream codegen
  daytona-schema-descriptions:
    description: Components schemas SHOULD have a description so SDK comments are populated.
    severity: warn
    given: $.components.schemas[*]
    then:
      field: description
      function: truthy