Interact with the Patreon API via OAuth.
Get the artifact from Maven
<dependency>
<groupId>com.patreon</groupId>
<artifactId>patreon</artifactId>
<version>0.4.2</version>
</dependency>
This library is not maintained at the moment, and its not certain whether it will return to a maintained status and if so, when. So if you want to use this lib, forking it and adapting it to your needs would be the best option.
Visit the Patreon Platform Page while logged in as a Patreon creator to register your client.
This will provide you with a client_id
and a client_secret
.
import com.github.jasminb.jsonapi.JSONAPIDocument;
import com.patreon.PatreonAPI;
import com.patreon.PatreonOAuth;
import com.patreon.PatreonOAuth;
import com.patreon.resources.User;
import com.patreon.resources.Pledge;
...
String clientId = null; // Get this when you set up your client
String clientSecret = null; // Get this when you set up your client
String redirectUri = null; // Provide this to set up your client
String code = null; // Get this from the query parameter `code`
PatreonOAuth oauthClient = new PatreonOAuth(clientId, clientSecret, redirectUri);
PatreonOAuth.TokensResponse tokens = oauthClient.getTokens(code);
//Store the refresh TokensResponse in your data store
String accessToken = tokens.getAccessToken();
PatreonAPI apiClient = new PatreonAPI(accessToken);
JSONAPIDocument<User> userResponse = apiClient.fetchUser();
User user = userResponse.get();
Log.i(user.getFullName());
List<Pledge> pledges = user.getPledges()
if (pledges != null && pledges.size() > 0) {
Pledge pledge = pledges.get(0);
Log.i(pledge.getAmountCents());
}
// You should save the user's PatreonOAuth.TokensResponse in your database
// (for refreshing their Patreon data whenever you like),
// along with any relevant user info or pledge info you want to store.