Java
Java
RSAP Union API - Get OAuth2 Access Token
See more _Miscellaneous_ Examples
Demonstrates how to get an OAuth2 access token for the RSAP Union API. Note: This uses the client credentials flow, which does NOT require an interactive engagement using a browser.Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkHttp http = new CkHttp();
// The following JSON is sent in the request body.
// {
// "grant_type": "client_credentials",
// "client_id": 1234,
// "client_secret": "23456abcde"
// }
CkJsonObject json = new CkJsonObject();
json.UpdateString("grant_type","client_credentials");
json.UpdateInt("client_id",1234);
json.UpdateString("client_secret","23456abcde");
http.SetRequestHeader("Content-type","application/json");
// Add the client certificate TLS authentication.
CkCert cert = new CkCert();
success = cert.LoadFromFile("qa_data/certs_and_keys/union_client_certificate.crt");
if (success == false) {
System.out.println(cert.lastErrorText());
return;
}
CkPrivateKey privKey = new CkPrivateKey();
success = privKey.LoadAnyFormatFile("qa_data/certs_and_keys/union_client_certificate.nopass.key","");
if (success == false) {
System.out.println(privKey.lastErrorText());
return;
}
// Associate the private key with the cert.
// This will fail if the private key is not actually the correct one that corresponds to the public key stored within the cert.
success = cert.SetPrivateKey(privKey);
if (success == false) {
System.out.println(cert.lastErrorText());
return;
}
// Tell HTTP to use the cert for client TLS certificate authentication.
success = http.SetSslClientCert(cert);
if (success == false) {
System.out.println(http.lastErrorText());
return;
}
CkHttpResponse resp = new CkHttpResponse();
success = http.HttpJson("POST","https://api-test.rsap.ca/oauth/token",json,"application/json",resp);
if (success == false) {
System.out.println(http.lastErrorText());
return;
}
CkStringBuilder sbResponseBody = new CkStringBuilder();
resp.GetBodySb(sbResponseBody);
CkJsonObject jResp = new CkJsonObject();
jResp.LoadSb(sbResponseBody);
jResp.put_EmitCompact(false);
System.out.println("Response Body:");
System.out.println(jResp.emit());
int respStatusCode = resp.get_StatusCode();
System.out.println("Response Status Code = " + respStatusCode);
if (respStatusCode >= 400) {
System.out.println("Response Header:");
System.out.println(resp.header());
System.out.println("Failed.");
return;
}
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// {
// "token_type": "Bearer",
// "expires_in": 3600,
// "access_token": "eyJ0eXAi...LnE"
// }
// This token expires in 1 hour. Your application could re-use the same token for up to an hour,
// or it can simply get a new access token before each request (if you're not doing too many requests).
success = jResp.WriteFile("qa_data/tokens/rsapToken.json");
}
}