Get rid of cwd in THTTPD

git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@2021 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
patacongo 2009-08-15 20:25:13 +00:00
parent e1ec46aeca
commit 534fa87409
10 changed files with 37 additions and 54 deletions

View File

@ -2362,7 +2362,10 @@ extern void up_ledoff(int led);
<code>CONFIG_THTTPD_SERVER_SOFTWARE</code>: SERVER_SOFTWARE: response <code>CONFIG_THTTPD_SERVER_SOFTWARE</code>: SERVER_SOFTWARE: response
</li> </li>
<li> <li>
<code>CONFIG_THTTPD_CGI_PATH</code>: <code>CONFIG_THTTPD_PATH</code>: Server working directory
</li>
<li>
<code>CONFIG_THTTPD_CGI_PATH</code>: Path to CGI executables
</li> </li>
<li> <li>
<code>CONFIG_THTTPD_CGI_PATTERN</code>: Only CGI programs matching this <code>CONFIG_THTTPD_CGI_PATTERN</code>: Only CGI programs matching this

View File

@ -358,7 +358,8 @@ defconfig -- This is a configuration file similar to the Linux
CONFIG_THTTPD_IPADDR - Server IP address (no host name) CONFIG_THTTPD_IPADDR - Server IP address (no host name)
CONFIG_THTTPD_SERVER_ADDRESS - SERVER_ADDRESS: response CONFIG_THTTPD_SERVER_ADDRESS - SERVER_ADDRESS: response
CONFIG_THTTPD_SERVER_SOFTWARE - SERVER_SOFTWARE: response CONFIG_THTTPD_SERVER_SOFTWARE - SERVER_SOFTWARE: response
CONFIG_THTTPD_CGI_PATH - CONFIG_THTTPD_PATH - Server working directory
CONFIG_THTTPD_CGI_PATH - Path to CGI executables
CONFIG_THTTPD_CGI_PATTERN - Only CGI programs matching this CONFIG_THTTPD_CGI_PATTERN - Only CGI programs matching this
pattern will be executed. In fact, if this value is not defined pattern will be executed. In fact, if this value is not defined
then no CGI logic will be built. then no CGI logic will be built.

View File

@ -483,7 +483,8 @@ CONFIG_NET_RESOLV_ENTRIES=4
# CONFIG_THTTPD_IPADDR - Server IP address (no host name) # CONFIG_THTTPD_IPADDR - Server IP address (no host name)
# CONFIG_THTTPD_SERVER_ADDRESS - SERVER_ADDRESS: response # CONFIG_THTTPD_SERVER_ADDRESS - SERVER_ADDRESS: response
# CONFIG_THTTPD_SERVER_SOFTWARE - SERVER_SOFTWARE: response # CONFIG_THTTPD_SERVER_SOFTWARE - SERVER_SOFTWARE: response
# CONFIG_THTTPD_CGI_PATH - # CONFIG_THTTPD_PATH - Server working directory
# CONFIG_THTTPD_CGI_PATH - Path to CGI executables
# CONFIG_THTTPD_CGI_PATTERN - Only CGI programs matching this # CONFIG_THTTPD_CGI_PATTERN - Only CGI programs matching this
# pattern will be executed. In fact, if this value is not defined # pattern will be executed. In fact, if this value is not defined
# then no CGI logic will be built. # then no CGI logic will be built.
@ -536,6 +537,7 @@ CONFIG_THTTPD_PORT=80
CONFIG_THTTPD_IPADDR=(10<<24|0<<16|0<<8|2) CONFIG_THTTPD_IPADDR=(10<<24|0<<16|0<<8|2)
CONFIG_THTTPD_SERVER_ADDRESS="http://www.nuttx.org" CONFIG_THTTPD_SERVER_ADDRESS="http://www.nuttx.org"
CONFIG_THTTPD_SERVER_SOFTWARE="thttpd/2.25b 29dec2003-NuttX" CONFIG_THTTPD_SERVER_SOFTWARE="thttpd/2.25b 29dec2003-NuttX"
CONFIG_THTTPD_PATH="/mnt/www"
CONFIG_THTTPD_CGI_PATH="/mnt/www/cgi-bin" CONFIG_THTTPD_CGI_PATH="/mnt/www/cgi-bin"
CONFIG_THTTPD_CGI_PATTERN="/cgi-bin/*" CONFIG_THTTPD_CGI_PATTERN="/cgi-bin/*"
CONFIG_THTTPD_CGI_PRIORITY=50 CONFIG_THTTPD_CGI_PRIORITY=50

View File

@ -93,7 +93,7 @@
#define SECTORSIZE 512 #define SECTORSIZE 512
#define NSECTORS(b) (((b)+SECTORSIZE-1)/SECTORSIZE) #define NSECTORS(b) (((b)+SECTORSIZE-1)/SECTORSIZE)
#define ROMFSDEV "/dev/ram0" #define ROMFSDEV "/dev/ram0"
#define MOUNTPT "/mnt/www" #define MOUNTPT CONFIG_THTTPD_PATH
#ifdef CONFIG_CPP_HAVE_VARARGS #ifdef CONFIG_CPP_HAVE_VARARGS
# ifdef CONFIG_DEBUG # ifdef CONFIG_DEBUG

View File

@ -54,7 +54,7 @@
#ifndef CONFIG_ARCH_STRCMP #ifndef CONFIG_ARCH_STRCMP
int strcasecmp(const char *cs, const char *ct) int strcasecmp(const char *cs, const char *ct)
{ {
register int result; int result;
for (;;) for (;;)
{ {
if ((result = (int)toupper(*cs) - (int)toupper(*ct)) != 0 || !*cs) if ((result = (int)toupper(*cs) - (int)toupper(*ct)) != 0 || !*cs)

View File

@ -54,7 +54,7 @@
#ifndef CONFIG_ARCH_STRNCASECMP #ifndef CONFIG_ARCH_STRNCASECMP
int strncasecmp(const char *cs, const char *ct, size_t nb) int strncasecmp(const char *cs, const char *ct, size_t nb)
{ {
register int result = 0; int result = 0;
for (; nb > 0; nb--) for (; nb > 0; nb--)
{ {
if ((result = (int)toupper(*cs) - (int)toupper(*ct)) != 0 || !*cs) if ((result = (int)toupper(*cs) - (int)toupper(*ct)) != 0 || !*cs)

View File

@ -88,6 +88,13 @@
# define CONFIG_THTTPD_SERVER_SOFTWARE "thttpd/2.25b 29dec2003-NuttX" # define CONFIG_THTTPD_SERVER_SOFTWARE "thttpd/2.25b 29dec2003-NuttX"
# endif # endif
# ifndef CONFIG_THTTPD_PATH
# ifdef CONFIG_CPP_HAVE_WARNING
# warning "CONFIG_THTTPD_PATH not defined"
# endif
# define CONFIG_THTTPD_PATH "/mnt/www"
# endif
# ifndef CONFIG_THTTPD_CGI_PATH # ifndef CONFIG_THTTPD_CGI_PATH
# ifdef CONFIG_CPP_HAVE_WARNING # ifdef CONFIG_CPP_HAVE_WARNING
# warning "CONFIG_THTTPD_CGI_PATH not defined" # warning "CONFIG_THTTPD_CGI_PATH not defined"

View File

@ -293,10 +293,6 @@ static void free_httpd_server(httpd_server * hs)
free(hs->hostname); free(hs->hostname);
} }
if (hs->cwd)
{
free(hs->cwd);
}
free(hs); free(hs);
} }
} }
@ -736,10 +732,14 @@ static int auth_check(httpd_conn *hc, char *dirname)
#ifdef CONFIG_THTTPD_VHOST #ifdef CONFIG_THTTPD_VHOST
if (hc->hostdir[0] != '\0') if (hc->hostdir[0] != '\0')
{
topdir = hc->hostdir; topdir = hc->hostdir;
}
else else
#endif #endif
topdir = "."; {
topdir = CONFIG_THTTPD_PATH;
}
switch (auth_check2(hc, topdir)) switch (auth_check2(hc, topdir))
{ {
@ -1418,7 +1418,7 @@ static char *expand_filename(char *path, char **restP, boolean tildemapped)
*restP = r; *restP = r;
if (checked[0] == '\0') if (checked[0] == '\0')
{ {
(void)strcpy(checked, "."); (void)strcpy(checked, CONFIG_THTTPD_PATH);
} }
return checked; return checked;
} }
@ -1807,8 +1807,7 @@ static void ls_child(int argc, char **argv)
strlen(hc->origfilename) + 1 + strlen(hc->origfilename) + 1 +
strlen(nameptrs[i])); strlen(nameptrs[i]));
if (hc->expnfilename[0] == '\0' || if (hc->expnfilename[0] == '\0' || strcmp(hc->expnfilename, ".") == 0)
strcmp(hc->expnfilename, ".") == 0)
{ {
(void)strcpy(name, nameptrs[i]); (void)strcpy(name, nameptrs[i]);
(void)strcpy(rname, nameptrs[i]); (void)strcpy(rname, nameptrs[i]);
@ -2109,11 +2108,11 @@ static void create_environment(httpd_conn *hc)
(void)snprintf(buf, sizeof(buf), "/%s", hc->pathinfo); (void)snprintf(buf, sizeof(buf), "/%s", hc->pathinfo);
setenv("PATH_INFO", buf, TRUE); setenv("PATH_INFO", buf, TRUE);
l = strlen(hc->hs->cwd) + strlen(hc->pathinfo) + 1; l = strlen(CONFIG_THTTPD_PATH) + strlen(hc->pathinfo) + 1;
cp2 = NEW(char, l); cp2 = NEW(char, l);
if (cp2) if (cp2)
{ {
(void)snprintf(cp2, l, "%s%s", hc->hs->cwd, hc->pathinfo); (void)snprintf(cp2, l, "%s%s", CONFIG_THTTPD_PATH, hc->pathinfo);
setenv("PATH_TRANSLATED", cp2, TRUE); setenv("PATH_TRANSLATED", cp2, TRUE);
} }
} }
@ -3072,7 +3071,7 @@ static int really_start_request(httpd_conn *hc, struct timeval *nowP)
cp = strrchr(dirname, '/'); cp = strrchr(dirname, '/');
if (!cp) if (!cp)
{ {
(void)strcpy(dirname, "."); (void)strcpy(dirname, CONFIG_THTTPD_PATH);
} }
else else
{ {
@ -3381,12 +3380,10 @@ static size_t sockaddr_len(httpd_sockaddr *saP)
* Public Functions * Public Functions
****************************************************************************/ ****************************************************************************/
FAR httpd_server *httpd_initialize(FAR httpd_sockaddr *sa, FAR const char *cwd) FAR httpd_server *httpd_initialize(FAR httpd_sockaddr *sa)
{ {
FAR httpd_server *hs; FAR httpd_server *hs;
nvdbg("cwd: %s\n", cwd);
/* Save the PID of the main thread */ /* Save the PID of the main thread */
main_thread = getpid(); main_thread = getpid();
@ -3414,12 +3411,6 @@ FAR httpd_server *httpd_initialize(FAR httpd_sockaddr *sa, FAR const char *cwd)
} }
hs->cgi_count = 0; hs->cgi_count = 0;
hs->cwd = strdup(cwd);
if (!hs->cwd)
{
ndbg("out of memory copying cwd\n");
return (httpd_server *) 0;
}
/* Initialize listen sockets */ /* Initialize listen sockets */
@ -3999,7 +3990,7 @@ int httpd_parse_request(httpd_conn *hc)
} }
*url = '\0'; *url = '\0';
if (strchr(reqhost, '/') != (char *)0 || reqhost[0] == '.') if (strchr(reqhost, '/') != NULL || reqhost[0] == '.')
{ {
BADREQUEST("reqhost-2"); BADREQUEST("reqhost-2");
httpd_send_err(hc, 400, httpd_err400title, "", httpd_err400form, ""); httpd_send_err(hc, 400, httpd_err400title, "", httpd_err400form, "");
@ -4048,7 +4039,7 @@ int httpd_parse_request(httpd_conn *hc)
if (hc->origfilename[0] == '\0') if (hc->origfilename[0] == '\0')
{ {
(void)strcpy(hc->origfilename, "."); (void)strcpy(hc->origfilename, CONFIG_THTTPD_PATH);
} }
/* Extract query string from encoded URL. */ /* Extract query string from encoded URL. */
@ -4386,11 +4377,11 @@ int httpd_parse_request(httpd_conn *hc)
if (hc->expnfilename[0] == '/') if (hc->expnfilename[0] == '/')
{ {
if (strncmp(hc->expnfilename, hc->hs->cwd, strlen(hc->hs->cwd)) == 0) if (strncmp(hc->expnfilename, CONFIG_THTTPD_PATH, strlen(CONFIG_THTTPD_PATH)) == 0)
{ {
/* Elide the current directory. */ /* Elide the current directory. */
(void)strcpy(hc->expnfilename, &hc->expnfilename[strlen(hc->hs->cwd)]); (void)strcpy(hc->expnfilename, &hc->expnfilename[strlen(CONFIG_THTTPD_PATH)]);
} }
#ifdef CONFIG_THTTPD_TILDE_MAP2 #ifdef CONFIG_THTTPD_TILDE_MAP2
else if (hc->altdir[0] != '\0' && else if (hc->altdir[0] != '\0' &&

View File

@ -167,7 +167,6 @@ typedef struct
{ {
char *hostname; char *hostname;
int cgi_count; int cgi_count;
char *cwd;
int listen_fd; int listen_fd;
} httpd_server; } httpd_server;
@ -245,7 +244,7 @@ typedef struct
* Return (httpd_server*) 0 on error. * Return (httpd_server*) 0 on error.
*/ */
extern FAR httpd_server *httpd_initialize(FAR httpd_sockaddr *sa, FAR const char *cwd); extern FAR httpd_server *httpd_initialize(FAR httpd_sockaddr *sa);
/* Call to unlisten/close socket(s) listening for new connections. */ /* Call to unlisten/close socket(s) listening for new connections. */

View File

@ -752,7 +752,6 @@ static void thttpd_logstats(long secs)
int thttpd_main(int argc, char **argv) int thttpd_main(int argc, char **argv)
{ {
char cwd[MAXPATHLEN + 1];
int num_ready; int num_ready;
int cnum; int cnum;
FAR struct connect_s *conn; FAR struct connect_s *conn;
@ -775,25 +774,6 @@ int thttpd_main(int argc, char **argv)
sa.sin_addr.s_addr = HTONL(CONFIG_THTTPD_IPADDR); sa.sin_addr.s_addr = HTONL(CONFIG_THTTPD_IPADDR);
#endif #endif
/* Switch directories if requested */
#ifdef CONFIG_THTTPD_DIR
ret = chdir(CONFIG_THTTPD_DIR);
if (ret < 0)
{
ndbg("chdir: %d\n", errno);
exit(1);
}
#endif
/* Get current directory */
(void)getcwd(cwd, sizeof(cwd) - 1);
if (cwd[strlen(cwd) - 1] != '/')
{
(void)strcat(cwd, "/");
}
/* Initialize the fdwatch package to handle all of the configured /* Initialize the fdwatch package to handle all of the configured
* socket descriptors * socket descriptors
*/ */
@ -822,7 +802,7 @@ int thttpd_main(int argc, char **argv)
/* Initialize the HTTP layer */ /* Initialize the HTTP layer */
nvdbg("Calling httpd_initialize()\n"); nvdbg("Calling httpd_initialize()\n");
hs = httpd_initialize(&sa, cwd); hs = httpd_initialize(&sa);
if (!hs) if (!hs)
{ {
ndbg("httpd_initialize() failed\n"); ndbg("httpd_initialize() failed\n");