blob: 218bb05e21a2b189c30b6e01b2daf108898828f0 [file] [log] [blame]
Lorenzo Colittie4d626e2016-02-02 17:19:04 +09001/**
2 * Copyright (c) 2016, 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#ifndef _NETD_NATIVE_SERVICE_H_
18#define _NETD_NATIVE_SERVICE_H_
19
Lorenzo Colitti89faa342016-02-26 11:38:47 +090020#include <vector>
21
Lorenzo Colittie4d626e2016-02-02 17:19:04 +090022#include <binder/BinderService.h>
23
24#include "android/net/BnNetd.h"
Robin Lee9f9aae92016-03-30 18:33:07 +010025#include "android/net/UidRange.h"
Lorenzo Colittie4d626e2016-02-02 17:19:04 +090026
27namespace android {
28namespace net {
29
30class NetdNativeService : public BinderService<NetdNativeService>, public BnNetd {
31 public:
Lorenzo Colittie4851de2016-03-17 13:23:28 +090032 static status_t start();
Lorenzo Colittic2c7b752016-02-23 22:25:11 +090033 static char const* getServiceName() { return "netd"; }
Erik Kline2d3a1632016-03-15 16:33:48 +090034 virtual status_t dump(int fd, const Vector<String16> &args) override;
35
Lorenzo Colittie4d626e2016-02-02 17:19:04 +090036 binder::Status isAlive(bool *alive) override;
Lorenzo Colitti89faa342016-02-26 11:38:47 +090037 binder::Status firewallReplaceUidChain(
Erik Kline2d3a1632016-03-15 16:33:48 +090038 const String16& chainName, bool isWhitelist,
39 const std::vector<int32_t>& uids, bool *ret) override;
Lorenzo Colittidedd2712016-03-22 12:36:29 +090040 binder::Status bandwidthEnableDataSaver(bool enable, bool *ret) override;
Robin Leeb8087362016-03-30 18:43:08 +010041 binder::Status networkRejectNonSecureVpn(bool enable, const std::vector<UidRange>& uids)
42 override;
Lorenzo Colitti563d98b2016-04-24 13:13:14 +090043 binder::Status socketDestroy(const std::vector<UidRange>& uids,
44 const std::vector<int32_t>& skipUids) override;
Pierre Imaibeedec32016-04-13 06:44:51 +090045 binder::Status setResolverConfiguration(int32_t netId, const std::vector<std::string>& servers,
46 const std::vector<std::string>& domains, const std::vector<int32_t>& params) override;
47 binder::Status getResolverInfo(int32_t netId, std::vector<std::string>* servers,
48 std::vector<std::string>* domains, std::vector<int32_t>* params,
49 std::vector<int32_t>* stats) override;
Ben Schwartze7601812017-04-28 16:38:29 -040050 binder::Status addPrivateDnsServer(const std::string& server, int32_t port,
Ben Schwartz1691bc42017-08-16 12:53:09 -040051 const std::string& name,
Ben Schwartze7601812017-04-28 16:38:29 -040052 const std::string& fingerprintAlgorithm,
53 const std::vector<std::string>& fingerprints) override;
54 binder::Status removePrivateDnsServer(const std::string& server) override;
Erik Klinef48e4dd2016-07-18 04:02:07 +090055
Joel Scherpelzde937962017-06-01 13:20:21 +090056 binder::Status setIPv6AddrGenMode(const std::string& ifName, int32_t mode) override;
57
Joel Scherpelz08b84cd2017-05-22 13:11:54 +090058 // NFLOG-related commands
59 binder::Status wakeupAddInterface(const std::string& ifName, const std::string& prefix,
60 int32_t mark, int32_t mask) override;
61
62 binder::Status wakeupDelInterface(const std::string& ifName, const std::string& prefix,
63 int32_t mark, int32_t mask) override;
64
Erik Klinef48e4dd2016-07-18 04:02:07 +090065 // Tethering-related commands.
66 binder::Status tetherApplyDnsInterfaces(bool *ret) override;
Erik Kline53c20882016-08-02 15:22:53 +090067
68 binder::Status interfaceAddAddress(const std::string &ifName,
69 const std::string &addrString, int prefixLength) override;
70 binder::Status interfaceDelAddress(const std::string &ifName,
71 const std::string &addrString, int prefixLength) override;
Erik Kline55b06f82016-07-04 09:57:18 +090072
73 binder::Status setProcSysNet(
74 int32_t family, int32_t which, const std::string &ifname, const std::string &parameter,
75 const std::string &value) override;
Robin Lee2cf56172016-09-13 18:55:42 +090076
77 // Metrics reporting level set / get (internal use only).
78 binder::Status getMetricsReportingLevel(int *reportingLevel) override;
79 binder::Status setMetricsReportingLevel(const int reportingLevel) override;
Nathan Harold1a371532017-01-30 12:30:48 -080080
81 binder::Status ipSecAllocateSpi(
82 int32_t transformId,
83 int32_t direction,
84 const std::string& localAddress,
85 const std::string& remoteAddress,
86 int32_t inSpi,
87 int32_t* outSpi);
88
89 binder::Status ipSecAddSecurityAssociation(
90 int32_t transformId,
91 int32_t mode,
92 int32_t direction,
93 const std::string& localAddress,
94 const std::string& remoteAddress,
95 int64_t underlyingNetworkHandle,
96 int32_t spi,
97 const std::string& authAlgo,
98 const std::vector<uint8_t>& authKey,
99 int32_t authTruncBits,
100 const std::string& cryptAlgo,
101 const std::vector<uint8_t>& cryptKey,
102 int32_t cryptTruncBits,
103 int32_t encapType,
104 int32_t encapLocalPort,
ludiec836052017-05-20 14:17:05 -0700105 int32_t encapRemotePort);
Nathan Harold1a371532017-01-30 12:30:48 -0800106
107 binder::Status ipSecDeleteSecurityAssociation(
108 int32_t transformId,
109 int32_t direction,
110 const std::string& localAddress,
111 const std::string& remoteAddress,
112 int32_t spi);
113
114 binder::Status ipSecApplyTransportModeTransform(
115 const android::base::unique_fd& socket,
116 int32_t transformId,
117 int32_t direction,
118 const std::string& localAddress,
119 const std::string& remoteAddress,
120 int32_t spi);
121
122 binder::Status ipSecRemoveTransportModeTransform(
123 const android::base::unique_fd& socket);
Lorenzo Colittie4d626e2016-02-02 17:19:04 +0900124};
125
126} // namespace net
127} // namespace android
128
129#endif // _NETD_NATIVE_SERVICE_H_