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// StopCluster invokes the ehpc.StopCluster API synchronously
24func (client *Client) StopCluster(request *StopClusterRequest) (response *StopClusterResponse, err error) {
25	response = CreateStopClusterResponse()
26	err = client.DoAction(request, response)
27	return
28}
29
30// StopClusterWithChan invokes the ehpc.StopCluster API asynchronously
31func (client *Client) StopClusterWithChan(request *StopClusterRequest) (<-chan *StopClusterResponse, <-chan error) {
32	responseChan := make(chan *StopClusterResponse, 1)
33	errChan := make(chan error, 1)
34	err := client.AddAsyncTask(func() {
35		defer close(responseChan)
36		defer close(errChan)
37		response, err := client.StopCluster(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// StopClusterWithCallback invokes the ehpc.StopCluster API asynchronously
53func (client *Client) StopClusterWithCallback(request *StopClusterRequest, callback func(response *StopClusterResponse, err error)) <-chan int {
54	result := make(chan int, 1)
55	err := client.AddAsyncTask(func() {
56		var response *StopClusterResponse
57		var err error
58		defer close(result)
59		response, err = client.StopCluster(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// StopClusterRequest is the request struct for api StopCluster
72type StopClusterRequest struct {
73	*requests.RpcRequest
74	ClusterId string `position:"Query" name:"ClusterId"`
75}
76
77// StopClusterResponse is the response struct for api StopCluster
78type StopClusterResponse struct {
79	*responses.BaseResponse
80	RequestId string `json:"RequestId" xml:"RequestId"`
81	TaskId    string `json:"TaskId" xml:"TaskId"`
82}
83
84// CreateStopClusterRequest creates a request to invoke StopCluster API
85func CreateStopClusterRequest() (request *StopClusterRequest) {
86	request = &StopClusterRequest{
87		RpcRequest: &requests.RpcRequest{},
88	}
89	request.InitWithApiInfo("EHPC", "2018-04-12", "StopCluster", "", "")
90	request.Method = requests.GET
91	return
92}
93
94// CreateStopClusterResponse creates a response to parse from StopCluster response
95func CreateStopClusterResponse() (response *StopClusterResponse) {
96	response = &StopClusterResponse{
97		BaseResponse: &responses.BaseResponse{},
98	}
99	return
100}
101