Google Play Games Android Sign In Getting Error Code 4












2















I am currently working on an Android app in which I want to use Google Play Games services (Achievements, Leaderboards, ...). After many iterations I finally got the code working to show the Google Play Games Login promt. The problem is now that after the user signs in it takes a while and then throws error code 4 with error message being empty. After doing a lot of research nothing really helped me solving this problem.



I have tried starting it directly out of Android Studio, installing the app manually or over Google Play, all on multiple devices, nothing worked.



Here's some code if required:



private static GoogleSignInClient mGoogleSignInClient;

...

@Override
protected void onCreate(Bundle savedInstanceState) {
...

mGoogleSignInClient = GoogleSignIn.getClient(this, new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_GAMES_SIGN_IN).requestIdToken(getResources().getString(R.string.app_id)).build());

signInSilently(); // Can't be tested yet.
// isSignedIn() and loginDeclined are both false
if(!isSignedIn() && !loginDeclined) startSignInIntent();
}

...

private void startSignInIntent() {
startActivityForResult(mGoogleSignInClient.getSignInIntent(), RC_SIGN_IN);
loginDeclined = true;
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
super.onActivityResult(requestCode, resultCode, intent);
// resultCode = 0

if (requestCode == RC_SIGN_IN) {
Task<GoogleSignInAccount> task =
GoogleSignIn.getSignedInAccountFromIntent(intent);

try {
GoogleSignInAccount account = task.getResult(ApiException.class);
// Now this never happens :(
System.out.println("SUCCESS!");
} catch (ApiException apiException) {
System.out.println(apiException.getStatusCode() + " + " + apiException.getMessage());
// statusCode is 4, message is "4: "

String message = apiException.getMessage();
if (message == null || message.isEmpty()) {
message = "Error signing in to Google Play Games";
}

new android.app.AlertDialog.Builder(this)
.setMessage(message)
.setNeutralButton(android.R.string.ok, null)
.show();
}
}
}









share|improve this question





























    2















    I am currently working on an Android app in which I want to use Google Play Games services (Achievements, Leaderboards, ...). After many iterations I finally got the code working to show the Google Play Games Login promt. The problem is now that after the user signs in it takes a while and then throws error code 4 with error message being empty. After doing a lot of research nothing really helped me solving this problem.



    I have tried starting it directly out of Android Studio, installing the app manually or over Google Play, all on multiple devices, nothing worked.



    Here's some code if required:



    private static GoogleSignInClient mGoogleSignInClient;

    ...

    @Override
    protected void onCreate(Bundle savedInstanceState) {
    ...

    mGoogleSignInClient = GoogleSignIn.getClient(this, new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_GAMES_SIGN_IN).requestIdToken(getResources().getString(R.string.app_id)).build());

    signInSilently(); // Can't be tested yet.
    // isSignedIn() and loginDeclined are both false
    if(!isSignedIn() && !loginDeclined) startSignInIntent();
    }

    ...

    private void startSignInIntent() {
    startActivityForResult(mGoogleSignInClient.getSignInIntent(), RC_SIGN_IN);
    loginDeclined = true;
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
    super.onActivityResult(requestCode, resultCode, intent);
    // resultCode = 0

    if (requestCode == RC_SIGN_IN) {
    Task<GoogleSignInAccount> task =
    GoogleSignIn.getSignedInAccountFromIntent(intent);

    try {
    GoogleSignInAccount account = task.getResult(ApiException.class);
    // Now this never happens :(
    System.out.println("SUCCESS!");
    } catch (ApiException apiException) {
    System.out.println(apiException.getStatusCode() + " + " + apiException.getMessage());
    // statusCode is 4, message is "4: "

    String message = apiException.getMessage();
    if (message == null || message.isEmpty()) {
    message = "Error signing in to Google Play Games";
    }

    new android.app.AlertDialog.Builder(this)
    .setMessage(message)
    .setNeutralButton(android.R.string.ok, null)
    .show();
    }
    }
    }









    share|improve this question



























      2












      2








      2








      I am currently working on an Android app in which I want to use Google Play Games services (Achievements, Leaderboards, ...). After many iterations I finally got the code working to show the Google Play Games Login promt. The problem is now that after the user signs in it takes a while and then throws error code 4 with error message being empty. After doing a lot of research nothing really helped me solving this problem.



      I have tried starting it directly out of Android Studio, installing the app manually or over Google Play, all on multiple devices, nothing worked.



      Here's some code if required:



      private static GoogleSignInClient mGoogleSignInClient;

      ...

      @Override
      protected void onCreate(Bundle savedInstanceState) {
      ...

      mGoogleSignInClient = GoogleSignIn.getClient(this, new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_GAMES_SIGN_IN).requestIdToken(getResources().getString(R.string.app_id)).build());

      signInSilently(); // Can't be tested yet.
      // isSignedIn() and loginDeclined are both false
      if(!isSignedIn() && !loginDeclined) startSignInIntent();
      }

      ...

      private void startSignInIntent() {
      startActivityForResult(mGoogleSignInClient.getSignInIntent(), RC_SIGN_IN);
      loginDeclined = true;
      }

      @Override
      protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
      super.onActivityResult(requestCode, resultCode, intent);
      // resultCode = 0

      if (requestCode == RC_SIGN_IN) {
      Task<GoogleSignInAccount> task =
      GoogleSignIn.getSignedInAccountFromIntent(intent);

      try {
      GoogleSignInAccount account = task.getResult(ApiException.class);
      // Now this never happens :(
      System.out.println("SUCCESS!");
      } catch (ApiException apiException) {
      System.out.println(apiException.getStatusCode() + " + " + apiException.getMessage());
      // statusCode is 4, message is "4: "

      String message = apiException.getMessage();
      if (message == null || message.isEmpty()) {
      message = "Error signing in to Google Play Games";
      }

      new android.app.AlertDialog.Builder(this)
      .setMessage(message)
      .setNeutralButton(android.R.string.ok, null)
      .show();
      }
      }
      }









      share|improve this question
















      I am currently working on an Android app in which I want to use Google Play Games services (Achievements, Leaderboards, ...). After many iterations I finally got the code working to show the Google Play Games Login promt. The problem is now that after the user signs in it takes a while and then throws error code 4 with error message being empty. After doing a lot of research nothing really helped me solving this problem.



      I have tried starting it directly out of Android Studio, installing the app manually or over Google Play, all on multiple devices, nothing worked.



      Here's some code if required:



      private static GoogleSignInClient mGoogleSignInClient;

      ...

      @Override
      protected void onCreate(Bundle savedInstanceState) {
      ...

      mGoogleSignInClient = GoogleSignIn.getClient(this, new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_GAMES_SIGN_IN).requestIdToken(getResources().getString(R.string.app_id)).build());

      signInSilently(); // Can't be tested yet.
      // isSignedIn() and loginDeclined are both false
      if(!isSignedIn() && !loginDeclined) startSignInIntent();
      }

      ...

      private void startSignInIntent() {
      startActivityForResult(mGoogleSignInClient.getSignInIntent(), RC_SIGN_IN);
      loginDeclined = true;
      }

      @Override
      protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
      super.onActivityResult(requestCode, resultCode, intent);
      // resultCode = 0

      if (requestCode == RC_SIGN_IN) {
      Task<GoogleSignInAccount> task =
      GoogleSignIn.getSignedInAccountFromIntent(intent);

      try {
      GoogleSignInAccount account = task.getResult(ApiException.class);
      // Now this never happens :(
      System.out.println("SUCCESS!");
      } catch (ApiException apiException) {
      System.out.println(apiException.getStatusCode() + " + " + apiException.getMessage());
      // statusCode is 4, message is "4: "

      String message = apiException.getMessage();
      if (message == null || message.isEmpty()) {
      message = "Error signing in to Google Play Games";
      }

      new android.app.AlertDialog.Builder(this)
      .setMessage(message)
      .setNeutralButton(android.R.string.ok, null)
      .show();
      }
      }
      }






      java android google-play-games






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Jan 2 at 20:13









      Amir

      159214




      159214










      asked Jan 2 at 17:41









      MaanexMaanex

      187




      187
























          1 Answer
          1






          active

          oldest

          votes


















          0














          Please check the following details for GPG Sign in issues:



          Make sure that you have followed the instructions to create your client IDs and configure the games services.



          Your meta data Tag in manifest should match with your application's numeric ID, and it should only contain the numbers. Also double check your package name. Do not use the sample app package name. Use your own.



          The certificate with which you are signing your game should match the certificate fingerprint associated to your client ID.



          The last important thing, Check that test accounts are enabled. I keep forgetting this step.



          Make sure that the fingerprint from App signing certificate matches with the linked apps from Game services. You can also verify these details by navigating to your Google API console -> Select your app -> Credentials -> OAuth 2.0 client IDs.



          The other thing I noticed that, if the app is released, then you need to install the app from the Play Store for these credentials to work. If the app is not yet released, then make sure you are using the debug fingerprint and that matches in your Games services (Debug fingerprint).



          As far as you have these fingerprints in place, you should be fine. If you are still having issues, I would recommend to go through the code lab to get step by step help on how to to extend an existing Unity game to run on an Android device and integrate Play Game Services.
          https://codelabs.developers.google.com/codelabs/playservices_unity/index.html?index=..%2F..%2Findex#0



          Or here are the sample apps to help with quick test -
          https://github.com/playgameservices/android-basic-samples.



          You can also help us with the logcat to better understand the issue.






          share|improve this answer
























            Your Answer






            StackExchange.ifUsing("editor", function () {
            StackExchange.using("externalEditor", function () {
            StackExchange.using("snippets", function () {
            StackExchange.snippets.init();
            });
            });
            }, "code-snippets");

            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "1"
            };
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function() {
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled) {
            StackExchange.using("snippets", function() {
            createEditor();
            });
            }
            else {
            createEditor();
            }
            });

            function createEditor() {
            StackExchange.prepareEditor({
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader: {
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            },
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            });


            }
            });














            draft saved

            draft discarded


















            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54010800%2fgoogle-play-games-android-sign-in-getting-error-code-4%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            0














            Please check the following details for GPG Sign in issues:



            Make sure that you have followed the instructions to create your client IDs and configure the games services.



            Your meta data Tag in manifest should match with your application's numeric ID, and it should only contain the numbers. Also double check your package name. Do not use the sample app package name. Use your own.



            The certificate with which you are signing your game should match the certificate fingerprint associated to your client ID.



            The last important thing, Check that test accounts are enabled. I keep forgetting this step.



            Make sure that the fingerprint from App signing certificate matches with the linked apps from Game services. You can also verify these details by navigating to your Google API console -> Select your app -> Credentials -> OAuth 2.0 client IDs.



            The other thing I noticed that, if the app is released, then you need to install the app from the Play Store for these credentials to work. If the app is not yet released, then make sure you are using the debug fingerprint and that matches in your Games services (Debug fingerprint).



            As far as you have these fingerprints in place, you should be fine. If you are still having issues, I would recommend to go through the code lab to get step by step help on how to to extend an existing Unity game to run on an Android device and integrate Play Game Services.
            https://codelabs.developers.google.com/codelabs/playservices_unity/index.html?index=..%2F..%2Findex#0



            Or here are the sample apps to help with quick test -
            https://github.com/playgameservices/android-basic-samples.



            You can also help us with the logcat to better understand the issue.






            share|improve this answer




























              0














              Please check the following details for GPG Sign in issues:



              Make sure that you have followed the instructions to create your client IDs and configure the games services.



              Your meta data Tag in manifest should match with your application's numeric ID, and it should only contain the numbers. Also double check your package name. Do not use the sample app package name. Use your own.



              The certificate with which you are signing your game should match the certificate fingerprint associated to your client ID.



              The last important thing, Check that test accounts are enabled. I keep forgetting this step.



              Make sure that the fingerprint from App signing certificate matches with the linked apps from Game services. You can also verify these details by navigating to your Google API console -> Select your app -> Credentials -> OAuth 2.0 client IDs.



              The other thing I noticed that, if the app is released, then you need to install the app from the Play Store for these credentials to work. If the app is not yet released, then make sure you are using the debug fingerprint and that matches in your Games services (Debug fingerprint).



              As far as you have these fingerprints in place, you should be fine. If you are still having issues, I would recommend to go through the code lab to get step by step help on how to to extend an existing Unity game to run on an Android device and integrate Play Game Services.
              https://codelabs.developers.google.com/codelabs/playservices_unity/index.html?index=..%2F..%2Findex#0



              Or here are the sample apps to help with quick test -
              https://github.com/playgameservices/android-basic-samples.



              You can also help us with the logcat to better understand the issue.






              share|improve this answer


























                0












                0








                0







                Please check the following details for GPG Sign in issues:



                Make sure that you have followed the instructions to create your client IDs and configure the games services.



                Your meta data Tag in manifest should match with your application's numeric ID, and it should only contain the numbers. Also double check your package name. Do not use the sample app package name. Use your own.



                The certificate with which you are signing your game should match the certificate fingerprint associated to your client ID.



                The last important thing, Check that test accounts are enabled. I keep forgetting this step.



                Make sure that the fingerprint from App signing certificate matches with the linked apps from Game services. You can also verify these details by navigating to your Google API console -> Select your app -> Credentials -> OAuth 2.0 client IDs.



                The other thing I noticed that, if the app is released, then you need to install the app from the Play Store for these credentials to work. If the app is not yet released, then make sure you are using the debug fingerprint and that matches in your Games services (Debug fingerprint).



                As far as you have these fingerprints in place, you should be fine. If you are still having issues, I would recommend to go through the code lab to get step by step help on how to to extend an existing Unity game to run on an Android device and integrate Play Game Services.
                https://codelabs.developers.google.com/codelabs/playservices_unity/index.html?index=..%2F..%2Findex#0



                Or here are the sample apps to help with quick test -
                https://github.com/playgameservices/android-basic-samples.



                You can also help us with the logcat to better understand the issue.






                share|improve this answer













                Please check the following details for GPG Sign in issues:



                Make sure that you have followed the instructions to create your client IDs and configure the games services.



                Your meta data Tag in manifest should match with your application's numeric ID, and it should only contain the numbers. Also double check your package name. Do not use the sample app package name. Use your own.



                The certificate with which you are signing your game should match the certificate fingerprint associated to your client ID.



                The last important thing, Check that test accounts are enabled. I keep forgetting this step.



                Make sure that the fingerprint from App signing certificate matches with the linked apps from Game services. You can also verify these details by navigating to your Google API console -> Select your app -> Credentials -> OAuth 2.0 client IDs.



                The other thing I noticed that, if the app is released, then you need to install the app from the Play Store for these credentials to work. If the app is not yet released, then make sure you are using the debug fingerprint and that matches in your Games services (Debug fingerprint).



                As far as you have these fingerprints in place, you should be fine. If you are still having issues, I would recommend to go through the code lab to get step by step help on how to to extend an existing Unity game to run on an Android device and integrate Play Game Services.
                https://codelabs.developers.google.com/codelabs/playservices_unity/index.html?index=..%2F..%2Findex#0



                Or here are the sample apps to help with quick test -
                https://github.com/playgameservices/android-basic-samples.



                You can also help us with the logcat to better understand the issue.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Jan 2 at 21:53









                Android4FunAndroid4Fun

                155114




                155114
































                    draft saved

                    draft discarded




















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54010800%2fgoogle-play-games-android-sign-in-getting-error-code-4%23new-answer', 'question_page');
                    }
                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    MongoDB - Not Authorized To Execute Command

                    Npm cannot find a required file even through it is in the searched directory

                    in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith