/
getLoadBalancer.go
95 lines (90 loc) · 3.54 KB
/
getLoadBalancer.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package alb
import (
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
// > **Note:** `alb.LoadBalancer` is known as `lb.LoadBalancer`. The functionality is identical.
//
// Provides information about a Load Balancer.
//
// This data source can prove useful when a module accepts an LB as an input
// variable and needs to, for example, determine the security groups associated
// with it, etc.
//
// ## Example Usage
//
// ```go
// package main
//
// import (
// "github.com/pulumi/pulumi-aws/sdk/v4/go/aws/lb"
// "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
// "github.com/pulumi/pulumi/sdk/v3/go/pulumi/config"
// )
//
// func main() {
// pulumi.Run(func(ctx *pulumi.Context) error {
// cfg := config.New(ctx, "")
// lbArn := ""
// if param := cfg.Get("lbArn"); param != "" {
// lbArn = param
// }
// lbName := ""
// if param := cfg.Get("lbName"); param != "" {
// lbName = param
// }
// opt0 := lbArn
// opt1 := lbName
// _, err := lb.LookupLoadBalancer(ctx, &lb.LookupLoadBalancerArgs{
// Arn: &opt0,
// Name: &opt1,
// }, nil)
// if err != nil {
// return err
// }
// return nil
// })
// }
// ```
func LookupLoadBalancer(ctx *pulumi.Context, args *LookupLoadBalancerArgs, opts ...pulumi.InvokeOption) (*LookupLoadBalancerResult, error) {
var rv LookupLoadBalancerResult
err := ctx.Invoke("aws:alb/getLoadBalancer:getLoadBalancer", args, &rv, opts...)
if err != nil {
return nil, err
}
return &rv, nil
}
// A collection of arguments for invoking getLoadBalancer.
type LookupLoadBalancerArgs struct {
// The full ARN of the load balancer.
Arn *string `pulumi:"arn"`
// The unique name of the load balancer.
Name *string `pulumi:"name"`
// A mapping of tags, each pair of which must exactly match a pair on the desired load balancer.
Tags map[string]string `pulumi:"tags"`
}
// A collection of values returned by getLoadBalancer.
type LookupLoadBalancerResult struct {
AccessLogs GetLoadBalancerAccessLogs `pulumi:"accessLogs"`
Arn string `pulumi:"arn"`
ArnSuffix string `pulumi:"arnSuffix"`
CustomerOwnedIpv4Pool string `pulumi:"customerOwnedIpv4Pool"`
DnsName string `pulumi:"dnsName"`
DropInvalidHeaderFields bool `pulumi:"dropInvalidHeaderFields"`
EnableDeletionProtection bool `pulumi:"enableDeletionProtection"`
EnableHttp2 bool `pulumi:"enableHttp2"`
// The provider-assigned unique ID for this managed resource.
Id string `pulumi:"id"`
IdleTimeout int `pulumi:"idleTimeout"`
Internal bool `pulumi:"internal"`
IpAddressType string `pulumi:"ipAddressType"`
LoadBalancerType string `pulumi:"loadBalancerType"`
Name string `pulumi:"name"`
SecurityGroups []string `pulumi:"securityGroups"`
SubnetMappings []GetLoadBalancerSubnetMapping `pulumi:"subnetMappings"`
Subnets []string `pulumi:"subnets"`
Tags map[string]string `pulumi:"tags"`
VpcId string `pulumi:"vpcId"`
ZoneId string `pulumi:"zoneId"`
}