# 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 Gme module V20180711 class Client < TencentCloud::Common::AbstractClient def initialize(credential, region, profile = nil) api_version = '2018-07-11' api_endpoint = 'gme.tencentcloudapi.com' sdk_version = 'GME_' + File.read(File.expand_path('../VERSION', __dir__)).strip super(credential, region, api_version, api_endpoint, sdk_version, profile) end # 用于创建年龄语音识别任务的接口,请求频率10次/秒。该接口目前通过白名单开放试用,如有需求,请提交工单申请。 #
#

接口功能说明:

#
  • 支持对语音文件进行检测,判断是否为未成年人。
  • #
  • 支持批量提交检测子任务。检测子任务列表最多支持100个。
  • #
    #

    音频文件限制说明:

    #
  • 音频文件大小限制:10 M
  • #
  • 音频文件时长限制:3分钟
  • #
  • 音频文件格式支持的类型:.wav、.m4a、.amr、.mp3、.aac、.wma、.ogg
  • #
    # @param request: Request instance for CreateAgeDetectTask. # @type request: :class:`Tencentcloud::gme::V20180711::CreateAgeDetectTaskRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::CreateAgeDetectTaskResponse` def CreateAgeDetectTask(request) body = send_request('CreateAgeDetectTask', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = CreateAgeDetectTaskResponse.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 # 本接口(CreateApp)用于创建一个GME应用。 # @param request: Request instance for CreateApp. # @type request: :class:`Tencentcloud::gme::V20180711::CreateAppRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::CreateAppResponse` def CreateApp(request) body = send_request('CreateApp', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = CreateAppResponse.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 CreateScanUser. # @type request: :class:`Tencentcloud::gme::V20180711::CreateScanUserRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::CreateScanUserResponse` def CreateScanUser(request) body = send_request('CreateScanUser', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = CreateScanUserResponse.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 DeleteScanUser. # @type request: :class:`Tencentcloud::gme::V20180711::DeleteScanUserRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DeleteScanUserResponse` def DeleteScanUser(request) body = send_request('DeleteScanUser', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DeleteScanUserResponse.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 # 查询年龄语音识别任务结果,请求频率10次/秒。该接口目前通过白名单开放试用,如有需求,请提交工单申请。 # @param request: Request instance for DescribeAgeDetectTask. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeAgeDetectTaskRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeAgeDetectTaskResponse` def DescribeAgeDetectTask(request) body = send_request('DescribeAgeDetectTask', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeAgeDetectTaskResponse.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 # 本接口(DescribeAppStatistics)用于获取某个GME应用的用量数据。包括实时语音,语音消息及转文本,语音分析等。最长查询周期为最近30天。 # @param request: Request instance for DescribeAppStatistics. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeAppStatisticsRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeAppStatisticsResponse` def DescribeAppStatistics(request) body = send_request('DescribeAppStatistics', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeAppStatisticsResponse.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 # 本接口(DescribeApplicationData)用于获取数据详情信息,最多可拉取最近90天的数据。 # @param request: Request instance for DescribeApplicationData. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeApplicationDataRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeApplicationDataResponse` def DescribeApplicationData(request) body = send_request('DescribeApplicationData', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeApplicationDataResponse.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 # 根据应用ID和文件ID查询识别结果 # @param request: Request instance for DescribeFilterResult. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeFilterResultRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeFilterResultResponse` def DescribeFilterResult(request) body = send_request('DescribeFilterResult', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeFilterResultResponse.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 DescribeFilterResultList. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeFilterResultListRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeFilterResultListResponse` def DescribeFilterResultList(request) body = send_request('DescribeFilterResultList', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeFilterResultListResponse.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 DescribeRealtimeScanConfig. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeRealtimeScanConfigRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeRealtimeScanConfigResponse` def DescribeRealtimeScanConfig(request) body = send_request('DescribeRealtimeScanConfig', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeRealtimeScanConfigResponse.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 DescribeRoomInfo. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeRoomInfoRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeRoomInfoResponse` def DescribeRoomInfo(request) body = send_request('DescribeRoomInfo', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeRoomInfoResponse.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 # 本接口(DescribeScanResultList)用于查询语音检测结果,查询任务列表最多支持100个。 #

    如果在提交语音检测任务时未设置 Callback 字段,则需要通过本接口获取检测结果

    # @param request: Request instance for DescribeScanResultList. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeScanResultListRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeScanResultListResponse` def DescribeScanResultList(request) body = send_request('DescribeScanResultList', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeScanResultListResponse.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 DescribeUserInAndOutTime. # @type request: :class:`Tencentcloud::gme::V20180711::DescribeUserInAndOutTimeRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::DescribeUserInAndOutTimeResponse` def DescribeUserInAndOutTime(request) body = send_request('DescribeUserInAndOutTime', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeUserInAndOutTimeResponse.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 # 本接口(ModifyAppStatus)用于修改应用总开关状态。 # @param request: Request instance for ModifyAppStatus. # @type request: :class:`Tencentcloud::gme::V20180711::ModifyAppStatusRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::ModifyAppStatusResponse` def ModifyAppStatus(request) body = send_request('ModifyAppStatus', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = ModifyAppStatusResponse.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 ModifyRoomInfo. # @type request: :class:`Tencentcloud::gme::V20180711::ModifyRoomInfoRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::ModifyRoomInfoResponse` def ModifyRoomInfo(request) body = send_request('ModifyRoomInfo', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = ModifyRoomInfoResponse.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 # 本接口(ScanVoice)用于提交语音检测任务,检测任务列表最多支持100个。使用前请您登录[控制台 - 服务配置](https://console.cloud.tencent.com/gamegme/conf)开启语音分析服务。 #

    #

    功能试用说明:

    #
  • 打开前往控制台 - 产品试用免费试用语音分析服务。
  • #
    #

    接口功能说明:

    #
  • 支持对语音流或语音文件进行检测,判断其中是否包含违规内容。
  • #
  • 支持设置回调地址 Callback 获取检测结果,同时支持通过接口(查询语音检测结果)主动轮询获取检测结果。
  • #
  • 支持场景输入,包括:谩骂、色情等场景
  • #
  • 支持批量提交检测任务。检测任务列表最多支持100个。
  • #
    #

    音频文件限制说明:

    #
  • 音频文件大小限制:100 M
  • #
  • 音频文件时长限制:30分钟
  • #
  • 音频文件格式支持的类型:.wav、.m4a、.amr、.mp3、.aac、.wma、.ogg
  • #
    #

    语音流限制说明:

    #
  • 语音流格式支持的类型:.m3u8、.flv
  • #
  • 语音流支持的传输协议:RTMP、HTTP、HTTPS
  • #
  • 语音流时长限制:4小时
  • #
  • 支持音视频流分离并对音频流进行分析
  • #
    #

    Scenes 与 Label 参数说明:

    #

    提交语音检测任务时,需要指定 Scenes 场景参数,目前要求您设置 Scenes 参数值为:["default"];而在检测结果中,则包含请求时指定的场景,以及对应类型的检测结果。

    # # # # # # # # # # # # # # # #
    场景描述Label
    语音检测语音检测的检测类型 #

    normal:正常文本

    #

    porn:色情

    #

    abuse:谩骂

    #

    ad :广告

    #

    contraband :违禁

    #

    customized:自定义词库。目前白名单开放,如有需要请联系我们

    #
    #
    #

    回调相关说明:

    #
  • 如果在请求参数中指定了回调地址参数 Callback,即一个 HTTP(S) 协议接口的 URL,则需要支持 POST 方法,传输数据编码采用 UTF-8。
  • #
  • 在推送回调数据后,接收到的 HTTP 状态码为 200 时,表示推送成功。
  • #
  • HTTP 头参数说明:
  • # # # # # # # # # # # # # # # # # #
    名称类型是否必需描述
    Signatuestring签名,具体见签名生成说明
    # #
  • 回调示例如下(详细字段说明见结构: # DescribeScanResult
  • #
    {
            # 	"Code": 0,
            # 	"DataId": "1400000000_test_data_id",
            # 	"ScanFinishTime": 1566720906,
            # 	"HitFlag": true,
            # 	"Live": false,
            # 	"Msg": "",
            # 	"ScanPiece": [{
            # 		"DumpUrl": "",
            # 		"HitFlag": true,
            # 		"MainType": "abuse",
            # 		"RoomId": "123",
            # 		"OpenId": "xxx",
            # 		"Info":"",
            # 		"Offset": 0,
            # 		"Duration": 3400,
            # 		"PieceStartTime":1574684231,
            # 		"ScanDetail": [{
            # 			"EndTime": 1110,
            # 			"KeyWord": "xxx",
            # 			"Label": "abuse",
            # 			"Rate": "90.00",
            # 			"StartTime": 1110
            # 		}, {
            # 			"EndTime": 1380,
            # 			"KeyWord": "xxx",
            # 			"Label": "abuse",
            # 			"Rate": "90.00",
            # 			"StartTime": 930
            # 		}, {
            # 			"EndTime": 1560,
            # 			"KeyWord": "xxx",
            # 			"Label": "abuse",
            # 			"Rate": "90.00",
            # 			"StartTime": 930
            # 		}, {
            # 			"EndTime": 2820,
            # 			"KeyWord": "xxx",
            # 			"Label": "abuse",
            # 			"Rate": "90.00",
            # 			"StartTime": 2490
            # 		}]
            # 	}],
            # 	"ScanStartTime": 1566720905,
            # 	"Scenes": [
            # 		"default"
            # 	],
            # 	"Status": "Success",
            # 	"TaskId": "xxx",
            # 	"Url": "https://xxx/xxx.m4a"
            # }
            # 
    # @param request: Request instance for ScanVoice. # @type request: :class:`Tencentcloud::gme::V20180711::ScanVoiceRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::ScanVoiceResponse` def ScanVoice(request) body = send_request('ScanVoice', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = ScanVoiceResponse.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 UpdateScanRooms. # @type request: :class:`Tencentcloud::gme::V20180711::UpdateScanRoomsRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::UpdateScanRoomsResponse` def UpdateScanRooms(request) body = send_request('UpdateScanRooms', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = UpdateScanRoomsResponse.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 UpdateScanUsers. # @type request: :class:`Tencentcloud::gme::V20180711::UpdateScanUsersRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::UpdateScanUsersResponse` def UpdateScanUsers(request) body = send_request('UpdateScanUsers', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = UpdateScanUsersResponse.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 # 本接口用于识别涉黄等违规音频,成功会回调配置在应用的回调地址。回调示例如下: # {"BizId":0,"FileId":"test_file_id","FileName":"test_file_name","FileUrl":"test_file_url","OpenId":"test_open_id","TimeStamp":"0000-00-00 00:00:00","Data":[{"Type":1,"Word":"xx"}]} # Type表示过滤类型,1:色情,2:谩骂 # @param request: Request instance for VoiceFilter. # @type request: :class:`Tencentcloud::gme::V20180711::VoiceFilterRequest` # @rtype: :class:`Tencentcloud::gme::V20180711::VoiceFilterResponse` def VoiceFilter(request) body = send_request('VoiceFilter', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = VoiceFilterResponse.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