diff options
author | Danny van Heumen <danny@dannyvanheumen.nl> | 2015-06-10 00:33:49 +0200 |
---|---|---|
committer | Danny van Heumen <danny@dannyvanheumen.nl> | 2015-07-20 22:29:45 +0200 |
commit | d00c3f896c741617f8367f4896d890d1aa1ba2fd (patch) | |
tree | 628f3750e7c44bd0f01296f9ed6ad263ebeda111 | |
parent | 218b69991e594ea56e29f809803900473a47b487 (diff) | |
download | jitsi-d00c3f896c741617f8367f4896d890d1aa1ba2fd.zip jitsi-d00c3f896c741617f8367f4896d890d1aa1ba2fd.tar.gz jitsi-d00c3f896c741617f8367f4896d890d1aa1ba2fd.tar.bz2 |
Add lots of comments to OAuth 2 implementation.
-rw-r--r-- | src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsConnectionImpl.java | 6 | ||||
-rw-r--r-- | src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java | 66 |
2 files changed, 68 insertions, 4 deletions
diff --git a/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsConnectionImpl.java b/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsConnectionImpl.java index 7c0bafc..503b413 100644 --- a/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsConnectionImpl.java +++ b/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsConnectionImpl.java @@ -227,9 +227,15 @@ public class GoogleContactsConnectionImpl return prefix; } + /** + * Exception for signaling failed contact query. + * + * @author Danny van Heumen + */ public static class FailedContactQueryException extends Exception { + private static final long serialVersionUID = -5451421392081973669L; private FailedContactQueryException(Throwable cause) { diff --git a/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java b/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java index 18a909d..cd04b39 100644 --- a/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java +++ b/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java @@ -192,7 +192,7 @@ public class OAuth2TokenStore ((UrlEncodedContent) request.getContent()).getData(); if (data instanceof RefreshTokenRequest) { - // Insert client authentication credentials in requests. + // Inject client authentication credentials in requests. final RefreshTokenRequest content = (RefreshTokenRequest) data; content.put("client_id", GOOGLE_API_CLIENT_ID); @@ -206,7 +206,7 @@ public class OAuth2TokenStore } else { - LOGGER.info("Unexpected type of request found."); + LOGGER.debug("Unexpected type of request found."); } } }); @@ -243,12 +243,26 @@ public class OAuth2TokenStore return credential; } + /** + * Request an authentication token using the approval code received from the + * user. + * + * @param approvalCode the approval code + * @return Returns the acquired token data from OAuth 2 token server. + */ private static TokenData requestAuthenticationToken(final String approvalCode) { // FIXME actually acquire credential return new TokenData("", "", 3600L); } + /** + * OAuth 2 approval dialog for instructing user for instructing the user to + * open a web browser and approve Jitsi Google Contacts plugin access and + * for receiving the resulting approval code. + * + * @author Danny van Heumen + */ private static class OAuthApprovalDialog extends SIPCommDialog { private static final long serialVersionUID = 6792589736608633346L; @@ -256,7 +270,7 @@ public class OAuth2TokenStore private final SIPCommTextField code = new SIPCommTextField(""); - public OAuthApprovalDialog() throws MalformedURLException + public OAuthApprovalDialog() { this.setModal(true); this.label = new SIPCommLinkButton("Click here to approve."); @@ -287,20 +301,47 @@ public class OAuth2TokenStore this.pack(); } + /** + * Get approval code entered by the user in the dialog input field. + * + * @return Returns the approval code. + */ public String getApprovalCode() { return this.code.getText(); } } + /** + * Container for token data for internal use. + * + * @author Danny van Heumen + */ private static class TokenData { + /** + * OAuth 2 access token. + */ private final String accessToken; + /** + * OAuth 2 refresh token. + */ private final String refreshToken; + /** + * Available time before expiration of the current access token. + */ private final long expiration; - private TokenData(final String accessToken, final String refreshToken, final long expirationTime) + /** + * Constructor for TokenData container. + * + * @param accessToken the access token + * @param refreshToken the refresh token + * @param expirationTime the expiration time + */ + private TokenData(final String accessToken, final String refreshToken, + final long expirationTime) { if (accessToken == null) { @@ -312,10 +353,21 @@ public class OAuth2TokenStore throw new NullPointerException("refresh token cannot be null"); } this.refreshToken = refreshToken; + if (expirationTime < 0) + { + throw new IllegalArgumentException( + "Expiration time cannot be null"); + } this.expiration = expirationTime; } } + /** + * Exception for error case where we failed to acquire initial credential + * for OAuth 2 authentication and authorization. + * + * @author Danny van Heumen + */ public static class FailedAcquireCredentialException extends Exception { @@ -327,6 +379,12 @@ public class OAuth2TokenStore } } + /** + * Exception for error case where we failed to refresh the OAuth 2 authn + * token. + * + * @author Danny van Heumen + */ public static class FailedTokenRefreshException extends Exception { |