Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f1da90fe authored by Felipe Leme's avatar Felipe Leme
Browse files

Listen to ACTION_UID_REMOVED only. DO NOT MERGE.

NMPS was listening to both ACTION_UID_REMOVED and
ACTION_PACKAGE_REMOVED, which not only was redundant but would also
cause problems when a package with shared UIDs was removed.

Fixes: 31375684

Change-Id: Iec006dbbec0e6298f1e568cbf81ed3672f61b7d2
(cherry picked from commit fdebbea4)
parent 845096ff
Loading
Loading
Loading
Loading
+1 −18
Original line number Original line Diff line number Diff line
@@ -166,7 +166,6 @@ import android.util.Xml;
import com.android.internal.R;
import com.android.internal.R;
import com.android.internal.annotations.GuardedBy;
import com.android.internal.annotations.GuardedBy;
import com.android.internal.annotations.VisibleForTesting;
import com.android.internal.annotations.VisibleForTesting;
import com.android.internal.content.PackageMonitor;
import com.android.internal.util.ArrayUtils;
import com.android.internal.util.ArrayUtils;
import com.android.internal.util.FastXmlSerializer;
import com.android.internal.util.FastXmlSerializer;
import com.android.internal.util.IndentingPrintWriter;
import com.android.internal.util.IndentingPrintWriter;
@@ -407,7 +406,6 @@ public class NetworkPolicyManagerService extends INetworkPolicyManager.Stub {


    private final AppOpsManager mAppOps;
    private final AppOpsManager mAppOps;


    private final MyPackageMonitor mPackageMonitor;
    private final IPackageManager mIPm;
    private final IPackageManager mIPm;




@@ -449,8 +447,6 @@ public class NetworkPolicyManagerService extends INetworkPolicyManager.Stub {


        mAppOps = context.getSystemService(AppOpsManager.class);
        mAppOps = context.getSystemService(AppOpsManager.class);


        mPackageMonitor = new MyPackageMonitor();

        // Expose private service for system components to use.
        // Expose private service for system components to use.
        LocalServices.addService(NetworkPolicyManagerInternal.class,
        LocalServices.addService(NetworkPolicyManagerInternal.class,
                new NetworkPolicyManagerInternalImpl());
                new NetworkPolicyManagerInternalImpl());
@@ -582,8 +578,6 @@ public class NetworkPolicyManagerService extends INetworkPolicyManager.Stub {


            mUsageStats = LocalServices.getService(UsageStatsManagerInternal.class);
            mUsageStats = LocalServices.getService(UsageStatsManagerInternal.class);


            mPackageMonitor.register(mContext, mHandler.getLooper(), UserHandle.ALL, true);

            synchronized (mUidRulesFirstLock) {
            synchronized (mUidRulesFirstLock) {
                synchronized (mNetworkPoliciesSecondLock) {
                synchronized (mNetworkPoliciesSecondLock) {
                    updatePowerSaveWhitelistUL();
                    updatePowerSaveWhitelistUL();
@@ -765,6 +759,7 @@ public class NetworkPolicyManagerService extends INetworkPolicyManager.Stub {
            if (LOGV) Slog.v(TAG, "ACTION_UID_REMOVED for uid=" + uid);
            if (LOGV) Slog.v(TAG, "ACTION_UID_REMOVED for uid=" + uid);
            synchronized (mUidRulesFirstLock) {
            synchronized (mUidRulesFirstLock) {
                mUidPolicy.delete(uid);
                mUidPolicy.delete(uid);
                removeRestrictBackgroundWhitelistedUidUL(uid, true, true);
                updateRestrictionRulesForUidUL(uid);
                updateRestrictionRulesForUidUL(uid);
                synchronized (mNetworkPoliciesSecondLock) {
                synchronized (mNetworkPoliciesSecondLock) {
                    writePolicyAL();
                    writePolicyAL();
@@ -3622,18 +3617,6 @@ public class NetworkPolicyManagerService extends INetworkPolicyManager.Stub {
        }
        }
    }
    }


    private class MyPackageMonitor extends PackageMonitor {

        @Override
        public void onPackageRemoved(String packageName, int uid) {
            if (LOGV) Slog.v(TAG, "onPackageRemoved: " + packageName + " ->" + uid);
            synchronized (mUidRulesFirstLock) {
                removeRestrictBackgroundWhitelistedUidUL(uid, true, true);
                updateRestrictionRulesForUidUL(uid);
            }
        }
    }

    private class NetworkPolicyManagerInternalImpl extends NetworkPolicyManagerInternal {
    private class NetworkPolicyManagerInternalImpl extends NetworkPolicyManagerInternal {


        @Override
        @Override