diff options
author | Steve Holme <steve_holme@hotmail.com> | 2013-09-08 22:53:27 +0100 |
---|---|---|
committer | Steve Holme <steve_holme@hotmail.com> | 2013-09-09 17:13:25 +0100 |
commit | 313c38c9de204f7806dd25db8dccc282358b8b11 (patch) | |
tree | c8313cc3d7af233e19e36f88f5ae94df16030430 | |
parent | ae6096471a3d3b30d37ad80931adce5139c5dcf0 (diff) |
ftpserver.pl: Added support for POP3 TOP command
-rwxr-xr-x | tests/ftpserver.pl | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/ftpserver.pl b/tests/ftpserver.pl index 0b495c67d..dc1c0815a 100755 --- a/tests/ftpserver.pl +++ b/tests/ftpserver.pl @@ -564,6 +564,7 @@ sub protocolsetup { 'QUIT' => \&QUIT_pop3, 'RETR' => \&RETR_pop3, 'STAT' => \&STAT_pop3, + 'TOP' => \&TOP_pop3, 'UIDL' => \&UIDL_pop3, ); %displaytext = ( @@ -1400,6 +1401,52 @@ sub UIDL_pop3 { return 0; } +sub TOP_pop3 { + my ($args) = @_; + my ($msg, $lines) = split(/ /, $args, 2); + + logmsg "TOP_pop3 got $args\n"; + + if (($msg eq "") || ($lines eq "")) { + sendcontrol "-ERR Protocol error\r\n"; + } + else { + my @data; + + if ($lines == "0") { + logmsg "retrieve header of mail\n"; + } + else { + logmsg "retrieve top $lines lines of mail\n"; + } + + my $testno = $msg; + $testno =~ s/^([^0-9]*)//; + my $testpart = ""; + if ($testno > 10000) { + $testpart = $testno % 10000; + $testno = int($testno / 10000); + } + + loadtest("$srcdir/data/test$testno"); + + @data = getpart("reply", "data$testpart"); + + sendcontrol "+OK Mail transfer starts\r\n"; + + # Send mail content + for my $d (@data) { + sendcontrol $d; + } + + # End with the magic 3-byte end of mail marker, assumes that the + # mail body ends with a CRLF! + sendcontrol ".\r\n"; + } + + return 0; +} + sub QUIT_pop3 { sendcontrol "+OK byebye\r\n"; |