We're trying to implement GDK glassware auth; have uploaded our beta APK to the Google Glass team and successfully implemented our MyGlass login page. We are now attempting to access the token via the steps listed here: https://developers.google.com/glass/develop/gdk/authentication#retrieving_accounts_on_glass
However the last step, String token = future.getResult().getString(AccountManager.KEY_AUTHTOKEN); is resulting in the following exception:
09-22 18:07:24.126: I/AccountManagerService(519): Sharing credentials is not allowed: canceling.
09-22 18:07:24.313: W/System.err(5822): android.accounts.OperationCanceledException
09-22 18:07:24.313: W/System.err(5822):     at android.accounts.AccountManager$AmsTask.internalGetResult(AccountManager.java:1503)
09-22 18:07:24.313: W/System.err(5822):     at android.accounts.AccountManager$AmsTask.getResult(AccountManager.java:1531)
09-22 18:07:24.313: W/System.err(5822):     at android.accounts.AccountManager$AmsTask.getResult(AccountManager.java:1452)
09-22 18:07:24.313: W/System.err(5822):     at com.mycom.app.MainActivity$5.run(MainActivity.java:234)
09-22 18:07:24.313: W/System.err(5822):     at android.accounts.AccountManager$11.run(AccountManager.java:1427)
09-22 18:07:24.313: W/System.err(5822):     at android.os.Handler.handleCallback(Handler.java:733)
09-22 18:07:24.313: W/System.err(5822):     at android.os.Handler.dispatchMessage(Handler.java:95)
09-22 18:07:24.313: W/System.err(5822):     at android.os.Looper.loop(Looper.java:149)
09-22 18:07:24.313: W/System.err(5822):     at android.app.ActivityThread.main(ActivityThread.java:5061)
09-22 18:07:24.313: W/System.err(5822):     at java.lang.reflect.Method.invokeNative(Native Method)
09-22 18:07:24.313: W/System.err(5822):     at java.lang.reflect.Method.invoke(Method.java:515)
09-22 18:07:24.313: W/System.err(5822):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
09-22 18:07:24.313: W/System.err(5822):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
09-22 18:07:24.313: W/System.err(5822):     at dalvik.system.NativeStart.main(Native Method)
The request we are trying to push via Mirror API is formed like this (and returns an OK status code):
POST https://www.googleapis.com/mirror/v1/accounts/google_user_token/com.ourcom.app.session/ourapp_username
BODY 
{"authTokens":[{"type":"com.ourcom.app.session","authToken":"****************"}]}
HEADERS
{"Authorization":"Bearer ya29.iAAf********","Content-Type":"application/json;charset=utf-8"}
And this is our local Glass code:
AccountManager accountManager = AccountManager.get(this);
// Use your Glassware's account type.
Account[] accounts = accountManager.getAccountsByType("com.ourcom.app.session");
// Your auth token type.
final String AUTH_TOKEN_TYPE = "com.ourcom.app.session";
if (accounts.length > 0) {
    accountManager.getAuthToken(accounts[0], AUTH_TOKEN_TYPE, null, this, new AccountManagerCallback<Bundle>() {
        @Override
        public void run(AccountManagerFuture<Bundle> future) {
            try {
                String token = future.getResult().getString(AccountManager.KEY_AUTHTOKEN);
                //do something with token
                });
            } catch (Exception e) {
                //handle exception
                //this is where we get our OperationCancelledException
                e.printStackTrace();
            }
        }
    }, null);
} else {
    //handle not authed state
}
What could be causing this kind of error? Is the username at the end of the Mirror POST URL supposed to match something specific or are we free to use our own thing?
A couple things to check:
adb? Make sure that you uninstall your APK and then install it by turning it on in MyGlass in order for the permissions to be set up correctly; from that point on, you can continue developing by replacing the APK over adb.If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With