Module Name: src
Committed By: mrg
Date: Tue Dec 29 04:21:46 UTC 2015
Modified Files:
src/libexec/httpd: bozohttpd.c bozohttpd.h cgi-bozo.c dir-index-bozo.c
Log Message:
- convert most asprintf() calls to bozoasprintf().
- don't call getpwuid(0) if we don't need to, or fail it it fails,
and remove the 'username' member of bozohttpd_t since it is not
used outside of bozo_setup().
To generate a diff of this commit:
cvs rdiff -u -r1.74 -r1.75 src/libexec/httpd/bozohttpd.c
cvs rdiff -u -r1.42 -r1.43 src/libexec/httpd/bozohttpd.h
cvs rdiff -u -r1.30 -r1.31 src/libexec/httpd/cgi-bozo.c
cvs rdiff -u -r1.24 -r1.25 src/libexec/httpd/dir-index-bozo.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/libexec/httpd/bozohttpd.c
diff -u src/libexec/httpd/bozohttpd.c:1.74 src/libexec/httpd/bozohttpd.c:1.75
--- src/libexec/httpd/bozohttpd.c:1.74 Mon Dec 28 07:37:59 2015
+++ src/libexec/httpd/bozohttpd.c Tue Dec 29 04:21:46 2015
@@ -1,4 +1,4 @@
-/* $NetBSD: bozohttpd.c,v 1.74 2015/12/28 07:37:59 mrg Exp $ */
+/* $NetBSD: bozohttpd.c,v 1.75 2015/12/29 04:21:46 mrg Exp $ */
/* $eterna: bozohttpd.c,v 1.178 2011/11/18 09:21:15 mrg Exp $ */
@@ -383,11 +383,7 @@ addmerge_header(bozo_httpreq_t *request,
/* yup, merge it in */
char *nval;
- if (asprintf(&nval, "%s, %s", hdr->h_value, str) == -1) {
- (void)bozo_http_error(httpd, 500, NULL,
- "memory allocation failure");
- return NULL;
- }
+ bozoasprintf(httpd, &nval, "%s, %s", hdr->h_value, str);
free(hdr->h_value);
hdr->h_value = nval;
} else {
@@ -955,9 +951,9 @@ handle_redirect(bozo_httpreq_t *request,
const char *s;
/*
- * absolute redirect may specify own protocol i.e. to redirect to
- * another schema like https:// or ftp://. Details: RFC 3986, section
- * 3.
+ * absolute redirect may specify own protocol i.e. to redirect
+ * to another schema like https:// or ftp://.
+ * Details: RFC 3986, section 3.
*/
/* 1. check if url contains :// */
@@ -969,8 +965,8 @@ handle_redirect(bozo_httpreq_t *request,
*/
if (sep) {
for (s = url; s != sep;) {
- if (!isalnum((int)*s) && *s != '+' && *s != '-' &&
- *s != '.')
+ if (!isalnum((int)*s) &&
+ *s != '+' && *s != '-' && *s != '.')
break;
if (++s == sep) {
absproto = 1;
@@ -2223,7 +2219,6 @@ bozo_setup(bozohttpd_t *httpd, bozoprefs
if (vhost == NULL) {
httpd->virthostname = bozomalloc(httpd, MAXHOSTNAMELEN+1);
- /* XXX we do not check for FQDN here */
if (gethostname(httpd->virthostname, MAXHOSTNAMELEN+1) < 0)
bozoerr(httpd, 1, "gethostname");
httpd->virthostname[MAXHOSTNAMELEN] = '\0';
@@ -2298,20 +2293,16 @@ bozo_setup(bozohttpd_t *httpd, bozoprefs
bozo_ssl_init(httpd);
bozo_daemon_init(httpd);
- if ((username = bozo_get_pref(prefs, "username")) == NULL) {
- if ((pw = getpwuid(uid = 0)) == NULL)
- bozoerr(httpd, 1, "getpwuid(0): %s", strerror(errno));
- httpd->username = bozostrdup(httpd, NULL, pw->pw_name);
- } else {
- httpd->username = bozostrdup(httpd, NULL, username);
- if ((pw = getpwnam(httpd->username)) == NULL)
- bozoerr(httpd, 1, "getpwnam(%s): %s", httpd->username,
- strerror(errno));
+ username = bozo_get_pref(prefs, "username");
+ if (username != NULL) {
+ if ((pw = getpwnam(username)) == NULL)
+ bozoerr(httpd, 1, "getpwnam(%s): %s", username,
+ strerror(errno));
if (initgroups(pw->pw_name, pw->pw_gid) == -1)
bozoerr(httpd, 1, "initgroups: %s", strerror(errno));
if (setgid(pw->pw_gid) == -1)
bozoerr(httpd, 1, "setgid(%u): %s", pw->pw_gid,
- strerror(errno));
+ strerror(errno));
uid = pw->pw_uid;
}
/*
@@ -2327,10 +2318,8 @@ bozo_setup(bozohttpd_t *httpd, bozoprefs
strerror(errno));
}
- if (username != NULL)
- if (setuid(uid) == -1)
- bozoerr(httpd, 1, "setuid(%d): %s", uid,
- strerror(errno));
+ if (username != NULL && setuid(uid) == -1)
+ bozoerr(httpd, 1, "setuid(%d): %s", uid, strerror(errno));
/*
* prevent info leakage between different compartments.
Index: src/libexec/httpd/bozohttpd.h
diff -u src/libexec/httpd/bozohttpd.h:1.42 src/libexec/httpd/bozohttpd.h:1.43
--- src/libexec/httpd/bozohttpd.h:1.42 Mon Dec 28 07:37:59 2015
+++ src/libexec/httpd/bozohttpd.h Tue Dec 29 04:21:46 2015
@@ -1,4 +1,4 @@
-/* $NetBSD: bozohttpd.h,v 1.42 2015/12/28 07:37:59 mrg Exp $ */
+/* $NetBSD: bozohttpd.h,v 1.43 2015/12/29 04:21:46 mrg Exp $ */
/* $eterna: bozohttpd.h,v 1.39 2011/11/18 09:21:15 mrg Exp $ */
@@ -90,7 +90,6 @@ typedef struct bozo_consts_t {
/* this structure encapsulates all the bozo flags and control vars */
typedef struct bozohttpd_t {
char *rootdir; /* root directory */
- char *username; /* username to switch to */
int numeric; /* avoid gethostby*() */
char *virtbase; /* virtual directory base */
int unknown_slash; /* unknown vhosts go to normal slashdir */
Index: src/libexec/httpd/cgi-bozo.c
diff -u src/libexec/httpd/cgi-bozo.c:1.30 src/libexec/httpd/cgi-bozo.c:1.31
--- src/libexec/httpd/cgi-bozo.c:1.30 Mon Dec 28 07:37:59 2015
+++ src/libexec/httpd/cgi-bozo.c Tue Dec 29 04:21:46 2015
@@ -1,4 +1,4 @@
-/* $NetBSD: cgi-bozo.c,v 1.30 2015/12/28 07:37:59 mrg Exp $ */
+/* $NetBSD: cgi-bozo.c,v 1.31 2015/12/29 04:21:46 mrg Exp $ */
/* $eterna: cgi-bozo.c,v 1.40 2011/11/18 09:21:15 mrg Exp $ */
@@ -274,7 +274,7 @@ bozo_process_cgi(bozo_httpreq_t *request
if (uri[0] == '/')
file = bozostrdup(httpd, request, uri);
else
- asprintf(&file, "/%s", uri);
+ bozoasprintf(httpd, &file, "/%s", uri);
if (file == NULL)
return 0;
@@ -283,7 +283,10 @@ bozo_process_cgi(bozo_httpreq_t *request
else
query = NULL;
- asprintf(&url, "%s%s%s", file, query ? "?" : "", query ? query : "");
+ bozoasprintf(httpd, &url, "%s%s%s",
+ file,
+ query ? "?" : "",
+ query ? query : "");
if (url == NULL)
goto out;
debug((httpd, DEBUG_NORMAL, "bozo_process_cgi: url `%s'", url));
@@ -420,8 +423,8 @@ bozo_process_cgi(bozo_httpreq_t *request
bozo_setenv(httpd, "REMOTE_ADDR", request->hr_remoteaddr,
curenvp++);
/*
- * XXX Apache does this when invoking content handlers, and PHP
- * XXX 5.3 requires it as a "security" measure.
+ * Apache does this when invoking content handlers, and PHP
+ * 5.3 requires it as a "security" measure.
*/
if (cgihandler)
bozo_setenv(httpd, "REDIRECT_STATUS", "200", curenvp++);
Index: src/libexec/httpd/dir-index-bozo.c
diff -u src/libexec/httpd/dir-index-bozo.c:1.24 src/libexec/httpd/dir-index-bozo.c:1.25
--- src/libexec/httpd/dir-index-bozo.c:1.24 Mon Dec 28 07:37:59 2015
+++ src/libexec/httpd/dir-index-bozo.c Tue Dec 29 04:21:46 2015
@@ -1,4 +1,4 @@
-/* $NetBSD: dir-index-bozo.c,v 1.24 2015/12/28 07:37:59 mrg Exp $ */
+/* $NetBSD: dir-index-bozo.c,v 1.25 2015/12/29 04:21:46 mrg Exp $ */
/* $eterna: dir-index-bozo.c,v 1.20 2011/11/18 09:21:15 mrg Exp $ */
@@ -110,9 +110,8 @@ bozo_dir_index(bozo_httpreq_t *request,
#ifndef NO_USER_SUPPORT
if (request->hr_user) {
- if (asprintf(&printname, "~%s/%s", request->hr_user,
- request->hr_file) < 0)
- bozoerr(httpd, 1, "asprintf");
+ bozoasprintf(httpd, &printname, "~%s/%s",
+ request->hr_user, request->hr_file);
} else
printname = bozostrdup(httpd, request, request->hr_file);
#else