]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/NetWriter.pm
lei: fix read/write IMAP access
[public-inbox.git] / lib / PublicInbox / NetWriter.pm
index 06d69f2787a6d218e78bfadfbaae8b1661bae158..629a752ae79a3b3b1c1ea8ed91e029f925801268 100644 (file)
@@ -26,20 +26,11 @@ sub imap_append {
                die "APPEND $folder: $@";
 }
 
-sub mic_for_folder {
-       my ($self, $uri) = @_;
-       if (!ref($uri)) {
-               my $u = PublicInbox::URIimap->new($uri);
-               $_[1] = $uri = $u;
-       }
-       my $mic = $self->mic_get($uri) or die "E: not connected: $@";
-       $mic->select($uri->mailbox) or return;
-       $mic;
-}
+sub folder_select { 'select' } # for PublicInbox::NetReader
 
 sub imap_delete_all {
-       my ($self, $url) = @_;
-       my $mic = mic_for_folder($self, my $uri = $url) or return;
+       my ($self, $uri) = @_;
+       my $mic = $self->mic_for_folder($uri) or return;
        my $sec = $self->can('uri_section')->($uri);
        local $0 = $uri->mailbox." $sec";
        if ($mic->delete_message('1:*')) {
@@ -48,8 +39,8 @@ sub imap_delete_all {
 }
 
 sub imap_delete_1 {
-       my ($self, $url, $uid, $delete_mic) = @_;
-       $$delete_mic //= mic_for_folder($self, my $uri = $url) or return;
+       my ($self, $uri, $uid, $delete_mic) = @_;
+       $$delete_mic //= $self->mic_for_folder($uri) or return;
        $$delete_mic->delete_message($uid);
 }