# 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.
require 'json'
module TencentCloud
module Ams
module V20201229
class Client < TencentCloud::Common::AbstractClient
def initialize(credential, region, profile = nil)
api_version = '2020-12-29'
api_endpoint = 'ams.tencentcloudapi.com'
sdk_version = 'AMS_' + File.read(File.expand_path('../VERSION', __dir__)).strip
super(credential, region, api_version, api_endpoint, sdk_version, profile)
end
# 可使用该接口取消审核任务。请求成功后,接口返回RequestId则说明取消成功。
默认接口请求频率限制:**20次/秒**。
# @param request: Request instance for CancelTask.
# @type request: :class:`Tencentcloud::ams::V20201229::CancelTaskRequest`
# @rtype: :class:`Tencentcloud::ams::V20201229::CancelTaskResponse`
def CancelTask(request)
body = send_request('CancelTask', request.serialize)
response = JSON.parse(body)
if response['Response'].key?('Error') == false
model = CancelTaskResponse.new
model.deserialize(response['Response'])
model
else
code = response['Response']['Error']['Code']
message = response['Response']['Error']['Message']
reqid = response['Response']['RequestId']
raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
end
rescue TencentCloud::Common::TencentCloudSDKException => e
raise e
rescue StandardError => e
raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
end
# 本接口(CreateAudioModerationSyncTask) 用于提交短音频内容进行智能审核任务,使用前请您使用腾讯云主账号登录控制台 [开通音频内容安全服务](https://console.cloud.tencent.com/cms/audio/package) 并调整好对应的业务配置。
# ### 接口使用说明:
# - 前往“[内容安全控制台-图片内容安全](https://console.cloud.tencent.com/cms/audio/package)”开启使用音频内容安全服务,首次开通服务的用户可免费领用试用套餐包,包含**10小时**免费调用时长,有效期为1个月。
# - 该接口为收费接口,计费方式敬请参见 [腾讯云音频内容安全定价](https://cloud.tencent.com/product/ams/pricing)。
# ### 接口调用说明:
# - 音频文件大小支持:**文件 <= 4M**;
# - 音频文件**时长不超过60s**,超过60s音频调用则报错;
# - 音频文件支持格式:**wav (PCM编码)** 、**mp3**、**aac**、**m4a** (采样率:16kHz~48kHz,位深:16bit 小端,声道数:单声道/双声道,建议格式:**16kHz/16bit/单声道**);
# - 接口仅限音频文件传入,视频文件传入请调用长音频异步接口;
# - 接口**默认QPS为20**,如需自定义配置并发或请求频率,请工单咨询;
# - 接口**默认超时为10s**,请求如超过该时长则接口会报错。
# @param request: Request instance for CreateAudioModerationSyncTask.
# @type request: :class:`Tencentcloud::ams::V20201229::CreateAudioModerationSyncTaskRequest`
# @rtype: :class:`Tencentcloud::ams::V20201229::CreateAudioModerationSyncTaskResponse`
def CreateAudioModerationSyncTask(request)
body = send_request('CreateAudioModerationSyncTask', request.serialize)
response = JSON.parse(body)
if response['Response'].key?('Error') == false
model = CreateAudioModerationSyncTaskResponse.new
model.deserialize(response['Response'])
model
else
code = response['Response']['Error']['Code']
message = response['Response']['Error']['Message']
reqid = response['Response']['RequestId']
raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
end
rescue TencentCloud::Common::TencentCloudSDKException => e
raise e
rescue StandardError => e
raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
end
# 本接口(Audio Moderation)用于提交音频内容(包括音频文件或流地址)进行智能审核任务,使用前请您使用腾讯云主账号登录控制台[开通音频内容安全服务](https://console.cloud.tencent.com/cms)并调整好对应的业务配置。
# ### 功能使用说明:
# - 前往“[内容安全控制台-音频内容安全](https://console.cloud.tencent.com/cms)”开启使用音频内容安全服务,首次开通可获得**10小时**免费调用时长,有效期为1个月。
# - 默认接口请求频率限制:**20次/秒**,对于异步审核任务(点播音频),超出频率限制的请求会自动排入待审核队列,对于同步审核任务(直播音频),超出频率限制将会报错。
# - 默认并发审核路数限制:点播默认10路,异步审核任务(点播音频)数量超过并发审核路数时,将会进入排队;直播默认100路,同步审核任务(直播音频)超过并发审核路数,接口会返回错误。
# ### 接口功能说明:
# - 支持对音频流或音频文件进行检测,判断其中是否包含违规内容;
# - 支持设置回调地址 Callback 获取检测结果(对于已在审核的任务,最长回调时间为用户配置的**切片时长 + 2s**),或通过接口(查询音频检测结果)主动轮询获取检测结果;
# - 支持识别违规内容,包括:低俗、谩骂、色情、广告等场景;
# - 支持批量提交检测任务,检测任务列表**最多支持10个**。
# ### 音频文件调用说明:
# - 音频文件大小支持:**文件 < 500M**;
# - 音频文件时长支持:**< 1小时**;
# - 音频码率类型支持:128 Kbps - 256 Kbps ;
# - 音频文件支持格式:wav、mp3、aac、flac、amr、3gp、 m4a、wma、ogg、ape;
# - (**当输入为视频文件时**)支持分离视频文件音轨,并对音频内容进行独立审核。
# ### 音频流调用说明:
# - 音频流时长支持:**< 3小时**;
# - 音频码率类型支持:128 Kbps - 256 Kbps ;
# - 音频流支持的传输协议:RTMP、HTTP、HTTPS;
# - 音频流格式支持的类型:rtp、srtp、rtmp、rtmps、mmsh、 mmst、hls、http、tcp、https、m3u8;
# - (**当输入为视频流时**)支持提取视频流音轨,并对音频内容进行独立审核。
# ### 直播断流处理说明:
# - 请确认已对接[取消任务](https://cloud.tencent.com/document/product/1219/53258)。
# - 如果直播任务取消/结束,则终止直播拉流并退出审核。
# - 如果直播任务没有取消/结束,直播视频推流因故中断,产品将在将在10分钟内持续拉流重试。如果10分钟检测到音频切片数据,则恢复正常审核,反之,则终止拉流并退出审核。在拉流终止后,用户如有审核需求,需重新送审。
# 默认接口请求频率限制:20次/秒。
# @param request: Request instance for CreateAudioModerationTask.
# @type request: :class:`Tencentcloud::ams::V20201229::CreateAudioModerationTaskRequest`
# @rtype: :class:`Tencentcloud::ams::V20201229::CreateAudioModerationTaskResponse`
def CreateAudioModerationTask(request)
body = send_request('CreateAudioModerationTask', request.serialize)
response = JSON.parse(body)
if response['Response'].key?('Error') == false
model = CreateAudioModerationTaskResponse.new
model.deserialize(response['Response'])
model
else
code = response['Response']['Error']['Code']
message = response['Response']['Error']['Message']
reqid = response['Response']['RequestId']
raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
end
rescue TencentCloud::Common::TencentCloudSDKException => e
raise e
rescue StandardError => e
raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
end
# 通过该接口可查看音频审核任务的详情信息,包括任务状态、检测结果、音频文件识别出的对应文本内容、检测结果所对应的恶意标签及推荐的后续操作等,具体输出内容可查看输出参数示例。
# @param request: Request instance for DescribeTaskDetail.
# @type request: :class:`Tencentcloud::ams::V20201229::DescribeTaskDetailRequest`
# @rtype: :class:`Tencentcloud::ams::V20201229::DescribeTaskDetailResponse`
def DescribeTaskDetail(request)
body = send_request('DescribeTaskDetail', request.serialize)
response = JSON.parse(body)
if response['Response'].key?('Error') == false
model = DescribeTaskDetailResponse.new
model.deserialize(response['Response'])
model
else
code = response['Response']['Error']['Code']
message = response['Response']['Error']['Message']
reqid = response['Response']['RequestId']
raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
end
rescue TencentCloud::Common::TencentCloudSDKException => e
raise e
rescue StandardError => e
raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
end
# 通过该接口可查看审核任务列表;您也可根据多种业务信息(业务类型、审核结果、任务状态等)筛选审核任务列表。任务列表输出内容包括当前查询的任务总量、任务名称、任务状态、音频审核类型、基于检测结果的恶意标签及其后续操作等,具体输出内容可查看输出参数示例。
默认接口请求频率限制:**20次/秒**。
# @param request: Request instance for DescribeTasks.
# @type request: :class:`Tencentcloud::ams::V20201229::DescribeTasksRequest`
# @rtype: :class:`Tencentcloud::ams::V20201229::DescribeTasksResponse`
def DescribeTasks(request)
body = send_request('DescribeTasks', request.serialize)
response = JSON.parse(body)
if response['Response'].key?('Error') == false
model = DescribeTasksResponse.new
model.deserialize(response['Response'])
model
else
code = response['Response']['Error']['Code']
message = response['Response']['Error']['Message']
reqid = response['Response']['RequestId']
raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
end
rescue TencentCloud::Common::TencentCloudSDKException => e
raise e
rescue StandardError => e
raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
end
end
end
end
end