1
0
mirror of https://github.com/MGislv/NekoX.git synced 2024-07-04 11:13:36 +00:00

[TF][KILL] remove fusedlocationprovider

(cherry picked from commit ff1f6ce18ea02936ea20020e711a29da1ba27112)
This commit is contained in:
thermatk 2020-02-22 20:31:44 +00:00 committed by 世界
parent 84acf56d38
commit c72c70c46e
No known key found for this signature in database
GPG Key ID: CD109927C34A63C4
2 changed files with 19 additions and 175 deletions

View File

@ -8,6 +8,7 @@
package org.telegram.messenger; package org.telegram.messenger;
import android.annotation.SuppressLint;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.location.Address; import android.location.Address;
@ -22,17 +23,6 @@ import android.text.TextUtils;
import android.util.LongSparseArray; import android.util.LongSparseArray;
import android.util.SparseIntArray; import android.util.SparseIntArray;
import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.GoogleApiAvailability;
import com.google.android.gms.common.api.GoogleApiClient;
import com.google.android.gms.common.api.PendingResult;
import com.google.android.gms.common.api.Status;
import com.google.android.gms.location.LocationRequest;
import com.google.android.gms.location.LocationServices;
import com.google.android.gms.location.LocationSettingsRequest;
import com.google.android.gms.location.LocationSettingsResult;
import com.google.android.gms.location.LocationSettingsStatusCodes;
import org.telegram.SQLite.SQLiteCursor; import org.telegram.SQLite.SQLiteCursor;
import org.telegram.SQLite.SQLitePreparedStatement; import org.telegram.SQLite.SQLitePreparedStatement;
import org.telegram.tgnet.NativeByteBuffer; import org.telegram.tgnet.NativeByteBuffer;
@ -44,7 +34,7 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
public class LocationController extends BaseController implements NotificationCenter.NotificationCenterDelegate, GoogleApiClient.ConnectionCallbacks, GoogleApiClient.OnConnectionFailedListener { public class LocationController extends BaseController implements NotificationCenter.NotificationCenterDelegate {
private LongSparseArray<SharingLocationInfo> sharingLocationsMap = new LongSparseArray<>(); private LongSparseArray<SharingLocationInfo> sharingLocationsMap = new LongSparseArray<>();
private ArrayList<SharingLocationInfo> sharingLocations = new ArrayList<>(); private ArrayList<SharingLocationInfo> sharingLocations = new ArrayList<>();
@ -54,7 +44,6 @@ public class LocationController extends BaseController implements NotificationCe
private GpsLocationListener gpsLocationListener = new GpsLocationListener(); private GpsLocationListener gpsLocationListener = new GpsLocationListener();
private GpsLocationListener networkLocationListener = new GpsLocationListener(); private GpsLocationListener networkLocationListener = new GpsLocationListener();
private GpsLocationListener passiveLocationListener = new GpsLocationListener(); private GpsLocationListener passiveLocationListener = new GpsLocationListener();
private FusedLocationListener fusedLocationListener = new FusedLocationListener();
private Location lastKnownLocation; private Location lastKnownLocation;
private long lastLocationSendTime; private long lastLocationSendTime;
private boolean locationSentSinceLastGoogleMapUpdate = true; private boolean locationSentSinceLastGoogleMapUpdate = true;
@ -71,10 +60,6 @@ public class LocationController extends BaseController implements NotificationCe
public ArrayList<SharingLocationInfo> sharingLocationsUI = new ArrayList<>(); public ArrayList<SharingLocationInfo> sharingLocationsUI = new ArrayList<>();
private LongSparseArray<SharingLocationInfo> sharingLocationsMapUI = new LongSparseArray<>(); private LongSparseArray<SharingLocationInfo> sharingLocationsMapUI = new LongSparseArray<>();
private Boolean playServicesAvailable;
private boolean wasConnectedToPlayServices;
private GoogleApiClient googleApiClient;
private final static int PLAY_SERVICES_RESOLUTION_REQUEST = 9000;
private final static long UPDATE_INTERVAL = 1000, FASTEST_INTERVAL = 1000; private final static long UPDATE_INTERVAL = 1000, FASTEST_INTERVAL = 1000;
private final static int BACKGROUD_UPDATE_TIME = 30 * 1000; private final static int BACKGROUD_UPDATE_TIME = 30 * 1000;
private final static int LOCATION_ACQUIRE_TIME = 10 * 1000; private final static int LOCATION_ACQUIRE_TIME = 10 * 1000;
@ -85,8 +70,6 @@ public class LocationController extends BaseController implements NotificationCe
private ArrayList<TLRPC.TL_peerLocated> cachedNearbyUsers = new ArrayList<>(); private ArrayList<TLRPC.TL_peerLocated> cachedNearbyUsers = new ArrayList<>();
private ArrayList<TLRPC.TL_peerLocated> cachedNearbyChats = new ArrayList<>(); private ArrayList<TLRPC.TL_peerLocated> cachedNearbyChats = new ArrayList<>();
private LocationRequest locationRequest;
private static volatile LocationController[] Instance = new LocationController[UserConfig.MAX_ACCOUNT_COUNT]; private static volatile LocationController[] Instance = new LocationController[UserConfig.MAX_ACCOUNT_COUNT];
public static LocationController getInstance(int num) { public static LocationController getInstance(int num) {
@ -144,30 +127,10 @@ public class LocationController extends BaseController implements NotificationCe
} }
} }
private class FusedLocationListener implements com.google.android.gms.location.LocationListener {
@Override
public void onLocationChanged(Location location) {
if (location == null) {
return;
}
setLastKnownLocation(location);
}
}
public LocationController(int instance) { public LocationController(int instance) {
super(instance); super(instance);
locationManager = (LocationManager) ApplicationLoader.applicationContext.getSystemService(Context.LOCATION_SERVICE); locationManager = (LocationManager) ApplicationLoader.applicationContext.getSystemService(Context.LOCATION_SERVICE);
googleApiClient = new GoogleApiClient.Builder(ApplicationLoader.applicationContext).
addApi(LocationServices.API).
addConnectionCallbacks(this).
addOnConnectionFailedListener(this).build();
locationRequest = new LocationRequest();
locationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
locationRequest.setInterval(UPDATE_INTERVAL);
locationRequest.setFastestInterval(FASTEST_INTERVAL);
AndroidUtilities.runOnUIThread(() -> { AndroidUtilities.runOnUIThread(() -> {
LocationController locationController = getAccountInstance().getLocationController(); LocationController locationController = getAccountInstance().getLocationController();
@ -275,93 +238,6 @@ public class LocationController extends BaseController implements NotificationCe
} }
} }
@Override
public void onConnected(Bundle bundle) {
wasConnectedToPlayServices = true;
try {
if (Build.VERSION.SDK_INT >= 21) {
LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder().addLocationRequest(locationRequest);
PendingResult<LocationSettingsResult> result = LocationServices.SettingsApi.checkLocationSettings(googleApiClient, builder.build());
result.setResultCallback(locationSettingsResult -> {
final Status status = locationSettingsResult.getStatus();
switch (status.getStatusCode()) {
case LocationSettingsStatusCodes.SUCCESS:
startFusedLocationRequest(true);
break;
case LocationSettingsStatusCodes.RESOLUTION_REQUIRED:
Utilities.stageQueue.postRunnable(() -> {
if (lookingForPeopleNearby || !sharingLocations.isEmpty()) {
AndroidUtilities.runOnUIThread(() -> getNotificationCenter().postNotificationName(NotificationCenter.needShowPlayServicesAlert, status));
}
});
break;
case LocationSettingsStatusCodes.SETTINGS_CHANGE_UNAVAILABLE:
Utilities.stageQueue.postRunnable(() -> {
playServicesAvailable = false;
try {
googleApiClient.disconnect();
start();
} catch (Throwable ignore) {
}
});
break;
}
});
} else {
startFusedLocationRequest(true);
}
} catch (Throwable e) {
FileLog.e(e);
}
}
public void startFusedLocationRequest(boolean permissionsGranted) {
Utilities.stageQueue.postRunnable(() -> {
if (!permissionsGranted) {
playServicesAvailable = false;
}
if (shareMyCurrentLocation || lookingForPeopleNearby || !sharingLocations.isEmpty()) {
if (permissionsGranted) {
try {
setLastKnownLocation(LocationServices.FusedLocationApi.getLastLocation(googleApiClient));
LocationServices.FusedLocationApi.requestLocationUpdates(googleApiClient, locationRequest, fusedLocationListener);
} catch (Throwable e) {
FileLog.e(e);
}
} else {
start();
}
}
});
}
@Override
public void onConnectionSuspended(int i) {
}
@Override
public void onConnectionFailed(ConnectionResult connectionResult) {
if (wasConnectedToPlayServices) {
return;
}
playServicesAvailable = false;
if (started) {
started = false;
start();
}
}
private boolean checkPlayServices() {
if (playServicesAvailable == null) {
GoogleApiAvailability apiAvailability = GoogleApiAvailability.getInstance();
int resultCode = apiAvailability.isGooglePlayServicesAvailable(ApplicationLoader.applicationContext);
playServicesAvailable = resultCode == ConnectionResult.SUCCESS;
}
return playServicesAvailable;
}
private void broadcastLastKnownLocation(boolean cancelCurrent) { private void broadcastLastKnownLocation(boolean cancelCurrent) {
if (lastKnownLocation == null) { if (lastKnownLocation == null) {
return; return;
@ -807,6 +683,8 @@ public class LocationController extends BaseController implements NotificationCe
setLastKnownLocation(location); setLastKnownLocation(location);
} }
// TFOSS it asks properly anyway
@SuppressLint("MissingPermission")
private void start() { private void start() {
if (started) { if (started) {
return; return;
@ -814,14 +692,6 @@ public class LocationController extends BaseController implements NotificationCe
lastLocationStartTime = SystemClock.elapsedRealtime(); lastLocationStartTime = SystemClock.elapsedRealtime();
started = true; started = true;
boolean ok = false; boolean ok = false;
if (checkPlayServices()) {
try {
googleApiClient.connect();
ok = true;
} catch (Throwable e) {
FileLog.e(e);
}
}
if (!ok) { if (!ok) {
try { try {
locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 1, 0, gpsLocationListener); locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 1, 0, gpsLocationListener);
@ -856,14 +726,6 @@ public class LocationController extends BaseController implements NotificationCe
return; return;
} }
started = false; started = false;
if (checkPlayServices()) {
try {
LocationServices.FusedLocationApi.removeLocationUpdates(googleApiClient, fusedLocationListener);
googleApiClient.disconnect();
} catch (Throwable e) {
FileLog.e(e);
}
}
locationManager.removeUpdates(gpsLocationListener); locationManager.removeUpdates(gpsLocationListener);
if (empty) { if (empty) {
locationManager.removeUpdates(networkLocationListener); locationManager.removeUpdates(networkLocationListener);

View File

@ -25,6 +25,7 @@ import android.graphics.Point;
import android.graphics.Shader; import android.graphics.Shader;
import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.ColorDrawable; import android.graphics.drawable.ColorDrawable;
import android.location.Location;
import android.net.Uri; import android.net.Uri;
import android.os.Build; import android.os.Build;
import android.os.Bundle; import android.os.Bundle;
@ -49,10 +50,6 @@ import android.widget.LinearLayout;
import android.widget.RelativeLayout; import android.widget.RelativeLayout;
import android.widget.Toast; import android.widget.Toast;
import com.google.android.gms.common.api.Status;
import com.microsoft.appcenter.AppCenter;
import com.microsoft.appcenter.analytics.Analytics;
import org.telegram.messenger.AccountInstance; import org.telegram.messenger.AccountInstance;
import org.telegram.messenger.AndroidUtilities; import org.telegram.messenger.AndroidUtilities;
import org.telegram.messenger.BuildVars; import org.telegram.messenger.BuildVars;
@ -231,13 +228,9 @@ public class LaunchActivity extends Activity implements ActionBarLayout.ActionBa
} }
} }
private static final int PLAY_SERVICES_REQUEST_CHECK_SETTINGS = 140;
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
ApplicationLoader.postInitApplication(); ApplicationLoader.postInitApplication();
AppCenter.start(getApplication(), "033a70ca-ea8d-4c2f-8c2c-b37f1b47f766", Analytics.class);
AndroidUtilities.checkDisplaySize(this, getResources().getConfiguration()); AndroidUtilities.checkDisplaySize(this, getResources().getConfiguration());
currentAccount = UserConfig.selectedAccount; currentAccount = UserConfig.selectedAccount;
if (!UserConfig.getInstance(currentAccount).isClientActivated()) { if (!UserConfig.getInstance(currentAccount).isClientActivated()) {
@ -2812,26 +2805,22 @@ public class LaunchActivity extends Activity implements ActionBarLayout.ActionBa
UserConfig.getInstance(currentAccount).saveConfig(false); UserConfig.getInstance(currentAccount).saveConfig(false);
} }
super.onActivityResult(requestCode, resultCode, data); super.onActivityResult(requestCode, resultCode, data);
if (requestCode == PLAY_SERVICES_REQUEST_CHECK_SETTINGS) { ThemeEditorView editorView = ThemeEditorView.getInstance();
LocationController.getInstance(currentAccount).startFusedLocationRequest(resultCode == Activity.RESULT_OK); if (editorView != null) {
} else { editorView.onActivityResult(requestCode, resultCode, data);
ThemeEditorView editorView = ThemeEditorView.getInstance(); }
if (editorView != null) { if (actionBarLayout.fragmentsStack.size() != 0) {
editorView.onActivityResult(requestCode, resultCode, data); BaseFragment fragment = actionBarLayout.fragmentsStack.get(actionBarLayout.fragmentsStack.size() - 1);
} fragment.onActivityResultFragment(requestCode, resultCode, data);
if (actionBarLayout.fragmentsStack.size() != 0) { }
BaseFragment fragment = actionBarLayout.fragmentsStack.get(actionBarLayout.fragmentsStack.size() - 1); if (AndroidUtilities.isTablet()) {
if (rightActionBarLayout.fragmentsStack.size() != 0) {
BaseFragment fragment = rightActionBarLayout.fragmentsStack.get(rightActionBarLayout.fragmentsStack.size() - 1);
fragment.onActivityResultFragment(requestCode, resultCode, data); fragment.onActivityResultFragment(requestCode, resultCode, data);
} }
if (AndroidUtilities.isTablet()) { if (layersActionBarLayout.fragmentsStack.size() != 0) {
if (rightActionBarLayout.fragmentsStack.size() != 0) { BaseFragment fragment = layersActionBarLayout.fragmentsStack.get(layersActionBarLayout.fragmentsStack.size() - 1);
BaseFragment fragment = rightActionBarLayout.fragmentsStack.get(rightActionBarLayout.fragmentsStack.size() - 1); fragment.onActivityResultFragment(requestCode, resultCode, data);
fragment.onActivityResultFragment(requestCode, resultCode, data);
}
if (layersActionBarLayout.fragmentsStack.size() != 0) {
BaseFragment fragment = layersActionBarLayout.fragmentsStack.get(layersActionBarLayout.fragmentsStack.size() - 1);
fragment.onActivityResultFragment(requestCode, resultCode, data);
}
} }
} }
} }
@ -3307,13 +3296,6 @@ public class LaunchActivity extends Activity implements ActionBarLayout.ActionBa
} }
} }
} }
} else if (id == NotificationCenter.needShowPlayServicesAlert) {
try {
final Status status = (Status) args[0];
status.startResolutionForResult(this, PLAY_SERVICES_REQUEST_CHECK_SETTINGS);
} catch (Throwable ignore) {
}
} else if (id == NotificationCenter.fileDidLoad) { } else if (id == NotificationCenter.fileDidLoad) {
if (loadingThemeFileName != null) { if (loadingThemeFileName != null) {
String path = (String) args[0]; String path = (String) args[0];