Invoke a flow with an API endpoint
An API Endpoint flow is a type of flow triggered by changes at an external source.
Unlike flows that start with events associated with a connected application, these flows can be triggered at any time. When the external client calls the endpoint, the flow is executed and the client receives any output from that flow execution.
The only requirement is that the external client calls the designated endpoint with valid security credentials. There are three ways of securing your API endpoint for Okta Workflows:
- Secure with OAuth 2.0
-
The API endpoint flow is secured using OAuth 2.0 protocols for authorization of scoped access tokens. An admin adds the appropriate scopes to any app integration that needs to call the API. This feature supports the OAuth client credentials grant type with the use of a private JSON Web Token (JWT). The flow is triggered after the Okta authorization server receives and approves the access token.
Custom authorization servers aren't supported for this method.
- Secure with client token
-
The API endpoint flow is registered as a webhook and is secured through a unique client token. It's only accessible if the requesting service passes the proper client token through the invoke URL. The invoke URL is constructed using a flow alias.
- None (public service)
-
The API endpoint flow is publicly available to anyone with the invoke URL. The invoke URL is constructed using a flow alias.
Early Access release. See Enable self-service features.
You can change how you secure your API endpoint using the API endpoint settings dialog.
After you invoke a flow, it sends the flow output as a response object.
Secure with OAuth 2.0
Early Access release. See Enable self-service features.
Use the following procedure to invoke the API endpoint for a flow using a secure OAuth 2.0 client credential exchange. This process requires a private JWT key.
Create an API service integration app
Creating an API service integration app is an ideal way to invoke a secured flow. The app's only purpose is to invoke the flow and return the output to the invoking request.
-
In the Admin Console, go to .
-
Click Create App Integration.
-
Select API Services and click Next.
-
Provide an App integration name and select click Save to create your app integration.
If you want to build your own API service, see Build your API service integration in the Okta developer documentation.
-
In the list of applications, open your new API service app.
-
On the General tab, edit the Client Credentials pane and select the Public key / Private key option.
-
Click Add key and in the dialog click Generate new key. Copy this private key value to your local system. Use this private key to sign the payload from your client when it calls the authorization server. The Okta authorization server uses the corresponding public key to validate the credentials and generate the access token. For more details on creating a service application, see Implement OAuth for Okta with a service app and Build a JWT for Client Authentication.
-
On the Okta API Scopes tab, click Grant for the okta.workflows.invoke.manage scope. Click Grant Access on the permissions dialog to confirm the action.
If you built your own custom API service, add this scope as it is required for the invocation to work properly.
Configure your API endpoint settings
For existing API endpoint flows, you can skip the flow creation steps. Instead, click the Endpoint settings icon shown on the bottom of the API Endpoint event card in your flow.
-
Create a flow in your Workflows Console and click Add event.
-
From the Pick an app to start your flow dialog, select API Endpoint.
-
In the API endpoint settings dialog, select Secure with OAuth 2.0 as the security level.
-
Select which app integrations can trigger the flow when the Invoke URL receives a request:
-
Any: All app integrations in the org can trigger the flow if they have the appropriate scope.
-
Select from list: Use the dropdown menu to select specific app integrations that can trigger the flow. Each integration must have the appropriate scope.
To filter the list, you can start typing the name of the integration inside the field. To remove any integrations from the list, click the 'X' beside the app name.
-
-
Click Close to confirm the changed endpoint settings.
Test your API endpoint flow
To test the OAuth protected endpoint, you need to use an OAuth client such as the Postman client.
In Postman, you can perform a GET or POST request to your Okta org's OAuth token endpoint at https://${yourOktaDomain}/oauth2/v1/token.
When the request is authenticated, the authorization server returns an access token that you can use to query the endpoint at the Invoke URL and invoke the flow.
Secure with client token
Use the following procedure to invoke a flow through a registered webhook.
For existing API endpoint flows, you can skip the flow creation steps. Instead, click the Endpoint settings icon shown on the bottom of the API Endpoint event card in your flow.
-
Create a flow in your Workflows Console and click Add event.
-
From the Pick an app to start your flow dialog, select API Endpoint.
-
In the API endpoint settings dialog, select Secure with client token as the security level.
-
When you select this option, it generates a Client token to identify the registered webhook. This unique client token is automatically added as the alias value in the Invoke URL and Resume URL fields.
-
Click copy to save the URL in the Invoke URL field.
-
Click Close to confirm the changed endpoint settings.
Test your API endpoint flow
To invoke the flow, perform a GET or POST request to the Invoke URL. Use the POST method if you need to send data in the body of the request.
If necessary, authenticate your request using one of the following methods.
-
Pass the provided Client token using the clientToken query parameter. This is the default behavior.
-
Pass the provided Client token as a value in the x-api-client-token header. This is the most secure option. However, don't use this together with the clientToken query parameter.
No security (public service)
Use the following procedure to invoke a flow as a public service.
For existing API endpoint flows, you can skip the flow creation steps. Instead, click the Endpoint settings icon shown on the bottom of the API Endpoint event card in your flow.
-
Create a flow in your Workflows Console and click Add event.
-
From the Pick an app to start your flow dialog, select API Endpoint.
-
In the API endpoint settings dialog, select None (public service) as the security level.
-
Copy the URL in the Invoke URL field.
-
Click Close to confirm the changed endpoint settings.
Test your API endpoint flow
To invoke the flow, perform a GET or POST request to the Invoke URL. Use the POST method if you need to send data in the body of the request.
At this security level, you don't need to pass along any authentication options in the request to invoke a flow.
Related topics
Function: API Endpoint