Access Control Routing
In API Connectivity Manager, you can apply global policies to API Gateways and Developer Portals to ensure your organization’s security requirements are enforced.
When you add policies at the environment level, they will apply to all proxies hosted within that environment.
See the Learn about Policies topic for an overview of the different policy types and available policies.
Complete the following prerequisites before proceeding with this guide:
- API Connectivity Manager is installed, licensed, and running.
- You have one or more Environments with API Gateway or Dev Portal clusters.
- You have published one or more API Gateways or Developer Portals with either JSON Web Token Assertion or OAuth2 Introspection enabled.
This guide provides instructions for completing tasks using the API Connectivity Manager user interface (UI).
To access the UI, go to the FQDN of your NGINX Instance Manager host and log in. On the Launchpad menu, select “API Connectivity Manager.”
You can use tools such as curl or Postman to interact with the API Connectivity Manager REST API. The API URL follows the format https://<NMS_FQDN>/api/acm/<API_VERSION> and must include authentication information with each call. For more information about authentication options, please refer to the API Overview.
Take the steps in this section if you would like to restrict access to Advanced Routes or HTTP methods based on either request headers or JWT tokens.
- In the API Connectivity Manager user interface, go to Services > <your workspace>, where “your workspace” is the workspace that contains the API Proxy.
- Select Edit Proxy from the Actions menu for the desired API Proxy.
- On the Policies tab, select Add Policy from the Actions menu.
- Select Add route to configure a rule. Select one or more keys and approved values which will be checked before allowing the end user access to the API. Optionally select an Advanced Route or list of HTTP methods which will restrict the Access Control check to requests which match that configuration.
- Optionally set the return code, which should be returned to requests which do not satisfy the condition specified.
"policies": {
    "access-control-routing": [
            {
                "action": {
                    "conditions": [
                        {
                            "allowAccess": {
                                "httpMethods": ["GET"]
                            },
                            "when": [
                                {
                                    "key": "token.role",
                                    "matchType": "STRING",
                                    "matchOneOf": {
                                        "values": [
                                            "admin"
                                        ]
                                    }
                                },
                                {
                                    "key": "token.sub",
                                    "matchType": "REGEX",
                                    "matchOneOf": {
                                        "values": [
                                            "^.*test.com"
                                        ]
                                    }
                                }
                            ]
                        }
                    ]
                }
            }
        ]
- Any requests which do not match a specified condition will be allowed to access the API Gateway or Developer Portal. Adding a rule with no route or HTTP method specified means that
- Adding multiple match conditions in a rule requires that all conditions are matched in order to access the API.
- Adding the same configuration of route and HTTP method to multiple rules will be treated as an OR condition.
- Any requests which match multiple rules will be checked from most to least specific.
- If
matchTypeis not specified,STRINGwill be used.- If the token claim is an array value,
STRINGandREGEXbehave differently.
STRINGwill match if any of the values contained in the array match one of the values.
REGEXwill check against the array converted to a comma-separated string. For example,[ "first", "second", "third" ]will becomefirst,second,thirdwhen the regular expression is checked against it.
- Attempt to contact the API Gateway or Developer Portal from a client
- Contact the IP address from an allowed IP address. The traffic should not be denied.