1*a71a9546SAutomerger Merge Worker /*
2*a71a9546SAutomerger Merge Worker * Shared library add-on for iptables to add IDLETIMER support.
3*a71a9546SAutomerger Merge Worker *
4*a71a9546SAutomerger Merge Worker * Copyright (C) 2010 Nokia Corporation. All rights reserved.
5*a71a9546SAutomerger Merge Worker *
6*a71a9546SAutomerger Merge Worker * Contact: Luciano Coelho <[email protected]>
7*a71a9546SAutomerger Merge Worker *
8*a71a9546SAutomerger Merge Worker * This program is free software; you can redistribute it and/or
9*a71a9546SAutomerger Merge Worker * modify it under the terms of the GNU General Public License
10*a71a9546SAutomerger Merge Worker * version 2 as published by the Free Software Foundation.
11*a71a9546SAutomerger Merge Worker *
12*a71a9546SAutomerger Merge Worker * This program is distributed in the hope that it will be useful, but
13*a71a9546SAutomerger Merge Worker * WITHOUT ANY WARRANTY; without even the implied warranty of
14*a71a9546SAutomerger Merge Worker * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15*a71a9546SAutomerger Merge Worker * General Public License for more details.
16*a71a9546SAutomerger Merge Worker *
17*a71a9546SAutomerger Merge Worker * You should have received a copy of the GNU General Public License
18*a71a9546SAutomerger Merge Worker * along with this program; if not, write to the Free Software
19*a71a9546SAutomerger Merge Worker * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20*a71a9546SAutomerger Merge Worker * 02110-1301 USA
21*a71a9546SAutomerger Merge Worker *
22*a71a9546SAutomerger Merge Worker */
23*a71a9546SAutomerger Merge Worker #include <stdio.h>
24*a71a9546SAutomerger Merge Worker #include <xtables.h>
25*a71a9546SAutomerger Merge Worker #include <linux/netfilter/xt_IDLETIMER.h>
26*a71a9546SAutomerger Merge Worker
27*a71a9546SAutomerger Merge Worker enum {
28*a71a9546SAutomerger Merge Worker O_TIMEOUT = 0,
29*a71a9546SAutomerger Merge Worker O_LABEL,
30*a71a9546SAutomerger Merge Worker O_ALARM,
31*a71a9546SAutomerger Merge Worker O_NETLINK,
32*a71a9546SAutomerger Merge Worker };
33*a71a9546SAutomerger Merge Worker
34*a71a9546SAutomerger Merge Worker #define s struct idletimer_tg_info
35*a71a9546SAutomerger Merge Worker static const struct xt_option_entry idletimer_tg_opts[] = {
36*a71a9546SAutomerger Merge Worker {.name = "timeout", .id = O_TIMEOUT, .type = XTTYPE_UINT32,
37*a71a9546SAutomerger Merge Worker .flags = XTOPT_MAND | XTOPT_PUT, XTOPT_POINTER(s, timeout)},
38*a71a9546SAutomerger Merge Worker {.name = "label", .id = O_LABEL, .type = XTTYPE_STRING,
39*a71a9546SAutomerger Merge Worker .flags = XTOPT_MAND | XTOPT_PUT, XTOPT_POINTER(s, label)},
40*a71a9546SAutomerger Merge Worker XTOPT_TABLEEND,
41*a71a9546SAutomerger Merge Worker };
42*a71a9546SAutomerger Merge Worker #undef s
43*a71a9546SAutomerger Merge Worker
44*a71a9546SAutomerger Merge Worker #define s struct idletimer_tg_info_v1
45*a71a9546SAutomerger Merge Worker static const struct xt_option_entry idletimer_tg_opts_v1[] = {
46*a71a9546SAutomerger Merge Worker {.name = "timeout", .id = O_TIMEOUT, .type = XTTYPE_UINT32,
47*a71a9546SAutomerger Merge Worker .flags = XTOPT_MAND | XTOPT_PUT, XTOPT_POINTER(s, timeout)},
48*a71a9546SAutomerger Merge Worker {.name = "label", .id = O_LABEL, .type = XTTYPE_STRING,
49*a71a9546SAutomerger Merge Worker .flags = XTOPT_MAND | XTOPT_PUT, XTOPT_POINTER(s, label)},
50*a71a9546SAutomerger Merge Worker {.name = "alarm", .id = O_ALARM, .type = XTTYPE_NONE},
51*a71a9546SAutomerger Merge Worker {.name = "send_nl_msg", .id = O_NETLINK, .type = XTTYPE_NONE},
52*a71a9546SAutomerger Merge Worker XTOPT_TABLEEND,
53*a71a9546SAutomerger Merge Worker };
54*a71a9546SAutomerger Merge Worker #undef s
55*a71a9546SAutomerger Merge Worker
idletimer_tg_help(void)56*a71a9546SAutomerger Merge Worker static void idletimer_tg_help(void)
57*a71a9546SAutomerger Merge Worker {
58*a71a9546SAutomerger Merge Worker printf(
59*a71a9546SAutomerger Merge Worker "IDLETIMER target options:\n"
60*a71a9546SAutomerger Merge Worker " --timeout time Timeout until the notification is sent (in seconds)\n"
61*a71a9546SAutomerger Merge Worker " --label string Unique rule identifier\n"
62*a71a9546SAutomerger Merge Worker "\n");
63*a71a9546SAutomerger Merge Worker }
64*a71a9546SAutomerger Merge Worker
idletimer_tg_help_v1(void)65*a71a9546SAutomerger Merge Worker static void idletimer_tg_help_v1(void)
66*a71a9546SAutomerger Merge Worker {
67*a71a9546SAutomerger Merge Worker printf(
68*a71a9546SAutomerger Merge Worker "IDLETIMER target options:\n"
69*a71a9546SAutomerger Merge Worker " --timeout time Timeout until the notification is sent (in seconds)\n"
70*a71a9546SAutomerger Merge Worker " --label string Unique rule identifier\n"
71*a71a9546SAutomerger Merge Worker " --alarm Use alarm instead of default timer\n"
72*a71a9546SAutomerger Merge Worker " --send_nl_msg Enable netlink messages and show remaining time in sysfs.\n"
73*a71a9546SAutomerger Merge Worker "\n");
74*a71a9546SAutomerger Merge Worker }
75*a71a9546SAutomerger Merge Worker
idletimer_tg_print(const void * ip,const struct xt_entry_target * target,int numeric)76*a71a9546SAutomerger Merge Worker static void idletimer_tg_print(const void *ip,
77*a71a9546SAutomerger Merge Worker const struct xt_entry_target *target,
78*a71a9546SAutomerger Merge Worker int numeric)
79*a71a9546SAutomerger Merge Worker {
80*a71a9546SAutomerger Merge Worker struct idletimer_tg_info *info =
81*a71a9546SAutomerger Merge Worker (struct idletimer_tg_info *) target->data;
82*a71a9546SAutomerger Merge Worker
83*a71a9546SAutomerger Merge Worker printf(" timeout:%u", info->timeout);
84*a71a9546SAutomerger Merge Worker printf(" label:%s", info->label);
85*a71a9546SAutomerger Merge Worker }
86*a71a9546SAutomerger Merge Worker
idletimer_tg_print_v1(const void * ip,const struct xt_entry_target * target,int numeric)87*a71a9546SAutomerger Merge Worker static void idletimer_tg_print_v1(const void *ip,
88*a71a9546SAutomerger Merge Worker const struct xt_entry_target *target,
89*a71a9546SAutomerger Merge Worker int numeric)
90*a71a9546SAutomerger Merge Worker {
91*a71a9546SAutomerger Merge Worker struct idletimer_tg_info_v1 *info =
92*a71a9546SAutomerger Merge Worker (struct idletimer_tg_info_v1 *) target->data;
93*a71a9546SAutomerger Merge Worker
94*a71a9546SAutomerger Merge Worker printf(" timeout:%u", info->timeout);
95*a71a9546SAutomerger Merge Worker printf(" label:%s", info->label);
96*a71a9546SAutomerger Merge Worker if (info->timer_type == XT_IDLETIMER_ALARM)
97*a71a9546SAutomerger Merge Worker printf(" alarm");
98*a71a9546SAutomerger Merge Worker if (info->send_nl_msg)
99*a71a9546SAutomerger Merge Worker printf(" send_nl_msg");
100*a71a9546SAutomerger Merge Worker }
101*a71a9546SAutomerger Merge Worker
102*a71a9546SAutomerger Merge Worker
idletimer_tg_save(const void * ip,const struct xt_entry_target * target)103*a71a9546SAutomerger Merge Worker static void idletimer_tg_save(const void *ip,
104*a71a9546SAutomerger Merge Worker const struct xt_entry_target *target)
105*a71a9546SAutomerger Merge Worker {
106*a71a9546SAutomerger Merge Worker struct idletimer_tg_info *info =
107*a71a9546SAutomerger Merge Worker (struct idletimer_tg_info *) target->data;
108*a71a9546SAutomerger Merge Worker
109*a71a9546SAutomerger Merge Worker printf(" --timeout %u", info->timeout);
110*a71a9546SAutomerger Merge Worker printf(" --label %s", info->label);
111*a71a9546SAutomerger Merge Worker }
112*a71a9546SAutomerger Merge Worker
idletimer_tg_save_v1(const void * ip,const struct xt_entry_target * target)113*a71a9546SAutomerger Merge Worker static void idletimer_tg_save_v1(const void *ip,
114*a71a9546SAutomerger Merge Worker const struct xt_entry_target *target)
115*a71a9546SAutomerger Merge Worker {
116*a71a9546SAutomerger Merge Worker struct idletimer_tg_info_v1 *info =
117*a71a9546SAutomerger Merge Worker (struct idletimer_tg_info_v1 *) target->data;
118*a71a9546SAutomerger Merge Worker
119*a71a9546SAutomerger Merge Worker printf(" --timeout %u", info->timeout);
120*a71a9546SAutomerger Merge Worker printf(" --label %s", info->label);
121*a71a9546SAutomerger Merge Worker if (info->timer_type == XT_IDLETIMER_ALARM)
122*a71a9546SAutomerger Merge Worker printf(" --alarm");
123*a71a9546SAutomerger Merge Worker if (info->send_nl_msg)
124*a71a9546SAutomerger Merge Worker printf(" --send_nl_msg");
125*a71a9546SAutomerger Merge Worker }
126*a71a9546SAutomerger Merge Worker
idletimer_tg_parse_v1(struct xt_option_call * cb)127*a71a9546SAutomerger Merge Worker static void idletimer_tg_parse_v1(struct xt_option_call *cb)
128*a71a9546SAutomerger Merge Worker {
129*a71a9546SAutomerger Merge Worker struct idletimer_tg_info_v1 *info = cb->data;
130*a71a9546SAutomerger Merge Worker
131*a71a9546SAutomerger Merge Worker xtables_option_parse(cb);
132*a71a9546SAutomerger Merge Worker if (cb->entry->id == O_ALARM)
133*a71a9546SAutomerger Merge Worker info->timer_type = XT_IDLETIMER_ALARM;
134*a71a9546SAutomerger Merge Worker if (cb->entry->id == O_NETLINK)
135*a71a9546SAutomerger Merge Worker info->send_nl_msg = 1;
136*a71a9546SAutomerger Merge Worker }
137*a71a9546SAutomerger Merge Worker
138*a71a9546SAutomerger Merge Worker static struct xtables_target idletimer_tg_reg[] = {
139*a71a9546SAutomerger Merge Worker {
140*a71a9546SAutomerger Merge Worker .family = NFPROTO_UNSPEC,
141*a71a9546SAutomerger Merge Worker .name = "IDLETIMER",
142*a71a9546SAutomerger Merge Worker .version = XTABLES_VERSION,
143*a71a9546SAutomerger Merge Worker .revision = 0,
144*a71a9546SAutomerger Merge Worker .size = XT_ALIGN(sizeof(struct idletimer_tg_info)),
145*a71a9546SAutomerger Merge Worker .userspacesize = offsetof(struct idletimer_tg_info, timer),
146*a71a9546SAutomerger Merge Worker .help = idletimer_tg_help,
147*a71a9546SAutomerger Merge Worker .x6_parse = xtables_option_parse,
148*a71a9546SAutomerger Merge Worker .print = idletimer_tg_print,
149*a71a9546SAutomerger Merge Worker .save = idletimer_tg_save,
150*a71a9546SAutomerger Merge Worker .x6_options = idletimer_tg_opts,
151*a71a9546SAutomerger Merge Worker },
152*a71a9546SAutomerger Merge Worker {
153*a71a9546SAutomerger Merge Worker .family = NFPROTO_UNSPEC,
154*a71a9546SAutomerger Merge Worker .name = "IDLETIMER",
155*a71a9546SAutomerger Merge Worker .version = XTABLES_VERSION,
156*a71a9546SAutomerger Merge Worker .revision = 1,
157*a71a9546SAutomerger Merge Worker .size = XT_ALIGN(sizeof(struct idletimer_tg_info_v1)),
158*a71a9546SAutomerger Merge Worker .userspacesize = offsetof(struct idletimer_tg_info_v1, timer),
159*a71a9546SAutomerger Merge Worker .help = idletimer_tg_help_v1,
160*a71a9546SAutomerger Merge Worker .x6_parse = idletimer_tg_parse_v1,
161*a71a9546SAutomerger Merge Worker .print = idletimer_tg_print_v1,
162*a71a9546SAutomerger Merge Worker .save = idletimer_tg_save_v1,
163*a71a9546SAutomerger Merge Worker .x6_options = idletimer_tg_opts_v1,
164*a71a9546SAutomerger Merge Worker },
165*a71a9546SAutomerger Merge Worker
166*a71a9546SAutomerger Merge Worker };
167*a71a9546SAutomerger Merge Worker
_init(void)168*a71a9546SAutomerger Merge Worker void _init(void)
169*a71a9546SAutomerger Merge Worker {
170*a71a9546SAutomerger Merge Worker xtables_register_targets(idletimer_tg_reg, ARRAY_SIZE(idletimer_tg_reg));
171*a71a9546SAutomerger Merge Worker }
172