Merge "Add NetworkStackPermissionStub definitions"
This commit is contained in:
@@ -3196,6 +3196,10 @@ package android.net {
|
|||||||
field public static final String EXTRA_PACKAGE_NAME = "packageName";
|
field public static final String EXTRA_PACKAGE_NAME = "packageName";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class NetworkStack {
|
||||||
|
field public static final String PERMISSION_MAINLINE_NETWORK_STACK = "android.permission.MAINLINE_NETWORK_STACK";
|
||||||
|
}
|
||||||
|
|
||||||
public final class RouteInfo implements android.os.Parcelable {
|
public final class RouteInfo implements android.os.Parcelable {
|
||||||
ctor public RouteInfo(android.net.IpPrefix, java.net.InetAddress, String, int);
|
ctor public RouteInfo(android.net.IpPrefix, java.net.InetAddress, String, int);
|
||||||
method public int getType();
|
method public int getType();
|
||||||
|
|||||||
@@ -669,6 +669,10 @@ package android.net {
|
|||||||
method public boolean satisfiedByNetworkCapabilities(android.net.NetworkCapabilities);
|
method public boolean satisfiedByNetworkCapabilities(android.net.NetworkCapabilities);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class NetworkStack {
|
||||||
|
field public static final String PERMISSION_MAINLINE_NETWORK_STACK = "android.permission.MAINLINE_NETWORK_STACK";
|
||||||
|
}
|
||||||
|
|
||||||
public final class RouteInfo implements android.os.Parcelable {
|
public final class RouteInfo implements android.os.Parcelable {
|
||||||
ctor public RouteInfo(android.net.IpPrefix, java.net.InetAddress, String, int);
|
ctor public RouteInfo(android.net.IpPrefix, java.net.InetAddress, String, int);
|
||||||
method public int getType();
|
method public int getType();
|
||||||
|
|||||||
@@ -20,7 +20,9 @@ import static android.os.IServiceManager.DUMP_FLAG_PRIORITY_NORMAL;
|
|||||||
|
|
||||||
import android.annotation.NonNull;
|
import android.annotation.NonNull;
|
||||||
import android.annotation.Nullable;
|
import android.annotation.Nullable;
|
||||||
|
import android.annotation.SystemApi;
|
||||||
import android.annotation.SystemService;
|
import android.annotation.SystemService;
|
||||||
|
import android.annotation.TestApi;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
@@ -46,9 +48,22 @@ import java.util.ArrayList;
|
|||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
@SystemService(Context.NETWORK_STACK_SERVICE)
|
@SystemService(Context.NETWORK_STACK_SERVICE)
|
||||||
|
@SystemApi
|
||||||
|
@TestApi
|
||||||
public class NetworkStack {
|
public class NetworkStack {
|
||||||
private static final String TAG = NetworkStack.class.getSimpleName();
|
private static final String TAG = NetworkStack.class.getSimpleName();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Permission granted only to the NetworkStack APK, defined in NetworkStackStub with signature
|
||||||
|
* protection level.
|
||||||
|
* @hide
|
||||||
|
*/
|
||||||
|
@SystemApi
|
||||||
|
@TestApi
|
||||||
|
public static final String PERMISSION_MAINLINE_NETWORK_STACK =
|
||||||
|
"android.permission.MAINLINE_NETWORK_STACK";
|
||||||
|
|
||||||
|
/** @hide */
|
||||||
public static final String NETWORKSTACK_PACKAGE_NAME = "com.android.mainline.networkstack";
|
public static final String NETWORKSTACK_PACKAGE_NAME = "com.android.mainline.networkstack";
|
||||||
|
|
||||||
private static final int NETWORKSTACK_TIMEOUT_MS = 10_000;
|
private static final int NETWORKSTACK_TIMEOUT_MS = 10_000;
|
||||||
@@ -66,12 +81,14 @@ public class NetworkStack {
|
|||||||
void onNetworkStackConnected(INetworkStackConnector connector);
|
void onNetworkStackConnected(INetworkStackConnector connector);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @hide */
|
||||||
public NetworkStack() { }
|
public NetworkStack() { }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a DHCP server according to the specified parameters.
|
* Create a DHCP server according to the specified parameters.
|
||||||
*
|
*
|
||||||
* <p>The server will be returned asynchronously through the provided callbacks.
|
* <p>The server will be returned asynchronously through the provided callbacks.
|
||||||
|
* @hide
|
||||||
*/
|
*/
|
||||||
public void makeDhcpServer(final String ifName, final DhcpServingParamsParcel params,
|
public void makeDhcpServer(final String ifName, final DhcpServingParamsParcel params,
|
||||||
final IDhcpServerCallbacks cb) {
|
final IDhcpServerCallbacks cb) {
|
||||||
@@ -88,6 +105,7 @@ public class NetworkStack {
|
|||||||
* Create an IpClient on the specified interface.
|
* Create an IpClient on the specified interface.
|
||||||
*
|
*
|
||||||
* <p>The IpClient will be returned asynchronously through the provided callbacks.
|
* <p>The IpClient will be returned asynchronously through the provided callbacks.
|
||||||
|
* @hide
|
||||||
*/
|
*/
|
||||||
public void makeIpClient(String ifName, IIpClientCallbacks cb) {
|
public void makeIpClient(String ifName, IIpClientCallbacks cb) {
|
||||||
requestConnector(connector -> {
|
requestConnector(connector -> {
|
||||||
@@ -103,6 +121,7 @@ public class NetworkStack {
|
|||||||
* Create a NetworkMonitor.
|
* Create a NetworkMonitor.
|
||||||
*
|
*
|
||||||
* <p>The INetworkMonitor will be returned asynchronously through the provided callbacks.
|
* <p>The INetworkMonitor will be returned asynchronously through the provided callbacks.
|
||||||
|
* @hide
|
||||||
*/
|
*/
|
||||||
public void makeNetworkMonitor(
|
public void makeNetworkMonitor(
|
||||||
NetworkParcelable network, String name, INetworkMonitorCallbacks cb) {
|
NetworkParcelable network, String name, INetworkMonitorCallbacks cb) {
|
||||||
@@ -153,6 +172,7 @@ public class NetworkStack {
|
|||||||
* the system server on devices that do not support the network stack module. The network stack
|
* the system server on devices that do not support the network stack module. The network stack
|
||||||
* connector will then be delivered asynchronously to clients that requested it before it was
|
* connector will then be delivered asynchronously to clients that requested it before it was
|
||||||
* started.
|
* started.
|
||||||
|
* @hide
|
||||||
*/
|
*/
|
||||||
public void start(Context context) {
|
public void start(Context context) {
|
||||||
mNetworkStackStartRequested = true;
|
mNetworkStackStartRequested = true;
|
||||||
|
|||||||
@@ -41,4 +41,5 @@ android_app {
|
|||||||
"NetworkStackLib"
|
"NetworkStackLib"
|
||||||
],
|
],
|
||||||
manifest: "AndroidManifest.xml",
|
manifest: "AndroidManifest.xml",
|
||||||
|
required: ["NetworkStackPermissionStub"],
|
||||||
}
|
}
|
||||||
@@ -25,6 +25,8 @@
|
|||||||
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
|
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
|
||||||
<uses-permission android:name="android.permission.CONNECTIVITY_INTERNAL" />
|
<uses-permission android:name="android.permission.CONNECTIVITY_INTERNAL" />
|
||||||
<uses-permission android:name="android.permission.NETWORK_SETTINGS" />
|
<uses-permission android:name="android.permission.NETWORK_SETTINGS" />
|
||||||
|
<!-- Signature permission defined in NetworkStackStub -->
|
||||||
|
<uses-permission android:name="android.permission.MAINLINE_NETWORK_STACK" />
|
||||||
<!-- Launch captive portal app as specific user -->
|
<!-- Launch captive portal app as specific user -->
|
||||||
<uses-permission android:name="android.permission.INTERACT_ACROSS_USERS_FULL" />
|
<uses-permission android:name="android.permission.INTERACT_ACROSS_USERS_FULL" />
|
||||||
<uses-permission android:name="android.permission.NETWORK_STACK" />
|
<uses-permission android:name="android.permission.NETWORK_STACK" />
|
||||||
|
|||||||
27
packages/NetworkStackPermissionStub/Android.bp
Normal file
27
packages/NetworkStackPermissionStub/Android.bp
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
//
|
||||||
|
// Copyright (C) 2019 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.
|
||||||
|
//
|
||||||
|
|
||||||
|
// Stub APK to define permissions for NetworkStack
|
||||||
|
android_app {
|
||||||
|
name: "NetworkStackPermissionStub",
|
||||||
|
// TODO: mark app as hasCode=false in manifest once soong stops complaining about apps without
|
||||||
|
// a classes.dex.
|
||||||
|
srcs: ["src/**/*.java"],
|
||||||
|
platform_apis: true,
|
||||||
|
certificate: "platform",
|
||||||
|
privileged: true,
|
||||||
|
manifest: "AndroidManifest.xml",
|
||||||
|
}
|
||||||
36
packages/NetworkStackPermissionStub/AndroidManifest.xml
Normal file
36
packages/NetworkStackPermissionStub/AndroidManifest.xml
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2019 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.
|
||||||
|
*/
|
||||||
|
-->
|
||||||
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
package="com.android.mainline.networkstack.permissionstub">
|
||||||
|
<!--
|
||||||
|
This package only exists to define the below permissions, and enforce that they are only
|
||||||
|
granted to apps sharing the same signature.
|
||||||
|
Permissions defined here are intended to be used only by the NetworkStack: both
|
||||||
|
NetworkStack and this stub APK are to be signed with a dedicated certificate to ensure
|
||||||
|
that, with the below permissions being signature permissions.
|
||||||
|
|
||||||
|
This APK *must* be installed, even if the NetworkStack app is not installed, because otherwise,
|
||||||
|
any application will be able to define this permission and the system will give that application
|
||||||
|
full access to the network stack.
|
||||||
|
-->
|
||||||
|
<permission android:name="android.permission.MAINLINE_NETWORK_STACK"
|
||||||
|
android:protectionLevel="signature"/>
|
||||||
|
|
||||||
|
<application android:name="com.android.server.NetworkStackPermissionStub"/>
|
||||||
|
</manifest>
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2019 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;
|
||||||
|
|
||||||
|
import android.app.Application;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Empty application for NetworkStackStub that only exists because soong builds complain if APKs
|
||||||
|
* have no source file.
|
||||||
|
*/
|
||||||
|
public class NetworkStackPermissionStub extends Application {
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user