添加插件hhsh
This commit is contained in:
parent
673dd3eb76
commit
5211d1d8c6
4 changed files with 68 additions and 0 deletions
2
go.mod
2
go.mod
|
@ -3,3 +3,5 @@ module go-bot
|
||||||
go 1.21.0
|
go 1.21.0
|
||||||
|
|
||||||
require github.com/BurntSushi/toml v1.3.2
|
require github.com/BurntSushi/toml v1.3.2
|
||||||
|
|
||||||
|
require github.com/goccy/go-json v0.10.2 // indirect
|
||||||
|
|
2
go.sum
2
go.sum
|
@ -1,2 +1,4 @@
|
||||||
github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8=
|
github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8=
|
||||||
github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
|
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
60
workers/hhsh.go
Normal 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) + "的释义"
|
||||||
|
}
|
|
@ -14,6 +14,10 @@ func NewWorker(parms []string, uid, gid, role, mid, rawMsg string) Worker {
|
||||||
return &Pkg{
|
return &Pkg{
|
||||||
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg),
|
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg),
|
||||||
}
|
}
|
||||||
|
case "hhsh":
|
||||||
|
return &Hhsh{
|
||||||
|
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg),
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
return &Emm{
|
return &Emm{
|
||||||
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg)}
|
StdAns: NewStdAns(parms, uid, gid, role, mid, rawMsg)}
|
||||||
|
|
Loading…
Reference in a new issue