mirror of https://github.com/nealey/eris.git
Fix merge fail
This commit is contained in:
parent
e46094d637
commit
4b54e2b2f3
188
eris.c
188
eris.c
|
@ -79,20 +79,13 @@
|
||||||
/*
|
/*
|
||||||
* Options
|
* Options
|
||||||
*/
|
*/
|
||||||
<<<<<<< HEAD
|
|
||||||
int doauth = 0;
|
int doauth = 0;
|
||||||
int docgi = 0;
|
int docgi = 0;
|
||||||
int doidx = 0;
|
int doidx = 0;
|
||||||
int nochdir = 0;
|
int nochdir = 0;
|
||||||
int redirect = 0;
|
int redirect = 0;
|
||||||
int portappend = 0;
|
int portappend = 0;
|
||||||
=======
|
|
||||||
int docgi = 0;
|
|
||||||
int doidx = 0;
|
|
||||||
int nochdir = 0;
|
|
||||||
int redirect = 0;
|
|
||||||
int portappend = 0;
|
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
|
|
||||||
/* Variables that persist between requests */
|
/* Variables that persist between requests */
|
||||||
int cwd;
|
int cwd;
|
||||||
|
@ -117,34 +110,9 @@ off_t range_start, range_end;
|
||||||
time_t ims;
|
time_t ims;
|
||||||
|
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
#define BUFFER_SIZE 8192
|
#define BUFFER_SIZE 8192
|
||||||
char stdout_buf[BUFFER_SIZE];
|
char stdout_buf[BUFFER_SIZE];
|
||||||
|
|
||||||
#include "strings.c"
|
|
||||||
#include "mime.c"
|
|
||||||
#include "time.c"
|
|
||||||
|
|
||||||
=======
|
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
/*
|
|
||||||
* TCP_CORK is a Linux extension to work around a TCP problem.
|
|
||||||
* http://www.baus.net/on-tcp_cork has a good description.
|
|
||||||
* XXX: Since we do our own buffering, TCP_CORK may not be helping
|
|
||||||
* with anything. This needs testing.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
cork(int enable)
|
|
||||||
{
|
|
||||||
#ifdef TCP_CORK
|
|
||||||
static int corked = 0;
|
|
||||||
|
|
||||||
if (enable != corked) {
|
|
||||||
setsockopt(1, IPPROTO_TCP, TCP_CORK, &enable, sizeof(enable));
|
|
||||||
corked = enable;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Log a request */
|
/** Log a request */
|
||||||
void
|
void
|
||||||
|
@ -161,15 +129,10 @@ dolog(int code, off_t len)
|
||||||
void
|
void
|
||||||
header(unsigned int code, const char *httpcomment)
|
header(unsigned int code, const char *httpcomment)
|
||||||
{
|
{
|
||||||
<<<<<<< HEAD
|
|
||||||
printf("HTTP/1.%d %u %s\r\n", http_version, code, httpcomment);
|
|
||||||
printf("Server: " FNORD "\r\n");
|
|
||||||
printf("Connection: %s\r\n", keepalive?"keep-alive":"close");
|
|
||||||
=======
|
|
||||||
printf("HTTP/1.%d %u %s\r\n", http_version, code, httpcomment);
|
printf("HTTP/1.%d %u %s\r\n", http_version, code, httpcomment);
|
||||||
printf("Server: %s\r\n", FNORD);
|
printf("Server: %s\r\n", FNORD);
|
||||||
printf("Connection: %s\r\n", keepalive?"keep-alive":"close");
|
printf("Connection: %s\r\n", keepalive?"keep-alive":"close");
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -202,7 +165,6 @@ badrequest(long code, const char *httpcomment, const char *message)
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
void
|
void
|
||||||
env(const char *k, const char *v)
|
env(const char *k, const char *v)
|
||||||
{
|
{
|
||||||
|
@ -210,8 +172,6 @@ env(const char *k, const char *v)
|
||||||
setenv(k, v, 1);
|
setenv(k, v, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
=======
|
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -228,14 +188,6 @@ not_found()
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
env(const char *k, const char *v)
|
|
||||||
{
|
|
||||||
if (v) {
|
|
||||||
setenv(k, v, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
char *
|
char *
|
||||||
proto_getenv(char *proto, char *name)
|
proto_getenv(char *proto, char *name)
|
||||||
{
|
{
|
||||||
|
@ -277,7 +229,6 @@ get_ucspi_env()
|
||||||
void
|
void
|
||||||
parse_options(int argc, char *argv[])
|
parse_options(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
<<<<<<< HEAD
|
|
||||||
int opt;
|
int opt;
|
||||||
|
|
||||||
while (-1 != (opt = getopt(argc, argv, "acdhkprv."))) {
|
while (-1 != (opt = getopt(argc, argv, "acdhkprv."))) {
|
||||||
|
@ -301,7 +252,7 @@ parse_options(int argc, char *argv[])
|
||||||
redirect = 1;
|
redirect = 1;
|
||||||
break;
|
break;
|
||||||
case 'v':
|
case 'v':
|
||||||
printf(FNORD "\n");
|
printf("%s\n", FNORD);
|
||||||
exit(0);
|
exit(0);
|
||||||
case 'h':
|
case 'h':
|
||||||
default:
|
default:
|
||||||
|
@ -318,44 +269,6 @@ parse_options(int argc, char *argv[])
|
||||||
exit(69);
|
exit(69);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
=======
|
|
||||||
int opt;
|
|
||||||
|
|
||||||
while (-1 != (opt = getopt(argc, argv, "cdhkprv."))) {
|
|
||||||
switch (opt) {
|
|
||||||
case 'c':
|
|
||||||
docgi = 1;
|
|
||||||
break;
|
|
||||||
case 'd':
|
|
||||||
doidx = 1;
|
|
||||||
break;
|
|
||||||
case '.':
|
|
||||||
nochdir = 1;
|
|
||||||
break;
|
|
||||||
case 'p':
|
|
||||||
portappend = 1;
|
|
||||||
break;
|
|
||||||
case 'r':
|
|
||||||
redirect = 1;
|
|
||||||
break;
|
|
||||||
case 'v':
|
|
||||||
printf("%s\n", FNORD);
|
|
||||||
exit(0);
|
|
||||||
case 'h':
|
|
||||||
default:
|
|
||||||
fprintf(stderr, "Usage: %s [OPTIONS]\n",
|
|
||||||
argv[0]);
|
|
||||||
fprintf(stderr, "\n");
|
|
||||||
fprintf(stderr, "-c Enable CGI\n");
|
|
||||||
fprintf(stderr, "-d Enable directory listing\n");
|
|
||||||
fprintf(stderr, "-. Serve out of ./ (no vhosting)\n");
|
|
||||||
fprintf(stderr, "-p Append port to hostname directory\n");
|
|
||||||
fprintf(stderr, "-r Enable symlink redirection\n");
|
|
||||||
fprintf(stderr, "-v Print version and exit\n");
|
|
||||||
exit(69);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -539,7 +452,6 @@ cgi_parent(int cin, int cout, int passthru)
|
||||||
|
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
dolog(200, size);
|
dolog(200, size);
|
||||||
cork(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -628,20 +540,12 @@ serve_file(int fd, char *filename, struct stat *st)
|
||||||
badrequest(405, "Method Not Supported", "POST is not supported by this URL");
|
badrequest(405, "Method Not Supported", "POST is not supported by this URL");
|
||||||
}
|
}
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
if (st->st_mtime <= ims) {
|
if (st->st_mtime <= ims) {
|
||||||
header(304, "Not Changed");
|
header(304, "Not Changed");
|
||||||
eoh();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
=======
|
|
||||||
if (st->st_mtime <= ims) {
|
|
||||||
header(304, "Not Changed");
|
|
||||||
eoh();
|
|
||||||
dolog(304, 0);
|
dolog(304, 0);
|
||||||
|
eoh();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
|
|
||||||
header(200, "OK");
|
header(200, "OK");
|
||||||
printf("Content-Type: %s\r\n", getmimetype(filename));
|
printf("Content-Type: %s\r\n", getmimetype(filename));
|
||||||
|
@ -687,70 +591,6 @@ serve_file(int fd, char *filename, struct stat *st)
|
||||||
void
|
void
|
||||||
serve_idx(int fd, char *path)
|
serve_idx(int fd, char *path)
|
||||||
{
|
{
|
||||||
<<<<<<< HEAD
|
|
||||||
DIR *d = fdopendir(fd);
|
|
||||||
struct dirent *de;
|
|
||||||
|
|
||||||
if (method == POST) {
|
|
||||||
badrequest(405, "Method Not Supported", "POST is not supported by this URL");
|
|
||||||
}
|
|
||||||
|
|
||||||
keepalive = 0;
|
|
||||||
header(200, "OK");
|
|
||||||
printf("Content-Type: text/html\r\n");
|
|
||||||
eoh();
|
|
||||||
|
|
||||||
printf("<!DOCTYPE html>\r<html><head><title>");
|
|
||||||
html_esc(stdout, path);
|
|
||||||
printf("</title></head><body><h1>Directory Listing: ");
|
|
||||||
html_esc(stdout, path);
|
|
||||||
printf("</h1><pre>");
|
|
||||||
if (path[1]) {
|
|
||||||
printf("<a href=\"../\">Parent Directory</a>\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
while ((de = readdir(d))) {
|
|
||||||
char *name = de->d_name;
|
|
||||||
char symlink[PATH_MAX];
|
|
||||||
struct stat st;
|
|
||||||
|
|
||||||
if (name[0] == '.') {
|
|
||||||
continue; /* hidden files -> skip */
|
|
||||||
}
|
|
||||||
if (lstat(name, &st)) {
|
|
||||||
continue; /* can't stat -> skip */
|
|
||||||
}
|
|
||||||
|
|
||||||
if (S_ISDIR(st.st_mode)) {
|
|
||||||
printf("[DIR] ");
|
|
||||||
} else if (S_ISLNK(st.st_mode)) {
|
|
||||||
ssize_t len = readlink(de->d_name, symlink, (sizeof symlink) - 1);
|
|
||||||
|
|
||||||
if (len < 1) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
name = symlink;
|
|
||||||
printf("[LNK] "); /* symlink */
|
|
||||||
} else if (S_ISREG(st.st_mode)) {
|
|
||||||
printf("%10llu", (unsigned long long)st.st_size);
|
|
||||||
} else {
|
|
||||||
continue; /* not a file we can provide -> skip */
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* write a href
|
|
||||||
*/
|
|
||||||
printf(" <a href=\"");
|
|
||||||
url_esc(stdout, name);
|
|
||||||
if (S_ISDIR(st.st_mode)) {
|
|
||||||
printf("/");
|
|
||||||
}
|
|
||||||
printf("\">");
|
|
||||||
url_esc(stdout, name);
|
|
||||||
printf("</a>\n");
|
|
||||||
}
|
|
||||||
printf("</pre></body></html>");
|
|
||||||
=======
|
|
||||||
DIR *d = fdopendir(fd);
|
DIR *d = fdopendir(fd);
|
||||||
struct dirent *de;
|
struct dirent *de;
|
||||||
|
|
||||||
|
@ -812,10 +652,9 @@ serve_idx(int fd, char *path)
|
||||||
url_esc(stdout, name);
|
url_esc(stdout, name);
|
||||||
printf("</a>\n");
|
printf("</a>\n");
|
||||||
}
|
}
|
||||||
printf("</pre></body></html>\n");
|
printf("</pre></body></html>");
|
||||||
|
|
||||||
dolog(200, 0);
|
dolog(200, 0);
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1128,10 +967,8 @@ handle_request()
|
||||||
|
|
||||||
/* Serve the file */
|
/* Serve the file */
|
||||||
alarm(WRITETIMEOUT);
|
alarm(WRITETIMEOUT);
|
||||||
cork(1);
|
|
||||||
find_serve_file(fspath);
|
find_serve_file(fspath);
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
cork(0);
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1143,20 +980,6 @@ main(int argc, char *argv[], const char *const *envp)
|
||||||
|
|
||||||
cwd = open(".", O_RDONLY);
|
cwd = open(".", O_RDONLY);
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
setbuffer(stdout, stdout_buf, sizeof stdout_buf);
|
|
||||||
|
|
||||||
signal(SIGPIPE, SIG_IGN);
|
|
||||||
get_ucspi_env();
|
|
||||||
|
|
||||||
while (1) {
|
|
||||||
handle_request();
|
|
||||||
if (! keepalive) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
fchdir(cwd);
|
|
||||||
}
|
|
||||||
=======
|
|
||||||
signal(SIGPIPE, SIG_IGN);
|
signal(SIGPIPE, SIG_IGN);
|
||||||
get_ucspi_env();
|
get_ucspi_env();
|
||||||
|
|
||||||
|
@ -1169,7 +992,6 @@ main(int argc, char *argv[], const char *const *envp)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
>>>>>>> 78dec35acd3e12a01a037244ce64d0d1b7de4cc4
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
1
test.sh
1
test.sh
|
@ -190,7 +190,6 @@ H "Directory indexing"
|
||||||
|
|
||||||
title "Basic index"
|
title "Basic index"
|
||||||
printf 'GET /empty/ HTTP/1.0\r\n\r\n' | $HTTPD_IDX 2>/dev/null | d | grep -Fq '<h1>Directory Listing: /empty/</h1><pre>%<a href="../">Parent Directory</a>%</pre>' && pass || fail
|
printf 'GET /empty/ HTTP/1.0\r\n\r\n' | $HTTPD_IDX 2>/dev/null | d | grep -Fq '<h1>Directory Listing: /empty/</h1><pre>%<a href="../">Parent Directory</a>%</pre>' && pass || fail
|
||||||
|
|
||||||
title "Hidden file"
|
title "Hidden file"
|
||||||
printf 'GET /subdir/ HTTP/1.0\r\n\r\n' | $HTTPD_IDX 2>/dev/null | grep -q 'hidden' && fail || pass
|
printf 'GET /subdir/ HTTP/1.0\r\n\r\n' | $HTTPD_IDX 2>/dev/null | grep -q 'hidden' && fail || pass
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue