lin
2025-07-30 fcd736bf35fd93b563e9bbf594f2aa7b62028cc9
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*
 * Shared library add-on for iptables to add IDLETIMER support.
 *
 * Copyright (C) 2010 Nokia Corporation. All rights reserved.
 *
 * Contact: Luciano Coelho <luciano.coelho@nokia.com>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * version 2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.     See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA
 *
 */
#include <stdio.h>
#include <xtables.h>
#include <linux/netfilter/xt_IDLETIMER.h>
 
enum {
   O_TIMEOUT = 0,
   O_LABEL,
   O_NETLINK,
};
 
#define s struct idletimer_tg_info
static const struct xt_option_entry idletimer_tg_opts[] = {
   {.name = "timeout", .id = O_TIMEOUT, .type = XTTYPE_UINT32,
    .flags = XTOPT_MAND | XTOPT_PUT, XTOPT_POINTER(s, timeout)},
   {.name = "label", .id = O_LABEL, .type = XTTYPE_STRING,
    .flags = XTOPT_MAND | XTOPT_PUT, XTOPT_POINTER(s, label)},
   {.name = "send_nl_msg", .id = O_NETLINK, .type = XTTYPE_UINT8,
    .flags = XTOPT_PUT, XTOPT_POINTER(s, send_nl_msg)},
   XTOPT_TABLEEND,
};
#undef s
 
static void idletimer_tg_help(void)
{
   printf(
"IDLETIMER target options:\n"
" --timeout time    Timeout until the notification is sent (in seconds)\n"
" --label string    Unique rule identifier\n"
" --send_nl_msg        (0/1) Enable netlink messages,"
           " and show remaining time in sysfs. Defaults to 0.\n"
"\n");
}
 
static void idletimer_tg_print(const void *ip,
                  const struct xt_entry_target *target,
                  int numeric)
{
   struct idletimer_tg_info *info =
       (struct idletimer_tg_info *) target->data;
 
   printf(" timeout:%u", info->timeout);
   printf(" label:%s", info->label);
   printf(" send_nl_msg:%u", info->send_nl_msg);
}
 
static void idletimer_tg_save(const void *ip,
                 const struct xt_entry_target *target)
{
   struct idletimer_tg_info *info =
       (struct idletimer_tg_info *) target->data;
 
   printf(" --timeout %u", info->timeout);
   printf(" --label %s", info->label);
   printf(" --send_nl_msg %u", info->send_nl_msg);
}
 
static struct xtables_target idletimer_tg_reg = {
   .family           = NFPROTO_UNSPEC,
   .name           = "IDLETIMER",
   .version       = XTABLES_VERSION,
   .revision      = 1,
   .size           = XT_ALIGN(sizeof(struct idletimer_tg_info)),
   .userspacesize = offsetof(struct idletimer_tg_info, timer),
   .help           = idletimer_tg_help,
   .x6_parse      = xtables_option_parse,
   .print           = idletimer_tg_print,
   .save           = idletimer_tg_save,
   .x6_options    = idletimer_tg_opts,
};
 
void _init(void)
{
   xtables_register_target(&idletimer_tg_reg);
}