Add new function to read nftables command from a file

Signed-off-by: Eric Leblond <e...@regit.org>
---
 include/nftables/nftables.h |  2 ++
 src/libnftables.c           | 25 +++++++++++++++++++++++++
 src/main.c                  | 16 +++-------------
 3 files changed, 30 insertions(+), 13 deletions(-)

diff --git a/include/nftables/nftables.h b/include/nftables/nftables.h
index 63150ba..980c6ec 100644
--- a/include/nftables/nftables.h
+++ b/include/nftables/nftables.h
@@ -22,5 +22,7 @@ void nft_context_free(struct nft_ctx *nft);
 
 int nft_run_command_from_buffer(struct nft_ctx *nft, struct nft_cache *cache,
                                char *buf, size_t buflen);
+int nft_run_command_from_filename(struct nft_ctx *nft, struct nft_cache *cache,
+                                 const char *filename);
 
 #endif
diff --git a/src/libnftables.c b/src/libnftables.c
index 9248741..8c92fbf 100644
--- a/src/libnftables.c
+++ b/src/libnftables.c
@@ -93,5 +93,30 @@ int nft_run_command_from_buffer(struct nft_ctx *nft, struct 
nft_cache *cache,
        if (nft_run(nft, nft->nf_sock, cache, scanner, &state, &msgs) != 0)
                rc = NFT_EXIT_FAILURE;
 
+       scanner_destroy(scanner);
+       erec_print_list(stderr, &msgs);
+       return rc;
+}
+
+int nft_run_command_from_filename(struct nft_ctx *nft, struct nft_cache *cache,
+                                 const char *filename)
+{
+       int rc = NFT_EXIT_SUCCESS;
+       struct parser_state state;
+       LIST_HEAD(msgs);
+       void *scanner;
+
+       rc = cache_update(nft->nf_sock, cache, CMD_INVALID, &msgs);
+       if (rc < 0)
+               return rc;
+       parser_init(nft->nf_sock, cache, &state, &msgs);
+       scanner = scanner_init(&state);
+       if (scanner_read_file(scanner, filename, &internal_location) < 0)
+               return NFT_EXIT_FAILURE;
+       if (nft_run(nft, nft->nf_sock, cache, scanner, &state, &msgs) != 0)
+               rc = NFT_EXIT_FAILURE;
+
+       scanner_destroy(scanner);
+       erec_print_list(stderr, &msgs);
        return rc;
 }
diff --git a/src/main.c b/src/main.c
index f863dec..658988d 100644
--- a/src/main.c
+++ b/src/main.c
@@ -271,7 +271,6 @@ int main(int argc, char * const *argv)
 {
        struct parser_state state;
        struct nft_cache cache;
-       void *scanner;
        LIST_HEAD(msgs);
        char *buf = NULL, *filename = NULL;
        unsigned int len;
@@ -383,18 +382,12 @@ int main(int argc, char * const *argv)
                rc = nft_run_command_from_buffer(nft, &cache, buf, len + 2);
                if (rc < 0)
                        return rc;
-               goto libout;
+               goto out;
        } else if (filename != NULL) {
-               rc = cache_update(nft->nf_sock, &cache, CMD_INVALID, &msgs);
+               rc = nft_run_command_from_filename(nft, &cache, filename);
                if (rc < 0)
                        return rc;
-
-               parser_init(nft->nf_sock, &cache, &state, &msgs);
-               scanner = scanner_init(&state);
-               if (scanner_read_file(scanner, filename, &internal_location) < 
0)
-                       goto out;
-               if (nft_run(nft, nft->nf_sock, &cache, scanner, &state, &msgs) 
!= 0)
-                       rc = NFT_EXIT_FAILURE;
+               goto out;
        } else if (interactive) {
                if (cli_init(nft, nft->nf_sock, &cache, &state) < 0) {
                        fprintf(stderr, "%s: interactive CLI not supported in 
this build\n",
@@ -408,9 +401,6 @@ int main(int argc, char * const *argv)
        }
 
 out:
-       scanner_destroy(scanner);
-       erec_print_list(stderr, &msgs);
-libout:
        xfree(buf);
        cache_release(&cache);
        iface_cache_release();
-- 
2.14.1

--
To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to