# 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