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