HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
Upload Files
File: //snap/google-cloud-cli/current/lib/surface/certificate_manager/certificates/create.yaml
- release_tracks: [ALPHA, BETA, GA]

  help_text:
    brief: Create a certificate.
    description: |
      Create a new certificate.

      * Managed certificates can be created by supplying one or more domain names
        and an (optional) list of DNS authorizations for those domain names.
      * Self-managed certificates can be created by uploading a certificate
        and its corresponding private key (both in PEM format).
    examples: |
      To create (upload) a self-managed certificate called `www-example-com`, run:

        $ {command} www-example-com --private-key-file=key.pem --certificate-file=cert.pem

      To create a certificate managed by Certificate Manager called `api-example-com`, run:

        $ {command} api-example-com --domains="api.example.com"

      To create a certificate managed by Certificate Manager called `api-example-com`, using an
      existing DNS authorization, run:

        $ {command} api-example-com --dns-authorizations=api-example-com \
          --domains="api.example.com"

  request:
    collection: certificatemanager.projects.locations.certificates
    api_version: v1
    modify_request_hooks:
    - googlecloudsdk.command_lib.certificate_manager.hooks:SetAuthorizationURL
    - googlecloudsdk.command_lib.certificate_manager.hooks:SetIssuanceConfigURL

  async:
    collection: certificatemanager.projects.locations.operations

  arguments:
    resource:
      help_text: The name of the certificate to create.
      spec: !REF googlecloudsdk.command_lib.certificate_manager.resources:certificate

    params:
    - group:
        mutex: true
        required: true
        help_text: |
          Configuration for creating and uploading certificates to Cloud Certificate Manager.
        params:
        - group:
            help_text: |
              Configuration for creating new managed certificates.
            params:
            - arg_name: domains
              api_field: certificate.managed.domains
              repeated: true
              required: true
              help_text: |
                Public domain name(s) to create a certificate for.

                * If a DNS authorization is provided for the domain, the certificate will be
                validated against the DNS record you added as part of the authorization flow.
                * If no DNS authorization is provided, Certificate Manager will attempt to validate
                the domain against the serving endpoint directly.

                You may list multiple, comma-separated domain names to include multiple
                names as Subject Alternative Names on the issued certificate.
            - group:
                mutex: true
                params:
                - arg_name: dns-authorizations
                  api_field: certificate.managed.dnsAuthorizations
                  repeated: true
                  help_text: |
                    Name(s) of the DNS authorizations for each listed domain.

                    Note that each domain requires a matching authorization, and any domain that
                    fails authorization will prevent issuance and/or renewal of the certificate.

                    To reference multiple DNS authorizations, provide a list of comma separated DNS
                    authorization resource names or URLs. For example:

                     $ {command} --dns-authorizations=api-example-com,www-example-com
                - arg_name: issuance-config
                  api_field: certificate.managed.issuanceConfig
                  help_text: |
                    Name of the Certificate Issuance Config to use for issuance.
        - group:
            help_text: |
              Configuration for uploading self-managed certificates and keys.
            params:
            - arg_name: certificate-file
              api_field: certificate.selfManaged.pemCertificate
              required: true
              type: "googlecloudsdk.calliope.arg_parsers:FileContents:"
              help_text: |
                Certificate data in PEM-encoded form.
            - arg_name: private-key-file
              api_field: certificate.selfManaged.pemPrivateKey
              required: true
              type: "googlecloudsdk.calliope.arg_parsers:FileContents:"
              help_text: |
                Private key data in PEM-encoded form
    - arg_name: scope
      api_field: certificate.scope
      default: DEFAULT
      help_text: |
        Scope of the managed certificate. This determines which services the certificate can
        be attached to/associated with. Defaults to `DEFAULT`.
      choices:
      - arg_value: "default"
        enum_value: DEFAULT
        help_text: |
          Certificates with DEFAULT scope are used for Load Balancing and Cloud CDN.

          If unsure, choose this option.
      - arg_value: "edge-cache"
        enum_value: EDGE_CACHE
        help_text: |
          Certificates with scope EDGE_CACHE are special-purposed certificates,
          scoped for use with Media Edge services only.
      - arg_value: "all-regions"
        enum_value: ALL_REGIONS
        help_text: |
          Certificates with scope ALL_REGIONS are currently used for
          Cross-region Internal Application Load Balancer only.
      - arg_value: "client-auth"
        enum_value: CLIENT_AUTH
        help_text: |
          Certificates with scope CLIENT_AUTH are used for client authentication.
    - arg_name: description
      api_field: certificate.description
      help_text: |
        Human-readable description of the resource.
    - arg_name: tags
      hidden: true
      api_field: certificate.tags.additionalProperties
      metavar: KEY=VALUE
      help_text: |
        List of tag KEY=VALUE pairs to add.
      type:
        arg_dict:
          flatten: true
          spec:
          - api_field: key
          - api_field: value

    labels:
      api_field: certificate.labels