From 3f73dcc52366c52a7a3d0453bfe251db02e6e125 Mon Sep 17 00:00:00 2001 From: partisan Date: Sun, 18 Aug 2024 14:49:42 +0200 Subject: [PATCH] fix getting wrong search results from cache (when using different search settings) --- files.go | 2 +- images.go | 2 +- main.go | 33 ++++++++++++++++----------------- text.go | 4 ++-- 4 files changed, 20 insertions(+), 21 deletions(-) diff --git a/files.go b/files.go index cbafb66..68f8742 100755 --- a/files.go +++ b/files.go @@ -41,7 +41,7 @@ func initializeTorrentSites() { func handleFileSearch(w http.ResponseWriter, settings UserSettings, query string, page int) { startTime := time.Now() - cacheKey := CacheKey{Query: query, Page: page, Safe: settings.SafeSearch == "true", Lang: settings.Language, Type: "file"} + cacheKey := CacheKey{Query: query, Page: page, Safe: settings.SafeSearch == "active", Lang: settings.Language, Type: "file"} combinedResults := getFileResultsFromCacheOrFetch(cacheKey, query, settings.SafeSearch, settings.Language, page) sort.Slice(combinedResults, func(i, j int) bool { return combinedResults[i].Seeders > combinedResults[j].Seeders }) diff --git a/images.go b/images.go index bdac1cd..86920e2 100755 --- a/images.go +++ b/images.go @@ -21,7 +21,7 @@ func init() { func handleImageSearch(w http.ResponseWriter, settings UserSettings, query string, page int) { startTime := time.Now() - cacheKey := CacheKey{Query: query, Page: page, Safe: settings.SafeSearch == "true", Lang: settings.Language, Type: "image"} + cacheKey := CacheKey{Query: query, Page: page, Safe: settings.SafeSearch == "active", Lang: settings.Language, Type: "image"} combinedResults := getImageResultsFromCacheOrFetch(cacheKey, query, settings.SafeSearch, settings.Language, page) elapsedTime := time.Since(startTime) diff --git a/main.go b/main.go index 65c272b..d16485f 100755 --- a/main.go +++ b/main.go @@ -81,37 +81,36 @@ func handleSearch(w http.ResponseWriter, r *http.Request) { settings.Theme = "dark" // Default theme } - if safe != "" { + if safe != "" && safe != settings.SafeSearch { settings.SafeSearch = safe saveUserSettings(w, settings) } - if lang != "" { + if lang != "" && lang != settings.Language { settings.Language = lang saveUserSettings(w, settings) } - // Render the search page template if no query - - data := struct { - LanguageOptions []LanguageOption - CurrentLang string - Theme string - Safe string - }{ - LanguageOptions: languageOptions, - CurrentLang: settings.Language, - Theme: settings.Theme, - Safe: settings.SafeSearch, - } + // Check if there is a search query if query == "" { + // If no query is provided, render the search page template + data := struct { + LanguageOptions []LanguageOption + CurrentLang string + Theme string + Safe string + }{ + LanguageOptions: languageOptions, + CurrentLang: settings.Language, + Theme: settings.Theme, + Safe: settings.SafeSearch, + } + tmpl := template.Must(template.ParseFiles("templates/search.html")) tmpl.Execute(w, data) return } - settings := loadUserSettings(r) - // Handle search based on the type switch searchType { case "image": diff --git a/text.go b/text.go index d088a07..1fed73d 100755 --- a/text.go +++ b/text.go @@ -22,7 +22,7 @@ func init() { func HandleTextSearch(w http.ResponseWriter, settings UserSettings, query string, page int) { startTime := time.Now() - cacheKey := CacheKey{Query: query, Page: page, Safe: settings.SafeSearch == "true", Lang: settings.Language, Type: "text"} + cacheKey := CacheKey{Query: query, Page: page, Safe: settings.SafeSearch == "active", Lang: settings.Language, Type: "text"} combinedResults := getTextResultsFromCacheOrFetch(cacheKey, query, settings.SafeSearch, settings.Language, page) hasPrevPage := page > 1 // dupe @@ -114,7 +114,7 @@ func getTextResultsFromCacheOrFetch(cacheKey CacheKey, query, safe, lang string, } func prefetchPage(query, safe, lang string, page int) { - cacheKey := CacheKey{Query: query, Page: page, Safe: safe == "true", Lang: lang, Type: "text"} + cacheKey := CacheKey{Query: query, Page: page, Safe: safe == "active", Lang: lang, Type: "text"} if _, exists := resultsCache.Get(cacheKey); !exists { printInfo("Page %d not cached, caching now...", page) pageResults := fetchTextResults(query, safe, lang, page)