diff --git a/clients/gohttp/README.md b/clients/gohttp/README.md index a42688a..dd1908a 100644 --- a/clients/gohttp/README.md +++ b/clients/gohttp/README.md @@ -1,54 +1,44 @@ -# WeChat Rest +# Wrest Chat -基于 [WeChatFerry RPC](https://github.com/lich0821/WeChatFerry/tree/master/WeChatFerry) 实现,主要特性如下: +智能聊天助手,是一个通用的聊天辅助程序,通过 **Nanomsg 协议** 与聊天软件互通,内置 WEB 管理界面,可接入GPT、Gemini、星火、文心、混元、通义千问等大语言模型。目前已适配 *PC微信*,更多聊天软件适配中,敬请期待! + +> 为保证客户端纯粹性,此包仅提供 HTTP 和 Websocket 接口能力,完整功能可参考 [wrest-chat](https://github.com/opentdp/wrest-chat) 项目说明 + +## 功能特性 + +这里仅列举了一些主要的特性,其他信息请参阅[项目文档](https://docs.opentdp.org/#/wrest/)(by [KincaidYang](https://github.com/KincaidYang)) - 使用 Go 语言编写,无运行时依赖 - 提供 HTTP 接口,便于对接各类编程语言 - 提供 Websocket 接口,接收推送的新消息 -- 支持 HTTP/WS 接口授权,参见 [配置说明](#配置说明) -- 支持作为 SDK 使用,参见 [wcferry/README.md](https://github.com/opentdp/wechat-rest/wcferry/README.md) -- 内置 AI 机器人,参见 [wclient/README.md](https://github.com/opentdp/wechat-rest/wclient/README.md) -- 内置 Web 管理界面,参见 `http://localhost:7600/` -- 内置 Api 调试工具,参见 `http://localhost:7600/swagger/` +- 支持 HTTP/WS 接口授权,参见 [配置文件解析](https://docs.opentdp.org/#/wrest/配置文件解析) +- 支持作为 SDK 使用,参见 [SDK模块说明](https://docs.opentdp.org/#/wrest/开发指南/SDK模块) +- 内置 AI 机器人,参见 [BOT模块说明](https://docs.opentdp.org/#/wrest/开发指南/BOT模块) +- 内置 Web 管理界面,可以管理机器人各项配置 +- 内置 Api 调试工具,所有接口都可以在线调试 - 尽可能将消息中的 Xml 转为 Object,便于前端解析 +- 支持计划任务、外部指令、指令插件等扩展功能,详见 [wrest-plugin](https://github.com/opentdp/wrest-plugin) -> 为保证客户端纯粹性,此包仅提供 HTTP 和 Websocket 接口能力,完整功能可参考 [wechat-rest](https://github.com/opentdp/wechat-rest) 项目说明 +## 代码提交 -## 快速开始 +提交代码时请使用 `feat: something` 作为说明,支持的标识如下 -1、下载并安装 [WeChatSetup-3.9.2.23.exe](https://github.com/opentdp/wechat-rest/releases/download/v0.0.1/WeChatSetup-3.9.2.23.exe) 和 [wechat-rest.zip](https://github.com/opentdp/wechat-rest/releases) +- `feat` 新功能(feature) +- `fix` 错误修复 +- `docs` 文档更改(documentation) +- `style` 格式(不影响代码含义的更改,空格、格式、缺少分号等) +- `refactor` 重构(即不是新功能,也不是修补bug的代码变动) +- `perf` 优化(提高性能的代码更改) +- `test` 测试(添加缺失的测试或更正现有测试) +- `chore` 构建过程或辅助工具的变动 +- `revert` 还原以前的提交 -- 非开发者请直接下载编译好的二进制文件,不要下载源码 +## 免责声明 -2、双击 `wrest.exe` 将自动启动微信和接口服务,扫码登录微信 +[WrestChat](https://github.com/opentdp/wrest-chat) 和 [WeChatFerry](https://github.com/lich0821/WeChatFerry) 是供学习交流的开源项目,代码及其制品仅供参考,不保证质量,不构成任何商业承诺或担保,不得用于商业或非法用途,使用者自行承担后果。 -- 初始化时若出现 *Attempt to access invalid address* 信息可忽略 +## 其他 -3、修改 [config.yml](./config.yml) 配置机器人参数,重启 **wrest.exe** 后生效 +License [GPL-3.0](https://www.gnu.org/licenses/gpl-3.0.txt) -- 请使用 `Ctrl + C` 终止 **wrest.exe**,切勿直接关闭任务窗口 -- 重启时,提示端口被占用,请退出微信后重试 - -## 配置说明 - -启动时将自动创建一个默认配置文件,完整配置可参考开源仓库中的 [config.yml](./config.yml) - -- 如设置了 `token`,请求接口时需携带 **header** 信息: `Authorization: Bearer $token` - -## 开发说明 - -- 查看和调试*HTTP*接口文档,请使用浏览器打开 `http://localhost:7600` - -- 由于微信和*WCF*均为32位应用,对接*bot*和*sdk*部分,必须设置环境变量 `GOARCH=386` - -### API 模块 - -实现了 HTTP 接口,详情查看 [httpd/README.md](https://github.com/opentdp/wechat-rest/httpd/README.md) - -### BOT 模块 - -实现了群聊机器人,详情查看 [wclient/README.md](https://github.com/opentdp/wechat-rest/wclient/README.md) - -### SDK 模块 - -实现了 WCF 客户端,详情查看 [wcferry/README.md](https://github.com/opentdp/wechat-rest/wcferry/README.md) +Copyright (c) 2022 - 2024 OpenTDP diff --git a/clients/gohttp/args/args.go b/clients/gohttp/args/args.go deleted file mode 100644 index 0a44cae..0000000 --- a/clients/gohttp/args/args.go +++ /dev/null @@ -1,35 +0,0 @@ -package args - -// 日志配置 - -var Log = struct { - Dir string `yaml:"dir"` - Level string `yaml:"level"` - Target string `yaml:"target"` -}{ - Dir: "logs", - Level: "info", - Target: "stdout", -} - -// Web 服务 - -var Web = struct { - Address string `yaml:"address"` - Swagger bool `yaml:"swagger"` - Token string `yaml:"token"` -}{ - Address: "127.0.0.1:7600", - Swagger: true, -} - -// Wcf 服务 - -var Wcf = struct { - Address string `yaml:"address"` - WeChatAuto bool `yaml:"wechatAuto"` - MsgPrinter bool `yaml:"msgPrinter"` -}{ - Address: "127.0.0.1:7601", - WeChatAuto: true, -} diff --git a/clients/gohttp/args/build.go b/clients/gohttp/args/build.go deleted file mode 100644 index 376fb04..0000000 --- a/clients/gohttp/args/build.go +++ /dev/null @@ -1,31 +0,0 @@ -package args - -import ( - "embed" -) - -// 调试模式 - -var Debug bool - -// 嵌入目录 - -var Efs *embed.FS - -// 版本信息 - -const Version = "0.10.0" -const BuildVersion = "240106" - -// 应用描述 - -const AppName = "TDP Wrest" -const AppSummary = "智能聊天机器人" - -// 输出说明 -func init() { - - println(AppName, AppSummary) - println("Version:", Version, "build", BuildVersion) - -} diff --git a/clients/gohttp/args/koanf.go b/clients/gohttp/args/koanf.go deleted file mode 100644 index 3053276..0000000 --- a/clients/gohttp/args/koanf.go +++ /dev/null @@ -1,76 +0,0 @@ -package args - -import ( - "os" - - "github.com/knadh/koanf/parsers/yaml" - "github.com/knadh/koanf/providers/file" - "github.com/knadh/koanf/v2" - "github.com/opentdp/go-helper/filer" - "github.com/opentdp/go-helper/logman" -) - -// 配置信息操作类 - -type Config struct { - Koanf *koanf.Koanf - Parser *yaml.YAML - File string -} - -func (c *Config) Init() *Config { - - debug := os.Getenv("TDP_DEBUG") - Debug = debug == "1" || debug == "true" - - c.Koanf = koanf.NewWithConf(koanf.Conf{ - StrictMerge: true, - Delim: ".", - }) - c.Parser = yaml.Parser() - - c.File = "config.yml" - if len(os.Args) > 1 { - c.File = os.Args[1] - } - - return c - -} - -func (c *Config) ReadYaml() { - - // 配置不存在则忽略 - _, err := os.Stat(c.File) - if os.IsNotExist(err) { - return - } - - // 从配置文件读取参数 - err = c.Koanf.Load(file.Provider(c.File), c.Parser) - if err != nil { - logman.Fatal("read config error", "error", err) - } - -} - -func (c *Config) WriteYaml() { - - // 是否强制覆盖 - if filer.Exists(c.File) { - return - } - - // 序列化参数信息 - buf, err := c.Koanf.Marshal(c.Parser) - if err != nil { - logman.Fatal("write config error", "error", err) - } - - // 将参数写入配置文件 - err = os.WriteFile(c.File, buf, 0644) - if err != nil { - logman.Fatal("write config error", "error", err) - } - -} diff --git a/clients/gohttp/args/unmarshal.go b/clients/gohttp/args/unmarshal.go deleted file mode 100644 index 18caabe..0000000 --- a/clients/gohttp/args/unmarshal.go +++ /dev/null @@ -1,45 +0,0 @@ -package args - -import ( - "os" - - "github.com/knadh/koanf/providers/confmap" - "github.com/opentdp/go-helper/logman" -) - -func (c *Config) Unmarshal() { - - // 读取默认配置 - - mp := map[string]any{ - "log": &Log, - "web": &Web, - "wcf": &Wcf, - } - c.Koanf.Load(confmap.Provider(mp, "."), nil) - - // 读取配置文件 - - c.ReadYaml() - for k, v := range mp { - c.Koanf.Unmarshal(k, v) - } - - // 初始化日志 - - if Log.Dir != "" && Log.Dir != "." { - os.MkdirAll(Log.Dir, 0755) - } - - logman.SetDefault(&logman.Config{ - Level: Log.Level, - Target: Log.Target, - Storage: Log.Dir, - Filename: "wrest", - }) - - // 写入配置文件 - - c.WriteYaml() - -} diff --git a/clients/gohttp/config.yml b/clients/gohttp/config.yml index 5bf5f81..40b6fd9 100644 --- a/clients/gohttp/config.yml +++ b/clients/gohttp/config.yml @@ -1,17 +1,19 @@ # 运行日志 -log: - dir: logs # 日志目录 - level: info # 日志级别 - target: stdout # 日志输出方式 - -# Web 服务 -web: - address: 127.0.0.1:7600 # 监听地址 - swagger: true # 是否启用 OpenApi 文档 - token: "" # 使用 Token 验证请求 +Log: + Dir: logs # 存储目录,非必要不修改 + Level: info # 记录级别,debug|info|warn|error + Target: stdout # 输出方式,both|file|null|stdout|stderr # Wcf 服务 -wcf: - address: 127.0.0.1:7601 # Rpc 监听地址 - wechatAuto: true # 是否跟随启停微信 - msgPrinter: false # 是否打印收到的消息 +Wcf: + Address: 127.0.0.1:7601 # 若使用外部地址,请删除 SdkLibrary 选项 + MsgPrint: false # 是否将消息输出到控制台,可用于调试 + SdkLibrary: sdk.dll # wcf 二进制文件路径,留空则不托管(Linux 必须留空) + +# Web 服务 +Web: + Address: 127.0.0.1:7600 # 监听地址,外网访问修改为 0.0.0.0:7600 + PushUrl: "" # 消息推送地址,一行一个,留空则不启用 + Storage: storage # 附件存储路径,非必要不修改 + Swagger: true # 是否启用内置接口文档和调试工具 + Token: "" # 使用 Token 验证请求,留空则不验证 diff --git a/clients/gohttp/go.mod b/clients/gohttp/go.mod index 07e396b..7d875c0 100644 --- a/clients/gohttp/go.mod +++ b/clients/gohttp/go.mod @@ -3,57 +3,66 @@ module wechat-rest go 1.21 require ( - github.com/gin-gonic/gin v1.9.1 - github.com/knadh/koanf v1.5.0 - github.com/knadh/koanf/v2 v2.0.1 - github.com/mitchellh/mapstructure v1.5.0 - github.com/opentdp/go-helper v0.5.7 - github.com/opentdp/wechat-rest v0.10.1 - golang.org/x/net v0.20.0 + github.com/opentdp/go-helper v0.7.2 + github.com/opentdp/wrest-chat v0.27.0 ) require ( - github.com/Microsoft/go-winio v0.6.1 // indirect + filippo.io/edwards25519 v1.1.0 // indirect + github.com/Microsoft/go-winio v0.6.2 // indirect github.com/VividCortex/ewma v1.2.0 // indirect - github.com/bytedance/sonic v1.10.2 // indirect - github.com/cheggaaa/pb/v3 v3.1.4 // indirect - github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d // indirect - github.com/chenzhuoyu/iasm v0.9.1 // indirect + github.com/bytedance/sonic v1.11.6 // indirect + github.com/bytedance/sonic/loader v0.1.1 // indirect + github.com/cheggaaa/pb/v3 v3.1.5 // indirect github.com/clbanning/mxj v1.8.4 // indirect + github.com/cloudwego/base64x v0.1.4 // indirect + github.com/cloudwego/iasm v0.2.0 // indirect + github.com/dustin/go-humanize v1.0.1 // indirect github.com/fatih/color v1.16.0 // indirect - github.com/fsnotify/fsnotify v1.7.0 // indirect github.com/gabriel-vasile/mimetype v1.4.3 // indirect github.com/gin-contrib/sse v0.1.0 // indirect + github.com/gin-gonic/gin v1.10.0 // indirect + github.com/glebarez/go-sqlite v1.22.0 // indirect + github.com/glebarez/sqlite v1.11.0 // indirect github.com/go-playground/locales v0.14.1 // indirect github.com/go-playground/universal-translator v0.18.1 // indirect - github.com/go-playground/validator/v10 v10.17.0 // indirect + github.com/go-playground/validator/v10 v10.20.0 // indirect + github.com/go-sql-driver/mysql v1.8.1 // indirect github.com/goccy/go-json v0.10.2 // indirect - github.com/google/go-cmp v0.6.0 // indirect + github.com/google/uuid v1.6.0 // indirect github.com/gorilla/websocket v1.5.1 // indirect + github.com/jinzhu/inflection v1.0.0 // indirect + github.com/jinzhu/now v1.1.5 // indirect github.com/json-iterator/go v1.1.12 // indirect - github.com/klauspost/cpuid/v2 v2.2.6 // indirect - github.com/leodido/go-urn v1.2.4 // indirect + github.com/klauspost/cpuid/v2 v2.2.7 // indirect + github.com/kr/pretty v0.2.0 // indirect + github.com/leodido/go-urn v1.4.0 // indirect github.com/mattn/go-colorable v0.1.13 // indirect github.com/mattn/go-isatty v0.0.20 // indirect github.com/mattn/go-runewidth v0.0.15 // indirect - github.com/mitchellh/copystructure v1.2.0 // indirect - github.com/mitchellh/reflectwalk v1.0.2 // indirect + github.com/mitchellh/mapstructure v1.5.0 // indirect github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect github.com/modern-go/reflect2 v1.0.2 // indirect - github.com/pelletier/go-toml/v2 v2.1.1 // indirect - github.com/rivo/uniseg v0.4.4 // indirect + github.com/ncruces/go-strftime v0.1.9 // indirect + github.com/pelletier/go-toml/v2 v2.2.2 // indirect + github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec // indirect + github.com/rivo/uniseg v0.4.7 // indirect github.com/twitchyliquid64/golang-asm v0.15.1 // indirect github.com/ugorji/go/codec v1.2.12 // indirect - go.nanomsg.org/mangos v2.0.0+incompatible // indirect go.nanomsg.org/mangos/v3 v3.4.2 // indirect - golang.org/x/arch v0.7.0 // indirect - golang.org/x/crypto v0.18.0 // indirect - golang.org/x/mod v0.14.0 // indirect - golang.org/x/sys v0.16.0 // indirect - golang.org/x/text v0.14.0 // indirect - golang.org/x/tools v0.17.0 // indirect - google.golang.org/protobuf v1.32.0 // indirect + golang.org/x/arch v0.8.0 // indirect + golang.org/x/crypto v0.23.0 // indirect + golang.org/x/net v0.25.0 // indirect + golang.org/x/sync v0.7.0 // indirect + golang.org/x/sys v0.20.0 // indirect + golang.org/x/text v0.15.0 // indirect + google.golang.org/protobuf v1.34.1 // indirect gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect - nanomsg.org/go/mangos/v2 v2.0.8 // indirect + gorm.io/driver/mysql v1.5.6 // indirect + gorm.io/gorm v1.25.10 // indirect + modernc.org/libc v1.50.5 // indirect + modernc.org/mathutil v1.6.0 // indirect + modernc.org/memory v1.8.0 // indirect + modernc.org/sqlite v1.29.9 // indirect ) diff --git a/clients/gohttp/go.sum b/clients/gohttp/go.sum index c3af5e0..4019d82 100644 --- a/clients/gohttp/go.sum +++ b/clients/gohttp/go.sum @@ -1,501 +1,190 @@ -cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= -cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= -github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= -github.com/Microsoft/go-winio v0.4.11/go.mod h1:VhR8bwka0BXejwEJY73c50VrPtXAaKcyvVC4A4RozmA= +filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA= +filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4= github.com/Microsoft/go-winio v0.5.2/go.mod h1:WpS1mjBmmwHBEWmogvA2mj8546UReBk4v8QkMxJ6pZY= -github.com/Microsoft/go-winio v0.6.1 h1:9/kr64B9VUZrLm5YYwbGtUJnMgqWVOdUAXu6Migciow= -github.com/Microsoft/go-winio v0.6.1/go.mod h1:LRdKpFKfdobln8UmuiYcKPot9D2v6svN5+sAH+4kjUM= +github.com/Microsoft/go-winio v0.6.2 h1:F2VQgta7ecxGYO8k3ZZz3RS8fVIXVxONVUPlNERoyfY= +github.com/Microsoft/go-winio v0.6.2/go.mod h1:yd8OoFMLzJbo9gZq8j5qaps8bJ9aShtEA8Ipt1oGCvU= github.com/VividCortex/ewma v1.2.0 h1:f58SaIzcDXrSy3kWaHNvuJgJ3Nmz59Zji6XoJR/q1ow= github.com/VividCortex/ewma v1.2.0/go.mod h1:nz4BbCtbLyFDeC9SUHbtcT5644juEuWfUAUnGx7j5l4= -github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= -github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= -github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= -github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= -github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d/go.mod h1:rBZYJk541a8SKzHPHnH3zbiI+7dagKZ0cgpgrD7Fyho= -github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY= -github.com/armon/circbuf v0.0.0-20150827004946-bbbad097214e/go.mod h1:3U/XgcO3hCbHZ8TKRvWD2dDTCfh9M9ya+I9JpbB7O8o= -github.com/armon/go-metrics v0.0.0-20180917152333-f0300d1749da/go.mod h1:Q73ZrmVTwzkszR9V5SSuryQ31EELlFMUz1kKyl939pY= -github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8= -github.com/armon/go-radix v1.0.0/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8= -github.com/aws/aws-sdk-go-v2 v1.9.2/go.mod h1:cK/D0BBs0b/oWPIcX/Z/obahJK1TT7IPVjy53i/mX/4= -github.com/aws/aws-sdk-go-v2/config v1.8.3/go.mod h1:4AEiLtAb8kLs7vgw2ZV3p2VZ1+hBavOc84hqxVNpCyw= -github.com/aws/aws-sdk-go-v2/credentials v1.4.3/go.mod h1:FNNC6nQZQUuyhq5aE5c7ata8o9e4ECGmS4lAXC7o1mQ= -github.com/aws/aws-sdk-go-v2/feature/ec2/imds v1.6.0/go.mod h1:gqlclDEZp4aqJOancXK6TN24aKhT0W0Ae9MHk3wzTMM= -github.com/aws/aws-sdk-go-v2/internal/ini v1.2.4/go.mod h1:ZcBrrI3zBKlhGFNYWvju0I3TR93I7YIgAfy82Fh4lcQ= -github.com/aws/aws-sdk-go-v2/service/appconfig v1.4.2/go.mod h1:FZ3HkCe+b10uFZZkFdvf98LHW21k49W8o8J366lqVKY= -github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.3.2/go.mod h1:72HRZDLMtmVQiLG2tLfQcaWLCssELvGl+Zf2WVxMmR8= -github.com/aws/aws-sdk-go-v2/service/sso v1.4.2/go.mod h1:NBvT9R1MEF+Ud6ApJKM0G+IkPchKS7p7c2YPKwHmBOk= -github.com/aws/aws-sdk-go-v2/service/sts v1.7.2/go.mod h1:8EzeIqfWt2wWT4rJVu3f21TfrhJ8AEMzVybRNSb/b4g= -github.com/aws/smithy-go v1.8.0/go.mod h1:SObp3lf9smib00L/v3U2eAKG8FyQ7iLrJnQiAmR5n+E= -github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= -github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= -github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= -github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs= -github.com/bytedance/sonic v1.5.0/go.mod h1:ED5hyg4y6t3/9Ku1R6dU/4KyJ48DZ4jPhfY1O2AihPM= -github.com/bytedance/sonic v1.10.0-rc/go.mod h1:ElCzW+ufi8qKqNW0FY314xriJhyJhuoJ3gFZdAHF7NM= -github.com/bytedance/sonic v1.10.2 h1:GQebETVBxYB7JGWJtLBi07OVzWwt+8dWA00gEVW2ZFE= -github.com/bytedance/sonic v1.10.2/go.mod h1:iZcSUejdk5aukTND/Eu/ivjQuEL0Cu9/rf50Hi0u/g4= -github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= -github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= -github.com/cheggaaa/pb/v3 v3.1.4 h1:DN8j4TVVdKu3WxVwcRKu0sG00IIU6FewoABZzXbRQeo= -github.com/cheggaaa/pb/v3 v3.1.4/go.mod h1:6wVjILNBaXMs8c21qRiaUM8BR82erfgau1DQ4iUXmSA= -github.com/chenzhuoyu/base64x v0.0.0-20211019084208-fb5309c8db06/go.mod h1:DH46F32mSOjUmXrMHnKwZdA8wcEefY7UVqBKYGjpdQY= -github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311/go.mod h1:b583jCggY9gE99b6G5LEC39OIiVsWj+R97kbl5odCEk= -github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d h1:77cEq6EriyTZ0g/qfRdp61a3Uu/AWrgIq2s0ClJV1g0= -github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d/go.mod h1:8EPpVsBuRksnlj1mLy4AWzRNQYxauNi62uWcE3to6eA= -github.com/chenzhuoyu/iasm v0.9.0/go.mod h1:Xjy2NpN3h7aUqeqM+woSuuvxmIe6+DDsiNLIrkAmYog= -github.com/chenzhuoyu/iasm v0.9.1 h1:tUHQJXo3NhBqw6s33wkGn9SP3bvrWLdlVIJ3hQBL7P0= -github.com/chenzhuoyu/iasm v0.9.1/go.mod h1:Xjy2NpN3h7aUqeqM+woSuuvxmIe6+DDsiNLIrkAmYog= +github.com/bytedance/sonic v1.11.6 h1:oUp34TzMlL+OY1OUWxHqsdkgC/Zfc85zGqw9siXjrc0= +github.com/bytedance/sonic v1.11.6/go.mod h1:LysEHSvpvDySVdC2f87zGWf6CIKJcAvqab1ZaiQtds4= +github.com/bytedance/sonic/loader v0.1.1 h1:c+e5Pt1k/cy5wMveRDyk2X4B9hF4g7an8N3zCYjJFNM= +github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU= +github.com/cheggaaa/pb/v3 v3.1.5 h1:QuuUzeM2WsAqG2gMqtzaWithDJv0i+i6UlnwSCI4QLk= +github.com/cheggaaa/pb/v3 v3.1.5/go.mod h1:CrxkeghYTXi1lQBEI7jSn+3svI3cuc19haAj6jM60XI= github.com/clbanning/mxj v1.8.4 h1:HuhwZtbyvyOw+3Z1AowPkU87JkJUSv751ELWaiTpj8I= github.com/clbanning/mxj v1.8.4/go.mod h1:BVjHeAH+rl9rs6f+QIpeRl0tfu10SXn1pUSa5PVGJng= -github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= -github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= -github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= -github.com/coreos/go-semver v0.3.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= -github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= +github.com/cloudwego/base64x v0.1.4 h1:jwCgWpFanWmN8xoIUHa2rtzmkd5J2plF/dnLS6Xd/0Y= +github.com/cloudwego/base64x v0.1.4/go.mod h1:0zlkT4Wn5C6NdauXdJRhSKRlJvmclQ1hhJgA0rcu/8w= +github.com/cloudwego/iasm v0.2.0 h1:1KNIy1I1H9hNNFEEH3DVnI4UujN+1zjpuk6gwHLTssg= +github.com/cloudwego/iasm v0.2.0/go.mod h1:8rXZaNYT2n95jn+zTI1sDr+IgcD2GVs0nlbbQPiEFhY= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= -github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= -github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= -github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= -github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= -github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= -github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= -github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= -github.com/fatih/color v1.9.0/go.mod h1:eQcE1qtQxscV5RaZvpXrrb8Drkc3/DdQ+uUYCNjL+zU= +github.com/dustin/go-humanize v1.0.1 h1:GzkhY7T5VNhEkwH0PVJgjz+fX1rhBrR7pRT3mDkpeCY= +github.com/dustin/go-humanize v1.0.1/go.mod h1:Mu1zIs6XwVuF/gI1OepvI0qD18qycQx+mFykh5fBlto= github.com/fatih/color v1.16.0 h1:zmkK9Ngbjj+K0yRhTVONQh1p/HknKYSlNT+vZCzyokM= github.com/fatih/color v1.16.0/go.mod h1:fL2Sau1YI5c0pdGEVCbKQbLXB6edEj1ZgiY4NijnWvE= -github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M= -github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= -github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= -github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= github.com/gabriel-vasile/mimetype v1.4.3 h1:in2uUcidCuFcDKtdcBxlR0rJ1+fsokWf+uqxgUFjbI0= github.com/gabriel-vasile/mimetype v1.4.3/go.mod h1:d8uq/6HKRL6CGdk+aubisF/M5GcPfT7nKyLpA0lbSSk= github.com/gdamore/optopia v0.2.0/go.mod h1:YKYEwo5C1Pa617H7NlPcmQXl+vG6YnSSNB44n8dNL0Q= -github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE= github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI= -github.com/gin-gonic/gin v1.9.1 h1:4idEAncQnU5cB7BeOkPtxjfCSye0AAm1R0RVIqJ+Jmg= -github.com/gin-gonic/gin v1.9.1/go.mod h1:hPrL7YrpYKXt5YId3A/Tnip5kqbEAP+KLuI3SUcPTeU= -github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= -github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= -github.com/go-kit/log v0.1.0/go.mod h1:zbhenjAZHb184qTLMA9ZjW7ThYL0H2mk7Q6pNt4vbaY= -github.com/go-ldap/ldap v3.0.2+incompatible/go.mod h1:qfd9rJvER9Q0/D/Sqn1DfHRoBp40uXYvFoEVrNEPqRc= -github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE= -github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= -github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A= +github.com/gin-gonic/gin v1.10.0 h1:nTuyha1TYqgedzytsKYqna+DfLos46nTv2ygFy86HFU= +github.com/gin-gonic/gin v1.10.0/go.mod h1:4PMNQiOhvDRa013RKVbsiNwoyezlm2rm0uX/T7kzp5Y= +github.com/glebarez/go-sqlite v1.22.0 h1:uAcMJhaA6r3LHMTFgP0SifzgXg46yJkgxqyuyec+ruQ= +github.com/glebarez/go-sqlite v1.22.0/go.mod h1:PlBIdHe0+aUEFn+r2/uthrWq4FxbzugL0L8Li6yQJbc= +github.com/glebarez/sqlite v1.11.0 h1:wSG0irqzP6VurnMEpFGer5Li19RpIRi2qvQz++w0GMw= +github.com/glebarez/sqlite v1.11.0/go.mod h1:h8/o8j5wiAsqSPoWELDUdJXhjAhsVliSn7bWZjOhrgQ= github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= -github.com/go-playground/validator/v10 v10.17.0 h1:SmVVlfAOtlZncTxRuinDPomC2DkXJ4E5T9gDA0AIH74= -github.com/go-playground/validator/v10 v10.17.0/go.mod h1:9iXMNT7sEkjXb0I+enO7QXmzG6QCsPWY4zveKFVRSyU= -github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= -github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA= +github.com/go-playground/validator/v10 v10.20.0 h1:K9ISHbSaI0lyB2eWMPJo+kOS/FBExVwjEviJTixqxL8= +github.com/go-playground/validator/v10 v10.20.0/go.mod h1:dbuPbCMFw/DrkbEynArYaCwl3amGuJotoKCe95atGMM= +github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI= +github.com/go-sql-driver/mysql v1.8.1 h1:LedoTUt/eveggdHS9qUFC1EFSa8bU2+1pZjSRpvNJ1Y= +github.com/go-sql-driver/mysql v1.8.1/go.mod h1:wEBSXgmK//2ZFJyE+qWnIsVGmvmEKlqwuVSjsCm7DZg= github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU= github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= -github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= -github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ= -github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= -github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= -github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= -github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= -github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= -github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= -github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= -github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8= -github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA= -github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrUpVNzEA03Pprs= -github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:WU3c8KckQ9AFe+yFwt9sWVRKCVIyN9cPHBJSNnbL67w= -github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0= -github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QDs8UjoX8= -github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= -github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= -github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= -github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= -github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= -github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= -github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M= -github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= -github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= -github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.7/go.mod h1:n+brtR0CgQNWTVd5ZUFpTBC8YFBDLK/h/bpaJ8/DtOE= github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= -github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= -github.com/gorilla/websocket v1.4.1/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= +github.com/google/pprof v0.0.0-20240409012703-83162a5b38cd h1:gbpYu9NMq8jhDVbvlGkMFWCjLFlqqEZjEmObmhUy6Vo= +github.com/google/pprof v0.0.0-20240409012703-83162a5b38cd/go.mod h1:kf6iHlnVGwgKolg33glAes7Yg/8iWP8ukqeldJSO7jw= +github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= +github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/gorilla/websocket v1.5.0/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= github.com/gorilla/websocket v1.5.1 h1:gmztn0JnHVt9JZquRuzLw3g4wouNVzKL15iLr/zn/QY= github.com/gorilla/websocket v1.5.1/go.mod h1:x3kM2JMyaluk02fnUJpQuwD2dCS5NDG2ZHL0uE0tcaY= -github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk= -github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw= -github.com/hashicorp/consul/api v1.13.0/go.mod h1:ZlVrynguJKcYr54zGaDbaL3fOvKC9m72FhPvA8T35KQ= -github.com/hashicorp/consul/sdk v0.8.0/go.mod h1:GBvyrGALthsZObzUGsfgHZQDXjg4lOjagTIwIR1vPms= -github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= -github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= -github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= -github.com/hashicorp/go-hclog v0.0.0-20180709165350-ff2cf002a8dd/go.mod h1:9bjs9uLqI8l75knNv3lV1kA55veR+WUPSiKIWcQHudI= -github.com/hashicorp/go-hclog v0.8.0/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ= -github.com/hashicorp/go-hclog v0.12.0/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ= -github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= -github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM= -github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk= -github.com/hashicorp/go-multierror v1.1.0/go.mod h1:spPvp8C1qA32ftKqdAHm4hHTbPw+vmowP0z+KUhOZdA= -github.com/hashicorp/go-plugin v1.0.1/go.mod h1:++UyYGoz3o5w9ZzAdZxtQKrWWP+iqPBn3cQptSMzBuY= -github.com/hashicorp/go-retryablehttp v0.5.4/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs= -github.com/hashicorp/go-rootcerts v1.0.1/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8= -github.com/hashicorp/go-rootcerts v1.0.2/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8= -github.com/hashicorp/go-sockaddr v1.0.0/go.mod h1:7Xibr9yA9JjQq1JpNB2Vw7kxv8xerXegt+ozgdvDeDU= -github.com/hashicorp/go-sockaddr v1.0.2/go.mod h1:rB4wwRAUzs07qva3c5SdrY/NEtAUjGlgmH/UkBUC97A= -github.com/hashicorp/go-syslog v1.0.0/go.mod h1:qPfqrKkXGihmCqbJM2mZgkZGvKG1dFdvsLplgctolz4= -github.com/hashicorp/go-uuid v1.0.0/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro= -github.com/hashicorp/go-uuid v1.0.1/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro= -github.com/hashicorp/go-version v1.1.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA= -github.com/hashicorp/golang-lru v0.5.0/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= -github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= -github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= -github.com/hashicorp/logutils v1.0.0/go.mod h1:QIAnNjmIWmVIIkWDTG1z5v++HQmx9WQRO+LraFDTW64= -github.com/hashicorp/mdns v1.0.4/go.mod h1:mtBihi+LeNXGtG8L9dX59gAEa12BDtBQSp4v/YAJqrc= -github.com/hashicorp/memberlist v0.3.0/go.mod h1:MS2lj3INKhZjWNqd3N0m3J+Jxf3DAOnAH9VT3Sh9MUE= -github.com/hashicorp/serf v0.9.6/go.mod h1:TXZNMjZQijwlDvp+r0b63xZ45H7JmCmgg4gpTwn9UV4= -github.com/hashicorp/vault/api v1.0.4/go.mod h1:gDcqh3WGcR1cpF5AJz/B1UFheUEneMoIospckxBxk6Q= -github.com/hashicorp/vault/sdk v0.1.13/go.mod h1:B+hVj7TpuQY1Y/GPbCpffmgd+tSEwvhkWnjtSYCaS2M= -github.com/hashicorp/yamux v0.0.0-20180604194846-3520598351bb/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM= -github.com/hashicorp/yamux v0.0.0-20181012175058-2f1d1f20f75d/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM= -github.com/hjson/hjson-go/v4 v4.0.0/go.mod h1:KaYt3bTw3zhBjYqnXkYywcYctk0A2nxeEFTse3rH13E= -github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo= -github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U= -github.com/joho/godotenv v1.3.0/go.mod h1:7hK45KPybAkOC6peb+G5yklZfMxEjkZhHbwpqxOKXbg= -github.com/jpillora/backoff v1.0.0/go.mod h1:J/6gKK9jxlEcS3zixgDgUAsiuZ7yrSoa/FX5e0EB2j4= -github.com/json-iterator/go v1.1.6/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU= -github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= -github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= +github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E= +github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc= +github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ= +github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8= github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= -github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= -github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= -github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= -github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= -github.com/klauspost/cpuid/v2 v2.2.6 h1:ndNyv040zDGIDh8thGkXYjnFtiN02M1PVVF+JE/48xc= -github.com/klauspost/cpuid/v2 v2.2.6/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws= -github.com/knadh/koanf v1.5.0 h1:q2TSd/3Pyc/5yP9ldIrSdIz26MCcyNQzW0pEAugLPNs= -github.com/knadh/koanf v1.5.0/go.mod h1:Hgyjp4y8v44hpZtPzs7JZfRAW5AhN7KfZcwv1RYggDs= -github.com/knadh/koanf/v2 v2.0.1 h1:1dYGITt1I23x8cfx8ZnldtezdyaZtfAuRtIFOiRzK7g= -github.com/knadh/koanf/v2 v2.0.1/go.mod h1:ZeiIlIDXTE7w1lMT6UVcNiRAS2/rCeLn/GdLNvY1Dus= +github.com/klauspost/cpuid/v2 v2.2.7 h1:ZWSB3igEs+d0qvnxR/ZBzXVmxkgt8DdzP6m9pfuVLDM= +github.com/klauspost/cpuid/v2 v2.2.7/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws= github.com/knz/go-libedit v1.10.1/go.mod h1:MZTVkCWyz0oBc7JOWP3wNAzd002ZbM/5hgShxwh4x8M= -github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= -github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= -github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc= -github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= github.com/kr/pretty v0.2.0 h1:s5hAObm+yFO5uHYt5dYjxi2rXrsnmRpJx4OYvIWUaQs= github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= -github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE= github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= -github.com/leodido/go-urn v1.2.4 h1:XlAE/cm/ms7TE/VMVoduSpNBoyc2dOxHs5MZSwAN63Q= -github.com/leodido/go-urn v1.2.4/go.mod h1:7ZrI8mTSeBSHl/UaRyKQW1qZeMgak41ANeCNaVckg+4= -github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU= -github.com/mattn/go-colorable v0.1.4/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE= -github.com/mattn/go-colorable v0.1.6/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= +github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= +github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= +github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ= +github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI= github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= -github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= -github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s= -github.com/mattn/go-isatty v0.0.10/go.mod h1:qgIWMr58cqv1PHHyhnkY9lrL7etaEgOFcMEpPG5Rm84= -github.com/mattn/go-isatty v0.0.11/go.mod h1:PhnuNfih5lzO57/f3n+odYbM4JtupLOxQOAqxQCu2WE= -github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/mattn/go-runewidth v0.0.15 h1:UNAjwbU9l54TA3KzvqLGxwWjHmMgBUVhBiTjelZgg3U= github.com/mattn/go-runewidth v0.0.15/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w= -github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0= -github.com/miekg/dns v1.1.26/go.mod h1:bPDLeHnStXmXAq1m/Ch/hvfNHr14JKNPMBo3VZKjuso= -github.com/miekg/dns v1.1.41/go.mod h1:p6aan82bvRIyn+zDIv9xYNUpwa73JcSh9BKwknJysuI= -github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc= -github.com/mitchellh/cli v1.1.0/go.mod h1:xcISNoH86gajksDmfB23e/pu+B+GeFRMYmoHXxx3xhI= -github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw= -github.com/mitchellh/copystructure v1.2.0 h1:vpKXTN4ewci03Vljg/q9QvCGUDttBOGBIa15WveJJGw= -github.com/mitchellh/copystructure v1.2.0/go.mod h1:qLl+cE2AmVv+CoeAwDPye/v+N2HKCj9FbZEVFJRxO9s= -github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0= -github.com/mitchellh/go-testing-interface v0.0.0-20171004221916-a61a99592b77/go.mod h1:kRemZodwjscx+RGhAo8eIhFbs2+BFgRtFPeD/KE+zxI= -github.com/mitchellh/go-testing-interface v1.0.0/go.mod h1:kRemZodwjscx+RGhAo8eIhFbs2+BFgRtFPeD/KE+zxI= -github.com/mitchellh/go-wordwrap v1.0.0/go.mod h1:ZXFpozHsX6DPmq2I0TCekCxypsnAUbP2oI0UX1GXzOo= -github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= -github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY= github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= -github.com/mitchellh/reflectwalk v1.0.0/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= -github.com/mitchellh/reflectwalk v1.0.2 h1:G2LzWKi524PWgd3mLHV8Y5k7s6XUvT0Gef6zxSIeXaQ= -github.com/mitchellh/reflectwalk v1.0.2/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= -github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= -github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M= github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= -github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= -github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= -github.com/npillmayer/nestext v0.1.3/go.mod h1:h2lrijH8jpicr25dFY+oAJLyzlya6jhnuG+zWp9L0Uk= -github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQA= -github.com/opentdp/go-helper v0.5.7 h1:6NPodNpmc37qt7urS6n/mA2Jk3DQTHA0rlh2qXa8dKI= -github.com/opentdp/go-helper v0.5.7/go.mod h1:9m+t/2x1CmjZ9YQP37+xECCO84eqMnsxnRE/7y37GjE= -github.com/opentdp/wechat-rest v0.10.1 h1:P+yIKang4ckAOB10+7kbm/2V/0Punx2ElxDLL+Dp0Cw= -github.com/opentdp/wechat-rest v0.10.1/go.mod h1:JCrwAaKhosZ9oyEhN6R09XA4ACP31xn/0VL3DOY5VF0= -github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= -github.com/pascaldekloe/goe v0.1.0/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= -github.com/pelletier/go-toml v1.7.0/go.mod h1:vwGMzjaWMwyfHwgIBhI2YUM4fB6nL6lVAvS1LBMMhTE= -github.com/pelletier/go-toml/v2 v2.1.1 h1:LWAJwfNvjQZCFIDKWYQaM62NcYeYViCmWIwmOStowAI= -github.com/pelletier/go-toml/v2 v2.1.1/go.mod h1:tJU2Z3ZkXwnxa4DPO899bsyIoywizdUvyaeZurnPPDc= -github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= -github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= -github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= -github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= +github.com/ncruces/go-strftime v0.1.9 h1:bY0MQC28UADQmHmaF5dgpLmImcShSi2kHU9XLdhx/f4= +github.com/ncruces/go-strftime v0.1.9/go.mod h1:Fwc5htZGVVkseilnfgOVb9mKy6w1naJmn9CehxcKcls= +github.com/opentdp/go-helper v0.7.2 h1:u0DGQ8JxbyApcNPYAurQ1CqOhdUyw7/sVXcDdJP3JQE= +github.com/opentdp/go-helper v0.7.2/go.mod h1:bRR6EpSuQNNNwgCSWwwuO90Lh1lUG+PnMa6PFS41mF8= +github.com/opentdp/wrest-chat v0.27.0 h1:4hFDEwMxtV40ztNuKIR7nhmuxTeNIP2ndzDX6nWYlRU= +github.com/opentdp/wrest-chat v0.27.0/go.mod h1:UVPT/sxBvfsjv8ynbItzMsugBcFErQ2eg/Cws/T/4wE= +github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= +github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= -github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI= -github.com/posener/complete v1.2.3/go.mod h1:WZIdtGGp+qx0sLrYKtIRAruyNpv6hFCicSgv7Sy7s/s= -github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw= -github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5FsnadC4Ky3P0J6CfImo= -github.com/prometheus/client_golang v1.7.1/go.mod h1:PY5Wy2awLA44sXw4AOSfFBetzPP4j5+D6mVACh+pe2M= -github.com/prometheus/client_golang v1.11.1/go.mod h1:Z6t4BnS23TR94PD6BsDNk8yVqroYurpAkEiz0P2BEV0= -github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo= -github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= -github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= -github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= -github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= -github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo= -github.com/prometheus/common v0.26.0/go.mod h1:M7rCNAaPfAosfx8veZJCuw84e35h3Cfd9VFqTh1DIvc= -github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk= -github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA= -github.com/prometheus/procfs v0.1.3/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU= -github.com/prometheus/procfs v0.6.0/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1xBZuNvfVA= -github.com/rhnvrm/simples3 v0.6.1/go.mod h1:Y+3vYm2V7Y4VijFoJHHTrja6OgPrJ2cBti8dPGkC3sA= +github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec h1:W09IVJc94icq4NjY3clb7Lk8O1qJ8BdBEF8z0ibU0rE= +github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo= github.com/rivo/uniseg v0.2.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc= -github.com/rivo/uniseg v0.4.4 h1:8TfxU8dW6PdqD27gjM8MVNuicgxIjxpm4K7x4jp8sis= -github.com/rivo/uniseg v0.4.4/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88= -github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= -github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts= -github.com/ryanuber/columnize v2.1.0+incompatible/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts= -github.com/ryanuber/go-glob v1.0.0/go.mod h1:807d1WSdnB0XRJzKNil9Om6lcp/3a0v4qIHxIXzX/Yc= -github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc= -github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= -github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= -github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88= +github.com/rivo/uniseg v0.4.7 h1:WUdvkW8uEhrYfLC4ZzdpI2ztxP1I582+49Oc5Mq64VQ= +github.com/rivo/uniseg v0.4.7/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88= github.com/sirupsen/logrus v1.7.0/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0= -github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= -github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= +github.com/stretchr/objx v0.5.2/go.mod h1:FRsXN1f5AsAjCGJKqEizvkpNtU+EGNCLh3NxZ/8L+MA= github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= -github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= -github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA= github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= -github.com/stretchr/testify v1.8.2/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= -github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk= github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= +github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= +github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI= github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE= github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= -github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= -github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= -github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= -go.etcd.io/etcd/api/v3 v3.5.4/go.mod h1:5GB2vv4A4AOn3yk7MftYGHkUfGtDHnEraIjym4dYz5A= -go.etcd.io/etcd/client/pkg/v3 v3.5.4/go.mod h1:IJHfcCEKxYu1Os13ZdwCwIUTUVGYTSAM3YSwc9/Ac1g= -go.etcd.io/etcd/client/v3 v3.5.4/go.mod h1:ZaRkVgBZC+L+dLCjTcF1hRXpgZXQPOvnA/Ak/gq3kiY= -go.nanomsg.org/mangos v2.0.0+incompatible h1:Ll6GIzeGGld6/bFrVgBB8CjwibhHXZtF5jon+GoH1bE= -go.nanomsg.org/mangos v2.0.0+incompatible/go.mod h1:gf+avvdfHf8ziBBaiglErv4Pds81OMC1zYvfYyLyjpg= go.nanomsg.org/mangos/v3 v3.4.2 h1:gHlopxjWvJcVCcUilQIsRQk9jdj6/HB7wrTiUN8Ki7Q= go.nanomsg.org/mangos/v3 v3.4.2/go.mod h1:8+hjBMQub6HvXmuGvIq6hf19uxGQIjCofmc62lbedLA= -go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= -go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9iU= -go.uber.org/zap v1.17.0/go.mod h1:MXVU+bhUf/A7Xi2HNOnopQOrmycQ5Ih87HtOu4q5SSo= golang.org/x/arch v0.0.0-20210923205945-b76863e36670/go.mod h1:5om86z9Hs0C8fWVUuoMHwpExlXzs5Tkyp9hOrfG7pp8= -golang.org/x/arch v0.7.0 h1:pskyeJh/3AmoQ8CPE95vxHLqp1G1GfGNXTmcl9NEKTc= -golang.org/x/arch v0.7.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= -golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= -golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= -golang.org/x/crypto v0.0.0-20190923035154-9ee001bba392/go.mod h1:/lpIB1dKB+9EgE3H3cr1v9wB50oz8l4C4h62xy7jSTY= -golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= -golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= -golang.org/x/crypto v0.18.0 h1:PGVlW0xEltQnzFZ55hkuX5+KLyrMYhHld1YHO4AKcdc= -golang.org/x/crypto v0.18.0/go.mod h1:R0j02AL6hcrfOiy9T4ZYp/rcWeMxM3L6QYxlOuEG1mg= -golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= -golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= -golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU= -golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= -golang.org/x/lint v0.0.0-20210508222113-6edffad5e616/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= -golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg= -golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= -golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= -golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= -golang.org/x/mod v0.14.0 h1:dGoOF9QVLYng8IHTm7BAyWqCqSheQ5pYWGhzW00YJr0= -golang.org/x/mod v0.14.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= -golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= -golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= -golang.org/x/net v0.0.0-20181114220301-adae6a3d119a/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= -golang.org/x/net v0.0.0-20190108225652-1e06a53dbb7e/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= -golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= -golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= -golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= -golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20190923162816-aa69164e4478/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= -golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= -golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= -golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= -golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= -golang.org/x/net v0.0.0-20210410081132-afb366fc7cd1/go.mod h1:9tjilg8BloeKEkVJvy7fQ90B1CfIiPueXVOjqfkSzI8= -golang.org/x/net v0.20.0 h1:aCL9BSgETF1k+blQaYUBx9hJ9LOGP3gAVemcZlf1Kpo= -golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY= -golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= -golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= -golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= -golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.6.0 h1:5BMeUDZ7vkXGfEr1x9B4bRcTH4lpkTkpdh0T/J+qjbQ= -golang.org/x/sync v0.6.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= -golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20181128092732-4ed8d59d0b35/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190129075346-302c3dd5f1cc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190222072716-a9d3bda3a223/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190403152447-81d4e9dc473e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20190922100055-0a153f010e69/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20190924154521-2837fb4f24fe/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20191008105621-543471e840be/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/arch v0.8.0 h1:3wRIsP3pM4yUptoR96otTUOXI367OS0+c9eeRi9doIc= +golang.org/x/arch v0.8.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= +golang.org/x/crypto v0.23.0 h1:dIJU/v2J8Mdglj/8rJ6UUOM3Zc9zLZxVZwwxMooUSAI= +golang.org/x/crypto v0.23.0/go.mod h1:CKFgDieR+mRhux2Lsu27y0fO304Db0wZe70UKqHu0v8= +golang.org/x/mod v0.17.0 h1:zY54UmvipHiNd+pm+m0x9KhZ9hl1/7QNMyxXbc6ICqA= +golang.org/x/mod v0.17.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/net v0.25.0 h1:d/OCCoBEUq33pjydKrGQhw7IlUPI2Oylr+8qLx49kac= +golang.org/x/net v0.25.0/go.mod h1:JkAGAh7GEvH74S6FOH42FLoXpXbE/aqXSrIQjXgsiwM= +golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M= +golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200124204421-9fbb57f87de9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210303074136-134d130e1a04/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210403161142-5e06dd20ab57/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.16.0 h1:xWw16ngr6ZMtmxDyKyIgsE93KNKz5HKmMa3b8ALHidU= -golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= -golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= -golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= -golang.org/x/text v0.3.1-0.20181227161524-e6919f6577db/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= -golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= -golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= -golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= -golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= -golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ= -golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= -golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= -golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= -golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= -golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= -golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= -golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= -golang.org/x/tools v0.0.0-20190907020128-2ca718005c18/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= -golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= -golang.org/x/tools v0.0.0-20200130002326-2f3ba24bd6e7/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= -golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= -golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= -golang.org/x/tools v0.1.2/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= -golang.org/x/tools v0.17.0 h1:FvmRgNOcs3kOa+T20R1uhfP9F6HgG2mfxDv1vrx1Htc= -golang.org/x/tools v0.17.0/go.mod h1:xsh6VxdV005rRVaS6SSAf9oiAqljS7UZUacMZ8Bnsps= -golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= -google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= -google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= -google.golang.org/genproto v0.0.0-20190404172233-64821d5d2107/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= -google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= -google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= -google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo= -google.golang.org/genproto v0.0.0-20210602131652-f16073e35f0c/go.mod h1:UODoCrxHCcBojKKwX1terBiRUaqAsFqJiF615XL43r0= -google.golang.org/grpc v1.14.0/go.mod h1:yo6s7OP7yaDglbqo1J04qKzAhqBH6lvTonzMVmEdcZw= -google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= -google.golang.org/grpc v1.22.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= -google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= -google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY= -google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= -google.golang.org/grpc v1.33.1/go.mod h1:fr5YgcSWrqhRRxogOsw7RzIpsmvOZ6IcH4kBYTpR3n0= -google.golang.org/grpc v1.38.0/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM= -google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= -google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= -google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= -google.golang.org/protobuf v1.20.1-0.20200309200217-e05f789c0967/go.mod h1:A+miEFZTKqfCUM6K7xSMQL9OKL/b6hQv+e19PK+JZNE= -google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzikPIcrTAo= -google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= -google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= -google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= -google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c= -google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= -google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= -google.golang.org/protobuf v1.32.0 h1:pPC6BG5ex8PDFnkbrGU3EixyhKcQ2aDuBS36lqK/C7I= -google.golang.org/protobuf v1.32.0/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= -gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw= -gopkg.in/asn1-ber.v1 v1.0.0-20181015200546-f715ec2f112d/go.mod h1:cuepJuh7vyXfUyUwEgHQXw849cJrilpS5NeIjOWESAw= +golang.org/x/sys v0.20.0 h1:Od9JTbYCk261bKm4M/mw7AklTlFYIa0bIp9BgSm1S8Y= +golang.org/x/sys v0.20.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/text v0.15.0 h1:h1V/4gjBv8v9cjcR6+AR5+/cIYK5N/WAgiv4xlsEtAk= +golang.org/x/text v0.15.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= +golang.org/x/tools v0.21.0 h1:qc0xYgIbsSDt9EyWz05J5wfa7LOVW0YTLOXrqdLAWIw= +golang.org/x/tools v0.21.0/go.mod h1:aiJjzUbINMkxbQROHiO6hDPo2LHcIPhhQsa9DLh0yGk= +google.golang.org/protobuf v1.34.1 h1:9ddQBjfCyZPOHPUiPxpYESBLc+T8P3E+Vo4IbKZgFWg= +google.golang.org/protobuf v1.34.1/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= -gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo= -gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= +gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q= gopkg.in/natefinch/lumberjack.v2 v2.2.1 h1:bBRl1b0OH9s/DuPhuXpNl+VtCaJXFZ5/uEFST95x9zc= gopkg.in/natefinch/lumberjack.v2 v2.2.1/go.mod h1:YD8tP3GAjkrDg1eZH7EGmyESg/lsYskCTPBJVb9jqSc= -gopkg.in/square/go-jose.v2 v2.3.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI= -gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.2.3/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.2.5/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= -gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= -honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= -honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= -nanomsg.org/go/mangos/v2 v2.0.8 h1:Nnc5gCNPd8sSyxgfMTdlKK020p4nxLAxcQrhLVnjGQ8= -nanomsg.org/go/mangos/v2 v2.0.8/go.mod h1:gngxudWUZkxqHN+8n/2y9gWZPcwmSbliFYJsYG8mbKs= +gorm.io/driver/mysql v1.5.6 h1:Ld4mkIickM+EliaQZQx3uOJDJHtrd70MxAUqWqlx3Y8= +gorm.io/driver/mysql v1.5.6/go.mod h1:sEtPWMiqiN1N1cMXoXmBbd8C6/l+TESwriotuRRpkDM= +gorm.io/gorm v1.25.7/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8= +gorm.io/gorm v1.25.10 h1:dQpO+33KalOA+aFYGlK+EfxcI5MbO7EP2yYygwh9h+s= +gorm.io/gorm v1.25.10/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8= +modernc.org/cc/v4 v4.21.0 h1:D/gLKtcztomvWbsbvBKo3leKQv+86f+DdqEZBBXhnag= +modernc.org/cc/v4 v4.21.0/go.mod h1:HM7VJTZbUCR3rV8EYBi9wxnJ0ZBRiGE5OeGXNA0IsLQ= +modernc.org/ccgo/v4 v4.17.3 h1:t2CQci84jnxKw3GGnHvjGKjiNZeZqyQx/023spkk4hU= +modernc.org/ccgo/v4 v4.17.3/go.mod h1:1FCbAtWYJoKuc+AviS+dH+vGNtYmFJqBeRWjmnDWsIg= +modernc.org/fileutil v1.3.0 h1:gQ5SIzK3H9kdfai/5x41oQiKValumqNTDXMvKo62HvE= +modernc.org/fileutil v1.3.0/go.mod h1:XatxS8fZi3pS8/hKG2GH/ArUogfxjpEKs3Ku3aK4JyQ= +modernc.org/gc/v2 v2.4.1 h1:9cNzOqPyMJBvrUipmynX0ZohMhcxPtMccYgGOJdOiBw= +modernc.org/gc/v2 v2.4.1/go.mod h1:wzN5dK1AzVGoH6XOzc3YZ+ey/jPgYHLuVckd62P0GYU= +modernc.org/libc v1.50.5 h1:ZzeUd0dIc/sUtoPTCYIrgypkuzoGzNu6kbEWj2VuEmk= +modernc.org/libc v1.50.5/go.mod h1:rhzrUx5oePTSTIzBgM0mTftwWHK8tiT9aNFUt1mldl0= +modernc.org/mathutil v1.6.0 h1:fRe9+AmYlaej+64JsEEhoWuAYBkOtQiMEU7n/XgfYi4= +modernc.org/mathutil v1.6.0/go.mod h1:Ui5Q9q1TR2gFm0AQRqQUaBWFLAhQpCwNcuhBOSedWPo= +modernc.org/memory v1.8.0 h1:IqGTL6eFMaDZZhEWwcREgeMXYwmW83LYW8cROZYkg+E= +modernc.org/memory v1.8.0/go.mod h1:XPZ936zp5OMKGWPqbD3JShgd/ZoQ7899TUuQqxY+peU= +modernc.org/opt v0.1.3 h1:3XOZf2yznlhC+ibLltsDGzABUGVx8J6pnFMS3E4dcq4= +modernc.org/opt v0.1.3/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0= +modernc.org/sortutil v1.2.0 h1:jQiD3PfS2REGJNzNCMMaLSp/wdMNieTbKX920Cqdgqc= +modernc.org/sortutil v1.2.0/go.mod h1:TKU2s7kJMf1AE84OoiGppNHJwvB753OYfNl2WRb++Ss= +modernc.org/sqlite v1.29.9 h1:9RhNMklxJs+1596GNuAX+O/6040bvOwacTxuFcRuQow= +modernc.org/sqlite v1.29.9/go.mod h1:ItX2a1OVGgNsFh6Dv60JQvGfJfTPHPVpV6DF59akYOA= +modernc.org/strutil v1.2.0 h1:agBi9dp1I+eOnxXeiZawM8F4LawKv4NzGWSaLfyeNZA= +modernc.org/strutil v1.2.0/go.mod h1:/mdcBmfOibveCTBxUl5B5l6W+TTH1FXPLHZE6bTosX0= +modernc.org/token v1.1.0 h1:Xl7Ap9dKaEs5kLoOQeQmPWevfnk/DM5qcLcYlA8ys6Y= +modernc.org/token v1.1.0/go.mod h1:UGzOrNV1mAFSEB63lOFHIpNRUVMvYTc6yu1SMY/XTDM= nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50= rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= -sigs.k8s.io/yaml v1.2.0/go.mod h1:yfXDCHCao9+ENCvLSE62v9VSji2MKu5jeNfTrofGhJc= diff --git a/clients/gohttp/httpd/README.md b/clients/gohttp/httpd/README.md deleted file mode 100644 index 31f2b22..0000000 --- a/clients/gohttp/httpd/README.md +++ /dev/null @@ -1,45 +0,0 @@ -# WeChat Rest Api - -基于 [wcferry](https://github.com/opentdp/wechat-rest/tree/master/wcferry) 实现的 HTTP 接口服务,已实现如下功能: - -- 检查登录状态 -- 获取登录账号 wxid -- 获取登录账号个人信息 -- 获取所有消息类型 -- 获取完整通讯录 -- 获取好友列表 -- 获取所有数据库 -- 获取数据库中所有表 -- 执行 SQL 查询 -- 发送文本消息(可 @) -- 发送图片 -- 发送文件 -- 发送卡片消息 -- 保存图片 -- 保存语音 -- 图片 OCR -- 接受好友申请 -- 接收转账 -- 刷新朋友圈 -- 添加群成员 -- 删除群成员 -- 获取群列表 -- 获取群成员列表 -- 获取群成员昵称 -- 邀请群成员 -- 拍一拍群友 -- 转发消息给好友 -- 转发收到的消息到URL - -## 生成 OpenApi 文档 - -```shell -go get github.com/swaggo/swag/cmd/swag -go install github.com/swaggo/swag/cmd/swag - -swag init --parseDependency -g httpd/server.go -o public/swagger -ot json -``` - -## 生成 OpenApi 客户端 - -将生成的 `swagger.json` 上传至 `https://editor.swagger.io` 生成对应的客户端 diff --git a/clients/gohttp/httpd/midware/guard.go b/clients/gohttp/httpd/midware/guard.go deleted file mode 100644 index 1f004b5..0000000 --- a/clients/gohttp/httpd/midware/guard.go +++ /dev/null @@ -1,39 +0,0 @@ -package midware - -import ( - "strings" - - "github.com/gin-gonic/gin" - - "wechat-rest/args" -) - -func ApiGuard(c *gin.Context) { - - token := "" - - // 取回 Token - authcode := c.GetHeader("Authorization") - parts := strings.SplitN(authcode, " ", 2) - if len(parts) == 2 && parts[0] == "Bearer" { - token = parts[1] - } - - // 校验 Token - if token != args.Web.Token { - c.Set("Error", gin.H{"Code": 401, "Message": "操作未授权"}) - c.Set("ExitCode", 401) - c.Abort() - } - -} - -func SwaggerGuard(c *gin.Context) { - - if !args.Web.Swagger && strings.HasPrefix(c.Request.URL.Path, "/swagger") { - c.Header("Content-Type", "text/html; charset=utf-8") - c.String(200, "功能已禁用") - c.Abort() - } - -} diff --git a/clients/gohttp/httpd/midware/helper.go b/clients/gohttp/httpd/midware/helper.go deleted file mode 100644 index 9d26ac3..0000000 --- a/clients/gohttp/httpd/midware/helper.go +++ /dev/null @@ -1,69 +0,0 @@ -package midware - -import ( - "errors" - - "github.com/gin-gonic/gin" -) - -// 获取错误代码 - -func exitCode(c *gin.Context, code int) int { - - if code := c.GetInt("ExitCode"); code > 100 { - return code - } - - return code - -} - -// 创建错误实例 - -func newError(data any) error { - - if err, ok := data.(error); ok { - return err - } - - if err, ok := data.(string); ok { - return errors.New(err) - } - - return errors.New("未知错误") - -} - -// 构造错误信息 - -func newErrorMessage(data any) gin.H { - - if err, ok := data.(error); ok { - return gin.H{"Error": gin.H{"Message": err.Error()}} - } - - if err, ok := data.(string); ok { - return gin.H{"Error": gin.H{"Message": err}} - } - - return gin.H{"Error": data} - -} - -// 构造结构数据 - -func newPayload(data any, msg, token string) gin.H { - - payload := gin.H{"Payload": data} - - if msg != "" { - payload["Message"] = msg - } - - if token != "" { - payload["Token"] = token - } - - return payload - -} diff --git a/clients/gohttp/httpd/midware/output.go b/clients/gohttp/httpd/midware/output.go deleted file mode 100644 index 4d531e9..0000000 --- a/clients/gohttp/httpd/midware/output.go +++ /dev/null @@ -1,41 +0,0 @@ -package midware - -import ( - "github.com/gin-gonic/gin" -) - -func OutputHandle(c *gin.Context) { - - c.Next() - - // 输出错误信息 - - if err, exists := c.Get("Error"); exists { - c.AbortWithStatusJSON(exitCode(c, 400), newErrorMessage(err)) - return - } - - // 输出请求结果 - - msg := c.GetString("Message") - - if res, exists := c.Get("Payload"); exists || msg != "" { - data := newPayload(res, msg, c.GetString("JwtToken")) - c.AbortWithStatusJSON(exitCode(c, 200), data) - return - } - - // 输出HTML内容 - - if htm := c.GetString("HTML"); htm != "" { - c.Header("Content-Type", "text/html; charset=utf-8") - c.String(200, htm) - c.Abort() - return - } - - // 捕获异常返回 - - c.AbortWithStatusJSON(500, newErrorMessage("内部错误")) - -} diff --git a/clients/gohttp/httpd/server.go b/clients/gohttp/httpd/server.go index 64a9930..6d2a112 100644 --- a/clients/gohttp/httpd/server.go +++ b/clients/gohttp/httpd/server.go @@ -3,33 +3,29 @@ package httpd import ( "github.com/opentdp/go-helper/httpd" - "wechat-rest/args" - "wechat-rest/httpd/midware" - "wechat-rest/httpd/wcfrest" + "github.com/opentdp/wrest-chat/args" + "github.com/opentdp/wrest-chat/httpd/middle" + "github.com/opentdp/wrest-chat/httpd/wcfrest" ) -// @title WeChat Rest Api +// @title Wrest Chat Api // @version v0.10.0 // @description 基于 WeChatFerry RPC 实现的微信接口,使用 Go 语言编写,无第三方运行时依赖,易于对接任意编程语言。 // @contact.name WeChatRest -// @contact.url https://github.com/opentdp/wechat-rest +// @contact.url https://github.com/opentdp/wrest-chat // @license.name Apache 2.0 // @license.url http://www.apache.org/licenses/LICENSE-2.0.html -// @BasePath /api +// @BasePath / func Server() { httpd.Engine(args.Debug) - // Api 守卫 - api := httpd.Group("/api") - api.Use(midware.OutputHandle, midware.ApiGuard) - - // Wcf 路由 - wcfrest.Route(api) + // Wcfrest 路由 + wcfrest.Route() // Swagger 守卫 - httpd.Use(midware.SwaggerGuard) + httpd.Use(middle.SwaggerGuard) // 前端文件路由 httpd.StaticEmbed("/", "public", args.Efs) diff --git a/clients/gohttp/httpd/wcfrest/controller.go b/clients/gohttp/httpd/wcfrest/controller.go deleted file mode 100644 index 747b34a..0000000 --- a/clients/gohttp/httpd/wcfrest/controller.go +++ /dev/null @@ -1,951 +0,0 @@ -package wcfrest - -import ( - "strings" - - "github.com/gin-gonic/gin" - "github.com/mitchellh/mapstructure" - "github.com/opentdp/go-helper/logman" - "golang.org/x/net/websocket" - - "github.com/opentdp/wechat-rest/wcferry" -) - -type Controller struct { - *wcferry.Client -} - -// 通用结果 -type CommonPayload struct { - // 是否成功 - Success bool `json:"success,omitempty"` - // 返回结果 - Result string `json:"result,omitempty"` - // 错误信息 - Error error `json:"error,omitempty"` -} - -// @Summary 检查登录状态 -// @Produce json -// @Success 200 {object} bool -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /is_login [post] -func (wc *Controller) isLogin(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.IsLogin()) - -} - -// @Summary 获取登录账号wxid -// @Produce json -// @Success 200 {object} string -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /self_wxid [post] -func (wc *Controller) getSelfWxid(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.GetSelfWxid()) - -} - -// @Summary 获取登录账号个人信息 -// @Produce json -// @Success 200 {object} UserInfoPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /self_info [post] -func (wc *Controller) getSelfInfo(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.GetSelfInfo()) - -} - -type UserInfoPayload struct { - // 用户 id - Wxid string `json:"wxid,omitempty"` - // 昵称 - Name string `json:"name,omitempty"` - // 手机号 - Mobile string `json:"mobile,omitempty"` - // 文件/图片等父路径 - Home string `json:"home,omitempty"` -} - -// @Summary 获取所有消息类型 -// @Produce json -// @Success 200 {object} map[int32]string -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /msg_types [post] -func (wc *Controller) getMsgTypes(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.GetMsgTypes()) - -} - -// @Summary 获取数据库列表 -// @Produce json -// @Success 200 {object} []string -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /db_names [post] -func (wc *Controller) getDbNames(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.GetDbNames()) - -} - -// @Summary 获取数据库表列表 -// @Produce json -// @Param body body GetDbTablesRequest true "获取数据库表列表参数" -// @Success 200 {object} []DbTablePayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /db_tables [post] -func (wc *Controller) getDbTables(c *gin.Context) { - - var req GetDbTablesRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - c.Set("Payload", wc.CmdClient.GetDbTables(req.Db)) - -} - -type DbTablePayload struct { - // 表名 - Name string `json:"name,omitempty"` - // 建表 SQL - Sql string `json:"sql,omitempty"` -} - -type GetDbTablesRequest struct { - // 数据库名称 - Db string `json:"db"` -} - -// @Summary 执行数据库查询 -// @Produce json -// @Param body body DbSqlQueryRequest true "数据库查询参数" -// @Success 200 {object} []map[string]any -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /db_query_sql [post] -func (wc *Controller) dbSqlQuery(c *gin.Context) { - - var req DbSqlQueryRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - c.Set("Payload", wc.CmdClient.DbSqlQuery(req.Db, req.Sql)) - -} - -type DbSqlQueryRequest struct { - // 数据库名称 - Db string `json:"db"` - // 待执行的 SQL - Sql string `json:"sql"` -} - -// @Summary 获取群列表 -// @Produce json -// @Success 200 {object} []ContactPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /chatrooms [post] -func (wc *Controller) getChatRooms(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.GetChatRooms()) - -} - -// @Summary 获取群成员列表 -// @Produce json -// @Param body body GetChatRoomMembersRequest true "获取群成员列表参数" -// @Success 200 {object} []ContactPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /chatroom_members [post] -func (wc *Controller) getChatRoomMembers(c *gin.Context) { - - var req GetChatRoomMembersRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - c.Set("Payload", wc.CmdClient.GetChatRoomMembers(req.Roomid)) - -} - -type GetChatRoomMembersRequest struct { - // 群聊 id - Roomid string `json:"roomid"` -} - -// @Summary 获取群成员昵称 -// @Produce json -// @Param body body GetAliasInChatRoomRequest true "获取群成员昵称参数" -// @Success 200 {object} string -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /alias_in_chatroom [post] -func (wc *Controller) getAliasInChatRoom(c *gin.Context) { - - var req GetAliasInChatRoomRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - c.Set("Payload", wc.CmdClient.GetAliasInChatRoom(req.Wxid, req.Roomid)) - -} - -type GetAliasInChatRoomRequest struct { - // 群聊 id - Roomid string `json:"roomid"` - // 用户 id - Wxid string `json:"wxid"` -} - -// @Summary 邀请群成员 -// @Produce json -// @Param body body ChatroomMembersRequest true "管理群成员参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /invite_chatroom_members [post] -func (wc *Controller) inviteChatroomMembers(c *gin.Context) { - - var req ChatroomMembersRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.InviteChatroomMembers(req.Roomid, strings.Join(req.Wxids, ",")) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -type ChatroomMembersRequest struct { - // 群聊 id - Roomid string `json:"roomid"` - // 用户 id 列表 - Wxids []string `json:"wxids"` -} - -// @Summary 添加群成员 -// @Produce json -// @Param body body ChatroomMembersRequest true "管理群成员参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /add_chatroom_members [post] -func (wc *Controller) addChatRoomMembers(c *gin.Context) { - - var req ChatroomMembersRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.AddChatRoomMembers(req.Roomid, strings.Join(req.Wxids, ",")) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -// @Summary 删除群成员 -// @Produce json -// @Param body body ChatroomMembersRequest true "管理群成员参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /del_chatroom_members [post] -func (wc *Controller) delChatRoomMembers(c *gin.Context) { - - var req ChatroomMembersRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.DelChatRoomMembers(req.Roomid, strings.Join(req.Wxids, ",")) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -// @Summary 撤回消息 -// @Produce json -// @Param body body RevokeMsgRequest true "撤回消息参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /revoke_msg [post] -func (wc *Controller) revokeMsg(c *gin.Context) { - - var req RevokeMsgRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.RevokeMsg(req.Msgid) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -type RevokeMsgRequest struct { - // 消息 id - Msgid uint64 `json:"msgid"` -} - -// @Summary 转发消息 -// @Produce json -// @Param body body ForwardMsgRequest true "转发消息参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /forward_msg [post] -func (wc *Controller) forwardMsg(c *gin.Context) { - - var req ForwardMsgRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.ForwardMsg(req.Id, strings.Join(req.Receiver, ",")) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -type ForwardMsgRequest struct { - // 待转发消息 id - Id uint64 `json:"id"` - // 转发接收人或群的 id 列表 - Receiver []string `json:"receiver"` -} - -// @Summary 发送文本消息 -// @Produce json -// @Param body body SendTxtRequest true "发送文本消息参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /send_txt [post] -func (wc *Controller) sendTxt(c *gin.Context) { - - var req SendTxtRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.SendTxt(req.Msg, req.Receiver, strings.Join(req.Aters, ",")) - - c.Set("Payload", CommonPayload{ - Success: status == 0, - }) - -} - -type SendTxtRequest struct { - // 消息内容 - Msg string `json:"msg"` - // 接收人或群的 id - Receiver string `json:"receiver"` - // 需要 At 的用户 id 列表 - Aters []string `json:"aters"` -} - -// @Summary 发送图片消息 -// @Produce json -// @Param body body SendImgRequest true "发送图片消息参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /send_img [post] -func (wc *Controller) sendImg(c *gin.Context) { - - var req SendImgRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.SendImg(req.Path, req.Receiver) - - c.Set("Payload", CommonPayload{ - Success: status == 0, - }) - -} - -type SendImgRequest struct { - // 图片路径 - Path string `json:"path"` - // 接收人或群的 id - Receiver string `json:"receiver"` -} - -// @Summary 发送文件消息 -// @Produce json -// @Param body body SendFileRequest true "发送文件消息参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /send_file [post] -func (wc *Controller) sendFile(c *gin.Context) { - - var req SendFileRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.SendFile(req.Path, req.Receiver) - - c.Set("Payload", CommonPayload{ - Success: status == 0, - }) - -} - -type SendFileRequest struct { - // 文件路径 - Path string `json:"path"` - // 接收人或群的 id - Receiver string `json:"receiver"` -} - -// @Summary 发送卡片消息 -// @Produce json -// @Param body body SendRichTextRequest true "发送卡片消息参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /send_rich_text [post] -func (wc *Controller) sendRichText(c *gin.Context) { - - var req SendRichTextRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.SendRichText(req.Name, req.Account, req.Title, req.Digest, req.Url, req.Thumburl, req.Receiver) - - c.Set("Payload", CommonPayload{ - Success: status == 0, - }) - -} - -type SendRichTextRequest struct { - // 左下显示的名字 - Name string `json:"name"` - // 填公众号 id 可以显示对应的头像(gh_ 开头的) - Account string `json:"account"` - // 标题,最多两行 - Title string `json:"title"` - // 摘要,三行 - Digest string `json:"digest"` - // 点击后跳转的链接 - Url string `json:"url"` - // 缩略图的链接 - Thumburl string `json:"thumburl"` - // 接收人或群的 id - Receiver string `json:"receiver"` -} - -// @Summary 拍一拍群友 -// @Produce json -// @Param body body SendPatMsgRequest true "拍一拍群友参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /send_pat_msg [post] -func (wc *Controller) sendPatMsg(c *gin.Context) { - - var req SendPatMsgRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.SendPatMsg(req.Roomid, req.Wxid) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -type SendPatMsgRequest struct { - // 群 id - Roomid string `json:"roomid"` - // 用户 id - Wxid string `json:"wxid"` -} - -// @Summary 获取语音消息 -// @Produce json -// @Param body body GetAudioMsgRequest true "获取语音消息参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /get_audio_msg [post] -func (wc *Controller) getAudioMsg(c *gin.Context) { - - var req GetAudioMsgRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - if req.Timeout > 0 { - resp, err := wc.CmdClient.GetAudioMsgTimeout(req.Msgid, req.Dir, req.Timeout) - c.Set("Payload", CommonPayload{ - Success: resp != "", - Result: resp, - Error: err, - }) - } else { - resp := wc.CmdClient.GetAudioMsg(req.Msgid, req.Dir) - c.Set("Payload", CommonPayload{ - Success: resp != "", - Result: resp, - }) - } - -} - -type GetAudioMsgRequest struct { - // 消息 id - Msgid uint64 `json:"msgid"` - // 存储路径 - Dir string `json:"path"` - // 超时重试次数 - Timeout int `json:"timeout"` -} - -// @Summary 获取OCR识别结果 -// @Produce json -// @Param body body GetOcrRequest true "获取OCR识别结果参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /get_ocr_result [post] -func (wc *Controller) getOcrResult(c *gin.Context) { - - var req GetOcrRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - if req.Timeout > 0 { - resp, err := wc.CmdClient.GetOcrResultTimeout(req.Extra, req.Timeout) - c.Set("Payload", CommonPayload{ - Success: resp != "", - Result: resp, - Error: err, - }) - } else { - resp, stat := wc.CmdClient.GetOcrResult(req.Extra) - c.Set("Payload", CommonPayload{ - Success: stat == 0, - Result: resp, - }) - } - -} - -type GetOcrRequest struct { - // 消息中的 extra 字段 - Extra string `json:"extra"` - // 超时重试次数 - Timeout int `json:"timeout"` -} - -// @Summary 下载图片 -// @Produce json -// @Param body body DownloadImageRequest true "下载图片参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /download_image [post] -func (wc *Controller) downloadImage(c *gin.Context) { - - var req DownloadImageRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - resp, err := wc.CmdClient.DownloadImage(req.Msgid, req.Extra, req.Dir, req.Timeout) - - c.Set("Payload", CommonPayload{ - Success: resp != "", - Result: resp, - Error: err, - }) - -} - -type DownloadImageRequest struct { - // 消息 id - Msgid uint64 `json:"msgid"` - // 消息中的 extra 字段 - Extra string `json:"extra"` - // 存储路径 - Dir string `json:"dir"` - // 超时重试次数 - Timeout int `json:"timeout"` -} - -// @Summary 下载附件 -// @Produce json -// @Param body body DownloadAttachRequest true "下载附件参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /download_attach [post] -func (wc *Controller) downloadAttach(c *gin.Context) { - - var req DownloadAttachRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.DownloadAttach(req.Msgid, req.Thumb, req.Extra) - - c.Set("Payload", CommonPayload{ - Success: status == 0, - }) - -} - -type DownloadAttachRequest struct { - // 消息 id - Msgid uint64 `json:"msgid"` - // 消息中的 thumb 字段 - Thumb string `json:"thumb"` - // 消息中的 extra 字段 - Extra string `json:"extra"` -} - -// @Summary 获取头像列表 -// @Produce json -// @Param body body GetAvatarsRequest true "获取头像列表参数" -// @Success 200 {object} []AvatarPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /avatars [post] -func (wc *Controller) getAvatars(c *gin.Context) { - - var req GetAvatarsRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - sql := "SELECT usrName as UsrName, bigHeadImgUrl as BigHeadImgUrl, smallHeadImgUrl as SmallHeadImgUrl FROM ContactHeadImgUrl" - - if len(req.Wxids) > 0 { - for i, v := range req.Wxids { - req.Wxids[i] = strings.ReplaceAll(v, "'", "''") - } - sql += " WHERE usrName IN ('" + strings.Join(req.Wxids, "','") + "')" - } - - res := wc.CmdClient.DbSqlQuery("MicroMsg.db", sql) - - var result []AvatarPayload - if mapstructure.Decode(res, &result) == nil { - c.Set("Payload", result) - } else { - c.Set("Payload", res) - } - -} - -type GetAvatarsRequest struct { - // 用户 id 列表 - Wxids []string `json:"wxids"` -} - -type AvatarPayload struct { - // 用户 id - UsrName string `json:"usr_name,omitempty"` - // 大头像 url - BigHeadImgUrl string `json:"big_head_img_url,omitempty"` - // 小头像 url - SmallHeadImgUrl string `json:"small_head_img_url,omitempty"` -} - -// @Summary 获取完整通讯录 -// @Produce json -// @Success 200 {object} []ContactPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /contacts [post] -func (wc *Controller) getContacts(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.GetContacts()) - -} - -type ContactPayload struct { - // 用户 id - Wxid string `json:"wxid,omitempty"` - // 微信号 - Code string `json:"code,omitempty"` - // 备注 - Remark string `json:"remark,omitempty"` - // 昵称 - Name string `json:"name,omitempty"` - // 国家 - Country string `json:"country,omitempty"` - // 省/州 - Province string `json:"province,omitempty"` - // 城市 - City string `json:"city,omitempty"` - // 性别 - Gender int32 `json:"gender,omitempty"` -} - -// @Summary 获取好友列表 -// @Produce json -// @Success 200 {object} []ContactPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /friends [post] -func (wc *Controller) getFriends(c *gin.Context) { - - c.Set("Payload", wc.CmdClient.GetFriends()) - -} - -// @Summary 根据wxid获取个人信息 -// @Produce json -// @Param body body GetInfoByWxidRequest true "根据wxid获取个人信息参数" -// @Success 200 {object} ContactPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /user_info [post] -func (wc *Controller) getInfoByWxid(c *gin.Context) { - - var req GetInfoByWxidRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - c.Set("Payload", wc.CmdClient.GetInfoByWxid(req.Wxid)) - -} - -type GetInfoByWxidRequest struct { - // 用户 id - Wxid string `json:"wxid"` -} - -// @Summary 刷新朋友圈 -// @Produce json -// @Param body body RefreshPyqRequest true "刷新朋友圈参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /refresh_pyq [post] -func (wc *Controller) refreshPyq(c *gin.Context) { - - var req RefreshPyqRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.RefreshPyq(req.Id) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -type RefreshPyqRequest struct { - // 分页 id - Id uint64 `json:"id"` -} - -// @Summary 接受好友请求 -// @Produce json -// @Param body body AcceptNewFriendRequest true "接受好友参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /accept_new_friend [post] -func (wc *Controller) acceptNewFriend(c *gin.Context) { - - var req AcceptNewFriendRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.AcceptNewFriend(req.V3, req.V4, req.Scene) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -type AcceptNewFriendRequest struct { - // 加密的用户名 - V3 string `json:"v3"` - // 验证信息 Ticket - V4 string `json:"v4"` - // 添加方式:17 名片,30 扫码 - Scene int32 `json:"scene"` -} - -// @Summary 接受转账 -// @Produce json -// @Param body body ReceiveTransferRequest true "接受转账参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /receive_transfer [post] -func (wc *Controller) receiveTransfer(c *gin.Context) { - - var req ReceiveTransferRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - status := wc.CmdClient.ReceiveTransfer(req.Wxid, req.Tfid, req.Taid) - - c.Set("Payload", CommonPayload{ - Success: status == 1, - }) - -} - -type ReceiveTransferRequest struct { - // 转账人 - Wxid string `json:"wxid,omitempty"` - // 转账id transferid - Tfid string `json:"tfid,omitempty"` - // Transaction id - Taid string `json:"taid,omitempty"` -} - -// @Summary 开启推送消息到URL -// @Produce json -// @Param body body ReceiverRequest true "推送消息到URL参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /enable_receiver [post] -func (wc *Controller) enabledReceiver(c *gin.Context) { - - var req ReceiverRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - if !strings.HasPrefix(req.Url, "http") { - c.Set("Error", "url must start with http(s)://") - return - } - - err := wc.enableUrlReceiver(req.Url) - c.Set("Payload", CommonPayload{ - Success: err == nil, - Error: err, - }) - -} - -type ReceiverRequest struct { - // 接收推送消息的 url - Url string `json:"url"` -} - -// @Summary 关闭推送消息到URL -// @Produce json -// @Param body body ReceiverRequest true "推送消息到URL参数" -// @Success 200 {object} CommonPayload -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /disable_receiver [post] -func (wc *Controller) disableReceiver(c *gin.Context) { - - var req ReceiverRequest - if err := c.ShouldBindJSON(&req); err != nil { - c.Set("Error", err) - return - } - - err := wc.disableUrlReceiver(req.Url) - c.Set("Payload", CommonPayload{ - Success: err == nil, - Error: err, - }) - -} - -// @Summary 推送消息到Socket -// @Produce json -// @Tags websocket -// @Success 101 {string} string "Switching Protocols 响应" -// @Failure 400 {string} string "非法请求" -// @Failure 500 {string} string "内部服务器错误" -// @Router /socket_receiver [get] -func (wc *Controller) socketReceiver(c *gin.Context) { - - h := websocket.Handler(func(ws *websocket.Conn) { - wc.enableSocketReceiver(ws) - for { - var rq string - if err := websocket.Message.Receive(ws, &rq); err != nil { - logman.Error("read:error", "error", err) - break - } - } - wc.disableSocketReceiver(ws) - }) - - h.ServeHTTP(c.Writer, c.Request) - - c.Set("Payload", "连接已关闭") - -} diff --git a/clients/gohttp/httpd/wcfrest/receiver.go b/clients/gohttp/httpd/wcfrest/receiver.go deleted file mode 100644 index 772dbfa..0000000 --- a/clients/gohttp/httpd/wcfrest/receiver.go +++ /dev/null @@ -1,107 +0,0 @@ -package wcfrest - -import ( - "errors" - - "github.com/opentdp/go-helper/logman" - "github.com/opentdp/go-helper/request" - "golang.org/x/net/websocket" - - "github.com/opentdp/wechat-rest/wcferry" -) - -var urlReceiverKey = "" -var urlReceiverList = map[string]bool{} - -var socketReceiverKey = "" -var socketReceiverList = map[*websocket.Conn]bool{} - -func (wc *Controller) enableUrlReceiver(url string) error { - - logman.Info("enable receiver", "url", url) - - if urlReceiverKey == "" { - key, err := wc.EnrollReceiver(true, func(msg *wcferry.WxMsg) { - ret := wcferry.ParseWxMsg(msg) - for u := range urlReceiverList { - logman.Info("call receiver", "url", u, "Id", ret.Id) - go request.JsonPost(u, ret, request.H{}) - } - }) - if err != nil { - return err - } - urlReceiverKey = key - } - - if _, ok := urlReceiverList[url]; ok { - return errors.New("url already exists") - } - - urlReceiverList[url] = true - return nil - -} - -func (wc *Controller) disableUrlReceiver(url string) error { - - logman.Info("disable receiver", "url", url) - - if _, ok := urlReceiverList[url]; !ok { - return errors.New("url not exists") - } - - delete(urlReceiverList, url) - - if len(urlReceiverList) == 0 { - return wc.DisableReceiver(urlReceiverKey) - } - - return nil - -} - -func (wc *Controller) enableSocketReceiver(ws *websocket.Conn) error { - - logman.Info("enable receiver", "socket", ws.RemoteAddr().String()) - - if len(socketReceiverList) == 0 { - key, err := wc.EnrollReceiver(true, func(msg *wcferry.WxMsg) { - ret := wcferry.ParseWxMsg(msg) - for w := range socketReceiverList { - logman.Info("call receiver", "socket", ws.RemoteAddr().String(), "Id", ret.Id) - go websocket.JSON.Send(w, ret) - } - }) - if err != nil { - return err - } - socketReceiverKey = key - } - - if _, ok := socketReceiverList[ws]; ok { - return errors.New("socket already exists") - } - - socketReceiverList[ws] = true - return nil - -} - -func (wc *Controller) disableSocketReceiver(ws *websocket.Conn) error { - - logman.Info("disable receiver", "socket", ws.RemoteAddr().String()) - - if _, ok := socketReceiverList[ws]; !ok { - return errors.New("socket not exists") - } - - delete(socketReceiverList, ws) - - if len(socketReceiverList) == 0 { - return wc.DisableReceiver(socketReceiverKey) - } - - return nil - -} diff --git a/clients/gohttp/httpd/wcfrest/router.go b/clients/gohttp/httpd/wcfrest/router.go deleted file mode 100644 index 3218f62..0000000 --- a/clients/gohttp/httpd/wcfrest/router.go +++ /dev/null @@ -1,54 +0,0 @@ -package wcfrest - -import ( - "github.com/gin-gonic/gin" - - "github.com/opentdp/wechat-rest/wclient" -) - -func Route(rg *gin.RouterGroup) { - - ctrl := &Controller{wclient.Register()} - - rg.POST("is_login", ctrl.isLogin) - rg.POST("self_wxid", ctrl.getSelfWxid) - rg.POST("self_info", ctrl.getSelfInfo) - rg.POST("msg_types", ctrl.getMsgTypes) - - rg.POST("db_names", ctrl.getDbNames) - rg.POST("db_tables", ctrl.getDbTables) - rg.POST("db_query_sql", ctrl.dbSqlQuery) - - rg.POST("chatrooms", ctrl.getChatRooms) - rg.POST("chatroom_members", ctrl.getChatRoomMembers) - rg.POST("alias_in_chatroom", ctrl.getAliasInChatRoom) - rg.POST("invite_chatroom_members", ctrl.inviteChatroomMembers) - rg.POST("add_chatroom_members", ctrl.addChatRoomMembers) - rg.POST("del_chatroom_members", ctrl.delChatRoomMembers) - - rg.POST("revoke_msg", ctrl.revokeMsg) - rg.POST("forward_msg", ctrl.forwardMsg) - rg.POST("send_txt", ctrl.sendTxt) - rg.POST("send_img", ctrl.sendImg) - rg.POST("send_file", ctrl.sendFile) - rg.POST("send_rich_text", ctrl.sendRichText) - rg.POST("send_pat_msg", ctrl.sendPatMsg) - rg.POST("audio_msg", ctrl.getAudioMsg) - rg.POST("ocr_result", ctrl.getOcrResult) - rg.POST("download_image", ctrl.downloadImage) - rg.POST("download_attach", ctrl.downloadAttach) - - rg.POST("avatars", ctrl.getAvatars) - rg.POST("contacts", ctrl.getContacts) - rg.POST("friends", ctrl.getFriends) - rg.POST("user_info", ctrl.getInfoByWxid) - rg.POST("refresh_pyq", ctrl.refreshPyq) - rg.POST("accept_new_friend", ctrl.acceptNewFriend) - rg.POST("receive_transfer", ctrl.receiveTransfer) - - rg.POST("enable_receiver", ctrl.enabledReceiver) - rg.POST("disable_receiver", ctrl.disableReceiver) - - rg.GET("socket_receiver", ctrl.socketReceiver) - -} diff --git a/clients/gohttp/main.go b/clients/gohttp/main.go index 1988b6e..973f4c0 100644 --- a/clients/gohttp/main.go +++ b/clients/gohttp/main.go @@ -3,8 +3,9 @@ package main import ( "embed" - "wechat-rest/args" "wechat-rest/httpd" + + "github.com/opentdp/wrest-chat/args" ) //go:embed public @@ -14,9 +15,6 @@ func main() { args.Efs = &efs - c := args.Config{} - c.Init().Unmarshal() - httpd.Server() } diff --git a/clients/gohttp/public/index.html b/clients/gohttp/public/index.html index 4b23856..9f7c0a2 100644 --- a/clients/gohttp/public/index.html +++ b/clients/gohttp/public/index.html @@ -3,14 +3,20 @@
+