|
@@ -19,18 +19,21 @@ public class OAuth2GetAccessToken extends RemoteOperation {
|
|
|
|
|
|
private static final String TAG = OAuth2GetAccessToken.class.getSimpleName();
|
|
|
|
|
|
- private Map<String, String> mOAuth2AuthorizationResponse;
|
|
|
+ private String mOAuth2AuthorizationResponse;
|
|
|
+ private Map<String, String> mOAuth2ParsedAuthorizationResponse;
|
|
|
private Map<String, String> mResultTokenMap;
|
|
|
|
|
|
|
|
|
- public OAuth2GetAccessToken(Map<String, String> oAuth2AuthorizationResponse) {
|
|
|
+ public OAuth2GetAccessToken(String oAuth2AuthorizationResponse) {
|
|
|
+
|
|
|
mOAuth2AuthorizationResponse = oAuth2AuthorizationResponse;
|
|
|
+ mOAuth2ParsedAuthorizationResponse = new HashMap<String, String>();
|
|
|
mResultTokenMap = null;
|
|
|
}
|
|
|
|
|
|
|
|
|
public Map<String, String> getOauth2AutorizationResponse() {
|
|
|
- return mOAuth2AuthorizationResponse;
|
|
|
+ return mOAuth2ParsedAuthorizationResponse;
|
|
|
}
|
|
|
|
|
|
public Map<String, String> getResultTokenMap() {
|
|
@@ -43,31 +46,44 @@ public class OAuth2GetAccessToken extends RemoteOperation {
|
|
|
PostMethod postMethod = null;
|
|
|
|
|
|
try {
|
|
|
- NameValuePair[] nameValuePairs = new NameValuePair[5];
|
|
|
- nameValuePairs[0] = new NameValuePair(OAuth2Context.KEY_CLIENT_ID, OAuth2Context.OAUTH2_F_CLIENT_ID);
|
|
|
- nameValuePairs[1] = new NameValuePair(OAuth2Context.KEY_CODE, mOAuth2AuthorizationResponse.get(OAuth2Context.KEY_CODE));
|
|
|
- nameValuePairs[2] = new NameValuePair(OAuth2Context.KEY_SCOPE, mOAuth2AuthorizationResponse.get(OAuth2Context.KEY_SCOPE));
|
|
|
- nameValuePairs[3] = new NameValuePair(OAuth2Context.KEY_REDIRECT_URI, OAuth2Context.MY_REDIRECT_URI);
|
|
|
- nameValuePairs[4] = new NameValuePair(OAuth2Context.KEY_GRANT_TYPE, OAuth2Context.OAUTH2_AUTH_CODE_GRANT_TYPE);
|
|
|
+ parseAuthorizationResponse();
|
|
|
+ if (mOAuth2ParsedAuthorizationResponse.keySet().contains(OAuth2Context.KEY_ERROR)) {
|
|
|
+ if (OAuth2Context.ERROR_ACCESS_DENIED.equals(mOAuth2ParsedAuthorizationResponse.get(OAuth2Context.KEY_ERROR))) {
|
|
|
+ result = new RemoteOperationResult(ResultCode.OAUTH2_ERROR_ACCESS_DENIED);
|
|
|
+ } else {
|
|
|
+ result = new RemoteOperationResult(ResultCode.OAUTH2_ERROR);
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
- postMethod = new PostMethod(client.getBaseUri().toString());
|
|
|
- postMethod.setRequestBody(nameValuePairs);
|
|
|
- int status = client.executeMethod(postMethod);
|
|
|
- if (status >= 300) {
|
|
|
- client.exhaustResponse(postMethod.getResponseBodyAsStream());
|
|
|
- result = new RemoteOperationResult(false, status);
|
|
|
+ if (result == null) {
|
|
|
+ NameValuePair[] nameValuePairs = new NameValuePair[5];
|
|
|
+ nameValuePairs[0] = new NameValuePair(OAuth2Context.KEY_CLIENT_ID, OAuth2Context.OAUTH2_F_CLIENT_ID);
|
|
|
+ nameValuePairs[1] = new NameValuePair(OAuth2Context.KEY_CODE, mOAuth2ParsedAuthorizationResponse.get(OAuth2Context.KEY_CODE));
|
|
|
+ nameValuePairs[2] = new NameValuePair(OAuth2Context.KEY_SCOPE, mOAuth2ParsedAuthorizationResponse.get(OAuth2Context.KEY_SCOPE));
|
|
|
+ nameValuePairs[3] = new NameValuePair(OAuth2Context.KEY_REDIRECT_URI, OAuth2Context.MY_REDIRECT_URI);
|
|
|
+ nameValuePairs[4] = new NameValuePair(OAuth2Context.KEY_GRANT_TYPE, OAuth2Context.OAUTH2_AUTH_CODE_GRANT_TYPE);
|
|
|
|
|
|
- } else {
|
|
|
- JSONObject tokenJson = new JSONObject(postMethod.getResponseBodyAsString());
|
|
|
- parseResult(tokenJson);
|
|
|
- if (mResultTokenMap.get(OAuth2Context.OAUTH2_TOKEN_RECEIVED_ERROR) != null) {
|
|
|
- result = new RemoteOperationResult(ResultCode.OAUTH2_ERROR);
|
|
|
+ postMethod = new PostMethod(client.getBaseUri().toString());
|
|
|
+ postMethod.setRequestBody(nameValuePairs);
|
|
|
+ int status = client.executeMethod(postMethod);
|
|
|
+
|
|
|
+ String response = postMethod.getResponseBodyAsString();
|
|
|
+ if (response != null && response.length() > 0) {
|
|
|
+ JSONObject tokenJson = new JSONObject(response);
|
|
|
+ parseAccessTokenResult(tokenJson);
|
|
|
+ if (mResultTokenMap.get(OAuth2Context.OAUTH2_TOKEN_RECEIVED_ERROR) != null || mResultTokenMap.get(OAuth2Context.KEY_ACCESS_TOKEN) == null) {
|
|
|
+ result = new RemoteOperationResult(ResultCode.OAUTH2_ERROR);
|
|
|
+
|
|
|
+ } else {
|
|
|
+ result = new RemoteOperationResult(true, status);
|
|
|
+ }
|
|
|
|
|
|
} else {
|
|
|
- result = new RemoteOperationResult(true, status);
|
|
|
+ client.exhaustResponse(postMethod.getResponseBodyAsStream());
|
|
|
+ result = new RemoteOperationResult(false, status);
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
} catch (Exception e) {
|
|
|
result = new RemoteOperationResult(e);
|
|
|
|
|
@@ -76,16 +92,16 @@ public class OAuth2GetAccessToken extends RemoteOperation {
|
|
|
postMethod.releaseConnection(); // let the connection available for other methods
|
|
|
|
|
|
if (result.isSuccess()) {
|
|
|
- Log.i(TAG, "OAuth2 TOKEN REQUEST with code " + mOAuth2AuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + result.getLogMessage());
|
|
|
+ Log.i(TAG, "OAuth2 TOKEN REQUEST with auth code " + mOAuth2ParsedAuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + result.getLogMessage());
|
|
|
|
|
|
} else if (result.getException() != null) {
|
|
|
- Log.e(TAG, "OAuth2 TOKEN REQUEST with code " + mOAuth2AuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + result.getLogMessage(), result.getException());
|
|
|
+ Log.e(TAG, "OAuth2 TOKEN REQUEST with auth code " + mOAuth2ParsedAuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + result.getLogMessage(), result.getException());
|
|
|
|
|
|
} else if (result.getCode() == ResultCode.OAUTH2_ERROR) {
|
|
|
- Log.e(TAG, "OAuth2 TOKEN REQUEST with code " + mOAuth2AuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + mResultTokenMap.get(OAuth2Context.OAUTH2_TOKEN_RECEIVED_ERROR));
|
|
|
+ Log.e(TAG, "OAuth2 TOKEN REQUEST with auth code " + mOAuth2ParsedAuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + mResultTokenMap.get(OAuth2Context.OAUTH2_TOKEN_RECEIVED_ERROR));
|
|
|
|
|
|
} else {
|
|
|
- Log.e(TAG, "OAuth2 TOKEN REQUEST with code " + mOAuth2AuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + result.getLogMessage());
|
|
|
+ Log.e(TAG, "OAuth2 TOKEN REQUEST with auth code " + mOAuth2ParsedAuthorizationResponse.get("code") + " to " + client.getBaseUri() + ": " + result.getLogMessage());
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -93,7 +109,35 @@ public class OAuth2GetAccessToken extends RemoteOperation {
|
|
|
}
|
|
|
|
|
|
|
|
|
- private void parseResult (JSONObject tokenJson) throws JSONException {
|
|
|
+ private void parseAuthorizationResponse() {
|
|
|
+ String[] pairs = mOAuth2AuthorizationResponse.split("&");
|
|
|
+ int i = 0;
|
|
|
+ String key = "";
|
|
|
+ String value = "";
|
|
|
+ StringBuilder sb = new StringBuilder();
|
|
|
+ while (pairs.length > i) {
|
|
|
+ int j = 0;
|
|
|
+ String[] part = pairs[i].split("=");
|
|
|
+ while (part.length > j) {
|
|
|
+ String p = part[j];
|
|
|
+ if (j == 0) {
|
|
|
+ key = p;
|
|
|
+ sb.append(key + " = ");
|
|
|
+ } else if (j == 1) {
|
|
|
+ value = p;
|
|
|
+ mOAuth2ParsedAuthorizationResponse.put(key, value);
|
|
|
+ sb.append(value + "\n");
|
|
|
+ }
|
|
|
+
|
|
|
+ Log.v(TAG, "[" + i + "," + j + "] = " + p);
|
|
|
+ j++;
|
|
|
+ }
|
|
|
+ i++;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private void parseAccessTokenResult (JSONObject tokenJson) throws JSONException {
|
|
|
mResultTokenMap = new HashMap<String, String>();
|
|
|
|
|
|
if (tokenJson.has(OAuth2Context.KEY_ACCESS_TOKEN)) {
|