summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/smtpd/map.c26
-rw-r--r--usr.sbin/smtpd/smtpd.h8
2 files changed, 32 insertions, 2 deletions
diff --git a/usr.sbin/smtpd/map.c b/usr.sbin/smtpd/map.c
index 4e8a5737cff..3b159c77ca4 100644
--- a/usr.sbin/smtpd/map.c
+++ b/usr.sbin/smtpd/map.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: map.c,v 1.10 2010/04/21 19:37:32 gilles Exp $ */
+/* $OpenBSD: map.c,v 1.11 2010/04/21 19:45:07 gilles Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -35,6 +35,7 @@
#include "smtpd.h"
struct map_backend *map_backend_lookup(enum map_src);
+struct map_parser *map_parser_lookup(enum map_kind);
/* db(3) backend */
void *map_db_open(char *);
@@ -62,6 +63,15 @@ struct map_backend {
map_stdio_open, map_stdio_close, map_stdio_get, map_stdio_put },
};
+struct map_parser {
+ enum map_kind kind;
+ void *(*extract)(char *, size_t len);
+} map_parsers[] = {
+ { K_NONE, NULL },
+ { K_ALIASES, NULL },
+ { K_CREDENTIALS, NULL }
+};
+
struct map *
map_findbyname(struct smtpd *env, const char *name)
{
@@ -127,6 +137,20 @@ map_backend_lookup(enum map_src source)
return &map_backends[i];
}
+struct map_parser *
+map_parser_lookup(enum map_kind kind)
+{
+ u_int8_t i;
+
+ for (i = 0; i < nitems(map_parsers); ++i)
+ if (map_parsers[i].kind == kind)
+ break;
+
+ if (i == nitems(map_parsers))
+ fatalx("invalid map kind");
+
+ return &map_parsers[i];
+}
/* db(3) backend */
void *
diff --git a/usr.sbin/smtpd/smtpd.h b/usr.sbin/smtpd/smtpd.h
index bdbf1d52bf9..eb4aed746fb 100644
--- a/usr.sbin/smtpd/smtpd.h
+++ b/usr.sbin/smtpd/smtpd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: smtpd.h,v 1.175 2010/04/21 18:54:43 jacekm Exp $ */
+/* $OpenBSD: smtpd.h,v 1.176 2010/04/21 19:45:07 gilles Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -249,6 +249,12 @@ enum map_src {
S_EXT
};
+enum map_kind {
+ K_NONE,
+ K_ALIASES,
+ K_CREDENTIALS
+};
+
enum mapel_type {
ME_STRING,
ME_NET,