/** * 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 <vector> #include <binder/BinderService.h> #include "android/net/BnNetd.h" #include "android/net/UidRange.h" namespace android { namespace net { class NetdNativeService : public BinderService<NetdNativeService>, public BnNetd { public: static status_t start(); static char const* getServiceName() { return "netd"; } virtual status_t dump(int fd, const Vector<String16> &args) override; binder::Status isAlive(bool *alive) override; binder::Status firewallReplaceUidChain( const String16& chainName, bool isWhitelist, const std::vector<int32_t>& uids, bool *ret) override; binder::Status bandwidthEnableDataSaver(bool enable, bool *ret) override; binder::Status networkRejectNonSecureVpn(bool enable, const std::vector<UidRange>& uids) override; binder::Status socketDestroy(const std::vector<UidRange>& uids, const std::vector<int32_t>& skipUids) override; binder::Status setResolverConfiguration(int32_t netId, const std::vector<std::string>& servers, const std::vector<std::string>& domains, const std::vector<int32_t>& params) override; binder::Status getResolverInfo(int32_t netId, std::vector<std::string>* servers, std::vector<std::string>* domains, std::vector<int32_t>* params, std::vector<int32_t>* stats) 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<uint8_t>& authKey, int32_t authTruncBits, const std::string& cryptAlgo, const std::vector<uint8_t>& cryptKey, int32_t cryptTruncBits, int32_t encapType, int32_t encapLocalPort, int32_t encapRemotePort, int32_t* allocatedSpi); 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_