1package ehpc
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// ListInvocationStatus invokes the ehpc.ListInvocationStatus API synchronously
24func (client *Client) ListInvocationStatus(request *ListInvocationStatusRequest) (response *ListInvocationStatusResponse, err error) {
25	response = CreateListInvocationStatusResponse()
26	err = client.DoAction(request, response)
27	return
28}
29
30// ListInvocationStatusWithChan invokes the ehpc.ListInvocationStatus API asynchronously
31func (client *Client) ListInvocationStatusWithChan(request *ListInvocationStatusRequest) (<-chan *ListInvocationStatusResponse, <-chan error) {
32	responseChan := make(chan *ListInvocationStatusResponse, 1)
33	errChan := make(chan error, 1)
34	err := client.AddAsyncTask(func() {
35		defer close(responseChan)
36		defer close(errChan)
37		response, err := client.ListInvocationStatus(request)
38		if err != nil {
39			errChan <- err
40		} else {
41			responseChan <- response
42		}
43	})
44	if err != nil {
45		errChan <- err
46		close(responseChan)
47		close(errChan)
48	}
49	return responseChan, errChan
50}
51
52// ListInvocationStatusWithCallback invokes the ehpc.ListInvocationStatus API asynchronously
53func (client *Client) ListInvocationStatusWithCallback(request *ListInvocationStatusRequest, callback func(response *ListInvocationStatusResponse, err error)) <-chan int {
54	result := make(chan int, 1)
55	err := client.AddAsyncTask(func() {
56		var response *ListInvocationStatusResponse
57		var err error
58		defer close(result)
59		response, err = client.ListInvocationStatus(request)
60		callback(response, err)
61		result <- 1
62	})
63	if err != nil {
64		defer close(result)
65		callback(nil, err)
66		result <- 0
67	}
68	return result
69}
70
71// ListInvocationStatusRequest is the request struct for api ListInvocationStatus
72type ListInvocationStatusRequest struct {
73	*requests.RpcRequest
74	ClusterId string `position:"Query" name:"ClusterId"`
75	CommandId string `position:"Query" name:"CommandId"`
76}
77
78// ListInvocationStatusResponse is the response struct for api ListInvocationStatus
79type ListInvocationStatusResponse struct {
80	*responses.BaseResponse
81	RequestId       string          `json:"RequestId" xml:"RequestId"`
82	CommandId       string          `json:"CommandId" xml:"CommandId"`
83	InvokeStatus    string          `json:"InvokeStatus" xml:"InvokeStatus"`
84	InvokeInstances InvokeInstances `json:"InvokeInstances" xml:"InvokeInstances"`
85}
86
87// CreateListInvocationStatusRequest creates a request to invoke ListInvocationStatus API
88func CreateListInvocationStatusRequest() (request *ListInvocationStatusRequest) {
89	request = &ListInvocationStatusRequest{
90		RpcRequest: &requests.RpcRequest{},
91	}
92	request.InitWithApiInfo("EHPC", "2018-04-12", "ListInvocationStatus", "", "")
93	request.Method = requests.GET
94	return
95}
96
97// CreateListInvocationStatusResponse creates a response to parse from ListInvocationStatus response
98func CreateListInvocationStatusResponse() (response *ListInvocationStatusResponse) {
99	response = &ListInvocationStatusResponse{
100		BaseResponse: &responses.BaseResponse{},
101	}
102	return
103}
104