summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/external_inject.c36
1 files changed, 31 insertions, 5 deletions
diff --git a/src/external_inject.c b/src/external_inject.c
index ec1cb16..8e5bbea 100644
--- a/src/external_inject.c
+++ b/src/external_inject.c
@@ -29,6 +29,15 @@
static struct nfct_handle *inject;
+struct {
+ uint32_t add_ok;
+ uint32_t add_fail;
+ uint32_t upd_ok;
+ uint32_t upd_fail;
+ uint32_t del_ok;
+ uint32_t del_fail;
+} external_inject_stat;
+
static int external_inject_init(void)
{
/* handler to directly inject conntracks into kernel-space */
@@ -65,10 +74,12 @@ retry:
goto retry;
}
}
+ external_inject_stat.add_fail++;
dlog(LOG_ERR, "inject-add1: %s", strerror(errno));
dlog_ct(STATE(log), ct, NFCT_O_PLAIN);
return;
}
+ external_inject_stat.add_fail++;
dlog(LOG_ERR, "inject-add2: %s", strerror(errno));
dlog_ct(STATE(log), ct, NFCT_O_PLAIN);
}
@@ -85,6 +96,7 @@ static void external_inject_upd(struct nf_conntrack *ct)
/* state entries does not exist, we have to create it */
if (errno == ENOENT) {
if (nl_create_conntrack(inject, ct, 0) == -1) {
+ external_inject_stat.upd_fail++;
dlog(LOG_ERR, "inject-upd1: %s", strerror(errno));
dlog_ct(STATE(log), ct, NFCT_O_PLAIN);
}
@@ -97,11 +109,13 @@ static void external_inject_upd(struct nf_conntrack *ct)
ret = nl_destroy_conntrack(inject, ct);
if (ret == 0 || (ret == -1 && errno == ENOENT)) {
if (nl_create_conntrack(inject, ct, 0) == -1) {
+ external_inject_stat.upd_fail++;
dlog(LOG_ERR, "inject-upd2: %s", strerror(errno));
dlog_ct(STATE(log), ct, NFCT_O_PLAIN);
}
return;
}
+ external_inject_stat.upd_fail++;
dlog(LOG_ERR, "inject-upd3: %s", strerror(errno));
dlog_ct(STATE(log), ct, NFCT_O_PLAIN);
}
@@ -110,6 +124,7 @@ static void external_inject_del(struct nf_conntrack *ct)
{
if (nl_destroy_conntrack(inject, ct) == -1) {
if (errno != ENOENT) {
+ external_inject_stat.del_fail++;
dlog(LOG_ERR, "inject-del: %s", strerror(errno));
dlog_ct(STATE(log), ct, NFCT_O_PLAIN);
}
@@ -130,10 +145,21 @@ static void external_inject_flush(void)
static void external_inject_stats(int fd)
{
-}
-
-static void external_inject_stats_ext(int fd)
-{
+ char buf[512];
+ int size;
+
+ size = sprintf(buf, "external inject:\n"
+ "connections created:\t\t%12u\tfailed:\t%12u\n"
+ "connections updated:\t\t%12u\tfailed:\t%12u\n"
+ "connections destroyed:\t\t%12u\tfailed:\t%12u\n\n",
+ external_inject_stat.add_ok,
+ external_inject_stat.add_fail,
+ external_inject_stat.upd_ok,
+ external_inject_stat.upd_fail,
+ external_inject_stat.del_ok,
+ external_inject_stat.del_fail);
+
+ send(fd, buf, size, 0);
}
struct external_handler external_inject = {
@@ -146,5 +172,5 @@ struct external_handler external_inject = {
.commit = external_inject_commit,
.flush = external_inject_flush,
.stats = external_inject_stats,
- .stats_ext = external_inject_stats_ext,
+ .stats_ext = external_inject_stats,
};