diff options
Diffstat (limited to 'perl/lib/Mail/Rspamd/Client.pm')
-rw-r--r-- | perl/lib/Mail/Rspamd/Client.pm | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/perl/lib/Mail/Rspamd/Client.pm b/perl/lib/Mail/Rspamd/Client.pm index 529a2bf9b..5c6182868 100644 --- a/perl/lib/Mail/Rspamd/Client.pm +++ b/perl/lib/Mail/Rspamd/Client.pm @@ -1251,7 +1251,7 @@ sub _parse_imap_sequences { } -sub process_imap { +sub _process_imap { my ($self, $ssl, $user, $password, $host, $mbox) = @_; my $seq = 1; my $sock; @@ -1259,13 +1259,13 @@ sub process_imap { if (!$password) { eval { require Term::ReadKey; - Term::ReadKey->import( LIST ); - $self->{error} = "Enter IMAP password: "; - Term::ReadKey->ReadMode('noecho'); - $password = Term::ReadKey->ReadLine(0); + Term::ReadKey->import( qw(ReadMode ReadLine) ); + print "Enter IMAP password: "; + ReadMode(2); + $password = ReadLine(0); chomp $password; - Term::ReadKey->ReadMode('normal'); - $self->{error} = "\n"; + ReadMode(0); + print "\n"; } or croak "cannot get password. Check that Term::ReadKey is installed"; } @@ -1274,7 +1274,15 @@ sub process_imap { $sock = $self->_make_ssl_socket ($host, 'imaps'); } else { - $sock = $self->_make_tcp_socket ($host, 143); + $sock = IO::Socket::INET->new( Proto => "tcp", + PeerAddr => $host, + PeerPort => 'imap', + Blocking => 1, + ); + } + unless ($sock) { + $self->{error} = "Cannot connect to imap server: $!"; + return; } my $reply = <$sock>; if (!defined ($reply) || $reply !~ /^\* OK/) { |