Deploy Integration Endpoints to Oracle Cloud Infrastructure API Gateway
You can deploy individual integration endpoints as routes to Oracle Cloud Infrastructure API Gateway. An Oracle Cloud Infrastructure API Gateway instance supports a maximum of 20 deployments. Each deployment can contain up to 50 routes (each routing to individual endpoints). This provides you with a capacity of 1000 integration endpoints to which to deploy.
- Restrictions
- Create a Dynamic Group and Policy to Grant Gateway Access
- Create a Virtual Cloud Network and an Internet Gateway
- Create an Oracle Cloud Infrastructure API Gateway and Deployment in Oracle Cloud Infrastructure Console
- Deploy an Integration to API Gateway
Note:
To perform tasks in the Oracle Cloud Infrastructure Console, you must have the ServiceAdministrator role.Restrictions
- Deployment to Oracle Cloud Infrastructure API Gateway only works in identity domain-enabled environments.
- Only integrations in a project can be deployed to Oracle Cloud Infrastructure API Gateway. The integration must be publicly available. That is, the Available to other projects check box must be selected for this integration.
- The integration must be activated.
- You can only deploy a REST Adapter trigger-based integration.
- REST Adapter trigger connections that expose multiple entry points to a single integration are not supported. See Receive Requests for Multiple Resources in a Single REST Adapter Trigger with a Pick Action.
See API Limits.
Create a Dynamic Group and Policy to Grant Gateway Access
- Create a dynamic group.
- Create a policy to grant access to Oracle Cloud Infrastructure API Gateway.
You create the required dynamic group and assign a policy to that group to allow your Oracle Integration instance to access Oracle Cloud Infrastructure API Gateway. The policy defines the permissions for the dynamic group and determines which operations the dynamic group can perform in the Oracle Cloud Infrastructure API Gateway.
- Log in to the Oracle Cloud Infrastructure Console.
- Obtain the client ID of the OAuth application for the Oracle Integration instance.
- In the upper right corner, select Profile, then click the identity domain.
- In the left navigation pane, click Oracle Cloud
Services.
The Oracle Cloud Services page for your domain appears.
- In the Name column, click your service instance.
- Scroll down to the General Information section and copy the client ID value to use to create your dynamic group.
- Scroll to the breadcrumbs at the top and click Default
domain.
- In the left navigation pane, click Dynamic groups.
- Click Create Dynamic Group.
- Enter the following details:
- In the Name and Description fields, enter values. These fields are required.
- In the Matching Rules section, enter the
required rule. The resource ID you specify must match the client ID of the OAuth
application of your Oracle Integration instance. Ensure that you enclose the value
in single quotes. For
example:
resource.id = 'client_ID'
- Scroll to the breadcrumbs at the top and click
Identity.
- In the left navigation pane, click Policies.
- Click Create Policy.
- Select the compartment in which to create the policy.
- Enter the following details:
- In the Name and Description fields, enter values. These fields are required.
- In the Policy Builder section, build the
required policy for the dynamic group. For
example:
allow dynamic-group dynamic_group to manage api-gateway-family in compartment compartment_name
Where:dynamic_group
: Is the dynamic group name you created.compartment_name
: Is the compartment in which your Oracle Integration instance is located.
This enables the Oracle Integration instance associated with the dynamic group to call Oracle Cloud Infrastructure API Gateway in this particular compartment.
Create a Virtual Cloud Network and an Internet Gateway
You must create a virtual cloud network and internet gateway before you can create an Oracle Cloud Infrastructure API Gateway.
- In the navigation menu, go to Networking.
- Click Virtual cloud networks.
- Click Create VCN.
- Enter the following information, then click Create
VCN.
Element Description Name Enter a virtual cloud network name. Compartment Displays the compartment you previously selected. IPv4 CIDR Blocks Assign up to five IPv4 CIDR blocks to a VCN. At least one is required. See VCN and Subnet Management. Use DNS hostnames in this VCN If you plan to use VCN DNS or a third-party DNS, this is required for instance hostname assignment. This selection cannot be changed after the VCN is created. See DNS in Your Virtual Cloud Network DNS Label This value is generated from the virtual cloud network name if not specified. DNS Domain Name This value is generated from the virtual cloud network name if not specified. The details page for the virtual cloud network is displayed.
- Click Create Subnet.
- Enter the following information, then click Create Subnet.
Element Description Name Enter a subnet name. Compartment Displays the compartment you previously selected. Subnet Type Select a subnet type: - Regional (Recommended)
- Availability Domain-specific
IPv4 CIDR Block Enter the IPv4 CIDR block. Route Table Compartment Select the route table compartment. Subnet Access Select an access type: - Public Access
- Private Access
Use DNS hostnames in this VCN If you plan to use VCN DNS or a third-party DNS, this is required for instance hostname assignment. This selection cannot be changed after the VCN is created. DNS Label This value is generated from the virtual cloud network name if not specified. DNS Domain Name This value is generated from the virtual cloud network name if not specified. Dhcp Options Compartment Select the default DHCP options. Select Security List Compartment Select the security list. Resource Logging Select to enable resource logging. - Under Resources, select Internet Gateways.
- Click Create Internet Gateway.
- Enter the following information, then click Create Internet
Gateway.
Element Description Name Enter an internet gateway name. Compartment Displays the compartment you previously selected. - Under Resources, select Security Lists.
- In the Name column, click the default security list.
- Click Add Ingress Rules.
- Specify the source CIDR value.
- Leave the Source Port Range field blank.
- Enter
443
in the Destination Port Range field. - Click Add Ingress Rules.
- Return to the details page for the virtual cloud network you created.
- In the Resources section, click Route Tables.
- In the Name column of the Route Tables section, click the default route rule.
- Click Add Route Rules.
- Enter the following information, then click Add Route
Rules.
Element Description Target Type Select Internet Gateway. Destination CIDR Block Enter the destination CIDR block. Target Internet Gateway Select the API gateway. Description Enter an optional description. - In the Resources section, click Network Security Groups.
- Click Network Security Group.
- Enter a name.
- Leave the compartment as is.
- Click Next.
- Select CIDR in the Source Type list.
- Select TCP in the IP Protocol list.
- Specify
All
in the Source Port Range field. - Specify the value in the Source CIDR field.
- Specify
443
in the Destination Port Range field. - Click Create.
- In the breadcrumbs at the top of the page, click the link for the virtual cloud network that you created.
- In the Resources section, click Security
Lists.
If egress rules do not exist, you must define them.
- In the Resources section, click Egress Rules.
Create an Oracle Cloud Infrastructure API Gateway and Deployment in Oracle Cloud Infrastructure Console
You must create an Oracle Cloud Infrastructure API Gateway. Each gateway instance supports a maximum of 20 deployments. Each deployment can handle up to 50 routes. This means that one gateway instance can protect up to 1000 APIs. You can select an existing deployment, enabling a new route to be created in that deployment. You can also create a new deployment.
- In the navigation menu, go to Developer Services.
- Under API Management, select Gateways.
- Select the compartment to use for deployment.
- Click Create Gateway.
- Enter the following information, then click
Create Gateway.
Element Description Name Enter a gateway name. Type Select Public. Compartment Displays the compartment you previously selected. Network Select the following networking details: - Virtual cloud network: Select a virtual cloud network.
- Subnet: Select a VCN with at least one regional subnet added.
See Networking Overview.
Enable network security groups Select the check box, then select a compartment with at least one network security group. Certificate Select an SSL/TLS certificate that has been added to Oracle Cloud for use with a custom DNS configuration or use the default certificate provided by the gateway. See Setting Up Custom Domains and TLS Certificates. The new gateway is displayed in the Name column on the Gateways page.
- Click the gateway name.
- Under Resources, click Deployments.
- Click Create
deployment.
The Create deployment wizard is displayed.
You can create deployments based on categories appropriate to your business environment. For example, you may want to create separate deployments for applications, functional areas within an application, client requirements (for example, all APIs for a client-facing portal), and so on. You then deploy the integration endpoints to the appropriate deployment category.
- Enter the following information, then click
Next.
Element Description Name Enter a deployment name. For this example, Netsuite
is entered.Path prefix Enter a prefix. For this example, /netsuite
is entered.Compartment Displays the compartment you previously selected. API request policies Select API request policies as required for your environment: - Mutual-TLS: Select to enable mTLS.
- CORS: Configure CORS access.
- Rate limiting: Configure rate limiting.
- Usage plans: Configure usage plans.
API logging policies Select a logging level. Tags (under Show advanced options) Add tags to organize your resources. - Select an Authentication
method, and specify additional details, then click Next
- No Authentication: Any client that has network access to the gateway can make requests to all routes in this deployment.
- Single Authentication: Configure integration with
a single identity provider. You can optionally limit access for all routes to
authenticated clients only.
If you select this option, authentication, validation, and other security fields are displayed for configuration.
- Multi-Authentication: Configure integration with
one or more identity providers. You can optionally limit access for all routes to
authenticated clients only.
If you select this option, additional authentication fields are displayed for configuration.
Route 1 is displayed.
Individual integration endpoints are deployed as routes to an Oracle Cloud Infrastructure API Gateway deployment.
- Enter the following information, then click
Next.
Element Description Path Enter a path (for example, /order
).Methods Select one or more methods based upon your requirements (for example, GET, POST, PUT, or others). Add a single backend This option enables all requests for this route to be sent to the same backend. Select a backend type. Each selection causes additional fields to be displayed for you to configure. - HTTP
- Oracle functions
- Stock response
- Logout
Add multiple backends Route to different backends based on criteria at runtime. To configure your route to support multiple backends, first define the request context element to use as the selector. The gateway uses the selector at runtime to choose the backend based on a matching rule defined for the backend.
Selector: Select the request context table. Some selections cause additional fields to be displayed for you to configure.- Auth
- Headers
- Host
- Path
- Query parameters
- Subdomain
- Usage plan ocid
Backends: Add one or more backends for your route. Each backend needs a matching expression that the gateway uses to match based on the request context in the selector at runtime.
Specifies the type of the backend service Expand and specify polices as required for your environment. - Show route request policies
- Show route response policies
- Show response caching policies
- Show route logging policies
- Review your selections on the Deployment
page, then click Create.
Route 1 is configured.
Note that HTTP is selected and the URL field shows the REST Adapter-trigger based integration to later publish from your project in Oracle Integration.
- Create additional routes, as needed.
For this example, a second route is created with a second REST Adapter-trigger based integration to later publish from your project in Oracle Integration.
- Follow Step 8 through Step 12 to create any additional deployments and routes. For this
example, a second deployment (Oracle Rest Say Hello World) is
created that includes a single route:
When complete, the two deployments are listed on the details page for the gateway.
You are now ready to deploy individual integration endpoints as routes to Oracle Cloud Infrastructure API Gateway.
Deploy an Integration to API Gateway
After completing all prerequisites and gateway and deployment configuration tasks, you can deploy individual integration endpoints as routes from a project to Oracle Cloud Infrastructure API Gateway.
- In the navigation pane, click Projects.
- Click the project name or click
.
- In the Integrations section, find the already-activated integration to publish. Only active REST Adapter, triggered-based integrations can be deployed.
- Click Actions
, and select Publish to API Gateway.
The Publish to API gateway panel opens.
- Enter the following information:
Element Description REST endpoint Displays the endpoint of the integration. This endpoint cannot be deselected. Search or select compartment Select the compartment created in the Oracle Cloud Infrastructure Console that includes Oracle Cloud Infrastructure API Gateway. Search or select API gateway Select the Oracle Cloud Infrastructure API Gateway instance created in that compartment. Select or create API gateway deployment Select a deployment inside the gateway instance. You can also create a gateway from this field. For this example, the test-oic-apigw gateway and NetSuite deployment created in Create an Oracle Cloud Infrastructure API Gateway and Deployment in Oracle Cloud Infrastructure Console are selected.
- Click Publish.
The deployment is visible in Oracle Cloud Infrastructure API Gateway. Use the Observe tab in the project to check if the API calls are being reached when invoked by the Oracle Cloud Infrastructure API Gateway deployment URL.
- If you want to unpublish your API gateway deployment, click Undo publish.