package apertium import ( "encoding/json" "errors" "fmt" "io/ioutil" "net/http" "net/url" "github.com/eeeXun/gtt/internal/translate/core" ) const ( textURL = "https://www.apertium.org/apy/translate?langpair=%s|%s&q=%s" ) type Translator struct { *core.APIKey *core.Language *core.TTSLock core.EngineName } func NewTranslator() *Translator { return &Translator{ APIKey: new(core.APIKey), Language: new(core.Language), TTSLock: core.NewTTSLock(), EngineName: core.NewEngineName("Apertium"), } } func (t *Translator) GetAllLang() []string { return lang } func (t *Translator) Translate(message string) (translation *core.Translation, err error) { translation = new(core.Translation) var data map[string]interface{} urlStr := fmt.Sprintf( textURL, langCode[t.GetSrcLang()], langCode[t.GetDstLang()], url.QueryEscape(message), ) res, err := http.Get(urlStr) if err != nil { return nil, err } body, err := ioutil.ReadAll(res.Body) if err != nil { return nil, err } if err = json.Unmarshal(body, &data); err != nil { return nil, err } if len(data) <= 0 { return nil, errors.New("Translation not found") } // If responseData is nil, then suppose the translation pair is not available if data["responseData"] == nil { return nil, errors.New(fmt.Sprintf("%s does not support translate from %s to %s.", t.GetEngineName(), t.GetSrcLang(), t.GetDstLang(), )) } translation.TEXT = data["responseData"].(map[string]interface{})["translatedText"].(string) return translation, nil } func (t *Translator) PlayTTS(lang, message string) error { defer t.ReleaseLock() return errors.New(t.GetEngineName() + " does not support text to speech") }