]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/NetWriter.pm
lei convert: support IMAP output and "-F eml" inputs
[public-inbox.git] / lib / PublicInbox / NetWriter.pm
index 6f0a0b94e7527b81429e7bc4ff3723d6666b1d62..e26e9815610a3680aab3e6dc05a1321f9f94c1e9 100644 (file)
@@ -16,11 +16,24 @@ my %IMAPkw2flags;
 sub imap_append {
        my ($mic, $folder, $bref, $smsg, $eml) = @_;
        $bref //= \($eml->as_string);
-       $smsg //= bless { }, 'PublicInbox::Smsg';
+       $smsg //= bless {}, 'PublicInbox::Smsg';
+       bless($smsg, 'PublicInbox::Smsg') if ref($smsg) eq 'HASH';
        $smsg->{ts} //= msg_timestamp($eml // PublicInbox::Eml->new($$bref));
        my @f = map { $IMAPkw2flags{$_} } @{$smsg->{kw}};
        $mic->append_string($folder, $$bref, "@f", $smsg->internaldate) or
                die "APPEND $folder: $@";
 }
 
+sub imap_delete_all {
+       my ($self, $url) = @_;
+       my $uri = PublicInbox::URIimap->new($url);
+       my $sec = $self->can('uri_section')->($uri);
+       local $0 = $uri->mailbox." $sec";
+       my $mic = $self->mic_get($uri) or die "E: not connected: $@";
+       $mic->select($uri->mailbox) or return; # non-existent
+       if ($mic->delete_message('1:*')) {
+               $mic->expunge;
+       }
+}
+
 1;