eksahin/google-api-java-client

Method Credential.refreshToken calls TokenResponseException.from which throws NullPointerException

Closed this issue · 10 comments

Version of google-api-java-client (e.g. 1.15.0-rc)?
1.18.0-rc

Java environment (e.g. Java 6, Android 2.3, App Engine)?
Java 1.7.0_55-b13 on Linux Gentoo 3.12.20

Describe the problem.
java.lang.NullPointerException
        at com.google.api.client.repackaged.com.google.common.base.Preconditions.checkNotNull(Preconditions.java:191)
        at com.google.api.client.util.Preconditions.checkNotNull(Preconditions.java:127)
        at com.google.api.client.json.jackson2.JacksonFactory.createJsonParser(JacksonFactory.java:96)
        at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:85)
        at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:81)
        at com.google.api.client.auth.oauth2.TokenResponseException.from(TokenResponseException.java:88)
        at com.google.api.client.auth.oauth2.TokenRequest.executeUnparsed(TokenRequest.java:287)
        at com.google.api.client.auth.oauth2.TokenRequest.execute(TokenRequest.java:307)
        at com.google.api.client.auth.oauth2.Credential.executeRefreshToken(Credential.java:570)
        at com.google.api.client.googleapis.auth.oauth2.GoogleCredential.executeRefreshToken(GoogleCredential.java:247)
        at com.google.api.client.auth.oauth2.Credential.refreshToken(Credential.java:489)

How would you expect it to be fixed?
Surely there has to be a cutomized runtime exception instead of NPE to figure 
out the cause.

Original issue reported on code.google.com by KoichiSe...@gmail.com on 18 Sep 2014 at 12:36

This problem also occurs in 1.19.0.

I have tried several error cases and found that this problem occurs in 
following situations:
 * invalid client_id\client_secret (i.e. strings like "foobar")
 * disabled client_secret (client_secret replace but a new one)
 * deleted application credentials

Just FYI.

Original comment by y.c...@appresso.com on 2 Dec 2014 at 12:42

We run into this error all the time when we're trying to obtain a service 
account credential using refreshToken(). The token endpoint 
(https://accounts.google.com/o/oauth2/token) properly returns a 401 error if we 
can't obtain a service account credential for the user, but the 
TokenResponseException.from() promptly blows up because the 401 response 
doesn't have any content.

For now we are trapping the NullPointerException explicitly, but I agree with 
the original bug - the underlying HTTP error should be returned cleanly rather 
than throwing a NPE.

Original comment by ben.gilb...@smartsheet.com on 3 Dec 2014 at 9:44

I am trying to connect to the GMAIL using service account to list my emails and 
I am getting the same error. I am using the 1.19.0 clients. Please advise.

java.lang.NullPointerException
    at com.google.api.client.repackaged.com.google.common.base.Preconditions.checkNotNull(Preconditions.java:191)
    at com.google.api.client.util.Preconditions.checkNotNull(Preconditions.java:127)
    at com.google.api.client.json.jackson2.JacksonFactory.createJsonParser(JacksonFactory.java:92)
    at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:85)
    at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:81)
    at com.google.api.client.auth.oauth2.TokenResponseException.from(TokenResponseException.java:88)
    at com.google.api.client.auth.oauth2.TokenRequest.executeUnparsed(TokenRequest.java:287)
    at com.google.api.client.auth.oauth2.TokenRequest.execute(TokenRequest.java:307)
    at com.google.api.client.googleapis.auth.oauth2.GoogleCredential.executeRefreshToken(GoogleCredential.java:384)
    at com.google.api.client.auth.oauth2.Credential.refreshToken(Credential.java:489)
    at com.google.api.client.auth.oauth2.Credential.intercept(Credential.java:217)
    at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:859)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:410)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:343)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:460)
    at TestGmailNew.main(TestGmailNew.java:72)

Original comment by premna...@gmail.com on 16 Dec 2014 at 1:40

I am getting the following exception when i access using service account for 
Prediction API. I am using 1.19.0 java client api. I changed and tried with new 
p12 keys , but nothing worked.

java.lang.NullPointerException: null
    at com.google.api.client.repackaged.com.google.common.base.Preconditions.checkNotNull(Preconditions.java:191)
    at com.google.api.client.util.Preconditions.checkNotNull(Preconditions.java:127)
    at com.google.api.client.json.jackson2.JacksonFactory.createJsonParser(JacksonFactory.java:92)
    at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:85)
    at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:81)
    at com.google.api.client.auth.oauth2.TokenResponseException.from(TokenResponseException.java:88)
    at com.google.api.client.auth.oauth2.TokenRequest.executeUnparsed(TokenRequest.java:287)
    at com.google.api.client.auth.oauth2.TokenRequest.execute(TokenRequest.java:307)
    at com.google.api.client.googleapis.auth.oauth2.GoogleCredential.executeRefreshToken(GoogleCredential.java:384)
    at com.google.api.client.auth.oauth2.Credential.refreshToken(Credential.java:489)
    at com.rest.services.PredictionService.authorize(PredictionService.java:241)
    at com.rest.services.PredictionService.trainModel(PredictionService.java:163)
    at com.rest.controller.PredictionController.train(PredictionController.java:40)

Original comment by rajesh.s...@gmail.com on 17 Dec 2014 at 10:20

The bug method TokenResponseException is here.
https://code.google.com/p/google-oauth-java-client/source/browse/google-oauth-cl
ient/src/main/java/com/google/api/client/auth/oauth2/TokenResponseException.java
Can we submit a fixed file into the sources?

Original comment by KoichiSe...@gmail.com on 17 Dec 2014 at 10:29

Hi,
I have changed the code the following way and it worked. I changed the 
PredictionScopes.all() and no more null pointer exception with 1.19.0 version.

credential = new 
GoogleCredential.Builder().setTransport(httpTransport).setJsonFactory(JSON_FACTO
RY)
                .setServiceAccountId(OAUTH_EMAIL_ADDRESS)
                .setServiceAccountPrivateKeyFromP12File(new File(Prediction.class.getClassLoader().getResource(OAUTH_PRIVATE_KEY_FILE).getPath()))
                .setServiceAccountScopes(PredictionScopes.all()).build();
                credential.refreshToken();

Regards,
Rajesh.

Original comment by rajesh.s...@gmail.com on 18 Dec 2014 at 2:38

Hi,

I get this error after receiving "Authorization Code"

199.74.155.50 - - [22/Dec/2014:19:29:44 +0000] "GET 
/Hello-JSP/ObtainOAuth2Token HTTP/1.1" 302 -
199.74.155.50 - - [22/Dec/2014:19:29:52 +0000] "GET 
/Hello-JSP/oauth2callback?code=4/ati4kh_xKKrEWzwH30Gm6uU7UBObn360gUWOOfyW9aI.Ug6
pyULC7CcdqPsZ5lQMyhHyuPjmlAI HTTP/1.1" 500 2470
 It fails even before the access and refresh tokens were requested from my server.

Thanks

Original comment by tharshan...@gmail.com on 23 Dec 2014 at 1:04

hi i m trying to access google drive using sample DriveSample offered by 
google.But i got same npe as above:

CONFIG: -------------- RESPONSE --------------
HTTP/1.1 401 Unauthorized
X-XSS-Protection: 1; mode=block
Expires: Fri, 01 Jan 1990 00:00:00 GMT
Alternate-Protocol: 443:quic,p=0.02
Server: GSE
X-Content-Type-Options: nosniff
Pragma: no-cache
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
X-Frame-Options: SAMEORIGIN
Transfer-Encoding: chunked
Date: Fri, 26 Dec 2014 13:00:11 GMT
Content-Encoding: gzip
Content-Type: application/json

java.lang.NullPointerException
    at com.google.api.client.repackaged.com.google.common.base.Preconditions.checkNotNull(Preconditions.java:191)
    at com.google.api.client.util.Preconditions.checkNotNull(Preconditions.java:127)
    at com.google.api.client.json.jackson2.JacksonFactory.createJsonParser(JacksonFactory.java:92)
    at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:85)
    at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:81)
    at com.google.api.client.auth.oauth2.TokenResponseException.from(TokenResponseException.java:88)
    at com.google.api.client.auth.oauth2.TokenRequest.executeUnparsed(TokenRequest.java:287)
    at com.google.api.client.auth.oauth2.TokenRequest.execute(TokenRequest.java:307)
    at com.google.api.client.auth.oauth2.Credential.executeRefreshToken(Credential.java:570)
    at com.google.api.client.auth.oauth2.Credential.refreshToken(Credential.java:489)
    at com.google.api.client.auth.oauth2.Credential.intercept(Credential.java:217)
    at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:859)
    at com.google.api.client.googleapis.media.MediaHttpUploader.executeCurrentRequestWithoutGZip(MediaHttpUploader.java:545)
    at com.google.api.client.googleapis.media.MediaHttpUploader.executeCurrentRequest(MediaHttpUploader.java:562)
    at com.google.api.client.googleapis.media.MediaHttpUploader.executeUploadInitiation(MediaHttpUploader.java:519)
    at com.google.api.client.googleapis.media.MediaHttpUploader.resumableUpload(MediaHttpUploader.java:384)
    at com.google.api.client.googleapis.media.MediaHttpUploader.upload(MediaHttpUploader.java:336)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:418)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:343)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:460)
    at com.google.api.services.samples.drive.cmdline.DriveSample.insertFile(DriveSample.java:108)
    at com.google.api.services.samples.drive.cmdline.DriveSample.main(DriveSample.java:160)

Any hint?

Original comment by g.dilemb...@gmail.com on 26 Dec 2014 at 1:18

There is clearly a bug in the 
com.google.api.client.auth.oauth2.TokenResponseException.from method code.
https://code.google.com/p/google-oauth-java-client/source/browse/google-oauth-cl
ient/src/main/java/com/google/api/client/auth/oauth2/TokenResponseException.java

It just does not check the response.getContent() return value for null before 
calling the com.google.api.client.json.JsonObjectParser.parseAndClose method 
with it.
https://code.google.com/p/google-http-java-client/source/browse/google-http-clie
nt/src/main/java/com/google/api/client/json/JsonObjectParser.java

Only the last method 
com.google.api.client.json.jackson2.JacksonFactory.createJsonParser does the 
check for null, which is already too late, and so it throws the 
NullPointerException.
https://code.google.com/p/google-http-java-client/source/browse/google-http-clie
nt-jackson2/src/main/java/com/google/api/client/json/jackson2/JacksonFactory.jav
a

I guess the code should just check for null in the TokenResponseException.from 
method itself in the "if" section.

I will most likely get my hands on doing that myself some day soon if the 
original code developers will not fix it before.

Original comment by KoichiSe...@gmail.com on 27 Dec 2014 at 6:23

Moved to: Issue google-oauth-java-client:101

Original comment by wonder...@google.com on 29 Dec 2014 at 7:47

  • Changed state: Moved