/* * Copyright (C) 2022 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. * */ #pragma once #include #define BPF_MAP_LOCKLESS_FOR_TEST #include #include "netd.h" using android::base::Result; using android::bpf::BpfMap; class Firewall { public: Firewall() EXCLUDES(mMutex); static Firewall* getInstance(); Result toggleStandbyMatch(bool enable) EXCLUDES(mMutex); Result addRule(uint32_t uid, UidOwnerMatchType match, uint32_t iif = 0) EXCLUDES(mMutex); Result removeRule(uint32_t uid, UidOwnerMatchType match) EXCLUDES(mMutex); Result addUidInterfaceRules(const std::string& ifName, const std::vector& uids); Result removeUidInterfaceRules(const std::vector& uids); Result getDataSaverSetting(); Result setDataSaver(bool enabled); private: BpfMap mConfigurationMap GUARDED_BY(mMutex); BpfMap mUidOwnerMap GUARDED_BY(mMutex); BpfMap mDataSaverEnabledMap GUARDED_BY(mMutex); std::mutex mMutex; };