##Google+ Java API
A Java client for the Google+ API, based on spring-social.
This library is built ontop of spring-social and uses apache http components and jackson (see below the full list of dependencies)
###Usage
The way to use the API is:
GooglePlusFactory factory = new GooglePlusFactory(clientId, clientSecret);
// the refreshListener is notified in case a new access token is obtained after the old one expires
Plus plus = factory.getApi(accessToken, refreshToken, refreshListener);
ActivityFeed activities = plus.getActivityOperations().list(userId);
The factory is thread-safe and is supposed to have a single instance in your application.
###OAuth2
Google+ uses OAuth2. Read through the documentation to get a clear picture. Here tokens are obtained as follows (in a web application):
GooglePlusFactory factory = new GooglePlusFactory(clientId, clientSecret);
OAuth2Parameters oAuthParams = new OAuth2Parameters();
oAuthParams.setRedirectUri("http://yoursite.com/oauth/");
oAuthParams.setScope("https://www.googleapis.com/auth/plus.me
https://www.googleapis.com/auth/plus.moments.write");
String url = factory.getOAuthOperations()
.buildAuthenticateUrl(GrantType.AUTHORIZATION_CODE, oAuthParams);
response.sendRedirect(url);
After the user authorizes your app they will be redirected to your /oauth/ url. There you will receive a "code" parameter. You can exchange that code for an access token:
AccessGrant accessGrant = factory.getOAuthOperations()
.exchangeForAccess(code, oAuthParams.getRedirectUri(), null);
####Spring Social Configuration
If you want to integrate using Spring Social as described in their documentation simply add:
registry.addConnectionFactory(new GooglePlusConnectionFactory(
environment.getProperty("google.clientId"),
environment.getProperty("google.clientKey")))
Where the clientId and clientKey are supplied by Google having created a Web Application (not a Service Account or Installed Application).
An example scope:
https://www.googleapis.com/auth/plus.login https://www.googleapis.com/auth/plus.me https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/userinfo.profile
Google allows the registration of multiple email addresses of various types. For the purposes of UserProfile (as supplied by Spring Social), the email address is of the Google Account type. This may be null.
###Dependencies
This library depends on a couple of libraries. All of them are industry-standards - widely tested and adopted:
- spring-social (base framework for social network API clients) (including spring-social-core, and transitively: spring-web, spring-core, spring-beans and spring-context)
- apache http components (used for handling the http traffic)
- jackson (json mapper)
- joda-time (de-facto date-time standard)
- slf4j (logging facade that delegates to whatever logger you use in your project)
The preferable way of using this is through maven, so that all transitive dependencies are fetched automatically.
###Download
You can download the .jar file from the Releases section, or you can get it with maven:
<dependency>
<groupId>com.googlecode.googleplus</groupId>
<artifactId>google-plus-java-api</artifactId>
<version>0.0.1</version>
</dependency>
If you want to use the latest SNAPSHOT, the repository you have to add is:
<repository>
<id>sonatype-oss</id>
<url>https://oss.sonatype.org/content/groups/public</url>
</repository>