mirror of
https://github.com/OwO-Network/DeepLX.git
synced 2025-04-19 14:13:24 +00:00
fix: possible bugs
This commit is contained in:
parent
0815eb791c
commit
7246de3328
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
deepl-api
|
71
main.go
71
main.go
@ -3,6 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"math/rand"
|
"math/rand"
|
||||||
@ -21,6 +22,7 @@ type Lang struct {
|
|||||||
|
|
||||||
type CommonJobParams struct {
|
type CommonJobParams struct {
|
||||||
WasSpoken bool `json:"wasSpoken"`
|
WasSpoken bool `json:"wasSpoken"`
|
||||||
|
TranscribeAS string `json:"transcribe_as"`
|
||||||
RegionalVariant string `json:"regionalVariant"`
|
RegionalVariant string `json:"regionalVariant"`
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29,7 +31,7 @@ type Params struct {
|
|||||||
Splitting string `json:"splitting"`
|
Splitting string `json:"splitting"`
|
||||||
Lang Lang `json:"lang"`
|
Lang Lang `json:"lang"`
|
||||||
Timestamp int64 `json:"timestamp"`
|
Timestamp int64 `json:"timestamp"`
|
||||||
// CommonJobParams CommonJobParams `json:"commonJobParams"`
|
CommonJobParams CommonJobParams `json:"commonJobParams"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type Text struct {
|
type Text struct {
|
||||||
@ -54,6 +56,11 @@ func init_data(source_lang string, target_lang string) *PostData {
|
|||||||
SourceLangUserSelected: source_lang,
|
SourceLangUserSelected: source_lang,
|
||||||
TargetLang: target_lang,
|
TargetLang: target_lang,
|
||||||
},
|
},
|
||||||
|
CommonJobParams: CommonJobParams{
|
||||||
|
WasSpoken: false,
|
||||||
|
TranscribeAS: "",
|
||||||
|
RegionalVariant: "en-US",
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -64,7 +71,7 @@ func get_i_count(translate_text string) int64 {
|
|||||||
|
|
||||||
func getRandomNumber() int64 {
|
func getRandomNumber() int64 {
|
||||||
rand.Seed(time.Now().Unix())
|
rand.Seed(time.Now().Unix())
|
||||||
num := rand.Int63n(99999) + 100000
|
num := rand.Int63n(99999) + 8300000
|
||||||
return num * 1000
|
return num * 1000
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -85,12 +92,18 @@ type ResData struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
// display information
|
||||||
|
fmt.Println("DeepL X has been successfully launched! Listening on 0.0.0.0:1188")
|
||||||
|
fmt.Println("Made by sjlleo and missuo.")
|
||||||
|
|
||||||
// create a random id
|
// create a random id
|
||||||
id := getRandomNumber()
|
id := getRandomNumber()
|
||||||
r := gin.Default()
|
|
||||||
// r.SetTrustedProxies([]string{"192.168.36.153"})
|
|
||||||
r.GET("/", func(c *gin.Context) {
|
|
||||||
|
|
||||||
|
// set release mode
|
||||||
|
gin.SetMode(gin.ReleaseMode)
|
||||||
|
r := gin.Default()
|
||||||
|
|
||||||
|
r.GET("/", func(c *gin.Context) {
|
||||||
c.JSON(200, gin.H{
|
c.JSON(200, gin.H{
|
||||||
"code": 200,
|
"code": 200,
|
||||||
"msg": "DeepL API, Made by sjlleo and missuo. Go to /translate with POST.",
|
"msg": "DeepL API, Made by sjlleo and missuo. Go to /translate with POST.",
|
||||||
@ -101,10 +114,8 @@ func main() {
|
|||||||
r.POST("/translate", func(c *gin.Context) {
|
r.POST("/translate", func(c *gin.Context) {
|
||||||
reqj := ResData{}
|
reqj := ResData{}
|
||||||
c.BindJSON(&reqj)
|
c.BindJSON(&reqj)
|
||||||
// fmt.Printf("%v", &reqj)
|
|
||||||
source_lang := reqj.Source_Lang
|
source_lang := reqj.Source_Lang
|
||||||
target_lang := reqj.Target_Lang
|
target_lang := reqj.Target_Lang
|
||||||
// fmt.Println(reqj)
|
|
||||||
if source_lang == "" {
|
if source_lang == "" {
|
||||||
source_lang = "ZH"
|
source_lang = "ZH"
|
||||||
}
|
}
|
||||||
@ -114,27 +125,20 @@ func main() {
|
|||||||
translate_text := reqj.Trans_Text
|
translate_text := reqj.Trans_Text
|
||||||
// fmt.Printf("%v", translate_text)
|
// fmt.Printf("%v", translate_text)
|
||||||
if translate_text != "" {
|
if translate_text != "" {
|
||||||
|
|
||||||
url := "https://www2.deepl.com/jsonrpc"
|
url := "https://www2.deepl.com/jsonrpc"
|
||||||
|
|
||||||
id = id + 1
|
id = id + 1
|
||||||
|
|
||||||
post_data := init_data(source_lang, target_lang)
|
post_data := init_data(source_lang, target_lang)
|
||||||
|
|
||||||
text := Text{
|
text := Text{
|
||||||
Text: translate_text,
|
Text: translate_text,
|
||||||
RequestAlternatives: 3,
|
RequestAlternatives: 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
// set id
|
// set id
|
||||||
post_data.ID = id
|
post_data.ID = id
|
||||||
// set text
|
// set text
|
||||||
post_data.Params.Texts = append(post_data.Params.Texts, text)
|
post_data.Params.Texts = append(post_data.Params.Texts, text)
|
||||||
// set timestamp
|
// set timestamp
|
||||||
post_data.Params.Timestamp = getTimeStamp(get_i_count(translate_text))
|
post_data.Params.Timestamp = getTimeStamp(get_i_count(translate_text))
|
||||||
|
|
||||||
post_byte, _ := json.Marshal(post_data)
|
post_byte, _ := json.Marshal(post_data)
|
||||||
|
|
||||||
post_str := string(post_byte)
|
post_str := string(post_byte)
|
||||||
|
|
||||||
// add space if necessary
|
// add space if necessary
|
||||||
@ -145,7 +149,6 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
post_byte = []byte(post_str)
|
post_byte = []byte(post_str)
|
||||||
|
|
||||||
reader := bytes.NewReader(post_byte)
|
reader := bytes.NewReader(post_byte)
|
||||||
request, err := http.NewRequest("POST", url, reader)
|
request, err := http.NewRequest("POST", url, reader)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -153,26 +156,43 @@ func main() {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set Headers
|
||||||
request.Header.Set("Content-Type", "application/json")
|
request.Header.Set("Content-Type", "application/json")
|
||||||
|
request.Header.Set("Accept", "*/*")
|
||||||
|
request.Header.Set("x-app-os-name", "iOS")
|
||||||
|
request.Header.Set("x-app-os-version", "16.3.0")
|
||||||
|
request.Header.Set("Accept-Language", "en-US,en;q=0.9")
|
||||||
|
request.Header.Set("Accept-Encoding", "gzip, deflate, br")
|
||||||
|
request.Header.Set("x-app-device", "iPhone13,2")
|
||||||
|
request.Header.Set("User-Agent", "DeepL-iOS/2.6.0 iOS 16.3.0 (iPhone13,2)")
|
||||||
|
request.Header.Set("x-app-build", "353933")
|
||||||
|
request.Header.Set("x-app-version", "2.6")
|
||||||
|
request.Header.Set("Connection", "keep-alive")
|
||||||
|
|
||||||
client := &http.Client{}
|
client := &http.Client{}
|
||||||
resp, err := client.Do(request)
|
resp, err := client.Do(request)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
body, _ := io.ReadAll(resp.Body)
|
body, _ := io.ReadAll(resp.Body)
|
||||||
res := gjson.ParseBytes(body)
|
res := gjson.ParseBytes(body)
|
||||||
// fmt.Println(res)
|
// display response
|
||||||
// fmt.Println(res.Get("result").Bool())
|
fmt.Println(res)
|
||||||
if res.Get("error.code").String() == "-32600" {
|
if res.Get("error.code").String() == "-32600" {
|
||||||
log.Println(res.Get("error").String())
|
log.Println(res.Get("error").String())
|
||||||
c.JSON(406, gin.H{
|
c.JSON(406, gin.H{
|
||||||
"code": 406,
|
"code": 406,
|
||||||
"msg": "target_lang is not supported",
|
"msg": "Invalid target_lang",
|
||||||
})
|
})
|
||||||
return
|
return
|
||||||
|
} else {
|
||||||
|
if resp.StatusCode == 429 {
|
||||||
|
c.JSON(429, gin.H{
|
||||||
|
"code": 429,
|
||||||
|
"message": "Too Many Requests",
|
||||||
|
})
|
||||||
} else {
|
} else {
|
||||||
c.JSON(200, gin.H{
|
c.JSON(200, gin.H{
|
||||||
"code": 200,
|
"code": 200,
|
||||||
@ -180,19 +200,14 @@ func main() {
|
|||||||
"data": res.Get("result.texts.0.text").String(),
|
"data": res.Get("result.texts.0.text").String(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// data = res.Get("result.texts.0.text").String()
|
|
||||||
// if res.Get("result.lang_is_confident").String() == "false" {
|
|
||||||
|
|
||||||
// fmt.Printf(res.Get("result.texts.0.text").String())
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
c.JSON(404, gin.H{
|
c.JSON(404, gin.H{
|
||||||
"code": 404,
|
"code": 404,
|
||||||
"msg": "no text found",
|
"message": "No Text Found",
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
r.Run(":1199") // listen and serve on 0.0.0.0:1199
|
r.Run(":1188") // listen and serve on 0.0.0.0:1188
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user