All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.tencentcloudapi.gme.v20180711.GmeClient Maven / Gradle / Ivy

There is a newer version: 3.0.1076
Show newest version
/*
 * 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.
 */
package com.tencentcloudapi.gme.v20180711;

import java.lang.reflect.Type;
import com.google.gson.JsonSyntaxException;
import com.google.gson.reflect.TypeToken;
import com.tencentcloudapi.common.exception.TencentCloudSDKException;
import com.tencentcloudapi.common.AbstractClient;
import com.tencentcloudapi.common.profile.ClientProfile;
import com.tencentcloudapi.common.JsonResponseModel;
import com.tencentcloudapi.common.Credential;
import com.tencentcloudapi.gme.v20180711.models.*;

public class GmeClient extends AbstractClient{
    private static String endpoint = "gme.tencentcloudapi.com";
    private static String service = "gme";
    private static String version = "2018-07-11";

    public GmeClient(Credential credential, String region) {
        this(credential, region, new ClientProfile());
    }

    public GmeClient(Credential credential, String region, ClientProfile profile) {
        super(GmeClient.endpoint, GmeClient.version, credential, region, profile);
    }

    /**
     *This API is used to create a GME application.
     * @param req CreateAppRequest
     * @return CreateAppResponse
     * @throws TencentCloudSDKException
     */
    public CreateAppResponse CreateApp(CreateAppRequest req) throws TencentCloudSDKException{
        JsonResponseModel rsp = null;
        String rspStr = "";
        try {
                Type type = new TypeToken>() {
                }.getType();
                rspStr = this.internalRequest(req, "CreateApp");
                rsp  = gson.fromJson(rspStr, type);
        } catch (JsonSyntaxException e) {
            throw new TencentCloudSDKException("response message: " + rspStr + ".\n Error message: " + e.getMessage());
        }
        return rsp.response;
    }

    /**
     *This API is used to delete a room or remove members from the room.
     * @param req DeleteRoomMemberRequest
     * @return DeleteRoomMemberResponse
     * @throws TencentCloudSDKException
     */
    public DeleteRoomMemberResponse DeleteRoomMember(DeleteRoomMemberRequest req) throws TencentCloudSDKException{
        JsonResponseModel rsp = null;
        String rspStr = "";
        try {
                Type type = new TypeToken>() {
                }.getType();
                rspStr = this.internalRequest(req, "DeleteRoomMember");
                rsp  = gson.fromJson(rspStr, type);
        } catch (JsonSyntaxException e) {
            throw new TencentCloudSDKException("response message: " + rspStr + ".\n Error message: " + e.getMessage());
        }
        return rsp.response;
    }

    /**
     *This API is used to query the usage statistics of a GME application, including those of Voice Chat, Voice Message Service, Voice Analysis, etc. The maximum query period is the past 30 days.
     * @param req DescribeAppStatisticsRequest
     * @return DescribeAppStatisticsResponse
     * @throws TencentCloudSDKException
     */
    public DescribeAppStatisticsResponse DescribeAppStatistics(DescribeAppStatisticsRequest req) throws TencentCloudSDKException{
        JsonResponseModel rsp = null;
        String rspStr = "";
        try {
                Type type = new TypeToken>() {
                }.getType();
                rspStr = this.internalRequest(req, "DescribeAppStatistics");
                rsp  = gson.fromJson(rspStr, type);
        } catch (JsonSyntaxException e) {
            throw new TencentCloudSDKException("response message: " + rspStr + ".\n Error message: " + e.getMessage());
        }
        return rsp.response;
    }

    /**
     *This API is used to query data details for up to the past 90 days.
     * @param req DescribeApplicationDataRequest
     * @return DescribeApplicationDataResponse
     * @throws TencentCloudSDKException
     */
    public DescribeApplicationDataResponse DescribeApplicationData(DescribeApplicationDataRequest req) throws TencentCloudSDKException{
        JsonResponseModel rsp = null;
        String rspStr = "";
        try {
                Type type = new TypeToken>() {
                }.getType();
                rspStr = this.internalRequest(req, "DescribeApplicationData");
                rsp  = gson.fromJson(rspStr, type);
        } catch (JsonSyntaxException e) {
            throw new TencentCloudSDKException("response message: " + rspStr + ".\n Error message: " + e.getMessage());
        }
        return rsp.response;
    }

    /**
     *This API is used to query the result of voice moderation tasks. Up to 100 tasks can be queried in one time.

If the `Callback` field is not set when a voice moderation task is submitted, this API is called to query the moderation result.

* @param req DescribeScanResultListRequest * @return DescribeScanResultListResponse * @throws TencentCloudSDKException */ public DescribeScanResultListResponse DescribeScanResultList(DescribeScanResultListRequest req) throws TencentCloudSDKException{ JsonResponseModel rsp = null; String rspStr = ""; try { Type type = new TypeToken>() { }.getType(); rspStr = this.internalRequest(req, "DescribeScanResultList"); rsp = gson.fromJson(rspStr, type); } catch (JsonSyntaxException e) { throw new TencentCloudSDKException("response message: " + rspStr + ".\n Error message: " + e.getMessage()); } return rsp.response; } /** *This API is used to change the status of an application. * @param req ModifyAppStatusRequest * @return ModifyAppStatusResponse * @throws TencentCloudSDKException */ public ModifyAppStatusResponse ModifyAppStatus(ModifyAppStatusRequest req) throws TencentCloudSDKException{ JsonResponseModel rsp = null; String rspStr = ""; try { Type type = new TypeToken>() { }.getType(); rspStr = this.internalRequest(req, "ModifyAppStatus"); rsp = gson.fromJson(rspStr, type); } catch (JsonSyntaxException e) { throw new TencentCloudSDKException("response message: " + rspStr + ".\n Error message: " + e.getMessage()); } return rsp.response; } /** *This API is used to submit a voice detection task. Up to 100 tasks can be added in the detection task list. Before using this API, please activate the Voice Content Moderation Service in [GME Console > Voice Content Moderation > Service Configuration](https://console.cloud.tencent.com/gamegme/conf).

About the trial:

  • You can try out the Voice Content Moderation Service free of charge in GME Console > Voice Content Moderation > Product Trial.

  • API feature description:

  • This API checks voice streams or files for non-compliant content.
  • The detection result can be queried by setting the callback address (`Callback`) or calling the `DescribeScanResultList` API for polling.
  • The scenario can be specified, such as abusive or pornographic.
  • Detection tasks can be submitted in batches. Up to 100 tasks can be added in the detection task list.

  • Audio file limits:

  • Audio file size limit: 100 MB
  • Audio file duration limit: 30 minutes
  • Supported audio file formats: .wav, .m4a, .amr, .mp3, .aac, .wma, .ogg

  • Voice stream limits:

  • Supported voice stream formats: .m3u8, .flv
  • Supported voice stream transfer protocols: RTMP, HTTP, HTTPS
  • Voice stream duration limit: 4 hours
  • Audio/video stream separation and audio stream analysis are supported

  • `Scenes` and `Label` parameter description:

    When submitting a voice detection task, you need to specify the `Scenes` parameter. You are currently required to set the `Scenes` parameter to `["default"]`. The detection result will contain the scenario specified at the time of request and detection result in the corresponding type.

    Scenario Description Label
    Voice detection Voice detection type

    normal: Normal

    porn: Pornographic

    abuse: Abusive

    ad: Advertising

    illegal: Illegal

    moan: Moaning

    customized: Custom dictionary


    Callback description:

  • If the callback address parameter `Callback` (i.e., the URL of an HTTP(S) API) is specified in the request parameters, then the POST method should be supported and transferred data should be encoded with UTF-8.
  • After the callback data is pushed, if the HTTP status code received is 200, the push is successful.
  • HTTP header parameter description:
  • Item Type Required Description
    Signatue string Yes Signature. For more information, please see Signature generation description.
    • Signature generation description:
      • The HMAC-SH1 algorithm should be used, and the result should be encoded with Base64;
      • The original signature string is the entire JSON content of POST and body (the length is subject to `Content-Length`);
      • The signature key is the `SecretKey` of the application, which can be viewed in the console.
  • Sample callback (for more information on the fields, please see the structure: 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 req ScanVoiceRequest * @return ScanVoiceResponse * @throws TencentCloudSDKException */ public ScanVoiceResponse ScanVoice(ScanVoiceRequest req) throws TencentCloudSDKException{ JsonResponseModel rsp = null; String rspStr = ""; try { Type type = new TypeToken>() { }.getType(); rspStr = this.internalRequest(req, "ScanVoice"); rsp = gson.fromJson(rspStr, type); } catch (JsonSyntaxException e) { throw new TencentCloudSDKException("response message: " + rspStr + ".\n Error message: " + e.getMessage()); } return rsp.response; } }




    © 2015 - 2025 Weber Informatics LLC | Privacy Policy