aboutsummaryrefslogtreecommitdiff
path: root/gmid.c
diff options
context:
space:
mode:
authorOmar Polo <op@omarpolo.com>2020-11-06 15:06:50 +0100
committerOmar Polo <op@omarpolo.com>2020-11-06 15:06:50 +0100
commit75d233f00c010a1489d597b82b13e3d09bc01e45 (patch)
tree24e887a09c05929e72a34b1f6e53b957de75cef2 /gmid.c
parentaa0fe0cf240e0add51d5b60a83dd554fd0575b28 (diff)
pass the query parameter to start_cgi
Diffstat (limited to 'gmid.c')
-rw-r--r--gmid.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/gmid.c b/gmid.c
index a057e17..51cdc65 100644
--- a/gmid.c
+++ b/gmid.c
@@ -120,10 +120,10 @@ ssize_t filesize(int);
int start_reply(struct pollfd*, struct client*, int, const char*);
const char *path_ext(const char*);
const char *mime(const char*);
-int open_file(char*, struct pollfd*, struct client*);
-void start_cgi(const char*, struct pollfd*, struct client*);
+int open_file(char*, char*, struct pollfd*, struct client*);
+void start_cgi(const char*, const char*, struct pollfd*, struct client*);
void handle_cgi(struct pollfd*, struct client*);
-void send_file(char*, struct pollfd*, struct client*);
+void send_file(char*, char*, struct pollfd*, struct client*);
void send_dir(char*, struct pollfd*, struct client*);
void handle(struct pollfd*, struct client*);
@@ -303,7 +303,7 @@ mime(const char *path)
}
int
-open_file(char *path, struct pollfd *fds, struct client *c)
+open_file(char *path, char *query, struct pollfd *fds, struct client *c)
{
char fpath[PATHBUF];
struct stat sb;
@@ -342,7 +342,7 @@ open_file(char *path, struct pollfd *fds, struct client *c)
}
if (cgi && (sb.st_mode & S_IXUSR)) {
- start_cgi(fpath, fds, c);
+ start_cgi(fpath, query, fds, c);
return 0;
}
@@ -364,7 +364,8 @@ open_file(char *path, struct pollfd *fds, struct client *c)
}
void
-start_cgi(const char *path, struct pollfd *fds, struct client *c)
+start_cgi(const char *path, const char *query,
+ struct pollfd *fds, struct client *c)
{
pid_t pid;
int p[2];
@@ -478,12 +479,12 @@ end:
}
void
-send_file(char *path, struct pollfd *fds, struct client *c)
+send_file(char *path, char *query, struct pollfd *fds, struct client *c)
{
ssize_t ret, len;
if (c->fd == -1) {
- if (!open_file(path, fds, c))
+ if (!open_file(path, query, fds, c))
return;
c->state = S_SENDING;
}
@@ -537,7 +538,7 @@ send_dir(char *path, struct pollfd *fds, struct client *client)
strlcat(fpath, "index.gmi", sizeof(fpath));
- send_file(fpath, fds, client);
+ send_file(fpath, NULL, fds, client);
}
void
@@ -587,7 +588,7 @@ handle(struct pollfd *fds, struct client *client)
if (path_isdir(path))
send_dir(path, fds, client);
else
- send_file(path, fds, client);
+ send_file(path, query, fds, client);
break;
case S_INITIALIZING:
@@ -605,7 +606,7 @@ handle(struct pollfd *fds, struct client *client)
/* fallthrough */
case S_SENDING:
- send_file(NULL, fds, client);
+ send_file(NULL, NULL, fds, client);
break;
case S_CLOSING: