aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStefan Seyfried <stefan.seyfried@googlemail.com>2010-01-18 02:08:30 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2010-01-18 02:08:30 +0100
commitf3fc9ac166d2413d331e3189a132a693608695ba (patch)
tree35c067e4a80c872f7da5a3f37083294c1e1e3034
parent9c3b84a3049a152dd6a2b9e3aecaf897f57ac28e (diff)
downloadbusybox-w32-f3fc9ac166d2413d331e3189a132a693608695ba.tar.gz
busybox-w32-f3fc9ac166d2413d331e3189a132a693608695ba.tar.bz2
busybox-w32-f3fc9ac166d2413d331e3189a132a693608695ba.zip
ftpd: conditional support for broken clients
Signed-off-by: Stefan Seyfried <stefan.seyfried@googlemail.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--networking/Config.in11
-rw-r--r--networking/ftpd.c12
2 files changed, 23 insertions, 0 deletions
diff --git a/networking/Config.in b/networking/Config.in
index 80834c6d4..788e128ea 100644
--- a/networking/Config.in
+++ b/networking/Config.in
@@ -117,6 +117,17 @@ config FEATURE_FTP_WRITE
117 help 117 help
118 Enable all kinds of FTP upload commands (-w option) 118 Enable all kinds of FTP upload commands (-w option)
119 119
120config FEATURE_FTPD_ACCEPT_BROKEN_LIST
121 bool "Enable workaround for RFC-violating clients"
122 default y
123 depends on FTPD
124 help
125 Some ftp-clients (among them KDE's Konqueror) issue illegal
126 "LIST -la" requests. This option works around those problems.
127 It might prevent you from listing files starting with "-" and
128 it increases the code size by ~40 bytes.
129 Most other ftp servers seem to behave similar to this.
130
120config FTPGET 131config FTPGET
121 bool "ftpget" 132 bool "ftpget"
122 default n 133 default n
diff --git a/networking/ftpd.c b/networking/ftpd.c
index 4e9f65ca3..fdc6f5e45 100644
--- a/networking/ftpd.c
+++ b/networking/ftpd.c
@@ -632,6 +632,18 @@ popen_ls(const char *opt)
632 argv[3] = G.ftp_arg; 632 argv[3] = G.ftp_arg;
633 argv[4] = NULL; 633 argv[4] = NULL;
634 634
635 /* Improve compatibility with non-RFC conforming FTP clients
636 * which send e.g. "LIST -l", "LIST -la".
637 * See https://bugs.kde.org/show_bug.cgi?id=195578 */
638 if (ENABLE_FEATURE_FTPD_ACCEPT_BROKEN_LIST
639 && G.ftp_arg && G.ftp_arg[0] == '-' && G.ftp_arg[1] == 'l'
640 ) {
641 const char *tmp = strchr(G.ftp_arg, ' ');
642 if (tmp) /* skip the space */
643 tmp++;
644 argv[3] = tmp;
645 }
646
635 xpiped_pair(outfd); 647 xpiped_pair(outfd);
636 648
637 /*fflush_all(); - so far we dont use stdio on output */ 649 /*fflush_all(); - so far we dont use stdio on output */