make switchlanguage work with POST
All checks were successful
mozhi pipeline / Push Docker image to Codeberg docker registry (push) Successful in 15m6s
mozhi pipeline / Build and publish artifacts (push) Successful in 24m43s

This commit is contained in:
Arya 2023-10-11 15:57:28 +05:30
parent d4d45832c8
commit 99a4eca07b
Signed by: arya
GPG Key ID: 842D12BDA50DF120
4 changed files with 28 additions and 23 deletions

View File

@ -75,10 +75,10 @@ func HandleTTS(c *fiber.Ctx) error {
// @Success 200 {object} libmozhi.LangOut // @Success 200 {object} libmozhi.LangOut
// @Router /api/translate [get] // @Router /api/translate [get]
func HandleTranslate(c *fiber.Ctx) error { func HandleTranslate(c *fiber.Ctx) error {
engine := utils.Sanitize(getQueryOrFormValue(c, "engine"), "alpha") engine := utils.Sanitize(utils.GetQueryOrFormValue(c, "engine"), "alpha")
from := utils.Sanitize(getQueryOrFormValue(c, "from"), "alpha") from := utils.Sanitize(utils.GetQueryOrFormValue(c, "from"), "alpha")
to := utils.Sanitize(getQueryOrFormValue(c, "to"), "alpha") to := utils.Sanitize(utils.GetQueryOrFormValue(c, "to"), "alpha")
text := getQueryOrFormValue(c, "text") text := utils.GetQueryOrFormValue(c, "text")
if engine == "" || from == "" || to == "" || text == "" { if engine == "" || from == "" || to == "" || text == "" {
return fiber.NewError(fiber.StatusBadRequest, "from, to, engine, text are required query strings.") return fiber.NewError(fiber.StatusBadRequest, "from, to, engine, text are required query strings.")
} }

View File

@ -5,6 +5,7 @@ import (
"slices" "slices"
"codeberg.org/aryak/libmozhi" "codeberg.org/aryak/libmozhi"
"codeberg.org/aryak/mozhi/utils"
"github.com/gofiber/fiber/v2" "github.com/gofiber/fiber/v2"
) )
@ -68,14 +69,6 @@ func langListMerge(engines map[string]string) ([]libmozhi.List, []libmozhi.List)
return deDuplicateLists(sl), deDuplicateLists(tl) return deDuplicateLists(sl), deDuplicateLists(tl)
} }
func getQueryOrFormValue(c *fiber.Ctx, key string) string {
if c.Method() == "POST" {
return c.FormValue(key)
} else {
return c.Query(key)
}
}
func HandleIndex(c *fiber.Ctx) error { func HandleIndex(c *fiber.Ctx) error {
engines := engineList() engines := engineList()
var enginesAsArray []string var enginesAsArray []string
@ -83,7 +76,7 @@ func HandleIndex(c *fiber.Ctx) error {
enginesAsArray = append(enginesAsArray, engine) enginesAsArray = append(enginesAsArray, engine)
} }
var engine = getQueryOrFormValue(c, "engine") var engine = utils.GetQueryOrFormValue(c, "engine")
if engine == "" || !slices.Contains(enginesAsArray, engine) { if engine == "" || !slices.Contains(enginesAsArray, engine) {
engine = "google" engine = "google"
} }
@ -97,9 +90,9 @@ func HandleIndex(c *fiber.Ctx) error {
targetLanguages, _ = libmozhi.LangList(engine, "tl") targetLanguages, _ = libmozhi.LangList(engine, "tl")
} }
originalText := getQueryOrFormValue(c, "text") originalText := utils.GetQueryOrFormValue(c, "text")
to := getQueryOrFormValue(c, "to") to := utils.GetQueryOrFormValue(c, "to")
from := getQueryOrFormValue(c, "from") from := utils.GetQueryOrFormValue(c, "from")
var translation libmozhi.LangOut var translation libmozhi.LangOut
var translationExists bool var translationExists bool

View File

@ -11,6 +11,7 @@ import (
"codeberg.org/aryak/mozhi/pages" "codeberg.org/aryak/mozhi/pages"
"codeberg.org/aryak/mozhi/public" "codeberg.org/aryak/mozhi/public"
"codeberg.org/aryak/mozhi/views" "codeberg.org/aryak/mozhi/views"
"codeberg.org/aryak/mozhi/utils"
"github.com/gofiber/fiber/v2" "github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/middleware/compress" "github.com/gofiber/fiber/v2/middleware/compress"
"github.com/gofiber/fiber/v2/middleware/filesystem" "github.com/gofiber/fiber/v2/middleware/filesystem"
@ -97,14 +98,14 @@ func Serve(port string) {
api.Get("/swagger/*", swagger.HandlerDefault) // default api.Get("/swagger/*", swagger.HandlerDefault) // default
app.All("/", pages.HandleIndex) app.All("/", pages.HandleIndex)
app.Get("/about", pages.HandleAbout) app.All("/switchlanguages", func(c *fiber.Ctx) error {
app.Get("/switchlanguages", func(c *fiber.Ctx) error { engine := utils.Sanitize(utils.GetQueryOrFormValue(c, "engine"), "alpha")
engine := c.Query("engine") from := utils.Sanitize(utils.GetQueryOrFormValue(c, "from"), "alpha")
from := c.Query("from") to := utils.Sanitize(utils.GetQueryOrFormValue(c, "to"), "alpha")
to := c.Query("to") text := utils.Sanitize(utils.GetQueryOrFormValue(c, "text"), "alpha")
text := c.Query("text")
return c.Redirect("/?engine="+engine+"&from="+to+"&to="+from+"&text="+text+"&redirected=true", 301) return c.Redirect("/?engine="+engine+"&from="+to+"&to="+from+"&text="+text+"&redirected=true", 301)
}) })
app.Get("/about", pages.HandleAbout)
app.Use("/", filesystem.New(filesystem.Config{ app.Use("/", filesystem.New(filesystem.Config{
MaxAge: 2592000, MaxAge: 2592000,
Root: http.FS(public.GetFiles()), Root: http.FS(public.GetFiles()),

View File

@ -1,6 +1,17 @@
package utils package utils
import "regexp" import (
"regexp"
"github.com/gofiber/fiber/v2"
)
func GetQueryOrFormValue(c *fiber.Ctx, key string) string {
if c.Method() == "POST" {
return c.FormValue(key)
} else {
return c.Query(key)
}
}
func Sanitize(str string, strip string) string { func Sanitize(str string, strip string) string {
nonAlphanumericRegex := regexp.MustCompile(`[^a-zA-Z]+`) nonAlphanumericRegex := regexp.MustCompile(`[^a-zA-Z]+`)