Skip to content

Gravitee.io - API Management - Resource - OAuth2 Generic

License

Notifications You must be signed in to change notification settings

gravitee-io/gravitee-resource-oauth2-provider-generic

Repository files navigation

Generic OAuth2 Authorization Server Resource

Gravitee.io License Releases CircleCI Join the community forum

Description

Generic OAuth2 Authorization Server resource is defined to introspect an access_token generated by a generic OAuth2 authorization server.

This resource should be able to handle common authorization server from the market by providing a complete configuration about the way to apply token introspection.

Compatibility with APIM

Plugin version APIM version

4.0 and upper

4.6.x to latest

3.0 and upper

4.4.x to 4.5.x

2.0 and upper

3.18.x to 4.3.x

1.16.x and upper

3.10.x to 3.17.x

Up to 1.15.x

Up to 3.9.x

Configuration

You can configure the resource with the following options :

Property Required Description Type Default Support EL Support Secret

introspectionEndpoint

X

The URL which is used by the resource to introspect an incoming access token.

string

-

X

-

useSystemProxy

X

TUse system proxy.

boolean

false

-

-

introspectionEndpointMethod

X

HTTP method used to introspect the access token.

HTTP Method

GET

-

-

clientId

X

The client identifier.

string

-

X

X

clientSecret

X

The client secret.

string

-

X

X

useClientAuthorizationHeader

-

To prevent token scanning attacks, the endpoint MUST also require some form of authorization to access this endpoint. In this case we are using an HTTP header for client authentication.

boolean

true

-

-

clientAuthorizationHeaderName

-

Authorization header.

string

Authorization

X

-

clientAuthorizationHeaderScheme

-

Authorization scheme.

string

Basic

X

-

tokenIsSuppliedByQueryParam

-

Access token is passed to the introspection endpoint using a query parameter.

boolean

true

-

-

tokenQueryParamName

-

Query parameter used to supply access token.

string

token

-

-

tokenIsSuppliedByHttpHeader

-

Access token is passed to the introspection endpoint using an HTTP header.

boolean

false

-

-

tokenHeaderName

-

HTTP header used to supply access token.

string

-

X

-

Configuration example
{
    "configuration": {
        "introspectionEndpoint": "https://my_authorization_server/oauth/check_token",
        "introspectionEndpointMethod": "POST",
        "clientAuthorizationHeaderName": "Authorization",
        "clientAuthorizationHeaderScheme": "Basic",
        "clientId": "my-client",
        "clientSecret": "f2ddb55e-30b5-4a45-9db5-5e30b52a4574",
        "tokenIsSuppliedByHttpHeader": false,
        "tokenIsSuppliedByQueryParam": true,
        "tokenQueryParamName": "token",
        "useClientAuthorizationHeader": true
    }
}
Extract with a secret and EL
{
  "configuration": {
        "introspectionEndpoint": "https://{#dictionary['oauth']['host']/oauth/check_token",
        "clientId": "my-client",
        "clientSecret": "f2ddb55e-30b5-4a45-9db5-5e30b52a4574"
  }
}