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