From ad8c636dcc0bfc7cd88c98a246453a550a9b26d5 Mon Sep 17 00:00:00 2001 From: Danny van Heumen Date: Fri, 17 Jul 2015 22:16:43 +0200 Subject: Added browser launcher to hyperlink. Now opens the approval URL upon clicking the hyperlink. --- .../googlecontacts/GoogleContactsActivator.java | 22 ++++++++++++++++++++++ .../impl/googlecontacts/OAuth2TokenStore.java | 14 +++++++------- .../impl/googlecontacts/googlecontacts.manifest.mf | 1 + 3 files changed, 30 insertions(+), 7 deletions(-) (limited to 'src/net/java/sip/communicator/impl') diff --git a/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsActivator.java b/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsActivator.java index 75c6f14..a0ffdcd 100644 --- a/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsActivator.java +++ b/src/net/java/sip/communicator/impl/googlecontacts/GoogleContactsActivator.java @@ -8,6 +8,7 @@ package net.java.sip.communicator.impl.googlecontacts; import java.util.*; +import net.java.sip.communicator.service.browserlauncher.*; import net.java.sip.communicator.service.contactsource.*; import net.java.sip.communicator.service.credentialsstorage.*; import net.java.sip.communicator.service.googlecontacts.*; @@ -66,6 +67,11 @@ public class GoogleContactsActivator implements BundleActivator private static GoogleContactsServiceImpl googleContactsService; /** + * Browser launcher service. + */ + private static BrowserLauncherService browserLauncherService; + + /** * List of contact source service registrations. */ private static Map> cssList @@ -144,6 +150,22 @@ public class GoogleContactsActivator implements BundleActivator } /** + * Return reference to a browser launcher service implementation. + * + * @return Returns the browser launcher service instance. + */ + public static BrowserLauncherService getBrowserLauncherService() + { + if (browserLauncherService == null) + { + browserLauncherService = + ServiceUtils.getService(bundleContext, + BrowserLauncherService.class); + } + return browserLauncherService; + } + + /** * Starts the Google Contacts service * * @param bundleContext BundleContext diff --git a/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java b/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java index 3dfaaea..8f1a619 100644 --- a/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java +++ b/src/net/java/sip/communicator/impl/googlecontacts/OAuth2TokenStore.java @@ -146,7 +146,7 @@ public class OAuth2TokenStore * @throws FailedAcquireCredentialException * @throws MalformedURLException In case requesting authn token failed. */ - public Credential get(final String identity) + public synchronized Credential get(final String identity) throws FailedAcquireCredentialException { if (this.store.get() == null) @@ -239,7 +239,7 @@ public class OAuth2TokenStore * @throws FailedTokenRefreshException In case of failed token refresh * operation. */ - public void refresh() throws IOException, FailedTokenRefreshException + public synchronized void refresh() throws IOException, FailedTokenRefreshException { final Credential credential = this.store.get(); if (credential == null) @@ -412,17 +412,17 @@ public class OAuth2TokenStore { this.setModal(true); this.label = - new SIPCommLinkButton( - "Click here to approve. Make sure you log in as " - + identity); + new SIPCommLinkButton("Approve Jitsi's access to " + identity); this.label.addActionListener(new ActionListener() { @Override public void actionPerformed(ActionEvent e) { - LOGGER.info("Request user for approval via web page: " + APPROVAL_URL); - // FIXME open browser + LOGGER.info("Request user for approval via web page: " + + APPROVAL_URL); + GoogleContactsActivator.getBrowserLauncherService() + .openURL(APPROVAL_URL); } }); this.setLayout(new BorderLayout()); diff --git a/src/net/java/sip/communicator/impl/googlecontacts/googlecontacts.manifest.mf b/src/net/java/sip/communicator/impl/googlecontacts/googlecontacts.manifest.mf index 4fd9387..a385df7 100644 --- a/src/net/java/sip/communicator/impl/googlecontacts/googlecontacts.manifest.mf +++ b/src/net/java/sip/communicator/impl/googlecontacts/googlecontacts.manifest.mf @@ -15,6 +15,7 @@ Import-Package: org.osgi.framework, net.java.sip.communicator.service.protocol, net.java.sip.communicator.util, net.java.sip.communicator.plugin.desktoputil, + net.java.sip.communicator.service.browserlauncher, org.xml.sax, org.xml.sax.helpers, javax.xml.parsers, -- cgit v1.1