/**
* 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;
// Firewall commands.
binder::Status firewallReplaceUidChain(
const String16& chainName, bool isWhitelist,
const std::vector<int32_t>& uids, bool *ret) override;
// Bandwidth control commands.
binder::Status bandwidthEnableDataSaver(bool enable, bool *ret) override;
// Network and routing commands.
binder::Status networkCreatePhysical(int32_t netId, const std::string& permission)
override;
binder::Status networkCreateVpn(int32_t netId, bool hasDns, bool secure) override;
binder::Status networkDestroy(int32_t netId) override;
binder::Status networkAddInterface(int32_t netId, const std::string& iface) override;
binder::Status networkRemoveInterface(int32_t netId, const std::string& iface) override;
binder::Status networkAddUidRanges(int32_t netId, const std::vector<UidRange>& uids)
override;
binder::Status networkRemoveUidRanges(int32_t netId, const std::vector<UidRange>& uids)
override;
binder::Status networkRejectNonSecureVpn(bool enable, const std::vector<UidRange>& uids)
override;
// SOCK_DIAG commands.
binder::Status socketDestroy(const std::vector<UidRange>& uids,
const std::vector<int32_t>& skipUids) override;
// Resolver commands.
binder::Status setResolverConfiguration(int32_t netId, const std::vector<std::string>& servers,
const std::vector<std::string>& domains, const std::vector<int32_t>& params,
const std::string& tlsName,
const std::vector<std::string>& tlsServers,
const std::vector<std::string>& tlsFingerprints) 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;
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 tetherGetStats(android::os::PersistableBundle *ret) override;
// Interface-related commands.
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 ipSecSetEncapSocketOwner(const android::base::unique_fd& socket, int newUid);
binder::Status ipSecAllocateSpi(
int32_t transformId,
const std::string& localAddress,
const std::string& remoteAddress,
int32_t inSpi,
int32_t* outSpi);
binder::Status ipSecAddSecurityAssociation(
int32_t transformId,
int32_t mode,
const std::string& sourceAddress,
const std::string& destinationAddress,
int32_t underlyingNetId,
int32_t spi,
int32_t markValue,
int32_t markMask,
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,
const std::string& aeadAlgo,
const std::vector<uint8_t>& aeadKey,
int32_t aeadIcvBits,
int32_t encapType,
int32_t encapLocalPort,
int32_t encapRemotePort);
binder::Status ipSecDeleteSecurityAssociation(
int32_t transformId,
const std::string& sourceAddress,
const std::string& destinationAddress,
int32_t spi,
int32_t markValue,
int32_t markMask);
binder::Status ipSecApplyTransportModeTransform(
const android::base::unique_fd& socket,
int32_t transformId,
int32_t direction,
const std::string& sourceAddress,
const std::string& destinationAddress,
int32_t spi);
binder::Status ipSecRemoveTransportModeTransform(
const android::base::unique_fd& socket);
binder::Status ipSecAddSecurityPolicy(
int32_t transformId,
int32_t direction,
const std::string& sourceAddress,
const std::string& destinationAddress,
int32_t spi,
int32_t markValue,
int32_t markMask);
binder::Status ipSecUpdateSecurityPolicy(
int32_t transformId,
int32_t direction,
const std::string& sourceAddress,
const std::string& destinationAddress,
int32_t spi,
int32_t markValue,
int32_t markMask);
binder::Status ipSecDeleteSecurityPolicy(
int32_t transformId,
int32_t direction,
const std::string& sourceAddress,
const std::string& destinationAddress,
int32_t markValue,
int32_t markMask);
binder::Status trafficCheckBpfStatsEnable(bool* ret) override;
binder::Status addVirtualTunnelInterface(
const std::string& deviceName,
const std::string& localAddress,
const std::string& remoteAddress,
int32_t iKey,
int32_t oKey);
binder::Status updateVirtualTunnelInterface(
const std::string& deviceName,
const std::string& localAddress,
const std::string& remoteAddress,
int32_t iKey,
int32_t oKey);
binder::Status removeVirtualTunnelInterface(const std::string& deviceName);
};
} // namespace net
} // namespace android
#endif // _NETD_NATIVE_SERVICE_H_