1package ecs
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// CreateHpcCluster invokes the ecs.CreateHpcCluster API synchronously
24func (client *Client) CreateHpcCluster(request *CreateHpcClusterRequest) (response *CreateHpcClusterResponse, err error) {
25	response = CreateCreateHpcClusterResponse()
26	err = client.DoAction(request, response)
27	return
28}
29
30// CreateHpcClusterWithChan invokes the ecs.CreateHpcCluster API asynchronously
31func (client *Client) CreateHpcClusterWithChan(request *CreateHpcClusterRequest) (<-chan *CreateHpcClusterResponse, <-chan error) {
32	responseChan := make(chan *CreateHpcClusterResponse, 1)
33	errChan := make(chan error, 1)
34	err := client.AddAsyncTask(func() {
35		defer close(responseChan)
36		defer close(errChan)
37		response, err := client.CreateHpcCluster(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// CreateHpcClusterWithCallback invokes the ecs.CreateHpcCluster API asynchronously
53func (client *Client) CreateHpcClusterWithCallback(request *CreateHpcClusterRequest, callback func(response *CreateHpcClusterResponse, err error)) <-chan int {
54	result := make(chan int, 1)
55	err := client.AddAsyncTask(func() {
56		var response *CreateHpcClusterResponse
57		var err error
58		defer close(result)
59		response, err = client.CreateHpcCluster(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// CreateHpcClusterRequest is the request struct for api CreateHpcCluster
72type CreateHpcClusterRequest struct {
73	*requests.RpcRequest
74	ResourceOwnerId      requests.Integer `position:"Query" name:"ResourceOwnerId"`
75	ClientToken          string           `position:"Query" name:"ClientToken"`
76	Description          string           `position:"Query" name:"Description"`
77	ResourceOwnerAccount string           `position:"Query" name:"ResourceOwnerAccount"`
78	OwnerAccount         string           `position:"Query" name:"OwnerAccount"`
79	OwnerId              requests.Integer `position:"Query" name:"OwnerId"`
80	Name                 string           `position:"Query" name:"Name"`
81}
82
83// CreateHpcClusterResponse is the response struct for api CreateHpcCluster
84type CreateHpcClusterResponse struct {
85	*responses.BaseResponse
86	RequestId    string `json:"RequestId" xml:"RequestId"`
87	HpcClusterId string `json:"HpcClusterId" xml:"HpcClusterId"`
88}
89
90// CreateCreateHpcClusterRequest creates a request to invoke CreateHpcCluster API
91func CreateCreateHpcClusterRequest() (request *CreateHpcClusterRequest) {
92	request = &CreateHpcClusterRequest{
93		RpcRequest: &requests.RpcRequest{},
94	}
95	request.InitWithApiInfo("Ecs", "2014-05-26", "CreateHpcCluster", "ecs", "openAPI")
96	request.Method = requests.POST
97	return
98}
99
100// CreateCreateHpcClusterResponse creates a response to parse from CreateHpcCluster response
101func CreateCreateHpcClusterResponse() (response *CreateHpcClusterResponse) {
102	response = &CreateHpcClusterResponse{
103		BaseResponse: &responses.BaseResponse{},
104	}
105	return
106}
107