I have WSO2 API Manager on a standalone machine. I have a java client (Assume PSVM) with necessary Client Id and Secret of the registered application on APIM. Can we obtain the Bearer Token using only Client Id and Secret in Java.
Help appreciated, please.
I have following code but, it requires username and password.
public Token getToken(String username, String password, String scopes){
String submitUrl = GenarateAccessTokenConfiguration.getInstance().getLoginURL();
String consumerKey = GenarateAccessTokenConfiguration.getInstance().getConsumerKey();
String consumerSecret = GenarateAccessTokenConfiguration.getInstance().getConsumerSecret();
try {
String applicationToken = consumerKey + ":" + consumerSecret;
BASE64Encoder base64Encoder = new BASE64Encoder();
applicationToken = "Basic " + base64Encoder.encode(applicationToken.getBytes()).trim();
String payload = "grant_type=password&username="+username+"&password="+password+"&scope="+scopes;
HttpResponse httpResponse = httpClient.doPost(submitUrl,applicationToken,
payload,"application/x-www-form-urlencoded");
if (httpResponse.getStatusLine().getStatusCode() != 200) {
return null;
}
String response = httpClient.getResponsePayload(httpResponse);
System.out.println("JSON Response : "+response);
return JSONClient.getAccessToken(response);
} catch (IOException e) {
e.printStackTrace();
return null;
}
}
public Token getTokenWithScopes(String username, String password, String scopes){
String submitUrl = GenarateAccessTokenConfiguration.getInstance().getLoginURL();
String consumerKey = GenarateAccessTokenConfiguration.getInstance().getConsumerKey();
String consumerSecret = GenarateAccessTokenConfiguration.getInstance().getConsumerSecret();
try {
String applicationToken = consumerKey + ":" + consumerSecret;
BASE64Encoder base64Encoder = new BASE64Encoder();
applicationToken = "Basic " + base64Encoder.encode(applicationToken.getBytes()).trim();
String payload = "grant_type=password&username="+username+"&password="+password+"&scope="+scopes;
HttpResponse httpResponse = httpClient.doPost(submitUrl,applicationToken,
payload,"application/x-www-form-urlencoded");
if (httpResponse.getStatusLine().getStatusCode() != 200) {
return null;
}
String response = httpClient.getResponsePayload(httpResponse);
return JSONClient.getAccessToken(response);
} catch (IOException e) {
e.printStackTrace();
return null;
}
}