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