com.stripe.net.OAuth Maven / Gradle / Ivy
package com.stripe.net;
import com.stripe.Stripe;
import com.stripe.exception.AuthenticationException;
import com.stripe.exception.InvalidRequestException;
import com.stripe.exception.StripeException;
import com.stripe.model.oauth.DeauthorizedAccount;
import com.stripe.model.oauth.TokenResponse;
import java.util.HashMap;
import java.util.Map;
public final class OAuth {
private static StripeResponseGetter stripeResponseGetter = new LiveStripeResponseGetter();
public static void setStripeResponseGetter(StripeResponseGetter srg) {
OAuth.stripeResponseGetter = srg;
}
/**
* Generates a URL to Stripe's OAuth form.
*
* @param params the parameters to include in the URL.
* @param options the request options.
* @return the URL to Stripe's OAuth form.
*/
public static String authorizeUrl(Map params, RequestOptions options)
throws AuthenticationException, InvalidRequestException {
final String base = Stripe.getConnectBase();
params.put("client_id", getClientId(params, options));
if (params.get("response_type") == null) {
params.put("response_type", "code");
}
String query = FormEncoder.createQueryString(params);
String url = base + "/oauth/authorize?" + query;
return url;
}
/**
* Uses an authorization code to connect an account to your platform and fetch the user's
* credentials.
*
* @param params the request parameters.
* @param options the request options.
* @return the TokenResponse instance containing the response from the OAuth API.
*/
public static TokenResponse token(Map params, RequestOptions options)
throws StripeException {
String url = Stripe.getConnectBase() + "/oauth/token";
return OAuth.stripeResponseGetter.oauthRequest(
ApiResource.RequestMethod.POST, url, params, TokenResponse.class, options);
}
/**
* Disconnects an account from your platform.
*
* @param params the request parameters.
* @param options the request options.
* @return the DeauthorizedAccount instance containing the response from the OAuth API.
*/
public static DeauthorizedAccount deauthorize(Map params, RequestOptions options)
throws StripeException {
Map paramsCopy = new HashMap<>();
paramsCopy.putAll(params);
String url = Stripe.getConnectBase() + "/oauth/deauthorize";
paramsCopy.put("client_id", getClientId(paramsCopy, options));
return OAuth.stripeResponseGetter.oauthRequest(
ApiResource.RequestMethod.POST, url, params, DeauthorizedAccount.class, options);
}
/**
* Returns the client_id to use in OAuth requests.
*
* @param params the request parameters.
* @param options the request options.
* @return the client_id.
*/
private static String getClientId(Map params, RequestOptions options)
throws AuthenticationException {
String clientId = Stripe.clientId;
if ((options != null) && (options.getClientId() != null)) {
clientId = options.getClientId();
}
if ((params != null) && (params.get("client_id") != null)) {
clientId = (String) params.get("client_id");
}
if (clientId == null) {
throw new AuthenticationException(
"No client_id provided. (HINT: set client_id key using 'Stripe.clientId = '. "
+ "You can find your client_ids in your Stripe dashboard at "
+ "https://dashboard.stripe.com/account/applications/settings, "
+ "after registering your account as a platform. See "
+ "https://stripe.com/docs/connect/standard-accounts for details, "
+ "or email [email protected] if you have any questions.",
null,
null,
0);
}
return clientId;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy