diff options
author | Harsha Sharma <harshasharmaiitr@gmail.com> | 2018-01-14 21:48:46 +0530 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2018-03-05 16:41:07 +0100 |
commit | f4a34d25f6d5f4188573dbe16613ce96327f0e6c (patch) | |
tree | 1e22f0cf48ec94c66b6a6016b671ad9168775d6a /src/netlink.c | |
parent | 51d3592d22ea5b0d5e5740a3b3cc4b62a2fabb36 (diff) |
src: list set handle and delete set via set handle
Print 'handle' attribute in sets when listing via '-a' option and
delete sets via their unique set handles listed with '-a' option.
For e.g.
nft delete set [<family>] <table-name> [handle <handle>]
Signed-off-by: Harsha Sharma <harshasharmaiitr@gmail.com>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/netlink.c')
-rw-r--r-- | src/netlink.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/netlink.c b/src/netlink.c index 728b6fdf..9f6d24c8 100644 --- a/src/netlink.c +++ b/src/netlink.c @@ -195,6 +195,8 @@ struct nftnl_set *alloc_nftnl_set(const struct handle *h) nftnl_set_set_str(nls, NFTNL_SET_NAME, h->set); if (h->set_id) nftnl_set_set_u32(nls, NFTNL_SET_ID, h->set_id); + if (h->handle.id) + nftnl_set_set_u64(nls, NFTNL_SET_HANDLE, h->handle.id); return nls; } @@ -981,6 +983,7 @@ static struct set *netlink_delinearize_set(struct netlink_ctx *ctx, nftnl_set_get_u32(nls, NFTNL_SET_KEY_LEN) * BITS_PER_BYTE, NULL); set->flags = nftnl_set_get_u32(nls, NFTNL_SET_FLAGS); + set->handle.handle.id = nftnl_set_get_u64(nls, NFTNL_SET_HANDLE); set->objtype = objtype; @@ -1123,6 +1126,7 @@ int netlink_list_sets(struct netlink_ctx *ctx, const struct handle *h, return 0; } + ctx->data = h; err = nftnl_set_list_foreach(set_cache, list_set_cb, ctx); nftnl_set_list_free(set_cache); return err; |