From f132960772cdc6c144cce953ef14ac4b2521c760 Mon Sep 17 00:00:00 2001 From: "jiaji.H" Date: Thu, 16 Oct 2025 15:21:30 +0800 Subject: [PATCH] =?UTF-8?q?Updata=EF=BC=9A=E4=BF=AE=E6=AD=A3=E9=80=BB?= =?UTF-8?q?=E8=BE=91=E4=B8=8E=E5=AF=B9=E8=B1=A1=E7=BB=93=E6=9E=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cmd/main.go | 121 ++++++------------- conf/alibabacloud.env | 14 +-- conf/config.go | 25 +--- examples.md | 137 --------------------- go.mod | 16 ++- go.sum | 218 ++++++++++++++++++++++++++++++++- internal/api/image_scanner.go | 194 +++++++++++++++--------------- internal/api/text_scanner.go | 219 ++++++++++++++++++---------------- internal/api/video_scanner.go | 211 ++++++++++++++++---------------- internal/model/image.go | 38 ++---- internal/model/text.go | 42 +++---- internal/model/video.go | 79 +++++------- 12 files changed, 637 insertions(+), 677 deletions(-) delete mode 100644 examples.md diff --git a/cmd/main.go b/cmd/main.go index 9f2ddc0..4087d6a 100644 --- a/cmd/main.go +++ b/cmd/main.go @@ -25,71 +25,40 @@ func main() { // 显示配置信息(隐藏敏感信息) fmt.Printf("✅ 配置加载成功\n") - fmt.Printf(" 登录模式: %s\n", config.LoginMode) fmt.Printf(" 区域: %s\n", config.Region) fmt.Printf(" 端点: %s\n", config.Endpoint) - - if config.LoginMode == "sts" { - fmt.Printf(" RAM AccessKey ID: %s...\n", config.RAMAccessKeyID[:8]) - fmt.Printf(" RAM角色ARN: %s\n", config.RAMRoleArn) - } else { - if config.AccessKeyID != "" { - fmt.Printf(" AccessKey ID: %s...\n", config.AccessKeyID[:8]) - } - if config.AccessKeySecret != "" { - fmt.Printf(" AccessKey Secret: %s...\n", config.AccessKeySecret[:8]) - } - } + fmt.Printf(" RAM AccessKey ID: %s...\n", config.RAMAccessKeyID[:8]) + fmt.Printf(" RAM角色ARN: %s\n", config.RAMRoleArn) fmt.Println() - // 检查必要的配置 - if config.LoginMode == "sts" { - // STS模式检查 - if config.RAMAccessKeyID == "" || config.RAMAccessKeySecret == "" || config.RAMRoleArn == "" { - fmt.Println("❌ STS模式缺少必要的配置信息:") - if config.RAMAccessKeyID == "" { - fmt.Println(" - RAM_ACCESS_KEY_ID 未设置") - } - if config.RAMAccessKeySecret == "" { - fmt.Println(" - RAM_ACCESS_KEY_SECRET 未设置") - } - if config.RAMRoleArn == "" { - fmt.Println(" - RAM_ROLE_ARN 未设置") - } - fmt.Println() - fmt.Println("请检查以下配置文件:") - fmt.Println(" - .env") - fmt.Println(" - conf/alibabacloud.env") - fmt.Println(" - 环境变量") - return + // STS模式检查 + if config.RAMAccessKeyID == "" || config.RAMAccessKeySecret == "" || config.RAMRoleArn == "" { + fmt.Println("❌ STS模式缺少必要的配置信息:") + if config.RAMAccessKeyID == "" { + fmt.Println(" - RAM_ACCESS_KEY_ID 未设置") } - - // 获取STS临时凭证 - fmt.Println("正在获取STS临时凭证...") - if err := config.GetSTSToken(); err != nil { - fmt.Printf("❌ 获取STS临时凭证失败: %v\n", err) - return + if config.RAMAccessKeySecret == "" { + fmt.Println(" - RAM_ACCESS_KEY_SECRET 未设置") } - fmt.Println("✅ STS临时凭证获取成功") - } else { - // 直接模式检查 - if config.AccessKeyID == "" || config.AccessKeySecret == "" { - fmt.Println("❌ 直接模式缺少必要的配置信息:") - if config.AccessKeyID == "" { - fmt.Println(" - ALIBABA_CLOUD_ACCESS_KEY_ID 未设置") - } - if config.AccessKeySecret == "" { - fmt.Println(" - ALIBABA_CLOUD_ACCESS_KEY_SECRET 未设置") - } - fmt.Println() - fmt.Println("请检查以下配置文件:") - fmt.Println(" - .env") - fmt.Println(" - conf/alibabacloud.env") - fmt.Println(" - 环境变量") - return + if config.RAMRoleArn == "" { + fmt.Println(" - RAM_ROLE_ARN 未设置") } + fmt.Println() + fmt.Println("请检查以下配置文件:") + fmt.Println(" - .env") + fmt.Println(" - conf/alibabacloud.env") + fmt.Println(" - 环境变量") + return } + // 获取STS临时凭证 + fmt.Println("正在获取STS临时凭证...") + if err := config.GetSTSToken(); err != nil { + fmt.Printf("❌ 获取STS临时凭证失败: %v\n", err) + return + } + fmt.Println("✅ STS临时凭证获取成功") + // 显示菜单 for { showMenu() @@ -123,7 +92,7 @@ func showMenu() { } func handleImageScan(config *conf.Config) { - fmt.Println("\n=== 图片内容安全审核(2.0版本)===") + fmt.Println("\n=== 图片内容安全审核===") scanner, err := api.NewImageScanner(config) if err != nil { @@ -133,9 +102,9 @@ func handleImageScan(config *conf.Config) { // 选择服务类型 fmt.Println("请选择图片审核服务类型:") - fmt.Println("1. 通用基线检测(baselineCheck_global)") - fmt.Println("2. 大小模型融合图片审核服务(postImageCheckByVL_global)") - fmt.Println("3. AI生成图片鉴别(aigcDetector_global)") + fmt.Println("1. 通用基线检测") + fmt.Println("2. 大小模型融合图片审核服务") + fmt.Println("3. AI生成图片鉴别") serviceChoice := getUserInput("请选择服务类型 (1-3): ") var serviceType api.ImageServiceType @@ -198,7 +167,7 @@ func handleImageScan(config *conf.Config) { } func handleTextScan(config *conf.Config) { - fmt.Println("\n=== 文本内容安全审核(2.0版本)===") + fmt.Println("\n=== 文本内容安全审核===") scanner, err := api.NewTextScanner(config) if err != nil { @@ -206,26 +175,6 @@ func handleTextScan(config *conf.Config) { return } - // 选择服务类型 - fmt.Println("请选择文本审核服务类型:") - fmt.Println("1. 通用基线检测(baselineCheck_global)") - fmt.Println("2. 大小模型融合文本审核服务(postTextCheckByVL_global)") - - serviceChoice := getUserInput("请选择服务类型 (1-2): ") - var serviceType api.TextServiceType - - switch serviceChoice { - case "1": - serviceType = api.TextBaselineCheckGlobal - fmt.Println("✅ 已选择:通用基线检测") - case "2": - serviceType = api.TextPostCheckByVLGlobal - fmt.Println("✅ 已选择:大小模型融合文本审核服务") - default: - fmt.Println("❌ 无效选择") - return - } - fmt.Println("\n请选择文本输入方式:") fmt.Println("1. 单条文本") fmt.Println("2. 批量文本") @@ -241,7 +190,7 @@ func handleTextScan(config *conf.Config) { } fmt.Println("正在扫描文本...") - result, err := scanner.ScanText(text, "text_"+time.Now().Format("20060102150405"), serviceType) + result, err := scanner.ScanText(text, "text_"+time.Now().Format("20060102150405"), api.TextBaselineCheckGlobal) if err != nil { fmt.Printf("❌ 扫描失败: %v\n", err) return @@ -268,7 +217,7 @@ func handleTextScan(config *conf.Config) { } fmt.Printf("正在批量扫描 %d 条文本...\n", len(texts)) - result, err := scanner.ScanTextBatch(texts, dataIDs, serviceType) + result, err := scanner.ScanTextBatch(texts, dataIDs, api.TextBaselineCheckGlobal) if err != nil { fmt.Printf("❌ 扫描失败: %v\n", err) return @@ -281,7 +230,7 @@ func handleTextScan(config *conf.Config) { } func handleVideoScan(config *conf.Config) { - fmt.Println("\n=== 视频内容安全审核(2.0版本)===") + fmt.Println("\n=== 视频内容安全审核===") scanner, err := api.NewVideoScanner(config) if err != nil { @@ -291,8 +240,8 @@ func handleVideoScan(config *conf.Config) { // 选择服务类型 fmt.Println("请选择视频审核服务类型:") - fmt.Println("1. 通用基线检测(baselineCheck_global)") - fmt.Println("2. 大小模型融合视频审核服务(postVideoCheckByVL_global)") + fmt.Println("1. 通用基线检测") + fmt.Println("2. 大小模型融合视频审核服务") serviceChoice := getUserInput("请选择服务类型 (1-2): ") var serviceType api.VideoServiceType diff --git a/conf/alibabacloud.env b/conf/alibabacloud.env index a2e3443..570c8e1 100644 --- a/conf/alibabacloud.env +++ b/conf/alibabacloud.env @@ -1,14 +1,4 @@ #=========== 阿里云内容安全配置 =========== -# 登录模式:direct(直接使用AccessKey)或 sts(使用STS临时凭证) -LOGIN_MODE=sts - -# 直接登录模式配置 -# 阿里云AccessKey ID -ALIBABA_CLOUD_ACCESS_KEY_ID=LTAI5tNBzbeEbG1yCitvHsMb - -# 阿里云AccessKey Secret -ALIBABA_CLOUD_ACCESS_KEY_SECRET=G1xAUB8G6WDVo0SLr6DJaJjNWIlpmO - # STS登录模式配置 # RAM用户AccessKey ID(用于获取STS临时凭证) RAM_ACCESS_KEY_ID=LTAI5tNBzbeEbG1yCitvHsMb @@ -20,7 +10,7 @@ RAM_ACCESS_KEY_SECRET=G1xAUB8G6WDVo0SLr6DJaJjNWIlpmO RAM_ROLE_ARN=acs:ram::5828544250383902:role/content-secret # 阿里云区域(可选,默认为cn-shanghai) -ALIBABA_CLOUD_REGION=cn-shanghai +ALIBABA_CLOUD_REGION=ap-southeast-1 # 阿里云端点(可选,默认为green.cn-shanghai.aliyuncs.com) -ALIBABA_CLOUD_ENDPOINT=green.cn-shanghai.aliyuncs.com \ No newline at end of file +ALIBABA_CLOUD_ENDPOINT=green-cip.ap-southeast-1.aliyuncs.com \ No newline at end of file diff --git a/conf/config.go b/conf/config.go index 260f174..e06498a 100644 --- a/conf/config.go +++ b/conf/config.go @@ -10,13 +10,6 @@ import ( // Config 配置结构体 type Config struct { - // 登录模式 - LoginMode string - - // 直接登录模式配置 - AccessKeyID string - AccessKeySecret string - // STS登录模式配置 RAMAccessKeyID string RAMAccessKeySecret string @@ -50,9 +43,6 @@ func LoadConfig() (*Config, error) { } config := &Config{ - LoginMode: getEnv("LOGIN_MODE", "direct"), - AccessKeyID: getEnv("ALIBABA_CLOUD_ACCESS_KEY_ID", ""), - AccessKeySecret: getEnv("ALIBABA_CLOUD_ACCESS_KEY_SECRET", ""), RAMAccessKeyID: getEnv("RAM_ACCESS_KEY_ID", ""), RAMAccessKeySecret: getEnv("RAM_ACCESS_KEY_SECRET", ""), RAMRoleArn: getEnv("RAM_ROLE_ARN", ""), @@ -73,9 +63,6 @@ func LoadConfigFromFile(configFile string) (*Config, error) { fmt.Printf("成功加载配置文件: %s\n", configFile) config := &Config{ - LoginMode: getEnv("LOGIN_MODE", "direct"), - AccessKeyID: getEnv("ALIBABA_CLOUD_ACCESS_KEY_ID", ""), - AccessKeySecret: getEnv("ALIBABA_CLOUD_ACCESS_KEY_SECRET", ""), RAMAccessKeyID: getEnv("RAM_ACCESS_KEY_ID", ""), RAMAccessKeySecret: getEnv("RAM_ACCESS_KEY_SECRET", ""), RAMRoleArn: getEnv("RAM_ROLE_ARN", ""), @@ -96,9 +83,6 @@ func getEnv(key, defaultValue string) string { // GetSTSToken 获取STS临时凭证 func (c *Config) GetSTSToken() error { - if c.LoginMode != "sts" { - return nil // 非STS模式,不需要获取临时凭证 - } // 创建STS客户端 stsClient, err := sts.NewClientWithAccessKey(c.Region, c.RAMAccessKeyID, c.RAMAccessKeySecret) @@ -128,10 +112,7 @@ func (c *Config) GetSTSToken() error { // GetEffectiveCredentials 获取有效的访问凭证 func (c *Config) GetEffectiveCredentials() (accessKeyID, accessKeySecret, securityToken string) { - if c.LoginMode == "sts" && c.TempAccessKeyID != "" { - // 使用STS临时凭证 - return c.TempAccessKeyID, c.TempAccessKeySecret, c.SecurityToken - } - // 使用直接凭证 - return c.AccessKeyID, c.AccessKeySecret, "" + // 使用STS临时凭证 + return c.TempAccessKeyID, c.TempAccessKeySecret, c.SecurityToken + } diff --git a/examples.md b/examples.md deleted file mode 100644 index baa86c6..0000000 --- a/examples.md +++ /dev/null @@ -1,137 +0,0 @@ -# 使用示例 - -## 1. 图片审核示例 - -### 通过URL审核图片 -``` -请输入图片URL: https://example.com/test-image.jpg -``` - -### 通过本地文件审核图片 -``` -请输入图片文件路径: C:\Users\Desktop\test-image.png -``` - -## 2. 文本审核示例 - -### 单条文本审核 -``` -请输入要审核的文本: 这是一段测试文本,包含一些敏感词汇 -``` - -### 批量文本审核 -``` -文本1: 第一条测试文本 -文本2: 第二条测试文本 -文本3: 第三条测试文本 -文本4: [空行结束输入] -``` - -## 3. 视频审核示例 - -### 异步视频审核 -``` -请输入视频URL: https://example.com/test-video.mp4 -``` - -### 同步视频审核 -``` -请输入视频URL: https://example.com/test-video.mp4 -``` - -## 4. 审核结果示例 - -### 图片审核结果 -``` -=== 图片内容安全审核结果 === -状态码: 200 -消息: OK - -数据ID: image_20231201120000 -处理状态: 200 - OK -✅ 未检测到违规内容 -``` - -### 文本审核结果 -``` -=== 文本内容安全审核结果 === -状态码: 200 -消息: OK - -数据ID: text_20231201120000 -处理状态: 200 - OK -场景: antispam -标签: spam -建议: block -置信度: 0.95 -违规详情: - 内容: 敏感词汇 - 位置: [10, 15] ---- -``` - -### 视频审核结果 -``` -=== 视频内容安全审核结果 === -状态码: 200 -消息: OK - -数据ID: video_20231201120000 -任务ID: task_123456789 -处理状态: 200 - OK -审核状态: success -场景: porn -标签: porn -建议: block -置信度: 0.88 -违规帧详情: - 时间偏移: 30秒 - 帧URL: https://example.com/frame.jpg - 场景: porn, 标签: porn, 建议: block, 置信度: 0.88 ---- -``` - -## 5. 环境变量配置示例 - -### Windows (PowerShell) -```powershell -$env:ALIBABA_CLOUD_ACCESS_KEY_ID="your_access_key_id" -$env:ALIBABA_CLOUD_ACCESS_KEY_SECRET="your_access_key_secret" -``` - -### Windows (CMD) -```cmd -set ALIBABA_CLOUD_ACCESS_KEY_ID=your_access_key_id -set ALIBABA_CLOUD_ACCESS_KEY_SECRET=your_access_key_secret -``` - -### Linux/macOS -```bash -export ALIBABA_CLOUD_ACCESS_KEY_ID="your_access_key_id" -export ALIBABA_CLOUD_ACCESS_KEY_SECRET="your_access_key_secret" -``` - -### .env文件 -```env -ALIBABA_CLOUD_ACCESS_KEY_ID=your_access_key_id -ALIBABA_CLOUD_ACCESS_KEY_SECRET=your_access_key_secret -ALIBABA_CLOUD_REGION=cn-shanghai -ALIBABA_CLOUD_ENDPOINT=green.cn-shanghai.aliyuncs.com -``` - -## 6. 常见问题 - -### Q: 如何获取阿里云AccessKey? -A: 登录阿里云控制台,进入"访问控制" -> "用户" -> "创建AccessKey" - -### Q: 支持哪些图片格式? -A: 支持JPG、JPEG、PNG、BMP、GIF、WEBP格式,文件大小不超过9MB - -### Q: 视频审核需要多长时间? -A: 视频审核时间取决于视频长度,通常需要几分钟到十几分钟 - -### Q: 如何查看审核历史? -A: 可以通过任务ID查询历史审核结果 - -### Q: 审核费用如何计算? -A: 按调用次数计费,具体价格请查看阿里云官方定价页面 diff --git a/go.mod b/go.mod index 8b86dc1..7e18160 100644 --- a/go.mod +++ b/go.mod @@ -3,19 +3,25 @@ module contentSecurityDemo go 1.23 require ( - github.com/alibabacloud-go/darabonba-openapi/v2 v2.0.4 - github.com/alibabacloud-go/green-20220302/v2 v2.0.0 - github.com/alibabacloud-go/tea v1.2.1 - github.com/alibabacloud-go/tea-utils/v2 v2.0.1 - github.com/aliyun/alibaba-cloud-sdk-go v1.62.706 + github.com/alibabacloud-go/darabonba-openapi/v2 v2.1.12 + github.com/alibabacloud-go/green-20220302/v2 v2.23.0 + github.com/alibabacloud-go/tea v1.3.13 + github.com/alibabacloud-go/tea-utils/v2 v2.0.7 + github.com/aliyun/alibaba-cloud-sdk-go v1.63.107 github.com/joho/godotenv v1.5.1 ) require ( + github.com/alibabacloud-go/alibabacloud-gateway-spi v0.0.5 // indirect + github.com/alibabacloud-go/debug v1.0.1 // indirect + github.com/aliyun/credentials-go v1.4.5 // indirect + github.com/clbanning/mxj/v2 v2.7.0 // indirect github.com/jmespath/go-jmespath v0.4.0 // indirect github.com/json-iterator/go v1.1.12 // indirect github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect github.com/modern-go/reflect2 v1.0.2 // indirect github.com/opentracing/opentracing-go v1.2.1-0.20220228012449-10b1cf09e00b // indirect + github.com/tjfoc/gmsm v1.4.1 // indirect + golang.org/x/net v0.26.0 // indirect gopkg.in/ini.v1 v1.67.0 // indirect ) diff --git a/go.sum b/go.sum index 2784d53..656e259 100644 --- a/go.sum +++ b/go.sum @@ -1,27 +1,105 @@ +cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= +github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= github.com/HdrHistogram/hdrhistogram-go v1.1.2/go.mod h1:yDgFjdqOqDEKOvasDdhWNXYg9BVp4O+o5f6V/ehm6Oo= github.com/ajstarks/svgo v0.0.0-20180226025133-644b8db467af/go.mod h1:K08gAheRH3/J6wwsYMMT4xOr94bZjxIelGM0+d/wbFw= -github.com/aliyun/alibaba-cloud-sdk-go v1.62.706 h1:5qi9iWE+e6XoobqYHdg6rQj1o+ygAWhM4AzyvHgk4fA= -github.com/aliyun/alibaba-cloud-sdk-go v1.62.706/go.mod h1:SOSDHfe1kX91v3W5QiBsWSLqeLxImobbMX1mxrFHsVQ= +github.com/alibabacloud-go/alibabacloud-gateway-pop v0.0.6 h1:eIf+iGJxdU4U9ypaUfbtOWCsZSbTb8AUHvyPrxu6mAA= +github.com/alibabacloud-go/alibabacloud-gateway-pop v0.0.6/go.mod h1:4EUIoxs/do24zMOGGqYVWgw0s9NtiylnJglOeEB5UJo= +github.com/alibabacloud-go/alibabacloud-gateway-spi v0.0.4/go.mod h1:sCavSAvdzOjul4cEqeVtvlSaSScfNsTQ+46HwlTL1hc= +github.com/alibabacloud-go/alibabacloud-gateway-spi v0.0.5 h1:zE8vH9C7JiZLNJJQ5OwjU9mSi4T9ef9u3BURT6LCLC8= +github.com/alibabacloud-go/alibabacloud-gateway-spi v0.0.5/go.mod h1:tWnyE9AjF8J8qqLk645oUmVUnFybApTQWklQmi5tY6g= +github.com/alibabacloud-go/darabonba-array v0.1.0 h1:vR8s7b1fWAQIjEjWnuF0JiKsCvclSRTfDzZHTYqfufY= +github.com/alibabacloud-go/darabonba-array v0.1.0/go.mod h1:BLKxr0brnggqOJPqT09DFJ8g3fsDshapUD3C3aOEFaI= +github.com/alibabacloud-go/darabonba-encode-util v0.0.2 h1:1uJGrbsGEVqWcWxrS9MyC2NG0Ax+GpOM5gtupki31XE= +github.com/alibabacloud-go/darabonba-encode-util v0.0.2/go.mod h1:JiW9higWHYXm7F4PKuMgEUETNZasrDM6vqVr/Can7H8= +github.com/alibabacloud-go/darabonba-map v0.0.2 h1:qvPnGB4+dJbJIxOOfawxzF3hzMnIpjmafa0qOTp6udc= +github.com/alibabacloud-go/darabonba-map v0.0.2/go.mod h1:28AJaX8FOE/ym8OUFWga+MtEzBunJwQGceGQlvaPGPc= +github.com/alibabacloud-go/darabonba-openapi/v2 v2.1.12 h1:e2yCrhtWd6Qcsy4he2OL+jIAU+93Lx9OcLlPRoFLT1w= +github.com/alibabacloud-go/darabonba-openapi/v2 v2.1.12/go.mod h1:f2wDpbM7hK9SvLIH09zSKVU1TsyemUNOqErMscMMl7c= +github.com/alibabacloud-go/darabonba-signature-util v0.0.7 h1:UzCnKvsjPFzApvODDNEYqBHMFt1w98wC7FOo0InLyxg= +github.com/alibabacloud-go/darabonba-signature-util v0.0.7/go.mod h1:oUzCYV2fcCH797xKdL6BDH8ADIHlzrtKVjeRtunBNTQ= +github.com/alibabacloud-go/darabonba-string v1.0.2 h1:E714wms5ibdzCqGeYJ9JCFywE5nDyvIXIIQbZVFkkqo= +github.com/alibabacloud-go/darabonba-string v1.0.2/go.mod h1:93cTfV3vuPhhEwGGpKKqhVW4jLe7tDpo3LUM0i0g6mA= +github.com/alibabacloud-go/debug v0.0.0-20190504072949-9472017b5c68/go.mod h1:6pb/Qy8c+lqua8cFpEy7g39NRRqOWc3rOwAy8m5Y2BY= +github.com/alibabacloud-go/debug v1.0.0/go.mod h1:8gfgZCCAC3+SCzjWtY053FrOcd4/qlH6IHTI4QyICOc= +github.com/alibabacloud-go/debug v1.0.1 h1:MsW9SmUtbb1Fnt3ieC6NNZi6aEwrXfDksD4QA6GSbPg= +github.com/alibabacloud-go/debug v1.0.1/go.mod h1:8gfgZCCAC3+SCzjWtY053FrOcd4/qlH6IHTI4QyICOc= +github.com/alibabacloud-go/endpoint-util v1.1.0 h1:r/4D3VSw888XGaeNpP994zDUaxdgTSHBbVfZlzf6b5Q= +github.com/alibabacloud-go/endpoint-util v1.1.0/go.mod h1:O5FuCALmCKs2Ff7JFJMudHs0I5EBgecXXxZRyswlEjE= +github.com/alibabacloud-go/green-20220302/v2 v2.23.0 h1:t2WsqrKt/ztPq4X2Orh3cvG5PsFdes/IQDkxZmB/f5k= +github.com/alibabacloud-go/green-20220302/v2 v2.23.0/go.mod h1:iZWuUEakwGct+e0NDnTBzOMaoblCUXH8Lf7S5v4kGKg= +github.com/alibabacloud-go/openapi-util v0.1.0 h1:0z75cIULkDrdEhkLWgi9tnLe+KhAFE/r5Pb3312/eAY= +github.com/alibabacloud-go/openapi-util v0.1.0/go.mod h1:sQuElr4ywwFRlCCberQwKRFhRzIyG4QTP/P4y1CJ6Ws= +github.com/alibabacloud-go/tea v1.1.0/go.mod h1:IkGyUSX4Ba1V+k4pCtJUc6jDpZLFph9QMy2VUPTwukg= +github.com/alibabacloud-go/tea v1.1.7/go.mod h1:/tmnEaQMyb4Ky1/5D+SE1BAsa5zj/KeGOFfwYm3N/p4= +github.com/alibabacloud-go/tea v1.1.8/go.mod h1:/tmnEaQMyb4Ky1/5D+SE1BAsa5zj/KeGOFfwYm3N/p4= +github.com/alibabacloud-go/tea v1.1.11/go.mod h1:/tmnEaQMyb4Ky1/5D+SE1BAsa5zj/KeGOFfwYm3N/p4= +github.com/alibabacloud-go/tea v1.1.17/go.mod h1:nXxjm6CIFkBhwW4FQkNrolwbfon8Svy6cujmKFUq98A= +github.com/alibabacloud-go/tea v1.1.20/go.mod h1:nXxjm6CIFkBhwW4FQkNrolwbfon8Svy6cujmKFUq98A= +github.com/alibabacloud-go/tea v1.2.2/go.mod h1:CF3vOzEMAG+bR4WOql8gc2G9H3EkH3ZLAQdpmpXMgwk= +github.com/alibabacloud-go/tea v1.3.12/go.mod h1:A560v/JTQ1n5zklt2BEpurJzZTI8TUT+Psg2drWlxRg= +github.com/alibabacloud-go/tea v1.3.13 h1:WhGy6LIXaMbBM6VBYcsDCz6K/TPsT1Ri2hPmmZffZ94= +github.com/alibabacloud-go/tea v1.3.13/go.mod h1:A560v/JTQ1n5zklt2BEpurJzZTI8TUT+Psg2drWlxRg= +github.com/alibabacloud-go/tea-utils v1.3.1 h1:iWQeRzRheqCMuiF3+XkfybB3kTgUXkXX+JMrqfLeB2I= +github.com/alibabacloud-go/tea-utils v1.3.1/go.mod h1:EI/o33aBfj3hETm4RLiAxF/ThQdSngxrpF8rKUDJjPE= +github.com/alibabacloud-go/tea-utils/v2 v2.0.5/go.mod h1:dL6vbUT35E4F4bFTHL845eUloqaerYBYPsdWR2/jhe4= +github.com/alibabacloud-go/tea-utils/v2 v2.0.7 h1:WDx5qW3Xa5ZgJ1c8NfqJkF6w+AU5wB8835UdhPr6Ax0= +github.com/alibabacloud-go/tea-utils/v2 v2.0.7/go.mod h1:qxn986l+q33J5VkialKMqT/TTs3E+U9MJpd001iWQ9I= +github.com/aliyun/alibaba-cloud-sdk-go v1.63.107 h1:qagvUyrgOnBIlVRQWOyCZGVKUIYbMBdGdJ104vBpRFU= +github.com/aliyun/alibaba-cloud-sdk-go v1.63.107/go.mod h1:SOSDHfe1kX91v3W5QiBsWSLqeLxImobbMX1mxrFHsVQ= +github.com/aliyun/credentials-go v1.1.2/go.mod h1:ozcZaMR5kLM7pwtCMEpVmQ242suV6qTJya2bDq4X1Tw= +github.com/aliyun/credentials-go v1.3.1/go.mod h1:8jKYhQuDawt8x2+fusqa1Y6mPxemTsBEN04dgcAcYz0= +github.com/aliyun/credentials-go v1.3.6/go.mod h1:1LxUuX7L5YrZUWzBrRyk0SwSdH4OmPrib8NVePL3fxM= +github.com/aliyun/credentials-go v1.4.5 h1:O76WYKgdy1oQYYiJkERjlA2dxGuvLRrzuO2ScrtGWSk= +github.com/aliyun/credentials-go v1.4.5/go.mod h1:Jm6d+xIgwJVLVWT561vy67ZRP4lPTQxMbEYRuT2Ti1U= +github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= +github.com/clbanning/mxj/v2 v2.7.0 h1:WA/La7UGCanFe5NpHF0Q3DNtnCsVoxbPKuyBNHWRyME= +github.com/clbanning/mxj/v2 v2.7.0/go.mod h1:hNiWqW14h+kc+MdF9C6/YoRfjEJoR3ou6tn/Qo+ve2s= +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/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= 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/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= +github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= +github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= github.com/fogleman/gg v1.2.1-0.20190220221249-0403632d5b90/go.mod h1:R/bRT+9gY/C5z7JzPU0zXsXHKM4/ayA+zqcVNZzPa1k= github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU= github.com/goji/httpauth v0.0.0-20160601135302-2da839ab0f4d/go.mod h1:nnjvkQ9ptGaCkuDUx6wNykzzlUixGxvkme+H/lnzb+A= github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= +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.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.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= +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.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +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/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= +github.com/gopherjs/gopherjs v0.0.0-20200217142428-fce0ec30dd00/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= github.com/jmespath/go-jmespath v0.4.0 h1:BEgLn5cpjn8UN1mAw4NjwDrS35OdebyEtFe+9YPoQUg= github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo= github.com/jmespath/go-jmespath/internal/testify v1.5.1 h1:shLQSRRSCCPj3f2gpwzGwWFoC7ycTf1rcQZHOlsJ6N8= github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U= github.com/joho/godotenv v1.5.1 h1:7eLL/+HRGLY0ldzfGMeQkb7vMd0as4CfYvUVzLqw0N0= github.com/joho/godotenv v1.5.1/go.mod h1:f4LDr5Voq0i2e/R5DDNOoa2zzDfwtkZa6DnEwAbqwq4= +github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= 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/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU= github.com/jung-kurt/gofpdf v1.0.3-0.20190309125859-24315acbbda5/go.mod h1:7Id9E/uU8ce6rXgefFLlgrJj/GYY22cpxn+r32jIOes= github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= @@ -29,6 +107,8 @@ github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= 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/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= @@ -38,52 +118,186 @@ github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= 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/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= +github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc= +github.com/smartystreets/assertions v1.1.0/go.mod h1:tcbTF8ujkAEcZ8TElKY+i30BzYlVhC/LOxJk7iOWnoo= +github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= +github.com/stretchr/objx v0.2.0/go.mod h1:qt09Ya8vawLte6SNmTgCsAVtYtaKzEcn8ATUoHMkEqE= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= +github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA= github.com/stretchr/testify v1.7.0 h1:nwc3DEeHmmLAfoZucVR881uASk0Mfjw8xYJ99tb5CcY= github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/tjfoc/gmsm v1.3.2/go.mod h1:HaUcFuY0auTiaHB9MHFGCPx5IaLhTUd2atbCFBQXn9w= +github.com/tjfoc/gmsm v1.4.1 h1:aMe1GlZb+0bLjn+cKTPEvvn9oUEBlJitaZiiBwsbgho= +github.com/tjfoc/gmsm v1.4.1/go.mod h1:j4INPkHWMrhJb38G+J6W4Tw0AbuN8Thu3PbdVYhVcTE= github.com/uber/jaeger-client-go v2.30.0+incompatible h1:D6wyKGCecFaSRUpo8lCVbaOOb6ThwMmTEbhRwtKR97o= github.com/uber/jaeger-client-go v2.30.0+incompatible/go.mod h1:WVhlPFC8FDjOFMMWRy2pZqQJSXxYSwNYOkTr/Z6d3Kk= github.com/uber/jaeger-lib v2.4.1+incompatible h1:td4jdvLcExb4cBISKIpHuGoVXh+dVKhn2Um6rjCsSsg= github.com/uber/jaeger-lib v2.4.1+incompatible/go.mod h1:ComeNDZlWwrWnDv8aPp0Ba6+uUTzImX/AauajbLI56U= +github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.1.30/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= go.uber.org/atomic v1.9.0 h1:ECmE8Bn/WFTYwEW/bpKD3M8VtR/zQVbavAoalC1PYyE= go.uber.org/atomic v1.9.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20191219195013-becbf705a915/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20200510223506-06a226fb4e37/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20201012173705-84dcc777aaee/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= +golang.org/x/crypto v0.13.0/go.mod h1:y6Z2r+Rw4iayiXXAIxJIDAJ1zMW4yaTpebo8fPOliYc= +golang.org/x/crypto v0.14.0/go.mod h1:MVFd36DqK4CsrnJYDkBA3VC4m2GkXAM0PvzMCn4JQf4= +golang.org/x/crypto v0.18.0/go.mod h1:R0j02AL6hcrfOiy9T4ZYp/rcWeMxM3L6QYxlOuEG1mg= +golang.org/x/crypto v0.19.0/go.mod h1:Iy9bg/ha4yyC70EfRS8jz+B6ybOBKMaSxLj6P6oBDfU= +golang.org/x/crypto v0.21.0/go.mod h1:0BP7YvVV9gBbVKyeTG0Gyn+gZm94bibOW5BjDEYAOMs= +golang.org/x/crypto v0.23.0/go.mod h1:CKFgDieR+mRhux2Lsu27y0fO304Db0wZe70UKqHu0v8= +golang.org/x/crypto v0.24.0/go.mod h1:Z1PMYSOR5nyMcyAVAIQSKCDwalqy85Aqn1x3Ws4L5DM= golang.org/x/exp v0.0.0-20180321215751-8460e604b9de/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20180807140117-3d87b88a115f/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= +golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190125153040-c74c464bbbf2/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20191030013958-a1ab85dbe136/go.mod h1:JXzH8nQsPlswgeRAPE3MuO9GYsAcnJvJ4vnMwN/5qkY= golang.org/x/image v0.0.0-20180708004352-c73c2afc3b81/go.mod h1:ux5Hcp/YLpHSI86hEcLt0YII63i6oz57MZXIpbrjZUs= golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js= golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= +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/mobile v0.0.0-20190719004257-d2bd2a29d028/go.mod h1:E/iHnbuqvinMTCcRqshq8CkpyQDoeVncDDYHnLhea+o= golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY= +golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= +golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.12.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.15.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/mod v0.17.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-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-20190620200207-3b0461eec859/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-20200506145744-7e3656a0809f/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20201010224723-4f7140c49acb/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-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= +golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= +golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= +golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= +golang.org/x/net v0.15.0/go.mod h1:idbUs1IY1+zTqbi8yxTbhexhEEk5ur9LInksu6HrEpk= +golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= +golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY= +golang.org/x/net v0.21.0/go.mod h1:bIjVDfnllIU7BJ2DNgfnXvpSvtn8VRwhlsaeUTyUS44= +golang.org/x/net v0.23.0/go.mod h1:JKghWKKOSdJwpW2GEx0Ja7fmaKnMsbu+MWVZTokSYmg= +golang.org/x/net v0.25.0/go.mod h1:JkAGAh7GEvH74S6FOH42FLoXpXbE/aqXSrIQjXgsiwM= +golang.org/x/net v0.26.0 h1:soB7SVo0PWrY4vPW/+ay0jKDNScG2X9wFeYlXIvJsOQ= +golang.org/x/net v0.26.0/go.mod h1:5YKkiSynbBIh3p6iOc/vibscux0x38BZDkn8sCUPxHE= +golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= +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-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-20200317015054-43a5402ce75a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.3.0/go.mod h1:FU7BRWz2tNW+3quACPkgCx/L+uEAv1htQ0V83Z9Rj+Y= +golang.org/x/sync v0.6.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= +golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= +golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/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-20190312061237-fead79001313/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200509044756-6aff5f38e54f/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-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.17.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.20.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.21.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/telemetry v0.0.0-20240228155512-f48c80bd79b2/go.mod h1:TeRTkGYfJXctD9OcfyVLyj2J3IxLnKwHJR8f4D8a3YE= +golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= +golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= +golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= +golang.org/x/term v0.8.0/go.mod h1:xPskH00ivmX89bAKVGSKKtLOWNx2+17Eiy94tnKShWo= +golang.org/x/term v0.12.0/go.mod h1:owVbMEjm3cBLCHdkQu9b1opXd4ETQWc3BhuQGKgXgvU= +golang.org/x/term v0.13.0/go.mod h1:LTmsnFJwVN6bCy1rVCoS+qHT1HhALEFxKncY3WNNh4U= +golang.org/x/term v0.16.0/go.mod h1:yn7UURbUtPyrVJPGPq404EukNFxcm/foM+bV/bfcDsY= +golang.org/x/term v0.17.0/go.mod h1:lLRBjIVuehSbZlaOtGMbcMncT+aqLLLmKrsjNrUguwk= +golang.org/x/term v0.18.0/go.mod h1:ILwASektA3OnRv7amZ1xhE/KTR+u50pbXfZ03+6Nx58= +golang.org/x/term v0.20.0/go.mod h1:8UkIAJTvZgivsXaD6/pH6U9ecQzZ45awqEOzuCvwpFY= +golang.org/x/term v0.21.0/go.mod h1:ooXLefLobQVslOqselCNF4SxFAaoS6KujMbsGzSDmX0= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +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.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= +golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= +golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= +golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= +golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= +golang.org/x/text v0.15.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= +golang.org/x/text v0.16.0/go.mod h1:GhwF1Be+LQoKShO3cGOHzqOgRrGaYc9AvblQOmPVHnI= golang.org/x/tools v0.0.0-20180525024113-a5b4c53f6e8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +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-20190206041539-40960b6deb8e/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-20190328211700-ab21143f2384/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= +golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= golang.org/x/tools v0.0.0-20191012152004-8de300cfc20a/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-20200509030707-2212a7e161a5/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= +golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= +golang.org/x/tools v0.13.0/go.mod h1:HvlwmtVNQAhOuCjW7xxvovg8wbNq7LwfXh/k7wXUl58= +golang.org/x/tools v0.21.1-0.20240508182429-e35e4ccd0d2d/go.mod h1:aiJjzUbINMkxbQROHiO6hDPo2LHcIPhhQsa9DLh0yGk= 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= gonum.org/v1/gonum v0.0.0-20180816165407-929014505bf4/go.mod h1:Y+Yx5eoAFn32cQvJDxZx5Dpnq+c3wtXuadVZAcxbbBo= gonum.org/v1/gonum v0.8.2/go.mod h1:oe/vMfY3deqTw+1EZJhuvEW2iwGF1bW9wwu7XCu0+v0= gonum.org/v1/netlib v0.0.0-20190313105609-8cb42192e0e0/go.mod h1:wa6Ws7BG/ESfp6dHfk7C6KdzKA7wR7u/rKwOGE66zvw= gonum.org/v1/plot v0.0.0-20190515093506-e2840ee46a6b/go.mod h1:Wt8AAjI+ypCyYX3nZBvf6cAIx93T+c/OS2HFAYskSZc= +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-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= +google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= +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.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +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.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/ini.v1 v1.56.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= gopkg.in/ini.v1 v1.67.0 h1:Dgnx+6+nfE+IfzjUEISNeydPJh9AXNNsWbGP9KzCsOA= gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= +gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.8 h1:obN1ZagJSUGI0Ek/LBmuj4SNLPfIny3KsKFopxRdj10= gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.0 h1:hjy8E9ON/egN1tAYqKb61G10WtihqetD4sz2H+8nIeA= gopkg.in/yaml.v3 v3.0.0/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= rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= diff --git a/internal/api/image_scanner.go b/internal/api/image_scanner.go index 060cd14..e6a4c5e 100644 --- a/internal/api/image_scanner.go +++ b/internal/api/image_scanner.go @@ -1,7 +1,6 @@ package api import ( - "encoding/json" "fmt" "io" "os" @@ -11,13 +10,15 @@ import ( "contentSecurityDemo/conf" "contentSecurityDemo/internal/model" - "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests" - "github.com/aliyun/alibaba-cloud-sdk-go/services/green" + openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client" + green20220302 "github.com/alibabacloud-go/green-20220302/v2/client" + util "github.com/alibabacloud-go/tea-utils/v2/service" + "github.com/alibabacloud-go/tea/tea" ) // ImageScanner 图片内容安全扫描器2.0 type ImageScanner struct { - Client *green.Client + Client *green20220302.Client Config *conf.Config } @@ -27,7 +28,7 @@ type ImageServiceType string const ( // BaselineCheckGlobal 通用基线检测 BaselineCheckGlobal ImageServiceType = "baselineCheck_global" - // PostImageCheckByVLGlobal 大小模型融合图片审核服务 + // PostImageCheckByVLGlobal 大小模型融合图片审核服务(专业版) PostImageCheckByVLGlobal ImageServiceType = "postImageCheckByVL_global" // AigcDetectorGlobal AI生成图片鉴别 AigcDetectorGlobal ImageServiceType = "aigcDetector_global" @@ -38,17 +39,17 @@ func NewImageScanner(config *conf.Config) (*ImageScanner, error) { // 获取有效的访问凭证 accessKeyID, accessKeySecret, securityToken := config.GetEffectiveCredentials() - var client *green.Client - var err error - - if securityToken != "" { - // 使用STS临时凭证 - client, err = green.NewClientWithStsToken(config.Region, accessKeyID, accessKeySecret, securityToken) - } else { - // 使用直接凭证 - client, err = green.NewClientWithAccessKey(config.Region, accessKeyID, accessKeySecret) + // 创建配置 + clientConfig := &openapi.Config{ + AccessKeyId: tea.String(accessKeyID), + AccessKeySecret: tea.String(accessKeySecret), + SecurityToken: tea.String(securityToken), + RegionId: tea.String(config.Region), + Endpoint: tea.String(config.Endpoint), } + // 创建客户端 + client, err := green20220302.NewClient(clientConfig) if err != nil { return nil, fmt.Errorf("创建客户端失败: %v", err) } @@ -59,47 +60,52 @@ func NewImageScanner(config *conf.Config) (*ImageScanner, error) { }, nil } -// ScanImageByURL 通过URL扫描图片(2.0版本) +// ScanImageByURL 通过URL扫描图片 func (s *ImageScanner) ScanImageByURL(imageURL string, dataID string, serviceType ImageServiceType) (*model.ImageScanResponse, error) { - request := requests.NewCommonRequest() - request.Method = "POST" - request.Scheme = "https" - request.Domain = s.Config.Endpoint - request.Version = "2022-03-02" // 内容安全2.0图片审核API版本 - request.ApiName = "ImageSyncScan" - request.QueryParams["RegionId"] = s.Config.Region + // 创建运行时配置 + runtime := &util.RuntimeOptions{} + runtime.ReadTimeout = tea.Int(10000) + runtime.ConnectTimeout = tea.Int(10000) - scanRequest := model.ImageScanRequest{ - Tasks: []model.ImageTask{ - { - DataID: dataID, - URL: imageURL, - }, - }, - Services: []string{string(serviceType)}, // 使用服务类型而不是场景 + // 构建请求参数 + imageScanRequest := &green20220302.ImageModerationRequest{ + Service: tea.String(string(serviceType)), + ServiceParameters: tea.String(fmt.Sprintf(`{"imageUrl":"%s","dataId":"%s"}`, imageURL, dataID)), } - requestBody, err := json.Marshal(scanRequest) - if err != nil { - return nil, fmt.Errorf("序列化请求失败: %v", err) - } - - request.Content = requestBody - - response, err := s.Client.ProcessCommonRequest(request) + // 调用API + response, err := s.Client.ImageModerationWithOptions(imageScanRequest, runtime) if err != nil { return nil, fmt.Errorf("请求失败: %v", err) } - var scanResponse model.ImageScanResponse - if err := json.Unmarshal(response.GetHttpContentBytes(), &scanResponse); err != nil { - return nil, fmt.Errorf("解析响应失败: %v", err) + // 转换响应格式 + scanResponse := &model.ImageScanResponse{ + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Msg), + Data: make([]model.ImageScanData, 0), } - return &scanResponse, nil + // 创建单个数据项 + scanData := model.ImageScanData{ + DataID: *response.Body.Data.DataId, + Code: tea.Int32Value(response.Body.Code), + Message: "success", + Results: make([]*green20220302.ImageModerationResponseBodyDataResult, 0), + } + + // 如果有结果数据,进行转换 + if response.Body.Data != nil { + data := response.Body.Data + scanData.Results = append(scanData.Results, data.Result...) + } + + scanResponse.Data = append(scanResponse.Data, scanData) + + return scanResponse, nil } -// ScanImageByFile 通过文件扫描图片(2.0版本) +// ScanImageByFile 通过文件扫描图片 func (s *ImageScanner) ScanImageByFile(filePath string, dataID string, serviceType ImageServiceType) (*model.ImageScanResponse, error) { // 读取文件 file, err := os.Open(filePath) @@ -143,47 +149,54 @@ func (s *ImageScanner) ScanImageByFile(filePath string, dataID string, serviceTy base64Content := fmt.Sprintf("data:image/%s;base64,%s", ext[1:], strings.ReplaceAll(string(fileContent), "\n", "")) - request := requests.NewCommonRequest() - request.Method = "POST" - request.Scheme = "https" - request.Domain = s.Config.Endpoint - request.Version = "2022-03-02" // 内容安全2.0图片审核API版本 - request.ApiName = "ImageSyncScan" - request.QueryParams["RegionId"] = s.Config.Region + // 创建运行时配置 + runtime := &util.RuntimeOptions{} + runtime.ReadTimeout = tea.Int(10000) + runtime.ConnectTimeout = tea.Int(10000) - scanRequest := model.ImageScanRequest{ - Tasks: []model.ImageTask{ - { - DataID: dataID, - Content: base64Content, - }, - }, - Services: []string{string(serviceType)}, // 使用服务类型而不是场景 + // 构建请求参数 + imageScanRequest := &green20220302.ImageModerationRequest{ + Service: tea.String(string(serviceType)), + ServiceParameters: tea.String(fmt.Sprintf(`{"content":"%s"}`, base64Content)), } - requestBody, err := json.Marshal(scanRequest) - if err != nil { - return nil, fmt.Errorf("序列化请求失败: %v", err) - } - - request.Content = requestBody - - response, err := s.Client.ProcessCommonRequest(request) + // 调用API + response, err := s.Client.ImageModerationWithOptions(imageScanRequest, runtime) if err != nil { return nil, fmt.Errorf("请求失败: %v", err) } - var scanResponse model.ImageScanResponse - if err := json.Unmarshal(response.GetHttpContentBytes(), &scanResponse); err != nil { - return nil, fmt.Errorf("解析响应失败: %v", err) + // 转换响应格式 + scanResponse := &model.ImageScanResponse{ + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Msg), + Data: make([]model.ImageScanData, 0), } - return &scanResponse, nil + // 创建单个数据项 + scanData := model.ImageScanData{ + DataID: dataID, + Code: tea.Int32Value(response.Body.Code), + Message: "success", + Results: make([]*green20220302.ImageModerationResponseBodyDataResult, 0), + } + + // 如果有结果数据,进行转换 + if response.Body.Data != nil { + // 这里需要根据实际的响应结构进行调整 + // 暂时创建一个基本的结果结构 + data := response.Body.Data + scanData.Results = append(scanData.Results, data.Result...) + } + + scanResponse.Data = append(scanResponse.Data, scanData) + + return scanResponse, nil } -// PrintResult 打印扫描结果(2.0版本) +// PrintResult 打印扫描结果 func (s *ImageScanner) PrintResult(response *model.ImageScanResponse) { - fmt.Println("=== 图片内容安全审核结果(2.0版本)===") + fmt.Println("=== 图片内容安全审核结果===") fmt.Printf("状态码: %d\n", response.Code) fmt.Printf("消息: %s\n", response.Message) @@ -191,37 +204,18 @@ func (s *ImageScanner) PrintResult(response *model.ImageScanResponse) { fmt.Printf("\n数据ID: %s\n", data.DataID) fmt.Printf("处理状态: %d - %s\n", data.Code, data.Message) - if len(data.Results) == 0 { - fmt.Println("✅ 未检测到违规内容") - continue - } - for _, result := range data.Results { - fmt.Printf("场景: %s\n", result.Scene) - fmt.Printf("标签: %s\n", result.Label) - if result.SubLabel != "" { - fmt.Printf("子标签: %s\n", result.SubLabel) + if result.Confidence != nil { + fmt.Printf("置信度: %f\n", *result.Confidence) } - fmt.Printf("建议: %s\n", result.Suggestion) - fmt.Printf("置信度: %.2f\n", result.Rate) - - // 打印详细信息 - if len(result.Details) > 0 { - fmt.Println("详细信息:") - for _, detail := range result.Details { - fmt.Printf(" 内容: %s\n", detail.Context.Context) - if len(detail.Context.Pos) > 0 { - fmt.Printf(" 位置: %v\n", detail.Context.Pos) - } - } + if result.Description != nil { + fmt.Printf("描述: %s\n", *result.Description) } - - // 打印扩展信息 - if len(result.Extras) > 0 { - fmt.Println("扩展信息:") - for key, value := range result.Extras { - fmt.Printf(" %s: %v\n", key, value) - } + if result.Label != nil { + fmt.Printf("标签: %s\n", *result.Label) + } + if result.RiskLevel != nil { + fmt.Printf("风险等级: %s\n", *result.RiskLevel) } fmt.Println("---") } diff --git a/internal/api/text_scanner.go b/internal/api/text_scanner.go index 86ff5c4..e52e131 100644 --- a/internal/api/text_scanner.go +++ b/internal/api/text_scanner.go @@ -7,13 +7,15 @@ import ( "contentSecurityDemo/conf" "contentSecurityDemo/internal/model" - "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests" - "github.com/aliyun/alibaba-cloud-sdk-go/services/green" + openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client" + green20220302 "github.com/alibabacloud-go/green-20220302/v2/client" + util "github.com/alibabacloud-go/tea-utils/v2/service" + "github.com/alibabacloud-go/tea/tea" ) // TextScanner 文本内容安全扫描器2.0 type TextScanner struct { - Client *green.Client + Client *green20220302.Client Config *conf.Config } @@ -21,10 +23,8 @@ type TextScanner struct { type TextServiceType string const ( - // TextBaselineCheckGlobal 文本通用基线检测 - TextBaselineCheckGlobal TextServiceType = "baselineCheck_global" - // TextPostCheckByVLGlobal 文本大小模型融合审核服务 - TextPostCheckByVLGlobal TextServiceType = "postTextCheckByVL_global" + // TextBaselineCheckGlobal 文国际业务多语言检测 + TextBaselineCheckGlobal TextServiceType = "comment_multilingual_pro_global" ) // NewTextScanner 创建文本扫描器 @@ -32,17 +32,17 @@ func NewTextScanner(config *conf.Config) (*TextScanner, error) { // 获取有效的访问凭证 accessKeyID, accessKeySecret, securityToken := config.GetEffectiveCredentials() - var client *green.Client - var err error - - if securityToken != "" { - // 使用STS临时凭证 - client, err = green.NewClientWithStsToken(config.Region, accessKeyID, accessKeySecret, securityToken) - } else { - // 使用直接凭证 - client, err = green.NewClientWithAccessKey(config.Region, accessKeyID, accessKeySecret) + // 创建配置 + clientConfig := &openapi.Config{ + AccessKeyId: tea.String(accessKeyID), + AccessKeySecret: tea.String(accessKeySecret), + SecurityToken: tea.String(securityToken), + RegionId: tea.String(config.Region), + Endpoint: tea.String(config.Endpoint), } + // 创建客户端 + client, err := green20220302.NewClient(clientConfig) if err != nil { return nil, fmt.Errorf("创建客户端失败: %v", err) } @@ -53,134 +53,143 @@ func NewTextScanner(config *conf.Config) (*TextScanner, error) { }, nil } -// ScanText 扫描文本内容(2.0版本) +// ScanText 扫描文本内容 func (s *TextScanner) ScanText(content string, dataID string, serviceType TextServiceType) (*model.TextScanResponse, error) { - request := requests.NewCommonRequest() - request.Method = "POST" - request.Scheme = "https" - request.Domain = s.Config.Endpoint - request.Version = "2022-03-02" // 内容安全2.0文本审核API版本 - request.ApiName = "TextScan" - request.QueryParams["RegionId"] = s.Config.Region + // 创建运行时配置 + runtime := &util.RuntimeOptions{} + runtime.ReadTimeout = tea.Int(10000) + runtime.ConnectTimeout = tea.Int(10000) - scanRequest := model.TextScanRequest{ - Tasks: []model.TextTask{ - { - DataID: dataID, - Content: content, - }, + serviceParameters, _ := json.Marshal( + map[string]interface{}{ + "content": content, }, - Services: []string{string(serviceType)}, // 使用服务类型而不是场景 + ) + // 构建请求参数 + textScanRequest := &green20220302.TextModerationPlusRequest{ + Service: tea.String(string(serviceType)), + ServiceParameters: tea.String(string(serviceParameters)), } - requestBody, err := json.Marshal(scanRequest) - if err != nil { - return nil, fmt.Errorf("序列化请求失败: %v", err) - } - - request.Content = requestBody - - response, err := s.Client.ProcessCommonRequest(request) + // 调用API + response, err := s.Client.TextModerationPlusWithOptions(textScanRequest, runtime) if err != nil { return nil, fmt.Errorf("请求失败: %v", err) } - var scanResponse model.TextScanResponse - if err := json.Unmarshal(response.GetHttpContentBytes(), &scanResponse); err != nil { - return nil, fmt.Errorf("解析响应失败: %v", err) + // 转换响应格式 + scanResponse := &model.TextScanResponse{ + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + Data: make([]model.TextScanData, 0), } - return &scanResponse, nil + // 创建单个数据项 + scanData := model.TextScanData{ + DataID: dataID, + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + DetectedLanguage: tea.StringValue(response.Body.Data.DetectedLanguage), + TranslatedContent: tea.StringValue(response.Body.Data.TranslatedContent), + Results: make([]*green20220302.TextModerationPlusResponseBodyDataResult, 0, len(response.Body.Data.Result)), + } + + // 如果有结果数据,进行转换 + if response.Body.Data != nil { + // 暂时创建一个基本的结果结构 + data := response.Body.Data + scanData.Results = append(scanData.Results, data.Result...) + } + + scanResponse.Data = append(scanResponse.Data, scanData) + + return scanResponse, nil } -// ScanTextBatch 批量扫描文本内容(2.0版本) +// ScanTextBatch 批量扫描文本内容 func (s *TextScanner) ScanTextBatch(texts []string, dataIDs []string, serviceType TextServiceType) (*model.TextScanResponse, error) { - if len(texts) != len(dataIDs) { - return nil, fmt.Errorf("文本数量和ID数量不匹配") - } - request := requests.NewCommonRequest() - request.Method = "POST" - request.Scheme = "https" - request.Domain = s.Config.Endpoint - request.Version = "2022-03-02" // 内容安全2.0文本审核API版本 - request.ApiName = "TextScan" - request.QueryParams["RegionId"] = s.Config.Region + // 创建运行时配置 + runtime := &util.RuntimeOptions{} + runtime.ReadTimeout = tea.Int(10000) + runtime.ConnectTimeout = tea.Int(10000) - var tasks []model.TextTask + // 构建请求参数 - 将多个文本合并为一个请求 + combinedText := "" for i, text := range texts { - tasks = append(tasks, model.TextTask{ - DataID: dataIDs[i], - Content: text, - }) + if i > 0 { + combinedText += "\n" + } + combinedText += text } - scanRequest := model.TextScanRequest{ - Tasks: tasks, - Services: []string{string(serviceType)}, // 使用服务类型而不是场景 + serviceParameters, _ := json.Marshal( + map[string]interface{}{ + "content": combinedText, + }, + ) + // 构建请求参数 + textScanRequest := &green20220302.TextModerationPlusRequest{ + Service: tea.String(string(serviceType)), + ServiceParameters: tea.String(string(serviceParameters)), } - requestBody, err := json.Marshal(scanRequest) - if err != nil { - return nil, fmt.Errorf("序列化请求失败: %v", err) - } - - request.Content = requestBody - - response, err := s.Client.ProcessCommonRequest(request) + // 调用API + response, err := s.Client.TextModerationPlusWithOptions(textScanRequest, runtime) if err != nil { return nil, fmt.Errorf("请求失败: %v", err) } - var scanResponse model.TextScanResponse - if err := json.Unmarshal(response.GetHttpContentBytes(), &scanResponse); err != nil { - return nil, fmt.Errorf("解析响应失败: %v", err) + // 转换响应格式 + scanResponse := &model.TextScanResponse{ + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + Data: make([]model.TextScanData, 0), } - return &scanResponse, nil + scanData := model.TextScanData{ + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + DetectedLanguage: tea.StringValue(response.Body.Data.DetectedLanguage), + TranslatedContent: tea.StringValue(response.Body.Data.TranslatedContent), + Results: make([]*green20220302.TextModerationPlusResponseBodyDataResult, 0, len(response.Body.Data.Result)), + } + + // 如果有结果数据,进行转换 + if response.Body.Data != nil { + data := response.Body.Data + scanData.Results = append(scanData.Results, data.Result...) + } + + scanResponse.Data = append(scanResponse.Data, scanData) + + return scanResponse, nil } -// PrintResult 打印扫描结果(2.0版本) +// PrintResult 打印扫描结果 func (s *TextScanner) PrintResult(response *model.TextScanResponse) { - fmt.Println("=== 文本内容安全审核结果(2.0版本)===") + fmt.Println("=== 文本内容安全审核结果===") fmt.Printf("状态码: %d\n", response.Code) fmt.Printf("消息: %s\n", response.Message) for _, data := range response.Data { fmt.Printf("\n数据ID: %s\n", data.DataID) fmt.Printf("处理状态: %d - %s\n", data.Code, data.Message) - - if len(data.Results) == 0 { - fmt.Println("✅ 未检测到违规内容") - continue - } - + fmt.Printf("检测语言: %s\n", data.DetectedLanguage) + fmt.Printf("翻译内容: %s\n", data.TranslatedContent) for _, result := range data.Results { - fmt.Printf("场景: %s\n", result.Scene) - fmt.Printf("标签: %s\n", result.Label) - if result.SubLabel != "" { - fmt.Printf("子标签: %s\n", result.SubLabel) - } - fmt.Printf("建议: %s\n", result.Suggestion) - fmt.Printf("置信度: %.2f\n", result.Rate) - // 打印详细信息 - if len(result.Details) > 0 { - fmt.Println("违规详情:") - for _, detail := range result.Details { - fmt.Printf(" 内容: %s\n", detail.Context.Context) - if len(detail.Context.Pos) > 0 { - fmt.Printf(" 位置: %v\n", detail.Context.Pos) - } - } + if result.Confidence != nil { + fmt.Printf("置信度: %f\n", *result.Confidence) } - - // 打印扩展信息 - if len(result.Extras) > 0 { - fmt.Println("扩展信息:") - for key, value := range result.Extras { - fmt.Printf(" %s: %v\n", key, value) - } + if result.Description != nil { + fmt.Printf("描述: %s\n", *result.Description) + } + if result.Label != nil { + fmt.Printf("标签: %s\n", *result.Label) + } + if result.RiskWords != nil { + fmt.Printf("风险等级: %s\n", *result.RiskWords) } fmt.Println("---") } diff --git a/internal/api/video_scanner.go b/internal/api/video_scanner.go index 385535b..bc6f1cd 100644 --- a/internal/api/video_scanner.go +++ b/internal/api/video_scanner.go @@ -1,20 +1,21 @@ package api import ( - "encoding/json" "fmt" "time" "contentSecurityDemo/conf" "contentSecurityDemo/internal/model" - "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests" - "github.com/aliyun/alibaba-cloud-sdk-go/services/green" + openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client" + green20220302 "github.com/alibabacloud-go/green-20220302/v2/client" + util "github.com/alibabacloud-go/tea-utils/v2/service" + "github.com/alibabacloud-go/tea/tea" ) // VideoScanner 视频内容安全扫描器2.0 type VideoScanner struct { - Client *green.Client + Client *green20220302.Client Config *conf.Config } @@ -22,10 +23,10 @@ type VideoScanner struct { type VideoServiceType string const ( - // VideoBaselineCheckGlobal 视频通用基线检测 - VideoBaselineCheckGlobal VideoServiceType = "baselineCheck_global" - // VideoPostCheckByVLGlobal 视频大小模型融合审核服务 - VideoPostCheckByVLGlobal VideoServiceType = "postVideoCheckByVL_global" + // VideoBaselineCheckGlobal 视频文件检测 + VideoBaselineCheckGlobal VideoServiceType = "videoDetection_global" + // VideoPostCheckByVLGlobal 视频文件检测_大模型版 + VideoPostCheckByVLGlobal VideoServiceType = "videoDetectionByVL_global" ) // NewVideoScanner 创建视频扫描器 @@ -33,17 +34,17 @@ func NewVideoScanner(config *conf.Config) (*VideoScanner, error) { // 获取有效的访问凭证 accessKeyID, accessKeySecret, securityToken := config.GetEffectiveCredentials() - var client *green.Client - var err error - - if securityToken != "" { - // 使用STS临时凭证 - client, err = green.NewClientWithStsToken(config.Region, accessKeyID, accessKeySecret, securityToken) - } else { - // 使用直接凭证 - client, err = green.NewClientWithAccessKey(config.Region, accessKeyID, accessKeySecret) + // 创建配置 + clientConfig := &openapi.Config{ + AccessKeyId: tea.String(accessKeyID), + AccessKeySecret: tea.String(accessKeySecret), + SecurityToken: tea.String(securityToken), + RegionId: tea.String(config.Region), + Endpoint: tea.String(config.Endpoint), } + // 创建客户端 + client, err := green20220302.NewClient(clientConfig) if err != nil { return nil, fmt.Errorf("创建客户端失败: %v", err) } @@ -54,75 +55,92 @@ func NewVideoScanner(config *conf.Config) (*VideoScanner, error) { }, nil } -// ScanVideoAsync 异步扫描视频(2.0版本) +// ScanVideoAsync 异步扫描视频 func (s *VideoScanner) ScanVideoAsync(videoURL string, dataID string, serviceType VideoServiceType) (*model.VideoScanResponse, error) { - request := requests.NewCommonRequest() - request.Method = "POST" - request.Scheme = "https" - request.Domain = s.Config.Endpoint - request.Version = "2022-03-02" // 内容安全2.0视频审核API版本 - request.ApiName = "VideoAsyncScan" - request.QueryParams["RegionId"] = s.Config.Region + // 创建运行时配置 + runtime := &util.RuntimeOptions{} + runtime.ReadTimeout = tea.Int(10000) + runtime.ConnectTimeout = tea.Int(10000) - scanRequest := model.VideoScanRequest{ - Tasks: []model.VideoTask{ - { - DataID: dataID, - URL: videoURL, - Interval: 1, // 每秒截取一帧 - MaxFrames: 100, // 最多截取100帧 - }, - }, - Services: []string{string(serviceType)}, // 使用服务类型而不是场景 + // 构建请求参数 + videoScanRequest := &green20220302.VideoModerationRequest{ + Service: tea.String(string(serviceType)), + ServiceParameters: tea.String(fmt.Sprintf(`{"url":"%s","dataId":"%s"}`, videoURL, dataID)), } - requestBody, err := json.Marshal(scanRequest) - if err != nil { - return nil, fmt.Errorf("序列化请求失败: %v", err) - } - - request.Content = requestBody - - response, err := s.Client.ProcessCommonRequest(request) + // 调用API + response, err := s.Client.VideoModerationWithOptions(videoScanRequest, runtime) if err != nil { return nil, fmt.Errorf("请求失败: %v", err) } - var scanResponse model.VideoScanResponse - if err := json.Unmarshal(response.GetHttpContentBytes(), &scanResponse); err != nil { - return nil, fmt.Errorf("解析响应失败: %v", err) + // 转换响应格式 + scanResponse := &model.VideoScanResponse{ + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + Data: make([]model.VideoScanData, 0), } - return &scanResponse, nil + // 创建单个数据项 + scanData := model.VideoScanData{ + DataID: dataID, + TaskID: fmt.Sprintf("task_%s_%d", dataID, time.Now().Unix()), + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + URL: videoURL, + } + + scanResponse.Data = append(scanResponse.Data, scanData) + + return scanResponse, nil } -// GetVideoResult 获取视频审核结果(2.0版本) +// GetVideoResult 获取视频审核结果 func (s *VideoScanner) GetVideoResult(taskID string) (*model.VideoResultResponse, error) { - request := requests.NewCommonRequest() - request.Method = "POST" - request.Scheme = "https" - request.Domain = s.Config.Endpoint - request.Version = "2022-03-02" // 内容安全2.0视频审核API版本 - request.ApiName = "VideoAsyncScanResults" - request.QueryParams["RegionId"] = s.Config.Region + // 创建运行时配置 + runtime := &util.RuntimeOptions{} + runtime.ReadTimeout = tea.Int(10000) + runtime.ConnectTimeout = tea.Int(10000) - requestBody := fmt.Sprintf(`{"taskId": "%s"}`, taskID) - request.Content = []byte(requestBody) + // 构建请求参数 + videoResultRequest := &green20220302.VideoModerationResultRequest{ + Service: tea.String("videoDetection"), + ServiceParameters: tea.String(fmt.Sprintf(`{"taskId":"%s"}`, taskID)), + } - response, err := s.Client.ProcessCommonRequest(request) + // 调用API + response, err := s.Client.VideoModerationResultWithOptions(videoResultRequest, runtime) if err != nil { return nil, fmt.Errorf("请求失败: %v", err) } - var resultResponse model.VideoResultResponse - if err := json.Unmarshal(response.GetHttpContentBytes(), &resultResponse); err != nil { - return nil, fmt.Errorf("解析响应失败: %v", err) + // 转换响应格式 + resultResponse := &model.VideoResultResponse{ + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + Data: make([]model.VideoResultData, 0), } - return &resultResponse, nil + // 创建单个数据项 + resultData := model.VideoResultData{ + DataID: tea.StringValue(response.Body.Data.DataId), + TaskID: tea.StringValue(response.Body.Data.TaskId), + Code: tea.Int32Value(response.Body.Code), + Message: tea.StringValue(response.Body.Message), + Status: "success", + } + + // 如果有结果数据,进行转换 + if response.Body.Data != nil { + resultData.Results = response.Body.Data + } + + resultResponse.Data = append(resultResponse.Data, resultData) + + return resultResponse, nil } -// ScanVideoAndWait 扫描视频并等待结果(2.0版本) +// ScanVideoAndWait 扫描视频并等待结果 func (s *VideoScanner) ScanVideoAndWait(videoURL string, dataID string, serviceType VideoServiceType, maxWaitTime time.Duration) (*model.VideoResultResponse, error) { // 提交扫描任务 scanResponse, err := s.ScanVideoAsync(videoURL, dataID, serviceType) @@ -182,9 +200,9 @@ func (s *VideoScanner) PrintScanResult(response *model.VideoScanResponse) { } } -// PrintResult 打印审核结果(2.0版本) +// PrintResult 打印审核结果 func (s *VideoScanner) PrintResult(response *model.VideoResultResponse) { - fmt.Println("=== 视频内容安全审核结果(2.0版本)===") + fmt.Println("=== 视频内容安全审核结果===") fmt.Printf("状态码: %d\n", response.Code) fmt.Printf("消息: %s\n", response.Message) @@ -194,55 +212,32 @@ func (s *VideoScanner) PrintResult(response *model.VideoResultResponse) { fmt.Printf("处理状态: %d - %s\n", data.Code, data.Message) fmt.Printf("审核状态: %s\n", data.Status) - if len(data.Results) == 0 { - fmt.Println("✅ 未检测到违规内容") - continue - } - - for _, result := range data.Results { - fmt.Printf("场景: %s\n", result.Scene) - fmt.Printf("标签: %s\n", result.Label) - if result.SubLabel != "" { - fmt.Printf("子标签: %s\n", result.SubLabel) + if data.Results != nil { + result := *data.Results + if result.LiveId != nil { + fmt.Printf("直播ID: %s\n", *result.LiveId) + } + if result.ManualTaskId != nil { + fmt.Printf("人工任务ID: %s\n", *result.ManualTaskId) + } + if result.RiskLevel != nil { + fmt.Printf("风险等级: %s\n", *result.RiskLevel) } - fmt.Printf("建议: %s\n", result.Suggestion) - fmt.Printf("置信度: %.2f\n", result.Rate) - // 打印详细信息 - if len(result.Details) > 0 { - fmt.Println("详细信息:") - for _, detail := range result.Details { - fmt.Printf(" 内容: %s\n", detail.Context.Context) - if len(detail.Context.Pos) > 0 { - fmt.Printf(" 位置: %v\n", detail.Context.Pos) - } + if result.AudioResult != nil { + fmt.Println("音频审核结果:") + audioResult := *result.AudioResult + if audioResult.RiskLevel != nil { + fmt.Printf("风险等级: %s\n", *audioResult.RiskLevel) } } // 打印扩展信息 - if len(result.Extras) > 0 { - fmt.Println("扩展信息:") - for key, value := range result.Extras { - fmt.Printf(" %s: %v\n", key, value) - } - } - - // 打印帧级别的结果 - if len(result.Frames) > 0 { - fmt.Println("违规帧详情:") - for _, frame := range result.Frames { - fmt.Printf(" 时间偏移: %d秒\n", frame.Offset) - fmt.Printf(" 帧URL: %s\n", frame.URL) - for _, frameResult := range frame.Results { - fmt.Printf(" 场景: %s, 标签: %s, 建议: %s, 置信度: %.2f\n", - frameResult.Scene, frameResult.Label, frameResult.Suggestion, frameResult.Rate) - if frameResult.SubLabel != "" { - fmt.Printf(" 子标签: %s\n", frameResult.SubLabel) - } - if len(frameResult.Details) > 0 { - fmt.Printf(" 详细信息: %v\n", frameResult.Details) - } - } + if result.FrameResult != nil { + fmt.Println("帧审核结果:") + frameResult := *result.FrameResult + if frameResult.RiskLevel != nil { + fmt.Printf("风险等级: %s\n", *frameResult.RiskLevel) } } fmt.Println("---") diff --git a/internal/model/image.go b/internal/model/image.go index 532a5b9..6e83486 100644 --- a/internal/model/image.go +++ b/internal/model/image.go @@ -1,6 +1,8 @@ package model -// ImageScanRequest 图片审核请求结构(2.0版本) +import green20220302 "github.com/alibabacloud-go/green-20220302/v2/client" + +// ImageScanRequest 图片审核请求结构 type ImageScanRequest struct { Tasks []ImageTask `json:"tasks"` Services []string `json:"services"` // 2.0版本使用services而不是scenes @@ -13,31 +15,17 @@ type ImageTask struct { Content string `json:"content,omitempty"` // base64编码的图片内容 } -// ImageScanResponse 图片审核响应结构(2.0版本) +// ImageScanResponse 图片审核响应结构 type ImageScanResponse struct { - Code int `json:"code"` - Message string `json:"message"` - Data []struct { - Code int `json:"code"` - Message string `json:"message"` - DataID string `json:"dataId"` - Results []struct { - Scene string `json:"scene"` - Label string `json:"label"` - Suggestion string `json:"suggestion"` - Rate float64 `json:"rate"` - // 2.0版本新增字段 - SubLabel string `json:"subLabel,omitempty"` // 子标签 - Details []ImageDetail `json:"details,omitempty"` // 详细信息 - Extras map[string]interface{} `json:"extras,omitempty"` // 扩展信息 - } `json:"results"` - } `json:"data"` + Code int32 `json:"code"` + Message string `json:"message"` + Data []ImageScanData `json:"data"` } -// ImageDetail 图片审核详细信息 -type ImageDetail struct { - Context struct { - Context string `json:"context"` - Pos []int `json:"pos"` - } `json:"context"` +// ImageScanData 图片审核数据 +type ImageScanData struct { + Code int32 `json:"code"` + Message string `json:"message"` + DataID string `json:"dataId"` + Results []*green20220302.ImageModerationResponseBodyDataResult `json:"results"` } diff --git a/internal/model/text.go b/internal/model/text.go index 74aee7a..8842b8b 100644 --- a/internal/model/text.go +++ b/internal/model/text.go @@ -1,6 +1,10 @@ package model -// TextScanRequest 文本审核请求结构(2.0版本) +import ( + green20220302 "github.com/alibabacloud-go/green-20220302/v2/client" +) + +// TextScanRequest 文本审核请求结构 type TextScanRequest struct { Tasks []TextTask `json:"tasks"` Services []string `json:"services"` // 2.0版本使用services而不是scenes @@ -12,31 +16,19 @@ type TextTask struct { Content string `json:"content"` } -// TextScanResponse 文本审核响应结构(2.0版本) +// TextScanResponse 文本审核响应结构 type TextScanResponse struct { - Code int `json:"code"` - Message string `json:"message"` - Data []struct { - Code int `json:"code"` - Message string `json:"message"` - DataID string `json:"dataId"` - Results []struct { - Scene string `json:"scene"` - Label string `json:"label"` - Suggestion string `json:"suggestion"` - Rate float64 `json:"rate"` - // 2.0版本新增字段 - SubLabel string `json:"subLabel,omitempty"` // 子标签 - Details []TextDetail `json:"details,omitempty"` // 详细信息 - Extras map[string]interface{} `json:"extras,omitempty"` // 扩展信息 - } `json:"results"` - } `json:"data"` + Code int32 `json:"code"` + Message string `json:"message"` + Data []TextScanData `json:"data"` } -// TextDetail 文本审核详细信息 -type TextDetail struct { - Context struct { - Context string `json:"context"` - Pos []int `json:"pos"` - } `json:"context"` +// TextScanData 文本审核数据 +type TextScanData struct { + Code int32 `json:"code"` + Message string `json:"message"` + DataID string `json:"dataId"` + DetectedLanguage string `json:"detectedLanguage"` + TranslatedContent string `json:"translatedContent"` + Results []*green20220302.TextModerationPlusResponseBodyDataResult `json:"results"` } diff --git a/internal/model/video.go b/internal/model/video.go index 6b761a4..124d903 100644 --- a/internal/model/video.go +++ b/internal/model/video.go @@ -1,6 +1,10 @@ package model -// VideoScanRequest 视频审核请求结构(2.0版本) +import ( + green20220302 "github.com/alibabacloud-go/green-20220302/v2/client" +) + +// VideoScanRequest 视频审核请求结构 type VideoScanRequest struct { Tasks []VideoTask `json:"tasks"` Services []string `json:"services"` // 2.0版本使用services而不是scenes @@ -16,58 +20,33 @@ type VideoTask struct { // VideoScanResponse 视频审核响应结构 type VideoScanResponse struct { - Code int `json:"code"` - Message string `json:"message"` - Data []struct { - Code int `json:"code"` - Message string `json:"message"` - DataID string `json:"dataId"` - TaskID string `json:"taskId"` - URL string `json:"url"` - } `json:"data"` + Code int32 `json:"code"` + Message string `json:"message"` + Data []VideoScanData `json:"data"` } -// VideoResultResponse 视频审核结果响应结构(2.0版本) +// VideoScanData 视频审核数据 +type VideoScanData struct { + Code int32 `json:"code"` + Message string `json:"message"` + DataID string `json:"dataId"` + TaskID string `json:"taskId"` + URL string `json:"url"` +} + +// VideoResultResponse 视频审核结果响应结构 type VideoResultResponse struct { - Code int `json:"code"` - Message string `json:"message"` - Data []struct { - Code int `json:"code"` - Message string `json:"message"` - DataID string `json:"dataId"` - TaskID string `json:"taskId"` - Status string `json:"status"` - Results []struct { - Scene string `json:"scene"` - Label string `json:"label"` - Suggestion string `json:"suggestion"` - Rate float64 `json:"rate"` - // 2.0版本新增字段 - SubLabel string `json:"subLabel,omitempty"` // 子标签 - Details []VideoDetail `json:"details,omitempty"` // 详细信息 - Extras map[string]interface{} `json:"extras,omitempty"` // 扩展信息 - Frames []struct { - Offset int `json:"offset"` - URL string `json:"url"` - Results []struct { - Scene string `json:"scene"` - Label string `json:"label"` - Suggestion string `json:"suggestion"` - Rate float64 `json:"rate"` - // 2.0版本新增字段 - SubLabel string `json:"subLabel,omitempty"` - Details []VideoDetail `json:"details,omitempty"` - Extras map[string]interface{} `json:"extras,omitempty"` - } `json:"results"` - } `json:"frames"` - } `json:"results"` - } `json:"data"` + Code int32 `json:"code"` + Message string `json:"message"` + Data []VideoResultData `json:"data"` } -// VideoDetail 视频审核详细信息 -type VideoDetail struct { - Context struct { - Context string `json:"context"` - Pos []int `json:"pos"` - } `json:"context"` +// VideoResultData 视频审核结果数据 +type VideoResultData struct { + Code int32 `json:"code"` + Message string `json:"message"` + DataID string `json:"dataId"` + TaskID string `json:"taskId"` + Status string `json:"status"` + Results *green20220302.VideoModerationResultResponseBodyData `json:"results"` }