1package emr 2 3//Licensed under the Apache License, Version 2.0 (the "License"); 4//you may not use this file except in compliance with the License. 5//You may obtain a copy of the License at 6// 7//http://www.apache.org/licenses/LICENSE-2.0 8// 9//Unless required by applicable law or agreed to in writing, software 10//distributed under the License is distributed on an "AS IS" BASIS, 11//WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12//See the License for the specific language governing permissions and 13//limitations under the License. 14// 15// Code generated by Alibaba Cloud SDK Code Generator. 16// Changes may cause incorrect behavior and will be lost if the code is regenerated. 17 18import ( 19 "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests" 20 "github.com/aliyun/alibaba-cloud-sdk-go/sdk/responses" 21) 22 23// MetastoreDescribeKafkaTopic invokes the emr.MetastoreDescribeKafkaTopic API synchronously 24// api document: https://help.aliyun.com/api/emr/metastoredescribekafkatopic.html 25func (client *Client) MetastoreDescribeKafkaTopic(request *MetastoreDescribeKafkaTopicRequest) (response *MetastoreDescribeKafkaTopicResponse, err error) { 26 response = CreateMetastoreDescribeKafkaTopicResponse() 27 err = client.DoAction(request, response) 28 return 29} 30 31// MetastoreDescribeKafkaTopicWithChan invokes the emr.MetastoreDescribeKafkaTopic API asynchronously 32// api document: https://help.aliyun.com/api/emr/metastoredescribekafkatopic.html 33// asynchronous document: https://help.aliyun.com/document_detail/66220.html 34func (client *Client) MetastoreDescribeKafkaTopicWithChan(request *MetastoreDescribeKafkaTopicRequest) (<-chan *MetastoreDescribeKafkaTopicResponse, <-chan error) { 35 responseChan := make(chan *MetastoreDescribeKafkaTopicResponse, 1) 36 errChan := make(chan error, 1) 37 err := client.AddAsyncTask(func() { 38 defer close(responseChan) 39 defer close(errChan) 40 response, err := client.MetastoreDescribeKafkaTopic(request) 41 if err != nil { 42 errChan <- err 43 } else { 44 responseChan <- response 45 } 46 }) 47 if err != nil { 48 errChan <- err 49 close(responseChan) 50 close(errChan) 51 } 52 return responseChan, errChan 53} 54 55// MetastoreDescribeKafkaTopicWithCallback invokes the emr.MetastoreDescribeKafkaTopic API asynchronously 56// api document: https://help.aliyun.com/api/emr/metastoredescribekafkatopic.html 57// asynchronous document: https://help.aliyun.com/document_detail/66220.html 58func (client *Client) MetastoreDescribeKafkaTopicWithCallback(request *MetastoreDescribeKafkaTopicRequest, callback func(response *MetastoreDescribeKafkaTopicResponse, err error)) <-chan int { 59 result := make(chan int, 1) 60 err := client.AddAsyncTask(func() { 61 var response *MetastoreDescribeKafkaTopicResponse 62 var err error 63 defer close(result) 64 response, err = client.MetastoreDescribeKafkaTopic(request) 65 callback(response, err) 66 result <- 1 67 }) 68 if err != nil { 69 defer close(result) 70 callback(nil, err) 71 result <- 0 72 } 73 return result 74} 75 76// MetastoreDescribeKafkaTopicRequest is the request struct for api MetastoreDescribeKafkaTopic 77type MetastoreDescribeKafkaTopicRequest struct { 78 *requests.RpcRequest 79 ResourceOwnerId requests.Integer `position:"Query" name:"ResourceOwnerId"` 80 TopicId string `position:"Query" name:"TopicId"` 81} 82 83// MetastoreDescribeKafkaTopicResponse is the response struct for api MetastoreDescribeKafkaTopic 84type MetastoreDescribeKafkaTopicResponse struct { 85 *responses.BaseResponse 86 RequestId string `json:"RequestId" xml:"RequestId"` 87 Id string `json:"Id" xml:"Id"` 88 DataSourceId string `json:"DataSourceId" xml:"DataSourceId"` 89 TopicName string `json:"TopicName" xml:"TopicName"` 90 NumPartitions int `json:"NumPartitions" xml:"NumPartitions"` 91 ReplicationFactor int `json:"ReplicationFactor" xml:"ReplicationFactor"` 92 GmtCreate int `json:"GmtCreate" xml:"GmtCreate"` 93 GmtModified int `json:"GmtModified" xml:"GmtModified"` 94 BrokerTotal int `json:"BrokerTotal" xml:"BrokerTotal"` 95 NumUsingBrokers int `json:"NumUsingBrokers" xml:"NumUsingBrokers"` 96 BrokersLeaderSkewPercentage string `json:"BrokersLeaderSkewPercentage" xml:"BrokersLeaderSkewPercentage"` 97 UnderReplicatedPercentage string `json:"UnderReplicatedPercentage" xml:"UnderReplicatedPercentage"` 98 PreferredReplicasPercentage string `json:"PreferredReplicasPercentage" xml:"PreferredReplicasPercentage"` 99 Cluster Cluster `json:"Cluster" xml:"Cluster"` 100 AdvancedConfigList AdvancedConfigListInMetastoreDescribeKafkaTopic `json:"AdvancedConfigList" xml:"AdvancedConfigList"` 101 SummaryList SummaryList `json:"SummaryList" xml:"SummaryList"` 102 DistributionList DistributionList `json:"DistributionList" xml:"DistributionList"` 103} 104 105// CreateMetastoreDescribeKafkaTopicRequest creates a request to invoke MetastoreDescribeKafkaTopic API 106func CreateMetastoreDescribeKafkaTopicRequest() (request *MetastoreDescribeKafkaTopicRequest) { 107 request = &MetastoreDescribeKafkaTopicRequest{ 108 RpcRequest: &requests.RpcRequest{}, 109 } 110 request.InitWithApiInfo("Emr", "2016-04-08", "MetastoreDescribeKafkaTopic", "emr", "openAPI") 111 return 112} 113 114// CreateMetastoreDescribeKafkaTopicResponse creates a response to parse from MetastoreDescribeKafkaTopic response 115func CreateMetastoreDescribeKafkaTopicResponse() (response *MetastoreDescribeKafkaTopicResponse) { 116 response = &MetastoreDescribeKafkaTopicResponse{ 117 BaseResponse: &responses.BaseResponse{}, 118 } 119 return 120} 121