pf plugin: add very simple rule monitoring
[collectd.git] / src / pf.c
index a52bc9e..02eb5ae 100644 (file)
--- a/src/pf.c
+++ b/src/pf.c
  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  */
 
-#include <sys/types.h>
-#include <sys/ioctl.h>
-#include <sys/socket.h>
-
-#include <net/if.h>
-#include <net/pfvar.h>
-
-#include <limits.h>
-#include <fcntl.h>
-#include <paths.h>
-#include <string.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <errno.h>
-#include <unistd.h>
+#include "pfcommon.h"
 
-#ifndef TEST
-#include "collectd.h"
-#include "common.h"
-#include "plugin.h"
-#include "configfile.h"
-#else
-#include <err.h>
-typedef u_int64_t      counter_t;
-#endif
-
-#define PF_SOCKET "/dev/pf"
-
-struct pfdata {
-       int             pd_dev;
-};
-
-static struct pfdata   pd;
-
-static int             pf_init(void);
-static int             pf_read(void);
-static void            submit_counter(const char *, const char *, counter_t);
+static int     pf_init(void);
+static int     pf_read(void);
+static void    submit_counter(const char *, const char *, counter_t);
 
 void
 submit_counter(const char *type, const char *inst, counter_t val)
@@ -80,38 +48,38 @@ pf_init(void)
 {
        struct pf_status        status;
 
-       memset(&pd, '\0', sizeof(pd));
-
-       if ((pd.pd_dev = open(PF_SOCKET, O_RDWR)) == -1) {
+       if ((dev = open(PF_SOCKET, O_RDWR)) == -1) {
                return (-1);
        }
-       if (ioctl(pd.pd_dev, DIOCGETSTATUS, &status) == -1) {
+       if (ioctl(dev, DIOCGETSTATUS, &status) == -1) {
                return (-1);
        }
-        close(pd.pd_dev);
+
+       close(dev);
        if (!status.running)
                return (-1);
-       
+
        return (0);
 }
 
 int
 pf_read(void)
 {
-       int                      i;
-       struct pf_status         status;
+       int                     i;
+       struct pf_status        status;
 
-       char            *cnames[] = PFRES_NAMES;
-       char            *lnames[] = LCNT_NAMES;
-       char            *names[] = { "searches", "inserts", "removals" };
+       char            *cnames[] = PFRES_NAMES;
+       char            *lnames[] = LCNT_NAMES;
+       char            *names[] = { "searches", "inserts", "removals" };
 
-       if ((pd.pd_dev = open(PF_SOCKET, O_RDWR)) == -1) {
+       if ((dev = open(PF_SOCKET, O_RDWR)) == -1) {
                return (-1);
        }
-       if (ioctl(pd.pd_dev, DIOCGETSTATUS, &status) == -1) {
+       if (ioctl(dev, DIOCGETSTATUS, &status) == -1) {
                return (-1);
        }
-        close(pd.pd_dev);
+
+       close(dev);
        for (i = 0; i < PFRES_MAX; i++)
                submit_counter("pf_counters", cnames[i], status.counters[i]);
        for (i = 0; i < LCNT_MAX; i++)