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// DescribeFlowNodeInstance invokes the emr.DescribeFlowNodeInstance API synchronously
24// api document: https://help.aliyun.com/api/emr/describeflownodeinstance.html
25func (client *Client) DescribeFlowNodeInstance(request *DescribeFlowNodeInstanceRequest) (response *DescribeFlowNodeInstanceResponse, err error) {
26	response = CreateDescribeFlowNodeInstanceResponse()
27	err = client.DoAction(request, response)
28	return
29}
30
31// DescribeFlowNodeInstanceWithChan invokes the emr.DescribeFlowNodeInstance API asynchronously
32// api document: https://help.aliyun.com/api/emr/describeflownodeinstance.html
33// asynchronous document: https://help.aliyun.com/document_detail/66220.html
34func (client *Client) DescribeFlowNodeInstanceWithChan(request *DescribeFlowNodeInstanceRequest) (<-chan *DescribeFlowNodeInstanceResponse, <-chan error) {
35	responseChan := make(chan *DescribeFlowNodeInstanceResponse, 1)
36	errChan := make(chan error, 1)
37	err := client.AddAsyncTask(func() {
38		defer close(responseChan)
39		defer close(errChan)
40		response, err := client.DescribeFlowNodeInstance(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// DescribeFlowNodeInstanceWithCallback invokes the emr.DescribeFlowNodeInstance API asynchronously
56// api document: https://help.aliyun.com/api/emr/describeflownodeinstance.html
57// asynchronous document: https://help.aliyun.com/document_detail/66220.html
58func (client *Client) DescribeFlowNodeInstanceWithCallback(request *DescribeFlowNodeInstanceRequest, callback func(response *DescribeFlowNodeInstanceResponse, err error)) <-chan int {
59	result := make(chan int, 1)
60	err := client.AddAsyncTask(func() {
61		var response *DescribeFlowNodeInstanceResponse
62		var err error
63		defer close(result)
64		response, err = client.DescribeFlowNodeInstance(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// DescribeFlowNodeInstanceRequest is the request struct for api DescribeFlowNodeInstance
77type DescribeFlowNodeInstanceRequest struct {
78	*requests.RpcRequest
79	Id        string `position:"Query" name:"Id"`
80	ProjectId string `position:"Query" name:"ProjectId"`
81}
82
83// DescribeFlowNodeInstanceResponse is the response struct for api DescribeFlowNodeInstance
84type DescribeFlowNodeInstanceResponse struct {
85	*responses.BaseResponse
86	RequestId        string `json:"RequestId" xml:"RequestId"`
87	Id               string `json:"Id" xml:"Id"`
88	GmtCreate        int    `json:"GmtCreate" xml:"GmtCreate"`
89	GmtModified      int    `json:"GmtModified" xml:"GmtModified"`
90	Type             string `json:"Type" xml:"Type"`
91	Status           string `json:"Status" xml:"Status"`
92	JobId            string `json:"JobId" xml:"JobId"`
93	JobName          string `json:"JobName" xml:"JobName"`
94	JobType          string `json:"JobType" xml:"JobType"`
95	JobParams        string `json:"JobParams" xml:"JobParams"`
96	FailAct          string `json:"FailAct" xml:"FailAct"`
97	MaxRetry         string `json:"MaxRetry" xml:"MaxRetry"`
98	RetryInterval    string `json:"RetryInterval" xml:"RetryInterval"`
99	NodeName         string `json:"NodeName" xml:"NodeName"`
100	FlowId           string `json:"FlowId" xml:"FlowId"`
101	FlowInstanceId   string `json:"FlowInstanceId" xml:"FlowInstanceId"`
102	ClusterId        string `json:"ClusterId" xml:"ClusterId"`
103	HostName         string `json:"HostName" xml:"HostName"`
104	ProjectId        string `json:"ProjectId" xml:"ProjectId"`
105	Pending          bool   `json:"Pending" xml:"Pending"`
106	StartTime        int    `json:"StartTime" xml:"StartTime"`
107	EndTime          int    `json:"EndTime" xml:"EndTime"`
108	Duration         int    `json:"Duration" xml:"Duration"`
109	Retries          int    `json:"Retries" xml:"Retries"`
110	ExternalId       string `json:"ExternalId" xml:"ExternalId"`
111	ExternalSubId    string `json:"ExternalSubId" xml:"ExternalSubId"`
112	ExternalChildIds string `json:"ExternalChildIds" xml:"ExternalChildIds"`
113	ExternalStatus   string `json:"ExternalStatus" xml:"ExternalStatus"`
114	ExternalInfo     string `json:"ExternalInfo" xml:"ExternalInfo"`
115	ParamConf        string `json:"ParamConf" xml:"ParamConf"`
116	EnvConf          string `json:"EnvConf" xml:"EnvConf"`
117	RunConf          string `json:"RunConf" xml:"RunConf"`
118	Adhoc            bool   `json:"Adhoc" xml:"Adhoc"`
119	MonitorConf      string `json:"MonitorConf" xml:"MonitorConf"`
120	Mode             string `json:"Mode" xml:"Mode"`
121	ClusterName      string `json:"ClusterName" xml:"ClusterName"`
122}
123
124// CreateDescribeFlowNodeInstanceRequest creates a request to invoke DescribeFlowNodeInstance API
125func CreateDescribeFlowNodeInstanceRequest() (request *DescribeFlowNodeInstanceRequest) {
126	request = &DescribeFlowNodeInstanceRequest{
127		RpcRequest: &requests.RpcRequest{},
128	}
129	request.InitWithApiInfo("Emr", "2016-04-08", "DescribeFlowNodeInstance", "emr", "openAPI")
130	return
131}
132
133// CreateDescribeFlowNodeInstanceResponse creates a response to parse from DescribeFlowNodeInstance response
134func CreateDescribeFlowNodeInstanceResponse() (response *DescribeFlowNodeInstanceResponse) {
135	response = &DescribeFlowNodeInstanceResponse{
136		BaseResponse: &responses.BaseResponse{},
137	}
138	return
139}
140