diff options
Diffstat (limited to 'core')
-rw-r--r-- | core/java/android/net/INetworkPolicyManager.aidl | 4 | ||||
-rw-r--r-- | core/java/android/net/INetworkStatsService.aidl | 2 | ||||
-rw-r--r-- | core/java/android/net/NetworkPolicy.aidl | 19 | ||||
-rw-r--r-- | core/java/android/net/NetworkPolicy.java | 81 | ||||
-rw-r--r-- | core/java/android/net/NetworkPolicyManager.java | 17 | ||||
-rw-r--r-- | core/res/AndroidManifest.xml | 13 | ||||
-rwxr-xr-x | core/res/res/values/strings.xml | 10 |
7 files changed, 145 insertions, 1 deletions
diff --git a/core/java/android/net/INetworkPolicyManager.aidl b/core/java/android/net/INetworkPolicyManager.aidl index c1f3530..c9238eb 100644 --- a/core/java/android/net/INetworkPolicyManager.aidl +++ b/core/java/android/net/INetworkPolicyManager.aidl @@ -17,6 +17,7 @@ package android.net; import android.net.INetworkPolicyListener; +import android.net.NetworkPolicy; /** * Interface that creates and modifies network policy rules. @@ -33,6 +34,7 @@ interface INetworkPolicyManager { void registerListener(INetworkPolicyListener listener); void unregisterListener(INetworkPolicyListener listener); - // TODO: build API to surface stats details for settings UI + void setNetworkPolicy(int networkType, String subscriberId, in NetworkPolicy policy); + NetworkPolicy getNetworkPolicy(int networkType, String subscriberId); } diff --git a/core/java/android/net/INetworkStatsService.aidl b/core/java/android/net/INetworkStatsService.aidl index d05c9d3..288112a 100644 --- a/core/java/android/net/INetworkStatsService.aidl +++ b/core/java/android/net/INetworkStatsService.aidl @@ -27,6 +27,8 @@ interface INetworkStatsService { /** Return historical stats for specific UID traffic that matches template. */ NetworkStatsHistory getHistoryForUid(int uid, int networkTemplate); + /** Return usage summary for traffic that matches template. */ + NetworkStats getSummaryForNetwork(long start, long end, int networkTemplate, String subscriberId); /** Return usage summary per UID for traffic that matches template. */ NetworkStats getSummaryForAllUid(long start, long end, int networkTemplate); diff --git a/core/java/android/net/NetworkPolicy.aidl b/core/java/android/net/NetworkPolicy.aidl new file mode 100644 index 0000000..dbabb06 --- /dev/null +++ b/core/java/android/net/NetworkPolicy.aidl @@ -0,0 +1,19 @@ +/** + * Copyright (c) 2011, 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 android.net; + +parcelable NetworkPolicy; diff --git a/core/java/android/net/NetworkPolicy.java b/core/java/android/net/NetworkPolicy.java new file mode 100644 index 0000000..b9909c3 --- /dev/null +++ b/core/java/android/net/NetworkPolicy.java @@ -0,0 +1,81 @@ +/* + * Copyright (C) 2011 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 android.net; + +import android.os.Parcel; +import android.os.Parcelable; + +/** + * Policy for a specific network, including usage cycle and limits to be + * enforced. + * + * @hide + */ +public class NetworkPolicy implements Parcelable, Comparable<NetworkPolicy> { + public final int cycleDay; + public final long warningBytes; + public final long limitBytes; + + public NetworkPolicy(int cycleDay, long warningBytes, long limitBytes) { + this.cycleDay = cycleDay; + this.warningBytes = warningBytes; + this.limitBytes = limitBytes; + } + + public NetworkPolicy(Parcel in) { + cycleDay = in.readInt(); + warningBytes = in.readLong(); + limitBytes = in.readLong(); + } + + /** {@inheritDoc} */ + public void writeToParcel(Parcel dest, int flags) { + dest.writeInt(cycleDay); + dest.writeLong(warningBytes); + dest.writeLong(limitBytes); + } + + /** {@inheritDoc} */ + public int describeContents() { + return 0; + } + + /** {@inheritDoc} */ + public int compareTo(NetworkPolicy another) { + if (another == null || limitBytes < another.limitBytes) { + return -1; + } else { + return 1; + } + } + + @Override + public String toString() { + return "NetworkPolicy: cycleDay=" + cycleDay + ", warningBytes=" + warningBytes + + ", limitBytes=" + limitBytes; + } + + public static final Creator<NetworkPolicy> CREATOR = new Creator<NetworkPolicy>() { + public NetworkPolicy createFromParcel(Parcel in) { + return new NetworkPolicy(in); + } + + public NetworkPolicy[] newArray(int size) { + return new NetworkPolicy[size]; + } + }; +} diff --git a/core/java/android/net/NetworkPolicyManager.java b/core/java/android/net/NetworkPolicyManager.java index dd7c1b0..0f4dc9a 100644 --- a/core/java/android/net/NetworkPolicyManager.java +++ b/core/java/android/net/NetworkPolicyManager.java @@ -51,6 +51,23 @@ public class NetworkPolicyManager { return (NetworkPolicyManager) context.getSystemService(Context.NETWORK_POLICY_SERVICE); } + /** {@hide} */ + public void setNetworkPolicy(int networkType, String subscriberId, NetworkPolicy policy) { + try { + mService.setNetworkPolicy(networkType, subscriberId, policy); + } catch (RemoteException e) { + } + } + + /** {@hide} */ + public NetworkPolicy getNetworkPolicy(int networkType, String subscriberId) { + try { + return mService.getNetworkPolicy(networkType, subscriberId); + } catch (RemoteException e) { + return null; + } + } + /** * Set policy flags for specific UID. * diff --git a/core/res/AndroidManifest.xml b/core/res/AndroidManifest.xml index b2606c1..a8aff37 100644 --- a/core/res/AndroidManifest.xml +++ b/core/res/AndroidManifest.xml @@ -1377,6 +1377,19 @@ <permission android:name="android.permission.CRYPT_KEEPER" android:protectionLevel="signatureOrSystem" /> + <!-- Allows an application to read historical network usage for + specific networks and applications. @hide --> + <permission android:name="android.permission.READ_NETWORK_USAGE_HISTORY" + android:label="@string/permlab_readNetworkUsageHistory" + android:description="@string/permdesc_readNetworkUsageHistory" + android:protectionLevel="signature" /> + + <!-- Allows an application to manage network policies (such as warning and disable + limits) and to define application-specific rules. @hide --> + <permission android:name="android.permission.MANAGE_NETWORK_POLICY" + android:label="@string/permlab_manageNetworkPolicy" + android:description="@string/permdesc_manageNetworkPolicy" + android:protectionLevel="signature" /> <!-- C2DM permission. @hide Used internally. diff --git a/core/res/res/values/strings.xml b/core/res/res/values/strings.xml index 3736157..b264b41 100755 --- a/core/res/res/values/strings.xml +++ b/core/res/res/values/strings.xml @@ -1431,6 +1431,16 @@ <!-- Description of an application permission, listed so the user can choose whether they want to allow the application to do this. --> <string name="permdesc_use_sip">Allows an application to use the SIP service to make/receive Internet calls.</string> + <!-- Title of an application permission, listed so the user can choose whether they want to allow the application to do this. --> + <string name="permlab_readNetworkUsageHistory">read historical network usage</string> + <!-- Description of an application permission, listed so the user can choose whether they want to allow the application to do this. --> + <string name="permdesc_readNetworkUsageHistory">Allows an application to read historical network usage for specific networks and applications.</string> + + <!-- Title of an application permission, listed so the user can choose whether they want to allow the application to do this. --> + <string name="permlab_manageNetworkPolicy">manage network policy</string> + <!-- Description of an application permission, listed so the user can choose whether they want to allow the application to do this. --> + <string name="permdesc_manageNetworkPolicy">Allows an application to manage network policies and define application-specific rules.</string> + <!-- Policy administration --> <!-- Title of policy access to limiting the user's password choices --> |