/** * 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. */ #ifndef _NETD_NATIVE_SERVICE_H_ #define _NETD_NATIVE_SERVICE_H_ #include #include #include "android/net/BnNetd.h" #include "android/net/UidRange.h" namespace android { namespace net { class NetdNativeService : public BinderService, public BnNetd { public: static status_t start(); static char const* getServiceName() { return "netd"; } virtual status_t dump(int fd, const Vector &args) override; binder::Status isAlive(bool *alive) override; binder::Status firewallReplaceUidChain( const String16& chainName, bool isWhitelist, const std::vector& uids, bool *ret) override; binder::Status bandwidthEnableDataSaver(bool enable, bool *ret) override; binder::Status networkRejectNonSecureVpn(bool enable, const std::vector& uids) override; binder::Status socketDestroy(const std::vector& uids, const std::vector& skipUids) override; binder::Status setResolverConfiguration(int32_t netId, const std::vector& servers, const std::vector& domains, const std::vector& params) override; binder::Status getResolverInfo(int32_t netId, std::vector* servers, std::vector* domains, std::vector* params, std::vector* stats) override; binder::Status addPrivateDnsServer(const std::string& server, int32_t port, const std::string& fingerprintAlgorithm, const std::vector& fingerprints) override; binder::Status removePrivateDnsServer(const std::string& server) override; binder::Status setIPv6AddrGenMode(const std::string& ifName, int32_t mode) override; // NFLOG-related commands binder::Status wakeupAddInterface(const std::string& ifName, const std::string& prefix, int32_t mark, int32_t mask) override; binder::Status wakeupDelInterface(const std::string& ifName, const std::string& prefix, int32_t mark, int32_t mask) override; // Tethering-related commands. binder::Status tetherApplyDnsInterfaces(bool *ret) override; binder::Status interfaceAddAddress(const std::string &ifName, const std::string &addrString, int prefixLength) override; binder::Status interfaceDelAddress(const std::string &ifName, const std::string &addrString, int prefixLength) override; binder::Status setProcSysNet( int32_t family, int32_t which, const std::string &ifname, const std::string ¶meter, const std::string &value) override; // Metrics reporting level set / get (internal use only). binder::Status getMetricsReportingLevel(int *reportingLevel) override; binder::Status setMetricsReportingLevel(const int reportingLevel) override; binder::Status ipSecAllocateSpi( int32_t transformId, int32_t direction, const std::string& localAddress, const std::string& remoteAddress, int32_t inSpi, int32_t* outSpi); binder::Status ipSecAddSecurityAssociation( int32_t transformId, int32_t mode, int32_t direction, const std::string& localAddress, const std::string& remoteAddress, int64_t underlyingNetworkHandle, int32_t spi, const std::string& authAlgo, const std::vector& authKey, int32_t authTruncBits, const std::string& cryptAlgo, const std::vector& cryptKey, int32_t cryptTruncBits, int32_t encapType, int32_t encapLocalPort, int32_t encapRemotePort); binder::Status ipSecDeleteSecurityAssociation( int32_t transformId, int32_t direction, const std::string& localAddress, const std::string& remoteAddress, int32_t spi); binder::Status ipSecApplyTransportModeTransform( const android::base::unique_fd& socket, int32_t transformId, int32_t direction, const std::string& localAddress, const std::string& remoteAddress, int32_t spi); binder::Status ipSecRemoveTransportModeTransform( const android::base::unique_fd& socket); }; } // namespace net } // namespace android #endif // _NETD_NATIVE_SERVICE_H_