Blob


1 #!/usr/bin/env perl
2 #
3 # smingest was written by Omar Polo <op@openbsd.org> and is placed in the
4 # public domain. The author hereby disclaims copyright to this source
5 # code.
7 use strict;
8 use warnings;
9 use v5.32;
10 use utf8;
12 use Date::Parse;
13 use File::Basename;
15 die "usage: $0 dbpath\n" if @ARGV != 1;
16 my $dbpath = shift @ARGV;
18 open(my $sqlite, "|-", "sqlite3", $dbpath) or die "can't spawn sqlite3";
20 if (`uname` =~ "OpenBSD") {
21 use OpenBSD::Pledge;
22 use OpenBSD::Unveil;
24 unveil("/usr/local/bin/mshow", "rx") or die "unveil mshow: $!";
25 pledge("stdio proc exec") or die "pledge: $!";
26 }
28 say $sqlite ".import --csv /dev/stdin email"
29 or die "can't speak to sqlite: $!";
31 while (<>) {
32 chomp;
34 open(my $fh, "-|", "mshow", "-Atext/plain", "-NF", $_)
35 or die "can't run mshow $_: $!";
37 my ($time, $id) = split /\./, basename $_;
38 my $mid = "$time.$id";
39 $mid =~ s/"/""/g;
41 my ($from, $subj, $date) = ('', '', undef);
42 while (<$fh>) {
43 chomp;
44 last if /^$/;
45 s/"/""/g;
46 $from = s/.*?: //r if /^From:/;
47 $subj = s/.*?: //r if /^Subject:/;
48 $date = str2time(s/.*?: //r) if /^Date:/;
49 }
50 $date //= time;
51 $from =~ s/ +<.*>//;
53 print $sqlite "\"$mid\",\"$from\",\"$date\",\"$subj\",\"";
54 while (<$fh>) {
55 s/"/""/g;
56 print $sqlite $_;
57 }
58 print $sqlite "\"\r\n";
60 close $fh;
61 }
63 close $sqlite;
64 die "sqlite3 exited with $?\n" unless $? == 0;