Setting Up Custom Domains and TLS Certificates

Find out how to set up custom domains and TLS certificates with API Gateway.

The API gateways you create with the API Gateway service are TLS-enabled, and therefore require TLS certificates (formerly SSL certificates) issued by a Certificate Authority to secure them. You can have the API Gateway service obtain a default TLS certificate for you, or you can obtain a custom TLS certificate from a Certificate Authority yourself. To specify a particular custom domain name for an API gateway, you must obtain a custom TLS certificate, rather than have the API Gateway service obtain a default TLS certificate.

When you create an API gateway, you specify that the API gateway uses one of the following:

  • A default TLS certificate that the API Gateway service obtains for you. In this case, the API Gateway service requests a TLS certificate from an Oracle-designated Certificate Authority.
  • A custom TLS certificate that you obtain from your chosen Certificate Authority yourself. Your request to the Certificate Authority includes the custom domain name. The Certificate Authority returns a file containing the custom TLS certificate, and typically one or more files containing intermediate certificates forming a certificate chain from the TLS certificate back to the Certificate Authority.

You can obtain a custom TLS certificate in multiple ways:

  • You can obtain a custom TLS certificate from a third-party Certificate Authority, and then create an API Gateway certificate resource comprising the custom TLS certificate, any intermediate certificates, and the private key used to generate the TLS certificate. You can then select that API Gateway certificate resource when creating a new API gateway.
  • You can obtain a custom TLS certificate using the Certificates service to create a certificate resource. The Certificates service can issue a certificate directly, or you can import a certificate issued by a third-party Certificate Authority into the Certificates service. You can then select that Certificates service certificate resource when creating a new API gateway.

The way in which the TLS certificate is obtained determines how much control you have over the API gateway's domain name:

  • If the API Gateway service obtains a default TLS certificate for you, the API Gateway service gives the API gateway an auto-generated default domain name. The auto-generated default domain name comprises a random string of characters followed by .apigateway.<region-identifier>.oci.customer-oci.com. For example, laksjd.apigateway.us-phoenix-1.oci.customer-oci.com .
  • If you obtain a custom TLS certificate yourself, the API Gateway service gives the API gateway the custom domain name you specified in your request to the Certificate Authority.

The way in which the TLS certificate is obtained also determines responsibility for recording the mapping between the API gateway's domain name and its public IP address with a DNS provider:

  • If the API Gateway service obtains a default TLS certificate for you, the API Gateway service takes responsibility for recording the mapping between the API gateway's auto-generated default domain name and its public IP address with the Oracle Cloud Infrastructure DNS service.
  • If you obtain a custom TLS certificate yourself, you are responsible for recording the mapping between the API gateway's custom domain name and its public IP address with your chosen DNS provider as an A record.

Similarly, the handling of TLS certificate expiry and renewal is determined by how the TLS certificate is originally obtained:

  • If the API Gateway service obtains a default TLS certificate for you, the API Gateway service automatically renews the TLS certificate with the Oracle-designated Certificate Authority before it expires.
  • If you obtain a custom TLS certificate yourself, you are responsible for renewing the TLS certificate with your chosen Certificate Authority before it expires. See Renewing Custom TLS Certificates Used by API Gateways.

For some customers, use of custom domains and custom TLS certificates is obligatory. For example, if you are using Oracle Cloud Infrastructure Government Cloud, you are required to:

  • only obtain a TLS certificate from a particular, approved Certificate Authority
  • only use a particular, approved DNS provider

For other customers, use of custom domains is likely to be driven by commercial requirements. For example, typically you'll want to include your company name in the API gateway's domain name, rather than using the auto-generated random string of characters followed by .apigateway.<region-identifier>.oci.customer-oci.com.

Note the following:

  • You cannot delete an API Gateway certificate resource or Certificates service certificate resource that is currently being used by an API gateway. To delete the certificate resource, you must first remove it from any API gateway that is using it.
  • You can only specify one API Gateway certificate resource or Certificates service certificate resource for an API gateway.
  • You cannot update an API Gateway certificate resource after you have created it. However, you can update a Certificates service certificate resource.
Important

For public or production systems, Oracle recommends using custom TLS certificates. Oracle recommends only using default TLS certificates obtained by the API Gateway service for private or non-production systems (for example, for development and testing).

Obtaining a Custom TLS Certificate to Set Up a Custom Domain Name for an API Gateway

You can set up a custom domain name and custom TLS certificate in multiple ways:

Using an API Gateway Certificate Resource to Set Up a Custom Domain Name for an API Gateway

To use an API Gateway certificate resource to set up a custom domain name for an API gateway:

Step 1: Obtain a TLS Certificate from your chosen Certificate Authority

The precise steps to obtain a TLS certificate will be different, according to the Certificate Authority you choose to use. At a high level, the steps will probably be somewhat similar to the following, but always refer to the Certificate Authority documentation for more detailed information:

  1. Create a certificate signing request for your chosen Certificate Authority.

    Typically, you'll include information like the organization name, locality, and country in the certificate signing request.

    You'll also include a common name in the certificate signing request as the fully qualified domain name of the site you want to secure. The common name usually connects the TLS certificate with a particular domain. This domain name is used as the custom domain name for API gateways.

    When you create a certificate signing request, a public key is added to the request, and a corresponding private key is also generated and stored in a local file. You'll use this private key when you set up an API Gateway certificate resource, so make a note of its location. The private key you use to obtain a TLS certificate:

    • must be an RSA key
    • must be in PEM-encoded X.509 format
    • must start with -----BEGIN RSA PRIVATE KEY-----
    • must end with -----END RSA PRIVATE KEY-----
    • must not be protected by a passphrase
    • must have a minimum length of 2048 bits and must not exceed 4096 bits
  2. Submit the certificate signing request to the Certificate Authority.

    The Certificate Authority returns:

    • a file containing the custom TLS certificate for the API gateway itself (known as the 'leaf certificate' or 'end-entity certificate')
    • typically one or more files containing intermediate certificates that form a certificate chain from the leaf certificate back to the Certificate Authority

You can now use these certificate files to create an API Gateway certificate resource.

Step 2: Create an API Gateway certificate resource

An API Gateway certificate resource is a named definition of a TLS certificate that you can use when creating or updating an API gateway using the API Gateway service.

An API Gateway certificate resource comprises:

  • a name of your choice for the certificate resource itself
  • the custom TLS certificate for the API gateway (the 'leaf certificate' or 'end-entity certificate') returned by the Certificate Authority
  • any intermediate certificates forming a certificate chain from the leaf certificate back to the Certificate Authority
  • the private key paired with the public key that was included in the original certificate signing request

Note that you cannot update an API Gateway certificate resource after you have created it.

You can create an API Gateway certificate resource using the Console or the CLI.

Using the Console

To create an API Gateway certificate resource using the Console:

  1. In the Console, open the navigation menu and click Developer Services. Under API Management, click Gateways.
  2. Choose a Compartment you have permission to work in.
  3. On the Certificates page, click Add Certificate and specify:

    • Name: The name of the new API Gateway certificate resource. Avoid entering confidential information.
    • Certificate: The custom TLS certificate returned by the Certificate Authority (the 'leaf certficate' or 'end-entity certificate'). Drag and drop, select, or paste a valid TLS certificate. Note that the TLS certificate you specify:
      • must be in PEM-encoded X.509 format
      • must start with -----BEGIN CERTIFICATE-----
      • must end with -----END CERTIFICATE-----
      • must not exceed 4096 bits in length
    • Intermediate Certificates: (Optional) If there is one or more intermediate certificates forming a certificate chain from the TLS certificate back to the Certificate Authority, include the contents of the intermediate certificate files in the correct order. The correct order begins with the certificate directly signed by the Trusted Root Certificate Authority at the bottom, with any additional certificate directly above the Certificate Authority that signed it. For example:

      -----BEGIN CERTIFICATE-----
      <PEM_encoded_certificate>
      -----END CERTIFICATE-----
      -----BEGIN CERTIFICATE-----
      <PEM_encoded_certificate>
      -----END CERTIFICATE-----
      -----BEGIN CERTIFICATE-----
      <PEM_encoded_certificate>
      -----END CERTIFICATE-----
      -----BEGIN CERTIFICATE-----
      <PEM_encoded_certificate>
      -----END CERTIFICATE-----

      If you have concatenated the contents of intermediate certificate files into a single certificate chain file in the correct order, drag and drop that file, or select that file, or paste that file's content.

      If you don't have a concatenated certificate chain file, paste the contents of the individual certificate files, in the correct order.

      The combined length of any intermediate certificates you specify must not exceed 10240 bits.

    • Private Key: The private key used to obtain the TLS certificate from the Certificate Authority. Drag and drop, select, or paste a valid private key in this field. Note that the key you specify:
      • must be an RSA key
      • must be in PEM-encoded X.509 format
      • must start with -----BEGIN RSA PRIVATE KEY-----
      • must end with -----END RSA PRIVATE KEY-----
      • must not be protected by a passphrase
      • must have a minimum length of 2048 bits and must not exceed 4096 bits
  4. Click Create to create the API Gateway certificate resource.

Using the CLI

To create an API Gateway certificate resource using the CLI:

  1. Configure your client environment to use the CLI (Configuring Your Client Environment to use the CLI for API Gateway Development).
  2. Open a command prompt and run oci api-gateway certificate create to create the API Gateway certificate resource:

    oci api-gateway certificate create --display-name "<certificate-name>" --compartment-id <compartment-ocid> --certificate-file <certificate-file-path> --intermediate-certificates-file <intermediate-certificates-file-path> --private-key-file <private-key-file-path>

    where:

    • <certificate-name> is the name of the new API Gateway certificate resource. Avoid entering confidential information.
    • <compartment-ocid> is the OCID of the compartment to which the new API Gateway certificate resource will belong.
    • <certificate-file-path> is the path and name of the file containing the leaf certificate returned by the Certificate Authority. For example, ~/.certs/cert.pem. Note that the leaf certificate in the file you specify:

      • must be in PEM-encoded X.509 format
      • must start with -----BEGIN CERTIFICATE-----
      • must end with -----END CERTIFICATE-----
      • must not exceed 4096 bits in length
    • <intermediate-certificates-file-path> is optionally the path and name of a file containing one or more intermediate certificates forming a certificate chain from the leaf certificate back to the Certificate Authority. For example, ~/.certs/int_cert.pem. If the file contains multiple intermediate certificates, the intermediate certificates must be in the correct order. The correct order ends with the certificate directly signed by the Trusted Root Certificate Authority, with any additional certificate directly preceding the Certificate Authority that signed it. For example:

      -----BEGIN CERTIFICATE-----<PEM_encoded_certificate>-----END CERTIFICATE----------BEGIN CERTIFICATE-----<PEM_encoded_certificate>-----END CERTIFICATE----------BEGIN CERTIFICATE-----<PEM_encoded_certificate>-----END CERTIFICATE----------BEGIN CERTIFICATE-----<PEM_encoded_certificate>-----END CERTIFICATE-----

      The combined length of any intermediate certificates you specify must not exceed 10240 bits.

    • <private-key-file-path> is the path and name of the file containing the private key used to obtain the TLS certificate from the Certificate Authority. For example, ~/.certs/key.pem. Note that the private key in the file you specify:

      • must be an RSA key
      • must be in PEM-encoded X.509 format
      • must start with -----BEGIN RSA PRIVATE KEY-----
      • must end with -----END RSA PRIVATE KEY-----
      • must not be protected by a passphrase
      • must have a minimum length of 2048 bits and must not exceed 4096 bits

    For example:

    oci api-gateway certificate create --display-name "Acme gateway certificate" --compartment-id ocid1.compartment.oc1..aaaaaaaa7______ysq --certificate-file ~/.certs/cert.pem --private-key-file ~/.certs/key.pem

    The response to the command includes:

    • The OCID of the new API Gateway certificate resource.
    • The lifecycle state (for example, ACTIVE, FAILED).
    • The id of the work request to create the API Gateway certificate resource (details of work requests are available for seven days after completion, cancellation, or failure).

    If you want the command to wait to return control until the API Gateway certificate resource is active (or the request has failed), include either or both the following parameters:

    • --wait-for-state ACTIVE
    • --wait-for-state FAILED

    For example:

    oci api-gateway certificate create --display-name "Acme gateway certificate" --compartment-id ocid1.compartment.oc1..aaaaaaaa7______ysq --certificate-file ~/.certs/cert.pem --private-key-file ~/.certs/key.pem --wait-for-state ACTIVE

For more information about using the CLI, see Command Line Interface (CLI). For a complete list of flags and options available for CLI commands, see CLI Help.

Step 3: Specify the API Gateway certificate resource when creating an API gateway

To specify the API Gateway certificate resource when creating an API gateway:

  1. Follow the instructions in Creating an API Gateway to create an API gateway using either the Console or the CLI.
  2. Specify the API Gateway certificate resource as described in the instructions:

    • If using the Console: Use the Certificate field.
    • If using the CLI: Set the --certificate-id <certificate-ocid> property.

    The API Gateway service creates the new API gateway, and installs the custom TLS certificate and private key.

  3. Obtain the public IP address of the API gateway.
Step 4: Record the mapping between the API Gateway's custom domain name and public IP address with your chosen DNS provider

The precise steps to record the mapping between an API gateway's custom domain name and its public IP address depend on the DNS provider you choose to use. Typically, you will create a new record (specifically a new A record) in the DNS provider's configuration. The record associates the domain name you configured when requesting the TLS certificate from your chosen Certificate Authority with the public IP address that the API Gateway service assigns to the new API gateway. Refer to your chosen DNS provider's documentation for more detailed information.

Using a Certificates Service Certificate Resource to Set Up a Custom Domain Name for an API Gateway

To use a Certificates service certificate resource to set up a custom domain name for an API gateway:

Step 1: Create a Certificates Service certificate resource

You can use the Certificates service in multiple ways to create a certificate resource when setting up a custom domain name for an API gateway:

  • You can use the Certificates service to issue a TLS certificate that you plan to manage internally with the Certificates service. For more information about creating a Certificates service certificate resource in this way, see Creating a Certificate.
  • You can use the Certificates service to import a TLS certificate issued by a third-party Certificate Authority, that you plan to manage internally with the Certificates service. For more information about creating a Certificates service certificate resource in this way, see Importing a Certificate.

Note that although you can use the Certificates service to issue a TLS certificate that you plan to manage externally with a third-party Certificate Authority, you cannot use such an externally-managed TLS certificate when setting up a custom domain name for an API gateway.

Also note the following:

  • The TLS certificate:
    • must be in PEM-encoded X.509 format
    • must start with -----BEGIN CERTIFICATE-----
    • must end with -----END CERTIFICATE-----
    • must not exceed 4096 bits in length
  • The TLS certificate must have been created using one of the supported certificate profile types, as follows:
    • Supported certificate profile types: TLS Server or Client; TLS server.
    • Unsupported certificate profile types: TLS Client; TLS Code Sign.
  • The private key used to obtain the TLS certificate:
    • must be an RSA key
    • must be in PEM-encoded X.509 format
    • must start with -----BEGIN RSA PRIVATE KEY-----
    • must end with -----END RSA PRIVATE KEY-----
    • must not be protected by a passphrase
    • must have a minimum length of 2048 bits and must not exceed 4096 bits
Step 2: Specify the Certificates Service certificate resource when creating an API gateway

To specify the Certificates service certificate resource when creating an API gateway:

  1. Follow the instructions in Creating an API Gateway to create an API gateway using either the Console or the CLI.
  2. Specify the Certificates service certificate resource as described in the instructions:

    • If using the Console: Use the Certificate field.
    • If using the CLI: Set the --certificate-id <certificate-ocid> property.

    The API Gateway service creates the new API gateway, and installs the custom TLS certificate and private key.

  3. Obtain the public IP address of the API gateway.
Step 3: Record the Mapping Between the API Gateway's Custom Domain Name and Public IP Address With Your Chosen DNS Provider

The precise steps to record the mapping between an API gateway's custom domain name and its public IP address depend on the DNS provider you choose to use. Typically, you will create a new record (specifically a new A record) in the DNS provider's configuration. The record associates the domain name you configured when requesting the TLS certificate from your chosen Certificate Authority with the public IP address that the API Gateway service assigns to the new API gateway. Refer to your chosen DNS provider's documentation for more detailed information.

Renewing Custom TLS Certificates Used by API Gateways

TLS certificates are valid for a limited period of time (typically one or two years) before they expire. If the TLS certificate used by an API gateway expires, calls to an API deployed on the API gateway might be marked as insecure by the API client (for example, by a browser or by the curl command line tool) and blocked. To avoid blocked calls, you have to renew TLS certificates before they expire (sometimes referred to as 'rotating' certificates).

If the API Gateway service obtained the original TLS certificate for you, the API Gateway service automatically renews the TLS certificate with the Oracle-designated Certificate Authority before it expires. However, if you obtained a custom TLS certificate yourself, you are responsible for renewing the custom TLS certificate with your chosen Certificate Authority before it expires. When you request the renewal of a TLS certificate, the Certificate Authority returns a completely new TLS certificate.

The procedure for renewing a custom TLS certificate used by API gateways depends on whether you've created API Gateway certificate resources or Certificates service certificate resources.

Renewing custom TLS certificates for API Gateway certificate resources

When you've created an API Gateway certificate resource used by an API gateway, you cannot simply update the existing API Gateway certificate resource with the new TLS certificate. Instead, you create a new API Gateway certificate resource, add the new TLS certificate to the new certificate resource, and then update any API gateways that used the previous certificate resource to use the new certificate resource.

To renew the custom TLS certificate used by an API gateway:

  1. Submit a TLS certificate renewal request to the Certificate Authority from which you originally obtained the TLS certificate. The exact steps to renew a TLS certificate depend on the Certificate Authority you use, so always refer to the Certificate Authority documentation for more detailed information.

    When you create the certificate renewal request, a public key is added to the request, and a corresponding private key is also generated and stored in a local file. You'll use this private key when you set up the new API Gateway certificate resource, so make a note of its location.

    The Certificate Authority returns a file containing the new custom TLS certificate, and typically one or more files containing intermediate certificates forming a certificate chain from the TLS certificate back to the Certificate Authority.

  2. Create a new API Gateway certificate resource and add to it the new TLS certificate, any intermediate certificates, and the new private key (see Step 2: Create an API Gateway certificate resource).
  3. Update all the existing API gateways that used the original API Gateway certificate resource to use the new API Gateway certificate resource (see Updating API Gateways and API Deployments).
  4. When there are no API gateways still using the original API Gateway certificate resource, delete the original certificate resource:
    • If using the Console: On the Certificates page, click the Actions menu (Actions Menu) beside the original API Gateway certificate resource you want to delete, and then click Delete.
    • If using the CLI: Use the following command to delete the original API Gateway certificate resource:
      oci api-gateway certificate delete --certificate-id <certificate-ocid>

    Note that you cannot delete an API Gateway certificate resource if there are API gateways still using it.

Renewing custom TLS certificates for Certificates service certificate resources

When you've created a Certificates service certificate resource used by an API gateway, you can use the Certificates service to renew the TLS certificate by creating a new certificate version. The new certificate version has the same OCID as the original certificate, so you don't have to modify API gateways to use a new certificate resource. The API Gateway service automatically updates API gateways to use the new version. Note that there are some restrictions on the certificates that the Certificates service can renew. See Renewing a Certificate.

Using the API

For information about using the API and signing requests, see REST API documentation and Security Credentials. For information about SDKs, see SDKs and the CLI.

Use the:

  • CreateCertificate operation to create a new API Gateway certificate resource.
  • DeleteCertificate operation to delete an existing API Gateway certificate resource.
  • UpdateCertificate operation to change the details of an existing API Gateway certificate resource.
  • GetCertificate operation to see details of an existing API Gateway certificate resource.
  • ListCertificates operation to list all the certificates in a compartment.
  • ChangeCertificateCompartment operation to change the compartment to which an existing API Gateway certificate resource belongs.