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