VancedMicroG/src/org/microg/gms/auth/AuthManager.java

107 lines
4.9 KiB
Java
Raw Normal View History

2015-02-03 22:08:55 +00:00
/*
* Copyright 2013-2015 µg Project Team
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.microg.gms.auth;
import android.accounts.Account;
import android.accounts.AccountManager;
import android.content.Context;
2015-02-10 02:33:30 +00:00
import android.content.pm.PackageManager;
2015-02-03 22:08:55 +00:00
import android.util.Log;
2015-02-09 22:16:37 +00:00
import org.microg.gms.common.Utils;
2015-02-03 22:08:55 +00:00
public class AuthManager {
private static final String TAG = "GmsAuthManager";
2015-02-10 02:33:30 +00:00
public static final String PERMISSION_TREE_BASE = "com.google.android.googleapps.permission.GOOGLE_AUTH.";
2015-02-03 22:08:55 +00:00
public static void storeResponse(Context context, Account account, String packageName,
String sig, String service, AuthResponse response) {
AccountManager accountManager = AccountManager.get(context);
if (response.accountId != null)
accountManager.setUserData(account, "GoogleUserId", response.accountId);
if (response.Sid != null)
accountManager.setAuthToken(account, buildTokenKey(packageName, sig, "SID"), response.Sid);
if (response.LSid != null)
accountManager.setAuthToken(account, buildTokenKey(packageName, sig, "LSID"), response.LSid);
if (response.expiry > 0)
accountManager.setUserData(account, buildExpireKey(packageName, sig, service), Long.toString(response.expiry));
2015-02-09 22:16:37 +00:00
if (response.auth != null && response.expiry != 0 && response.storeConsentRemotely) {
2015-02-03 22:08:55 +00:00
accountManager.setAuthToken(account, buildTokenKey(packageName, sig, service), response.auth);
accountManager.setUserData(account, buildPermKey(packageName, sig, service), "1");
}
}
2015-02-10 02:33:30 +00:00
public static String getToken(Context context, Account account, String packageName,
String sig, String service) {
AccountManager accountManager = AccountManager.get(context);
return accountManager.peekAuthToken(account, buildTokenKey(packageName, sig, service));
}
2015-02-03 22:08:55 +00:00
public static boolean isPermitted(Context context, Account account, String packageName,
String sig, String service) {
2015-02-10 02:33:30 +00:00
if (service.startsWith("audience:server:client_id:")) {
// https://developers.google.com/accounts/docs/CrossClientAuth
Log.d(TAG, "Always permitting scope: " + service);
return true;
}
if (!service.startsWith("oauth")) {
if (context.getPackageManager().checkPermission(PERMISSION_TREE_BASE + service, packageName) == PackageManager.PERMISSION_GRANTED) {
Log.d(TAG, "Permitting, permission is present");
return true;
}
}
2015-02-03 22:08:55 +00:00
AccountManager accountManager = AccountManager.get(context);
String perm = accountManager.getUserData(account, buildPermKey(packageName, sig, service));
2015-02-10 02:33:30 +00:00
if (!"1".equals(perm)) {
Log.d(TAG, "Not permitting, permission not stored for " + packageName + ": " + service);
2015-02-03 22:08:55 +00:00
return false;
2015-02-10 02:33:30 +00:00
}
2015-02-03 22:08:55 +00:00
String exp = accountManager.getUserData(account, buildExpireKey(packageName, sig, service));
if (exp != null) {
long expLong = Long.parseLong(exp);
if (expLong < System.currentTimeMillis() / 1000L) {
Log.d(TAG, "Permission for " + packageName + " / " + service + " present, but expired");
return false;
}
}
return true;
}
2015-02-09 22:16:37 +00:00
public static void storePermission(Context context, Account account, String packageName, String service) {
storePermission(context, account, packageName, Utils.getFirstPackageSignatureDigest(context, packageName), service);
}
2015-02-07 19:56:49 +00:00
public static void storePermission(Context context, Account account, String packageName,
String sig, String service) {
AccountManager accountManager = AccountManager.get(context);
accountManager.setUserData(account, buildPermKey(packageName, sig, service), "1");
}
2015-02-03 22:08:55 +00:00
private static String buildTokenKey(String packageName, String sig, String service) {
return packageName + ":" + sig + ":" + service;
}
private static String buildPermKey(String packageName, String sig, String service) {
return "perm." + packageName + ":" + sig + ":" + service;
}
private static String buildExpireKey(String packageName, String sig, String service) {
return "EXP." + packageName + ":" + sig + ":" + service;
}
}