about summary refs log tree commit homepage
path: root/lib/PublicInbox/LeiMailSync.pm
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-05-29 20:20:38 +0000
committerEric Wong <e@80x24.org>2021-05-30 05:02:41 +0000
commit528d69bbbda3cd26d9cc317eff92d21d980b2056 (patch)
tree2d49a4e6cfcc4fd61ffa98ca431619277a1cf606 /lib/PublicInbox/LeiMailSync.pm
parent8299d33f315ec2f923dd8b9b45f49403af5912aa (diff)
downloadpublic-inbox-528d69bbbda3cd26d9cc317eff92d21d980b2056.tar.gz
lcat can now dump the memoized contents of entire IMAP folders,
not just a single UID.  It's now parallelized and pipelined for
multiple lei2mail workers.

Furthemore, various forms of JSON output work consistently
with blob-only output, now.

While working on this, I noticed NetReader was passing UID URLs
to imap_each callbacks, which was causing mail_sync.sqlite3 to
store UIDs in `folders' and clearly wrong so it's now fixed.
Diffstat (limited to 'lib/PublicInbox/LeiMailSync.pm')
-rw-r--r--lib/PublicInbox/LeiMailSync.pm23
1 files changed, 14 insertions, 9 deletions
diff --git a/lib/PublicInbox/LeiMailSync.pm b/lib/PublicInbox/LeiMailSync.pm
index 5c0988b5..c7f78239 100644
--- a/lib/PublicInbox/LeiMailSync.pm
+++ b/lib/PublicInbox/LeiMailSync.pm
@@ -64,9 +64,9 @@ CREATE TABLE IF NOT EXISTS blob2name (
 
 }
 
-sub _fid_for {
+sub fid_for {
         my ($self, $folder, $rw) = @_;
-        my $dbh = $self->{dbh};
+        my $dbh = $self->{dbh} //= dbh_new($self, $rw);
         my $sel = 'SELECT fid FROM folders WHERE loc = ? LIMIT 1';
         my ($fid) = $dbh->selectrow_array($sel, undef, $folder);
         return $fid if defined $fid;
@@ -111,7 +111,7 @@ EOM
 
 sub set_src {
         my ($self, $oidhex, $folder, $id) = @_;
-        my $fid = $self->{fmap}->{$folder} //= _fid_for($self, $folder, 1);
+        my $fid = $self->{fmap}->{$folder} //= fid_for($self, $folder, 1);
         my $sth;
         if (ref($id)) { # scalar name
                 $id = $$id;
@@ -128,7 +128,7 @@ INSERT OR IGNORE INTO blob2num (oidbin, fid, uid) VALUES (?, ?, ?)
 
 sub clear_src {
         my ($self, $folder, $id) = @_;
-        my $fid = $self->{fmap}->{$folder} //= _fid_for($self, $folder, 1);
+        my $fid = $self->{fmap}->{$folder} //= fid_for($self, $folder, 1);
         my $sth;
         if (ref($id)) { # scalar name
                 $id = $$id;
@@ -146,7 +146,7 @@ DELETE FROM blob2num WHERE fid = ? AND uid = ?
 # Maildir-only
 sub mv_src {
         my ($self, $folder, $oidbin, $id, $newbn) = @_;
-        my $fid = $self->{fmap}->{$folder} //= _fid_for($self, $folder, 1);
+        my $fid = $self->{fmap}->{$folder} //= fid_for($self, $folder, 1);
         my $sth = $self->{dbh}->prepare_cached(<<'');
 UPDATE blob2name SET name = ? WHERE fid = ? AND oidbin = ? AND name = ?
 
@@ -158,7 +158,12 @@ sub each_src {
         my ($self, $folder, $cb, @args) = @_;
         my $dbh = $self->{dbh} //= dbh_new($self);
         my ($fid, $sth);
-        $fid = $self->{fmap}->{$folder} //= _fid_for($self, $folder) // return;
+        if (ref($folder) eq 'HASH') {
+                $fid = $folder->{fid} // die "BUG: no `fid'";
+        } else {
+                $fid = $self->{fmap}->{$folder} //=
+                        fid_for($self, $folder) // return;
+        }
         $sth = $dbh->prepare('SELECT oidbin,uid FROM blob2num WHERE fid = ?');
         $sth->execute($fid);
         while (my ($oidbin, $id) = $sth->fetchrow_array) {
@@ -176,7 +181,7 @@ sub location_stats {
         my $dbh = $self->{dbh} //= dbh_new($self);
         my $fid;
         my $ret = {};
-        $fid = $self->{fmap}->{$folder} //= _fid_for($self, $folder) // return;
+        $fid = $self->{fmap}->{$folder} //= fid_for($self, $folder) // return;
         my ($row) = $dbh->selectrow_array(<<"", undef, $fid);
 SELECT COUNT(name) FROM blob2name WHERE fid = ?
 
@@ -349,7 +354,7 @@ sub forget_folder {
         my ($self, $folder) = @_;
         my ($fid, $sth);
         $fid = delete($self->{fmap}->{$folder}) //
-                _fid_for($self, $folder) // return;
+                fid_for($self, $folder) // return;
         my $dbh = $self->{dbh};
         $dbh->do('DELETE FROM blob2name WHERE fid = ?', undef, $fid);
         $dbh->do('DELETE FROM blob2num WHERE fid = ?', undef, $fid);
@@ -369,7 +374,7 @@ sub imap_oid {
                 $lei->qerr(@{$err->{qerr}}) if $err->{qerr};
         }
         my $fid = $self->{fmap}->{$folders->[0]} //=
-                _fid_for($self, $folders->[0]) // return;
+                fid_for($self, $folders->[0]) // return;
         my $sth = $self->{dbh}->prepare_cached(<<EOM, undef, 1);
 SELECT oidbin FROM blob2num WHERE fid = ? AND uid = ?
 EOM