package com.github.scribejava.apis.examples; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.net.URLDecoder; import java.net.URLEncoder; import java.util.Scanner; import java.util.concurrent.ExecutionException; import com.github.scribejava.apis.SalesforceApi; import com.github.scribejava.apis.salesforce.SalesforceToken; import com.github.scribejava.httpclient.ning.NingHttpClientConfig; import com.github.scribejava.core.builder.ServiceBuilder; import com.github.scribejava.core.model.OAuth2AccessToken; import com.github.scribejava.core.model.OAuthRequest; import com.github.scribejava.core.model.Response; import com.github.scribejava.core.model.Verb; import com.github.scribejava.core.oauth.OAuth20Service; import com.ning.http.client.AsyncHttpClientConfig; import java.security.KeyManagementException; import java.security.NoSuchAlgorithmException; public final class SalesforceNingAsyncExample { private static final String NETWORK_NAME = "Salesforce"; private SalesforceNingAsyncExample() { } @SuppressWarnings({"unchecked", "rawtypes"}) public static void main(String... args) throws InterruptedException, ExecutionException, UnsupportedEncodingException, IOException, NoSuchAlgorithmException, KeyManagementException { // Replace these with your client id and secret final String clientId = "your client id"; final String clientSecret = "your client secret"; final NingHttpClientConfig clientConfig = new NingHttpClientConfig(new AsyncHttpClientConfig.Builder() .setMaxConnections(5) .setRequestTimeout(10_000) .setAllowPoolingConnections(false) .setPooledConnectionIdleTimeout(1_000) .setReadTimeout(10_000) .build()); //IT's important! Salesforce upper require TLS v1.1 or 1.2 SalesforceApi.initTLSv11orUpper(); try (OAuth20Service service = new ServiceBuilder() .apiKey(clientId) .apiSecret(clientSecret) .httpClientConfig(clientConfig) .callback("https://www.example.com/callback") .build(SalesforceApi.instance())) { System.out.println("=== " + NETWORK_NAME + "'s OAuth20 Workflow ==="); System.out.println(); // Obtain the Authorization URL System.out.println("Fetching the Authorization URL..."); final String authorizationUrl = service.getAuthorizationUrl(); System.out.println("Got the Authorization URL!"); System.out.println("Now go and authorize ScribeJava here:"); System.out.println(authorizationUrl); System.out.println("And paste the authorization code here"); System.out.print(">>"); final String code; try (Scanner in = new Scanner(System.in)) { code = in.nextLine(); } System.out.println(); final String codeEncoded = URLDecoder.decode(code, "UTF-8"); // Trade the Request Token and Verifier for the Access Token System.out.println("Trading the Request Token for an Access Token..."); final OAuth2AccessToken accessToken = service.getAccessToken(codeEncoded); final SalesforceToken salesforceAccessToken; if (accessToken instanceof SalesforceToken) { salesforceAccessToken = (SalesforceToken) accessToken; } else { throw new IllegalStateException("Salesforce API didn't return SalesforceToken."); } System.out.println("Got the Access Token!"); System.out.println("(if your curious it looks like this: " + salesforceAccessToken + ", 'rawResponse'='" + accessToken.getRawResponse() + "')"); System.out.println(); System.out.println("Instance is: " + salesforceAccessToken.getInstanceUrl()); // Now let's go and ask for a protected resource! System.out.println("Now we're reading accounts from the Salesforce org (maxing them to 10)."); // Sample SOQL statement final String queryEncoded = URLEncoder.encode("Select Id, Name from Account LIMIT 10", "UTF-8"); // Building the query URI. We've parsed the instance URL from the // accessToken request. final String url = salesforceAccessToken.getInstanceUrl() + "/services/data/v36.0/query?q=" + queryEncoded; System.out.println(); System.out.println("Full URL: " + url); final OAuthRequest request = new OAuthRequest(Verb.GET, url); final Response response = service.execute(request); System.out.println(); System.out.println(response.getCode()); System.out.println(response.getBody()); } } }