blob: 2912e4b12d764b64932d4c294cc77ae51dcf5da5 [file] [log] [blame]
San Mehat9ff78fb2010-01-19 12:59:15 -08001/*
2 * Copyright (C) 2008 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 _NAT_CONTROLLER_H
18#define _NAT_CONTROLLER_H
19
20#include <linux/in.h>
JP Abgrallf3cc83f2013-09-11 20:01:59 -070021#include <list>
Paul Jensen17de4f02014-04-04 00:04:39 -040022#include <string>
San Mehat9ff78fb2010-01-19 12:59:15 -080023
Szymon Jakubczaka0efaec2014-02-14 17:09:43 -050024class NetworkController;
25class SecondaryTableController;
Robert Greenwaltfc97b822011-11-02 16:48:36 -070026
San Mehat9ff78fb2010-01-19 12:59:15 -080027class NatController {
28
29public:
Szymon Jakubczaka0efaec2014-02-14 17:09:43 -050030 NatController(SecondaryTableController *table_ctrl, NetworkController* net_ctrl);
San Mehat9ff78fb2010-01-19 12:59:15 -080031 virtual ~NatController();
32
Robert Greenwaltfc97b822011-11-02 16:48:36 -070033 int enableNat(const int argc, char **argv);
34 int disableNat(const int argc, char **argv);
JP Abgrall0031cea2012-04-17 16:38:23 -070035 int setupIptablesHooks();
San Mehat9ff78fb2010-01-19 12:59:15 -080036
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070037 static const char* LOCAL_FORWARD;
38 static const char* LOCAL_NAT_POSTROUTING;
JP Abgrallbaeccc42013-06-25 09:44:10 -070039 static const char* LOCAL_TETHER_COUNTERS_CHAIN;
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070040
JP Abgrallf3cc83f2013-09-11 20:01:59 -070041 // List of strings of interface pairs.
42 std::list<std::string> ifacePairList;
43
San Mehat9ff78fb2010-01-19 12:59:15 -080044private:
Robert Greenwalt1caafe62010-03-24 15:43:00 -070045 int natCount;
Szymon Jakubczaka0efaec2014-02-14 17:09:43 -050046 SecondaryTableController *mSecondaryTableCtrl;
47 NetworkController *mNetCtrl;
Robert Greenwalt1caafe62010-03-24 15:43:00 -070048
JP Abgrallf3cc83f2013-09-11 20:01:59 -070049 bool checkTetherCountingRuleExist(const char *pair_name);
50
San Mehat9ff78fb2010-01-19 12:59:15 -080051 int setDefaults();
Rom Lemarchand001f0a42013-01-31 12:41:03 -080052 int runCmd(int argc, const char **argv);
Robert Greenwaltfc97b822011-11-02 16:48:36 -070053 bool checkInterface(const char *iface);
54 int setForwardRules(bool set, const char *intIface, const char *extIface);
JP Abgrallbaeccc42013-06-25 09:44:10 -070055 int setTetherCountingRules(bool add, const char *intIface, const char *extIface);
JP Abgrall4ae80de2013-03-14 20:06:20 -070056 int routesOp(bool add, const char *intIface, const char *extIface, char **argv, int addrCount);
San Mehat9ff78fb2010-01-19 12:59:15 -080057};
58
59#endif