mirror of
https://codeberg.org/aryak/mozhi
synced 2024-12-22 13:39:45 +05:30
add support for disablin engines
This commit is contained in:
parent
0e2be0cd32
commit
fc6f689fb6
17
README.md
17
README.md
@ -29,6 +29,23 @@ Mozhi makes use of swagger (with the swagger fiber middleware) to manage the doc
|
||||
|
||||
You can find it in /api/swagger of any instance.
|
||||
|
||||
## Configuration
|
||||
Features of Mozhi can be customized and toggled on/off using Environment Variables.
|
||||
|
||||
- `MOZHI_PORT`: Port the webserver listens on (if hosting API)
|
||||
- `MOZHI_USER_AGENT`: Change user agent used to make HTTP requests
|
||||
- `MOZHI_LIBRETRANSLATE_URL`: URL of Libretranslate instance (Example: `MOZHI_LIBRETRANSLATE_URL=https://lt.psf.lt`)
|
||||
|
||||
These envvars turn off/on engines. By default all of them are enabled.
|
||||
- `MOZHI_GOOGLE_ENABLED`
|
||||
- `MOZHI_REVERSO_ENABLED`
|
||||
- `MOZHI_DEEPL_ENABLED`
|
||||
- `MOZHI_LIBRETRANSLATE_ENABLED`
|
||||
- `MOZHI_YANDEX_ENABLED`
|
||||
- `MOZHI_WATSON_ENABLED`
|
||||
- `MOZHI_MYMEMORY_ENABLED`
|
||||
- `MOZHI_DUCKDUCKGO_ENABLED`
|
||||
|
||||
## Features
|
||||
- An all mode where the responses of all supported engines will be shown.
|
||||
- Autodetect which will show the language that was detected
|
||||
|
1
TODO.md
1
TODO.md
@ -2,7 +2,6 @@
|
||||
- Create a web interface
|
||||
- Interactive/Step-by-step CLI
|
||||
- CI/CD
|
||||
- Support for disabling engines
|
||||
- Ability for user to choose engines they want to use
|
||||
- Proper Error handling for requests.go
|
||||
- Tell which language Detect Language chose -- Only support for deepl and google is pending
|
||||
|
@ -23,20 +23,21 @@ var langlistCmd = &cobra.Command{
|
||||
list, err := utils.LangList(engineused, listtype)
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
}
|
||||
idxs, err := fuzzyfinder.FindMulti(
|
||||
list,
|
||||
func(i int) string {
|
||||
return list[i].Name
|
||||
})
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
}
|
||||
for _, idx := range idxs {
|
||||
if raw == true {
|
||||
fmt.Println(list[idx].Id)
|
||||
} else {
|
||||
fmt.Println("Selected Language:", list[idx].Id, "("+list[idx].Name+")")
|
||||
} else {
|
||||
idxs, err := fuzzyfinder.FindMulti(
|
||||
list,
|
||||
func(i int) string {
|
||||
return list[i].Name
|
||||
})
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
}
|
||||
for _, idx := range idxs {
|
||||
if raw == true {
|
||||
fmt.Println(list[idx].Id)
|
||||
} else {
|
||||
fmt.Println("Selected Language:", list[idx].Id, "("+list[idx].Name+")")
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
|
@ -41,6 +41,7 @@ var translateCmd = &cobra.Command{
|
||||
fmt.Println("Source Language: " + data[i].SourceLang)
|
||||
fmt.Println("Target Language: " + data[i].TargetLang)
|
||||
}
|
||||
fmt.Println("-----------------------------------")
|
||||
}
|
||||
} else {
|
||||
data, err := utils.Translate(engine, dest, source, query)
|
||||
|
@ -17,32 +17,39 @@ type LangOut struct {
|
||||
TargetLang string `json:"target_language"`
|
||||
}
|
||||
|
||||
func EnvTrueNoExist(env string) bool {
|
||||
if _, ok := os.LookupEnv(env); ok == false || os.Getenv(env) == "true" {
|
||||
return true
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
func LangList(engine string, listType string) ([]List, error) {
|
||||
var data []List
|
||||
if listType != "sl" && listType != "tl" {
|
||||
return []List{}, errors.New("list type invalid: either give tl for target languages or sl for source languages.")
|
||||
}
|
||||
if engine == "google" {
|
||||
if engine == "google" && EnvTrueNoExist("MOZHI_GOOGLE_ENABLED") {
|
||||
data = LangListGoogle(listType)
|
||||
} else if engine == "libre" {
|
||||
if os.Getenv("MOZHI_LIBRETRANSLATE_URL") == "" {
|
||||
} else if engine == "libre" && EnvTrueNoExist("MOZHI_LIBRETRANSLATE_ENABLED") {
|
||||
if EnvTrueNoExist("MOZHI_LIBRETRANSLATE_URL") {
|
||||
return []List{}, errors.New("Please set MOZHI_LIBRETRANSLATE_URL if you want to use libretranslate. Example: MOZHI_LIBRETRANSLATE_URL=https://lt.psf.lt")
|
||||
}
|
||||
data = LangListLibreTranslate(listType)
|
||||
} else if engine == "reverso" {
|
||||
} else if engine == "reverso" && EnvTrueNoExist("MOZHI_REVERSO_ENABLED") {
|
||||
data = LangListReverso(listType)
|
||||
} else if engine == "deepl" {
|
||||
} else if engine == "deepl" && EnvTrueNoExist("MOZHI_DEEPL_ENABLED") {
|
||||
data = LangListDeepl(listType)
|
||||
} else if engine == "watson" {
|
||||
} else if engine == "watson" && EnvTrueNoExist("MOZHI_WATSON_ENABLED") {
|
||||
data = LangListWatson(listType)
|
||||
} else if engine == "yandex" {
|
||||
} else if engine == "yandex" && EnvTrueNoExist("MOZHI_YANDEX_ENABLED") {
|
||||
data = LangListYandex(listType)
|
||||
} else if engine == "mymemory" {
|
||||
} else if engine == "mymemory" && EnvTrueNoExist("MOZHI_MYMEMORY_ENABLED") {
|
||||
data = LangListMyMemory(listType)
|
||||
} else if engine == "duckduckgo" {
|
||||
} else if engine == "duckduckgo" && EnvTrueNoExist("MOZHI_DUCKDUCKGO_ENABLED") {
|
||||
data = LangListDuckDuckGo(listType)
|
||||
} else {
|
||||
return []List{}, errors.New("Engine does not exist.")
|
||||
return []List{}, errors.New("Engine does not exist or has been disabled.")
|
||||
}
|
||||
return data, nil
|
||||
}
|
||||
@ -51,27 +58,27 @@ func LangList(engine string, listType string) ([]List, error) {
|
||||
func Translate(engine string, to string, from string, text string) (LangOut, error) {
|
||||
var err error
|
||||
var data LangOut
|
||||
if engine == "google" {
|
||||
if engine == "google" && EnvTrueNoExist("MOZHI_GOOGLE_ENABLED") {
|
||||
data, err = TranslateGoogle(to, from, text)
|
||||
} else if engine == "libre" {
|
||||
} else if engine == "libre" && EnvTrueNoExist("MOZHI_LIBRETRANSLATE_ENABLED") {
|
||||
if os.Getenv("MOZHI_LIBRETRANSLATE_URL") == "" {
|
||||
return LangOut{}, errors.New("Please set MOZHI_LIBRETRANSLATE_URL if you want to use libretranslate. Example: MOZHI_LIBRETRANSLATE_URL=https://lt.psf.lt")
|
||||
}
|
||||
data, err = TranslateLibreTranslate(to, from, text)
|
||||
} else if engine == "reverso" {
|
||||
} else if engine == "reverso" && EnvTrueNoExist("MOZHI_REVERSO_ENABLED") {
|
||||
data, err = TranslateReverso(to, from, text)
|
||||
} else if engine == "deepl" {
|
||||
} else if engine == "deepl" && EnvTrueNoExist("MOZHI_DEEPL_ENABLED") {
|
||||
data, err = TranslateDeepl(to, from, text)
|
||||
} else if engine == "watson" {
|
||||
} else if engine == "watson" && EnvTrueNoExist("MOZHI_WATSON_ENABLED") {
|
||||
data, err = TranslateWatson(to, from, text)
|
||||
} else if engine == "yandex" {
|
||||
} else if engine == "yandex" && EnvTrueNoExist("MOZHI_YANDEX_ENABLED") {
|
||||
data, err = TranslateYandex(to, from, text)
|
||||
} else if engine == "mymemory" {
|
||||
} else if engine == "mymemory" && EnvTrueNoExist("MOZHI_MYMEMORY_ENABLED") {
|
||||
data, err = TranslateMyMemory(to, from, text)
|
||||
} else if engine == "duckduckgo" {
|
||||
} else if engine == "duckduckgo" && EnvTrueNoExist("MOZHI_DUCKDUCKGO_ENABLED") {
|
||||
data, err = TranslateDuckDuckGo(to, from, text)
|
||||
} else {
|
||||
return LangOut{}, errors.New("Engine does not exist.")
|
||||
return LangOut{}, errors.New("Engine does not exist or has been disabled.")
|
||||
}
|
||||
if err != nil {
|
||||
return LangOut{}, err
|
||||
@ -82,12 +89,12 @@ func Translate(engine string, to string, from string, text string) (LangOut, err
|
||||
func TTS(engine string, lang string, text string) ([]byte, error) {
|
||||
var err error
|
||||
var data []byte
|
||||
if engine == "google" {
|
||||
if engine == "google" && EnvTrueNoExist("MOZHI_GOOGLE_ENABLED") {
|
||||
data, err = TTSGoogle(lang, text)
|
||||
} else if engine == "reverso" {
|
||||
} else if engine == "reverso" && EnvTrueNoExist("MOZHI_REVERSO_ENABLED") {
|
||||
data, err = TTSReverso(lang, text)
|
||||
} else {
|
||||
return []byte(""), errors.New("Engine does not exist and/or doesn't support TTS.")
|
||||
return []byte(""), errors.New("Engine does not exist and/or doesn't support TTS and/or has been disabled.")
|
||||
}
|
||||
if err != nil {
|
||||
return []byte(""), err
|
||||
|
Loading…
Reference in New Issue
Block a user