Setting Up Authentication patterns
3scale supports the following authentication patterns out of the box:
- Standard API Keys: single randomized strings or hashes acting as an identifier and a secret token.
- Application Identifier and Key pairs: immutable identifier and mutable secret key strings.
- openAuth client Tokens (oAuth 1.0 and 2.0): openAuth client Identifier, client secret and referrer domain
In addition we support some more advanced, custom scenarios – please contact us for more information to meet your specific needs.
3scale also supports coupling issues credentials with IP address filtering or referrer domain filtering – see the extra section at the end of this HowTo.
By the time you complete this HowTo you’ll know how to set the authentication pattern on your API and the effect this has on applications communicating with your API.
Step by Step Guide
Step 1: Select the Authentication mode for your service.
Once in your Administration Dashboard, navigate to the API tab and select the service you wish to work on (there may be only one service named “API” in which case select this). Click on the Settings Link.
Note that each service you operate could use a different authentication pattern, but only one pattern can be used per service.
It is not recommended you change the authentication pattern once credentials have already been registered since behavior may be unpredictable. To change authentication patterns we recommend creating a new service and migrating customers.
Step 2: Select the Auth Mode you want to use
Choose the required Authentication mode from the radio button menu in the bottom of the section.
Step 3: Ensure your API accepts the right types of Credentials
Depending on the credential type chosen, you will likely need to accept different parameters in your API calls (key fields, IDs etc.). The names of these parameters need not be the same as those used internally at 3scale, your 3scale authentication will function correctly just as long as the correct parameter names are used in calls to the 3scale backend.
Step 4: Create an application to test credentials
In order to test the credential sets are working you can create a new application to issue credentials to use the API. Navigate to the Accounts area of your dashboard, click on the account you wish to use and click the new application button.
Filling out the form and clicking save will create a new application with credentials to use the API. You can now use these credentials to make calls to your API and records will be checked against 3scale list of registered applications.
Standard Authentication Patterns
3scale supports the following authentication patterns out of the box.
The simplest form of credentials supported is the single API model. Here each application with permissions on the API has a single (unique) long character string something like this:
API Key = 853a76f7c8d5f4a1ee8bf10a4e0d1f13
The string acts as both an identifier and a secret token for use of the API. It is recommended such patterns are only used either in environments with low security requirements or with SSL security on API calls. The operations which can be carried out on the token and application are:
- Application Suspend: this suspends the applications access to the API and in effect all calls to the API with the relevant key will be suspended
- Application Resume: undoes the effect of an application suspend action
- Key Regenerate: this action generates a new random string key for the application and associates it with the application. Immediately after this action is taken calls with the previous token will cease to be accepted.
The latter action can be triggered from the API Administration dashboard and (if permitted) from the API Developers User console.
App_ID and App_Key Pair
Whereas the API Key Pattern combines the identity of the application and the secret usage token in one token, this pattern separates the two. Each application using the API issues an immutable initial identifier known as the Application ID (App ID). The App ID is constant and may or may not be secret. In addition each application may have 1-n Application Keys (App_Keys). Each Key is associated directly with the App_ID and should be treated as secret.
App Id = 80a4e03
App Key = a1ee8bf10a4e0d1f13853a76f7c8d5f4
In the default setting, developers are able to create up to 5 keys per application. This allow a developer to create a new key, add it to their code redeploy their application and then disable old keys – causing no application downtime as an API Key Regeneration would.
Note that statistics and rate limits are always kept at the application ID level of granularity and not per API Key. If a developer wishes to track two sets of statistics, they should create two applications rather than two keys.
It is also possible to change mode in the system and allow applications to be created without applications keys present. In this case the 3scale system will authenticate access based on the App ID only (and no key checks are made). This mode is useful for (for example) widget type scenarios or where rate limits are applied to users rather than applications. Note that in most cases you will want your API to enforce there to be at least one application key per application present (this setting can be found on the “Settings” menu item under usage rules).
openAuth is a set of specifications which enable a variety of different authentication patterns for APIs. The two major versions released so far (v1 and v2) are significantly different and version 2 includes a number of different supported authentication flows.
3scale supports all flavors of oAuth APIs with one overall openAuth authentication pattern based on. openAuth support is described in the oAuth HowTo.
If you have authentication needs which are not covered by this how to, let us know by email at firstname.lastname@example.org for information on what else we support.
In addition, 3scale supports coupling credentials with authorized IP ranges per key or referrer domains per key to restrict where specific API credentials can be used. You can enable this additional filtering by navigating to the API Tab and accessing the Settings screen on the API.