diff options
| author | 2014-07-31 17:55:09 +0000 | |
|---|---|---|
| committer | 2014-07-31 17:55:09 +0000 | |
| commit | cebbf23c9fbb7df6bcc4715bf4c9221520b00cd2 (patch) | |
| tree | fb1c3798960c932e5c6c7991b9ab1d06f19aa0af /usr.sbin/httpd/server_file.c | |
| parent | use proper on-disk inode size: no more, no less. (diff) | |
| download | wireguard-openbsd-cebbf23c9fbb7df6bcc4715bf4c9221520b00cd2.tar.xz wireguard-openbsd-cebbf23c9fbb7df6bcc4715bf4c9221520b00cd2.zip | |
some fastcgi improvements:
- DPRINTF instead of log_info for internal debugging.
- submit QUERY_STRING, if it exists
- use a proper function to create an HTTP header.
- use server_file_error() to detect EOF and fastcgi stream errors.
- disable keep-alive/persist for now until we have a reliable way to
get the content length from the cgi response or support chunked
encoding.
"Cool, jep" florian@
Diffstat (limited to 'usr.sbin/httpd/server_file.c')
| -rw-r--r-- | usr.sbin/httpd/server_file.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/usr.sbin/httpd/server_file.c b/usr.sbin/httpd/server_file.c index 035c7088b7d..7084c9f3d77 100644 --- a/usr.sbin/httpd/server_file.c +++ b/usr.sbin/httpd/server_file.c @@ -1,4 +1,4 @@ -/* $OpenBSD: server_file.c,v 1.21 2014/07/31 14:25:14 reyk Exp $ */ +/* $OpenBSD: server_file.c,v 1.22 2014/07/31 17:55:09 reyk Exp $ */ /* * Copyright (c) 2006 - 2014 Reyk Floeter <reyk@openbsd.org> @@ -51,7 +51,6 @@ int server_file_access(struct client *, char *, size_t, struct stat *); int server_file_index(struct httpd *, struct client *); -void server_file_error(struct bufferevent *, short, void *); int server_file_access(struct client *clt, char *path, size_t len, @@ -178,7 +177,7 @@ server_file(struct httpd *env, struct client *clt) case 0: /* Connection is already finished */ close(fd); - return (0); + goto done; default: break; } @@ -199,6 +198,8 @@ server_file(struct httpd *env, struct client *clt) bufferevent_enable(clt->clt_srvbev, EV_READ); bufferevent_disable(clt->clt_bev, EV_READ); + done: + server_reset_http(clt); return (0); fail: if (errstr == NULL) @@ -309,7 +310,7 @@ server_file_index(struct httpd *env, struct client *clt) case 0: /* Connection is already finished */ evbuffer_free(evb); - return (0); + goto done; default: break; } @@ -325,6 +326,8 @@ server_file_index(struct httpd *env, struct client *clt) clt->clt_toread = TOREAD_HTTP_NONE; clt->clt_done = 0; + done: + server_reset_http(clt); return (0); fail: |
