diff options
author | Pablo Neira Ayuso <pablo@netfilter.org> | 2018-01-19 01:41:38 +0100 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2018-03-05 16:30:15 +0100 |
commit | f1f6c326d78594fd0dc279d4870502addcd6fcc2 (patch) | |
tree | 79750c93b413e4f31fdbd96baa60d45b0c0d6646 /src/netlink.c | |
parent | 92911b362e9067a9a335ac1a63e15119fb69a47d (diff) |
src: delete flowtable
This patch allows you to delete an existing flowtable:
# nft delete flowtable x m
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/netlink.c')
-rw-r--r-- | src/netlink.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/src/netlink.c b/src/netlink.c index 5b2d5e16..d4ed09bf 100644 --- a/src/netlink.c +++ b/src/netlink.c @@ -1547,6 +1547,24 @@ int netlink_add_flowtable(struct netlink_ctx *ctx, const struct handle *h, return err; } +int netlink_delete_flowtable(struct netlink_ctx *ctx, const struct handle *h, + struct location *loc) +{ + struct nftnl_flowtable *flo; + int err; + + flo = alloc_nftnl_flowtable(h, NULL); + netlink_dump_flowtable(flo, ctx); + + err = mnl_nft_flowtable_batch_del(flo, ctx->batch, 0, ctx->seqnum); + if (err < 0) + netlink_io_error(ctx, loc, "Could not delete flowtable: %s", + strerror(errno)); + nftnl_flowtable_free(flo); + + return err; +} + static int list_obj_cb(struct nftnl_obj *nls, void *arg) { struct netlink_ctx *ctx = arg; |