diff options
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/spamdb/spamdb.c | 63 |
1 files changed, 17 insertions, 46 deletions
diff --git a/usr.sbin/spamdb/spamdb.c b/usr.sbin/spamdb/spamdb.c index 74cdcad2bdb..137e965352f 100644 --- a/usr.sbin/spamdb/spamdb.c +++ b/usr.sbin/spamdb/spamdb.c @@ -1,4 +1,4 @@ -/* $OpenBSD: spamdb.c,v 1.7 2004/03/11 18:14:21 beck Exp $ */ +/* $OpenBSD: spamdb.c,v 1.8 2004/04/19 18:21:09 otto Exp $ */ /* * Copyright (c) 2004 Bob Beck. All rights reserved. @@ -18,48 +18,18 @@ #include <sys/types.h> #include <sys/socket.h> -#include <sys/ioctl.h> -#include <sys/fcntl.h> -#include <sys/wait.h> -#include <net/if.h> #include <netinet/in.h> -#include <net/pfvar.h> #include <arpa/inet.h> #include <db.h> #include <err.h> -#include <errno.h> #include <fcntl.h> -#include <pwd.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <time.h> -#include <unistd.h> #include "grey.h" -extern struct passwd *pw; -extern FILE * grey; -extern int debug; - -size_t whitecount, whitealloc; -char **whitelist; -int pfdev; - -/* borrowed from dhartmei.. */ -static int -address_valid_v4(const char *a) -{ - if (!*a) - return (0); - while (*a) - if ((*a >= '0' && *a <= '9') || *a == '.') - a++; - else - return (0); - return (1); -} - int dbupdate(char *dbname, char *ip, int add) { @@ -69,14 +39,15 @@ dbupdate(char *dbname, char *ip, int add) struct gdata gd; time_t now; int r; + struct in_addr ia; now = time(NULL); memset(&btreeinfo, 0, sizeof(btreeinfo)); db = dbopen(dbname, O_EXLOCK|O_RDWR, 0600, DB_BTREE, &btreeinfo); if (db == NULL) - return(-1); - if (!address_valid_v4(ip)) { - warnx("invalid ip address %s\n", ip); + err(1, "cannot open %s for writing", dbname); + if (inet_pton(AF_INET, ip, &ia) != 1) { + warnx("invalid ip address %s", ip); goto bad; } memset(&dbk, 0, sizeof(dbk)); @@ -150,7 +121,7 @@ dbupdate(char *dbname, char *ip, int add) bad: db->close(db); db = NULL; - return(-1); + return (1); } int @@ -166,7 +137,7 @@ dblist(char *dbname) memset(&btreeinfo, 0, sizeof(btreeinfo)); db = dbopen(dbname, O_EXLOCK|O_RDONLY, 0600, DB_BTREE, &btreeinfo); if (db == NULL) - err(1, "dbopen"); + err(1, "cannot open %s for reading", dbname); memset(&dbk, 0, sizeof(dbk)); memset(&dbd, 0, sizeof(dbd)); for (r = db->seq(db, &dbk, &dbd, R_FIRST); !r; @@ -210,19 +181,21 @@ dblist(char *dbname) } db->close(db); db = NULL; - return(0); + return (0); bad: db->close(db); db = NULL; errx(1, "incorrect db format entry"); /* NOTREACHED */ - return(-1); + return (1); } +extern char *__progname; + static int usage(void) { - fprintf(stderr, "usage: spamdb [-a ip] [-d ip]\n"); + fprintf(stderr, "usage: %s [-a ip] [-d ip]\n", __progname); exit(1); } @@ -250,16 +223,14 @@ main(int argc, char **argv) switch (action) { case 0: - dblist(PATH_SPAMD_DB); - break; + return dblist(PATH_SPAMD_DB); case 1: - dbupdate(PATH_SPAMD_DB, ip, 1); - break; + return dbupdate(PATH_SPAMD_DB, ip, 1); case 2: - dbupdate(PATH_SPAMD_DB, ip, 0); - break; + return dbupdate(PATH_SPAMD_DB, ip, 0); default: errx(-1, "bad action"); } - return(0); + /* NOT REACHED */ + return (0); } |