1package vpc 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// DescribePhysicalConnections invokes the vpc.DescribePhysicalConnections API synchronously 24// api document: https://help.aliyun.com/api/vpc/describephysicalconnections.html 25func (client *Client) DescribePhysicalConnections(request *DescribePhysicalConnectionsRequest) (response *DescribePhysicalConnectionsResponse, err error) { 26 response = CreateDescribePhysicalConnectionsResponse() 27 err = client.DoAction(request, response) 28 return 29} 30 31// DescribePhysicalConnectionsWithChan invokes the vpc.DescribePhysicalConnections API asynchronously 32// api document: https://help.aliyun.com/api/vpc/describephysicalconnections.html 33// asynchronous document: https://help.aliyun.com/document_detail/66220.html 34func (client *Client) DescribePhysicalConnectionsWithChan(request *DescribePhysicalConnectionsRequest) (<-chan *DescribePhysicalConnectionsResponse, <-chan error) { 35 responseChan := make(chan *DescribePhysicalConnectionsResponse, 1) 36 errChan := make(chan error, 1) 37 err := client.AddAsyncTask(func() { 38 defer close(responseChan) 39 defer close(errChan) 40 response, err := client.DescribePhysicalConnections(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// DescribePhysicalConnectionsWithCallback invokes the vpc.DescribePhysicalConnections API asynchronously 56// api document: https://help.aliyun.com/api/vpc/describephysicalconnections.html 57// asynchronous document: https://help.aliyun.com/document_detail/66220.html 58func (client *Client) DescribePhysicalConnectionsWithCallback(request *DescribePhysicalConnectionsRequest, callback func(response *DescribePhysicalConnectionsResponse, err error)) <-chan int { 59 result := make(chan int, 1) 60 err := client.AddAsyncTask(func() { 61 var response *DescribePhysicalConnectionsResponse 62 var err error 63 defer close(result) 64 response, err = client.DescribePhysicalConnections(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// DescribePhysicalConnectionsRequest is the request struct for api DescribePhysicalConnections 77type DescribePhysicalConnectionsRequest struct { 78 *requests.RpcRequest 79 Filter *[]DescribePhysicalConnectionsFilter `position:"Query" name:"Filter" type:"Repeated"` 80 ResourceOwnerId requests.Integer `position:"Query" name:"ResourceOwnerId"` 81 ResourceOwnerAccount string `position:"Query" name:"ResourceOwnerAccount"` 82 ClientToken string `position:"Query" name:"ClientToken"` 83 OwnerAccount string `position:"Query" name:"OwnerAccount"` 84 PageSize requests.Integer `position:"Query" name:"PageSize"` 85 OwnerId requests.Integer `position:"Query" name:"OwnerId"` 86 IncludeReservationData requests.Boolean `position:"Query" name:"IncludeReservationData"` 87 PageNumber requests.Integer `position:"Query" name:"PageNumber"` 88} 89 90// DescribePhysicalConnectionsFilter is a repeated param struct in DescribePhysicalConnectionsRequest 91type DescribePhysicalConnectionsFilter struct { 92 Value *[]string `name:"Value" type:"Repeated"` 93 Key string `name:"Key"` 94} 95 96// DescribePhysicalConnectionsResponse is the response struct for api DescribePhysicalConnections 97type DescribePhysicalConnectionsResponse struct { 98 *responses.BaseResponse 99 RequestId string `json:"RequestId" xml:"RequestId"` 100 PageNumber int `json:"PageNumber" xml:"PageNumber"` 101 PageSize int `json:"PageSize" xml:"PageSize"` 102 TotalCount int `json:"TotalCount" xml:"TotalCount"` 103 PhysicalConnectionSet PhysicalConnectionSet `json:"PhysicalConnectionSet" xml:"PhysicalConnectionSet"` 104} 105 106// CreateDescribePhysicalConnectionsRequest creates a request to invoke DescribePhysicalConnections API 107func CreateDescribePhysicalConnectionsRequest() (request *DescribePhysicalConnectionsRequest) { 108 request = &DescribePhysicalConnectionsRequest{ 109 RpcRequest: &requests.RpcRequest{}, 110 } 111 request.InitWithApiInfo("Vpc", "2016-04-28", "DescribePhysicalConnections", "vpc", "openAPI") 112 return 113} 114 115// CreateDescribePhysicalConnectionsResponse creates a response to parse from DescribePhysicalConnections response 116func CreateDescribePhysicalConnectionsResponse() (response *DescribePhysicalConnectionsResponse) { 117 response = &DescribePhysicalConnectionsResponse{ 118 BaseResponse: &responses.BaseResponse{}, 119 } 120 return 121} 122