1package ens
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// CreateLoadBalancerHTTPListener invokes the ens.CreateLoadBalancerHTTPListener API synchronously
24func (client *Client) CreateLoadBalancerHTTPListener(request *CreateLoadBalancerHTTPListenerRequest) (response *CreateLoadBalancerHTTPListenerResponse, err error) {
25	response = CreateCreateLoadBalancerHTTPListenerResponse()
26	err = client.DoAction(request, response)
27	return
28}
29
30// CreateLoadBalancerHTTPListenerWithChan invokes the ens.CreateLoadBalancerHTTPListener API asynchronously
31func (client *Client) CreateLoadBalancerHTTPListenerWithChan(request *CreateLoadBalancerHTTPListenerRequest) (<-chan *CreateLoadBalancerHTTPListenerResponse, <-chan error) {
32	responseChan := make(chan *CreateLoadBalancerHTTPListenerResponse, 1)
33	errChan := make(chan error, 1)
34	err := client.AddAsyncTask(func() {
35		defer close(responseChan)
36		defer close(errChan)
37		response, err := client.CreateLoadBalancerHTTPListener(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// CreateLoadBalancerHTTPListenerWithCallback invokes the ens.CreateLoadBalancerHTTPListener API asynchronously
53func (client *Client) CreateLoadBalancerHTTPListenerWithCallback(request *CreateLoadBalancerHTTPListenerRequest, callback func(response *CreateLoadBalancerHTTPListenerResponse, err error)) <-chan int {
54	result := make(chan int, 1)
55	err := client.AddAsyncTask(func() {
56		var response *CreateLoadBalancerHTTPListenerResponse
57		var err error
58		defer close(result)
59		response, err = client.CreateLoadBalancerHTTPListener(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// CreateLoadBalancerHTTPListenerRequest is the request struct for api CreateLoadBalancerHTTPListener
72type CreateLoadBalancerHTTPListenerRequest struct {
73	*requests.RpcRequest
74	ListenerForward        string           `position:"Query" name:"ListenerForward"`
75	HealthCheckTimeout     requests.Integer `position:"Query" name:"HealthCheckTimeout"`
76	XForwardedFor          string           `position:"Query" name:"XForwardedFor"`
77	HealthCheckURI         string           `position:"Query" name:"HealthCheckURI"`
78	HealthCheck            string           `position:"Query" name:"HealthCheck"`
79	Protocol               string           `position:"Query" name:"Protocol"`
80	Cookie                 string           `position:"Query" name:"Cookie"`
81	HealthCheckMethod      string           `position:"Query" name:"HealthCheckMethod"`
82	HealthCheckDomain      string           `position:"Query" name:"HealthCheckDomain"`
83	RequestTimeout         requests.Integer `position:"Query" name:"RequestTimeout"`
84	LoadBalancerId         string           `position:"Query" name:"LoadBalancerId"`
85	HealthCheckInterval    requests.Integer `position:"Query" name:"HealthCheckInterval"`
86	Description            string           `position:"Query" name:"Description"`
87	UnhealthyThreshold     requests.Integer `position:"Query" name:"UnhealthyThreshold"`
88	HealthyThreshold       requests.Integer `position:"Query" name:"HealthyThreshold"`
89	Scheduler              string           `position:"Query" name:"Scheduler"`
90	ForwardPort            requests.Integer `position:"Query" name:"ForwardPort"`
91	CookieTimeout          requests.Integer `position:"Query" name:"CookieTimeout"`
92	StickySessionType      string           `position:"Query" name:"StickySessionType"`
93	ListenerPort           requests.Integer `position:"Query" name:"ListenerPort"`
94	StickySession          string           `position:"Query" name:"StickySession"`
95	IdleTimeout            requests.Integer `position:"Query" name:"IdleTimeout"`
96	HealthCheckConnectPort requests.Integer `position:"Query" name:"HealthCheckConnectPort"`
97	HealthCheckHttpCode    string           `position:"Query" name:"HealthCheckHttpCode"`
98}
99
100// CreateLoadBalancerHTTPListenerResponse is the response struct for api CreateLoadBalancerHTTPListener
101type CreateLoadBalancerHTTPListenerResponse struct {
102	*responses.BaseResponse
103	RequestId string `json:"RequestId" xml:"RequestId"`
104}
105
106// CreateCreateLoadBalancerHTTPListenerRequest creates a request to invoke CreateLoadBalancerHTTPListener API
107func CreateCreateLoadBalancerHTTPListenerRequest() (request *CreateLoadBalancerHTTPListenerRequest) {
108	request = &CreateLoadBalancerHTTPListenerRequest{
109		RpcRequest: &requests.RpcRequest{},
110	}
111	request.InitWithApiInfo("Ens", "2017-11-10", "CreateLoadBalancerHTTPListener", "ens", "openAPI")
112	request.Method = requests.POST
113	return
114}
115
116// CreateCreateLoadBalancerHTTPListenerResponse creates a response to parse from CreateLoadBalancerHTTPListener response
117func CreateCreateLoadBalancerHTTPListenerResponse() (response *CreateLoadBalancerHTTPListenerResponse) {
118	response = &CreateLoadBalancerHTTPListenerResponse{
119		BaseResponse: &responses.BaseResponse{},
120	}
121	return
122}
123