1 /*
2  * Copyright (C) 2011 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package android.net;
18 
19 import android.net.INetworkPolicyListener;
20 import android.net.NetworkPolicy;
21 import android.net.NetworkQuotaInfo;
22 import android.net.NetworkState;
23 import android.net.NetworkTemplate;
24 
25 /**
26  * Interface that creates and modifies network policy rules.
27  *
28  * {@hide}
29  */
30 interface INetworkPolicyManager {
31 
32     /** Control UID policies. */
setUidPolicy(int uid, int policy)33     void setUidPolicy(int uid, int policy);
addUidPolicy(int uid, int policy)34     void addUidPolicy(int uid, int policy);
removeUidPolicy(int uid, int policy)35     void removeUidPolicy(int uid, int policy);
getUidPolicy(int uid)36     int getUidPolicy(int uid);
getUidsWithPolicy(int policy)37     int[] getUidsWithPolicy(int policy);
38 
isUidForeground(int uid)39     boolean isUidForeground(int uid);
40 
registerListener(INetworkPolicyListener listener)41     void registerListener(INetworkPolicyListener listener);
unregisterListener(INetworkPolicyListener listener)42     void unregisterListener(INetworkPolicyListener listener);
43 
44     /** Control network policies atomically. */
setNetworkPolicies(in NetworkPolicy[] policies)45     void setNetworkPolicies(in NetworkPolicy[] policies);
getNetworkPolicies(String callingPackage)46     NetworkPolicy[] getNetworkPolicies(String callingPackage);
47 
48     /** Snooze limit on policy matching given template. */
snoozeLimit(in NetworkTemplate template)49     void snoozeLimit(in NetworkTemplate template);
50 
51     /** Control if background data is restricted system-wide. */
setRestrictBackground(boolean restrictBackground)52     void setRestrictBackground(boolean restrictBackground);
getRestrictBackground()53     boolean getRestrictBackground();
54 
55     /** Callback used to change internal state on tethering */
onTetheringChanged(String iface, boolean tethering)56     void onTetheringChanged(String iface, boolean tethering);
57 
58     /** Gets the restrict background status based on the caller's UID:
59         1 - disabled
60         2 - whitelisted
61         3 - enabled
62     */
getRestrictBackgroundByCaller()63     int getRestrictBackgroundByCaller();
64 
setDeviceIdleMode(boolean enabled)65     void setDeviceIdleMode(boolean enabled);
66 
getNetworkQuotaInfo(in NetworkState state)67     NetworkQuotaInfo getNetworkQuotaInfo(in NetworkState state);
isNetworkMetered(in NetworkState state)68     boolean isNetworkMetered(in NetworkState state);
69 
factoryReset(String subscriber)70     void factoryReset(String subscriber);
71 }
72