list_clusters.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. package emr
  2. //Licensed under the Apache License, Version 2.0 (the "License");
  3. //you may not use this file except in compliance with the License.
  4. //You may obtain a copy of the License at
  5. //
  6. //http://www.apache.org/licenses/LICENSE-2.0
  7. //
  8. //Unless required by applicable law or agreed to in writing, software
  9. //distributed under the License is distributed on an "AS IS" BASIS,
  10. //WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. //See the License for the specific language governing permissions and
  12. //limitations under the License.
  13. //
  14. // Code generated by Alibaba Cloud SDK Code Generator.
  15. // Changes may cause incorrect behavior and will be lost if the code is regenerated.
  16. import (
  17. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
  18. "github.com/aliyun/alibaba-cloud-sdk-go/sdk/responses"
  19. )
  20. func (client *Client) ListClusters(request *ListClustersRequest) (response *ListClustersResponse, err error) {
  21. response = CreateListClustersResponse()
  22. err = client.DoAction(request, response)
  23. return
  24. }
  25. func (client *Client) ListClustersWithChan(request *ListClustersRequest) (<-chan *ListClustersResponse, <-chan error) {
  26. responseChan := make(chan *ListClustersResponse, 1)
  27. errChan := make(chan error, 1)
  28. err := client.AddAsyncTask(func() {
  29. defer close(responseChan)
  30. defer close(errChan)
  31. response, err := client.ListClusters(request)
  32. responseChan <- response
  33. errChan <- err
  34. })
  35. if err != nil {
  36. errChan <- err
  37. close(responseChan)
  38. close(errChan)
  39. }
  40. return responseChan, errChan
  41. }
  42. func (client *Client) ListClustersWithCallback(request *ListClustersRequest, callback func(response *ListClustersResponse, err error)) <-chan int {
  43. result := make(chan int, 1)
  44. err := client.AddAsyncTask(func() {
  45. var response *ListClustersResponse
  46. var err error
  47. defer close(result)
  48. response, err = client.ListClusters(request)
  49. callback(response, err)
  50. result <- 1
  51. })
  52. if err != nil {
  53. defer close(result)
  54. callback(nil, err)
  55. result <- 0
  56. }
  57. return result
  58. }
  59. type ListClustersRequest struct {
  60. *requests.RpcRequest
  61. PageSize string `position:"Query" name:"PageSize"`
  62. PageNumber string `position:"Query" name:"PageNumber"`
  63. IsDesc string `position:"Query" name:"IsDesc"`
  64. ClusterTypeList *[]string `position:"Query" name:"ClusterTypeList" type:"Repeated"`
  65. CreateType string `position:"Query" name:"CreateType"`
  66. ResourceOwnerId string `position:"Query" name:"ResourceOwnerId"`
  67. StatusList *[]string `position:"Query" name:"StatusList" type:"Repeated"`
  68. DefaultStatus string `position:"Query" name:"DefaultStatus"`
  69. }
  70. type ListClustersResponse struct {
  71. *responses.BaseResponse
  72. RequestId string `json:"RequestId" xml:"RequestId"`
  73. TotalCount int `json:"TotalCount" xml:"TotalCount"`
  74. PageNumber int `json:"PageNumber" xml:"PageNumber"`
  75. PageSize int `json:"PageSize" xml:"PageSize"`
  76. Clusters []struct {
  77. Id string `json:"Id" xml:"Id"`
  78. Name string `json:"Name" xml:"Name"`
  79. Type string `json:"Type" xml:"Type"`
  80. CreateTime int64 `json:"CreateTime" xml:"CreateTime"`
  81. RunningTime int `json:"RunningTime" xml:"RunningTime"`
  82. Status string `json:"Status" xml:"Status"`
  83. ChargeType string `json:"ChargeType" xml:"ChargeType"`
  84. ExpiredTime int64 `json:"ExpiredTime" xml:"ExpiredTime"`
  85. Period int `json:"Period" xml:"Period"`
  86. HasUncompletedOrder bool `json:"HasUncompletedOrder" xml:"HasUncompletedOrder"`
  87. OrderList string `json:"OrderList" xml:"OrderList"`
  88. CreateResource string `json:"CreateResource" xml:"CreateResource"`
  89. OrderTaskInfo struct {
  90. TargetCount int `json:"TargetCount" xml:"TargetCount"`
  91. CurrentCount int `json:"CurrentCount" xml:"CurrentCount"`
  92. OrderIdList string `json:"OrderIdList" xml:"OrderIdList"`
  93. } `json:"OrderTaskInfo" xml:"OrderTaskInfo"`
  94. FailReason struct {
  95. ErrorCode string `json:"ErrorCode" xml:"ErrorCode"`
  96. ErrorMsg string `json:"ErrorMsg" xml:"ErrorMsg"`
  97. RequestId string `json:"RequestId" xml:"RequestId"`
  98. } `json:"FailReason" xml:"FailReason"`
  99. } `json:"Clusters" xml:"Clusters"`
  100. }
  101. func CreateListClustersRequest() (request *ListClustersRequest) {
  102. request = &ListClustersRequest{
  103. RpcRequest: &requests.RpcRequest{},
  104. }
  105. request.InitWithApiInfo("Emr", "2016-04-08", "ListClusters", "", "")
  106. return
  107. }
  108. func CreateListClustersResponse() (response *ListClustersResponse) {
  109. response = &ListClustersResponse{
  110. BaseResponse: &responses.BaseResponse{},
  111. }
  112. return
  113. }