static int nft_chain_json_parse(struct nft_chain *c, char *json)
{
#ifdef JSON_PARSING
- json_t *root;
+ json_t *root, *node;
json_error_t error;
uint64_t uval64;
uint32_t policy;
int32_t val32;
const char *valstr;
- root = nft_jansson_get_root(json, "chain", &error);
+ node = nft_jansson_create_root(json, &error);
+ if (node == NULL)
+ return -1;
+
+ root = nft_jansson_get_node(node, "chain");
if (root == NULL)
return -1;
if (valstr == NULL)
goto err;
- nft_chain_attr_set_str(c, NFT_CHAIN_ATTR_NAME, strdup(valstr));
+ nft_chain_attr_set_str(c, NFT_CHAIN_ATTR_NAME, valstr);
if (nft_jansson_value_parse_val(root, "handle", NFT_TYPE_U64,
&uval64) == -1)
nft_chain_attr_set_u64(c, NFT_CHAIN_ATTR_PACKETS, uval64);
if (nft_jansson_parse_family(root, &val32) != 0)
- return -1;
+ goto err;
nft_chain_attr_set_u32(c, NFT_CHAIN_ATTR_FAMILY, val32);
if (valstr == NULL)
goto err;
- nft_chain_attr_set_str(c, NFT_CHAIN_ATTR_TABLE, strdup(valstr));
+ nft_chain_attr_set_str(c, NFT_CHAIN_ATTR_TABLE, valstr);
if (nft_jansson_node_exist(root, "hooknum")) {
valstr = nft_jansson_value_parse_str(root, "type");
if (valstr == NULL)
goto err;
- nft_chain_attr_set_str(c, NFT_CHAIN_ATTR_TYPE, strdup(valstr));
+ nft_chain_attr_set_str(c, NFT_CHAIN_ATTR_TYPE, valstr);
if (nft_jansson_value_parse_val(root, "prio", NFT_TYPE_S32,
&val32) == -1)
nft_chain_attr_set_u32(c, NFT_CHAIN_ATTR_POLICY, policy);
}
- xfree(root);
+ nft_jansson_free_root(node);
return 0;
err:
- xfree(root);
+ nft_jansson_free_root(node);
return -1;
#else
errno = EOPNOTSUPP;
int type, void *out);
const char *nft_jansson_value_parse_str(json_t *root, const char *tag);
bool nft_jansson_node_exist(json_t *root, const char *tag);
-json_t *nft_jansson_get_root(char *json, const char *tag, json_error_t *err);
+json_t *nft_jansson_create_root(char *json, json_error_t *err);
+json_t *nft_jansson_get_node(json_t *root, const char *tag);
+void nft_jansson_free_root(json_t *root);
int nft_jansson_parse_family(json_t *root, void *out);
#endif
return json_object_get(root, tag) != NULL;
}
-json_t *nft_jansson_get_root(char *json, const char *tag, json_error_t *err)
+json_t *nft_jansson_create_root(char *json, json_error_t *err)
{
json_t *root;
return NULL;
}
- root = json_object_get(root, tag);
- if (root == NULL) {
+ return root;
+}
+
+json_t *nft_jansson_get_node(json_t *root, const char *tag)
+{
+ json_t *node;
+
+ node = json_object_get(root, tag);
+ if (node == NULL) {
errno = EINVAL;
return NULL;
}
- return root;
+ return node;
}
+
+void nft_jansson_free_root(json_t *root)
+{
+ json_decref(root);
+}
+
int nft_jansson_parse_family(json_t *root, void *out)
{
const char *str;
static int nft_table_json_parse(struct nft_table *t, char *json)
{
#ifdef JSON_PARSING
- json_t *root;
+ json_t *root, *node;
json_error_t error;
uint32_t table_flag;
const char *str;
int family;
- root = nft_jansson_get_root(json, "table", &error);
+ node = nft_jansson_create_root(json, &error);
+ if (node == NULL)
+ return -1;
+
+ root = nft_jansson_get_node(node, "table");
if (root == NULL)
return -1;
if (str == NULL)
goto err;
- nft_table_attr_set_str(t, NFT_TABLE_ATTR_NAME, strdup(str));
+ nft_table_attr_set_str(t, NFT_TABLE_ATTR_NAME, str);
if (nft_jansson_parse_family(root, &family) != 0)
- return -1;
+ goto err;
nft_table_attr_set_u32(t, NFT_TABLE_ATTR_FAMILY, family);
nft_table_attr_set_u32(t, NFT_TABLE_ATTR_FLAGS, table_flag);
- xfree(root);
+ nft_jansson_free_root(node);
return 0;
err:
- xfree(root);
+ nft_jansson_free_root(node);
return -1;
#else
errno = EOPNOTSUPP;