Reputation: 2396
I'm having trouble with my first attempt to use authentication in debug mode in a Google Cloud Endpoints android app. I set up credentials like this:
credential = GoogleAccountCredential.usingAudience(this,
"server:client_id:long-string-i-got-from-api-console");
credential.setSelectedAccountName(accountName);
then try to use it like this:
final String LOCAL_APP_ENGINE_SERVER_URL = "http://xxx.xxx.x.xxx:8888";
Testdbendpoint.Builder endpointBuilder = new Testdbendpoint.Builder(
AndroidHttp.newCompatibleTransport(),
new GsonFactory(),
credential);
endpointBuilder.setRootUrl(LOCAL_APP_ENGINE_SERVER_URL + "/_ah/api/");
Testdbendpoint endpoint = endpointBuilder.build();
try {
TestDB testDB = new TestDB().setId(10101L);
TestDB result = endpoint.insertTestDB(testDB).execute(); //-- fails here!!!!
} catch ...
But the try fails and I get these messages in logCat:
03-06 23:33:20.418: W/System.err(11861): Caused by: com.google.android.gms.auth.GoogleAuthException: Unknown 03-06 23:33:20.418: W/System.err(11861): at com.google.android.gms.auth.GoogleAuthUtil.getToken(Unknown Source) 03-06 23:33:20.423: W/System.err(11861): at com.google.android.gms.auth.GoogleAuthUtil.getToken(Unknown Source) 03-06 23:33:20.428: W/System.err(11861): at com.google.api.client.googleapis.extensions.android.gms.auth.GoogleAccountCredential.getToken(GoogleAccountCredential.java:192)
Upvotes: 4
Views: 3321
Reputation: 4857
I wish this might help you.
import android.accounts.Account;
import android.app.Activity;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.support.v4.app.FragmentActivity;
import com.google.android.gms.auth.GoogleAuthException;
import com.google.android.gms.auth.GoogleAuthUtil;
import com.google.android.gms.auth.api.Auth;
import com.google.android.gms.auth.api.signin.GoogleSignInOptions;
import com.google.android.gms.auth.api.signin.GoogleSignInResult;
import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.api.GoogleApiClient;
import com.urbanft.utils.AppToast;
import java.io.IOException;
/**
* Created by kiwitech on 13/10/16.
*/
public class GoogleLogin extends FragmentActivity implements GoogleApiClient.OnConnectionFailedListener {
private GoogleSignInOptions gso;
protected GoogleApiClient mGoogleApiClient;
private int RC_SIGN_IN = 100;
public static String GOOGLE_ACCESS_TOKEN = "google_access_token";
public static String GOOGLE_USER_ID = "google_user_id";
private String mGooglesUserId;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
initialize();
}
private void initialize(){
gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
.requestEmail()
.build();
mGoogleApiClient = new GoogleApiClient.Builder(this)
.enableAutoManage(this , this)
.addApi(Auth.GOOGLE_SIGN_IN_API, gso)
.build();
}
protected void goForGoogleSignIn(){
Intent signInIntent = Auth.GoogleSignInApi.getSignInIntent(mGoogleApiClient);
startActivityForResult(signInIntent, RC_SIGN_IN);
}
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == RC_SIGN_IN) {
GoogleSignInResult result = Auth.GoogleSignInApi.getSignInResultFromIntent(data);
if(result.isSuccess()){
AppToast.showToast(this,"Google sign-in success");
mGooglesUserId = result.getSignInAccount().getId();
new LocalAsyncTask(result.getSignInAccount().getEmail()).execute();
}else{
AppToast.showToast(this,"Google sign-in failure");
onBackPressed();
finish();
}
}
}
class LocalAsyncTask extends AsyncTask<String,String,String> {
private String email;
LocalAsyncTask(String email) {
this.email = email;
}
@Override
protected String doInBackground(String... params) {
String token = null;
try {
String SCOPE = "oauth2:https://www.googleapis.com/auth/userinfo.profile";
Account account = new Account(email, "com.google");
token = GoogleAuthUtil.getToken(GoogleLogin.this, account, SCOPE);
} catch (IOException e) {
e.printStackTrace();
} catch (GoogleAuthException e) {
e.printStackTrace();
}
return token;
}
@Override
protected void onPostExecute(String s){
Intent intent =new Intent();
intent.putExtra(GOOGLE_ACCESS_TOKEN,s);
intent.putExtra(GOOGLE_USER_ID,mGooglesUserId);
setResult(Activity.RESULT_OK, intent);
onBackPressed();
finish();
}
}
@Override
public void onConnectionFailed(@NonNull ConnectionResult connectionResult) {
}
}
Upvotes: 0
Reputation: 2380
Maybe you have the wrong Certificate fingerprint (SHA1) for your Android Client-Id? The authentication with the fingerprint of your production key works only if you sign the .apk manually.
Register a Client-Id for an Installed Application (Android) with your debug.keystore fingerprint in your API Console. To get the fingerprint use:
C:\>keytool -list -alias androiddebugkey -keystore C:\.android\debug.keystore -storepass android -keypass android
Also you need a Web-Client-Id and set it as Audience in your Android application:
credential = GoogleAccountCredential.usingAudience(this,"server:client_id:" + WEB_CLIENT_ID);
AppEngine Endpoint configuration should look like this:
@Api(
name = "testEndpoint",
version = "v1",
clientIds = {ClientIds.WEB_ID, ClientIds.ANDROID_PRODUCTION_ID, ClientIds.ANDROID_DEBUG_ID},
audiences = {ClientIds.WEB_ID}
)
Upvotes: 12
Reputation: 1088
Just making sure, but did you register a client ID in the Google APIs Console as well as an App Engine App ID? And has that google account been added to the device?
The instructions on this blog might be useful:
http://devthots.blogspot.com/
Hope that helps!
Upvotes: 0