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