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

# Create a secret

> Creates a new secret in a project across one or more environments. Values are encrypted at rest. Requires `read-write` permission on every environment in the request.



## OpenAPI

````yaml /api-reference/openapi.json post /v1/workspace/{ws}/project/{prj}/secret/
openapi: 3.0.3
info:
  title: Enkryptify API
  version: 1.0.0
  description: >-
    REST API for Enkryptify. Manage secrets, projects, teams and workspaces.
    Authenticate with an `ek_live_` API token via the `Authorization: Bearer`
    header. See https://docs.enkryptify.com/api-reference/introduction.
servers:
  - url: http://localhost:8080
    description: Production
security: []
tags:
  - name: auth
    description: Token exchange and authentication for API access.
  - name: workspace
    description: Workspaces group your projects, teams and members.
  - name: project
    description: Projects organize secrets per application or service.
  - name: team
    description: Teams scope which members can access which projects.
  - name: secret
    description: Read, create, update and delete secret values.
  - name: secret-share
    description: Create and consume time-bound encrypted secret shares.
  - name: tokens
    description: Manage API tokens for programmatic access.
  - name: sync
    description: Manage integrations that sync secrets to external systems.
  - name: me
    description: Inspect the authenticated user, sessions and preferences.
  - name: oidc
    description: Workspace-scoped OpenID Connect identity federation.
paths:
  /v1/workspace/{ws}/project/{prj}/secret/:
    post:
      tags:
        - secret
      summary: Create a secret
      description: >-
        Creates a new secret in a project across one or more environments.
        Values are encrypted at rest. Requires `read-write` permission on every
        environment in the request.
      operationId: createSecret
      parameters:
        - schema:
            type: string
          in: path
          name: ws
          required: true
        - schema:
            type: string
          in: path
          name: prj
          required: true
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                environments:
                  minItems: 1
                  type: array
                  items:
                    type: string
                    format: uuid
                    pattern: >-
                      ^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[1-8][0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$
                secrets:
                  minItems: 1
                  type: array
                  items:
                    type: object
                    properties:
                      key:
                        type: string
                        minLength: 2
                        maxLength: 48
                        pattern: ^[A-Za-z0-9_-]+$
                      value:
                        type: string
                        maxLength: 65536
                      note:
                        type: string
                        maxLength: 255
                      type:
                        type: string
                        enum:
                          - runtime
                          - build
                      dataType:
                        type: string
                        enum:
                          - text
                          - json
                    required:
                      - key
                      - value
                      - type
                      - dataType
              required:
                - environments
                - secrets
      responses:
        '200':
          description: Default Response
          content:
            application/json:
              schema:
                type: object
                properties:
                  success:
                    type: boolean
                required:
                  - success
                additionalProperties: false
      security:
        - apiKeyAuth: []
      x-codeSamples:
        - lang: bash
          label: cURL
          source: >-
            curl -X POST
            'http://localhost:8080/v1/workspace/ws_example/project/prj_example/secret/'
            \
              -H 'Authorization: Bearer ek_live_xxxxx' \
              -H 'Content-Type: application/json' \
              -d '{ // request body fields, see schema }'
        - lang: javascript
          label: TypeScript
          source: >-
            const response = await
            fetch('http://localhost:8080/v1/workspace/ws_example/project/prj_example/secret/',
            {
              method: 'POST',
              headers: {
                Authorization: 'Bearer ek_live_xxxxx',
                'Content-Type': 'application/json',
              },
              body: JSON.stringify({
                // request body fields, see schema
              }),
            });


            const data = await response.json();
        - lang: python
          label: Python
          source: |-
            import requests

            response = requests.post(
                'http://localhost:8080/v1/workspace/ws_example/project/prj_example/secret/',
                headers={
                    'Authorization': 'Bearer ek_live_xxxxx',
                    'Content-Type': 'application/json',
                },
                json={
                    # request body fields, see schema
                },
            )

            data = response.json()
components:
  securitySchemes:
    apiKeyAuth:
      type: http
      scheme: bearer
      bearerFormat: API Key
      description: >-
        API key authentication. Pass `Authorization: Bearer ek_live_xxxxx` on
        every request.

````