summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAaron Ball <nullspoon@oper.io>2023-05-25 11:21:50 -0600
committerAaron Ball <nullspoon@oper.io>2023-05-25 11:27:16 -0600
commit4207e2029557fc1090e62ab2be765e48a070997e (patch)
treee48774096acec1f48cb99f414c447c008dd06b90 /src
parent0096d75f76690d50010cd77a4d8416079ca38247 (diff)
downloadoper.io-4207e2029557fc1090e62ab2be765e48a070997e.tar.gz
oper.io-4207e2029557fc1090e62ab2be765e48a070997e.tar.xz
Better organize main qs handling and improve 404
This moves page handling logic into a new function, `handle_page`, and special qs handling logic to `handle_special`. This keeps code better organized. This also better handles 404 pages. If a custom 404.html is available, it is treated as a normal page and parsed correctly. If none exists, a generic 404 is sent in all scenarios where no logic handled the query string.
Diffstat (limited to 'src')
-rw-r--r--src/main.c94
1 files changed, 55 insertions, 39 deletions
diff --git a/src/main.c b/src/main.c
index 4578318..ac5b14c 100644
--- a/src/main.c
+++ b/src/main.c
@@ -24,60 +24,51 @@
#include "j2.h"
-int main(int argc, char* argv[], char* envp[]) {
- char buf[256];
- char path[512];
- int status = 200;
-
- // Space for title assembly
- char titlebuf[TITLE_MAX] = {'\0'};
- char title[TITLE_MAX + 2] = {'\0'};
-
- // Required environment variables
- char* header = getenv("INDEX_HEADER");
- char* footer = getenv("INDEX_FOOTER");
- char* posts = getenv("INDEX_POSTS");
-
- // List of supported query string key names
- char* keys[] = {"q", "p", "title", "\0"};
- // Parse the query string (if present)
- struct querystring qs;
- qs.qs = getenv("QUERY_STRING");
- qs.pos = 0;
-
- // If no title specified (return non-zero), default to "index"
- if(cgi_qs_get_val(&qs, keys, buf) != 0)
- strcpy(buf, "index");
-
- // If the IP address was requested
- if(strncmp(buf, "ip", 2) == 0) {
+int handle_special(char* querystring) {
+ if(strncmp(querystring, "ip", 2) == 0) {
+ // If the IP address was requested
cgi_print_header("text/plain", 200);
- printf("%s\n", cgi_remote_ip());
+ puts(cgi_remote_ip());
return 0;
- }
- // If the remote agent was requested
- if(strncmp(buf, "agent", 5) == 0) {
+ } else if(strncmp(querystring, "agent", 5) == 0) {
+ // If the remote agent was requested
cgi_print_header("text/plain", 200);
- printf("%s\n", cgi_user_agent());
+ puts(cgi_user_agent());
return 0;
- }
- // If client headers requested
- if(strncmp(buf, "headers", 5) == 0) {
+ } else if(strncmp(querystring, "headers", 5) == 0) {
+ // If client headers requested
cgi_print_header("text/plain", 200);
cgi_print_headers();
return 0;
}
+ return -1;
+}
+
+int handle_page(char* querystring) {
+ char path[512] = {0};
+ int status = 200;
+ // Space for title assembly
+ char titlebuf[TITLE_MAX] = {'\0'};
+ char title[TITLE_MAX + 2] = {'\0'};
+ // Required environment variables
+ char* header = getenv("INDEX_HEADER");
+ char* footer = getenv("INDEX_FOOTER");
+ char* posts = getenv("INDEX_POSTS");
// Assemble the page path
- sprintf(path, "%s/%s.html", posts, buf);
+ sprintf(path, "%s/%s.html", posts, querystring);
- // If the file does not exist, set status to 404 and set the page to be
- // printed to the 404 page.
+ // If the file does not exist, attempt to read the 404 page instead
+ // Return -1 if 404 page does not exist
if(access(path, F_OK) != 0) {
+ sprintf(path, "%s/404.html", posts);
+
+ if(access(path, F_OK) != 0)
+ return -1;
+
status = 404;
- sprintf(path, "%s/%s.html", posts, "404");
strcpy(title, ": 404");
}
@@ -94,6 +85,31 @@ int main(int argc, char* argv[], char* envp[]) {
j2_cat(path);
j2_cat(footer);
fflush(stdout);
+ return 0;
+}
+
+int main(int argc, char* argv[], char* envp[]) {
+ char buf[256] = {0};
+ char* keys[] = {"q", "p", "title", "\0"}; // Supported query string key names
+ struct querystring qs;
+ // Parse the query string (if present)
+ qs.qs = getenv("QUERY_STRING");
+ qs.pos = 0;
+
+ // If no title specified (return non-zero), default to "index"
+ if(cgi_qs_get_val(&qs, keys, buf) != 0)
+ strcpy(buf, "index");
+
+ if(handle_special(buf) == 0)
+ return 0;
+ if(handle_page(buf) == 0)
+ return 0;
+
+ // All attempts to recognize the request have failed. Return generic 404.
+ cgi_print_header("text/html", 404);
+ setenv("PAGE_TITLE", "404 Not Found", 1);
+ puts("404 Not Found");
+ fflush(stdout);
return 0;
}

Generated by cgit