mozhi/pages/api.go

148 lines
5.2 KiB
Go
Raw Normal View History

2023-07-06 16:24:45 +05:30
package pages
import (
"codeberg.org/aryak/libmozhi"
2023-09-10 18:04:08 +05:30
"codeberg.org/aryak/mozhi/utils"
2024-04-14 18:41:18 +05:30
"encoding/base64"
2023-07-06 16:24:45 +05:30
"github.com/gofiber/fiber/v2"
2024-04-14 18:41:18 +05:30
"strings"
2023-07-06 16:24:45 +05:30
)
2023-08-27 21:27:46 +05:30
// HandleSourceLanguages godoc
2023-08-29 14:50:56 +05:30
//
2023-08-27 21:27:46 +05:30
// @Summary Show list of available source languages for engine
// @Param engine query string true "Engine name"
// @Success 200 {object} libmozhi.List
// @Router /api/source_languages [get]
2023-07-06 16:24:45 +05:30
func HandleSourceLanguages(c *fiber.Ctx) error {
2023-08-15 21:41:02 +05:30
engine := utils.Sanitize(c.Query("engine"), "alpha")
2023-07-06 16:24:45 +05:30
if engine == "" {
return fiber.NewError(fiber.StatusBadRequest, "engine is a required query string.")
2023-07-06 16:24:45 +05:30
}
data, err := libmozhi.LangList(engine, "sl")
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
2023-07-22 19:52:38 +05:30
}
2023-07-06 16:24:45 +05:30
return c.JSON(data)
}
2023-08-27 19:54:30 +05:30
2023-08-27 21:27:46 +05:30
// HandleTargetLanguages godoc
2023-08-29 14:50:56 +05:30
//
2023-08-27 21:27:46 +05:30
// @Summary Show list of available target languages for engine
// @Param engine query string true "Engine name"
// @Success 200 {object} libmozhi.List
// @Router /api/target_languages [get]
2023-07-06 16:24:45 +05:30
func HandleTargetLanguages(c *fiber.Ctx) error {
2023-08-15 21:41:02 +05:30
engine := utils.Sanitize(c.Query("engine"), "alpha")
2023-07-06 16:24:45 +05:30
if engine == "" {
return fiber.NewError(fiber.StatusBadRequest, "engine is a required query string.")
2023-07-06 16:24:45 +05:30
}
data, err := libmozhi.LangList(engine, "tl")
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
2023-07-22 19:52:38 +05:30
}
2023-07-06 16:24:45 +05:30
return c.JSON(data)
}
2023-08-27 19:54:30 +05:30
2023-08-27 21:27:46 +05:30
// HandleTTS godoc
2023-08-29 14:50:56 +05:30
//
2023-08-27 21:27:46 +05:30
// @Summary Get Text-To-Speech for specified language using specified engine
// @Param engine query string true "Engine name"
// @Param lang query string true "Language being TTS'd"
// @Param text query string true "Text being TTS'd"
// @Router /api/tts [get]
2023-07-06 16:24:45 +05:30
func HandleTTS(c *fiber.Ctx) error {
2023-08-15 21:41:02 +05:30
engine := utils.Sanitize(c.Query("engine"), "alpha")
lang := utils.Sanitize(c.Query("lang"), "alpha")
2023-07-22 19:54:15 +05:30
text := c.Query("text")
if engine == "" || text == "" || lang == "" {
return fiber.NewError(fiber.StatusBadRequest, "engine, lang, text are required query strings.")
2023-07-06 16:24:45 +05:30
}
data, err := libmozhi.TTS(engine, lang, text)
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
2023-07-06 16:24:45 +05:30
}
2023-07-22 19:54:15 +05:30
c.Set("Content-Type", "audio/mpeg")
2023-09-10 18:44:17 +05:30
return c.Status(fiber.StatusOK).Send(data)
2023-07-06 16:24:45 +05:30
}
2023-08-27 19:54:30 +05:30
2023-08-27 21:27:46 +05:30
// HandleTranslate godoc
2023-08-29 14:50:56 +05:30
//
// @Summary Translate text
// @Description When engine is set to all, it will return an array of libmozhi.LangOut.
// @Param engine query string true "Engine name"
// @Param from query string true "Source language"
// @Param to query string true "Target language"
// @Param text query string true "Text being translated"
2023-09-10 18:04:08 +05:30
// @Success 200 {object} libmozhi.LangOut
// @Router /api/translate [get]
2023-08-15 21:41:02 +05:30
func HandleTranslate(c *fiber.Ctx) error {
2023-10-11 15:57:28 +05:30
engine := utils.Sanitize(utils.GetQueryOrFormValue(c, "engine"), "alpha")
from := utils.Sanitize(utils.GetQueryOrFormValue(c, "from"), "alpha")
to := utils.Sanitize(utils.GetQueryOrFormValue(c, "to"), "alpha")
text := utils.GetQueryOrFormValue(c, "text")
if engine == "" || from == "" || to == "" || text == "" {
2023-08-15 21:41:02 +05:30
return fiber.NewError(fiber.StatusBadRequest, "from, to, engine, text are required query strings.")
}
if engine == "all" {
2024-02-20 10:11:45 +01:00
dataarr := libmozhi.TranslateAll(to, from, text)
return c.JSON(dataarr)
} else if strings.Contains(engine, ",") == true {
engineArr := strings.Split(engine, ",")
dataarr, err := libmozhi.TranslateSome(engineArr, to, from, text)
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
}
return c.JSON(dataarr)
} else {
2024-02-20 10:11:45 +01:00
data, err := libmozhi.Translate(engine, to, from, text)
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
}
2023-08-16 11:58:03 +05:30
return c.JSON(data)
}
2023-08-15 21:41:02 +05:30
}
2024-04-14 18:41:18 +05:30
// HandleImg godoc
//
// @Summary Translate an image
// @Description When engine is set to all, it will return an array of libmozhi.LangOut.
// @Param engine query string true "Engine name"
// @Param from query string true "Source language"
// @Param to query string true "Target language"
// @Param image query string true "PNG image in base64 format"
// @Success 200 {object} libmozhi.ImgOut
// @Router /api/image [post]
func HandleImg(c *fiber.Ctx) error {
engine := utils.Sanitize(utils.GetQueryOrFormValue(c, "engine"), "alpha")
from := utils.Sanitize(utils.GetQueryOrFormValue(c, "from"), "alpha")
to := utils.Sanitize(utils.GetQueryOrFormValue(c, "to"), "alpha")
image := utils.GetQueryOrFormValue(c, "image")
if engine == "" || from == "" || to == "" || image == "" {
return fiber.NewError(fiber.StatusBadRequest, "from, to, engine, image are required query strings.")
}
if _, err := base64.StdEncoding.DecodeString(image); err != nil {
return fiber.NewError(fiber.StatusBadRequest, "Invalid base64 image")
}
data, err := libmozhi.ImageGoogle(to, from, image)
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
}
return c.JSON(data)
}
// HandleEngines godoc
//
// @Summary List engines
// @Description Lists available Engines.
// @Success 200 {object} map[string]string
// @Router /api/engines [get]
func HandleEngines(c *fiber.Ctx) error {
engines := utils.EngineList()
serializedData := make(map[string]interface{}, len(engines))
for engineId, engineName := range engines {
serializedData[engineId] = engineName
}
return c.JSON(serializedData)
}