127 lines
2.8 KiB
C
127 lines
2.8 KiB
C
/* Shared library add-on to iptables for the TTL target
|
|
* (C) 2000 by Harald Welte <laforge@gnumonks.org>
|
|
*
|
|
* This program is distributed under the terms of GNU GPL
|
|
*/
|
|
#include <stdio.h>
|
|
#include <xtables.h>
|
|
#include <linux/netfilter_ipv4/ipt_TTL.h>
|
|
|
|
enum {
|
|
O_TTL_SET = 0,
|
|
O_TTL_INC,
|
|
O_TTL_DEC,
|
|
F_TTL_SET = 1 << O_TTL_SET,
|
|
F_TTL_INC = 1 << O_TTL_INC,
|
|
F_TTL_DEC = 1 << O_TTL_DEC,
|
|
F_ANY = F_TTL_SET | F_TTL_INC | F_TTL_DEC,
|
|
};
|
|
|
|
#define s struct ipt_TTL_info
|
|
static const struct xt_option_entry TTL_opts[] = {
|
|
{.name = "ttl-set", .type = XTTYPE_UINT8, .id = O_TTL_SET,
|
|
.excl = F_ANY, .flags = XTOPT_PUT, XTOPT_POINTER(s, ttl)},
|
|
{.name = "ttl-dec", .type = XTTYPE_UINT8, .id = O_TTL_DEC,
|
|
.excl = F_ANY, .flags = XTOPT_PUT, XTOPT_POINTER(s, ttl),
|
|
.min = 1},
|
|
{.name = "ttl-inc", .type = XTTYPE_UINT8, .id = O_TTL_INC,
|
|
.excl = F_ANY, .flags = XTOPT_PUT, XTOPT_POINTER(s, ttl),
|
|
.min = 1},
|
|
XTOPT_TABLEEND,
|
|
};
|
|
#undef s
|
|
|
|
static void TTL_help(void)
|
|
{
|
|
printf(
|
|
"TTL target options\n"
|
|
" --ttl-set value Set TTL to <value 0-255>\n"
|
|
" --ttl-dec value Decrement TTL by <value 1-255>\n"
|
|
" --ttl-inc value Increment TTL by <value 1-255>\n");
|
|
}
|
|
|
|
static void TTL_parse(struct xt_option_call *cb)
|
|
{
|
|
struct ipt_TTL_info *info = cb->data;
|
|
|
|
xtables_option_parse(cb);
|
|
switch (cb->entry->id) {
|
|
case O_TTL_SET:
|
|
info->mode = IPT_TTL_SET;
|
|
break;
|
|
case O_TTL_DEC:
|
|
info->mode = IPT_TTL_DEC;
|
|
break;
|
|
case O_TTL_INC:
|
|
info->mode = IPT_TTL_INC;
|
|
break;
|
|
}
|
|
}
|
|
|
|
static void TTL_check(struct xt_fcheck_call *cb)
|
|
{
|
|
if (!(cb->xflags & F_ANY))
|
|
xtables_error(PARAMETER_PROBLEM,
|
|
"TTL: You must specify an action");
|
|
}
|
|
|
|
static void TTL_save(const void *ip, const struct xt_entry_target *target)
|
|
{
|
|
const struct ipt_TTL_info *info =
|
|
(struct ipt_TTL_info *) target->data;
|
|
|
|
switch (info->mode) {
|
|
case IPT_TTL_SET:
|
|
printf(" --ttl-set");
|
|
break;
|
|
case IPT_TTL_DEC:
|
|
printf(" --ttl-dec");
|
|
break;
|
|
|
|
case IPT_TTL_INC:
|
|
printf(" --ttl-inc");
|
|
break;
|
|
}
|
|
printf(" %u", info->ttl);
|
|
}
|
|
|
|
static void TTL_print(const void *ip, const struct xt_entry_target *target,
|
|
int numeric)
|
|
{
|
|
const struct ipt_TTL_info *info =
|
|
(struct ipt_TTL_info *) target->data;
|
|
|
|
printf(" TTL ");
|
|
switch (info->mode) {
|
|
case IPT_TTL_SET:
|
|
printf("set to");
|
|
break;
|
|
case IPT_TTL_DEC:
|
|
printf("decrement by");
|
|
break;
|
|
case IPT_TTL_INC:
|
|
printf("increment by");
|
|
break;
|
|
}
|
|
printf(" %u", info->ttl);
|
|
}
|
|
|
|
static struct xtables_target ttl_tg_reg = {
|
|
.name = "TTL",
|
|
.version = XTABLES_VERSION,
|
|
.family = NFPROTO_IPV4,
|
|
.size = XT_ALIGN(sizeof(struct ipt_TTL_info)),
|
|
.userspacesize = XT_ALIGN(sizeof(struct ipt_TTL_info)),
|
|
.help = TTL_help,
|
|
.print = TTL_print,
|
|
.save = TTL_save,
|
|
.x6_parse = TTL_parse,
|
|
.x6_fcheck = TTL_check,
|
|
.x6_options = TTL_opts,
|
|
};
|
|
|
|
void _init(void)
|
|
{
|
|
xtables_register_target(&ttl_tg_reg);
|
|
}
|