-
Notifications
You must be signed in to change notification settings - Fork 128
OAuth2
This is for version 0.9.0 and below. The documentation for v1.0.0+ can be found here
There are five types of authentication available under reddit's OAuth implementation, and each type has a specific use case. Please make sure you choose the most appropriate type for your app.
- Web app: Runs as part of a web service on a server you control. Can keep a secret.
- Installed app: Runs on devices you don't control, such as the user's mobile phone. Cannot keep a secret, and therefore, does not receive one.
- Script app: Runs on hardware you control, such as your own laptop or server. Can keep a secret. Only has access to your account.
- Application-only: A web or script app acting in a user-less context.
- Application-only installed app: The combination of "installed app" and "application-only."
These types are the easiest to authenticate. Invoking OAuthHelper.easyAuth(Credentials)
will result in a OAuthData
instance, given the credentials are valid. An example:
RedditClient redditClient = new RedditClient(...);
// This could also be Credentials.userless() or .userlessApp()
Credentials credentials = Credentials.script(...);
OAuthData authData = redditClient.getOAuthHelper().easyAuth(credentials);
redditClient.authenticate(authData);
Web and installed apps are harder to authenticate because they require the user to allow the app's permissions (scopes) action using a browser. A rough outline of this process goes as follows:
- Obtain an authorization URL using
getAuthorizationUrl(Credentials, boolean, String...)
. - Point the user's browser to that URL and have the user login and then press 'accept' on the authentication form. The URL that the browser redirects to will be your app's redirect URI with some arguments in the query.
- Provide this data as well as the same
Credentials
instance toOAuthHelper.onUserChallenge(String, Credentials)
. This method will parse the query arguments and report any errors. Once the response's integrity has been verified, a request to obtain the OAuth access code will be made and an instance ofOAuthData
retrieved.
For an Android example, see the example app here and here.
To refresh an access token, the permission must have been requested during getAuthorizationUrl(Credentials, boolean, String...)
, where permanent = true
. Note that this disqualifies script and application-only apps. A new access token may be requested using OAuthHelper.refreshToken(Credentials)
. For example:
// Provided that 'redditClient' is an already-authenticated RedditClient
// and `credentials' is a Credentials object for a web/installed app:
OAuthData newAuthData = redditClient.getOAuthHelper().refreshToken(credentials);
redditClient.authenticate(newAuthData);
Good clients clean up after themselves. That's why OAuthHelper.revokeToken(Credentials)
is provided. Simply call this method when your app no longer needs to hold on to the access token and it will be invalidated.