This is sample code for Alexa Skill developers to set up an OAuth 2.0 server. An OAuth 2.0 server is required for Skill account linking, which lets you connect user identities across different account systems. Reciprocal authorization and client token management are also included to support mutual account linking for calling Alexa APIs outside of Alexa Skills.
With the code sample and AWS Cloud Formation template, a standard OAuth 2.0 service is provided that supports the following grant types:
and an Alexa specific grant type (for reciprocal account linking):
- Alexa Reciprocal Authorization Code (Only required for mutual account linking)
- /oauth/authorize: The authorization endpoint is the endpoint on the authorization server where the resource owner logs in, and grants authorization to the client application.
- /oauth/token: The token endpoint is the endpoint on the authorization server where the client application exchanges the authorization code, client ID and client secret, for an access token.
- /api/reciprocal/authorize: The reciprocal authorization endpoint will be invoked by Alexa to send a LWA auth code. (Only required for mutual account linking)
- /login: The portal used for administration of OAuth Clients and Partners, as well as users to manage their approvals to other clients.
For testing purpose, a sample user (user/password) and a sample administrator (admin/password) are created for testing.
To integrate with your own authentication server or user DB, update the TODO task in AuthenticationServiceProvider
class.
public class AuthenticationServiceProvider {
@Override
public UserDetails loadUserByUsername(final String username) throws UsernameNotFoundException {
//TODO: Integrate with your authentication system to return UserDetails.
}
}
To setup your own OAuth server,
- Clone the repository from alexa-oauth-sample. Optionally, you can modify the repository name
- with this template
- Add your Domain Certificate and bind it to your load balancer (LB port: 443, Instance port: 80). (HTTPS is required for Alexa Skill Account Linking)
- Login to the Alexa Skill console and select your skill
- In the "PERMISSIONS" section, write down your Client Id and Client Secret
- In the "ACCOUNT LINKING" section, write down your Redirect URLs
- Login to https://YOUR_DOMAIN/login as an administrator. Create an OAuth client that you vend to Alexa (e.g. alexa_skill_client)
- (Only for mutual account linking) Login to https://YOUR_DOMAIN/login as an administrator, create an OAuth partner to call Alexa APIs IMPORTANT: clientId and clientSecret originate from your Alexa Skill (Under the PERMISSION tab). The partnerId should be the same as the "clientId" in previous step.
- Login to Alexa Skill console and select your skill
- Click "ACCOUNT LINKING" section, fill the form with the following:
- Authorization URI: https://YOUR_DOMAIN/oauth/authorize
- Access Token URI: https://YOUR_DOMAIN/oauth/token
- Client ID: the clientId of the client you have created in the previous section
- Client Secret: the clientSecret of the client you have created in the previous section
- Client Authentication Scheme: Choose credentials in request body
- Scope: OAuth scopes to define the permissions. (This is used for your resource server, leave empty if you do not have one)
- Domain List: YOUR DOMAIN (e.g. domain.com, www.domain.com)
This library is licensed under the Amazon Software License 1.0.