about summary refs log tree commit homepage
path: root/lib/PublicInbox/NetReader.pm
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-04-24 09:28:43 +0000
committerEric Wong <e@80x24.org>2021-04-24 16:10:01 -0400
commit15a3ec65a3ad0c1dcd686c2075d3f68730d416de (patch)
treefac93e5a1ca53e27a7c6c165942c4d482da7a3d7 /lib/PublicInbox/NetReader.pm
parent7ed233d847467ef2a963bf3f6dd25b1ee1cb1b1e (diff)
downloadpublic-inbox-15a3ec65a3ad0c1dcd686c2075d3f68730d416de.tar.gz
This will allow the callback to reliably maintain OID <=> UID
mappings between lei/store and the IMAP folder.
Diffstat (limited to 'lib/PublicInbox/NetReader.pm')
-rw-r--r--lib/PublicInbox/NetReader.pm11
1 files changed, 7 insertions, 4 deletions
diff --git a/lib/PublicInbox/NetReader.pm b/lib/PublicInbox/NetReader.pm
index 39129b34..5978752f 100644
--- a/lib/PublicInbox/NetReader.pm
+++ b/lib/PublicInbox/NetReader.pm
@@ -347,7 +347,7 @@ sub errors {
 }
 
 sub _imap_do_msg ($$$$$) {
-        my ($self, $uri, $uid, $raw, $flags) = @_;
+        my ($self, $url, $uid, $raw, $flags) = @_;
         # our target audience expects LF-only, save storage
         $$raw =~ s/\r\n/\n/sg;
         my $kw = [];
@@ -358,12 +358,12 @@ sub _imap_do_msg ($$$$$) {
                 } elsif ($f eq "\\Deleted") { # not in JMAP
                         return;
                 } elsif ($self->{verbose}) {
-                        warn "# unknown IMAP flag $f <$uri;uid=$uid>\n";
+                        warn "# unknown IMAP flag $f <$url/;UID=$uid>\n";
                 }
         }
         @$kw = sort @$kw; # for all UI/UX purposes
         my ($eml_cb, @args) = @{$self->{eml_each}};
-        $eml_cb->($uri, $uid, $kw, PublicInbox::Eml->new($raw), @args);
+        $eml_cb->($url, $uid, $kw, PublicInbox::Eml->new($raw), @args);
 }
 
 sub run_commit_cb ($) {
@@ -396,6 +396,9 @@ sub _imap_fetch_all ($$$) {
                 return "E: $uri cannot get UIDVALIDITY";
         $r_uidnext //= $mic->uidnext($mbx) //
                 return "E: $uri cannot get UIDNEXT";
+        my $url = ref($uri)->new($$uri);
+        $url->uidvalidity($r_uidval);
+        $url = $$url;
         my $itrk = _itrk($self, $uri);
         my $l_uid;
         $l_uid = $itrk->get_last($r_uidval) if $itrk;
@@ -455,7 +458,7 @@ sub _imap_fetch_all ($$$) {
                                 # messages get deleted, so holes appear
                                 my $per_uid = delete $r->{$uid} // next;
                                 my $raw = delete($per_uid->{$key}) // next;
-                                _imap_do_msg($self, $uri, $uid, \$raw,
+                                _imap_do_msg($self, $url, $uid, \$raw,
                                                 $per_uid->{FLAGS});
                                 $last_uid = $uid;
                                 last if $self->{quit};