blob: 38ffadeb6fb7513c241091481fde7c4acafc2536 [file] [log] [blame]
Pierre Imai1cfa5432016-02-24 18:00:03 +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 _CONTROLLERS_H__
18#define _CONTROLLERS_H__
19
20#include <sysutils/FrameworkListener.h>
Lorenzo Colittiddf2d5b2016-02-26 11:30:59 +090021
Pierre Imai1cfa5432016-02-24 18:00:03 +090022#include "BandwidthController.h"
Nathan Harold1a371532017-01-30 12:30:48 -080023#include "ClatdController.h"
24#include "EventReporter.h"
25#include "FirewallController.h"
Pierre Imai1cfa5432016-02-24 18:00:03 +090026#include "IdletimerController.h"
27#include "InterfaceController.h"
Narayan Kamatha5ace892017-01-06 15:10:02 +000028#include "IptablesRestoreController.h"
Nathan Harold1a371532017-01-30 12:30:48 -080029#include "NetworkController.h"
30#include "PppController.h"
Pierre Imai1cfa5432016-02-24 18:00:03 +090031#include "ResolverController.h"
Pierre Imai1cfa5432016-02-24 18:00:03 +090032#include "StrictController.h"
Nathan Harold1a371532017-01-30 12:30:48 -080033#include "TetherController.h"
Chenbo Fengf2759682017-10-10 17:31:57 -070034#include "TrafficController.h"
Joel Scherpelz08b84cd2017-05-22 13:11:54 +090035#include "WakeupController.h"
Nathan Harold1a371532017-01-30 12:30:48 -080036#include "XfrmController.h"
Hugo Benichi7b314e12018-01-15 21:54:00 +090037#include "TcpSocketMonitor.h"
Pierre Imai1cfa5432016-02-24 18:00:03 +090038
39namespace android {
40namespace net {
41
Lorenzo Colitti1ed96e22017-02-02 12:21:56 +090042class Controllers {
43public:
Pierre Imai1cfa5432016-02-24 18:00:03 +090044 Controllers();
45
46 NetworkController netCtrl;
47 TetherController tetherCtrl;
Pierre Imai1cfa5432016-02-24 18:00:03 +090048 PppController pppCtrl;
Pierre Imai1cfa5432016-02-24 18:00:03 +090049 BandwidthController bandwidthCtrl;
50 IdletimerController idletimerCtrl;
51 ResolverController resolverCtrl;
52 FirewallController firewallCtrl;
Pierre Imai1cfa5432016-02-24 18:00:03 +090053 ClatdController clatdCtrl;
54 StrictController strictCtrl;
Michal Karpinskid5440112016-10-06 16:56:04 +010055 EventReporter eventReporter;
Narayan Kamatha5ace892017-01-06 15:10:02 +000056 IptablesRestoreController iptablesRestoreCtrl;
Joel Scherpelz08b84cd2017-05-22 13:11:54 +090057 WakeupController wakeupCtrl;
Nathan Harold1a371532017-01-30 12:30:48 -080058 XfrmController xfrmCtrl;
Chenbo Fengf2759682017-10-10 17:31:57 -070059 TrafficController trafficCtrl;
Hugo Benichi7b314e12018-01-15 21:54:00 +090060 TcpSocketMonitor tcpSocketMonitor;
Lorenzo Colitti1ed96e22017-02-02 12:21:56 +090061
62 void init();
63
64private:
Lorenzo Colitti341d3a02017-08-08 17:31:35 +090065 friend class ControllersTest;
Lorenzo Colitti1ed96e22017-02-02 12:21:56 +090066 void initIptablesRules();
Lorenzo Colitti341d3a02017-08-08 17:31:35 +090067 static void initChildChains();
Lorenzo Colittiadc3a5f2017-08-08 17:23:12 +090068 static std::set<std::string> findExistingChildChains(const IptablesTarget target,
69 const char* table,
70 const char* parentChain);
Lorenzo Colitti341d3a02017-08-08 17:31:35 +090071 static void createChildChains(IptablesTarget target, const char* table, const char* parentChain,
Lorenzo Colittiadc3a5f2017-08-08 17:23:12 +090072 const std::vector<const char*>& childChains, bool exclusive);
Lorenzo Colitti341d3a02017-08-08 17:31:35 +090073 static int (*execIptablesRestore)(IptablesTarget, const std::string&);
Lorenzo Colittiadc3a5f2017-08-08 17:23:12 +090074 static int (*execIptablesRestoreWithOutput)(IptablesTarget, const std::string&, std::string *);
Pierre Imai1cfa5432016-02-24 18:00:03 +090075};
76
77extern Controllers* gCtls;
78
79} // namespace net
80} // namespace android
81
82#endif // _CONTROLLERS_H__