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// CreateFlowJob invokes the emr.CreateFlowJob API synchronously 24// api document: https://help.aliyun.com/api/emr/createflowjob.html 25func (client *Client) CreateFlowJob(request *CreateFlowJobRequest) (response *CreateFlowJobResponse, err error) { 26 response = CreateCreateFlowJobResponse() 27 err = client.DoAction(request, response) 28 return 29} 30 31// CreateFlowJobWithChan invokes the emr.CreateFlowJob API asynchronously 32// api document: https://help.aliyun.com/api/emr/createflowjob.html 33// asynchronous document: https://help.aliyun.com/document_detail/66220.html 34func (client *Client) CreateFlowJobWithChan(request *CreateFlowJobRequest) (<-chan *CreateFlowJobResponse, <-chan error) { 35 responseChan := make(chan *CreateFlowJobResponse, 1) 36 errChan := make(chan error, 1) 37 err := client.AddAsyncTask(func() { 38 defer close(responseChan) 39 defer close(errChan) 40 response, err := client.CreateFlowJob(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// CreateFlowJobWithCallback invokes the emr.CreateFlowJob API asynchronously 56// api document: https://help.aliyun.com/api/emr/createflowjob.html 57// asynchronous document: https://help.aliyun.com/document_detail/66220.html 58func (client *Client) CreateFlowJobWithCallback(request *CreateFlowJobRequest, callback func(response *CreateFlowJobResponse, err error)) <-chan int { 59 result := make(chan int, 1) 60 err := client.AddAsyncTask(func() { 61 var response *CreateFlowJobResponse 62 var err error 63 defer close(result) 64 response, err = client.CreateFlowJob(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// CreateFlowJobRequest is the request struct for api CreateFlowJob 77type CreateFlowJobRequest struct { 78 *requests.RpcRequest 79 RunConf string `position:"Query" name:"RunConf"` 80 EnvConf string `position:"Query" name:"EnvConf"` 81 Description string `position:"Query" name:"Description"` 82 ClusterId string `position:"Query" name:"ClusterId"` 83 Type string `position:"Query" name:"Type"` 84 Params string `position:"Query" name:"Params"` 85 ParamConf string `position:"Query" name:"ParamConf"` 86 ResourceList *[]CreateFlowJobResourceList `position:"Query" name:"ResourceList" type:"Repeated"` 87 FailAct string `position:"Query" name:"FailAct"` 88 Mode string `position:"Query" name:"Mode"` 89 RetryInterval requests.Integer `position:"Query" name:"RetryInterval"` 90 MonitorConf string `position:"Query" name:"MonitorConf"` 91 Name string `position:"Query" name:"Name"` 92 MaxRetry requests.Integer `position:"Query" name:"MaxRetry"` 93 Adhoc requests.Boolean `position:"Query" name:"Adhoc"` 94 AlertConf string `position:"Query" name:"AlertConf"` 95 ProjectId string `position:"Query" name:"ProjectId"` 96 ParentCategory string `position:"Query" name:"ParentCategory"` 97} 98 99// CreateFlowJobResourceList is a repeated param struct in CreateFlowJobRequest 100type CreateFlowJobResourceList struct { 101 Path string `name:"Path"` 102 Alias string `name:"Alias"` 103} 104 105// CreateFlowJobResponse is the response struct for api CreateFlowJob 106type CreateFlowJobResponse struct { 107 *responses.BaseResponse 108 RequestId string `json:"RequestId" xml:"RequestId"` 109 Id string `json:"Id" xml:"Id"` 110} 111 112// CreateCreateFlowJobRequest creates a request to invoke CreateFlowJob API 113func CreateCreateFlowJobRequest() (request *CreateFlowJobRequest) { 114 request = &CreateFlowJobRequest{ 115 RpcRequest: &requests.RpcRequest{}, 116 } 117 request.InitWithApiInfo("Emr", "2016-04-08", "CreateFlowJob", "emr", "openAPI") 118 return 119} 120 121// CreateCreateFlowJobResponse creates a response to parse from CreateFlowJob response 122func CreateCreateFlowJobResponse() (response *CreateFlowJobResponse) { 123 response = &CreateFlowJobResponse{ 124 BaseResponse: &responses.BaseResponse{}, 125 } 126 return 127} 128