aboutsummaryrefslogtreecommitdiffstats
path: root/common/t-mbox-util.c
diff options
context:
space:
mode:
authorWerner Koch <[email protected]>2018-11-12 06:44:33 +0000
committerWerner Koch <[email protected]>2018-11-12 06:44:33 +0000
commit6b9f772914624cc673ba26d49b6e3adc32dd7e0a (patch)
treec4366bbf661f10aba5c1441c299789eb2da2b57a /common/t-mbox-util.c
parentgpg: Fix format string in gpgcompose.c (diff)
downloadgnupg-6b9f772914624cc673ba26d49b6e3adc32dd7e0a.tar.gz
gnupg-6b9f772914624cc673ba26d49b6e3adc32dd7e0a.zip
common: Prepare for parsing mail sub-addresses.
* common/mbox-util.c (mailbox_from_userid): Add arg subaddress and implement. Change all callers to pass false for it. * common/t-mbox-util.c (run_mbox_no_sub_test): New. (run_filter): Add arg no_sub. (main): Call new test and add option --no-sub. -- Some stats: In the about 5300000 keys on the SKS servers we found 3055 unique mailboxes with a '+' in it. After removing leading and trailing '+' as well as multiple '+' (e.g. "c++" or "foo+bar+baz") 2697 were left which seem to be valid sub-addresses. To filter mailboxes out from a line delimited list with user-ids (e.g. an SQL output), the command t-mbox-util --verbose --filter can be used; to output w/o sub-addresses add --no-sub. GnuPG-bug-id: 4200 Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to 'common/t-mbox-util.c')
-rw-r--r--common/t-mbox-util.c95
1 files changed, 91 insertions, 4 deletions
diff --git a/common/t-mbox-util.c b/common/t-mbox-util.c
index e9cf41215..ae717f96f 100644
--- a/common/t-mbox-util.c
+++ b/common/t-mbox-util.c
@@ -83,7 +83,86 @@ run_mbox_test (void)
for (idx=0; testtbl[idx].userid; idx++)
{
- char *mbox = mailbox_from_userid (testtbl[idx].userid);
+ char *mbox = mailbox_from_userid (testtbl[idx].userid, 0);
+
+ if (!testtbl[idx].mbox)
+ {
+ if (mbox)
+ fail (idx);
+ }
+ else if (!mbox)
+ fail (idx);
+ else if (strcmp (mbox, testtbl[idx].mbox))
+ fail (idx);
+
+ xfree (mbox);
+ }
+}
+
+
+static void
+run_mbox_no_sub_test (void)
+{
+ static struct
+ {
+ const char *userid;
+ const char *mbox;
+ } testtbl[] =
+ {
+ { "Werner Koch <[email protected]>", "[email protected]" },
+ { "[email protected] ", NULL },
+ { " [email protected]", NULL },
+ { "Werner Koch (test) <[email protected]>", "[email protected]" },
+ { "Werner Koch <[email protected]> (test)", "[email protected]" },
+ { "Werner Koch <[email protected] (test)", NULL },
+ { "Werner Koch <[email protected] >", NULL },
+ { "Werner Koch <[email protected]", NULL },
+ { "", NULL },
+ { "@", NULL },
+ { "bar <>", NULL },
+ { "<[email protected].>", NULL },
+ { "<[email protected]>", NULL },
+ { "<foo@.>", NULL },
+ { "<@example.org>", NULL },
+ { "<foo@@example.org>", NULL },
+ { "<@[email protected]>", NULL },
+ { "<fo()[email protected]> ()", "fo()[email protected]" },
+ { "<fo()[email protected]> ()", "fo()[email protected]" },
+ { "fo()[email protected]", NULL},
+
+ { NULL, NULL }
+ };
+ int idx;
+
+ for (idx=0; testtbl[idx].userid; idx++)
+ {
+ char *mbox = mailbox_from_userid (testtbl[idx].userid, 1);
if (!testtbl[idx].mbox)
{
@@ -151,7 +230,7 @@ run_dns_test (void)
static void
-run_filter (void)
+run_filter (int no_sub)
{
char buf[4096];
int c;
@@ -172,7 +251,7 @@ run_filter (void)
}
count1++;
trim_spaces (buf);
- mbox = mailbox_from_userid (buf);
+ mbox = mailbox_from_userid (buf, no_sub);
if (mbox)
{
printf ("%s\n", mbox);
@@ -190,6 +269,7 @@ main (int argc, char **argv)
{
int last_argc = -1;
int opt_filter = 0;
+ int opt_no_sub = 0;
if (argc)
{ argc--; argv++; }
@@ -208,6 +288,7 @@ main (int argc, char **argv)
" --verbose Print timings etc.\n"
" --debug Flyswatter\n"
" --filter Filter mboxes from input lines\n"
+ " --no-sub Ignore '+'-sub-addresses\n"
, stdout);
exit (0);
}
@@ -227,6 +308,11 @@ main (int argc, char **argv)
opt_filter = 1;
argc--; argv++;
}
+ else if (!strcmp (*argv, "--no-sub"))
+ {
+ opt_no_sub = 1;
+ argc--; argv++;
+ }
else if (!strncmp (*argv, "--", 2))
{
fprintf (stderr, PGM ": unknown option '%s'\n", *argv);
@@ -235,10 +321,11 @@ main (int argc, char **argv)
}
if (opt_filter)
- run_filter ();
+ run_filter (opt_no_sub);
else
{
run_mbox_test ();
+ run_mbox_no_sub_test ();
run_dns_test ();
}