aboutsummaryrefslogtreecommitdiff
path: root/src/Main.c
diff options
context:
space:
mode:
authorfrosty <gabriel@bwaaa.monster>2026-05-04 20:42:12 -0400
committerfrosty <gabriel@bwaaa.monster>2026-05-04 20:43:27 -0400
commitba6dae676a5c268d6b4265d26b9556ba1cfa6923 (patch)
treea556a64316856f9426924b21d1824632f92c6b84 /src/Main.c
parenta9db276fd872951769451142137a5e0f88ed15bc (diff)
downloadomnisearch-ba6dae676a5c268d6b4265d26b9556ba1cfa6923.tar.gz
feat: remove domain field from config and derive domain from headers
Diffstat (limited to 'src/Main.c')
-rw-r--r--src/Main.c33
1 files changed, 27 insertions, 6 deletions
diff --git a/src/Main.c b/src/Main.c
index b6551bc..e5cf9be 100644
--- a/src/Main.c
+++ b/src/Main.c
@@ -19,17 +19,38 @@
#include "Utility/Utility.h"
Config global_config;
-
+
int handle_opensearch(UrlParams *params) {
(void)params;
- extern Config global_config;
TemplateContext ctx = new_context();
- context_set(&ctx, "domain", global_config.domain);
+
+ const char *http_host = beaker_get_header("Host");
+ if (http_host == NULL) {
+ http_host = "localhost";
+ }
+
+ const char *req_scheme =
+ "https"; // not sure if it's a good idea to just assume https, but you
+ // should probably be using https for anything other than testing
+ // or local network anyways.
+
+ if (strncmp(http_host, "localhost", 9) == 0 ||
+ strncmp(http_host, "127.", 4) == 0 ||
+ strncmp(http_host, "192.168.", 8) == 0 ||
+ strncmp(http_host, "10.", 3) == 0) {
+ req_scheme = "http";
+ }
+
+ context_set(&ctx, "domain", http_host);
+ context_set(&ctx, "scheme", req_scheme);
+
char *rendered = render_template("opensearch.xml", &ctx);
- serve_data(rendered, strlen(rendered), "application/opensearchdescription+xml");
+ serve_data(rendered, strlen(rendered),
+ "application/opensearchdescription+xml");
free(rendered);
free_context(&ctx);
+
return 0;
}
@@ -46,7 +67,6 @@ int main() {
Config cfg = {.host = DEFAULT_HOST,
.port = DEFAULT_PORT,
- .domain = "",
.default_locale = "en_gb",
.proxy = "",
.proxy_list_file = "",
@@ -75,7 +95,8 @@ int main() {
if (loaded > 0) {
fprintf(stderr, "[INFO] Loaded %d locales\n", loaded);
} else {
- fprintf(stderr, "[WARN] No locales loaded (make sure to run from omnisearch directory)\n");
+ fprintf(stderr, "[WARN] No locales loaded (make sure to run from "
+ "omnisearch directory)\n");
}
apply_engines_config(cfg.engines);