OR operator.
You’ll allow requests from trusted IPs OR those with valid Basic Auth credentials, and then reject all others.
1. Start an endpoint for your service
Start an internal Agent Endpoint, replacing$PORT based on where your service listens.
You can also use one of our SDKs or the Kubernetes Operator.
2. Reserve a domain
Navigate to the Domains section of the ngrok dashboard and click New + to reserve a free static domain likehttps://your-service.ngrok.app or a custom domain you already own.
We’ll refer to this domain as $NGROK_DOMAIN from here on out.
3. Create a Cloud Endpoint
Navigate to the Endpoints section of the ngrok dashboard, then click New + and Cloud Endpoint. In the URL field, enter the domain you just reserved to finish creating your Cloud Endpoint.4. Add layers of authentication with Traffic Policy
While viewing your new cloud endpoint in the dashboard, copy the policy below and paste it into the Traffic Policy editor. You will need to change:- $TRUSTED_IP_FOO/- $TRUSTED_IP_BAR: Replace with public IPs of those who should have access to your service or an IP policy in your ngrok dashboard.
allow list for restrict-ips, but doesn’t actually enforce the restriction there.
Instead, the expression that follows the first action checks whether the restrict-ips action result variable actions.ngrok.restrict_ips.action is set to allow, which means that it would’ve allowed the request directly if you had set enforce: true.
If it’s false—the request didn’t match the IP allow list—then the policy then validates whether it contains a valid Basic Auth header.
Next, the policy checks whether either IP restrictions OR Basic Auth were successful, and if so, forwards to your upstream service.
A catch-all rule then sends a custom error response to all other requests.
6. Try out your endpoint
Visit the domain you reserved either in the browser or in the terminal using a tool likecurl.
You should see the app or service at the port connected to your internal Agent Endpoint.
Add base64-encoded username:password pair as an Authorization: Bearer header to verify your basic-auth action works as expected.
What’s next?
- Layer in more authentication mechanisms, like the oauthorbasic-authactions using the same pattern of checking the subsequent action result variables with an expression.
- Use the action result variables and CEL interpolation to add specific error messages to your catch-all custom-responseaction.
- View your traffic in Traffic Inspector to see requests that failed to authenticate but should have—for example, maybe a specific IP address is missing from your restrict-ipsallow list or a user who doesn’t realize they’re using an invalid JWT token.