From 1efca320c81669253dc164c66e5c661ff6934f8c Mon Sep 17 00:00:00 2001 From: partisan Date: Mon, 15 Apr 2024 08:35:17 +0200 Subject: [PATCH] add simple settings template, cleanup --- main.go | 14 ++-- run.sh | 2 +- static/css/style.css | 2 +- static/searchicon.png | Bin 1067 -> 0 bytes templates/A.html | 28 ------- {static => templates}/search.html | 4 +- templates/settings.html | 70 ++++++++++++++++ templates/{results.html => text.html} | 0 text-google.go | 113 ++++++++++++++++++++++++++ text.go | 113 -------------------------- 10 files changed, 192 insertions(+), 154 deletions(-) delete mode 100644 static/searchicon.png delete mode 100644 templates/A.html rename {static => templates}/search.html (86%) create mode 100644 templates/settings.html rename templates/{results.html => text.html} (100%) create mode 100644 text-google.go diff --git a/main.go b/main.go index 46e2d4d..9550f84 100644 --- a/main.go +++ b/main.go @@ -63,18 +63,14 @@ var languageOptions = []LanguageOption{ {Code: "lang_vi", Name: "Tiếng Việt (Vietnamese)"}, } -// var funcs = template.FuncMap{ -// "title": func(s string) string { return strings.Title(s) }, -// "url_for": func(filename string) string { return "/" + filename }, -// } - -// var templates = template.Must(template.New("").Funcs(funcs).ParseFiles("templates/results.html")) - func main() { http.Handle("/static/", http.StripPrefix("/static/", http.FileServer(http.Dir("static")))) http.HandleFunc("/", handleSearch) http.HandleFunc("/search", handleSearch) http.HandleFunc("/img_proxy", handleImageProxy) + http.HandleFunc("/settings", func(w http.ResponseWriter, r *http.Request) { + http.ServeFile(w, r, "templates/settings.html") + }) fmt.Println("Server is listening on http://localhost:5000") log.Fatal(http.ListenAndServe(":5000", nil)) } @@ -102,7 +98,7 @@ func handleSearch(w http.ResponseWriter, r *http.Request) { } if query == "" { - http.ServeFile(w, r, "static/search.html") + http.ServeFile(w, r, "templates/search.html") return } @@ -114,6 +110,6 @@ func handleSearch(w http.ResponseWriter, r *http.Request) { case "video": videoSearchEndpointHandler(w, r) default: - http.ServeFile(w, r, "static/search.html") + http.ServeFile(w, r, "templates/search.html") } } diff --git a/run.sh b/run.sh index 469dfac..b422cea 100755 --- a/run.sh +++ b/run.sh @@ -1,3 +1,3 @@ #!/bin/bash -go run main.go text.go images.go imageproxy.go video.go \ No newline at end of file +$ go run main.go text-google.go images.go imageproxy.go video.go \ No newline at end of file diff --git a/static/css/style.css b/static/css/style.css index 7ac347c..b8171d2 100644 --- a/static/css/style.css +++ b/static/css/style.css @@ -1150,7 +1150,7 @@ p { background-color: inherit; font-size: 14px; font-family: 'Inter'; - margin-right: 14px; + margin-right: 10px; color: var(--search-button); margin-top: 72px; padding-bottom: 11px; diff --git a/static/searchicon.png b/static/searchicon.png deleted file mode 100644 index c751913d76aecc2eaedbfcbb86986a65e022ecfc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1067 zcmV+`1l0S9P)pF8FWQhbW?9;ba!ELWdL_~cP?peYja~^aAhuUa%Y?FJQ@H11Gq^< zK~!jg?U+Ao8+8=NKkt(GQaha~Nc<@bW$4l(2DUCpD0Z_@2RgQ@R4fERY3#CD9%}~_ zgrX1$DI*XIRMOgXVCV>yfGGo2MWIVliLL3?=i++|IUkOFcJ3To7bJhD-|zk2yWjhq z@BRK*RF(g;jHnYhs73%$YXlIrMgUQ31Q4}G08wjvm=7=9W-`80n-!6>3a5Z$?$EZt zZ>oC3nwnhCpP|<895SrKT&Y?=4|)yd`F&g;2y%5H8T-1Qc{%_}6?+l*5SZu^^Az|j zn>4e2gXJ<~_Y-zel=(1;sPO6W$7U{_rV%F2uLjePn7vTM$%B6ltN?R8AfBSE_zje*_493SzWl^8FXq$i?DdRo z0-J?0%Za$Xrf|+3xUyKS-&vTBtp^1dSPc|zGa0w+yDi^*Ih!=!0rs0fN;mB?!rN~D zFDqfb8nmznwv5JiYO~Gc6}BwPyvY8^1E@OY1>m9EfANS_O9!2IU;rX=)@!RQb$&M8 zm7C!aB1@h@Nd=7^7=Xg*X4_FJVdEYCi!qSXy?k3W$es9^W}_yt`(cB}#$$gp+X~MH zjT_2QA`wHv#yGY9av3B*vj}O}^_Rj1>-e6S?QVYU>evU0x9k%*%%I{AC+c9Zk$cPh zeUBM_Rd^Xd3{t>m&?ErFA?5vUsy_#f>j01jKLE$Ou7CAgta$AEpow(s z#Kl|o38NvipouOaj}6gp=BLfO?IVko`n!sL{Uuw8uc0Oc}c?y2(1 z0Ui?=VrUnd#cF+4RZGANJrjU?K*l|hUTzr*1Ti!K*gc^hv1)0Qlpv>o=XP^u3-l*d zBacN$IBjIl}v%MfuYD#k`!)tO?cCIqZ{7U5F-b$i**xt~jYQ1!h02T*5CD9LQfthPG!bEyxio|pds z(rnVqAbjEW9mV*&-N_GNh26JzP<6fhhmdBc%?wIX)p#S9nz+;MaM)I%&^nAo97-dA ls5JtJS|fm{H3EoQ{{n>nU!|S>?(YBq002ovPDHLkV1m0=`2hd` diff --git a/templates/A.html b/templates/A.html deleted file mode 100644 index 9bc0178..0000000 --- a/templates/A.html +++ /dev/null @@ -1,28 +0,0 @@ -{% extends "results_layout.html" %} - -{% block body %} -

{{ lang_data.results.results }} {{ fetched }} {{ lang_data.results.seconds }}

- {% if results %} - {% for result in results %} -
- -
-

{{ result[1] }}

-

{{ result[3] }} • {{ result[2] }}

-

{{ result[5] }} | {{ result[4] }}

-
-
-
- {% endfor %} - - {% else %} -
- Your search '{{ q }}' came back with no results.
- Try rephrasing your search term and/or recorrect any spelling mistakes. -
- {% endif %} -{% endblock %} \ No newline at end of file diff --git a/static/search.html b/templates/search.html similarity index 86% rename from static/search.html rename to templates/search.html index fc381d4..710f381 100644 --- a/static/search.html +++ b/templates/search.html @@ -8,14 +8,14 @@

Ocásek

- close + close
diff --git a/templates/settings.html b/templates/settings.html new file mode 100644 index 0000000..c7540b2 --- /dev/null +++ b/templates/settings.html @@ -0,0 +1,70 @@ + + + + + + Settings + + + + +

Ocásek

+
+ + + +
+
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+
+
+
+
+

Settings

+

Theme

+ +
+ +

Language

+ +
+ + + +

Privacy

+ +
+ +

+ + +
+
+ + diff --git a/templates/results.html b/templates/text.html similarity index 100% rename from templates/results.html rename to templates/text.html diff --git a/text-google.go b/text-google.go new file mode 100644 index 0000000..0a49342 --- /dev/null +++ b/text-google.go @@ -0,0 +1,113 @@ +package main + +import ( + "fmt" + "html/template" + "log" + "net/http" + "net/url" + "strings" + "time" + + "github.com/PuerkitoBio/goquery" +) + +type TextSearchResult struct { + URL string + Header string + Description string +} + +func PerformTextSearch(query, safe, lang string) ([]TextSearchResult, error) { + var results []TextSearchResult + + client := &http.Client{} + safeParam := "&safe=off" + if safe == "active" { + safeParam = "&safe=active" + } + + langParam := "" + if lang != "" { + langParam = "&lr=" + lang + } + + searchURL := "https://www.google.com/search?q=" + url.QueryEscape(query) + safeParam + langParam + + req, err := http.NewRequest("GET", searchURL, nil) + if err != nil { + log.Fatalf("Failed to create request: %v", err) + } + + req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36") + + resp, err := client.Do(req) + if err != nil { + return nil, err + } + defer resp.Body.Close() + + doc, err := goquery.NewDocumentFromReader(resp.Body) + if err != nil { + return nil, err + } + + doc.Find(".yuRUbf").Each(func(i int, s *goquery.Selection) { + link := s.Find("a") + href, _ := link.Attr("href") + header := link.Find("h3").Text() + header = strings.TrimSpace(strings.TrimSuffix(header, "›")) + + descSelection := doc.Find(".VwiC3b").Eq(i) + description := "" + if descSelection.Length() > 0 { + description = descSelection.Text() + } + + results = append(results, TextSearchResult{ + URL: href, + Header: header, + Description: description, + }) + }) + + return results, nil +} + +func handleTextSearch(w http.ResponseWriter, query, safe, lang string) { + // Perform the text search + results, err := PerformTextSearch(query, safe, lang) + if err != nil { + log.Printf("Error performing text search: %v", err) + http.Error(w, "Internal Server Error", http.StatusInternalServerError) + return + } + + // Assuming you have a separate template for text search results + tmpl, err := template.ParseFiles("templates/text.html") // Ensure this path matches your templates' location + if err != nil { + log.Printf("Error parsing template: %v", err) + http.Error(w, "Internal Server Error", http.StatusInternalServerError) + return + } + + data := struct { + Results []TextSearchResult // Ensure this type matches the structure expected by your template + Query string + Fetched string + LanguageOptions []LanguageOption + CurrentLang string + }{ + Results: results, + Query: query, + Fetched: fmt.Sprintf("%.2f seconds", time.Since(time.Now()).Seconds()), // Example fetched time, adjust as necessary + LanguageOptions: languageOptions, // Assuming this is defined globally or elsewhere + CurrentLang: lang, + } + + err = tmpl.Execute(w, data) + if err != nil { + log.Printf("Error executing template: %v", err) + http.Error(w, "Internal Server Error", http.StatusInternalServerError) + } +} diff --git a/text.go b/text.go index 141c44c..e69de29 100644 --- a/text.go +++ b/text.go @@ -1,113 +0,0 @@ -package main - -import ( - "fmt" - "html/template" - "log" - "net/http" - "net/url" - "strings" - "time" - - "github.com/PuerkitoBio/goquery" -) - -type TextSearchResult struct { - URL string - Header string - Description string -} - -func PerformTextSearch(query, safe, lang string) ([]TextSearchResult, error) { - var results []TextSearchResult - - client := &http.Client{} - safeParam := "&safe=off" - if safe == "active" { - safeParam = "&safe=active" - } - - langParam := "" - if lang != "" { - langParam = "&lr=" + lang - } - - searchURL := "https://www.google.com/search?q=" + url.QueryEscape(query) + safeParam + langParam - - req, err := http.NewRequest("GET", searchURL, nil) - if err != nil { - log.Fatalf("Failed to create request: %v", err) - } - - req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36") - - resp, err := client.Do(req) - if err != nil { - return nil, err - } - defer resp.Body.Close() - - doc, err := goquery.NewDocumentFromReader(resp.Body) - if err != nil { - return nil, err - } - - doc.Find(".yuRUbf").Each(func(i int, s *goquery.Selection) { - link := s.Find("a") - href, _ := link.Attr("href") - header := link.Find("h3").Text() - header = strings.TrimSpace(strings.TrimSuffix(header, "›")) - - descSelection := doc.Find(".VwiC3b").Eq(i) - description := "" - if descSelection.Length() > 0 { - description = descSelection.Text() - } - - results = append(results, TextSearchResult{ - URL: href, - Header: header, - Description: description, - }) - }) - - return results, nil -} - -func handleTextSearch(w http.ResponseWriter, query, safe, lang string) { - // Perform the text search - results, err := PerformTextSearch(query, safe, lang) - if err != nil { - log.Printf("Error performing text search: %v", err) - http.Error(w, "Internal Server Error", http.StatusInternalServerError) - return - } - - // Assuming you have a separate template for text search results - tmpl, err := template.ParseFiles("templates/results.html") // Ensure this path matches your templates' location - if err != nil { - log.Printf("Error parsing template: %v", err) - http.Error(w, "Internal Server Error", http.StatusInternalServerError) - return - } - - data := struct { - Results []TextSearchResult // Ensure this type matches the structure expected by your template - Query string - Fetched string - LanguageOptions []LanguageOption - CurrentLang string - }{ - Results: results, - Query: query, - Fetched: fmt.Sprintf("%.2f seconds", time.Since(time.Now()).Seconds()), // Example fetched time, adjust as necessary - LanguageOptions: languageOptions, // Assuming this is defined globally or elsewhere - CurrentLang: lang, - } - - err = tmpl.Execute(w, data) - if err != nil { - log.Printf("Error executing template: %v", err) - http.Error(w, "Internal Server Error", http.StatusInternalServerError) - } -}