mirror of
https://github.com/moparisthebest/curl
synced 2024-12-21 15:48:49 -05:00
sasl_getmesssage: make sure we have a long enough string to pass
For pop3/imap/smtp, added test 891 to somewhat verify the pop3 case. For this, I enhanced the pingpong test server to be able to send back responses with LF-only instead of always using CRLF. Closes #2150
This commit is contained in:
parent
4401409468
commit
615edc1f73
@ -344,15 +344,16 @@ static bool imap_endofresp(struct connectdata *conn, char *line, size_t len,
|
|||||||
*/
|
*/
|
||||||
static void imap_get_message(char *buffer, char **outptr)
|
static void imap_get_message(char *buffer, char **outptr)
|
||||||
{
|
{
|
||||||
size_t len = 0;
|
size_t len = strlen(buffer);
|
||||||
char *message = NULL;
|
char *message = NULL;
|
||||||
|
|
||||||
|
if(len > 2) {
|
||||||
/* Find the start of the message */
|
/* Find the start of the message */
|
||||||
for(message = buffer + 2; *message == ' ' || *message == '\t'; message++)
|
for(message = buffer + 2; *message == ' ' || *message == '\t'; message++)
|
||||||
;
|
;
|
||||||
|
|
||||||
/* Find the end of the message */
|
/* Find the end of the message */
|
||||||
for(len = strlen(message); len--;)
|
for(len -= 2; len--;)
|
||||||
if(message[len] != '\r' && message[len] != '\n' && message[len] != ' ' &&
|
if(message[len] != '\r' && message[len] != '\n' && message[len] != ' ' &&
|
||||||
message[len] != '\t')
|
message[len] != '\t')
|
||||||
break;
|
break;
|
||||||
@ -361,6 +362,10 @@ static void imap_get_message(char *buffer, char **outptr)
|
|||||||
if(++len) {
|
if(++len) {
|
||||||
message[len] = '\0';
|
message[len] = '\0';
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
/* junk input => zero length output */
|
||||||
|
message = &buffer[len];
|
||||||
|
|
||||||
*outptr = message;
|
*outptr = message;
|
||||||
}
|
}
|
||||||
|
@ -243,15 +243,16 @@ static bool pop3_endofresp(struct connectdata *conn, char *line, size_t len,
|
|||||||
*/
|
*/
|
||||||
static void pop3_get_message(char *buffer, char **outptr)
|
static void pop3_get_message(char *buffer, char **outptr)
|
||||||
{
|
{
|
||||||
size_t len = 0;
|
size_t len = strlen(buffer);
|
||||||
char *message = NULL;
|
char *message = NULL;
|
||||||
|
|
||||||
|
if(len > 2) {
|
||||||
/* Find the start of the message */
|
/* Find the start of the message */
|
||||||
for(message = buffer + 2; *message == ' ' || *message == '\t'; message++)
|
for(message = buffer + 2; *message == ' ' || *message == '\t'; message++)
|
||||||
;
|
;
|
||||||
|
|
||||||
/* Find the end of the message */
|
/* Find the end of the message */
|
||||||
for(len = strlen(message); len--;)
|
for(len -= 2; len--;)
|
||||||
if(message[len] != '\r' && message[len] != '\n' && message[len] != ' ' &&
|
if(message[len] != '\r' && message[len] != '\n' && message[len] != ' ' &&
|
||||||
message[len] != '\t')
|
message[len] != '\t')
|
||||||
break;
|
break;
|
||||||
@ -260,6 +261,10 @@ static void pop3_get_message(char *buffer, char **outptr)
|
|||||||
if(++len) {
|
if(++len) {
|
||||||
message[len] = '\0';
|
message[len] = '\0';
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
/* junk input => zero length output */
|
||||||
|
message = &buffer[len];
|
||||||
|
|
||||||
*outptr = message;
|
*outptr = message;
|
||||||
}
|
}
|
||||||
|
@ -232,15 +232,16 @@ static bool smtp_endofresp(struct connectdata *conn, char *line, size_t len,
|
|||||||
*/
|
*/
|
||||||
static void smtp_get_message(char *buffer, char **outptr)
|
static void smtp_get_message(char *buffer, char **outptr)
|
||||||
{
|
{
|
||||||
size_t len = 0;
|
size_t len = strlen(buffer);
|
||||||
char *message = NULL;
|
char *message = NULL;
|
||||||
|
|
||||||
|
if(len > 4) {
|
||||||
/* Find the start of the message */
|
/* Find the start of the message */
|
||||||
for(message = buffer + 4; *message == ' ' || *message == '\t'; message++)
|
for(message = buffer + 4; *message == ' ' || *message == '\t'; message++)
|
||||||
;
|
;
|
||||||
|
|
||||||
/* Find the end of the message */
|
/* Find the end of the message */
|
||||||
for(len = strlen(message); len--;)
|
for(len -= 4; len--;)
|
||||||
if(message[len] != '\r' && message[len] != '\n' && message[len] != ' ' &&
|
if(message[len] != '\r' && message[len] != '\n' && message[len] != ' ' &&
|
||||||
message[len] != '\t')
|
message[len] != '\t')
|
||||||
break;
|
break;
|
||||||
@ -249,6 +250,10 @@ static void smtp_get_message(char *buffer, char **outptr)
|
|||||||
if(++len) {
|
if(++len) {
|
||||||
message[len] = '\0';
|
message[len] = '\0';
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
/* junk input => zero length output */
|
||||||
|
message = &buffer[len];
|
||||||
|
|
||||||
*outptr = message;
|
*outptr = message;
|
||||||
}
|
}
|
||||||
|
@ -124,6 +124,8 @@ REPLY [command] [return value] [response string]
|
|||||||
evaluated as a perl string, so it can contain embedded \r\n, for example.
|
evaluated as a perl string, so it can contain embedded \r\n, for example.
|
||||||
There's a special [command] named "welcome" (without quotes) which is the
|
There's a special [command] named "welcome" (without quotes) which is the
|
||||||
string sent immediately on connect as a welcome.
|
string sent immediately on connect as a welcome.
|
||||||
|
REPLYLF (like above but sends the response terminated with LF-only and not
|
||||||
|
CRLF)
|
||||||
COUNT [command] [num]
|
COUNT [command] [num]
|
||||||
- Do the REPLY change for [command] only [num] times and then go back to the
|
- Do the REPLY change for [command] only [num] times and then go back to the
|
||||||
built-in approach
|
built-in approach
|
||||||
|
@ -95,7 +95,7 @@ test850 test851 test852 test853 test854 test855 test856 test857 test858 \
|
|||||||
test859 test860 test861 test862 test863 test864 test865 test866 test867 \
|
test859 test860 test861 test862 test863 test864 test865 test866 test867 \
|
||||||
test868 test869 test870 test871 test872 test873 test874 test875 test876 \
|
test868 test869 test870 test871 test872 test873 test874 test875 test876 \
|
||||||
test877 test878 test879 test880 test881 test882 test883 test884 test885 \
|
test877 test878 test879 test880 test881 test882 test883 test884 test885 \
|
||||||
test886 test887 test888 test889 test890 \
|
test886 test887 test888 test889 test890 test891 \
|
||||||
\
|
\
|
||||||
test900 test901 test902 test903 test904 test905 test906 test907 test908 \
|
test900 test901 test902 test903 test904 test905 test906 test907 test908 \
|
||||||
test909 test910 test911 test912 test913 test914 test915 test916 test917 \
|
test909 test910 test911 test912 test913 test914 test915 test916 test917 \
|
||||||
|
47
tests/data/test891
Normal file
47
tests/data/test891
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
<testcase>
|
||||||
|
<info>
|
||||||
|
<keywords>
|
||||||
|
POP3
|
||||||
|
</keywords>
|
||||||
|
</info>
|
||||||
|
|
||||||
|
#
|
||||||
|
# Server-side
|
||||||
|
<reply>
|
||||||
|
<servercmd>
|
||||||
|
AUTH CRAM-MD5
|
||||||
|
REPLYLF AUTH +
|
||||||
|
</servercmd>
|
||||||
|
</reply>
|
||||||
|
|
||||||
|
#
|
||||||
|
# Client-side
|
||||||
|
<client>
|
||||||
|
<server>
|
||||||
|
pop3
|
||||||
|
</server>
|
||||||
|
<features>
|
||||||
|
crypto
|
||||||
|
</features>
|
||||||
|
<name>
|
||||||
|
POP3 with short authentication response
|
||||||
|
</name>
|
||||||
|
<command>
|
||||||
|
pop3://%HOSTIP:%POP3PORT/891 -u user:secret
|
||||||
|
</command>
|
||||||
|
</client>
|
||||||
|
|
||||||
|
#
|
||||||
|
# Verify data after the test has been "shot"
|
||||||
|
<verify>
|
||||||
|
<protocol>
|
||||||
|
CAPA
|
||||||
|
AUTH CRAM-MD5
|
||||||
|
dXNlciA1YzhkYjAzZjA0Y2VjMGY0M2JjYjA2MDAyMzkxNDE5MA==
|
||||||
|
</protocol>
|
||||||
|
# CURLE_LOGIN_DENIED
|
||||||
|
<errorcode>
|
||||||
|
67
|
||||||
|
</errorcode>
|
||||||
|
</verify>
|
||||||
|
</testcase>
|
@ -2755,13 +2755,19 @@ sub customize {
|
|||||||
$fulltextreply{$1}=eval "qq{$2}";
|
$fulltextreply{$1}=eval "qq{$2}";
|
||||||
logmsg "FTPD: set custom reply for $1\n";
|
logmsg "FTPD: set custom reply for $1\n";
|
||||||
}
|
}
|
||||||
elsif($_ =~ /REPLY ([A-Za-z0-9+\/=\*]*) (.*)/) {
|
elsif($_ =~ /REPLY(LF|) ([A-Za-z0-9+\/=\*]*) (.*)/) {
|
||||||
$commandreply{$1}=eval "qq{$2}";
|
$commandreply{$2}=eval "qq{$3}";
|
||||||
if($1 eq "") {
|
if($1 ne "LF") {
|
||||||
|
$commandreply{$2}.="\r\n";
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$commandreply{$2}.="\n";
|
||||||
|
}
|
||||||
|
if($2 eq "") {
|
||||||
logmsg "FTPD: set custom reply for empty command\n";
|
logmsg "FTPD: set custom reply for empty command\n";
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
logmsg "FTPD: set custom reply for $1 command\n";
|
logmsg "FTPD: set custom reply for $2 command\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elsif($_ =~ /COUNT ([A-Z]+) (.*)/) {
|
elsif($_ =~ /COUNT ([A-Z]+) (.*)/) {
|
||||||
@ -3175,7 +3181,7 @@ while(1) {
|
|||||||
$commandreply{$FTPCMD}="";
|
$commandreply{$FTPCMD}="";
|
||||||
}
|
}
|
||||||
|
|
||||||
sendcontrol "$text\r\n";
|
sendcontrol $text;
|
||||||
$check = 0;
|
$check = 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
Loading…
Reference in New Issue
Block a user