netutils/ftpd: Do not terminate connection if CWD fails
Signed-off-by: Petro Karashchenko <petro.karashchenko@gmail.com>
This commit is contained in:
parent
124c1328a6
commit
aaa950faee
@ -484,7 +484,7 @@ ftpd_account_search_user(FAR struct ftpd_session_s *session,
|
||||
FAR const char *user)
|
||||
{
|
||||
FAR struct ftpd_account_s *newaccount = NULL;
|
||||
FAR struct ftpd_account_s *account;
|
||||
const FAR struct ftpd_account_s *account;
|
||||
uint8_t accountflags;
|
||||
|
||||
account = session->head;
|
||||
@ -1656,24 +1656,20 @@ static int ftpd_changedir(FAR struct ftpd_session_s *session,
|
||||
ret = stat(abspath, &st);
|
||||
if (ret < 0)
|
||||
{
|
||||
ret = -errno;
|
||||
|
||||
free(workpath);
|
||||
free(abspath);
|
||||
ftpd_response(session->cmd.sd, session->txtimeout,
|
||||
return ftpd_response(session->cmd.sd, session->txtimeout,
|
||||
g_respfmt2, 550, ' ', rempath,
|
||||
": No such file or directory");
|
||||
return ret;
|
||||
}
|
||||
|
||||
if (S_ISDIR(st.st_mode) == 0)
|
||||
{
|
||||
free(workpath);
|
||||
free(abspath);
|
||||
ftpd_response(session->cmd.sd, session->txtimeout,
|
||||
return ftpd_response(session->cmd.sd, session->txtimeout,
|
||||
g_respfmt2, 550, ' ', rempath,
|
||||
": No such file or directory");
|
||||
return -ENOTDIR;
|
||||
}
|
||||
|
||||
free(abspath);
|
||||
|
@ -118,8 +118,8 @@ struct ftpd_stream_s
|
||||
|
||||
struct ftpd_session_s
|
||||
{
|
||||
FAR struct ftpd_server_s *server;
|
||||
FAR struct ftpd_account_s *head;
|
||||
const FAR struct ftpd_server_s *server;
|
||||
const FAR struct ftpd_account_s *head;
|
||||
bool loggedin;
|
||||
uint8_t flags; /* See TPD_SESSIONFLAG_* definitions */
|
||||
int rxtimeout;
|
||||
|
Loading…
x
Reference in New Issue
Block a user