CleverQQ机器人框架Golang版SDK

CleverQQ-SDK-Golang

CleverQQ机器人框架Golang版SDK

CleverQQ框架 官方已停止服务

本项目为CleverQQ(原IRQQ)插件的Golang SDK, 方便Gopher们开发插件.

使用过程中有任何问题或建议, 请大胆提Issue或PR.

更新日志

2019-09-12: 修复IRUploadPic无法正常上传图片的问题, 新增file2byte()函数用以读取文件返回[]byte, 新增TODO List任务.2019-08-04: 给IR_Event事件添加recover, 避免插件panic直接导致框架主程序闪退, 但该功能默认情况下关闭, 需要clvq.OnRecover=true开启2019-08-01: 完善文档, 提出获取本项目可能出现的异常及其解决措施2019-07-31: 增加快速编译dll工具2019-07-30: 修复IRIfFriend函数的Bug2019-07-30: 过滤一些无用文件2019-07-30: 上传本项目

注意

本项目使用了cgo, 而框架提供的IRapi.dll为32位, 故请确保你的系统中有安装32位GCC编译器

附我的GCC编译器

编译时, 请将输出的.dll文件名修改为插件名称.IR.dll, 与你代码中的插件名称保持一致, 否则会导致框架无法正常启动(闪退)请勿在项目的其他包内导入clvq包, 因为这会导致IR_Create IR_Message等4个函数重复export, 最后导致框架调用到你的插件时会闪退

获取

go get github.com/yguilai/CleverQQ-SDK-Golang

获取本项目可能出现的异常

由于地区原因, 无法成功获取到golang.org的包

https fetch failed: Get https://golang.org/x/text/encoding/simplifiedchinese?go-get=1: dial tcp 216.239.37.1:443: // connectex: A connection attempt failed because the connected party did not properly respond after a period of time,or established connection failed because connected host has failed to respond.

请尝试修改GO的系统环境变量后, 重新go get本项目. 如下:

//打开cmd,执行SET GO111MODULE=onSET GOPROXY=https://goproxy.io

通过此设置, 当你go get通过go mod方式管理的项目时, 会将https://goproxy.io作为你的代理

此功能目前对非go mod方式管理的go语言项目无效

本地GCC编译器非32位, 或无32位GCC编译器, go get后得到如下异常:

# github.com/yguilai/CleverQQ-SDK-Golang/clvqcc1.exe: sorry, unimplemented: 64-bit mode not compiled in

此异常可以忽略, 你只需遵循使用章节中的规则编译插件即可.

使用

0.导入本项目

package mainimport "github.com/yguilai/CleverQQ-SDK-Golang/clvq"func init() { clvq.PluginName = "插件名称" clvq.PluginVer = "1.0.0" //插件版本 clvq.PluginDesc = "插件说明" clvq.PluginAuthor = "作者" clvq.IREvent = irEvent}// main函数不写代码, 仅为编译需要func main() {}//通过实现clvq包内的IREvent方式来处理机器人分发下来的所有消息, 事件//如果你有e语言开发插件的经验,相信你会很快上手这个SDKfunc irEvent(qq string, msgType, subMsgType int, msgFrom, tigObjAct, tigObjPas, msg, msgNum, msgId, rawMsg, json string, ptrNext int) int { return clvq.MT_CONTINUE}

1.修改几个GO的系统环境变量

SET CGO_LDFLAGS=-Wl,--kill-atSET CGO_ENABLED=1SET GOOS=windowsSET GOARCH=386

2.编译

go build -ldflags "-s -w" -buildmode=c-shared -o 插件名称.IR.dll

建议使用bat脚本, 这会让步骤1中的修改变为临时的. 如本项目demo中的build.bat. 建议按照规则使用快速编译工具.

快速编译工具

使用

将tool目录下的build.exe和build.bat文件复制到与你导入本项目的.go文件同级目录下, 双击执行build.exe即可.

注意: 你的.go文件必须包含你自定义的插件名, 例如clvq.PluginName = "demo"

TODO List

License

MIT