All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.paypal.api.payments.FuturePayment Maven / Gradle / Ivy

// Generated by delombok at Thu Nov 16 13:48:05 CST 2017
package com.paypal.api.payments;

import com.paypal.api.openidconnect.CreateFromAuthorizationCodeParameters;
import com.paypal.api.openidconnect.CreateFromRefreshTokenParameters;
import com.paypal.api.openidconnect.Tokeninfo;
import com.paypal.base.Constants;
import com.paypal.base.rest.APIContext;
import com.paypal.base.rest.PayPalRESTException;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

public class FuturePayment extends Payment {
	/**
	 * Creates a future payment using either authorization code or refresh token
	 * with correlation ID. 
* https://developer.paypal.com/webapps/developer/docs/integration/mobile/ * make-future-payment/ * * @param accessToken * an access token * @param correlationId * paypal application correlation ID * @return a Payment object * @throws PayPalRESTException * @throws IOException * thrown when config file cannot be read properly * @throws FileNotFoundException * thrown when config file does not exist */ public Payment create(String accessToken, String correlationId) throws PayPalRESTException, FileNotFoundException, IOException { if (correlationId == null || correlationId.equals("")) { throw new IllegalArgumentException("correlation ID cannot be null or empty"); } APIContext apiContext = new APIContext(accessToken); apiContext.addHTTPHeader("PAYPAL-CLIENT-METADATA-ID", correlationId); return this.create(apiContext); } /** * Creates a future payment using either authorization code or refresh token * with correlation ID.
* https://developer.paypal.com/webapps/developer/docs/integration/mobile/ * make-future-payment/ * * @param apiContext {@link APIContext} * @param correlationId * paypal application correlation ID * @return a Payment object * @throws PayPalRESTException * @throws IOException * thrown when config file cannot be read properly * @throws FileNotFoundException * thrown when config file does not exist */ public Payment create(APIContext apiContext, String correlationId) throws PayPalRESTException, FileNotFoundException, IOException { if (correlationId == null || correlationId.equals("")) { throw new IllegalArgumentException("correlation ID cannot be null or empty"); } apiContext.addHTTPHeader("PAYPAL-CLIENT-METADATA-ID", correlationId); return this.create(apiContext); } /** * @deprecated Please use {@link #fetchRefreshToken(APIContext, String)} instead. * In this method, we need to pass clientID, secret information that is already known to apiContext. The newer method allows for better * code readability, and make it less error prone. * * @param params Authorization code params * @return {@link Tokeninfo} * @throws PayPalRESTException */ public Tokeninfo getTokeninfo(CreateFromAuthorizationCodeParameters params) throws PayPalRESTException { Map configurationMap = new HashMap(); configurationMap.put(Constants.CLIENT_ID, params.getClientID()); configurationMap.put(Constants.CLIENT_SECRET, params.getClientSecret()); configurationMap.put("response_type", "token"); APIContext apiContext = new APIContext(); apiContext.setConfigurationMap(configurationMap); params.setRedirectURI("urn:ietf:wg:oauth:2.0:oob"); Tokeninfo info = Tokeninfo.createFromAuthorizationCodeForFpp(apiContext, params); return info; } /** * @deprecated Please use {@link #fetchRefreshToken(APIContext, String)} instead. * In this method, we need to pass clientID, secret information that is already known to apiContext. The newer method allows for better * code readability, and make it less error prone. * * @param params parameters * @return {@link Tokeninfo} * @throws PayPalRESTException */ public Tokeninfo getTokeninfo(CreateFromRefreshTokenParameters params, Tokeninfo info) throws PayPalRESTException { Map configurationMap = new HashMap(); APIContext apiContext = new APIContext(); apiContext.setConfigurationMap(configurationMap); info = info.createFromRefreshToken(apiContext, params); return info; } /** * Fetches long lived refresh token from authorization code, for future payment use. * * @param context {@link APIContext} * @param authorizationCode code returned from mobile * @return String of refresh token * @throws PayPalRESTException */ public static String fetchRefreshToken(APIContext context, String authorizationCode) throws PayPalRESTException { CreateFromAuthorizationCodeParameters params = new CreateFromAuthorizationCodeParameters(); params.setClientID(context.getClientID()); params.setClientSecret(context.getClientSecret()); params.setCode(authorizationCode); Tokeninfo info = Tokeninfo.createFromAuthorizationCodeForFpp(context, params); return info.getRefreshToken(); } @java.lang.Override @java.lang.SuppressWarnings("all") public boolean equals(final java.lang.Object o) { if (o == this) return true; if (!(o instanceof FuturePayment)) return false; final FuturePayment other = (FuturePayment) o; if (!other.canEqual((java.lang.Object) this)) return false; if (!super.equals(o)) return false; return true; } @java.lang.SuppressWarnings("all") protected boolean canEqual(final java.lang.Object other) { return other instanceof FuturePayment; } @java.lang.Override @java.lang.SuppressWarnings("all") public int hashCode() { final int PRIME = 59; int result = 1; result = result * PRIME + super.hashCode(); return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy