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