mirror of
https://codeberg.org/aryak/mozhi
synced 2025-01-10 12:57:51 +05:30
add API
This commit is contained in:
parent
9e6e7a3ef2
commit
1cf822eb80
1
go.mod
1
go.mod
@ -19,6 +19,7 @@ require (
|
|||||||
github.com/antchfx/htmlquery v1.3.0 // indirect
|
github.com/antchfx/htmlquery v1.3.0 // indirect
|
||||||
github.com/antchfx/xmlquery v1.3.17 // indirect
|
github.com/antchfx/xmlquery v1.3.17 // indirect
|
||||||
github.com/antchfx/xpath v1.2.4 // indirect
|
github.com/antchfx/xpath v1.2.4 // indirect
|
||||||
|
github.com/carlmjohnson/requests v0.23.4 // indirect
|
||||||
github.com/gobwas/glob v0.2.3 // indirect
|
github.com/gobwas/glob v0.2.3 // indirect
|
||||||
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
|
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
|
||||||
github.com/golang/protobuf v1.5.3 // indirect
|
github.com/golang/protobuf v1.5.3 // indirect
|
||||||
|
2
go.sum
2
go.sum
@ -86,6 +86,8 @@ github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24
|
|||||||
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
|
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
|
||||||
github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
|
github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
|
||||||
github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
|
github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
|
||||||
|
github.com/carlmjohnson/requests v0.23.4 h1:AxcvapfB9RPXLSyvAHk9YJoodQ43ZjzNHj6Ft3tQGdg=
|
||||||
|
github.com/carlmjohnson/requests v0.23.4/go.mod h1:Qzp6tW4DQyainPP+tGwiJTzwxvElTIKm0B191TgTtOA=
|
||||||
github.com/cbroglie/mustache v1.4.0/go.mod h1:SS1FTIghy0sjse4DUVGV1k/40B1qE1XkD9DtDsHo9iM=
|
github.com/cbroglie/mustache v1.4.0/go.mod h1:SS1FTIghy0sjse4DUVGV1k/40B1qE1XkD9DtDsHo9iM=
|
||||||
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
||||||
github.com/census-instrumentation/opencensus-proto v0.3.0/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
github.com/census-instrumentation/opencensus-proto v0.3.0/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
||||||
|
62
pages/api.go
Normal file
62
pages/api.go
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
package pages
|
||||||
|
|
||||||
|
import (
|
||||||
|
"codeberg.org/aryak/simplytranslate/utils"
|
||||||
|
"github.com/gofiber/fiber/v2"
|
||||||
|
)
|
||||||
|
|
||||||
|
func HandleSourceLanguages(c *fiber.Ctx) error {
|
||||||
|
engine := c.Query("engine")
|
||||||
|
if engine == "" {
|
||||||
|
return c.SendStatus(fiber.StatusBadRequest)
|
||||||
|
}
|
||||||
|
var data []utils.List
|
||||||
|
if engine == "google" {
|
||||||
|
data = utils.LangListGoogle("sl")
|
||||||
|
} else if engine == "libre" {
|
||||||
|
data = utils.LangListLibreTranslate("sl")
|
||||||
|
} else if engine == "reverso" {
|
||||||
|
data = utils.LangListReverso("sl")
|
||||||
|
} else if engine == "deepl" {
|
||||||
|
data = utils.LangListDeepl("sl")
|
||||||
|
}
|
||||||
|
return c.JSON(data)
|
||||||
|
}
|
||||||
|
func HandleTargetLanguages(c *fiber.Ctx) error {
|
||||||
|
engine := c.Query("engine")
|
||||||
|
if engine == "" {
|
||||||
|
return c.SendStatus(fiber.StatusBadRequest)
|
||||||
|
}
|
||||||
|
var data []utils.List
|
||||||
|
if engine == "google" {
|
||||||
|
data = utils.LangListGoogle("tl")
|
||||||
|
} else if engine == "libre" {
|
||||||
|
data = utils.LangListLibreTranslate("sl")
|
||||||
|
} else if engine == "reverso" {
|
||||||
|
data = utils.LangListReverso("tl")
|
||||||
|
} else if engine == "deepl" {
|
||||||
|
data = utils.LangListDeepl("tl")
|
||||||
|
}
|
||||||
|
return c.JSON(data)
|
||||||
|
}
|
||||||
|
func HandleTTS(c *fiber.Ctx) error {
|
||||||
|
engine := c.Query("engine")
|
||||||
|
lang := c.Query("lang")
|
||||||
|
text := c.Query("text")
|
||||||
|
// Why does go not have an andor statement :(
|
||||||
|
if engine == "" {
|
||||||
|
return c.SendStatus(fiber.StatusBadRequest)
|
||||||
|
} else if text == "" {
|
||||||
|
return c.SendStatus(fiber.StatusBadRequest)
|
||||||
|
} else if lang == "" {
|
||||||
|
return c.SendStatus(fiber.StatusBadRequest)
|
||||||
|
}
|
||||||
|
var data string
|
||||||
|
if engine == "google" {
|
||||||
|
data = utils.TTSGoogle(lang, text)
|
||||||
|
} else if engine == "reverso" {
|
||||||
|
data = utils.TTSReverso(lang, text)
|
||||||
|
}
|
||||||
|
c.Set("Content-Type", "audio/mpeg")
|
||||||
|
return c.Send([]byte(data))
|
||||||
|
}
|
@ -49,7 +49,6 @@ func Serve(port string) {
|
|||||||
err = ctx.Status(code).Render("error", fiber.Map{
|
err = ctx.Status(code).Render("error", fiber.Map{
|
||||||
"error": err,
|
"error": err,
|
||||||
"link": link,
|
"link": link,
|
||||||
"branch": utils.Branch,
|
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ctx.Status(fiber.StatusInternalServerError).SendString("Internal Server Error")
|
return ctx.Status(fiber.StatusInternalServerError).SendString("Internal Server Error")
|
||||||
@ -76,7 +75,6 @@ func Serve(port string) {
|
|||||||
// LimitReached: func(c *fiber.Ctx) error {
|
// LimitReached: func(c *fiber.Ctx) error {
|
||||||
// return c.Status(429).Render("ratelimit_gt", fiber.Map{
|
// return c.Status(429).Render("ratelimit_gt", fiber.Map{
|
||||||
// "Title": "Rate limit exceeded",
|
// "Title": "Rate limit exceeded",
|
||||||
// "branch": utils.Branch,
|
|
||||||
// })
|
// })
|
||||||
// },
|
// },
|
||||||
//})
|
//})
|
||||||
@ -99,6 +97,10 @@ func Serve(port string) {
|
|||||||
})
|
})
|
||||||
|
|
||||||
app.Get("/", pages.HandleIndex)
|
app.Get("/", pages.HandleIndex)
|
||||||
|
//app.Get("/api/translate", pages.HandleTranslateApi)
|
||||||
|
app.Get("/api/source_languages", pages.HandleSourceLanguages)
|
||||||
|
app.Get("/api/target_languages", pages.HandleTargetLanguages)
|
||||||
|
app.Get("/api/tts", pages.HandleTTS)
|
||||||
app.Static("/css", "./public/css", staticConfig)
|
app.Static("/css", "./public/css", staticConfig)
|
||||||
app.Static("/robots.txt", "./public/robots.txt", staticConfig)
|
app.Static("/robots.txt", "./public/robots.txt", staticConfig)
|
||||||
app.Static("/favicon.ico", "./public/assets/favicon.ico", staticConfig)
|
app.Static("/favicon.ico", "./public/assets/favicon.ico", staticConfig)
|
||||||
|
@ -94,8 +94,8 @@ func LangListReverso(listType string) []List {
|
|||||||
Name: "Greek",
|
Name: "Greek",
|
||||||
},
|
},
|
||||||
List{
|
List{
|
||||||
Id: "Hebrew",
|
Id: "heb",
|
||||||
Name: "heb",
|
Name: "Hebrew",
|
||||||
},
|
},
|
||||||
List{
|
List{
|
||||||
Id: "hin",
|
Id: "hin",
|
||||||
|
142
utils/tts.go
Normal file
142
utils/tts.go
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/carlmjohnson/requests"
|
||||||
|
"os"
|
||||||
|
"context"
|
||||||
|
"encoding/base64"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ReversoTTS struct {
|
||||||
|
Id string
|
||||||
|
Voice string
|
||||||
|
}
|
||||||
|
|
||||||
|
func TTSGoogle(lang string, query string) string {
|
||||||
|
params := "?tl="+lang+"&q="+query+"&client=tw-ob"
|
||||||
|
var file string
|
||||||
|
url := "https://translate.google.com/translate_tts"+params
|
||||||
|
err := requests.
|
||||||
|
URL(url).
|
||||||
|
ToString(&file).
|
||||||
|
Fetch(context.Background())
|
||||||
|
if err != nil {
|
||||||
|
file = ""
|
||||||
|
}
|
||||||
|
return file
|
||||||
|
}
|
||||||
|
func TTSReverso(lang string, query string) string {
|
||||||
|
var TTSData = []ReversoTTS{
|
||||||
|
// http://voice.reverso.net/RestPronunciation.svc/v1/output=json/GetAvailableVoices with randomized deduplication
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "ar",
|
||||||
|
Voice: "Mehdi22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "zh",
|
||||||
|
Voice: "Lulu22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "cz",
|
||||||
|
Voice: "Eliska22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "dk",
|
||||||
|
Voice: "Mette22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "nl",
|
||||||
|
Voice: "Daan22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "en",
|
||||||
|
Voice: "Will22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "fr",
|
||||||
|
Voice: "Margaux22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "de",
|
||||||
|
Voice: "Andreas22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "gr",
|
||||||
|
Voice: "Dimitris22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "heb",
|
||||||
|
Voice: "he-IL-Asaf",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "it",
|
||||||
|
Voice: "Chiara22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "jp",
|
||||||
|
Voice: "Sakura22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "kr",
|
||||||
|
Voice: "Minji22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "pl",
|
||||||
|
Voice: "Monika22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "pt",
|
||||||
|
Voice: "Celia22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "ro",
|
||||||
|
Voice: "ro-RO-Andrei",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "ru",
|
||||||
|
Voice: "Alyona22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "es",
|
||||||
|
Voice: "Antonio22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "se",
|
||||||
|
Voice: "Erik22k",
|
||||||
|
},
|
||||||
|
ReversoTTS{
|
||||||
|
Id: "tr",
|
||||||
|
Voice: "Ipek22k",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
// https://voice.reverso.net/RestPronunciation.svc/v1/output=json/GetVoiceStream/voiceName=Lulu22k?voiceSpeed=80&inputText=6K%20V6aqM Base64 input text
|
||||||
|
text := base64.StdEncoding.EncodeToString([]byte(query))
|
||||||
|
var voice string
|
||||||
|
for _, s := range TTSData {
|
||||||
|
if s.Id == lang {
|
||||||
|
voice = s.Voice
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
params := "voiceName="+voice+"?voiceSpeed=80&inputText="+text
|
||||||
|
|
||||||
|
var file string
|
||||||
|
|
||||||
|
url := "https://voice.reverso.net/RestPronunciation.svc/v1/output=json/GetVoiceStream/"+params
|
||||||
|
|
||||||
|
UserAgent, ok := os.LookupEnv("SIMPLYTRANSLATE_USER_AGENT")
|
||||||
|
if !ok {
|
||||||
|
UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/110.0.0.0 Safari/537.36"
|
||||||
|
}
|
||||||
|
|
||||||
|
err := requests.
|
||||||
|
URL(url).
|
||||||
|
ToString(&file).
|
||||||
|
UserAgent(UserAgent).
|
||||||
|
Fetch(context.Background())
|
||||||
|
if err != nil {
|
||||||
|
file = ""
|
||||||
|
}
|
||||||
|
return file
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user