Added firewall feature
[platform/core/connectivity/stc-manager.git] / src / helper / helper-iptables.h
1 /*
2  * Copyright (c) 2016 Samsung Electronics Co., Ltd.
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 __STC_HELPER_IPTABLES_H__
18 #define __STC_HELPER_IPTABLES_H__
19
20 #include "stc-manager.h"
21 #include "stc-error.h"
22
23 #define STC_IN_CHAIN     "STC_IN"
24 #define STC_OUT_CHAIN    "STC_OUT"
25 #define STC_FRWD_CHAIN    "STC_FRWD"
26
27 typedef enum {
28         IPTABLES_DIRECTION_NONE,
29         IPTABLES_DIRECTION_IN,
30         IPTABLES_DIRECTION_OUT
31 } iptables_rule_direction_e;
32
33 typedef enum {
34         IP_TYPE_UNKNOWN,
35         IP_TYPE_IPV4,
36         IP_TYPE_IPV6,
37         IP_TYPE_IPV4_IPV6,
38         IP_TYPE_LAST_ELEM
39 } iptables_ip_type_e;
40
41 typedef struct {
42         char *chain;
43         char *ifname;
44         char *nfacct_name;
45         char *target;
46         iptables_rule_direction_e direction;
47         uint32_t classid;
48 } iptables_rule_s;
49
50 stc_error_e iptables_add(iptables_rule_s *rule, iptables_ip_type_e iptype);
51 stc_error_e iptables_remove(iptables_rule_s *rule, iptables_ip_type_e iptype);
52 stc_error_e iptables_flush_chains(void);
53 stc_error_e iptables_init(void);
54 stc_error_e iptables_deinit(void);
55
56 #endif  /*__STC_HELPER_IPTABLES_H__*/