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// MetastoreUpdateTable invokes the emr.MetastoreUpdateTable API synchronously
24// api document: https://help.aliyun.com/api/emr/metastoreupdatetable.html
25func (client *Client) MetastoreUpdateTable(request *MetastoreUpdateTableRequest) (response *MetastoreUpdateTableResponse, err error) {
26	response = CreateMetastoreUpdateTableResponse()
27	err = client.DoAction(request, response)
28	return
29}
30
31// MetastoreUpdateTableWithChan invokes the emr.MetastoreUpdateTable API asynchronously
32// api document: https://help.aliyun.com/api/emr/metastoreupdatetable.html
33// asynchronous document: https://help.aliyun.com/document_detail/66220.html
34func (client *Client) MetastoreUpdateTableWithChan(request *MetastoreUpdateTableRequest) (<-chan *MetastoreUpdateTableResponse, <-chan error) {
35	responseChan := make(chan *MetastoreUpdateTableResponse, 1)
36	errChan := make(chan error, 1)
37	err := client.AddAsyncTask(func() {
38		defer close(responseChan)
39		defer close(errChan)
40		response, err := client.MetastoreUpdateTable(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// MetastoreUpdateTableWithCallback invokes the emr.MetastoreUpdateTable API asynchronously
56// api document: https://help.aliyun.com/api/emr/metastoreupdatetable.html
57// asynchronous document: https://help.aliyun.com/document_detail/66220.html
58func (client *Client) MetastoreUpdateTableWithCallback(request *MetastoreUpdateTableRequest, callback func(response *MetastoreUpdateTableResponse, err error)) <-chan int {
59	result := make(chan int, 1)
60	err := client.AddAsyncTask(func() {
61		var response *MetastoreUpdateTableResponse
62		var err error
63		defer close(result)
64		response, err = client.MetastoreUpdateTable(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// MetastoreUpdateTableRequest is the request struct for api MetastoreUpdateTable
77type MetastoreUpdateTableRequest struct {
78	*requests.RpcRequest
79	ResourceOwnerId     requests.Integer                    `position:"Query" name:"ResourceOwnerId"`
80	AddColumn           *[]MetastoreUpdateTableAddColumn    `position:"Query" name:"AddColumn"  type:"Repeated"`
81	AddPartition        *[]MetastoreUpdateTableAddPartition `position:"Query" name:"AddPartition"  type:"Repeated"`
82	DeleteColumnName    *[]string                           `position:"Query" name:"DeleteColumnName"  type:"Repeated"`
83	TableId             string                              `position:"Query" name:"TableId"`
84	DeletePartitionName *[]string                           `position:"Query" name:"DeletePartitionName"  type:"Repeated"`
85}
86
87// MetastoreUpdateTableAddColumn is a repeated param struct in MetastoreUpdateTableRequest
88type MetastoreUpdateTableAddColumn struct {
89	Name    string `name:"Name"`
90	Comment string `name:"Comment"`
91	Type    string `name:"Type"`
92}
93
94// MetastoreUpdateTableAddPartition is a repeated param struct in MetastoreUpdateTableRequest
95type MetastoreUpdateTableAddPartition struct {
96	Name    string `name:"Name"`
97	Comment string `name:"Comment"`
98	Type    string `name:"Type"`
99}
100
101// MetastoreUpdateTableResponse is the response struct for api MetastoreUpdateTable
102type MetastoreUpdateTableResponse struct {
103	*responses.BaseResponse
104	RequestId string `json:"RequestId" xml:"RequestId"`
105	Success   bool   `json:"success" xml:"success"`
106}
107
108// CreateMetastoreUpdateTableRequest creates a request to invoke MetastoreUpdateTable API
109func CreateMetastoreUpdateTableRequest() (request *MetastoreUpdateTableRequest) {
110	request = &MetastoreUpdateTableRequest{
111		RpcRequest: &requests.RpcRequest{},
112	}
113	request.InitWithApiInfo("Emr", "2016-04-08", "MetastoreUpdateTable", "emr", "openAPI")
114	return
115}
116
117// CreateMetastoreUpdateTableResponse creates a response to parse from MetastoreUpdateTable response
118func CreateMetastoreUpdateTableResponse() (response *MetastoreUpdateTableResponse) {
119	response = &MetastoreUpdateTableResponse{
120		BaseResponse: &responses.BaseResponse{},
121	}
122	return
123}
124