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// CreateClusterTemplate invokes the emr.CreateClusterTemplate API synchronously
24// api document: https://help.aliyun.com/api/emr/createclustertemplate.html
25func (client *Client) CreateClusterTemplate(request *CreateClusterTemplateRequest) (response *CreateClusterTemplateResponse, err error) {
26	response = CreateCreateClusterTemplateResponse()
27	err = client.DoAction(request, response)
28	return
29}
30
31// CreateClusterTemplateWithChan invokes the emr.CreateClusterTemplate API asynchronously
32// api document: https://help.aliyun.com/api/emr/createclustertemplate.html
33// asynchronous document: https://help.aliyun.com/document_detail/66220.html
34func (client *Client) CreateClusterTemplateWithChan(request *CreateClusterTemplateRequest) (<-chan *CreateClusterTemplateResponse, <-chan error) {
35	responseChan := make(chan *CreateClusterTemplateResponse, 1)
36	errChan := make(chan error, 1)
37	err := client.AddAsyncTask(func() {
38		defer close(responseChan)
39		defer close(errChan)
40		response, err := client.CreateClusterTemplate(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// CreateClusterTemplateWithCallback invokes the emr.CreateClusterTemplate API asynchronously
56// api document: https://help.aliyun.com/api/emr/createclustertemplate.html
57// asynchronous document: https://help.aliyun.com/document_detail/66220.html
58func (client *Client) CreateClusterTemplateWithCallback(request *CreateClusterTemplateRequest, callback func(response *CreateClusterTemplateResponse, err error)) <-chan int {
59	result := make(chan int, 1)
60	err := client.AddAsyncTask(func() {
61		var response *CreateClusterTemplateResponse
62		var err error
63		defer close(result)
64		response, err = client.CreateClusterTemplate(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// CreateClusterTemplateRequest is the request struct for api CreateClusterTemplate
77type CreateClusterTemplateRequest struct {
78	*requests.RpcRequest
79	ResourceOwnerId        requests.Integer                        `position:"Query" name:"ResourceOwnerId"`
80	LogPath                string                                  `position:"Query" name:"LogPath"`
81	MasterPwd              string                                  `position:"Query" name:"MasterPwd"`
82	Configurations         string                                  `position:"Query" name:"Configurations"`
83	IoOptimized            requests.Boolean                        `position:"Query" name:"IoOptimized"`
84	SecurityGroupId        string                                  `position:"Query" name:"SecurityGroupId"`
85	SshEnable              requests.Boolean                        `position:"Query" name:"SshEnable"`
86	EasEnable              requests.Boolean                        `position:"Query" name:"EasEnable"`
87	SecurityGroupName      string                                  `position:"Query" name:"SecurityGroupName"`
88	DepositType            string                                  `position:"Query" name:"DepositType"`
89	MachineType            string                                  `position:"Query" name:"MachineType"`
90	BootstrapAction        *[]CreateClusterTemplateBootstrapAction `position:"Query" name:"BootstrapAction"  type:"Repeated"`
91	UseLocalMetaDb         requests.Boolean                        `position:"Query" name:"UseLocalMetaDb"`
92	EmrVer                 string                                  `position:"Query" name:"EmrVer"`
93	TemplateName           string                                  `position:"Query" name:"TemplateName"`
94	UserDefinedEmrEcsRole  string                                  `position:"Query" name:"UserDefinedEmrEcsRole"`
95	IsOpenPublicIp         requests.Boolean                        `position:"Query" name:"IsOpenPublicIp"`
96	Period                 requests.Integer                        `position:"Query" name:"Period"`
97	InstanceGeneration     string                                  `position:"Query" name:"InstanceGeneration"`
98	VSwitchId              string                                  `position:"Query" name:"VSwitchId"`
99	ClusterType            string                                  `position:"Query" name:"ClusterType"`
100	AutoRenew              requests.Boolean                        `position:"Query" name:"AutoRenew"`
101	OptionSoftWareList     *[]string                               `position:"Query" name:"OptionSoftWareList"  type:"Repeated"`
102	VpcId                  string                                  `position:"Query" name:"VpcId"`
103	NetType                string                                  `position:"Query" name:"NetType"`
104	HostGroup              *[]CreateClusterTemplateHostGroup       `position:"Query" name:"HostGroup"  type:"Repeated"`
105	ZoneId                 string                                  `position:"Query" name:"ZoneId"`
106	UseCustomHiveMetaDb    requests.Boolean                        `position:"Query" name:"UseCustomHiveMetaDb"`
107	Config                 *[]CreateClusterTemplateConfig          `position:"Query" name:"Config"  type:"Repeated"`
108	HighAvailabilityEnable requests.Boolean                        `position:"Query" name:"HighAvailabilityEnable"`
109	InitCustomHiveMetaDb   requests.Boolean                        `position:"Query" name:"InitCustomHiveMetaDb"`
110}
111
112// CreateClusterTemplateBootstrapAction is a repeated param struct in CreateClusterTemplateRequest
113type CreateClusterTemplateBootstrapAction struct {
114	Path string `name:"Path"`
115	Arg  string `name:"Arg"`
116	Name string `name:"Name"`
117}
118
119// CreateClusterTemplateHostGroup is a repeated param struct in CreateClusterTemplateRequest
120type CreateClusterTemplateHostGroup struct {
121	Period             string `name:"Period"`
122	SysDiskCapacity    string `name:"SysDiskCapacity"`
123	DiskCapacity       string `name:"DiskCapacity"`
124	SysDiskType        string `name:"SysDiskType"`
125	ClusterId          string `name:"ClusterId"`
126	DiskType           string `name:"DiskType"`
127	HostGroupName      string `name:"HostGroupName"`
128	VSwitchId          string `name:"VSwitchId"`
129	DiskCount          string `name:"DiskCount"`
130	AutoRenew          string `name:"AutoRenew"`
131	HostGroupId        string `name:"HostGroupId"`
132	NodeCount          string `name:"NodeCount"`
133	InstanceType       string `name:"InstanceType"`
134	Comment            string `name:"Comment"`
135	ChargeType         string `name:"ChargeType"`
136	MultiInstanceTypes string `name:"MultiInstanceTypes"`
137	CreateType         string `name:"CreateType"`
138	HostGroupType      string `name:"HostGroupType"`
139}
140
141// CreateClusterTemplateConfig is a repeated param struct in CreateClusterTemplateRequest
142type CreateClusterTemplateConfig struct {
143	ConfigKey   string `name:"ConfigKey"`
144	FileName    string `name:"FileName"`
145	Encrypt     string `name:"Encrypt"`
146	Replace     string `name:"Replace"`
147	ConfigValue string `name:"ConfigValue"`
148	ServiceName string `name:"ServiceName"`
149}
150
151// CreateClusterTemplateResponse is the response struct for api CreateClusterTemplate
152type CreateClusterTemplateResponse struct {
153	*responses.BaseResponse
154	RequestId         string `json:"RequestId" xml:"RequestId"`
155	ClusterTemplateId string `json:"ClusterTemplateId" xml:"ClusterTemplateId"`
156}
157
158// CreateCreateClusterTemplateRequest creates a request to invoke CreateClusterTemplate API
159func CreateCreateClusterTemplateRequest() (request *CreateClusterTemplateRequest) {
160	request = &CreateClusterTemplateRequest{
161		RpcRequest: &requests.RpcRequest{},
162	}
163	request.InitWithApiInfo("Emr", "2016-04-08", "CreateClusterTemplate", "emr", "openAPI")
164	return
165}
166
167// CreateCreateClusterTemplateResponse creates a response to parse from CreateClusterTemplate response
168func CreateCreateClusterTemplateResponse() (response *CreateClusterTemplateResponse) {
169	response = &CreateClusterTemplateResponse{
170		BaseResponse: &responses.BaseResponse{},
171	}
172	return
173}
174