/* * Copyright (C) 2016 The Android Open Source Project * * 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 com.android.server.net; import android.net.Network; import android.net.NetworkTemplate; import android.telephony.SubscriptionPlan; import java.util.Set; /** * Network Policy Manager local system service interface. * * @hide Only for use within the system server. */ public abstract class NetworkPolicyManagerInternal { /** * Resets all policies associated with a given user. */ public abstract void resetUserState(int userId); /** * @return true if the given uid is restricted from doing networking on metered networks. */ public abstract boolean isUidRestrictedOnMeteredNetworks(int uid); /** * @return true if networking is blocked on the given interface for the given uid according * to current networking policies. */ public abstract boolean isUidNetworkingBlocked(int uid, String ifname); /** * Informs that an appId has been added or removed from the temp-powersave-whitelist so that * that network rules for that appId can be updated. * * @param appId The appId which has been updated in the whitelist. * @param added Denotes whether the {@param appId} has been added or removed from the whitelist. */ public abstract void onTempPowerSaveWhitelistChange(int appId, boolean added); /** * Return the active {@link SubscriptionPlan} for the given network. */ public abstract SubscriptionPlan getSubscriptionPlan(Network network); /** * Return the active {@link SubscriptionPlan} for the given template. */ public abstract SubscriptionPlan getSubscriptionPlan(NetworkTemplate template); public static final int QUOTA_TYPE_JOBS = 1; public static final int QUOTA_TYPE_MULTIPATH = 2; /** * Return the daily quota (in bytes) that can be opportunistically used on * the given network to improve the end user experience. It's called * "opportunistic" because it's traffic that would typically not use the * given network. */ public abstract long getSubscriptionOpportunisticQuota(Network network, int quotaType); /** * Informs that admin data is loaded and available. */ public abstract void onAdminDataAvailable(); /** * Sets a list of packages which are restricted by admin from accessing metered data. * * @param packageNames the list of restricted packages. * @param userId the userId in which {@param packagesNames} are restricted. */ public abstract void setMeteredRestrictedPackages( Set packageNames, int userId); /** * Similar to {@link #setMeteredRestrictedPackages(Set, int)} but updates the restricted * packages list asynchronously. */ public abstract void setMeteredRestrictedPackagesAsync( Set packageNames, int userId); }