mirror of
https://github.com/moparisthebest/curl
synced 2025-01-08 12:28:06 -05:00
security.c: We should always register the socket handler.
Following a change in the way socket handler are registered, the custom recv and send method were conditionaly registered. We need to register them everytime to handle the ftp security extensions. Re-added the clear text handling in sec_recv.
This commit is contained in:
parent
fc9f369829
commit
dacc44ddc2
@ -245,6 +245,10 @@ static ssize_t sec_recv(struct connectdata *conn, int sockindex,
|
|||||||
|
|
||||||
*err = CURLE_OK;
|
*err = CURLE_OK;
|
||||||
|
|
||||||
|
/* Handle clear text response. */
|
||||||
|
if(conn->sec_complete == 0 || conn->data_prot == prot_clear)
|
||||||
|
return read(fd, buffer, len);
|
||||||
|
|
||||||
if(conn->in_buffer.eof_flag) {
|
if(conn->in_buffer.eof_flag) {
|
||||||
conn->in_buffer.eof_flag = 0;
|
conn->in_buffer.eof_flag = 0;
|
||||||
return 0;
|
return 0;
|
||||||
@ -550,12 +554,10 @@ static CURLcode choose_mech(struct connectdata *conn)
|
|||||||
|
|
||||||
conn->mech = *mech;
|
conn->mech = *mech;
|
||||||
conn->sec_complete = 1;
|
conn->sec_complete = 1;
|
||||||
if (conn->data_prot != prot_clear) {
|
|
||||||
conn->recv[FIRSTSOCKET] = sec_recv;
|
conn->recv[FIRSTSOCKET] = sec_recv;
|
||||||
conn->send[FIRSTSOCKET] = sec_send;
|
conn->send[FIRSTSOCKET] = sec_send;
|
||||||
conn->recv[SECONDARYSOCKET] = sec_recv;
|
conn->recv[SECONDARYSOCKET] = sec_recv;
|
||||||
conn->send[SECONDARYSOCKET] = sec_send;
|
conn->send[SECONDARYSOCKET] = sec_send;
|
||||||
}
|
|
||||||
conn->command_prot = prot_safe;
|
conn->command_prot = prot_safe;
|
||||||
/* Set the requested protection level */
|
/* Set the requested protection level */
|
||||||
/* BLOCKING */
|
/* BLOCKING */
|
||||||
|
Loading…
Reference in New Issue
Block a user