blob: 5541a26507913925829500e5407edef269cb6a62 [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
Lorenzo Colitti4fcb4a02017-02-03 14:08:37 +090024#include "NetdConstants.h"
25
San Mehat9ff78fb2010-01-19 12:59:15 -080026class NatController {
San Mehat9ff78fb2010-01-19 12:59:15 -080027public:
Sreeram Ramachandran87475a12014-07-15 16:20:28 -070028 NatController();
San Mehat9ff78fb2010-01-19 12:59:15 -080029 virtual ~NatController();
30
Sreeram Ramachandran87475a12014-07-15 16:20:28 -070031 int enableNat(const char* intIface, const char* extIface);
32 int disableNat(const char* intIface, const char* extIface);
JP Abgrall0031cea2012-04-17 16:38:23 -070033 int setupIptablesHooks();
San Mehat9ff78fb2010-01-19 12:59:15 -080034
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070035 static const char* LOCAL_FORWARD;
Lorenzo Colittie8164dd2014-10-02 20:46:23 +090036 static const char* LOCAL_MANGLE_FORWARD;
Jeff Sharkey8e188ed2012-07-12 18:32:03 -070037 static const char* LOCAL_NAT_POSTROUTING;
Lorenzo Colitti8917e452016-08-01 16:47:50 +090038 static const char* LOCAL_RAW_PREROUTING;
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;
46
JP Abgrallf3cc83f2013-09-11 20:01:59 -070047 bool checkTetherCountingRuleExist(const char *pair_name);
48
San Mehat9ff78fb2010-01-19 12:59:15 -080049 int setDefaults();
Rom Lemarchand001f0a42013-01-31 12:41:03 -080050 int runCmd(int argc, const char **argv);
Robert Greenwaltfc97b822011-11-02 16:48:36 -070051 int setForwardRules(bool set, const char *intIface, const char *extIface);
JP Abgrallbaeccc42013-06-25 09:44:10 -070052 int setTetherCountingRules(bool add, const char *intIface, const char *extIface);
Lorenzo Colitti8e1cee92016-07-09 14:24:08 +090053
54 // For testing.
55 friend class NatControllerTest;
56 static int (*execFunction)(int, char **, int *, bool, bool);
Lorenzo Colitti4fcb4a02017-02-03 14:08:37 +090057 static int (*iptablesRestoreFunction)(IptablesTarget, const std::string&);
San Mehat9ff78fb2010-01-19 12:59:15 -080058};
59
60#endif