> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-mintlify-1d264819.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# Crear una clave

> Crea una nueva API key.



## OpenAPI

````yaml /es/products/cloud/api-reference/cloud-openapi.json post /v1/organizations/{organizationId}/keys
openapi: 3.0.1
info:
  contact:
    email: support@clickhouse.com
    name: ClickHouse Support
    url: >-
      https://clickhouse.com/docs/en/cloud/manage/openapi?referrer=openapi-299828
  title: OpenAPI spec for ClickHouse Cloud
  version: '1.0'
servers:
  - url: https://api.clickhouse.cloud
security:
  - basicAuth: []
tags:
  - name: Organization
  - name: User management
  - name: Billing
  - name: Service
  - name: Backup
  - name: OpenAPI
  - name: Prometheus
  - name: ClickPipes
paths:
  /v1/organizations/{organizationId}/keys:
    post:
      tags:
        - OpenAPI
      summary: Crear una clave
      description: Crea una nueva API key.
      parameters:
        - description: ID de la organización propietaria de la clave.
          in: path
          name: organizationId
          required: true
          schema:
            format: uuid
            type: string
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ApiKeyPostRequest'
      responses:
        '200':
          content:
            application/json:
              schema:
                properties:
                  requestId:
                    description: ID único asignado a cada solicitud. UUIDv4
                    format: uuid
                    type: string
                  result:
                    $ref: '#/components/schemas/ApiKeyPostResponse'
                  status:
                    description: Código de estado HTTP.
                    example: 200
                    type: number
                type: object
          description: Respuesta exitosa
        '400':
          content:
            application/json:
              schema:
                properties:
                  error:
                    description: Descripción detallada del error.
                    type: string
                  status:
                    description: Código de estado HTTP.
                    example: 400
                    type: number
                type: object
          description: >-
            El servidor no puede o no quiere procesar la solicitud debido a algo
            que se considera un error del cliente.
components:
  schemas:
    ApiKeyPostRequest:
      properties:
        expireAt:
          description: >-
            Timestamp de expiración de la clave. Si no está presente, es `null`
            o está vacío, la clave nunca expira. ISO-8601.
          format: date-time
          nullable: true
          type: string
        hashData:
          $ref: '#/components/schemas/ApiKeyHashData'
        ipAccessList:
          description: >-
            Lista de direcciones IP autorizadas para acceder a la API con esta
            clave
          items:
            $ref: '#/components/schemas/IpAccessListEntry'
          type: array
        name:
          description: Nombre de la clave.
          type: string
        roles:
          description: Lista de roles asignados a la clave. Contiene al menos 1 elemento.
          items:
            enum:
              - admin
              - developer
              - query_endpoints
            type: string
          type: array
        state:
          description: >-
            Estado inicial de la clave: 'enabled', 'disabled'. Si no se
            proporciona, la nueva clave será 'enabled'.
          enum:
            - enabled
            - disabled
          type: string
    ApiKeyPostResponse:
      properties:
        key:
          $ref: '#/components/schemas/ApiKey'
        keyId:
          description: >-
            ID de clave generado. Se proporciona solo si no había 'hashData' en
            la solicitud.
          type: string
        keySecret:
          description: >-
            Secret de clave generado. Se proporciona solo si no había 'hashData'
            en la solicitud.
          type: string
    ApiKeyHashData:
      properties:
        keyIdHash:
          description: 'Hash del ID de la clave. '
          type: string
        keyIdSuffix:
          description: >-
            Últimos 4 dígitos del ID de la clave. Algoritmo: echo -n
            "yourpassword" | sha256sum | tr -d '-' | xxd -r -p | base64
          type: string
        keySecretHash:
          description: >-
            Hash del secreto de la clave. Algoritmo: echo -n "yourpassword" |
            sha256sum | tr -d '-' | xxd -r -p | base64
          type: string
    IpAccessListEntry:
      properties:
        description:
          description: >-
            Descripción opcional de la dirección IPv4 o del CIDR IPv4 desde los
            que se permitirá el acceso
          type: string
        source:
          description: IP o CIDR
          type: string
    ApiKey:
      properties:
        createdAt:
          description: Marca temporal de creación de la clave. ISO-8601.
          format: date-time
          type: string
        expireAt:
          description: >-
            Marca temporal de vencimiento de la clave. Si no está presente, es
            `null` o está vacía, la clave nunca vence. ISO-8601.
          format: date-time
          nullable: true
          type: string
        id:
          description: ID único de la API key.
          format: uuid
          type: string
        ipAccessList:
          description: >-
            Lista de direcciones IP permitidas para acceder a la API con esta
            clave
          items:
            $ref: '#/components/schemas/IpAccessListEntry'
          type: array
        keySuffix:
          description: Últimos 4 caracteres de la clave.
          type: string
        name:
          description: Nombre de la clave
          type: string
        roles:
          description: Lista de roles asignados a la clave. Contiene al menos 1 elemento.
          items:
            enum:
              - admin
              - developer
              - query_endpoints
            type: string
          type: array
        state:
          description: 'Estado de la clave: ''enabled'', ''disabled''.'
          enum:
            - enabled
            - disabled
          type: string
        usedAt:
          description: >-
            Marca temporal del último uso de la clave. Si no está presente, la
            clave nunca se ha usado. ISO-8601.
          format: date-time
          type: string
  securitySchemes:
    basicAuth:
      description: >-
        Usa el ID y el secreto de la clave obtenidos en la consola de ClickHouse
        Cloud: https://clickhouse.com/docs/cloud/manage/openapi
      scheme: basic
      type: http

````