From e33310f26351e25fda718a353f8b8e9ece0007b5 Mon Sep 17 00:00:00 2001 From: frosty Date: Tue, 10 Mar 2026 03:40:34 -0400 Subject: feature: added caching --- src/Main.c | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'src/Main.c') diff --git a/src/Main.c b/src/Main.c index eef0aef..c76764a 100644 --- a/src/Main.c +++ b/src/Main.c @@ -5,7 +5,9 @@ #include #include +#include "Cache/Cache.h" #include "Config.h" +#include "Infobox/Wikipedia.h" #include "Proxy/Proxy.h" #include "Routes/Home.h" #include "Routes/ImageProxy.h" @@ -37,12 +39,27 @@ int main() { .proxy_list_file = "", .max_proxy_retries = 3, .randomize_username = 0, - .randomize_password = 0}; + .randomize_password = 0, + .cache_dir = "/tmp/omnisearch_cache", + .cache_ttl_search = 3600, + .cache_ttl_infobox = 86400}; if (load_config("config.ini", &config) != 0) { fprintf(stderr, "Warning: Could not load config file, using defaults\n"); } + if (cache_init(config.cache_dir) != 0) { + fprintf( + stderr, + "Warning: Failed to initialize cache, continuing without caching\n"); + } else { + fprintf(stderr, "Cache initialized at %s\n", config.cache_dir); + cache_cleanup(config.cache_ttl_search); + } + + set_cache_ttl_search(config.cache_ttl_search); + set_cache_ttl_infobox(config.cache_ttl_infobox); + if (config.proxy_list_file[0] != '\0') { if (load_proxy_list(config.proxy_list_file) < 0) { fprintf( @@ -82,5 +99,6 @@ int main() { curl_global_cleanup(); xmlCleanupParser(); free_proxy_list(); + cache_shutdown(); return EXIT_SUCCESS; } -- cgit v1.2.3