We use the Doorkeeper gem for OAuth, so you can refer to their docs on specifics of the end-points.
The API is divided up into access scopes:
read
: Read datawrite
: Post statuses and upload media for statusesfollow
: Follow, unfollow, block, unblock
Multiple scopes can be requested during the authorization phase with the scope
query param (space-separate the scopes). If you do not specify a scope
in your authorization request, the resulting access token will default to read
access.
One possible way this might work for you:
- Get
client_key
andclient_secret
from your local cache. If you don't have the two, you need to register the application. Storeclient_key
andclient_secret
in your local cache for next time. We actually don't need theid
returned from this call. - Get the
refresh_token
from your local cache. If you have one, any access token you might have has probably expired anyway. Refresh by visiting/oauth/token
using a POST request with the parametersclient_id=<client_key>
(yes, this is confusing!),client_secret=<client_secret>
,grant_type=refresh_token
,refresh_token=<refresh_token>
. Save theaccess_token
you get back in your local cache. - Get the
access_token
from your local cache. Try to connect. One simple way to do this is to verify credentials. Whatever API call you make, add the HTTP headerAuthorization: Bearer <access_token>
. - If you have neither refresh nor access token, tell the user to visit
/oauth/authorize
with parametersscope=read write follow
(URL encode the space to%20
, of course),response_type=code
,redirect_uri=urn:ietf:wg:oauth:2.0:oob
(assuming you don't want to redirect your users elsewhere),client_id=<client_key>
(yes, this is confusing). The user clicks on the URL and gets shown a page asking them to authorize your app for reading, writing, and following (assuming this is the scope you requested, feel free to request less). If the user clicks on the right button, they get back a code. Store this code as yourrefresh_token
. Go back to step #2.