# frozen_string_literal: true
# Copyright (c) 2017-2018 THL A29 Limited, a Tencent company. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
module TencentCloud
module Ams
module V20201229
# 音频审核输出参数
class AudioResult < TencentCloud::Common::AbstractModel
# @param HitFlag: 该字段用于返回审核内容是否命中审核模型;取值:0(**未命中**)、1(**命中**)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type HitFlag: Integer
# @param Label: 该字段用于返回检测结果所对应的恶意标签。
返回值:**Normal**:正常,**Porn**:色情,**Abuse**:谩骂,**Ad**:广告,**Custom**:自定义违规;以及其他令人反感、不安全或不适宜的内容类型。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param Suggestion: 该字段用于返回后续操作建议。当您获取到判定结果后,返回值表示具体的后续建议操作。
# 返回值:**Block**:建议屏蔽,**Review** :建议人工复审,**Pass**:建议通过
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Suggestion: String
# @param Score: 该字段用于返回当前标签下的置信度,取值范围:0(**置信度最低**)-100(**置信度最高** ),越高代表文本越有可能属于当前返回的标签;如:*色情 99*,则表明该文本非常有可能属于色情内容。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Score: Integer
# @param Text: 该字段用于返回音频文件经ASR识别后的文本信息。最长可识别**5小时**的音频文件,若超出时长限制,接口将会报错。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Text: String
# @param Url: 该字段用于返回音频片段存储的链接地址,该地址有效期为1天。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Url: String
# @param Duration: 该字段用于返回音频文件的时长,单位为秒。
# @type Duration: String
# @param Extra: 该字段用于返回额外附加信息,不同客户或Biztype下返回信息不同。
# @type Extra: String
# @param TextResults: 该字段用于返回音频文件经ASR识别后产生的文本的详细审核结果。具体结果内容请参见AudioResultDetailLanguageResult数据结构的细节描述。
# @type TextResults: Array
# @param MoanResults: 该字段用于返回音频文件呻吟检测的详细审核结果。具体结果内容请参见AudioResultDetailMoanResult数据结构的细节描述。
# @type MoanResults: Array
# @param LanguageResults: 该字段用于返回音频小语种检测的详细审核结果。具体结果内容请参见AudioResultDetailLanguageResult数据结构的细节描述。
# @type LanguageResults: Array
attr_accessor :HitFlag, :Label, :Suggestion, :Score, :Text, :Url, :Duration, :Extra, :TextResults, :MoanResults, :LanguageResults
def initialize(hitflag=nil, label=nil, suggestion=nil, score=nil, text=nil, url=nil, duration=nil, extra=nil, textresults=nil, moanresults=nil, languageresults=nil)
@HitFlag = hitflag
@Label = label
@Suggestion = suggestion
@Score = score
@Text = text
@Url = url
@Duration = duration
@Extra = extra
@TextResults = textresults
@MoanResults = moanresults
@LanguageResults = languageresults
end
def deserialize(params)
@HitFlag = params['HitFlag']
@Label = params['Label']
@Suggestion = params['Suggestion']
@Score = params['Score']
@Text = params['Text']
@Url = params['Url']
@Duration = params['Duration']
@Extra = params['Extra']
unless params['TextResults'].nil?
@TextResults = []
params['TextResults'].each do |i|
audioresultdetailtextresult_tmp = AudioResultDetailTextResult.new
audioresultdetailtextresult_tmp.deserialize(i)
@TextResults << audioresultdetailtextresult_tmp
end
end
unless params['MoanResults'].nil?
@MoanResults = []
params['MoanResults'].each do |i|
audioresultdetailmoanresult_tmp = AudioResultDetailMoanResult.new
audioresultdetailmoanresult_tmp.deserialize(i)
@MoanResults << audioresultdetailmoanresult_tmp
end
end
unless params['LanguageResults'].nil?
@LanguageResults = []
params['LanguageResults'].each do |i|
audioresultdetaillanguageresult_tmp = AudioResultDetailLanguageResult.new
audioresultdetaillanguageresult_tmp.deserialize(i)
@LanguageResults << audioresultdetaillanguageresult_tmp
end
end
end
end
# 音频语言种类检测结果
class AudioResultDetailLanguageResult < TencentCloud::Common::AbstractModel
# @param Label: 该字段用于返回对应的语言种类信息。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param Score: 该参数用于返回当前标签下的置信度,取值范围:0(**置信度最低**)-100(**置信度最高**),越高代表音频越有可能属于当前返回的语种标签;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Score: Integer
# @param StartTime: 该参数用于返回对应语种标签的片段在音频文件内的开始时间,单位为毫秒。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type StartTime: Float
# @param EndTime: 该参数用于返回对应语种标签的片段在音频文件内的结束时间,单位为毫秒。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type EndTime: Float
# @param SubLabelCode: *内测中,敬请期待*
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SubLabelCode: String
attr_accessor :Label, :Score, :StartTime, :EndTime, :SubLabelCode
def initialize(label=nil, score=nil, starttime=nil, endtime=nil, sublabelcode=nil)
@Label = label
@Score = score
@StartTime = starttime
@EndTime = endtime
@SubLabelCode = sublabelcode
end
def deserialize(params)
@Label = params['Label']
@Score = params['Score']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@SubLabelCode = params['SubLabelCode']
end
end
# 音频呻吟审核结果
class AudioResultDetailMoanResult < TencentCloud::Common::AbstractModel
# @param Label: 该字段用于返回检测结果需要检测的内容类型,此处固定为**Moan**(呻吟)以调用呻吟检测功能。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param Score: 该字段用于返回呻吟检测的置信度,取值范围:0(**置信度最低**)-100(**置信度最高**),越高代表音频越有可能属于呻吟内容。
# @type Score: Integer
# @param StartTime: 该字段用于返回对应呻吟标签的片段在音频文件内的开始时间,单位为毫秒。
# @type StartTime: Float
# @param EndTime: 该字段用于返回对应呻吟标签的片段在音频文件内的结束时间,单位为毫秒。
# @type EndTime: Float
# @param SubLabelCode: *内测中,敬请期待*
# @type SubLabelCode: String
attr_accessor :Label, :Score, :StartTime, :EndTime, :SubLabelCode
def initialize(label=nil, score=nil, starttime=nil, endtime=nil, sublabelcode=nil)
@Label = label
@Score = score
@StartTime = starttime
@EndTime = endtime
@SubLabelCode = sublabelcode
end
def deserialize(params)
@Label = params['Label']
@Score = params['Score']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
@SubLabelCode = params['SubLabelCode']
end
end
# 音频ASR文本审核结果
class AudioResultDetailTextResult < TencentCloud::Common::AbstractModel
# @param Label: 该字段用于返回检测结果所对应的恶意标签。
返回值:**Normal**:正常,**Porn**:色情,**Abuse**:谩骂,**Ad**:广告,**Custom**:自定义违规;以及其他令人反感、不安全或不适宜的内容类型。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param Keywords: 该字段用于返回ASR识别出的文本内容命中的关键词信息,用于标注内容违规的具体原因(如:加我微信)。该参数可能会有多个返回值,代表命中的多个关键词;若返回值为空,Score不为空,则代表识别结果所对应的恶意标签(Label)来自于语义模型判断的返回值。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Keywords: Array
# @param LibId: 该字段**仅当Label为Custom:自定义关键词时该参数有效**,用于返回自定义库的ID,以方便自定义库管理和配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LibId: String
# @param LibName: 该字段**仅当Label为Custom:自定义关键词时该参数有效**,用于返回自定义库的名称,以方便自定义库管理和配置。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LibName: String
# @param Score: 该字段用于返回当前标签下的置信度,取值范围:0(**置信度最低**)-100(**置信度最高**),越高代表文本越有可能属于当前返回的标签;如:*色情 99*,则表明该文本非常有可能属于色情内容。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Score: Integer
# @param Suggestion: 该字段用于返回后续操作建议。当您获取到判定结果后,返回值表示具体的后续建议操作。
# 返回值:**Block**:建议屏蔽,**Review** :建议人工复审,**Pass**:建议通过
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Suggestion: String
# @param LibType: 该字段用于返回自定义关键词对应的词库类型,取值为**1**(黑白库)和**2**(自定义关键词库),若未配置自定义关键词库,则默认值为1(黑白库匹配)。
# @type LibType: Integer
attr_accessor :Label, :Keywords, :LibId, :LibName, :Score, :Suggestion, :LibType
def initialize(label=nil, keywords=nil, libid=nil, libname=nil, score=nil, suggestion=nil, libtype=nil)
@Label = label
@Keywords = keywords
@LibId = libid
@LibName = libname
@Score = score
@Suggestion = suggestion
@LibType = libtype
end
def deserialize(params)
@Label = params['Label']
@Keywords = params['Keywords']
@LibId = params['LibId']
@LibName = params['LibName']
@Score = params['Score']
@Suggestion = params['Suggestion']
@LibType = params['LibType']
end
end
# 表示声音段信息
class AudioSegments < TencentCloud::Common::AbstractModel
# @param OffsetTime: 该字段用于返回音频片段的开始时间,单位为秒。对于点播文件,该参数代表对应音频相对于完整音轨的偏移时间,如0(代表不偏移),5(音轨开始后5秒),10(音轨开始后10秒);对于直播文件,该参数则返回对应音频片段开始时的Unix时间戳,如:1594650717。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OffsetTime: String
# @param Result: 该字段用于返回音频片段的具体审核结果,详细内容敬请参考AudioResult数据结构的描述。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Result: :class:`Tencentcloud::Ams.v20201229.models.AudioResult`
attr_accessor :OffsetTime, :Result
def initialize(offsettime=nil, result=nil)
@OffsetTime = offsettime
@Result = result
end
def deserialize(params)
@OffsetTime = params['OffsetTime']
unless params['Result'].nil?
@Result = AudioResult.new
@Result.deserialize(params['Result'])
end
end
end
# 文件桶信息
# 参考腾讯云存储相关说明 https://cloud.tencent.com/document/product/436/44352
class BucketInfo < TencentCloud::Common::AbstractModel
# @param Bucket: 该字段用于标识腾讯云对象存储的存储桶名称,关于文件桶的详细信息敬请参考 [腾讯云存储相关说明](https://cloud.tencent.com/document/product/436/44352)。
# @type Bucket: String
# @param Region: 该字段用于标识腾讯云对象存储的托管机房的分布地区,对象存储 COS 的数据存放在这些地域的存储桶中。
# @type Region: String
# @param Object: 该字段用于标识腾讯云对象存储的对象Key,对象z作为基本单元被存放在存储桶中;用户可以通过腾讯云控制台、API、SDK 等多种方式管理对象。有关对象的详细描述敬请参阅相应 [产品文档](https://cloud.tencent.com/document/product/436/13324)。
# @type Object: String
attr_accessor :Bucket, :Region, :Object
def initialize(bucket=nil, region=nil, object=nil)
@Bucket = bucket
@Region = region
@Object = object
end
def deserialize(params)
@Bucket = params['Bucket']
@Region = params['Region']
@Object = params['Object']
end
end
# CancelTask请求参数结构体
class CancelTaskRequest < TencentCloud::Common::AbstractModel
# @param TaskId: 该字段表示创建音频审核任务后返回的任务ID(在Results参数中),用于标识需要取消的审核任务。
# @type TaskId: String
attr_accessor :TaskId
def initialize(taskid=nil)
@TaskId = taskid
end
def deserialize(params)
@TaskId = params['TaskId']
end
end
# CancelTask返回参数结构体
class CancelTaskResponse < TencentCloud::Common::AbstractModel
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RequestId
def initialize(requestid=nil)
@RequestId = requestid
end
def deserialize(params)
@RequestId = params['RequestId']
end
end
# CreateAudioModerationSyncTask请求参数结构体
class CreateAudioModerationSyncTaskRequest < TencentCloud::Common::AbstractModel
# @param BizType: Biztype为策略的具体的编号,用于接口调度,在内容安全控制台中可配置。不同Biztype关联不同的业务场景与识别能力策略,调用前请确认正确的Biztype。Biztype仅为数字、字母与下划线的组合,长度为3-32个字符;调用时不传入Biztype代表采用默认的识别策略。
# @type BizType: String
# @param DataId: 数据标识,可以由英文字母、数字、下划线、-、@#组成,不超过64个字符
# @type DataId: String
# @param FileFormat: 音频文件资源格式,当前为mp3,wav,请按照实际文件格式填入
# @type FileFormat: String
# @param Name: 文件名称,可以由英文字母、数字、下划线、-、@#组成,不超过64个字符
# @type Name: String
# @param FileContent: 数据Base64编码,短音频同步接口仅传入可音频内容;
# 支持范围:文件大小不能超过5M,时长不可超过60s,码率范围为8-16Kbps;
# 支持格式:wav、mp3
# @type FileContent: String
# @param FileUrl: 音频资源访问链接,与FileContent参数必须二选一输入;
# 支持范围:同FileContent;
# @type FileUrl: String
attr_accessor :BizType, :DataId, :FileFormat, :Name, :FileContent, :FileUrl
def initialize(biztype=nil, dataid=nil, fileformat=nil, name=nil, filecontent=nil, fileurl=nil)
@BizType = biztype
@DataId = dataid
@FileFormat = fileformat
@Name = name
@FileContent = filecontent
@FileUrl = fileurl
end
def deserialize(params)
@BizType = params['BizType']
@DataId = params['DataId']
@FileFormat = params['FileFormat']
@Name = params['Name']
@FileContent = params['FileContent']
@FileUrl = params['FileUrl']
end
end
# CreateAudioModerationSyncTask返回参数结构体
class CreateAudioModerationSyncTaskResponse < TencentCloud::Common::AbstractModel
# @param DataId: 请求接口时传入的数据标识
# @type DataId: String
# @param Name: 文件名称,可以由英文字母、数字、下划线、-、@#组成,不超过64个字符
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param BizType: Biztype为策略的具体的编号,用于接口调度,在内容安全控制台中可配置。不同Biztype关联不同的业务场景与识别能力策略,调用前请确认正确的Biztype。Biztype仅为数字、字母与下划线的组合,长度为3-32个字符;调用时不传入Biztype代表采用默认的识别策略。
# @type BizType: String
# @param Suggestion: 智能审核服务对于内容违规类型的等级,可选值:
# Pass 建议通过;
# Reveiw 建议复审;
# Block 建议屏蔽;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Suggestion: String
# @param Label: 智能审核服务对于内容违规类型的判断,详见返回值列表
# 如:Label:Porn(色情);
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param AsrText: 音频文本,备注:这里的文本最大只返回前1000个字符
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AsrText: String
# @param TextResults: 音频中对话内容审核结果;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TextResults: Array
# @param MoanResults: 音频中低俗内容审核结果;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MoanResults: Array
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :DataId, :Name, :BizType, :Suggestion, :Label, :AsrText, :TextResults, :MoanResults, :RequestId
def initialize(dataid=nil, name=nil, biztype=nil, suggestion=nil, label=nil, asrtext=nil, textresults=nil, moanresults=nil, requestid=nil)
@DataId = dataid
@Name = name
@BizType = biztype
@Suggestion = suggestion
@Label = label
@AsrText = asrtext
@TextResults = textresults
@MoanResults = moanresults
@RequestId = requestid
end
def deserialize(params)
@DataId = params['DataId']
@Name = params['Name']
@BizType = params['BizType']
@Suggestion = params['Suggestion']
@Label = params['Label']
@AsrText = params['AsrText']
unless params['TextResults'].nil?
@TextResults = []
params['TextResults'].each do |i|
textresult_tmp = TextResult.new
textresult_tmp.deserialize(i)
@TextResults << textresult_tmp
end
end
unless params['MoanResults'].nil?
@MoanResults = []
params['MoanResults'].each do |i|
moanresult_tmp = MoanResult.new
moanresult_tmp.deserialize(i)
@MoanResults << moanresult_tmp
end
end
@RequestId = params['RequestId']
end
end
# CreateAudioModerationTask请求参数结构体
class CreateAudioModerationTaskRequest < TencentCloud::Common::AbstractModel
# @param Tasks: 该字段表示输入的音频审核任务信息,具体输入内容请参见TaskInput数据结构的详细描述。
备注:最多同时可创建**10个任务**。
# @type Tasks: Array
# @param BizType: 该字段表示策略的具体编号,用于接口调度,在内容安全控制台中可配置。若不传入Biztype参数(留空),则代表采用默认的识别策略;传入则会在审核时根据业务场景采取不同的审核策略。
备注:Biztype仅为数字、字母与下划线的组合,长度为3-32个字符;不同Biztype关联不同的业务场景与识别能力策略,调用前请确认正确的Biztype。
# @type BizType: String
# @param Type: 该字段表示输入的音频审核类型,取值为:**AUDIO**(点播音频)和 **LIVE_AUDIO**(直播音频),默认值为AUDIO。
# @type Type: String
# @param Seed: 可选参数,该字段表示回调签名的key信息,用于保证数据的安全性。 签名方法为在返回的HTTP头部添加 X-Signature 的字段,值为: seed + body 的 SHA256 编码和Hex字符串,在收到回调数据后,可以根据返回的body,用 **sha256(seed + body)**, 计算出 `X-Signature` 进行验证。
具体使用实例可参考 [回调签名示例](https://cloud.tencent.com/document/product/1219/53263)。
# @type Seed: String
# @param CallbackUrl: 可选参数,该字段表示接受审核信息回调的地址,格式为URL链接默认格式。配置成功后,审核过程中产生的违规音频片段将通过此接口发送。回调返回内容格式请参考 [回调签名示例](https://cloud.tencent.com/document/product/1219/53257#.E7.A4.BA.E4.BE.8B2-.E5.9B.9E.E8.B0.83.E7.AD.BE.E5.90.8D.E7.A4.BA.E4.BE.8B)
# @type CallbackUrl: String
attr_accessor :Tasks, :BizType, :Type, :Seed, :CallbackUrl
def initialize(tasks=nil, biztype=nil, type=nil, seed=nil, callbackurl=nil)
@Tasks = tasks
@BizType = biztype
@Type = type
@Seed = seed
@CallbackUrl = callbackurl
end
def deserialize(params)
unless params['Tasks'].nil?
@Tasks = []
params['Tasks'].each do |i|
taskinput_tmp = TaskInput.new
taskinput_tmp.deserialize(i)
@Tasks << taskinput_tmp
end
end
@BizType = params['BizType']
@Type = params['Type']
@Seed = params['Seed']
@CallbackUrl = params['CallbackUrl']
end
end
# CreateAudioModerationTask返回参数结构体
class CreateAudioModerationTaskResponse < TencentCloud::Common::AbstractModel
# @param Results: 该字段用于返回任务创建的结果,具体输出内容请参见TaskResult数据结构的详细描述。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Results: Array
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Results, :RequestId
def initialize(results=nil, requestid=nil)
@Results = results
@RequestId = requestid
end
def deserialize(params)
unless params['Results'].nil?
@Results = []
params['Results'].each do |i|
taskresult_tmp = TaskResult.new
taskresult_tmp.deserialize(i)
@Results << taskresult_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeTaskDetail请求参数结构体
class DescribeTaskDetailRequest < TencentCloud::Common::AbstractModel
# @param TaskId: 该字段表示创建音频审核任务后返回的任务ID(在Results参数中),用于标识需要查询任务详情的审核任务。
#
备注:查询接口单次最大查询量为**20条每次**。
# @type TaskId: String
# @param ShowAllSegments: 该布尔字段表示是否展示全部的音频片段,取值:True(展示全部的音频分片)、False(只展示命中审核规则的音频分片);默认值为False。
# @type ShowAllSegments: Boolean
attr_accessor :TaskId, :ShowAllSegments
def initialize(taskid=nil, showallsegments=nil)
@TaskId = taskid
@ShowAllSegments = showallsegments
end
def deserialize(params)
@TaskId = params['TaskId']
@ShowAllSegments = params['ShowAllSegments']
end
end
# DescribeTaskDetail返回参数结构体
class DescribeTaskDetailResponse < TencentCloud::Common::AbstractModel
# @param TaskId: 该字段用于返回创建音频审核任务后返回的任务ID(在Results参数中),用于标识需要查询任务详情的审核任务。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TaskId: String
# @param DataId: 该字段用于返回调用音频审核接口时在Tasks参数内传入的数据ID参数,方便数据的辨别和管理。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DataId: String
# @param BizType: 该字段用于返回调用音频审核接口时传入的BizType参数,方便数据的辨别和管理。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BizType: String
# @param Name: 该字段用于返回调用音频审核接口时传入的TaskInput参数中的任务名称,方便任务的识别与管理。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param Status: 该字段用于返回所查询内容的任务状态。
#
取值:**FINISH**(任务已完成)、**PENDING** (任务等待中)、**RUNNING** (任务进行中)、**ERROR** (任务出错)、**CANCELLED** (任务已取消)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Status: String
# @param Type: 该字段用于返回调用音频审核接口时输入的音频审核类型,取值为:**AUDIO**(点播音频)和**LIVE_AUDIO**(直播音频),默认值为AUDIO。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param Suggestion: 该字段用于返回基于恶意标签的后续操作建议。当您获取到判定结果后,返回值表示系统推荐的后续操作;建议您按照业务所需,对不同违规类型与建议值进行处理。
返回值:**Block**:建议屏蔽,**Review** :建议人工复审,**Pass**:建议通过
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Suggestion: String
# @param Labels: 该字段用于返回检测结果所对应的恶意标签。
返回值:**Normal**:正常,**Porn**:色情,**Abuse**:谩骂,**Ad**:广告,**Custom**:自定义违规;以及其他令人反感、不安全或不适宜的内容类型。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Labels: Array
# @param InputInfo: 该字段用于返回审核服务的媒体内容信息,主要包括传入文件类型和访问地址。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InputInfo: :class:`Tencentcloud::Ams.v20201229.models.InputInfo`
# @param AudioText: 该字段用于返回音频文件识别出的对应文本内容,最大支持**前1000个字符**。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AudioText: String
# @param AudioSegments: 该字段用于返回音频片段的审核结果,主要包括开始时间和音频审核的相应结果。
具体输出内容请参见AudioSegments及AudioResult数据结构的详细描述。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AudioSegments: Array
# @param ErrorType: 当任务状态为Error时,该字段用于返回对应错误的类型;任务状态非Error时,默认返回为空。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ErrorType: String
# @param ErrorDescription: 当任务状态为Error时,该字段用于返回对应错误的详细描述,任务状态非Error时默认返回为空。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ErrorDescription: String
# @param CreatedAt: 该字段用于返回被查询任务创建的时间,格式采用 ISO 8601标准。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CreatedAt: String
# @param UpdatedAt: 该字段用于返回被查询任务最后更新时间,格式采用 ISO 8601标准。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdatedAt: String
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TaskId, :DataId, :BizType, :Name, :Status, :Type, :Suggestion, :Labels, :InputInfo, :AudioText, :AudioSegments, :ErrorType, :ErrorDescription, :CreatedAt, :UpdatedAt, :RequestId
def initialize(taskid=nil, dataid=nil, biztype=nil, name=nil, status=nil, type=nil, suggestion=nil, labels=nil, inputinfo=nil, audiotext=nil, audiosegments=nil, errortype=nil, errordescription=nil, createdat=nil, updatedat=nil, requestid=nil)
@TaskId = taskid
@DataId = dataid
@BizType = biztype
@Name = name
@Status = status
@Type = type
@Suggestion = suggestion
@Labels = labels
@InputInfo = inputinfo
@AudioText = audiotext
@AudioSegments = audiosegments
@ErrorType = errortype
@ErrorDescription = errordescription
@CreatedAt = createdat
@UpdatedAt = updatedat
@RequestId = requestid
end
def deserialize(params)
@TaskId = params['TaskId']
@DataId = params['DataId']
@BizType = params['BizType']
@Name = params['Name']
@Status = params['Status']
@Type = params['Type']
@Suggestion = params['Suggestion']
unless params['Labels'].nil?
@Labels = []
params['Labels'].each do |i|
tasklabel_tmp = TaskLabel.new
tasklabel_tmp.deserialize(i)
@Labels << tasklabel_tmp
end
end
unless params['InputInfo'].nil?
@InputInfo = InputInfo.new
@InputInfo.deserialize(params['InputInfo'])
end
@AudioText = params['AudioText']
unless params['AudioSegments'].nil?
@AudioSegments = []
params['AudioSegments'].each do |i|
audiosegments_tmp = AudioSegments.new
audiosegments_tmp.deserialize(i)
@AudioSegments << audiosegments_tmp
end
end
@ErrorType = params['ErrorType']
@ErrorDescription = params['ErrorDescription']
@CreatedAt = params['CreatedAt']
@UpdatedAt = params['UpdatedAt']
@RequestId = params['RequestId']
end
end
# DescribeTasks请求参数结构体
class DescribeTasksRequest < TencentCloud::Common::AbstractModel
# @param Limit: 该参数表示任务列表每页展示的任务条数,**默认值为10**(每页展示10条任务)。
# @type Limit: Integer
# @param Filter: 该参数表示任务筛选器的输入参数,可根据业务类型、审核文件类型、处理建议及任务状态筛选想要查看的审核任务,具体参数内容请参见TaskFilter数据结构的详细描述。
# @type Filter: :class:`Tencentcloud::Ams.v20201229.models.TaskFilter`
# @param PageToken: 该参数表示翻页时使用的Token信息,由系统自动生成,并在翻页时向下一个生成的页面传递此参数,以方便快速翻页功能的实现。当到最后一页时,该字段为空。
# @type PageToken: String
# @param StartTime: 该参数表示任务列表的开始时间,格式为ISO8601标准的时间戳。**默认值为最近3天**,若传入该参数,则在这一时间到EndTime之间的任务将会被筛选出来。
备注:该参数与Filter共同起到任务筛选作用,二者作用无先后顺序。
# @type StartTime: String
# @param EndTime: 该参数表示任务列表的结束时间,格式为ISO8601标准的时间戳。**默认值为空**,若传入该参数,则在这StartTime到这一时间之间的任务将会被筛选出来。
备注:该参数与Filter共同起到任务筛选作用,二者作用无先后顺序。
# @type EndTime: String
attr_accessor :Limit, :Filter, :PageToken, :StartTime, :EndTime
def initialize(limit=nil, filter=nil, pagetoken=nil, starttime=nil, endtime=nil)
@Limit = limit
@Filter = filter
@PageToken = pagetoken
@StartTime = starttime
@EndTime = endtime
end
def deserialize(params)
@Limit = params['Limit']
unless params['Filter'].nil?
@Filter = TaskFilter.new
@Filter.deserialize(params['Filter'])
end
@PageToken = params['PageToken']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
end
end
# DescribeTasks返回参数结构体
class DescribeTasksResponse < TencentCloud::Common::AbstractModel
# @param Total: 该字段用于返回当前查询的任务总量,格式为int字符串。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Total: String
# @param Data: 该字段用于返回当前页的任务详细数据,具体输出内容请参见TaskData数据结构的详细描述。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Data: Array
# @param PageToken: 该字段用于返回翻页时使用的Token信息,由系统自动生成,并在翻页时向下一个生成的页面传递此参数,以方便快速翻页功能的实现。当到最后一页时,该字段为空。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PageToken: String
# @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Total, :Data, :PageToken, :RequestId
def initialize(total=nil, data=nil, pagetoken=nil, requestid=nil)
@Total = total
@Data = data
@PageToken = pagetoken
@RequestId = requestid
end
def deserialize(params)
@Total = params['Total']
unless params['Data'].nil?
@Data = []
params['Data'].each do |i|
taskdata_tmp = TaskData.new
taskdata_tmp.deserialize(i)
@Data << taskdata_tmp
end
end
@PageToken = params['PageToken']
@RequestId = params['RequestId']
end
end
# 输入信息详情
class InputInfo < TencentCloud::Common::AbstractModel
# @param Type: 该字段表示文件访问类型,取值为**URL**(资源链接)和**COS** (腾讯云对象存储)。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param Url: 该字段表示文件访问的链接地址,格式为标准URL格式。
备注:当Type为URL时此字段不为空。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Url: String
# @param BucketInfo: 该字段表示文件访问的腾讯云存储桶信息。
备注:当Type为COS时此字段不为空。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BucketInfo: :class:`Tencentcloud::Ams.v20201229.models.BucketInfo`
attr_accessor :Type, :Url, :BucketInfo
def initialize(type=nil, url=nil, bucketinfo=nil)
@Type = type
@Url = url
@BucketInfo = bucketinfo
end
def deserialize(params)
@Type = params['Type']
@Url = params['Url']
unless params['BucketInfo'].nil?
@BucketInfo = BucketInfo.new
@BucketInfo.deserialize(params['BucketInfo'])
end
end
end
# 媒体类型
class MediaInfo < TencentCloud::Common::AbstractModel
# @param Codecs: 该字段用于返回传入的媒体文件的编码格式,如wav、mp3、aac、flac、amr、3gp、 m4a、wma、ogg、ape等。
# @type Codecs: String
# @param Duration: 该字段用于返回对传入的流媒体文件进行分片的片段时长,单位为秒。**默认值为15秒**,支持用户自定义配置。
# @type Duration: Integer
# @param Width: *内测中,敬请期待*
# @type Width: Integer
# @param Height: *内测中,敬请期待*
# @type Height: Integer
# @param Thumbnail: *内测中,敬请期待*
# @type Thumbnail: String
attr_accessor :Codecs, :Duration, :Width, :Height, :Thumbnail
def initialize(codecs=nil, duration=nil, width=nil, height=nil, thumbnail=nil)
@Codecs = codecs
@Duration = duration
@Width = width
@Height = height
@Thumbnail = thumbnail
end
def deserialize(params)
@Codecs = params['Codecs']
@Duration = params['Duration']
@Width = params['Width']
@Height = params['Height']
@Thumbnail = params['Thumbnail']
end
end
# 呻吟低俗检测结果
class MoanResult < TencentCloud::Common::AbstractModel
# @param Label: 固定取值为Moan(呻吟/娇喘),如音频中无复杂类型「MoanResult」的返回则代表改音频中无呻吟/娇喘相关违规内容;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param Score: 机器判断当前分类的置信度,取值范围:0~100。分数越高,表示越有可能属于当前分类。
# (如:Moan 99,则该样本属于呻吟/娇喘的置信度非常高。)
# @type Score: Integer
# @param Suggestion: 建议您拿到判断结果后的执行操作。
# 建议值,Block:建议屏蔽,Review:建议复审,Pass:建议通过
# @type Suggestion: String
# @param StartTime: 违规事件开始时间,单位为毫秒(ms);
# @type StartTime: Float
# @param EndTime: 违规事件结束时间,单位为毫秒(ms);
# @type EndTime: Float
attr_accessor :Label, :Score, :Suggestion, :StartTime, :EndTime
def initialize(label=nil, score=nil, suggestion=nil, starttime=nil, endtime=nil)
@Label = label
@Score = score
@Suggestion = suggestion
@StartTime = starttime
@EndTime = endtime
end
def deserialize(params)
@Label = params['Label']
@Score = params['Score']
@Suggestion = params['Suggestion']
@StartTime = params['StartTime']
@EndTime = params['EndTime']
end
end
# 用于表示数据存储的相关信息
class StorageInfo < TencentCloud::Common::AbstractModel
# @param Type: 该字段表示文件访问类型,取值为**URL**(资源链接)和**COS** (腾讯云对象存储);该字段应当与传入的访问类型相对应,可用于强校验并方便系统快速识别访问地址;若不传入此参数,则默认值为URL,此时系统将自动判定访问地址类型。
# @type Type: String
# @param Url: 该字段表示文件访问的链接地址,格式为标准URL格式。
备注:当Type为URL时此字段不为空,该参数与BucketInfo参数须传入其中之一
# @type Url: String
# @param BucketInfo: 该字段表示文件访问的腾讯云存储桶信息。
备注:当Type为COS时此字段不为空,该参数与Url参数须传入其中之一。
# @type BucketInfo: :class:`Tencentcloud::Ams.v20201229.models.BucketInfo`
attr_accessor :Type, :Url, :BucketInfo
def initialize(type=nil, url=nil, bucketinfo=nil)
@Type = type
@Url = url
@BucketInfo = bucketinfo
end
def deserialize(params)
@Type = params['Type']
@Url = params['Url']
unless params['BucketInfo'].nil?
@BucketInfo = BucketInfo.new
@BucketInfo.deserialize(params['BucketInfo'])
end
end
end
# 任务数据
class TaskData < TencentCloud::Common::AbstractModel
# @param DataId: 该字段用于返回音频审核任务数据所对应的数据ID,方便后续查询和管理审核任务。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DataId: String
# @param TaskId: 该字段用于返回音频审核任务所生成的任务ID,用于标识具体审核任务,方便后续查询和管理。
# @type TaskId: String
# @param Status: 该字段用于返回所查询内容的任务状态。
#
取值:**FINISH**(任务已完成)、**PENDING** (任务等待中)、**RUNNING** (任务进行中)、**ERROR** (任务出错)、**CANCELLED** (任务已取消)。
# @type Status: String
# @param Name: 该字段用于返回音频审核任务所对应的任务名称,方便后续查询和管理审核任务。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Name: String
# @param BizType: 该字段用于返回调用音频审核接口时传入的BizType参数,方便数据的辨别和管理。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BizType: String
# @param Type: 该字段用于返回调用音频审核接口时输入的音频审核类型,取值为:**AUDIO**(点播音频)和**LIVE_AUDIO**(直播音频),默认值为AUDIO。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Type: String
# @param Suggestion: 该字段用于返回基于恶意标签的后续操作建议。当您获取到判定结果后,返回值表示系统推荐的后续操作;建议您按照业务所需,对不同违规类型与建议值进行处理。
返回值:**Block**:建议屏蔽,**Review** :建议人工复审,**Pass**:建议通过
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Suggestion: String
# @param MediaInfo: 输入信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MediaInfo: :class:`Tencentcloud::Ams.v20201229.models.MediaInfo`
# @param Labels: 该字段用于返回检测结果所对应的恶意标签。
返回值:**Normal**:正常,**Porn**:色情,**Abuse**:谩骂,**Ad**:广告,**Custom**:自定义违规;以及其他令人反感、不安全或不适宜的内容类型。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Labels: Array
# @param CreatedAt: 该字段用于返回被查询任务创建的时间,格式采用 ISO 8601标准。
# @type CreatedAt: String
# @param UpdatedAt: 该字段用于返回被查询任务最后更新时间,格式采用 ISO 8601标准。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UpdatedAt: String
attr_accessor :DataId, :TaskId, :Status, :Name, :BizType, :Type, :Suggestion, :MediaInfo, :Labels, :CreatedAt, :UpdatedAt
def initialize(dataid=nil, taskid=nil, status=nil, name=nil, biztype=nil, type=nil, suggestion=nil, mediainfo=nil, labels=nil, createdat=nil, updatedat=nil)
@DataId = dataid
@TaskId = taskid
@Status = status
@Name = name
@BizType = biztype
@Type = type
@Suggestion = suggestion
@MediaInfo = mediainfo
@Labels = labels
@CreatedAt = createdat
@UpdatedAt = updatedat
end
def deserialize(params)
@DataId = params['DataId']
@TaskId = params['TaskId']
@Status = params['Status']
@Name = params['Name']
@BizType = params['BizType']
@Type = params['Type']
@Suggestion = params['Suggestion']
unless params['MediaInfo'].nil?
@MediaInfo = MediaInfo.new
@MediaInfo.deserialize(params['MediaInfo'])
end
unless params['Labels'].nil?
@Labels = []
params['Labels'].each do |i|
tasklabel_tmp = TaskLabel.new
tasklabel_tmp.deserialize(i)
@Labels << tasklabel_tmp
end
end
@CreatedAt = params['CreatedAt']
@UpdatedAt = params['UpdatedAt']
end
end
# 任务筛选器
class TaskFilter < TencentCloud::Common::AbstractModel
# @param BizType: 该字段用于传入任务对应的业务类型供筛选器进行筛选。Biztype为策略的具体的编号,用于接口调度,在内容安全控制台中可配置。不同Biztype关联不同的业务场景与审核策略,调用前请确认正确的Biztype。Biztype仅为**数字、字母与下划线的组合**,长度为3-32个字符。
备注:在不传入该参数时筛选器默认不筛选业务类型。
# @type BizType: String
# @param Type: 该字段用于传入音频审核对应的任务类型供筛选器进行筛选,取值为:**VIDEO**(点播视频审核),**AUDIO**(点播音频审核), **LIVE_VIDEO**(直播视频审核), **LIVE_AUDIO**(直播音频审核)。
备注:在不传入该参数时筛选器默认不筛选任务类型。
# @type Type: String
# @param Suggestion: 该字段用于传入音频审核对应的建议操作供筛选器进行筛选,取值为:**Block**:建议屏蔽,**Review**:建议人工复审,**Pass**:建议通过。
备注:在不传入该参数时筛选器默认不筛选建议操作。
# @type Suggestion: String
# @param TaskStatus: 该字段用于传入审核任务的任务状态供筛选器进行筛选,取值为:**FINISH**(任务已完成)、**PENDING** (任务等待中)、**RUNNING** (任务进行中)、**ERROR** (任务出错)、**CANCELLED** (任务已取消)。
备注:在不传入该参数时筛选器默认不筛选任务状态。
# @type TaskStatus: String
attr_accessor :BizType, :Type, :Suggestion, :TaskStatus
def initialize(biztype=nil, type=nil, suggestion=nil, taskstatus=nil)
@BizType = biztype
@Type = type
@Suggestion = suggestion
@TaskStatus = taskstatus
end
def deserialize(params)
@BizType = params['BizType']
@Type = params['Type']
@Suggestion = params['Suggestion']
@TaskStatus = params['TaskStatus']
end
end
# 音视频任务数据结构
class TaskInput < TencentCloud::Common::AbstractModel
# @param DataId: 选填参数,该字段表示您为待检测对象分配的数据ID,传入后可方便您对文件进行标识和管理。
取值:由英文字母(大小写均可)、数字及四个特殊符号(_,-,@,#)组成,**长度不超过64个字符**。
# @type DataId: String
# @param Name: 选填参数,该字段表示音频审核任务所对应的任务名称,方便后续查询和管理审核任务。
# @type Name: String
# @param Input: 必填参数,该字段表示审核文件的访问参数,用于获取审核媒体文件,该参数内包括访问类型和访问地址。
# @type Input: :class:`Tencentcloud::Ams.v20201229.models.StorageInfo`
attr_accessor :DataId, :Name, :Input
def initialize(dataid=nil, name=nil, input=nil)
@DataId = dataid
@Name = name
@Input = input
end
def deserialize(params)
@DataId = params['DataId']
@Name = params['Name']
unless params['Input'].nil?
@Input = StorageInfo.new
@Input.deserialize(params['Input'])
end
end
end
# 用于返回审核任务输出的标签
class TaskLabel < TencentCloud::Common::AbstractModel
# @param Label: 该字段用于返回检测结果所对应的恶意标签。
返回值:**Normal**:正常,**Porn**:色情,**Abuse**:谩骂,**Ad**:广告,**Custom**:自定义违规;以及其他令人反感、不安全或不适宜的内容类型。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param Suggestion: 该字段用于返回当前标签对应的后续操作建议。当您获取到判定结果后,返回值表示系统推荐的后续操作;建议您按照业务所需,对不同违规类型与建议值进行处理。
返回值:**Block**:建议屏蔽,**Review** :建议人工复审,**Pass**:建议通过
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Suggestion: String
# @param Score: 该字段用于返回当前标签(Label)下的置信度,取值范围:0(**置信度最低**)-100(**置信度最高** ),越高代表文本越有可能属于当前返回的标签;如:*色情 99*,则表明该文本非常有可能属于色情内容;*色情 0*,则表明该文本不属于色情内容。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Score: Integer
attr_accessor :Label, :Suggestion, :Score
def initialize(label=nil, suggestion=nil, score=nil)
@Label = label
@Suggestion = suggestion
@Score = score
end
def deserialize(params)
@Label = params['Label']
@Suggestion = params['Suggestion']
@Score = params['Score']
end
end
# 创建任务时的返回结果
class TaskResult < TencentCloud::Common::AbstractModel
# @param DataId: 该字段用于返回创建音频审核任务时在TaskInput结构内传入的DataId,用于标识具体审核任务。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DataId: String
# @param TaskId: 该字段用于返回音频审核任务所生成的任务ID,用于标识具体审核任务,方便后续查询和管理。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TaskId: String
# @param Code: 该字段用于返回任务创建的状态,如返回OK则代表任务创建成功,其他返回值可参考公共错误码。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Code: String
# @param Message: **仅在Code的返回值为错误码时生效**,用于返回错误的详情内容。
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Message: String
attr_accessor :DataId, :TaskId, :Code, :Message
def initialize(dataid=nil, taskid=nil, code=nil, message=nil)
@DataId = dataid
@TaskId = taskid
@Code = code
@Message = message
end
def deserialize(params)
@DataId = params['DataId']
@TaskId = params['TaskId']
@Code = params['Code']
@Message = params['Message']
end
end
# 音频文本内容审核结果
class TextResult < TencentCloud::Common::AbstractModel
# @param Label: 恶意标签,Normal:正常,Porn:色情,Abuse:谩骂,Ad:广告,Custom:自定义词库。
# 以及其他令人反感、不安全或不适宜的内容类型。
# 如音频中无复杂类型「TextResults」的返回则代表改音频中无相关违规内容;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Label: String
# @param Keywords: 命中的关键词,为空则代表该违规内容出自于模型的判断;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Keywords: Array
# @param LibId: 命中关键词库的库标识;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LibId: String
# @param LibName: 命中关键词库的名字;
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LibName: String
# @param Score: 机器判断当前分类的置信度,取值范围:0~100。分数越高,表示越有可能属于当前分类。
# (如:Porn 99,则该样本属于色情的置信度非常高。)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Score: Integer
# @param Suggestion: 建议您拿到判断结果后的执行操作。
# 建议值,Block:建议屏蔽,Review:建议复审,Pass:建议通过
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Suggestion: String
# @param LibType: 自定义词库的类型,自定义词库相关的信息可登录控制台中查看;
# 1:自定义黑白库;
# 2:自定义库;
# @type LibType: Integer
attr_accessor :Label, :Keywords, :LibId, :LibName, :Score, :Suggestion, :LibType
def initialize(label=nil, keywords=nil, libid=nil, libname=nil, score=nil, suggestion=nil, libtype=nil)
@Label = label
@Keywords = keywords
@LibId = libid
@LibName = libname
@Score = score
@Suggestion = suggestion
@LibType = libtype
end
def deserialize(params)
@Label = params['Label']
@Keywords = params['Keywords']
@LibId = params['LibId']
@LibName = params['LibName']
@Score = params['Score']
@Suggestion = params['Suggestion']
@LibType = params['LibType']
end
end
end
end
end