]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/LeiImportKw.pm
lei: commit store on interrupted partial imports
[public-inbox.git] / lib / PublicInbox / LeiImportKw.pm
index 379101c2dae8c5525242263ba986a295fd66fc3d..4dd938f5c12c85ad41d1ed322aad9a33d59c49b8 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 2021 all contributors <meta@public-inbox.org>
+# Copyright (C) all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 
 # WQ worker for dealing with LeiImport IMAP flags on already-imported messages
@@ -28,31 +28,26 @@ sub ipc_atfork_child {
        $self->{verbose} = $lei->{opt}->{verbose};
        $self->{lse} = $self->{sto}->search;
        $self->{over} = $self->{lse}->over;
-       $self->{-lms_ro} = $net->{-lms_ro} || die 'BUG: net->{-lms_ro} FALSE';
+       $self->{-lms_rw} = $net->{-lms_rw} || die 'BUG: net->{-lms_rw} FALSE';
        $self->SUPER::ipc_atfork_child;
 }
 
 sub ck_update_kw { # via wq_io_do
        my ($self, $url, $uid, $kw) = @_;
-       my $oidbin = $self->{-lms_ro}->imap_oidbin($url, $uid) // return;
-       my @docids = $self->{over}->oidbin_exists($oidbin) or return;
+       my @oidbin = $self->{-lms_rw}->num_oidbin($url, $uid);
+       my $uid_url = "$url/;UID=$uid";
+       @oidbin > 1 and warn("W: $uid_url not unique:\n",
+                               map { "\t".unpack('H*', $_)."\n" } @oidbin);
+       my %seen;
+       my @docids = sort { $a <=> $b } grep { !$seen{$_}++ }
+               map { $self->{over}->oidbin_exists($_) } @oidbin;
        $self->{lse}->kw_changed(undef, $kw, \@docids) or return;
-       $self->{verbose} and
-               $self->{lei}->qerr('# '.unpack('H*', $oidbin)." => @$kw\n");
+       $self->{verbose} and $self->{lei}->qerr("# $uid_url => @$kw\n");
        $self->{sto}->wq_do('set_eml_vmd', undef, { kw => $kw }, \@docids);
 }
 
-sub ikw_done_wait {
-       my ($arg, $pid) = @_;
-       my ($self, $lei) = @$arg;
-       $lei->can('wq_done_wait')->($arg, $pid);
-}
-
 sub _lei_wq_eof { # EOF callback for main lei daemon
-       my ($lei) = @_;
-       my $ikw = delete $lei->{ikw} or return $lei->fail;
-       $lei->sto_done_request($ikw->{lei_sock});
-       $ikw->wq_wait_old(\&ikw_done_wait, $lei);
+       $_[0]->wq_eof('ikw');
 }
 
 1;