添加插件hhsh

This commit is contained in:
liyp 2024-04-14 19:08:12 +08:00
parent 673dd3eb76
commit 5211d1d8c6
4 changed files with 68 additions and 0 deletions

2
go.mod
View file

@ -3,3 +3,5 @@ module go-bot
go 1.21.0
require github.com/BurntSushi/toml v1.3.2
require github.com/goccy/go-json v0.10.2 // indirect

2
go.sum
View file

@ -1,2 +1,4 @@
github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8=
github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU=
github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I=

60
workers/hhsh.go Normal file
View file

@ -0,0 +1,60 @@
package workers
import (
"fmt"
"io"
"net/http"
"strings"
"github.com/goccy/go-json"
)
type Hhsh struct {
*StdAns
}
func (a *Hhsh) GetMsg() string {
if len(a.Parms) < 2 {
return "请输入参数 如:!hhsh awsl"
}
// 去除换行符
raw_msg := strings.TrimRight(a.RawMsg, "\n")
fmt.Println("raw_msg:", raw_msg)
parms := strings.Split(raw_msg, " ")
url := "https://api.beiyu.vip/api/hhsh?str=" + parms[1]
// 输出请求地址
// fmt.Println("url:", url)
req, err := http.Get(url)
if err != nil {
return "接口异常!"
}
defer req.Body.Close()
body, err := io.ReadAll(req.Body)
if err != nil {
return err.Error()
}
// fmt.Println("pkg body:", string(body))
// var pkg []Package
var data map[string]interface{}
err = json.Unmarshal(body, &data)
if err != nil {
return err.Error()
}
resultSlipe := data["data"].([]interface{})
fmt.Println("resultSlipe:", resultSlipe)
if trans, ok := resultSlipe[0].(map[string]interface{})["trans"]; ok {
// println("trans:", trans.([]interface{}))
transSlice := trans.([]interface{})
msg := "[CQ:reply,id={" + a.MID + "}]("
for _, item := range transSlice {
// fmt.Print(item, " ")
msg += item.(string) + ""
}
return msg + ")"
}
// return string(resultSlipe[0].([]byte))
return "未找到关于" + resultSlipe[0].(map[string]interface{})["trans"].([]interface{})[0].(string) + "的释义"
}

View file

@ -14,6 +14,10 @@ func NewWorker(parms []string, uid, gid, role, mid, rawMsg string) Worker {
return &Pkg{
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg),
}
case "hhsh":
return &Hhsh{
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg),
}
default:
return &Emm{
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg)}