mirror of
https://github.com/YTVanced/VancedMicroG
synced 2025-01-06 23:41:01 +00:00
Add package name to location requests when possible, fix incomplete permission check
This commit is contained in:
parent
c927f1a86a
commit
937e3422aa
4 changed files with 43 additions and 10 deletions
|
@ -16,6 +16,7 @@
|
||||||
|
|
||||||
package org.microg.gms.common;
|
package org.microg.gms.common;
|
||||||
|
|
||||||
|
import android.app.ActivityManager;
|
||||||
import android.app.PendingIntent;
|
import android.app.PendingIntent;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.PackageInfo;
|
import android.content.pm.PackageInfo;
|
||||||
|
@ -119,6 +120,16 @@ public class PackageUtils {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
public static String packageFromProcessId(Context context, int pid) {
|
||||||
|
ActivityManager manager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
|
||||||
|
if (manager == null) return null;
|
||||||
|
for (ActivityManager.RunningAppProcessInfo processInfo : manager.getRunningAppProcesses()) {
|
||||||
|
if (processInfo.pid == pid) return processInfo.processName;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
public static String packageFromPendingIntent(PendingIntent pi) {
|
public static String packageFromPendingIntent(PendingIntent pi) {
|
||||||
if (pi == null) return null;
|
if (pi == null) return null;
|
||||||
|
|
|
@ -18,6 +18,7 @@ package org.microg.gms.common;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.support.v4.content.ContextCompat;
|
import android.support.v4.content.ContextCompat;
|
||||||
|
import android.util.Log;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import com.google.android.gms.R;
|
import com.google.android.gms.R;
|
||||||
|
@ -53,8 +54,12 @@ public class Utils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean hasSelfPermissionOrNotify(Context context, String permission) {
|
public static boolean hasSelfPermissionOrNotify(Context context, String permission) {
|
||||||
if (ContextCompat.checkSelfPermission(context, permission) != PERMISSION_GRANTED) {
|
if (context.checkCallingOrSelfPermission(permission) != PERMISSION_GRANTED) {
|
||||||
|
try {
|
||||||
Toast.makeText(context, context.getString(R.string.lacking_permission_toast, permission), Toast.LENGTH_SHORT).show();
|
Toast.makeText(context, context.getString(R.string.lacking_permission_toast, permission), Toast.LENGTH_SHORT).show();
|
||||||
|
} catch (RuntimeException e) {
|
||||||
|
Log.w("GmsUtils", "Lacking permission to " + permission + " for pid:" + android.os.Process.myPid() + " uid:" + android.os.Process.myUid());
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -28,6 +28,7 @@ import com.google.android.gms.location.LocationRequest;
|
||||||
import com.google.android.gms.location.internal.FusedLocationProviderResult;
|
import com.google.android.gms.location.internal.FusedLocationProviderResult;
|
||||||
import com.google.android.gms.location.internal.LocationRequestUpdateData;
|
import com.google.android.gms.location.internal.LocationRequestUpdateData;
|
||||||
|
|
||||||
|
import org.microg.gms.common.PackageUtils;
|
||||||
import org.microg.gms.common.Utils;
|
import org.microg.gms.common.Utils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -42,6 +43,7 @@ import static com.google.android.gms.location.LocationRequest.PRIORITY_HIGH_ACCU
|
||||||
import static com.google.android.gms.location.LocationRequest.PRIORITY_NO_POWER;
|
import static com.google.android.gms.location.LocationRequest.PRIORITY_NO_POWER;
|
||||||
|
|
||||||
public class GoogleLocationManager implements LocationChangeListener {
|
public class GoogleLocationManager implements LocationChangeListener {
|
||||||
|
private static final String TAG = "GmsLocManager";
|
||||||
private static final String MOCK_PROVIDER = "mock";
|
private static final String MOCK_PROVIDER = "mock";
|
||||||
private static final long SWITCH_ON_FRESHNESS_CLIFF_MS = 30000; // 30 seconds
|
private static final long SWITCH_ON_FRESHNESS_CLIFF_MS = 30000; // 30 seconds
|
||||||
private static final String ACCESS_MOCK_LOCATION = "android.permission.ACCESS_MOCK_LOCATION";
|
private static final String ACCESS_MOCK_LOCATION = "android.permission.ACCESS_MOCK_LOCATION";
|
||||||
|
@ -155,8 +157,11 @@ public class GoogleLocationManager implements LocationChangeListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateLocationRequest(LocationRequestUpdateData data) {
|
public void updateLocationRequest(LocationRequestUpdateData data) {
|
||||||
|
String packageName = null;
|
||||||
|
if (data.pendingIntent != null)
|
||||||
|
packageName = PackageUtils.packageFromPendingIntent(data.pendingIntent);
|
||||||
if (data.opCode == LocationRequestUpdateData.REQUEST_UPDATES) {
|
if (data.opCode == LocationRequestUpdateData.REQUEST_UPDATES) {
|
||||||
requestLocationUpdates(new LocationRequestHelper(context, hasFineLocationPermission(), hasCoarseLocationPermission(), null, data));
|
requestLocationUpdates(new LocationRequestHelper(context, hasFineLocationPermission(), hasCoarseLocationPermission(), packageName, data));
|
||||||
if (data.fusedLocationProviderCallback != null) {
|
if (data.fusedLocationProviderCallback != null) {
|
||||||
try {
|
try {
|
||||||
data.fusedLocationProviderCallback.onFusedLocationProviderResult(FusedLocationProviderResult.SUCCESS);
|
data.fusedLocationProviderCallback.onFusedLocationProviderResult(FusedLocationProviderResult.SUCCESS);
|
||||||
|
|
|
@ -19,6 +19,7 @@ package org.microg.gms.location;
|
||||||
import android.app.PendingIntent;
|
import android.app.PendingIntent;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.location.Location;
|
import android.location.Location;
|
||||||
|
import android.os.Binder;
|
||||||
import android.os.IBinder;
|
import android.os.IBinder;
|
||||||
import android.os.Parcel;
|
import android.os.Parcel;
|
||||||
import android.os.RemoteException;
|
import android.os.RemoteException;
|
||||||
|
@ -52,6 +53,8 @@ import com.google.android.gms.location.places.internal.PlacesParams;
|
||||||
import com.google.android.gms.maps.model.LatLng;
|
import com.google.android.gms.maps.model.LatLng;
|
||||||
import com.google.android.gms.maps.model.LatLngBounds;
|
import com.google.android.gms.maps.model.LatLngBounds;
|
||||||
|
|
||||||
|
import org.microg.gms.common.PackageUtils;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -75,23 +78,27 @@ public class GoogleLocationManagerServiceImpl extends IGoogleLocationManagerServ
|
||||||
public void addGeofencesList(List<ParcelableGeofence> geofences, PendingIntent pendingIntent,
|
public void addGeofencesList(List<ParcelableGeofence> geofences, PendingIntent pendingIntent,
|
||||||
IGeofencerCallbacks callbacks, String packageName) throws RemoteException {
|
IGeofencerCallbacks callbacks, String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "addGeofencesList: " + geofences);
|
Log.d(TAG, "addGeofencesList: " + geofences);
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeGeofencesByIntent(PendingIntent pendingIntent, IGeofencerCallbacks callbacks,
|
public void removeGeofencesByIntent(PendingIntent pendingIntent, IGeofencerCallbacks callbacks,
|
||||||
String packageName) throws RemoteException {
|
String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "removeGeofencesByIntent: " + pendingIntent);
|
Log.d(TAG, "removeGeofencesByIntent: " + pendingIntent);
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeGeofencesById(String[] geofenceRequestIds, IGeofencerCallbacks callbacks,
|
public void removeGeofencesById(String[] geofenceRequestIds, IGeofencerCallbacks callbacks,
|
||||||
String packageName) throws RemoteException {
|
String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "removeGeofencesById: " + Arrays.toString(geofenceRequestIds));
|
Log.d(TAG, "removeGeofencesById: " + Arrays.toString(geofenceRequestIds));
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeAllGeofences(IGeofencerCallbacks callbacks, String packageName) throws RemoteException {
|
public void removeAllGeofences(IGeofencerCallbacks callbacks, String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "removeAllGeofences");
|
Log.d(TAG, "removeAllGeofences");
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -108,6 +115,7 @@ public class GoogleLocationManagerServiceImpl extends IGoogleLocationManagerServ
|
||||||
@Override
|
@Override
|
||||||
public ActivityRecognitionResult getLastActivity(String packageName) throws RemoteException {
|
public ActivityRecognitionResult getLastActivity(String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "getLastActivity");
|
Log.d(TAG, "getLastActivity");
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -138,35 +146,35 @@ public class GoogleLocationManagerServiceImpl extends IGoogleLocationManagerServ
|
||||||
@Override
|
@Override
|
||||||
public Location getLastLocation() throws RemoteException {
|
public Location getLastLocation() throws RemoteException {
|
||||||
Log.d(TAG, "getLastLocation");
|
Log.d(TAG, "getLastLocation");
|
||||||
return getLocationManager().getLastLocation(null);
|
return getLocationManager().getLastLocation(PackageUtils.packageFromProcessId(context, Binder.getCallingPid()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void requestLocationUpdatesWithListener(LocationRequest request,
|
public void requestLocationUpdatesWithListener(LocationRequest request,
|
||||||
final ILocationListener listener) throws RemoteException {
|
final ILocationListener listener) throws RemoteException {
|
||||||
Log.d(TAG, "requestLocationUpdatesWithListener: " + request);
|
Log.d(TAG, "requestLocationUpdatesWithListener: " + request);
|
||||||
getLocationManager().requestLocationUpdates(request, listener, null);
|
getLocationManager().requestLocationUpdates(request, listener, PackageUtils.packageFromProcessId(context, Binder.getCallingPid()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void requestLocationUpdatesWithIntent(LocationRequest request,
|
public void requestLocationUpdatesWithIntent(LocationRequest request,
|
||||||
PendingIntent callbackIntent) throws RemoteException {
|
PendingIntent callbackIntent) throws RemoteException {
|
||||||
Log.d(TAG, "requestLocationUpdatesWithIntent: " + request);
|
Log.d(TAG, "requestLocationUpdatesWithIntent: " + request);
|
||||||
getLocationManager().requestLocationUpdates(request, callbackIntent, null);
|
getLocationManager().requestLocationUpdates(request, callbackIntent, PackageUtils.packageFromPendingIntent(callbackIntent));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeLocationUpdatesWithListener(ILocationListener listener)
|
public void removeLocationUpdatesWithListener(ILocationListener listener)
|
||||||
throws RemoteException {
|
throws RemoteException {
|
||||||
Log.d(TAG, "removeLocationUpdatesWithListener: " + listener);
|
Log.d(TAG, "removeLocationUpdatesWithListener: " + listener);
|
||||||
getLocationManager().removeLocationUpdates(listener, null);
|
getLocationManager().removeLocationUpdates(listener, PackageUtils.packageFromProcessId(context, Binder.getCallingPid()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeLocationUpdatesWithIntent(PendingIntent callbackIntent)
|
public void removeLocationUpdatesWithIntent(PendingIntent callbackIntent)
|
||||||
throws RemoteException {
|
throws RemoteException {
|
||||||
Log.d(TAG, "removeLocationUpdatesWithIntent: " + callbackIntent);
|
Log.d(TAG, "removeLocationUpdatesWithIntent: " + callbackIntent);
|
||||||
getLocationManager().removeLocationUpdates(callbackIntent, null);
|
getLocationManager().removeLocationUpdates(callbackIntent, PackageUtils.packageFromPendingIntent(callbackIntent));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -226,12 +234,14 @@ public class GoogleLocationManagerServiceImpl extends IGoogleLocationManagerServ
|
||||||
public void requestLocationUpdatesWithPackage(LocationRequest request, ILocationListener listener,
|
public void requestLocationUpdatesWithPackage(LocationRequest request, ILocationListener listener,
|
||||||
String packageName) throws RemoteException {
|
String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "requestLocationUpdatesWithPackage: " + request);
|
Log.d(TAG, "requestLocationUpdatesWithPackage: " + request);
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
getLocationManager().requestLocationUpdates(request, listener, packageName);
|
getLocationManager().requestLocationUpdates(request, listener, packageName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Location getLastLocationWithPackage(String packageName) throws RemoteException {
|
public Location getLastLocationWithPackage(String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "getLastLocationWithPackage: " + packageName);
|
Log.d(TAG, "getLastLocationWithPackage: " + packageName);
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
return getLocationManager().getLastLocation(packageName);
|
return getLocationManager().getLastLocation(packageName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -248,6 +258,7 @@ public class GoogleLocationManagerServiceImpl extends IGoogleLocationManagerServ
|
||||||
@Override
|
@Override
|
||||||
public LocationAvailability getLocationAvailabilityWithPackage(String packageName) throws RemoteException {
|
public LocationAvailability getLocationAvailabilityWithPackage(String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "getLocationAvailabilityWithPackage: " + packageName);
|
Log.d(TAG, "getLocationAvailabilityWithPackage: " + packageName);
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
return new LocationAvailability();
|
return new LocationAvailability();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -295,6 +306,7 @@ public class GoogleLocationManagerServiceImpl extends IGoogleLocationManagerServ
|
||||||
@Override
|
@Override
|
||||||
public void requestLocationSettingsDialog(LocationSettingsRequest settingsRequest, ISettingsCallbacks callback, String packageName) throws RemoteException {
|
public void requestLocationSettingsDialog(LocationSettingsRequest settingsRequest, ISettingsCallbacks callback, String packageName) throws RemoteException {
|
||||||
Log.d(TAG, "requestLocationSettingsDialog: " + settingsRequest);
|
Log.d(TAG, "requestLocationSettingsDialog: " + settingsRequest);
|
||||||
|
PackageUtils.checkPackageUid(context, packageName, Binder.getCallingUid());
|
||||||
callback.onLocationSettingsResult(new LocationSettingsResult(new LocationSettingsStates(true, true, false, true, true, false), Status.CANCELED));
|
callback.onLocationSettingsResult(new LocationSettingsResult(new LocationSettingsStates(true, true, false, true, true, false), Status.CANCELED));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -302,14 +314,14 @@ public class GoogleLocationManagerServiceImpl extends IGoogleLocationManagerServ
|
||||||
public void requestLocationUpdatesInternalWithListener(LocationRequestInternal request,
|
public void requestLocationUpdatesInternalWithListener(LocationRequestInternal request,
|
||||||
ILocationListener listener) throws RemoteException {
|
ILocationListener listener) throws RemoteException {
|
||||||
Log.d(TAG, "requestLocationUpdatesInternalWithListener: " + request);
|
Log.d(TAG, "requestLocationUpdatesInternalWithListener: " + request);
|
||||||
getLocationManager().requestLocationUpdates(request.request, listener, null);
|
getLocationManager().requestLocationUpdates(request.request, listener, PackageUtils.packageFromProcessId(context, Binder.getCallingPid()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void requestLocationUpdatesInternalWithIntent(LocationRequestInternal request,
|
public void requestLocationUpdatesInternalWithIntent(LocationRequestInternal request,
|
||||||
PendingIntent callbackIntent) throws RemoteException {
|
PendingIntent callbackIntent) throws RemoteException {
|
||||||
Log.d(TAG, "requestLocationUpdatesInternalWithIntent: " + request);
|
Log.d(TAG, "requestLocationUpdatesInternalWithIntent: " + request);
|
||||||
getLocationManager().requestLocationUpdates(request.request, callbackIntent, null);
|
getLocationManager().requestLocationUpdates(request.request, callbackIntent, PackageUtils.packageFromPendingIntent(callbackIntent));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in a new issue