handle_merge(&cmd->set->handle, &cmd->handle);
return set_evaluate(ctx, cmd->set);
case CMD_OBJ_RULE:
- ret = cache_update(ctx->nf_sock, ctx->cache, cmd->op,
- ctx->msgs);
- if (ret < 0)
- return ret;
handle_merge(&cmd->rule->handle, &cmd->handle);
return rule_evaluate(ctx, cmd->rule);
case CMD_OBJ_CHAIN:
case CMD_OBJ_COUNTER:
case CMD_OBJ_QUOTA:
case CMD_OBJ_CT_HELPER:
- ret = cache_update(ctx->nf_sock, ctx->cache, cmd->op,
- ctx->msgs);
- if (ret < 0)
- return ret;
-
return 0;
default:
BUG("invalid command object type %u\n", cmd->obj);
const struct location *loc)
{
struct nftnl_rule *nlr;
- int err, flags = ctx->octx->echo ? NLM_F_ECHO : 0;
+ int err, flags = 0;
+
+ if (ctx->octx->echo) {
+ err = cache_update(ctx->nf_sock, ctx->cache,
+ CMD_INVALID, ctx->msgs);
+ if (err < 0)
+ return err;
+
+ flags |= NLM_F_ECHO;
+ }
nlr = alloc_nftnl_rule(&rule->handle);
netlink_linearize_rule(ctx, nlr, rule);
{
uint32_t flags = excl ? NLM_F_EXCL : 0;
- if (ctx->octx->echo)
+ if (ctx->octx->echo) {
+ int ret;
+
+ ret = cache_update(ctx->nf_sock, ctx->cache,
+ cmd->obj, ctx->msgs);
+ if (ret < 0)
+ return ret;
+
flags |= NLM_F_ECHO;
+ }
switch (cmd->obj) {
case CMD_OBJ_TABLE:
static int do_command_insert(struct netlink_ctx *ctx, struct cmd *cmd)
{
- uint32_t flags = ctx->octx->echo ? NLM_F_ECHO : 0;
+ uint32_t flags = 0;
+
+ if (ctx->octx->echo) {
+ int ret;
+
+ ret = cache_update(ctx->nf_sock, ctx->cache,
+ cmd->obj, ctx->msgs);
+ if (ret < 0)
+ return ret;
+
+ flags |= NLM_F_ECHO;
+ }
switch (cmd->obj) {
case CMD_OBJ_RULE: