1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
#include <stdio.h>
#include <string.h>
#include <fcntl.h>
#include <unistd.h>
#include <syslog.h>
#define VHOST_ROOT "/var/www"
#define CGI "cgi-bin"
#define SERVER "epochttpd/2.0 (Unix)"
void standard_headers() {
printf("Server: %s\r\n",SERVER);
printf("Connection: close\r\n");
}
int main(int argc,char *argv[]) {
int fd;
char *name[10];
int s,n;
short in;
char *method;
char *page;
char *version;
char *get_param;
char line[getpagesize()];
fgets(line,sizeof(line)-1,stdin);
// syslog(LOG_INFO,"ADDRESS did a LINE");
// syslog(LOG_WARNING,"httpd syslog test\n");
if(!strchr(line,'\n')) {
printf("HTTP/1.1 413 Entity Too Large\r\n");
standard_headers();
printf("Content-type: text/plain\r\n\r\n");
printf("use smaller (<%d bytes) headers.\n",getpagesize());
return 0;
}
if(strchr(line,'\r')) *strchr(line,'\r')=0;
method=strdup(line);
if((page=strchr(method,' '))) {
*page=0;
page++;
if((version=strchr(page,' '))) {
*version=0;
version++;
}
if((get_param=strchr(page,'?'))) {
*get_param=0;
get_param++;
setenv("QUERY_STRING",get_param);
}
}
while(fgets(line,sizeof(line)-1,stdin)) {
if(!strchr(line,'\n')) {
printf("HTTP/1.1 413 Entity Too Large\r\n");
standard_headers();
printf("Content-type: text/plain\r\n\r\n");
printf("use smaller (<%d bytes) headers.\n",getpagesize());
return 0;
}
if(strchr(line,'\r')) *strchr(line,'\r')=0;
if(!strncasecmp(line,"Host: ",6)) {
setenv("HTTP_HOST",line+6);
}
if(!strcmp(line,"")) {
break;
}
}
//TODO: sanitize this.
chdir(VHOST_ROOT);
chdir((char*)getenv("HTTP_HOST"));
if(strncmp(page,"/cgi-bin/",9)) {
for(;*page == '/';page++);
if(page[strlen(page)-1] == '/') {
printf("HTTP/1.1 302 Moved Permanently\r\n");
standard_headers();
printf("Location: /%sindex.html\r\n\r\n",page);
return 0;
}
if((fd=open(page,O_RDONLY)) != -1) {//need to check that the file isn't a directory. :P
printf("HTTP/1.1 200 OK\r\n");
standard_headers();
name[0]="/usr/local/bin/mime-type";
name[1]=page;
name[2]=0;
printf("Content-type: ");
fflush(stdout);
switch(fork()) {
case 0://child
execv(name[0],name);
break;
case -1://error
printf("fork failed.\n");
break;
default://parent
break;
}
wait(&s);
fflush(stdout);
printf("\r\n");
fflush(stdout);
while((n=read(fd,line,sizeof(line)-1)) > 0) {
write(STDOUT_FILENO,line,n);
}
} else {
printf("HTTP/1.1 404 Not Found\r\n");
standard_headers();
printf("Content-type: text/plain\r\n\r\n");
printf("Can't open that page.\n");
}
} else {
//attempt to run this bastard!
chdir(CGI);
page+=strlen("/cgi-bin/");
for(;*page == '/';page++);
name[0]=page;
name[1]=0;
printf("HTTP/1.1 200 OK\r\n");
standard_headers();
fflush(stdout);
execv(name[0],name);
}
return 0;
}
|