diff options
author | Arturo Borrero Gonzalez <arturo.borrero.glez@gmail.com> | 2013-02-08 17:51:56 +0100 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2013-02-08 19:12:55 +0100 |
commit | 26e06d838d6471f5233c1da3fee012bf113564a5 (patch) | |
tree | 0482737475d6dd151cd74a4e94bd82cff9278232 /src/expr/payload.c | |
parent | 1cef3296c64244736a000ab0d146d05ca1ac4b8b (diff) |
src: add XML output support
Signed-off-by: Arturo Borrero Gonzalez <arturo.borrero.glez@gmail.com>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/expr/payload.c')
-rw-r--r-- | src/expr/payload.c | 20 |
1 files changed, 17 insertions, 3 deletions
diff --git a/src/expr/payload.c b/src/expr/payload.c index f571206..33fcef1 100644 --- a/src/expr/payload.c +++ b/src/expr/payload.c @@ -20,6 +20,7 @@ #include <linux/netfilter/nf_tables.h> #include <libnftables/expr.h> +#include <libnftables/rule.h> #include "expr_ops.h" @@ -169,9 +170,22 @@ nft_rule_expr_payload_snprintf(char *buf, size_t len, uint32_t type, { struct nft_expr_payload *payload = (struct nft_expr_payload *)e->data; - return snprintf(buf, len, "dreg=%u base=%u offset=%u len=%u ", - payload->dreg, payload->base, - payload->offset, payload->len); + switch(type) { + case NFT_RULE_O_XML: + return snprintf(buf, len, "\t\t<dreg>%u</dreg>" + "<base>%u</base> <offset>%u</offset>" + "<len>%u</len>", + payload->dreg, payload->base, + payload->offset, payload->len); + + case NFT_RULE_O_DEFAULT: + return snprintf(buf, len, "dreg=%u base=%u offset=%u len=%u ", + payload->dreg, payload->base, + payload->offset, payload->len); + default: + break; + } + return -1; } struct expr_ops expr_ops_payload = { |