aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDanny van Heumen <danny@dannyvanheumen.nl>2015-06-10 00:33:49 +0200
committerDanny van Heumen <danny@dannyvanheumen.nl>2015-07-20 22:29:45 +0200
commitd00c3f896c741617f8367f4896d890d1aa1ba2fd (patch)
tree628f3750e7c44bd0f01296f9ed6ad263ebeda111
parent218b69991e594ea56e29f809803900473a47b487 (diff)
downloadjitsi-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.java6
-rw-r--r--src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java66
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
{