]>
Commit | Line | Data |
---|---|---|
baf7b1e1 PM |
1 | /* |
2 | * Copyright (c) 2006 Patrick McHardy <[email protected]> | |
3 | * | |
4 | * This program is free software; you can redistribute it and/or modify | |
5 | * it under the terms of the GNU General Public License version 2 as | |
6 | * published by the Free Software Foundation. | |
7 | */ | |
8 | ||
9 | #include <linux/module.h> | |
10 | #include <linux/init.h> | |
11 | #include <linux/skbuff.h> | |
12 | ||
13 | #include <linux/netfilter/x_tables.h> | |
14 | #include <linux/netfilter/xt_NFLOG.h> | |
f01ffbd6 | 15 | #include <net/netfilter/nf_log.h> |
5f7340ef | 16 | #include <net/netfilter/nfnetlink_log.h> |
baf7b1e1 PM |
17 | |
18 | MODULE_AUTHOR("Patrick McHardy <[email protected]>"); | |
2ae15b64 | 19 | MODULE_DESCRIPTION("Xtables: packet logging to netlink using NFLOG"); |
baf7b1e1 PM |
20 | MODULE_LICENSE("GPL"); |
21 | MODULE_ALIAS("ipt_NFLOG"); | |
22 | MODULE_ALIAS("ip6t_NFLOG"); | |
23 | ||
24 | static unsigned int | |
4b560b44 | 25 | nflog_tg(struct sk_buff *skb, const struct xt_action_param *par) |
baf7b1e1 | 26 | { |
7eb35586 | 27 | const struct xt_nflog_info *info = par->targinfo; |
baf7b1e1 PM |
28 | struct nf_loginfo li; |
29 | ||
30 | li.type = NF_LOG_TYPE_ULOG; | |
31 | li.u.ulog.copy_len = info->len; | |
32 | li.u.ulog.group = info->group; | |
33 | li.u.ulog.qthreshold = info->threshold; | |
34 | ||
5f7340ef EL |
35 | nfulnl_log_packet(par->family, par->hooknum, skb, par->in, |
36 | par->out, &li, info->prefix); | |
baf7b1e1 PM |
37 | return XT_CONTINUE; |
38 | } | |
39 | ||
135367b8 | 40 | static int nflog_tg_check(const struct xt_tgchk_param *par) |
baf7b1e1 | 41 | { |
af5d6dc2 | 42 | const struct xt_nflog_info *info = par->targinfo; |
baf7b1e1 PM |
43 | |
44 | if (info->flags & ~XT_NFLOG_MASK) | |
d6b00a53 | 45 | return -EINVAL; |
baf7b1e1 | 46 | if (info->prefix[sizeof(info->prefix) - 1] != '\0') |
d6b00a53 JE |
47 | return -EINVAL; |
48 | return 0; | |
baf7b1e1 PM |
49 | } |
50 | ||
92f3b2b1 JE |
51 | static struct xt_target nflog_tg_reg __read_mostly = { |
52 | .name = "NFLOG", | |
53 | .revision = 0, | |
54 | .family = NFPROTO_UNSPEC, | |
55 | .checkentry = nflog_tg_check, | |
56 | .target = nflog_tg, | |
57 | .targetsize = sizeof(struct xt_nflog_info), | |
58 | .me = THIS_MODULE, | |
baf7b1e1 PM |
59 | }; |
60 | ||
d3c5ee6d | 61 | static int __init nflog_tg_init(void) |
baf7b1e1 | 62 | { |
92f3b2b1 | 63 | return xt_register_target(&nflog_tg_reg); |
baf7b1e1 PM |
64 | } |
65 | ||
d3c5ee6d | 66 | static void __exit nflog_tg_exit(void) |
baf7b1e1 | 67 | { |
92f3b2b1 | 68 | xt_unregister_target(&nflog_tg_reg); |
baf7b1e1 PM |
69 | } |
70 | ||
d3c5ee6d JE |
71 | module_init(nflog_tg_init); |
72 | module_exit(nflog_tg_exit); |