Documentation ¶
Index ¶
- type DelegationSet
- type DelegationSetArgs
- type DelegationSetState
- type GetResolverRulesArgs
- type GetResolverRulesResult
- type HealthCheck
- type HealthCheckArgs
- type HealthCheckState
- type LookupDelegationSetArgs
- type LookupDelegationSetResult
- type LookupResolverRuleArgs
- type LookupResolverRuleResult
- type LookupZoneArgs
- type LookupZoneResult
- type QueryLog
- type QueryLogArgs
- type QueryLogState
- type Record
- type RecordAlias
- type RecordAliasArgs
- type RecordAliasArray
- type RecordAliasArrayInput
- type RecordAliasArrayOutput
- func (RecordAliasArrayOutput) ElementType() reflect.Type
- func (o RecordAliasArrayOutput) Index(i pulumi.IntInput) RecordAliasOutput
- func (o RecordAliasArrayOutput) ToRecordAliasArrayOutput() RecordAliasArrayOutput
- func (o RecordAliasArrayOutput) ToRecordAliasArrayOutputWithContext(ctx context.Context) RecordAliasArrayOutput
- type RecordAliasInput
- type RecordAliasOutput
- func (RecordAliasOutput) ElementType() reflect.Type
- func (o RecordAliasOutput) EvaluateTargetHealth() pulumi.BoolOutput
- func (o RecordAliasOutput) Name() pulumi.StringOutput
- func (o RecordAliasOutput) ToRecordAliasOutput() RecordAliasOutput
- func (o RecordAliasOutput) ToRecordAliasOutputWithContext(ctx context.Context) RecordAliasOutput
- func (o RecordAliasOutput) ZoneId() pulumi.StringOutput
- type RecordArgs
- type RecordFailoverRoutingPolicy
- type RecordFailoverRoutingPolicyArgs
- func (RecordFailoverRoutingPolicyArgs) ElementType() reflect.Type
- func (i RecordFailoverRoutingPolicyArgs) ToRecordFailoverRoutingPolicyOutput() RecordFailoverRoutingPolicyOutput
- func (i RecordFailoverRoutingPolicyArgs) ToRecordFailoverRoutingPolicyOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyOutput
- type RecordFailoverRoutingPolicyArray
- func (RecordFailoverRoutingPolicyArray) ElementType() reflect.Type
- func (i RecordFailoverRoutingPolicyArray) ToRecordFailoverRoutingPolicyArrayOutput() RecordFailoverRoutingPolicyArrayOutput
- func (i RecordFailoverRoutingPolicyArray) ToRecordFailoverRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyArrayOutput
- type RecordFailoverRoutingPolicyArrayInput
- type RecordFailoverRoutingPolicyArrayOutput
- func (RecordFailoverRoutingPolicyArrayOutput) ElementType() reflect.Type
- func (o RecordFailoverRoutingPolicyArrayOutput) Index(i pulumi.IntInput) RecordFailoverRoutingPolicyOutput
- func (o RecordFailoverRoutingPolicyArrayOutput) ToRecordFailoverRoutingPolicyArrayOutput() RecordFailoverRoutingPolicyArrayOutput
- func (o RecordFailoverRoutingPolicyArrayOutput) ToRecordFailoverRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyArrayOutput
- type RecordFailoverRoutingPolicyInput
- type RecordFailoverRoutingPolicyOutput
- func (RecordFailoverRoutingPolicyOutput) ElementType() reflect.Type
- func (o RecordFailoverRoutingPolicyOutput) ToRecordFailoverRoutingPolicyOutput() RecordFailoverRoutingPolicyOutput
- func (o RecordFailoverRoutingPolicyOutput) ToRecordFailoverRoutingPolicyOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyOutput
- func (o RecordFailoverRoutingPolicyOutput) Type() pulumi.StringOutput
- type RecordGeolocationRoutingPolicy
- type RecordGeolocationRoutingPolicyArgs
- func (RecordGeolocationRoutingPolicyArgs) ElementType() reflect.Type
- func (i RecordGeolocationRoutingPolicyArgs) ToRecordGeolocationRoutingPolicyOutput() RecordGeolocationRoutingPolicyOutput
- func (i RecordGeolocationRoutingPolicyArgs) ToRecordGeolocationRoutingPolicyOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyOutput
- type RecordGeolocationRoutingPolicyArray
- func (RecordGeolocationRoutingPolicyArray) ElementType() reflect.Type
- func (i RecordGeolocationRoutingPolicyArray) ToRecordGeolocationRoutingPolicyArrayOutput() RecordGeolocationRoutingPolicyArrayOutput
- func (i RecordGeolocationRoutingPolicyArray) ToRecordGeolocationRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyArrayOutput
- type RecordGeolocationRoutingPolicyArrayInput
- type RecordGeolocationRoutingPolicyArrayOutput
- func (RecordGeolocationRoutingPolicyArrayOutput) ElementType() reflect.Type
- func (o RecordGeolocationRoutingPolicyArrayOutput) Index(i pulumi.IntInput) RecordGeolocationRoutingPolicyOutput
- func (o RecordGeolocationRoutingPolicyArrayOutput) ToRecordGeolocationRoutingPolicyArrayOutput() RecordGeolocationRoutingPolicyArrayOutput
- func (o RecordGeolocationRoutingPolicyArrayOutput) ToRecordGeolocationRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyArrayOutput
- type RecordGeolocationRoutingPolicyInput
- type RecordGeolocationRoutingPolicyOutput
- func (o RecordGeolocationRoutingPolicyOutput) Continent() pulumi.StringPtrOutput
- func (o RecordGeolocationRoutingPolicyOutput) Country() pulumi.StringPtrOutput
- func (RecordGeolocationRoutingPolicyOutput) ElementType() reflect.Type
- func (o RecordGeolocationRoutingPolicyOutput) Subdivision() pulumi.StringPtrOutput
- func (o RecordGeolocationRoutingPolicyOutput) ToRecordGeolocationRoutingPolicyOutput() RecordGeolocationRoutingPolicyOutput
- func (o RecordGeolocationRoutingPolicyOutput) ToRecordGeolocationRoutingPolicyOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyOutput
- type RecordLatencyRoutingPolicy
- type RecordLatencyRoutingPolicyArgs
- func (RecordLatencyRoutingPolicyArgs) ElementType() reflect.Type
- func (i RecordLatencyRoutingPolicyArgs) ToRecordLatencyRoutingPolicyOutput() RecordLatencyRoutingPolicyOutput
- func (i RecordLatencyRoutingPolicyArgs) ToRecordLatencyRoutingPolicyOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyOutput
- type RecordLatencyRoutingPolicyArray
- func (RecordLatencyRoutingPolicyArray) ElementType() reflect.Type
- func (i RecordLatencyRoutingPolicyArray) ToRecordLatencyRoutingPolicyArrayOutput() RecordLatencyRoutingPolicyArrayOutput
- func (i RecordLatencyRoutingPolicyArray) ToRecordLatencyRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyArrayOutput
- type RecordLatencyRoutingPolicyArrayInput
- type RecordLatencyRoutingPolicyArrayOutput
- func (RecordLatencyRoutingPolicyArrayOutput) ElementType() reflect.Type
- func (o RecordLatencyRoutingPolicyArrayOutput) Index(i pulumi.IntInput) RecordLatencyRoutingPolicyOutput
- func (o RecordLatencyRoutingPolicyArrayOutput) ToRecordLatencyRoutingPolicyArrayOutput() RecordLatencyRoutingPolicyArrayOutput
- func (o RecordLatencyRoutingPolicyArrayOutput) ToRecordLatencyRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyArrayOutput
- type RecordLatencyRoutingPolicyInput
- type RecordLatencyRoutingPolicyOutput
- func (RecordLatencyRoutingPolicyOutput) ElementType() reflect.Type
- func (o RecordLatencyRoutingPolicyOutput) Region() pulumi.StringOutput
- func (o RecordLatencyRoutingPolicyOutput) ToRecordLatencyRoutingPolicyOutput() RecordLatencyRoutingPolicyOutput
- func (o RecordLatencyRoutingPolicyOutput) ToRecordLatencyRoutingPolicyOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyOutput
- type RecordState
- type RecordWeightedRoutingPolicy
- type RecordWeightedRoutingPolicyArgs
- func (RecordWeightedRoutingPolicyArgs) ElementType() reflect.Type
- func (i RecordWeightedRoutingPolicyArgs) ToRecordWeightedRoutingPolicyOutput() RecordWeightedRoutingPolicyOutput
- func (i RecordWeightedRoutingPolicyArgs) ToRecordWeightedRoutingPolicyOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyOutput
- type RecordWeightedRoutingPolicyArray
- func (RecordWeightedRoutingPolicyArray) ElementType() reflect.Type
- func (i RecordWeightedRoutingPolicyArray) ToRecordWeightedRoutingPolicyArrayOutput() RecordWeightedRoutingPolicyArrayOutput
- func (i RecordWeightedRoutingPolicyArray) ToRecordWeightedRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyArrayOutput
- type RecordWeightedRoutingPolicyArrayInput
- type RecordWeightedRoutingPolicyArrayOutput
- func (RecordWeightedRoutingPolicyArrayOutput) ElementType() reflect.Type
- func (o RecordWeightedRoutingPolicyArrayOutput) Index(i pulumi.IntInput) RecordWeightedRoutingPolicyOutput
- func (o RecordWeightedRoutingPolicyArrayOutput) ToRecordWeightedRoutingPolicyArrayOutput() RecordWeightedRoutingPolicyArrayOutput
- func (o RecordWeightedRoutingPolicyArrayOutput) ToRecordWeightedRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyArrayOutput
- type RecordWeightedRoutingPolicyInput
- type RecordWeightedRoutingPolicyOutput
- func (RecordWeightedRoutingPolicyOutput) ElementType() reflect.Type
- func (o RecordWeightedRoutingPolicyOutput) ToRecordWeightedRoutingPolicyOutput() RecordWeightedRoutingPolicyOutput
- func (o RecordWeightedRoutingPolicyOutput) ToRecordWeightedRoutingPolicyOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyOutput
- func (o RecordWeightedRoutingPolicyOutput) Weight() pulumi.IntOutput
- type ResolverEndpoint
- type ResolverEndpointArgs
- type ResolverEndpointIpAddress
- type ResolverEndpointIpAddressArgs
- func (ResolverEndpointIpAddressArgs) ElementType() reflect.Type
- func (i ResolverEndpointIpAddressArgs) ToResolverEndpointIpAddressOutput() ResolverEndpointIpAddressOutput
- func (i ResolverEndpointIpAddressArgs) ToResolverEndpointIpAddressOutputWithContext(ctx context.Context) ResolverEndpointIpAddressOutput
- type ResolverEndpointIpAddressArray
- func (ResolverEndpointIpAddressArray) ElementType() reflect.Type
- func (i ResolverEndpointIpAddressArray) ToResolverEndpointIpAddressArrayOutput() ResolverEndpointIpAddressArrayOutput
- func (i ResolverEndpointIpAddressArray) ToResolverEndpointIpAddressArrayOutputWithContext(ctx context.Context) ResolverEndpointIpAddressArrayOutput
- type ResolverEndpointIpAddressArrayInput
- type ResolverEndpointIpAddressArrayOutput
- func (ResolverEndpointIpAddressArrayOutput) ElementType() reflect.Type
- func (o ResolverEndpointIpAddressArrayOutput) Index(i pulumi.IntInput) ResolverEndpointIpAddressOutput
- func (o ResolverEndpointIpAddressArrayOutput) ToResolverEndpointIpAddressArrayOutput() ResolverEndpointIpAddressArrayOutput
- func (o ResolverEndpointIpAddressArrayOutput) ToResolverEndpointIpAddressArrayOutputWithContext(ctx context.Context) ResolverEndpointIpAddressArrayOutput
- type ResolverEndpointIpAddressInput
- type ResolverEndpointIpAddressOutput
- func (ResolverEndpointIpAddressOutput) ElementType() reflect.Type
- func (o ResolverEndpointIpAddressOutput) Ip() pulumi.StringPtrOutput
- func (o ResolverEndpointIpAddressOutput) IpId() pulumi.StringPtrOutput
- func (o ResolverEndpointIpAddressOutput) SubnetId() pulumi.StringOutput
- func (o ResolverEndpointIpAddressOutput) ToResolverEndpointIpAddressOutput() ResolverEndpointIpAddressOutput
- func (o ResolverEndpointIpAddressOutput) ToResolverEndpointIpAddressOutputWithContext(ctx context.Context) ResolverEndpointIpAddressOutput
- type ResolverEndpointState
- type ResolverRule
- type ResolverRuleArgs
- type ResolverRuleAssociation
- type ResolverRuleAssociationArgs
- type ResolverRuleAssociationState
- type ResolverRuleState
- type ResolverRuleTargetIp
- type ResolverRuleTargetIpArgs
- type ResolverRuleTargetIpArray
- type ResolverRuleTargetIpArrayInput
- type ResolverRuleTargetIpArrayOutput
- func (ResolverRuleTargetIpArrayOutput) ElementType() reflect.Type
- func (o ResolverRuleTargetIpArrayOutput) Index(i pulumi.IntInput) ResolverRuleTargetIpOutput
- func (o ResolverRuleTargetIpArrayOutput) ToResolverRuleTargetIpArrayOutput() ResolverRuleTargetIpArrayOutput
- func (o ResolverRuleTargetIpArrayOutput) ToResolverRuleTargetIpArrayOutputWithContext(ctx context.Context) ResolverRuleTargetIpArrayOutput
- type ResolverRuleTargetIpInput
- type ResolverRuleTargetIpOutput
- func (ResolverRuleTargetIpOutput) ElementType() reflect.Type
- func (o ResolverRuleTargetIpOutput) Ip() pulumi.StringOutput
- func (o ResolverRuleTargetIpOutput) Port() pulumi.IntPtrOutput
- func (o ResolverRuleTargetIpOutput) ToResolverRuleTargetIpOutput() ResolverRuleTargetIpOutput
- func (o ResolverRuleTargetIpOutput) ToResolverRuleTargetIpOutputWithContext(ctx context.Context) ResolverRuleTargetIpOutput
- type VpcAssociationAuthorization
- type VpcAssociationAuthorizationArgs
- type VpcAssociationAuthorizationState
- type Zone
- type ZoneArgs
- type ZoneAssociation
- type ZoneAssociationArgs
- type ZoneAssociationState
- type ZoneState
- type ZoneVpc
- type ZoneVpcArgs
- type ZoneVpcArray
- type ZoneVpcArrayInput
- type ZoneVpcArrayOutput
- type ZoneVpcInput
- type ZoneVpcOutput
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type DelegationSet ¶
type DelegationSet struct { pulumi.CustomResourceState // A list of authoritative name servers for the hosted zone // (effectively a list of NS records). NameServers pulumi.StringArrayOutput `pulumi:"nameServers"` // This is a reference name used in Caller Reference // (helpful for identifying single delegation set amongst others) ReferenceName pulumi.StringPtrOutput `pulumi:"referenceName"` }
Provides a [Route53 Delegation Set](https://docs.aws.amazon.com/Route53/latest/APIReference/API-actions-by-function.html#actions-by-function-reusable-delegation-sets) resource.
## Example Usage
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { main, err := route53.NewDelegationSet(ctx, "main", &route53.DelegationSetArgs{ ReferenceName: pulumi.String("DynDNS"), }) if err != nil { return err } _, err = route53.NewZone(ctx, "primary", &route53.ZoneArgs{ DelegationSetId: main.ID(), }) if err != nil { return err } _, err = route53.NewZone(ctx, "secondary", &route53.ZoneArgs{ DelegationSetId: main.ID(), }) if err != nil { return err } return nil }) }
```
func GetDelegationSet ¶
func GetDelegationSet(ctx *pulumi.Context, name string, id pulumi.IDInput, state *DelegationSetState, opts ...pulumi.ResourceOption) (*DelegationSet, error)
GetDelegationSet gets an existing DelegationSet resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewDelegationSet ¶
func NewDelegationSet(ctx *pulumi.Context, name string, args *DelegationSetArgs, opts ...pulumi.ResourceOption) (*DelegationSet, error)
NewDelegationSet registers a new resource with the given unique name, arguments, and options.
type DelegationSetArgs ¶
type DelegationSetArgs struct { // This is a reference name used in Caller Reference // (helpful for identifying single delegation set amongst others) ReferenceName pulumi.StringPtrInput }
The set of arguments for constructing a DelegationSet resource.
func (DelegationSetArgs) ElementType ¶
func (DelegationSetArgs) ElementType() reflect.Type
type DelegationSetState ¶
type DelegationSetState struct { // A list of authoritative name servers for the hosted zone // (effectively a list of NS records). NameServers pulumi.StringArrayInput // This is a reference name used in Caller Reference // (helpful for identifying single delegation set amongst others) ReferenceName pulumi.StringPtrInput }
func (DelegationSetState) ElementType ¶
func (DelegationSetState) ElementType() reflect.Type
type GetResolverRulesArgs ¶
type GetResolverRulesArgs struct { // When the desired resolver rules are shared with another AWS account, the account ID of the account that the rules are shared with. OwnerId *string `pulumi:"ownerId"` // The ID of the outbound resolver endpoint for the desired resolver rules. ResolverEndpointId *string `pulumi:"resolverEndpointId"` // The rule type of the desired resolver rules. Valid values are `FORWARD`, `SYSTEM` and `RECURSIVE`. RuleType *string `pulumi:"ruleType"` ShareStatus *string `pulumi:"shareStatus"` }
A collection of arguments for invoking getResolverRules.
type GetResolverRulesResult ¶
type GetResolverRulesResult struct { // The provider-assigned unique ID for this managed resource. Id string `pulumi:"id"` OwnerId *string `pulumi:"ownerId"` ResolverEndpointId *string `pulumi:"resolverEndpointId"` // The IDs of the matched resolver rules. ResolverRuleIds []string `pulumi:"resolverRuleIds"` RuleType *string `pulumi:"ruleType"` }
A collection of values returned by getResolverRules.
func GetResolverRules ¶
func GetResolverRules(ctx *pulumi.Context, args *GetResolverRulesArgs, opts ...pulumi.InvokeOption) (*GetResolverRulesResult, error)
`route53.getResolverRules` provides details about a set of Route53 Resolver rules.
## Example Usage
Retrieving the default resolver rule.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { opt0 := "Route 53 Resolver" opt1 := "RECURSIVE" opt2 := "NOT_SHARED" _, err := route53.GetResolverRules(ctx, &route53.GetResolverRulesArgs{ OwnerId: &opt0, RuleType: &opt1, ShareStatus: &opt2, }, nil) if err != nil { return err } return nil }) }
```
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { opt0 := "FORWARD" opt1 := "SHARED_WITH_ME" _, err := route53.GetResolverRules(ctx, &route53.GetResolverRulesArgs{ RuleType: &opt0, ShareStatus: &opt1, }, nil) if err != nil { return err } return nil }) }
```
type HealthCheck ¶
type HealthCheck struct { pulumi.CustomResourceState // The minimum number of child health checks that must be healthy for Route 53 to consider the parent health check to be healthy. Valid values are integers between 0 and 256, inclusive ChildHealthThreshold pulumi.IntPtrOutput `pulumi:"childHealthThreshold"` // For a specified parent health check, a list of HealthCheckId values for the associated child health checks. ChildHealthchecks pulumi.StringArrayOutput `pulumi:"childHealthchecks"` // The name of the CloudWatch alarm. CloudwatchAlarmName pulumi.StringPtrOutput `pulumi:"cloudwatchAlarmName"` // The CloudWatchRegion that the CloudWatch alarm was created in. CloudwatchAlarmRegion pulumi.StringPtrOutput `pulumi:"cloudwatchAlarmRegion"` // A boolean value that indicates whether Route53 should send the `fqdn` to the endpoint when performing the health check. This defaults to AWS' defaults: when the `type` is "HTTPS" `enableSni` defaults to `true`, when `type` is anything else `enableSni` defaults to `false`. EnableSni pulumi.BoolOutput `pulumi:"enableSni"` // The number of consecutive health checks that an endpoint must pass or fail. FailureThreshold pulumi.IntPtrOutput `pulumi:"failureThreshold"` // The fully qualified domain name of the endpoint to be checked. Fqdn pulumi.StringPtrOutput `pulumi:"fqdn"` // The status of the health check when CloudWatch has insufficient data about the state of associated alarm. Valid values are `Healthy` , `Unhealthy` and `LastKnownStatus`. InsufficientDataHealthStatus pulumi.StringPtrOutput `pulumi:"insufficientDataHealthStatus"` // A boolean value that indicates whether the status of health check should be inverted. For example, if a health check is healthy but Inverted is True , then Route 53 considers the health check to be unhealthy. InvertHealthcheck pulumi.BoolPtrOutput `pulumi:"invertHealthcheck"` // The IP address of the endpoint to be checked. IpAddress pulumi.StringPtrOutput `pulumi:"ipAddress"` // A Boolean value that indicates whether you want Route 53 to measure the latency between health checkers in multiple AWS regions and your endpoint and to display CloudWatch latency graphs in the Route 53 console. MeasureLatency pulumi.BoolPtrOutput `pulumi:"measureLatency"` // The port of the endpoint to be checked. Port pulumi.IntPtrOutput `pulumi:"port"` // This is a reference name used in Caller Reference // (helpful for identifying single healthCheck set amongst others) ReferenceName pulumi.StringPtrOutput `pulumi:"referenceName"` // A list of AWS regions that you want Amazon Route 53 health checkers to check the specified endpoint from. Regions pulumi.StringArrayOutput `pulumi:"regions"` // The number of seconds between the time that Amazon Route 53 gets a response from your endpoint and the time that it sends the next health-check request. RequestInterval pulumi.IntPtrOutput `pulumi:"requestInterval"` // The path that you want Amazon Route 53 to request when performing health checks. ResourcePath pulumi.StringPtrOutput `pulumi:"resourcePath"` // String searched in the first 5120 bytes of the response body for check to be considered healthy. Only valid with `HTTP_STR_MATCH` and `HTTPS_STR_MATCH`. SearchString pulumi.StringPtrOutput `pulumi:"searchString"` // A map of tags to assign to the health check. Tags pulumi.StringMapOutput `pulumi:"tags"` // The protocol to use when performing health checks. Valid values are `HTTP`, `HTTPS`, `HTTP_STR_MATCH`, `HTTPS_STR_MATCH`, `TCP`, `CALCULATED` and `CLOUDWATCH_METRIC`. Type pulumi.StringOutput `pulumi:"type"` }
Provides a Route53 health check.
## Example Usage ### Connectivity and HTTP Status Code Check
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewHealthCheck(ctx, "example", &route53.HealthCheckArgs{ FailureThreshold: pulumi.Int(5), Fqdn: pulumi.String("example.com"), Port: pulumi.Int(80), RequestInterval: pulumi.Int(30), ResourcePath: pulumi.String("/"), Tags: pulumi.StringMap{ "Name": pulumi.String("tf-test-health-check"), }, Type: pulumi.String("HTTP"), }) if err != nil { return err } return nil }) }
``` ### Connectivity and String Matching Check
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewHealthCheck(ctx, "example", &route53.HealthCheckArgs{ FailureThreshold: pulumi.Int(5), Fqdn: pulumi.String("example.com"), Port: pulumi.Int(443), RequestInterval: pulumi.Int(30), ResourcePath: pulumi.String("/"), SearchString: pulumi.String("example"), Type: pulumi.String("HTTPS_STR_MATCH"), }) if err != nil { return err } return nil }) }
``` ### CloudWatch Alarm Check
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/cloudwatch" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { foobar, err := cloudwatch.NewMetricAlarm(ctx, "foobar", &cloudwatch.MetricAlarmArgs{ ComparisonOperator: pulumi.String("GreaterThanOrEqualToThreshold"), EvaluationPeriods: pulumi.Int(2), MetricName: pulumi.String("CPUUtilization"), Namespace: pulumi.String("AWS/EC2"), Period: pulumi.Int(120), Statistic: pulumi.String("Average"), Threshold: pulumi.Float64(80), AlarmDescription: pulumi.String("This metric monitors ec2 cpu utilization"), }) if err != nil { return err } _, err = route53.NewHealthCheck(ctx, "foo", &route53.HealthCheckArgs{ Type: pulumi.String("CLOUDWATCH_METRIC"), CloudwatchAlarmName: foobar.Name, CloudwatchAlarmRegion: pulumi.String("us-west-2"), InsufficientDataHealthStatus: pulumi.String("Healthy"), }) if err != nil { return err } return nil }) }
```
func GetHealthCheck ¶
func GetHealthCheck(ctx *pulumi.Context, name string, id pulumi.IDInput, state *HealthCheckState, opts ...pulumi.ResourceOption) (*HealthCheck, error)
GetHealthCheck gets an existing HealthCheck resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewHealthCheck ¶
func NewHealthCheck(ctx *pulumi.Context, name string, args *HealthCheckArgs, opts ...pulumi.ResourceOption) (*HealthCheck, error)
NewHealthCheck registers a new resource with the given unique name, arguments, and options.
type HealthCheckArgs ¶
type HealthCheckArgs struct { // The minimum number of child health checks that must be healthy for Route 53 to consider the parent health check to be healthy. Valid values are integers between 0 and 256, inclusive ChildHealthThreshold pulumi.IntPtrInput // For a specified parent health check, a list of HealthCheckId values for the associated child health checks. ChildHealthchecks pulumi.StringArrayInput // The name of the CloudWatch alarm. CloudwatchAlarmName pulumi.StringPtrInput // The CloudWatchRegion that the CloudWatch alarm was created in. CloudwatchAlarmRegion pulumi.StringPtrInput // A boolean value that indicates whether Route53 should send the `fqdn` to the endpoint when performing the health check. This defaults to AWS' defaults: when the `type` is "HTTPS" `enableSni` defaults to `true`, when `type` is anything else `enableSni` defaults to `false`. EnableSni pulumi.BoolPtrInput // The number of consecutive health checks that an endpoint must pass or fail. FailureThreshold pulumi.IntPtrInput // The fully qualified domain name of the endpoint to be checked. Fqdn pulumi.StringPtrInput // The status of the health check when CloudWatch has insufficient data about the state of associated alarm. Valid values are `Healthy` , `Unhealthy` and `LastKnownStatus`. InsufficientDataHealthStatus pulumi.StringPtrInput // A boolean value that indicates whether the status of health check should be inverted. For example, if a health check is healthy but Inverted is True , then Route 53 considers the health check to be unhealthy. InvertHealthcheck pulumi.BoolPtrInput // The IP address of the endpoint to be checked. IpAddress pulumi.StringPtrInput // A Boolean value that indicates whether you want Route 53 to measure the latency between health checkers in multiple AWS regions and your endpoint and to display CloudWatch latency graphs in the Route 53 console. MeasureLatency pulumi.BoolPtrInput // The port of the endpoint to be checked. Port pulumi.IntPtrInput // This is a reference name used in Caller Reference // (helpful for identifying single healthCheck set amongst others) ReferenceName pulumi.StringPtrInput // A list of AWS regions that you want Amazon Route 53 health checkers to check the specified endpoint from. Regions pulumi.StringArrayInput // The number of seconds between the time that Amazon Route 53 gets a response from your endpoint and the time that it sends the next health-check request. RequestInterval pulumi.IntPtrInput // The path that you want Amazon Route 53 to request when performing health checks. ResourcePath pulumi.StringPtrInput // String searched in the first 5120 bytes of the response body for check to be considered healthy. Only valid with `HTTP_STR_MATCH` and `HTTPS_STR_MATCH`. SearchString pulumi.StringPtrInput // A map of tags to assign to the health check. Tags pulumi.StringMapInput // The protocol to use when performing health checks. Valid values are `HTTP`, `HTTPS`, `HTTP_STR_MATCH`, `HTTPS_STR_MATCH`, `TCP`, `CALCULATED` and `CLOUDWATCH_METRIC`. Type pulumi.StringInput }
The set of arguments for constructing a HealthCheck resource.
func (HealthCheckArgs) ElementType ¶
func (HealthCheckArgs) ElementType() reflect.Type
type HealthCheckState ¶
type HealthCheckState struct { // The minimum number of child health checks that must be healthy for Route 53 to consider the parent health check to be healthy. Valid values are integers between 0 and 256, inclusive ChildHealthThreshold pulumi.IntPtrInput // For a specified parent health check, a list of HealthCheckId values for the associated child health checks. ChildHealthchecks pulumi.StringArrayInput // The name of the CloudWatch alarm. CloudwatchAlarmName pulumi.StringPtrInput // The CloudWatchRegion that the CloudWatch alarm was created in. CloudwatchAlarmRegion pulumi.StringPtrInput // A boolean value that indicates whether Route53 should send the `fqdn` to the endpoint when performing the health check. This defaults to AWS' defaults: when the `type` is "HTTPS" `enableSni` defaults to `true`, when `type` is anything else `enableSni` defaults to `false`. EnableSni pulumi.BoolPtrInput // The number of consecutive health checks that an endpoint must pass or fail. FailureThreshold pulumi.IntPtrInput // The fully qualified domain name of the endpoint to be checked. Fqdn pulumi.StringPtrInput // The status of the health check when CloudWatch has insufficient data about the state of associated alarm. Valid values are `Healthy` , `Unhealthy` and `LastKnownStatus`. InsufficientDataHealthStatus pulumi.StringPtrInput // A boolean value that indicates whether the status of health check should be inverted. For example, if a health check is healthy but Inverted is True , then Route 53 considers the health check to be unhealthy. InvertHealthcheck pulumi.BoolPtrInput // The IP address of the endpoint to be checked. IpAddress pulumi.StringPtrInput // A Boolean value that indicates whether you want Route 53 to measure the latency between health checkers in multiple AWS regions and your endpoint and to display CloudWatch latency graphs in the Route 53 console. MeasureLatency pulumi.BoolPtrInput // The port of the endpoint to be checked. Port pulumi.IntPtrInput // This is a reference name used in Caller Reference // (helpful for identifying single healthCheck set amongst others) ReferenceName pulumi.StringPtrInput // A list of AWS regions that you want Amazon Route 53 health checkers to check the specified endpoint from. Regions pulumi.StringArrayInput // The number of seconds between the time that Amazon Route 53 gets a response from your endpoint and the time that it sends the next health-check request. RequestInterval pulumi.IntPtrInput // The path that you want Amazon Route 53 to request when performing health checks. ResourcePath pulumi.StringPtrInput // String searched in the first 5120 bytes of the response body for check to be considered healthy. Only valid with `HTTP_STR_MATCH` and `HTTPS_STR_MATCH`. SearchString pulumi.StringPtrInput // A map of tags to assign to the health check. Tags pulumi.StringMapInput // The protocol to use when performing health checks. Valid values are `HTTP`, `HTTPS`, `HTTP_STR_MATCH`, `HTTPS_STR_MATCH`, `TCP`, `CALCULATED` and `CLOUDWATCH_METRIC`. Type pulumi.StringPtrInput }
func (HealthCheckState) ElementType ¶
func (HealthCheckState) ElementType() reflect.Type
type LookupDelegationSetArgs ¶
type LookupDelegationSetArgs struct { // The Hosted Zone id of the desired delegation set. Id string `pulumi:"id"` }
A collection of arguments for invoking getDelegationSet.
type LookupDelegationSetResult ¶
type LookupDelegationSetResult struct { CallerReference string `pulumi:"callerReference"` Id string `pulumi:"id"` NameServers []string `pulumi:"nameServers"` }
A collection of values returned by getDelegationSet.
func LookupDelegationSet ¶
func LookupDelegationSet(ctx *pulumi.Context, args *LookupDelegationSetArgs, opts ...pulumi.InvokeOption) (*LookupDelegationSetResult, error)
`route53.DelegationSet` provides details about a specific Route 53 Delegation Set.
This data source allows to find a list of name servers associated with a specific delegation set.
## Example Usage
The following example shows how to get a delegation set from its id.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.LookupDelegationSet(ctx, &route53.LookupDelegationSetArgs{ Id: "MQWGHCBFAKEID", }, nil) if err != nil { return err } return nil }) }
```
type LookupResolverRuleArgs ¶
type LookupResolverRuleArgs struct { // The domain name the desired resolver rule forwards DNS queries for. Conflicts with `resolverRuleId`. DomainName *string `pulumi:"domainName"` // The friendly name of the desired resolver rule. Conflicts with `resolverRuleId`. Name *string `pulumi:"name"` // The ID of the outbound resolver endpoint of the desired resolver rule. Conflicts with `resolverRuleId`. ResolverEndpointId *string `pulumi:"resolverEndpointId"` // The ID of the desired resolver rule. Conflicts with `domainName`, `name`, `resolverEndpointId` and `ruleType`. ResolverRuleId *string `pulumi:"resolverRuleId"` // The rule type of the desired resolver rule. Valid values are `FORWARD`, `SYSTEM` and `RECURSIVE`. Conflicts with `resolverRuleId`. RuleType *string `pulumi:"ruleType"` // A map of tags assigned to the resolver rule. Tags map[string]string `pulumi:"tags"` }
A collection of arguments for invoking getResolverRule.
type LookupResolverRuleResult ¶
type LookupResolverRuleResult struct { // The ARN (Amazon Resource Name) for the resolver rule. Arn string `pulumi:"arn"` DomainName string `pulumi:"domainName"` // The provider-assigned unique ID for this managed resource. Id string `pulumi:"id"` Name string `pulumi:"name"` // When a rule is shared with another AWS account, the account ID of the account that the rule is shared with. OwnerId string `pulumi:"ownerId"` ResolverEndpointId string `pulumi:"resolverEndpointId"` ResolverRuleId string `pulumi:"resolverRuleId"` RuleType string `pulumi:"ruleType"` // Values are `NOT_SHARED`, `SHARED_BY_ME` or `SHARED_WITH_ME` ShareStatus string `pulumi:"shareStatus"` // A map of tags assigned to the resolver rule. Tags map[string]string `pulumi:"tags"` }
A collection of values returned by getResolverRule.
func LookupResolverRule ¶
func LookupResolverRule(ctx *pulumi.Context, args *LookupResolverRuleArgs, opts ...pulumi.InvokeOption) (*LookupResolverRuleResult, error)
`route53.ResolverRule` provides details about a specific Route53 Resolver rule.
## Example Usage
The following example shows how to get a Route53 Resolver rule based on its associated domain name and rule type.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { opt0 := "subdomain.example.com" opt1 := "SYSTEM" _, err := route53.LookupResolverRule(ctx, &route53.LookupResolverRuleArgs{ DomainName: &opt0, RuleType: &opt1, }, nil) if err != nil { return err } return nil }) }
```
type LookupZoneArgs ¶
type LookupZoneArgs struct { // The Hosted Zone name of the desired Hosted Zone. Name *string `pulumi:"name"` // Used with `name` field to get a private Hosted Zone. PrivateZone *bool `pulumi:"privateZone"` // The number of Record Set in the Hosted Zone. ResourceRecordSetCount *int `pulumi:"resourceRecordSetCount"` // Used with `name` field. A map of tags, each pair of which must exactly match a pair on the desired Hosted Zone. Tags map[string]string `pulumi:"tags"` // Used with `name` field to get a private Hosted Zone associated with the vpcId (in this case, privateZone is not mandatory). VpcId *string `pulumi:"vpcId"` // The Hosted Zone id of the desired Hosted Zone. ZoneId *string `pulumi:"zoneId"` }
A collection of arguments for invoking getZone.
type LookupZoneResult ¶
type LookupZoneResult struct { // Caller Reference of the Hosted Zone. CallerReference string `pulumi:"callerReference"` // The comment field of the Hosted Zone. Comment string `pulumi:"comment"` // The provider-assigned unique ID for this managed resource. Id string `pulumi:"id"` // The description provided by the service that created the Hosted Zone (e.g. `arn:aws:servicediscovery:us-east-1:1234567890:namespace/ns-xxxxxxxxxxxxxxxx`). LinkedServiceDescription string `pulumi:"linkedServiceDescription"` // The service that created the Hosted Zone (e.g. `servicediscovery.amazonaws.com`). LinkedServicePrincipal string `pulumi:"linkedServicePrincipal"` Name string `pulumi:"name"` // The list of DNS name servers for the Hosted Zone. NameServers []string `pulumi:"nameServers"` PrivateZone *bool `pulumi:"privateZone"` // The number of Record Set in the Hosted Zone. ResourceRecordSetCount int `pulumi:"resourceRecordSetCount"` Tags map[string]string `pulumi:"tags"` VpcId string `pulumi:"vpcId"` ZoneId string `pulumi:"zoneId"` }
A collection of values returned by getZone.
func LookupZone ¶
func LookupZone(ctx *pulumi.Context, args *LookupZoneArgs, opts ...pulumi.InvokeOption) (*LookupZoneResult, error)
`route53.Zone` provides details about a specific Route 53 Hosted Zone.
This data source allows to find a Hosted Zone ID given Hosted Zone name and certain search criteria.
## Example Usage
The following example shows how to get a Hosted Zone from its name and from this data how to create a Record Set.
```go package main
import (
"fmt" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { opt0 := "test.com." opt1 := true selected, err := route53.LookupZone(ctx, &route53.LookupZoneArgs{ Name: &opt0, PrivateZone: &opt1, }, nil) if err != nil { return err } _, err = route53.NewRecord(ctx, "www", &route53.RecordArgs{ ZoneId: pulumi.String(selected.ZoneId), Name: pulumi.String(fmt.Sprintf("%v%v", "www.", selected.Name)), Type: pulumi.String("A"), Ttl: pulumi.Int(300), Records: pulumi.StringArray{ pulumi.String("10.0.0.1"), }, }) if err != nil { return err } return nil }) }
```
type QueryLog ¶
type QueryLog struct { pulumi.CustomResourceState // CloudWatch log group ARN to send query logs. CloudwatchLogGroupArn pulumi.StringOutput `pulumi:"cloudwatchLogGroupArn"` // Route53 hosted zone ID to enable query logs. ZoneId pulumi.StringOutput `pulumi:"zoneId"` }
Provides a Route53 query logging configuration resource.
> **NOTE:** There are restrictions on the configuration of query logging. Notably, the CloudWatch log group must be in the `us-east-1` region, a permissive CloudWatch log resource policy must be in place, and the Route53 hosted zone must be public. See [Configuring Logging for DNS Queries](https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/query-logs.html?console_help=true#query-logs-configuring) for additional details.
## Example Usage
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/cloudwatch" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/iam" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/providers" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := providers.Newaws(ctx, "us_east_1", &providers.awsArgs{ Region: pulumi.String("us-east-1"), }) if err != nil { return err } awsRoute53ExampleCom, err := cloudwatch.NewLogGroup(ctx, "awsRoute53ExampleCom", &cloudwatch.LogGroupArgs{ RetentionInDays: pulumi.Int(30), }, pulumi.Provider(aws.Us-east-1)) if err != nil { return err } route53_query_logging_policyPolicyDocument, err := iam.GetPolicyDocument(ctx, &iam.GetPolicyDocumentArgs{ Statements: []iam.GetPolicyDocumentStatement{ iam.GetPolicyDocumentStatement{ Actions: []string{ "logs:CreateLogStream", "logs:PutLogEvents", }, Resources: []string{ "arn:aws:logs:*:*:log-group:/aws/route53/*", }, Principals: []iam.GetPolicyDocumentStatementPrincipal{ iam.GetPolicyDocumentStatementPrincipal{ Identifiers: []string{ "route53.amazonaws.com", }, Type: "Service", }, }, }, }, }, nil) if err != nil { return err } _, err = cloudwatch.NewLogResourcePolicy(ctx, "route53_query_logging_policyLogResourcePolicy", &cloudwatch.LogResourcePolicyArgs{ PolicyDocument: pulumi.String(route53_query_logging_policyPolicyDocument.Json), PolicyName: pulumi.String("route53-query-logging-policy"), }, pulumi.Provider(aws.Us-east-1)) if err != nil { return err } exampleComZone, err := route53.NewZone(ctx, "exampleComZone", nil) if err != nil { return err } _, err = route53.NewQueryLog(ctx, "exampleComQueryLog", &route53.QueryLogArgs{ CloudwatchLogGroupArn: awsRoute53ExampleCom.Arn, ZoneId: exampleComZone.ZoneId, }, pulumi.DependsOn([]pulumi.Resource{ route53_query_logging_policyLogResourcePolicy, })) if err != nil { return err } return nil }) }
```
func GetQueryLog ¶
func GetQueryLog(ctx *pulumi.Context, name string, id pulumi.IDInput, state *QueryLogState, opts ...pulumi.ResourceOption) (*QueryLog, error)
GetQueryLog gets an existing QueryLog resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewQueryLog ¶
func NewQueryLog(ctx *pulumi.Context, name string, args *QueryLogArgs, opts ...pulumi.ResourceOption) (*QueryLog, error)
NewQueryLog registers a new resource with the given unique name, arguments, and options.
type QueryLogArgs ¶
type QueryLogArgs struct { // CloudWatch log group ARN to send query logs. CloudwatchLogGroupArn pulumi.StringInput // Route53 hosted zone ID to enable query logs. ZoneId pulumi.StringInput }
The set of arguments for constructing a QueryLog resource.
func (QueryLogArgs) ElementType ¶
func (QueryLogArgs) ElementType() reflect.Type
type QueryLogState ¶
type QueryLogState struct { // CloudWatch log group ARN to send query logs. CloudwatchLogGroupArn pulumi.StringPtrInput // Route53 hosted zone ID to enable query logs. ZoneId pulumi.StringPtrInput }
func (QueryLogState) ElementType ¶
func (QueryLogState) ElementType() reflect.Type
type Record ¶
type Record struct { pulumi.CustomResourceState // An alias block. Conflicts with `ttl` & `records`. // Alias record documented below. Aliases RecordAliasArrayOutput `pulumi:"aliases"` // Allow creation of this record to overwrite an existing record, if any. This does not affect the ability to update the record using this provider and does not prevent other resources within this provider or manual Route 53 changes outside this provider from overwriting this record. `false` by default. This configuration is not recommended for most environments. AllowOverwrite pulumi.BoolOutput `pulumi:"allowOverwrite"` // A block indicating the routing behavior when associated health check fails. Conflicts with any other routing policy. Documented below. FailoverRoutingPolicies RecordFailoverRoutingPolicyArrayOutput `pulumi:"failoverRoutingPolicies"` // [FQDN](https://en.wikipedia.org/wiki/Fully_qualified_domain_name) built using the zone domain and `name`. Fqdn pulumi.StringOutput `pulumi:"fqdn"` // A block indicating a routing policy based on the geolocation of the requestor. Conflicts with any other routing policy. Documented below. GeolocationRoutingPolicies RecordGeolocationRoutingPolicyArrayOutput `pulumi:"geolocationRoutingPolicies"` // The health check the record should be associated with. HealthCheckId pulumi.StringPtrOutput `pulumi:"healthCheckId"` // A block indicating a routing policy based on the latency between the requestor and an AWS region. Conflicts with any other routing policy. Documented below. LatencyRoutingPolicies RecordLatencyRoutingPolicyArrayOutput `pulumi:"latencyRoutingPolicies"` // Set to `true` to indicate a multivalue answer routing policy. Conflicts with any other routing policy. MultivalueAnswerRoutingPolicy pulumi.BoolPtrOutput `pulumi:"multivalueAnswerRoutingPolicy"` // DNS domain name for a CloudFront distribution, S3 bucket, ELB, or another resource record set in this hosted zone. Name pulumi.StringOutput `pulumi:"name"` // A string list of records. To specify a single record value longer than 255 characters such as a TXT record for DKIM, add `\"\"` inside the configuration string (e.g. `"first255characters\"\"morecharacters"`). Records pulumi.StringArrayOutput `pulumi:"records"` // Unique identifier to differentiate records with routing policies from one another. Required if using `failover`, `geolocation`, `latency`, or `weighted` routing policies documented below. SetIdentifier pulumi.StringPtrOutput `pulumi:"setIdentifier"` // The TTL of the record. Ttl pulumi.IntPtrOutput `pulumi:"ttl"` // `PRIMARY` or `SECONDARY`. A `PRIMARY` record will be served if its healthcheck is passing, otherwise the `SECONDARY` will be served. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/dns-failover-configuring-options.html#dns-failover-failover-rrsets Type pulumi.StringOutput `pulumi:"type"` // A block indicating a weighted routing policy. Conflicts with any other routing policy. Documented below. WeightedRoutingPolicies RecordWeightedRoutingPolicyArrayOutput `pulumi:"weightedRoutingPolicies"` // Hosted zone ID for a CloudFront distribution, S3 bucket, ELB, or Route 53 hosted zone. See `resource_elb.zone_id` for example. ZoneId pulumi.StringOutput `pulumi:"zoneId"` }
Provides a Route53 record resource.
## Example Usage ### Weighted routing policy Other routing policies are configured similarly. See [AWS Route53 Developer Guide](https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/routing-policy.html) for details.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewRecord(ctx, "www_dev", &route53.RecordArgs{ ZoneId: pulumi.Any(aws_route53_zone.Primary.Zone_id), Name: pulumi.String("www"), Type: pulumi.String("CNAME"), Ttl: pulumi.Int(5), WeightedRoutingPolicies: route53.RecordWeightedRoutingPolicyArray{ &route53.RecordWeightedRoutingPolicyArgs{ Weight: pulumi.Int(10), }, }, SetIdentifier: pulumi.String("dev"), Records: pulumi.StringArray{ pulumi.String("dev.example.com"), }, }) if err != nil { return err } _, err = route53.NewRecord(ctx, "www_live", &route53.RecordArgs{ ZoneId: pulumi.Any(aws_route53_zone.Primary.Zone_id), Name: pulumi.String("www"), Type: pulumi.String("CNAME"), Ttl: pulumi.Int(5), WeightedRoutingPolicies: route53.RecordWeightedRoutingPolicyArray{ &route53.RecordWeightedRoutingPolicyArgs{ Weight: pulumi.Int(90), }, }, SetIdentifier: pulumi.String("live"), Records: pulumi.StringArray{ pulumi.String("live.example.com"), }, }) if err != nil { return err } return nil }) }
``` ### Alias record See [related part of AWS Route53 Developer Guide](https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/resource-record-sets-choosing-alias-non-alias.html) to understand differences between alias and non-alias records.
TTL for all alias records is [60 seconds](https://aws.amazon.com/route53/faqs/#dns_failover_do_i_need_to_adjust), you cannot change this, therefore `ttl` has to be omitted in alias records.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/elb" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { main, err := elb.NewLoadBalancer(ctx, "main", &elb.LoadBalancerArgs{ AvailabilityZones: pulumi.StringArray{ pulumi.String("us-east-1c"), }, Listeners: elb.LoadBalancerListenerArray{ &elb.LoadBalancerListenerArgs{ InstancePort: pulumi.Int(80), InstanceProtocol: pulumi.String("http"), LbPort: pulumi.Int(80), LbProtocol: pulumi.String("http"), }, }, }) if err != nil { return err } _, err = route53.NewRecord(ctx, "www", &route53.RecordArgs{ ZoneId: pulumi.Any(aws_route53_zone.Primary.Zone_id), Name: pulumi.String("example.com"), Type: pulumi.String("A"), Aliases: route53.RecordAliasArray{ &route53.RecordAliasArgs{ Name: main.DnsName, ZoneId: main.ZoneId, EvaluateTargetHealth: pulumi.Bool(true), }, }, }) if err != nil { return err } return nil }) }
``` ### NS and SOA Record Management
When creating Route 53 zones, the `NS` and `SOA` records for the zone are automatically created. Enabling the `allowOverwrite` argument will allow managing these records in a single deployment without the requirement for `import`.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { exampleZone, err := route53.NewZone(ctx, "exampleZone", nil) if err != nil { return err } _, err = route53.NewRecord(ctx, "exampleRecord", &route53.RecordArgs{ AllowOverwrite: pulumi.Bool(true), Name: pulumi.String("test.example.com"), Ttl: pulumi.Int(30), Type: pulumi.String("NS"), ZoneId: exampleZone.ZoneId, Records: pulumi.StringArray{ exampleZone.NameServers.ApplyT(func(nameServers []string) (string, error) { return nameServers[0], nil }).(pulumi.StringOutput), exampleZone.NameServers.ApplyT(func(nameServers []string) (string, error) { return nameServers[1], nil }).(pulumi.StringOutput), exampleZone.NameServers.ApplyT(func(nameServers []string) (string, error) { return nameServers[2], nil }).(pulumi.StringOutput), exampleZone.NameServers.ApplyT(func(nameServers []string) (string, error) { return nameServers[3], nil }).(pulumi.StringOutput), }, }) if err != nil { return err } return nil }) }
```
func GetRecord ¶
func GetRecord(ctx *pulumi.Context, name string, id pulumi.IDInput, state *RecordState, opts ...pulumi.ResourceOption) (*Record, error)
GetRecord gets an existing Record resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewRecord ¶
func NewRecord(ctx *pulumi.Context, name string, args *RecordArgs, opts ...pulumi.ResourceOption) (*Record, error)
NewRecord registers a new resource with the given unique name, arguments, and options.
type RecordAlias ¶
type RecordAlias struct { // Set to `true` if you want Route 53 to determine whether to respond to DNS queries using this resource record set by checking the health of the resource record set. Some resources have special requirements, see [related part of documentation](https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/resource-record-sets-values.html#rrsets-values-alias-evaluate-target-health). EvaluateTargetHealth bool `pulumi:"evaluateTargetHealth"` // DNS domain name for a CloudFront distribution, S3 bucket, ELB, or another resource record set in this hosted zone. Name string `pulumi:"name"` // Hosted zone ID for a CloudFront distribution, S3 bucket, ELB, or Route 53 hosted zone. See `resource_elb.zone_id` for example. ZoneId string `pulumi:"zoneId"` }
type RecordAliasArgs ¶
type RecordAliasArgs struct { // Set to `true` if you want Route 53 to determine whether to respond to DNS queries using this resource record set by checking the health of the resource record set. Some resources have special requirements, see [related part of documentation](https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/resource-record-sets-values.html#rrsets-values-alias-evaluate-target-health). EvaluateTargetHealth pulumi.BoolInput `pulumi:"evaluateTargetHealth"` // DNS domain name for a CloudFront distribution, S3 bucket, ELB, or another resource record set in this hosted zone. Name pulumi.StringInput `pulumi:"name"` // Hosted zone ID for a CloudFront distribution, S3 bucket, ELB, or Route 53 hosted zone. See `resource_elb.zone_id` for example. ZoneId pulumi.StringInput `pulumi:"zoneId"` }
func (RecordAliasArgs) ElementType ¶
func (RecordAliasArgs) ElementType() reflect.Type
func (RecordAliasArgs) ToRecordAliasOutput ¶
func (i RecordAliasArgs) ToRecordAliasOutput() RecordAliasOutput
func (RecordAliasArgs) ToRecordAliasOutputWithContext ¶
func (i RecordAliasArgs) ToRecordAliasOutputWithContext(ctx context.Context) RecordAliasOutput
type RecordAliasArray ¶
type RecordAliasArray []RecordAliasInput
func (RecordAliasArray) ElementType ¶
func (RecordAliasArray) ElementType() reflect.Type
func (RecordAliasArray) ToRecordAliasArrayOutput ¶
func (i RecordAliasArray) ToRecordAliasArrayOutput() RecordAliasArrayOutput
func (RecordAliasArray) ToRecordAliasArrayOutputWithContext ¶
func (i RecordAliasArray) ToRecordAliasArrayOutputWithContext(ctx context.Context) RecordAliasArrayOutput
type RecordAliasArrayInput ¶
type RecordAliasArrayInput interface { pulumi.Input ToRecordAliasArrayOutput() RecordAliasArrayOutput ToRecordAliasArrayOutputWithContext(context.Context) RecordAliasArrayOutput }
RecordAliasArrayInput is an input type that accepts RecordAliasArray and RecordAliasArrayOutput values. You can construct a concrete instance of `RecordAliasArrayInput` via:
RecordAliasArray{ RecordAliasArgs{...} }
type RecordAliasArrayOutput ¶
type RecordAliasArrayOutput struct{ *pulumi.OutputState }
func (RecordAliasArrayOutput) ElementType ¶
func (RecordAliasArrayOutput) ElementType() reflect.Type
func (RecordAliasArrayOutput) Index ¶
func (o RecordAliasArrayOutput) Index(i pulumi.IntInput) RecordAliasOutput
func (RecordAliasArrayOutput) ToRecordAliasArrayOutput ¶
func (o RecordAliasArrayOutput) ToRecordAliasArrayOutput() RecordAliasArrayOutput
func (RecordAliasArrayOutput) ToRecordAliasArrayOutputWithContext ¶
func (o RecordAliasArrayOutput) ToRecordAliasArrayOutputWithContext(ctx context.Context) RecordAliasArrayOutput
type RecordAliasInput ¶
type RecordAliasInput interface { pulumi.Input ToRecordAliasOutput() RecordAliasOutput ToRecordAliasOutputWithContext(context.Context) RecordAliasOutput }
RecordAliasInput is an input type that accepts RecordAliasArgs and RecordAliasOutput values. You can construct a concrete instance of `RecordAliasInput` via:
RecordAliasArgs{...}
type RecordAliasOutput ¶
type RecordAliasOutput struct{ *pulumi.OutputState }
func (RecordAliasOutput) ElementType ¶
func (RecordAliasOutput) ElementType() reflect.Type
func (RecordAliasOutput) EvaluateTargetHealth ¶
func (o RecordAliasOutput) EvaluateTargetHealth() pulumi.BoolOutput
Set to `true` if you want Route 53 to determine whether to respond to DNS queries using this resource record set by checking the health of the resource record set. Some resources have special requirements, see [related part of documentation](https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/resource-record-sets-values.html#rrsets-values-alias-evaluate-target-health).
func (RecordAliasOutput) Name ¶
func (o RecordAliasOutput) Name() pulumi.StringOutput
DNS domain name for a CloudFront distribution, S3 bucket, ELB, or another resource record set in this hosted zone.
func (RecordAliasOutput) ToRecordAliasOutput ¶
func (o RecordAliasOutput) ToRecordAliasOutput() RecordAliasOutput
func (RecordAliasOutput) ToRecordAliasOutputWithContext ¶
func (o RecordAliasOutput) ToRecordAliasOutputWithContext(ctx context.Context) RecordAliasOutput
func (RecordAliasOutput) ZoneId ¶
func (o RecordAliasOutput) ZoneId() pulumi.StringOutput
Hosted zone ID for a CloudFront distribution, S3 bucket, ELB, or Route 53 hosted zone. See `resource_elb.zone_id` for example.
type RecordArgs ¶
type RecordArgs struct { // An alias block. Conflicts with `ttl` & `records`. // Alias record documented below. Aliases RecordAliasArrayInput // Allow creation of this record to overwrite an existing record, if any. This does not affect the ability to update the record using this provider and does not prevent other resources within this provider or manual Route 53 changes outside this provider from overwriting this record. `false` by default. This configuration is not recommended for most environments. AllowOverwrite pulumi.BoolPtrInput // A block indicating the routing behavior when associated health check fails. Conflicts with any other routing policy. Documented below. FailoverRoutingPolicies RecordFailoverRoutingPolicyArrayInput // A block indicating a routing policy based on the geolocation of the requestor. Conflicts with any other routing policy. Documented below. GeolocationRoutingPolicies RecordGeolocationRoutingPolicyArrayInput // The health check the record should be associated with. HealthCheckId pulumi.StringPtrInput // A block indicating a routing policy based on the latency between the requestor and an AWS region. Conflicts with any other routing policy. Documented below. LatencyRoutingPolicies RecordLatencyRoutingPolicyArrayInput // Set to `true` to indicate a multivalue answer routing policy. Conflicts with any other routing policy. MultivalueAnswerRoutingPolicy pulumi.BoolPtrInput // DNS domain name for a CloudFront distribution, S3 bucket, ELB, or another resource record set in this hosted zone. Name pulumi.StringInput // A string list of records. To specify a single record value longer than 255 characters such as a TXT record for DKIM, add `\"\"` inside the configuration string (e.g. `"first255characters\"\"morecharacters"`). Records pulumi.StringArrayInput // Unique identifier to differentiate records with routing policies from one another. Required if using `failover`, `geolocation`, `latency`, or `weighted` routing policies documented below. SetIdentifier pulumi.StringPtrInput // The TTL of the record. Ttl pulumi.IntPtrInput // `PRIMARY` or `SECONDARY`. A `PRIMARY` record will be served if its healthcheck is passing, otherwise the `SECONDARY` will be served. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/dns-failover-configuring-options.html#dns-failover-failover-rrsets Type pulumi.Input // A block indicating a weighted routing policy. Conflicts with any other routing policy. Documented below. WeightedRoutingPolicies RecordWeightedRoutingPolicyArrayInput // Hosted zone ID for a CloudFront distribution, S3 bucket, ELB, or Route 53 hosted zone. See `resource_elb.zone_id` for example. ZoneId pulumi.StringInput }
The set of arguments for constructing a Record resource.
func (RecordArgs) ElementType ¶
func (RecordArgs) ElementType() reflect.Type
type RecordFailoverRoutingPolicy ¶
type RecordFailoverRoutingPolicy struct { // `PRIMARY` or `SECONDARY`. A `PRIMARY` record will be served if its healthcheck is passing, otherwise the `SECONDARY` will be served. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/dns-failover-configuring-options.html#dns-failover-failover-rrsets Type string `pulumi:"type"` }
type RecordFailoverRoutingPolicyArgs ¶
type RecordFailoverRoutingPolicyArgs struct { // `PRIMARY` or `SECONDARY`. A `PRIMARY` record will be served if its healthcheck is passing, otherwise the `SECONDARY` will be served. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/dns-failover-configuring-options.html#dns-failover-failover-rrsets Type pulumi.StringInput `pulumi:"type"` }
func (RecordFailoverRoutingPolicyArgs) ElementType ¶
func (RecordFailoverRoutingPolicyArgs) ElementType() reflect.Type
func (RecordFailoverRoutingPolicyArgs) ToRecordFailoverRoutingPolicyOutput ¶
func (i RecordFailoverRoutingPolicyArgs) ToRecordFailoverRoutingPolicyOutput() RecordFailoverRoutingPolicyOutput
func (RecordFailoverRoutingPolicyArgs) ToRecordFailoverRoutingPolicyOutputWithContext ¶
func (i RecordFailoverRoutingPolicyArgs) ToRecordFailoverRoutingPolicyOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyOutput
type RecordFailoverRoutingPolicyArray ¶
type RecordFailoverRoutingPolicyArray []RecordFailoverRoutingPolicyInput
func (RecordFailoverRoutingPolicyArray) ElementType ¶
func (RecordFailoverRoutingPolicyArray) ElementType() reflect.Type
func (RecordFailoverRoutingPolicyArray) ToRecordFailoverRoutingPolicyArrayOutput ¶
func (i RecordFailoverRoutingPolicyArray) ToRecordFailoverRoutingPolicyArrayOutput() RecordFailoverRoutingPolicyArrayOutput
func (RecordFailoverRoutingPolicyArray) ToRecordFailoverRoutingPolicyArrayOutputWithContext ¶
func (i RecordFailoverRoutingPolicyArray) ToRecordFailoverRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyArrayOutput
type RecordFailoverRoutingPolicyArrayInput ¶
type RecordFailoverRoutingPolicyArrayInput interface { pulumi.Input ToRecordFailoverRoutingPolicyArrayOutput() RecordFailoverRoutingPolicyArrayOutput ToRecordFailoverRoutingPolicyArrayOutputWithContext(context.Context) RecordFailoverRoutingPolicyArrayOutput }
RecordFailoverRoutingPolicyArrayInput is an input type that accepts RecordFailoverRoutingPolicyArray and RecordFailoverRoutingPolicyArrayOutput values. You can construct a concrete instance of `RecordFailoverRoutingPolicyArrayInput` via:
RecordFailoverRoutingPolicyArray{ RecordFailoverRoutingPolicyArgs{...} }
type RecordFailoverRoutingPolicyArrayOutput ¶
type RecordFailoverRoutingPolicyArrayOutput struct{ *pulumi.OutputState }
func (RecordFailoverRoutingPolicyArrayOutput) ElementType ¶
func (RecordFailoverRoutingPolicyArrayOutput) ElementType() reflect.Type
func (RecordFailoverRoutingPolicyArrayOutput) ToRecordFailoverRoutingPolicyArrayOutput ¶
func (o RecordFailoverRoutingPolicyArrayOutput) ToRecordFailoverRoutingPolicyArrayOutput() RecordFailoverRoutingPolicyArrayOutput
func (RecordFailoverRoutingPolicyArrayOutput) ToRecordFailoverRoutingPolicyArrayOutputWithContext ¶
func (o RecordFailoverRoutingPolicyArrayOutput) ToRecordFailoverRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyArrayOutput
type RecordFailoverRoutingPolicyInput ¶
type RecordFailoverRoutingPolicyInput interface { pulumi.Input ToRecordFailoverRoutingPolicyOutput() RecordFailoverRoutingPolicyOutput ToRecordFailoverRoutingPolicyOutputWithContext(context.Context) RecordFailoverRoutingPolicyOutput }
RecordFailoverRoutingPolicyInput is an input type that accepts RecordFailoverRoutingPolicyArgs and RecordFailoverRoutingPolicyOutput values. You can construct a concrete instance of `RecordFailoverRoutingPolicyInput` via:
RecordFailoverRoutingPolicyArgs{...}
type RecordFailoverRoutingPolicyOutput ¶
type RecordFailoverRoutingPolicyOutput struct{ *pulumi.OutputState }
func (RecordFailoverRoutingPolicyOutput) ElementType ¶
func (RecordFailoverRoutingPolicyOutput) ElementType() reflect.Type
func (RecordFailoverRoutingPolicyOutput) ToRecordFailoverRoutingPolicyOutput ¶
func (o RecordFailoverRoutingPolicyOutput) ToRecordFailoverRoutingPolicyOutput() RecordFailoverRoutingPolicyOutput
func (RecordFailoverRoutingPolicyOutput) ToRecordFailoverRoutingPolicyOutputWithContext ¶
func (o RecordFailoverRoutingPolicyOutput) ToRecordFailoverRoutingPolicyOutputWithContext(ctx context.Context) RecordFailoverRoutingPolicyOutput
func (RecordFailoverRoutingPolicyOutput) Type ¶
func (o RecordFailoverRoutingPolicyOutput) Type() pulumi.StringOutput
`PRIMARY` or `SECONDARY`. A `PRIMARY` record will be served if its healthcheck is passing, otherwise the `SECONDARY` will be served. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/dns-failover-configuring-options.html#dns-failover-failover-rrsets
type RecordGeolocationRoutingPolicy ¶
type RecordGeolocationRoutingPolicy struct { // A two-letter continent code. See http://docs.aws.amazon.com/Route53/latest/APIReference/API_GetGeoLocation.html for code details. Either `continent` or `country` must be specified. Continent *string `pulumi:"continent"` // A two-character country code or `*` to indicate a default resource record set. Country *string `pulumi:"country"` // A subdivision code for a country. Subdivision *string `pulumi:"subdivision"` }
type RecordGeolocationRoutingPolicyArgs ¶
type RecordGeolocationRoutingPolicyArgs struct { // A two-letter continent code. See http://docs.aws.amazon.com/Route53/latest/APIReference/API_GetGeoLocation.html for code details. Either `continent` or `country` must be specified. Continent pulumi.StringPtrInput `pulumi:"continent"` // A two-character country code or `*` to indicate a default resource record set. Country pulumi.StringPtrInput `pulumi:"country"` // A subdivision code for a country. Subdivision pulumi.StringPtrInput `pulumi:"subdivision"` }
func (RecordGeolocationRoutingPolicyArgs) ElementType ¶
func (RecordGeolocationRoutingPolicyArgs) ElementType() reflect.Type
func (RecordGeolocationRoutingPolicyArgs) ToRecordGeolocationRoutingPolicyOutput ¶
func (i RecordGeolocationRoutingPolicyArgs) ToRecordGeolocationRoutingPolicyOutput() RecordGeolocationRoutingPolicyOutput
func (RecordGeolocationRoutingPolicyArgs) ToRecordGeolocationRoutingPolicyOutputWithContext ¶
func (i RecordGeolocationRoutingPolicyArgs) ToRecordGeolocationRoutingPolicyOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyOutput
type RecordGeolocationRoutingPolicyArray ¶
type RecordGeolocationRoutingPolicyArray []RecordGeolocationRoutingPolicyInput
func (RecordGeolocationRoutingPolicyArray) ElementType ¶
func (RecordGeolocationRoutingPolicyArray) ElementType() reflect.Type
func (RecordGeolocationRoutingPolicyArray) ToRecordGeolocationRoutingPolicyArrayOutput ¶
func (i RecordGeolocationRoutingPolicyArray) ToRecordGeolocationRoutingPolicyArrayOutput() RecordGeolocationRoutingPolicyArrayOutput
func (RecordGeolocationRoutingPolicyArray) ToRecordGeolocationRoutingPolicyArrayOutputWithContext ¶
func (i RecordGeolocationRoutingPolicyArray) ToRecordGeolocationRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyArrayOutput
type RecordGeolocationRoutingPolicyArrayInput ¶
type RecordGeolocationRoutingPolicyArrayInput interface { pulumi.Input ToRecordGeolocationRoutingPolicyArrayOutput() RecordGeolocationRoutingPolicyArrayOutput ToRecordGeolocationRoutingPolicyArrayOutputWithContext(context.Context) RecordGeolocationRoutingPolicyArrayOutput }
RecordGeolocationRoutingPolicyArrayInput is an input type that accepts RecordGeolocationRoutingPolicyArray and RecordGeolocationRoutingPolicyArrayOutput values. You can construct a concrete instance of `RecordGeolocationRoutingPolicyArrayInput` via:
RecordGeolocationRoutingPolicyArray{ RecordGeolocationRoutingPolicyArgs{...} }
type RecordGeolocationRoutingPolicyArrayOutput ¶
type RecordGeolocationRoutingPolicyArrayOutput struct{ *pulumi.OutputState }
func (RecordGeolocationRoutingPolicyArrayOutput) ElementType ¶
func (RecordGeolocationRoutingPolicyArrayOutput) ElementType() reflect.Type
func (RecordGeolocationRoutingPolicyArrayOutput) ToRecordGeolocationRoutingPolicyArrayOutput ¶
func (o RecordGeolocationRoutingPolicyArrayOutput) ToRecordGeolocationRoutingPolicyArrayOutput() RecordGeolocationRoutingPolicyArrayOutput
func (RecordGeolocationRoutingPolicyArrayOutput) ToRecordGeolocationRoutingPolicyArrayOutputWithContext ¶
func (o RecordGeolocationRoutingPolicyArrayOutput) ToRecordGeolocationRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyArrayOutput
type RecordGeolocationRoutingPolicyInput ¶
type RecordGeolocationRoutingPolicyInput interface { pulumi.Input ToRecordGeolocationRoutingPolicyOutput() RecordGeolocationRoutingPolicyOutput ToRecordGeolocationRoutingPolicyOutputWithContext(context.Context) RecordGeolocationRoutingPolicyOutput }
RecordGeolocationRoutingPolicyInput is an input type that accepts RecordGeolocationRoutingPolicyArgs and RecordGeolocationRoutingPolicyOutput values. You can construct a concrete instance of `RecordGeolocationRoutingPolicyInput` via:
RecordGeolocationRoutingPolicyArgs{...}
type RecordGeolocationRoutingPolicyOutput ¶
type RecordGeolocationRoutingPolicyOutput struct{ *pulumi.OutputState }
func (RecordGeolocationRoutingPolicyOutput) Continent ¶
func (o RecordGeolocationRoutingPolicyOutput) Continent() pulumi.StringPtrOutput
A two-letter continent code. See http://docs.aws.amazon.com/Route53/latest/APIReference/API_GetGeoLocation.html for code details. Either `continent` or `country` must be specified.
func (RecordGeolocationRoutingPolicyOutput) Country ¶
func (o RecordGeolocationRoutingPolicyOutput) Country() pulumi.StringPtrOutput
A two-character country code or `*` to indicate a default resource record set.
func (RecordGeolocationRoutingPolicyOutput) ElementType ¶
func (RecordGeolocationRoutingPolicyOutput) ElementType() reflect.Type
func (RecordGeolocationRoutingPolicyOutput) Subdivision ¶
func (o RecordGeolocationRoutingPolicyOutput) Subdivision() pulumi.StringPtrOutput
A subdivision code for a country.
func (RecordGeolocationRoutingPolicyOutput) ToRecordGeolocationRoutingPolicyOutput ¶
func (o RecordGeolocationRoutingPolicyOutput) ToRecordGeolocationRoutingPolicyOutput() RecordGeolocationRoutingPolicyOutput
func (RecordGeolocationRoutingPolicyOutput) ToRecordGeolocationRoutingPolicyOutputWithContext ¶
func (o RecordGeolocationRoutingPolicyOutput) ToRecordGeolocationRoutingPolicyOutputWithContext(ctx context.Context) RecordGeolocationRoutingPolicyOutput
type RecordLatencyRoutingPolicy ¶
type RecordLatencyRoutingPolicy struct { // An AWS region from which to measure latency. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/routing-policy.html#routing-policy-latency Region string `pulumi:"region"` }
type RecordLatencyRoutingPolicyArgs ¶
type RecordLatencyRoutingPolicyArgs struct { // An AWS region from which to measure latency. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/routing-policy.html#routing-policy-latency Region pulumi.StringInput `pulumi:"region"` }
func (RecordLatencyRoutingPolicyArgs) ElementType ¶
func (RecordLatencyRoutingPolicyArgs) ElementType() reflect.Type
func (RecordLatencyRoutingPolicyArgs) ToRecordLatencyRoutingPolicyOutput ¶
func (i RecordLatencyRoutingPolicyArgs) ToRecordLatencyRoutingPolicyOutput() RecordLatencyRoutingPolicyOutput
func (RecordLatencyRoutingPolicyArgs) ToRecordLatencyRoutingPolicyOutputWithContext ¶
func (i RecordLatencyRoutingPolicyArgs) ToRecordLatencyRoutingPolicyOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyOutput
type RecordLatencyRoutingPolicyArray ¶
type RecordLatencyRoutingPolicyArray []RecordLatencyRoutingPolicyInput
func (RecordLatencyRoutingPolicyArray) ElementType ¶
func (RecordLatencyRoutingPolicyArray) ElementType() reflect.Type
func (RecordLatencyRoutingPolicyArray) ToRecordLatencyRoutingPolicyArrayOutput ¶
func (i RecordLatencyRoutingPolicyArray) ToRecordLatencyRoutingPolicyArrayOutput() RecordLatencyRoutingPolicyArrayOutput
func (RecordLatencyRoutingPolicyArray) ToRecordLatencyRoutingPolicyArrayOutputWithContext ¶
func (i RecordLatencyRoutingPolicyArray) ToRecordLatencyRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyArrayOutput
type RecordLatencyRoutingPolicyArrayInput ¶
type RecordLatencyRoutingPolicyArrayInput interface { pulumi.Input ToRecordLatencyRoutingPolicyArrayOutput() RecordLatencyRoutingPolicyArrayOutput ToRecordLatencyRoutingPolicyArrayOutputWithContext(context.Context) RecordLatencyRoutingPolicyArrayOutput }
RecordLatencyRoutingPolicyArrayInput is an input type that accepts RecordLatencyRoutingPolicyArray and RecordLatencyRoutingPolicyArrayOutput values. You can construct a concrete instance of `RecordLatencyRoutingPolicyArrayInput` via:
RecordLatencyRoutingPolicyArray{ RecordLatencyRoutingPolicyArgs{...} }
type RecordLatencyRoutingPolicyArrayOutput ¶
type RecordLatencyRoutingPolicyArrayOutput struct{ *pulumi.OutputState }
func (RecordLatencyRoutingPolicyArrayOutput) ElementType ¶
func (RecordLatencyRoutingPolicyArrayOutput) ElementType() reflect.Type
func (RecordLatencyRoutingPolicyArrayOutput) Index ¶
func (o RecordLatencyRoutingPolicyArrayOutput) Index(i pulumi.IntInput) RecordLatencyRoutingPolicyOutput
func (RecordLatencyRoutingPolicyArrayOutput) ToRecordLatencyRoutingPolicyArrayOutput ¶
func (o RecordLatencyRoutingPolicyArrayOutput) ToRecordLatencyRoutingPolicyArrayOutput() RecordLatencyRoutingPolicyArrayOutput
func (RecordLatencyRoutingPolicyArrayOutput) ToRecordLatencyRoutingPolicyArrayOutputWithContext ¶
func (o RecordLatencyRoutingPolicyArrayOutput) ToRecordLatencyRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyArrayOutput
type RecordLatencyRoutingPolicyInput ¶
type RecordLatencyRoutingPolicyInput interface { pulumi.Input ToRecordLatencyRoutingPolicyOutput() RecordLatencyRoutingPolicyOutput ToRecordLatencyRoutingPolicyOutputWithContext(context.Context) RecordLatencyRoutingPolicyOutput }
RecordLatencyRoutingPolicyInput is an input type that accepts RecordLatencyRoutingPolicyArgs and RecordLatencyRoutingPolicyOutput values. You can construct a concrete instance of `RecordLatencyRoutingPolicyInput` via:
RecordLatencyRoutingPolicyArgs{...}
type RecordLatencyRoutingPolicyOutput ¶
type RecordLatencyRoutingPolicyOutput struct{ *pulumi.OutputState }
func (RecordLatencyRoutingPolicyOutput) ElementType ¶
func (RecordLatencyRoutingPolicyOutput) ElementType() reflect.Type
func (RecordLatencyRoutingPolicyOutput) Region ¶
func (o RecordLatencyRoutingPolicyOutput) Region() pulumi.StringOutput
An AWS region from which to measure latency. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/routing-policy.html#routing-policy-latency
func (RecordLatencyRoutingPolicyOutput) ToRecordLatencyRoutingPolicyOutput ¶
func (o RecordLatencyRoutingPolicyOutput) ToRecordLatencyRoutingPolicyOutput() RecordLatencyRoutingPolicyOutput
func (RecordLatencyRoutingPolicyOutput) ToRecordLatencyRoutingPolicyOutputWithContext ¶
func (o RecordLatencyRoutingPolicyOutput) ToRecordLatencyRoutingPolicyOutputWithContext(ctx context.Context) RecordLatencyRoutingPolicyOutput
type RecordState ¶
type RecordState struct { // An alias block. Conflicts with `ttl` & `records`. // Alias record documented below. Aliases RecordAliasArrayInput // Allow creation of this record to overwrite an existing record, if any. This does not affect the ability to update the record using this provider and does not prevent other resources within this provider or manual Route 53 changes outside this provider from overwriting this record. `false` by default. This configuration is not recommended for most environments. AllowOverwrite pulumi.BoolPtrInput // A block indicating the routing behavior when associated health check fails. Conflicts with any other routing policy. Documented below. FailoverRoutingPolicies RecordFailoverRoutingPolicyArrayInput // [FQDN](https://en.wikipedia.org/wiki/Fully_qualified_domain_name) built using the zone domain and `name`. Fqdn pulumi.StringPtrInput // A block indicating a routing policy based on the geolocation of the requestor. Conflicts with any other routing policy. Documented below. GeolocationRoutingPolicies RecordGeolocationRoutingPolicyArrayInput // The health check the record should be associated with. HealthCheckId pulumi.StringPtrInput // A block indicating a routing policy based on the latency between the requestor and an AWS region. Conflicts with any other routing policy. Documented below. LatencyRoutingPolicies RecordLatencyRoutingPolicyArrayInput // Set to `true` to indicate a multivalue answer routing policy. Conflicts with any other routing policy. MultivalueAnswerRoutingPolicy pulumi.BoolPtrInput // DNS domain name for a CloudFront distribution, S3 bucket, ELB, or another resource record set in this hosted zone. Name pulumi.StringPtrInput // A string list of records. To specify a single record value longer than 255 characters such as a TXT record for DKIM, add `\"\"` inside the configuration string (e.g. `"first255characters\"\"morecharacters"`). Records pulumi.StringArrayInput // Unique identifier to differentiate records with routing policies from one another. Required if using `failover`, `geolocation`, `latency`, or `weighted` routing policies documented below. SetIdentifier pulumi.StringPtrInput // The TTL of the record. Ttl pulumi.IntPtrInput // `PRIMARY` or `SECONDARY`. A `PRIMARY` record will be served if its healthcheck is passing, otherwise the `SECONDARY` will be served. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/dns-failover-configuring-options.html#dns-failover-failover-rrsets Type pulumi.StringPtrInput // A block indicating a weighted routing policy. Conflicts with any other routing policy. Documented below. WeightedRoutingPolicies RecordWeightedRoutingPolicyArrayInput // Hosted zone ID for a CloudFront distribution, S3 bucket, ELB, or Route 53 hosted zone. See `resource_elb.zone_id` for example. ZoneId pulumi.StringPtrInput }
func (RecordState) ElementType ¶
func (RecordState) ElementType() reflect.Type
type RecordWeightedRoutingPolicy ¶
type RecordWeightedRoutingPolicy struct { // A numeric value indicating the relative weight of the record. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/routing-policy.html#routing-policy-weighted. Weight int `pulumi:"weight"` }
type RecordWeightedRoutingPolicyArgs ¶
type RecordWeightedRoutingPolicyArgs struct { // A numeric value indicating the relative weight of the record. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/routing-policy.html#routing-policy-weighted. Weight pulumi.IntInput `pulumi:"weight"` }
func (RecordWeightedRoutingPolicyArgs) ElementType ¶
func (RecordWeightedRoutingPolicyArgs) ElementType() reflect.Type
func (RecordWeightedRoutingPolicyArgs) ToRecordWeightedRoutingPolicyOutput ¶
func (i RecordWeightedRoutingPolicyArgs) ToRecordWeightedRoutingPolicyOutput() RecordWeightedRoutingPolicyOutput
func (RecordWeightedRoutingPolicyArgs) ToRecordWeightedRoutingPolicyOutputWithContext ¶
func (i RecordWeightedRoutingPolicyArgs) ToRecordWeightedRoutingPolicyOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyOutput
type RecordWeightedRoutingPolicyArray ¶
type RecordWeightedRoutingPolicyArray []RecordWeightedRoutingPolicyInput
func (RecordWeightedRoutingPolicyArray) ElementType ¶
func (RecordWeightedRoutingPolicyArray) ElementType() reflect.Type
func (RecordWeightedRoutingPolicyArray) ToRecordWeightedRoutingPolicyArrayOutput ¶
func (i RecordWeightedRoutingPolicyArray) ToRecordWeightedRoutingPolicyArrayOutput() RecordWeightedRoutingPolicyArrayOutput
func (RecordWeightedRoutingPolicyArray) ToRecordWeightedRoutingPolicyArrayOutputWithContext ¶
func (i RecordWeightedRoutingPolicyArray) ToRecordWeightedRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyArrayOutput
type RecordWeightedRoutingPolicyArrayInput ¶
type RecordWeightedRoutingPolicyArrayInput interface { pulumi.Input ToRecordWeightedRoutingPolicyArrayOutput() RecordWeightedRoutingPolicyArrayOutput ToRecordWeightedRoutingPolicyArrayOutputWithContext(context.Context) RecordWeightedRoutingPolicyArrayOutput }
RecordWeightedRoutingPolicyArrayInput is an input type that accepts RecordWeightedRoutingPolicyArray and RecordWeightedRoutingPolicyArrayOutput values. You can construct a concrete instance of `RecordWeightedRoutingPolicyArrayInput` via:
RecordWeightedRoutingPolicyArray{ RecordWeightedRoutingPolicyArgs{...} }
type RecordWeightedRoutingPolicyArrayOutput ¶
type RecordWeightedRoutingPolicyArrayOutput struct{ *pulumi.OutputState }
func (RecordWeightedRoutingPolicyArrayOutput) ElementType ¶
func (RecordWeightedRoutingPolicyArrayOutput) ElementType() reflect.Type
func (RecordWeightedRoutingPolicyArrayOutput) ToRecordWeightedRoutingPolicyArrayOutput ¶
func (o RecordWeightedRoutingPolicyArrayOutput) ToRecordWeightedRoutingPolicyArrayOutput() RecordWeightedRoutingPolicyArrayOutput
func (RecordWeightedRoutingPolicyArrayOutput) ToRecordWeightedRoutingPolicyArrayOutputWithContext ¶
func (o RecordWeightedRoutingPolicyArrayOutput) ToRecordWeightedRoutingPolicyArrayOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyArrayOutput
type RecordWeightedRoutingPolicyInput ¶
type RecordWeightedRoutingPolicyInput interface { pulumi.Input ToRecordWeightedRoutingPolicyOutput() RecordWeightedRoutingPolicyOutput ToRecordWeightedRoutingPolicyOutputWithContext(context.Context) RecordWeightedRoutingPolicyOutput }
RecordWeightedRoutingPolicyInput is an input type that accepts RecordWeightedRoutingPolicyArgs and RecordWeightedRoutingPolicyOutput values. You can construct a concrete instance of `RecordWeightedRoutingPolicyInput` via:
RecordWeightedRoutingPolicyArgs{...}
type RecordWeightedRoutingPolicyOutput ¶
type RecordWeightedRoutingPolicyOutput struct{ *pulumi.OutputState }
func (RecordWeightedRoutingPolicyOutput) ElementType ¶
func (RecordWeightedRoutingPolicyOutput) ElementType() reflect.Type
func (RecordWeightedRoutingPolicyOutput) ToRecordWeightedRoutingPolicyOutput ¶
func (o RecordWeightedRoutingPolicyOutput) ToRecordWeightedRoutingPolicyOutput() RecordWeightedRoutingPolicyOutput
func (RecordWeightedRoutingPolicyOutput) ToRecordWeightedRoutingPolicyOutputWithContext ¶
func (o RecordWeightedRoutingPolicyOutput) ToRecordWeightedRoutingPolicyOutputWithContext(ctx context.Context) RecordWeightedRoutingPolicyOutput
func (RecordWeightedRoutingPolicyOutput) Weight ¶
func (o RecordWeightedRoutingPolicyOutput) Weight() pulumi.IntOutput
A numeric value indicating the relative weight of the record. See http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/routing-policy.html#routing-policy-weighted.
type ResolverEndpoint ¶
type ResolverEndpoint struct { pulumi.CustomResourceState // The ARN of the Route 53 Resolver endpoint. Arn pulumi.StringOutput `pulumi:"arn"` // The direction of DNS queries to or from the Route 53 Resolver endpoint. // Valid values are `INBOUND` (resolver forwards DNS queries to the DNS service for a VPC from your network or another VPC) // or `OUTBOUND` (resolver forwards DNS queries from the DNS service for a VPC to your network or another VPC). Direction pulumi.StringOutput `pulumi:"direction"` // The ID of the VPC that you want to create the resolver endpoint in. HostVpcId pulumi.StringOutput `pulumi:"hostVpcId"` // The subnets and IP addresses in your VPC that you want DNS queries to pass through on the way from your VPCs // to your network (for outbound endpoints) or on the way from your network to your VPCs (for inbound endpoints). Described below. IpAddresses ResolverEndpointIpAddressArrayOutput `pulumi:"ipAddresses"` // The friendly name of the Route 53 Resolver endpoint. Name pulumi.StringOutput `pulumi:"name"` // The ID of one or more security groups that you want to use to control access to this VPC. SecurityGroupIds pulumi.StringArrayOutput `pulumi:"securityGroupIds"` // A map of tags to assign to the resource. Tags pulumi.StringMapOutput `pulumi:"tags"` }
Provides a Route 53 Resolver endpoint resource.
## Example Usage
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewResolverEndpoint(ctx, "foo", &route53.ResolverEndpointArgs{ Direction: pulumi.String("INBOUND"), SecurityGroupIds: pulumi.StringArray{ pulumi.Any(aws_security_group.Sg1.Id), pulumi.Any(aws_security_group.Sg2.Id), }, IpAddresses: route53.ResolverEndpointIpAddressArray{ &route53.ResolverEndpointIpAddressArgs{ SubnetId: pulumi.Any(aws_subnet.Sn1.Id), }, &route53.ResolverEndpointIpAddressArgs{ SubnetId: pulumi.Any(aws_subnet.Sn2.Id), Ip: pulumi.String("10.0.64.4"), }, }, Tags: pulumi.StringMap{ "Environment": pulumi.String("Prod"), }, }) if err != nil { return err } return nil }) }
```
func GetResolverEndpoint ¶
func GetResolverEndpoint(ctx *pulumi.Context, name string, id pulumi.IDInput, state *ResolverEndpointState, opts ...pulumi.ResourceOption) (*ResolverEndpoint, error)
GetResolverEndpoint gets an existing ResolverEndpoint resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewResolverEndpoint ¶
func NewResolverEndpoint(ctx *pulumi.Context, name string, args *ResolverEndpointArgs, opts ...pulumi.ResourceOption) (*ResolverEndpoint, error)
NewResolverEndpoint registers a new resource with the given unique name, arguments, and options.
type ResolverEndpointArgs ¶
type ResolverEndpointArgs struct { // The direction of DNS queries to or from the Route 53 Resolver endpoint. // Valid values are `INBOUND` (resolver forwards DNS queries to the DNS service for a VPC from your network or another VPC) // or `OUTBOUND` (resolver forwards DNS queries from the DNS service for a VPC to your network or another VPC). Direction pulumi.StringInput // The subnets and IP addresses in your VPC that you want DNS queries to pass through on the way from your VPCs // to your network (for outbound endpoints) or on the way from your network to your VPCs (for inbound endpoints). Described below. IpAddresses ResolverEndpointIpAddressArrayInput // The friendly name of the Route 53 Resolver endpoint. Name pulumi.StringPtrInput // The ID of one or more security groups that you want to use to control access to this VPC. SecurityGroupIds pulumi.StringArrayInput // A map of tags to assign to the resource. Tags pulumi.StringMapInput }
The set of arguments for constructing a ResolverEndpoint resource.
func (ResolverEndpointArgs) ElementType ¶
func (ResolverEndpointArgs) ElementType() reflect.Type
type ResolverEndpointIpAddressArgs ¶
type ResolverEndpointIpAddressArgs struct { // The IP address in the subnet that you want to use for DNS queries. Ip pulumi.StringPtrInput `pulumi:"ip"` IpId pulumi.StringPtrInput `pulumi:"ipId"` // The ID of the subnet that contains the IP address. SubnetId pulumi.StringInput `pulumi:"subnetId"` }
func (ResolverEndpointIpAddressArgs) ElementType ¶
func (ResolverEndpointIpAddressArgs) ElementType() reflect.Type
func (ResolverEndpointIpAddressArgs) ToResolverEndpointIpAddressOutput ¶
func (i ResolverEndpointIpAddressArgs) ToResolverEndpointIpAddressOutput() ResolverEndpointIpAddressOutput
func (ResolverEndpointIpAddressArgs) ToResolverEndpointIpAddressOutputWithContext ¶
func (i ResolverEndpointIpAddressArgs) ToResolverEndpointIpAddressOutputWithContext(ctx context.Context) ResolverEndpointIpAddressOutput
type ResolverEndpointIpAddressArray ¶
type ResolverEndpointIpAddressArray []ResolverEndpointIpAddressInput
func (ResolverEndpointIpAddressArray) ElementType ¶
func (ResolverEndpointIpAddressArray) ElementType() reflect.Type
func (ResolverEndpointIpAddressArray) ToResolverEndpointIpAddressArrayOutput ¶
func (i ResolverEndpointIpAddressArray) ToResolverEndpointIpAddressArrayOutput() ResolverEndpointIpAddressArrayOutput
func (ResolverEndpointIpAddressArray) ToResolverEndpointIpAddressArrayOutputWithContext ¶
func (i ResolverEndpointIpAddressArray) ToResolverEndpointIpAddressArrayOutputWithContext(ctx context.Context) ResolverEndpointIpAddressArrayOutput
type ResolverEndpointIpAddressArrayInput ¶
type ResolverEndpointIpAddressArrayInput interface { pulumi.Input ToResolverEndpointIpAddressArrayOutput() ResolverEndpointIpAddressArrayOutput ToResolverEndpointIpAddressArrayOutputWithContext(context.Context) ResolverEndpointIpAddressArrayOutput }
ResolverEndpointIpAddressArrayInput is an input type that accepts ResolverEndpointIpAddressArray and ResolverEndpointIpAddressArrayOutput values. You can construct a concrete instance of `ResolverEndpointIpAddressArrayInput` via:
ResolverEndpointIpAddressArray{ ResolverEndpointIpAddressArgs{...} }
type ResolverEndpointIpAddressArrayOutput ¶
type ResolverEndpointIpAddressArrayOutput struct{ *pulumi.OutputState }
func (ResolverEndpointIpAddressArrayOutput) ElementType ¶
func (ResolverEndpointIpAddressArrayOutput) ElementType() reflect.Type
func (ResolverEndpointIpAddressArrayOutput) Index ¶
func (o ResolverEndpointIpAddressArrayOutput) Index(i pulumi.IntInput) ResolverEndpointIpAddressOutput
func (ResolverEndpointIpAddressArrayOutput) ToResolverEndpointIpAddressArrayOutput ¶
func (o ResolverEndpointIpAddressArrayOutput) ToResolverEndpointIpAddressArrayOutput() ResolverEndpointIpAddressArrayOutput
func (ResolverEndpointIpAddressArrayOutput) ToResolverEndpointIpAddressArrayOutputWithContext ¶
func (o ResolverEndpointIpAddressArrayOutput) ToResolverEndpointIpAddressArrayOutputWithContext(ctx context.Context) ResolverEndpointIpAddressArrayOutput
type ResolverEndpointIpAddressInput ¶
type ResolverEndpointIpAddressInput interface { pulumi.Input ToResolverEndpointIpAddressOutput() ResolverEndpointIpAddressOutput ToResolverEndpointIpAddressOutputWithContext(context.Context) ResolverEndpointIpAddressOutput }
ResolverEndpointIpAddressInput is an input type that accepts ResolverEndpointIpAddressArgs and ResolverEndpointIpAddressOutput values. You can construct a concrete instance of `ResolverEndpointIpAddressInput` via:
ResolverEndpointIpAddressArgs{...}
type ResolverEndpointIpAddressOutput ¶
type ResolverEndpointIpAddressOutput struct{ *pulumi.OutputState }
func (ResolverEndpointIpAddressOutput) ElementType ¶
func (ResolverEndpointIpAddressOutput) ElementType() reflect.Type
func (ResolverEndpointIpAddressOutput) Ip ¶
func (o ResolverEndpointIpAddressOutput) Ip() pulumi.StringPtrOutput
The IP address in the subnet that you want to use for DNS queries.
func (ResolverEndpointIpAddressOutput) IpId ¶
func (o ResolverEndpointIpAddressOutput) IpId() pulumi.StringPtrOutput
func (ResolverEndpointIpAddressOutput) SubnetId ¶
func (o ResolverEndpointIpAddressOutput) SubnetId() pulumi.StringOutput
The ID of the subnet that contains the IP address.
func (ResolverEndpointIpAddressOutput) ToResolverEndpointIpAddressOutput ¶
func (o ResolverEndpointIpAddressOutput) ToResolverEndpointIpAddressOutput() ResolverEndpointIpAddressOutput
func (ResolverEndpointIpAddressOutput) ToResolverEndpointIpAddressOutputWithContext ¶
func (o ResolverEndpointIpAddressOutput) ToResolverEndpointIpAddressOutputWithContext(ctx context.Context) ResolverEndpointIpAddressOutput
type ResolverEndpointState ¶
type ResolverEndpointState struct { // The ARN of the Route 53 Resolver endpoint. Arn pulumi.StringPtrInput // The direction of DNS queries to or from the Route 53 Resolver endpoint. // Valid values are `INBOUND` (resolver forwards DNS queries to the DNS service for a VPC from your network or another VPC) // or `OUTBOUND` (resolver forwards DNS queries from the DNS service for a VPC to your network or another VPC). Direction pulumi.StringPtrInput // The ID of the VPC that you want to create the resolver endpoint in. HostVpcId pulumi.StringPtrInput // The subnets and IP addresses in your VPC that you want DNS queries to pass through on the way from your VPCs // to your network (for outbound endpoints) or on the way from your network to your VPCs (for inbound endpoints). Described below. IpAddresses ResolverEndpointIpAddressArrayInput // The friendly name of the Route 53 Resolver endpoint. Name pulumi.StringPtrInput // The ID of one or more security groups that you want to use to control access to this VPC. SecurityGroupIds pulumi.StringArrayInput // A map of tags to assign to the resource. Tags pulumi.StringMapInput }
func (ResolverEndpointState) ElementType ¶
func (ResolverEndpointState) ElementType() reflect.Type
type ResolverRule ¶
type ResolverRule struct { pulumi.CustomResourceState // The ARN (Amazon Resource Name) for the resolver rule. Arn pulumi.StringOutput `pulumi:"arn"` // DNS queries for this domain name are forwarded to the IP addresses that are specified using `targetIp`. DomainName pulumi.StringOutput `pulumi:"domainName"` // A friendly name that lets you easily find a rule in the Resolver dashboard in the Route 53 console. Name pulumi.StringOutput `pulumi:"name"` // When a rule is shared with another AWS account, the account ID of the account that the rule is shared with. OwnerId pulumi.StringOutput `pulumi:"ownerId"` // The ID of the outbound resolver endpoint that you want to use to route DNS queries to the IP addresses that you specify using `targetIp`. // This argument should only be specified for `FORWARD` type rules. ResolverEndpointId pulumi.StringPtrOutput `pulumi:"resolverEndpointId"` // The rule type. Valid values are `FORWARD`, `SYSTEM` and `RECURSIVE`. RuleType pulumi.StringOutput `pulumi:"ruleType"` // Values are `NOT_SHARED`, `SHARED_BY_ME` or `SHARED_WITH_ME` ShareStatus pulumi.StringOutput `pulumi:"shareStatus"` // A map of tags to assign to the resource. Tags pulumi.StringMapOutput `pulumi:"tags"` // Configuration block(s) indicating the IPs that you want Resolver to forward DNS queries to (documented below). // This argument should only be specified for `FORWARD` type rules. TargetIps ResolverRuleTargetIpArrayOutput `pulumi:"targetIps"` }
Provides a Route53 Resolver rule.
## Example Usage ### System rule
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewResolverRule(ctx, "sys", &route53.ResolverRuleArgs{ DomainName: pulumi.String("subdomain.example.com"), RuleType: pulumi.String("SYSTEM"), }) if err != nil { return err } return nil }) }
``` ### Forward rule
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewResolverRule(ctx, "fwd", &route53.ResolverRuleArgs{ DomainName: pulumi.String("example.com"), RuleType: pulumi.String("FORWARD"), ResolverEndpointId: pulumi.Any(aws_route53_resolver_endpoint.Foo.Id), TargetIps: route53.ResolverRuleTargetIpArray{ &route53.ResolverRuleTargetIpArgs{ Ip: pulumi.String("123.45.67.89"), }, }, Tags: pulumi.StringMap{ "Environment": pulumi.String("Prod"), }, }) if err != nil { return err } return nil }) }
```
func GetResolverRule ¶
func GetResolverRule(ctx *pulumi.Context, name string, id pulumi.IDInput, state *ResolverRuleState, opts ...pulumi.ResourceOption) (*ResolverRule, error)
GetResolverRule gets an existing ResolverRule resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewResolverRule ¶
func NewResolverRule(ctx *pulumi.Context, name string, args *ResolverRuleArgs, opts ...pulumi.ResourceOption) (*ResolverRule, error)
NewResolverRule registers a new resource with the given unique name, arguments, and options.
type ResolverRuleArgs ¶
type ResolverRuleArgs struct { // DNS queries for this domain name are forwarded to the IP addresses that are specified using `targetIp`. DomainName pulumi.StringInput // A friendly name that lets you easily find a rule in the Resolver dashboard in the Route 53 console. Name pulumi.StringPtrInput // The ID of the outbound resolver endpoint that you want to use to route DNS queries to the IP addresses that you specify using `targetIp`. // This argument should only be specified for `FORWARD` type rules. ResolverEndpointId pulumi.StringPtrInput // The rule type. Valid values are `FORWARD`, `SYSTEM` and `RECURSIVE`. RuleType pulumi.StringInput // A map of tags to assign to the resource. Tags pulumi.StringMapInput // Configuration block(s) indicating the IPs that you want Resolver to forward DNS queries to (documented below). // This argument should only be specified for `FORWARD` type rules. TargetIps ResolverRuleTargetIpArrayInput }
The set of arguments for constructing a ResolverRule resource.
func (ResolverRuleArgs) ElementType ¶
func (ResolverRuleArgs) ElementType() reflect.Type
type ResolverRuleAssociation ¶
type ResolverRuleAssociation struct { pulumi.CustomResourceState // A name for the association that you're creating between a resolver rule and a VPC. Name pulumi.StringOutput `pulumi:"name"` // The ID of the resolver rule that you want to associate with the VPC. ResolverRuleId pulumi.StringOutput `pulumi:"resolverRuleId"` // The ID of the VPC that you want to associate the resolver rule with. VpcId pulumi.StringOutput `pulumi:"vpcId"` }
Provides a Route53 Resolver rule association.
## Example Usage
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewResolverRuleAssociation(ctx, "example", &route53.ResolverRuleAssociationArgs{ ResolverRuleId: pulumi.Any(aws_route53_resolver_rule.Sys.Id), VpcId: pulumi.Any(aws_vpc.Foo.Id), }) if err != nil { return err } return nil }) }
```
func GetResolverRuleAssociation ¶
func GetResolverRuleAssociation(ctx *pulumi.Context, name string, id pulumi.IDInput, state *ResolverRuleAssociationState, opts ...pulumi.ResourceOption) (*ResolverRuleAssociation, error)
GetResolverRuleAssociation gets an existing ResolverRuleAssociation resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewResolverRuleAssociation ¶
func NewResolverRuleAssociation(ctx *pulumi.Context, name string, args *ResolverRuleAssociationArgs, opts ...pulumi.ResourceOption) (*ResolverRuleAssociation, error)
NewResolverRuleAssociation registers a new resource with the given unique name, arguments, and options.
type ResolverRuleAssociationArgs ¶
type ResolverRuleAssociationArgs struct { // A name for the association that you're creating between a resolver rule and a VPC. Name pulumi.StringPtrInput // The ID of the resolver rule that you want to associate with the VPC. ResolverRuleId pulumi.StringInput // The ID of the VPC that you want to associate the resolver rule with. VpcId pulumi.StringInput }
The set of arguments for constructing a ResolverRuleAssociation resource.
func (ResolverRuleAssociationArgs) ElementType ¶
func (ResolverRuleAssociationArgs) ElementType() reflect.Type
type ResolverRuleAssociationState ¶
type ResolverRuleAssociationState struct { // A name for the association that you're creating between a resolver rule and a VPC. Name pulumi.StringPtrInput // The ID of the resolver rule that you want to associate with the VPC. ResolverRuleId pulumi.StringPtrInput // The ID of the VPC that you want to associate the resolver rule with. VpcId pulumi.StringPtrInput }
func (ResolverRuleAssociationState) ElementType ¶
func (ResolverRuleAssociationState) ElementType() reflect.Type
type ResolverRuleState ¶
type ResolverRuleState struct { // The ARN (Amazon Resource Name) for the resolver rule. Arn pulumi.StringPtrInput // DNS queries for this domain name are forwarded to the IP addresses that are specified using `targetIp`. DomainName pulumi.StringPtrInput // A friendly name that lets you easily find a rule in the Resolver dashboard in the Route 53 console. Name pulumi.StringPtrInput // When a rule is shared with another AWS account, the account ID of the account that the rule is shared with. OwnerId pulumi.StringPtrInput // The ID of the outbound resolver endpoint that you want to use to route DNS queries to the IP addresses that you specify using `targetIp`. // This argument should only be specified for `FORWARD` type rules. ResolverEndpointId pulumi.StringPtrInput // The rule type. Valid values are `FORWARD`, `SYSTEM` and `RECURSIVE`. RuleType pulumi.StringPtrInput // Values are `NOT_SHARED`, `SHARED_BY_ME` or `SHARED_WITH_ME` ShareStatus pulumi.StringPtrInput // A map of tags to assign to the resource. Tags pulumi.StringMapInput // Configuration block(s) indicating the IPs that you want Resolver to forward DNS queries to (documented below). // This argument should only be specified for `FORWARD` type rules. TargetIps ResolverRuleTargetIpArrayInput }
func (ResolverRuleState) ElementType ¶
func (ResolverRuleState) ElementType() reflect.Type
type ResolverRuleTargetIp ¶
type ResolverRuleTargetIpArgs ¶
type ResolverRuleTargetIpArgs struct { // One IP address that you want to forward DNS queries to. You can specify only IPv4 addresses. Ip pulumi.StringInput `pulumi:"ip"` // The port at `ip` that you want to forward DNS queries to. Default value is `53` Port pulumi.IntPtrInput `pulumi:"port"` }
func (ResolverRuleTargetIpArgs) ElementType ¶
func (ResolverRuleTargetIpArgs) ElementType() reflect.Type
func (ResolverRuleTargetIpArgs) ToResolverRuleTargetIpOutput ¶
func (i ResolverRuleTargetIpArgs) ToResolverRuleTargetIpOutput() ResolverRuleTargetIpOutput
func (ResolverRuleTargetIpArgs) ToResolverRuleTargetIpOutputWithContext ¶
func (i ResolverRuleTargetIpArgs) ToResolverRuleTargetIpOutputWithContext(ctx context.Context) ResolverRuleTargetIpOutput
type ResolverRuleTargetIpArray ¶
type ResolverRuleTargetIpArray []ResolverRuleTargetIpInput
func (ResolverRuleTargetIpArray) ElementType ¶
func (ResolverRuleTargetIpArray) ElementType() reflect.Type
func (ResolverRuleTargetIpArray) ToResolverRuleTargetIpArrayOutput ¶
func (i ResolverRuleTargetIpArray) ToResolverRuleTargetIpArrayOutput() ResolverRuleTargetIpArrayOutput
func (ResolverRuleTargetIpArray) ToResolverRuleTargetIpArrayOutputWithContext ¶
func (i ResolverRuleTargetIpArray) ToResolverRuleTargetIpArrayOutputWithContext(ctx context.Context) ResolverRuleTargetIpArrayOutput
type ResolverRuleTargetIpArrayInput ¶
type ResolverRuleTargetIpArrayInput interface { pulumi.Input ToResolverRuleTargetIpArrayOutput() ResolverRuleTargetIpArrayOutput ToResolverRuleTargetIpArrayOutputWithContext(context.Context) ResolverRuleTargetIpArrayOutput }
ResolverRuleTargetIpArrayInput is an input type that accepts ResolverRuleTargetIpArray and ResolverRuleTargetIpArrayOutput values. You can construct a concrete instance of `ResolverRuleTargetIpArrayInput` via:
ResolverRuleTargetIpArray{ ResolverRuleTargetIpArgs{...} }
type ResolverRuleTargetIpArrayOutput ¶
type ResolverRuleTargetIpArrayOutput struct{ *pulumi.OutputState }
func (ResolverRuleTargetIpArrayOutput) ElementType ¶
func (ResolverRuleTargetIpArrayOutput) ElementType() reflect.Type
func (ResolverRuleTargetIpArrayOutput) Index ¶
func (o ResolverRuleTargetIpArrayOutput) Index(i pulumi.IntInput) ResolverRuleTargetIpOutput
func (ResolverRuleTargetIpArrayOutput) ToResolverRuleTargetIpArrayOutput ¶
func (o ResolverRuleTargetIpArrayOutput) ToResolverRuleTargetIpArrayOutput() ResolverRuleTargetIpArrayOutput
func (ResolverRuleTargetIpArrayOutput) ToResolverRuleTargetIpArrayOutputWithContext ¶
func (o ResolverRuleTargetIpArrayOutput) ToResolverRuleTargetIpArrayOutputWithContext(ctx context.Context) ResolverRuleTargetIpArrayOutput
type ResolverRuleTargetIpInput ¶
type ResolverRuleTargetIpInput interface { pulumi.Input ToResolverRuleTargetIpOutput() ResolverRuleTargetIpOutput ToResolverRuleTargetIpOutputWithContext(context.Context) ResolverRuleTargetIpOutput }
ResolverRuleTargetIpInput is an input type that accepts ResolverRuleTargetIpArgs and ResolverRuleTargetIpOutput values. You can construct a concrete instance of `ResolverRuleTargetIpInput` via:
ResolverRuleTargetIpArgs{...}
type ResolverRuleTargetIpOutput ¶
type ResolverRuleTargetIpOutput struct{ *pulumi.OutputState }
func (ResolverRuleTargetIpOutput) ElementType ¶
func (ResolverRuleTargetIpOutput) ElementType() reflect.Type
func (ResolverRuleTargetIpOutput) Ip ¶
func (o ResolverRuleTargetIpOutput) Ip() pulumi.StringOutput
One IP address that you want to forward DNS queries to. You can specify only IPv4 addresses.
func (ResolverRuleTargetIpOutput) Port ¶
func (o ResolverRuleTargetIpOutput) Port() pulumi.IntPtrOutput
The port at `ip` that you want to forward DNS queries to. Default value is `53`
func (ResolverRuleTargetIpOutput) ToResolverRuleTargetIpOutput ¶
func (o ResolverRuleTargetIpOutput) ToResolverRuleTargetIpOutput() ResolverRuleTargetIpOutput
func (ResolverRuleTargetIpOutput) ToResolverRuleTargetIpOutputWithContext ¶
func (o ResolverRuleTargetIpOutput) ToResolverRuleTargetIpOutputWithContext(ctx context.Context) ResolverRuleTargetIpOutput
type VpcAssociationAuthorization ¶ added in v3.1.0
type VpcAssociationAuthorization struct { pulumi.CustomResourceState // The VPC to authorize for association with the private hosted zone. VpcId pulumi.StringOutput `pulumi:"vpcId"` // The VPC's region. Defaults to the region of the AWS provider. VpcRegion pulumi.StringOutput `pulumi:"vpcRegion"` // The ID of the private hosted zone that you want to authorize associating a VPC with. ZoneId pulumi.StringOutput `pulumi:"zoneId"` }
Authorizes a VPC in a peer account to be associated with a local Route53 Hosted Zone.
## Example Usage
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/ec2" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/providers" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := providers.Newaws(ctx, "alternate", nil) if err != nil { return err } exampleVpc, err := ec2.NewVpc(ctx, "exampleVpc", &ec2.VpcArgs{ CidrBlock: pulumi.String("10.6.0.0/16"), EnableDnsHostnames: pulumi.Bool(true), EnableDnsSupport: pulumi.Bool(true), }) if err != nil { return err } exampleZone, err := route53.NewZone(ctx, "exampleZone", &route53.ZoneArgs{ Vpcs: route53.ZoneVpcArray{ &route53.ZoneVpcArgs{ VpcId: exampleVpc.ID(), }, }, }) if err != nil { return err } alternateVpc, err := ec2.NewVpc(ctx, "alternateVpc", &ec2.VpcArgs{ CidrBlock: pulumi.String("10.7.0.0/16"), EnableDnsHostnames: pulumi.Bool(true), EnableDnsSupport: pulumi.Bool(true), }, pulumi.Provider("aws.alternate")) if err != nil { return err } exampleVpcAssociationAuthorization, err := route53.NewVpcAssociationAuthorization(ctx, "exampleVpcAssociationAuthorization", &route53.VpcAssociationAuthorizationArgs{ VpcId: alternateVpc.ID(), ZoneId: exampleZone.ID(), }) if err != nil { return err } _, err = route53.NewZoneAssociation(ctx, "exampleZoneAssociation", &route53.ZoneAssociationArgs{ VpcId: exampleVpcAssociationAuthorization.VpcId, ZoneId: exampleVpcAssociationAuthorization.ZoneId, }, pulumi.Provider("aws.alternate")) if err != nil { return err } return nil }) }
```
func GetVpcAssociationAuthorization ¶ added in v3.1.0
func GetVpcAssociationAuthorization(ctx *pulumi.Context, name string, id pulumi.IDInput, state *VpcAssociationAuthorizationState, opts ...pulumi.ResourceOption) (*VpcAssociationAuthorization, error)
GetVpcAssociationAuthorization gets an existing VpcAssociationAuthorization resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewVpcAssociationAuthorization ¶ added in v3.1.0
func NewVpcAssociationAuthorization(ctx *pulumi.Context, name string, args *VpcAssociationAuthorizationArgs, opts ...pulumi.ResourceOption) (*VpcAssociationAuthorization, error)
NewVpcAssociationAuthorization registers a new resource with the given unique name, arguments, and options.
type VpcAssociationAuthorizationArgs ¶ added in v3.1.0
type VpcAssociationAuthorizationArgs struct { // The VPC to authorize for association with the private hosted zone. VpcId pulumi.StringInput // The VPC's region. Defaults to the region of the AWS provider. VpcRegion pulumi.StringPtrInput // The ID of the private hosted zone that you want to authorize associating a VPC with. ZoneId pulumi.StringInput }
The set of arguments for constructing a VpcAssociationAuthorization resource.
func (VpcAssociationAuthorizationArgs) ElementType ¶ added in v3.1.0
func (VpcAssociationAuthorizationArgs) ElementType() reflect.Type
type VpcAssociationAuthorizationState ¶ added in v3.1.0
type VpcAssociationAuthorizationState struct { // The VPC to authorize for association with the private hosted zone. VpcId pulumi.StringPtrInput // The VPC's region. Defaults to the region of the AWS provider. VpcRegion pulumi.StringPtrInput // The ID of the private hosted zone that you want to authorize associating a VPC with. ZoneId pulumi.StringPtrInput }
func (VpcAssociationAuthorizationState) ElementType ¶ added in v3.1.0
func (VpcAssociationAuthorizationState) ElementType() reflect.Type
type Zone ¶
type Zone struct { pulumi.CustomResourceState // A comment for the hosted zone. Defaults to 'Managed by Pulumi'. Comment pulumi.StringOutput `pulumi:"comment"` // The ID of the reusable delegation set whose NS records you want to assign to the hosted zone. Conflicts with `vpc` as delegation sets can only be used for public zones. DelegationSetId pulumi.StringPtrOutput `pulumi:"delegationSetId"` // Whether to destroy all records (possibly managed outside of this provider) in the zone when destroying the zone. ForceDestroy pulumi.BoolPtrOutput `pulumi:"forceDestroy"` // This is the name of the hosted zone. Name pulumi.StringOutput `pulumi:"name"` // A list of name servers in associated (or default) delegation set. // Find more about delegation sets in [AWS docs](https://docs.aws.amazon.com/Route53/latest/APIReference/actions-on-reusable-delegation-sets.html). NameServers pulumi.StringArrayOutput `pulumi:"nameServers"` // A mapping of tags to assign to the zone. Tags pulumi.StringMapOutput `pulumi:"tags"` // Configuration block(s) specifying VPC(s) to associate with a private hosted zone. Conflicts with the `delegationSetId` argument in this resource and any `route53.ZoneAssociation` resource specifying the same zone ID. Detailed below. Vpcs ZoneVpcArrayOutput `pulumi:"vpcs"` // The Hosted Zone ID. This can be referenced by zone records. ZoneId pulumi.StringOutput `pulumi:"zoneId"` }
Manages a Route53 Hosted Zone.
## Example Usage ### Public Zone
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewZone(ctx, "primary", nil) if err != nil { return err } return nil }) }
``` ### Public Subdomain Zone
For use in subdomains, note that you need to create a `route53.Record` of type `NS` as well as the subdomain zone.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { main, err := route53.NewZone(ctx, "main", nil) if err != nil { return err } dev, err := route53.NewZone(ctx, "dev", &route53.ZoneArgs{ Tags: pulumi.StringMap{ "Environment": pulumi.String("dev"), }, }) if err != nil { return err } _, err = route53.NewRecord(ctx, "dev_ns", &route53.RecordArgs{ ZoneId: main.ZoneId, Name: pulumi.String("dev.example.com"), Type: pulumi.String("NS"), Ttl: pulumi.Int(30), Records: dev.NameServers, }) if err != nil { return err } return nil }) }
``` ### Private Zone
> **NOTE:** This provider provides both exclusive VPC associations defined in-line in this resource via `vpc` configuration blocks and a separate ` Zone VPC Association resource. At this time, you cannot use in-line VPC associations in conjunction with any `route53.ZoneAssociation` resources with the same zone ID otherwise it will cause a perpetual difference in plan output. You can optionally use [ `ignoreChanges` ](https://www.pulumi.com/docs/intro/concepts/programming-model/#ignorechanges) to manage additional associations via the `route53.ZoneAssociation` resource.
> **NOTE:** Private zones require at least one VPC association at all times.
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { _, err := route53.NewZone(ctx, "private", &route53.ZoneArgs{ Vpcs: route53.ZoneVpcArray{ &route53.ZoneVpcArgs{ VpcId: pulumi.Any(aws_vpc.Example.Id), }, }, }) if err != nil { return err } return nil }) }
```
func GetZone ¶
func GetZone(ctx *pulumi.Context, name string, id pulumi.IDInput, state *ZoneState, opts ...pulumi.ResourceOption) (*Zone, error)
GetZone gets an existing Zone resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
type ZoneArgs ¶
type ZoneArgs struct { // A comment for the hosted zone. Defaults to 'Managed by Pulumi'. Comment pulumi.StringPtrInput // The ID of the reusable delegation set whose NS records you want to assign to the hosted zone. Conflicts with `vpc` as delegation sets can only be used for public zones. DelegationSetId pulumi.StringPtrInput // Whether to destroy all records (possibly managed outside of this provider) in the zone when destroying the zone. ForceDestroy pulumi.BoolPtrInput // This is the name of the hosted zone. Name pulumi.StringPtrInput // A mapping of tags to assign to the zone. Tags pulumi.StringMapInput // Configuration block(s) specifying VPC(s) to associate with a private hosted zone. Conflicts with the `delegationSetId` argument in this resource and any `route53.ZoneAssociation` resource specifying the same zone ID. Detailed below. Vpcs ZoneVpcArrayInput }
The set of arguments for constructing a Zone resource.
func (ZoneArgs) ElementType ¶
type ZoneAssociation ¶
type ZoneAssociation struct { pulumi.CustomResourceState // The account ID of the account that created the hosted zone. OwningAccount pulumi.StringOutput `pulumi:"owningAccount"` // The VPC to associate with the private hosted zone. VpcId pulumi.StringOutput `pulumi:"vpcId"` // The VPC's region. Defaults to the region of the AWS provider. VpcRegion pulumi.StringOutput `pulumi:"vpcRegion"` // The private hosted zone to associate. ZoneId pulumi.StringOutput `pulumi:"zoneId"` }
Manages a Route53 Hosted Zone VPC association. VPC associations can only be made on private zones. See the `route53.VpcAssociationAuthorization` resource for setting up cross-account associations.
> **NOTE:** Unless explicit association ordering is required (e.g. a separate cross-account association authorization), usage of this resource is not recommended. Use the `vpc` configuration blocks available within the `route53.Zone` resource instead.
> **NOTE:** This provider provides both this standalone Zone VPC Association resource and exclusive VPC associations defined in-line in the `route53.Zone` resource via `vpc` configuration blocks. At this time, you cannot use those in-line VPC associations in conjunction with this resource and the same zone ID otherwise it will cause a perpetual difference in plan output. You can optionally use [`ignoreChanges`](https://www.pulumi.com/docs/intro/concepts/programming-model/#ignorechanges) in the `route53.Zone` resource to manage additional associations via this resource.
## Example Usage
```go package main
import (
"github.com/pulumi/pulumi-aws/sdk/v3/go/aws/ec2" "github.com/pulumi/pulumi-aws/sdk/v3/go/aws/route53" "github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
func main() { pulumi.Run(func(ctx *pulumi.Context) error { primary, err := ec2.NewVpc(ctx, "primary", &ec2.VpcArgs{ CidrBlock: pulumi.String("10.6.0.0/16"), EnableDnsHostnames: pulumi.Bool(true), EnableDnsSupport: pulumi.Bool(true), }) if err != nil { return err } secondaryVpc, err := ec2.NewVpc(ctx, "secondaryVpc", &ec2.VpcArgs{ CidrBlock: pulumi.String("10.7.0.0/16"), EnableDnsHostnames: pulumi.Bool(true), EnableDnsSupport: pulumi.Bool(true), }) if err != nil { return err } example, err := route53.NewZone(ctx, "example", &route53.ZoneArgs{ Vpcs: route53.ZoneVpcArray{ &route53.ZoneVpcArgs{ VpcId: primary.ID(), }, }, }) if err != nil { return err } _, err = route53.NewZoneAssociation(ctx, "secondaryZoneAssociation", &route53.ZoneAssociationArgs{ ZoneId: example.ZoneId, VpcId: secondaryVpc.ID(), }) if err != nil { return err } return nil }) }
```
func GetZoneAssociation ¶
func GetZoneAssociation(ctx *pulumi.Context, name string, id pulumi.IDInput, state *ZoneAssociationState, opts ...pulumi.ResourceOption) (*ZoneAssociation, error)
GetZoneAssociation gets an existing ZoneAssociation resource's state with the given name, ID, and optional state properties that are used to uniquely qualify the lookup (nil if not required).
func NewZoneAssociation ¶
func NewZoneAssociation(ctx *pulumi.Context, name string, args *ZoneAssociationArgs, opts ...pulumi.ResourceOption) (*ZoneAssociation, error)
NewZoneAssociation registers a new resource with the given unique name, arguments, and options.
type ZoneAssociationArgs ¶
type ZoneAssociationArgs struct { // The VPC to associate with the private hosted zone. VpcId pulumi.StringInput // The VPC's region. Defaults to the region of the AWS provider. VpcRegion pulumi.StringPtrInput // The private hosted zone to associate. ZoneId pulumi.StringInput }
The set of arguments for constructing a ZoneAssociation resource.
func (ZoneAssociationArgs) ElementType ¶
func (ZoneAssociationArgs) ElementType() reflect.Type
type ZoneAssociationState ¶
type ZoneAssociationState struct { // The account ID of the account that created the hosted zone. OwningAccount pulumi.StringPtrInput // The VPC to associate with the private hosted zone. VpcId pulumi.StringPtrInput // The VPC's region. Defaults to the region of the AWS provider. VpcRegion pulumi.StringPtrInput // The private hosted zone to associate. ZoneId pulumi.StringPtrInput }
func (ZoneAssociationState) ElementType ¶
func (ZoneAssociationState) ElementType() reflect.Type
type ZoneState ¶
type ZoneState struct { // A comment for the hosted zone. Defaults to 'Managed by Pulumi'. Comment pulumi.StringPtrInput // The ID of the reusable delegation set whose NS records you want to assign to the hosted zone. Conflicts with `vpc` as delegation sets can only be used for public zones. DelegationSetId pulumi.StringPtrInput // Whether to destroy all records (possibly managed outside of this provider) in the zone when destroying the zone. ForceDestroy pulumi.BoolPtrInput // This is the name of the hosted zone. Name pulumi.StringPtrInput // A list of name servers in associated (or default) delegation set. // Find more about delegation sets in [AWS docs](https://docs.aws.amazon.com/Route53/latest/APIReference/actions-on-reusable-delegation-sets.html). NameServers pulumi.StringArrayInput // A mapping of tags to assign to the zone. Tags pulumi.StringMapInput // Configuration block(s) specifying VPC(s) to associate with a private hosted zone. Conflicts with the `delegationSetId` argument in this resource and any `route53.ZoneAssociation` resource specifying the same zone ID. Detailed below. Vpcs ZoneVpcArrayInput // The Hosted Zone ID. This can be referenced by zone records. ZoneId pulumi.StringPtrInput }
func (ZoneState) ElementType ¶
type ZoneVpcArgs ¶
type ZoneVpcArgs struct { // ID of the VPC to associate. VpcId pulumi.StringInput `pulumi:"vpcId"` // Region of the VPC to associate. Defaults to AWS provider region. VpcRegion pulumi.StringPtrInput `pulumi:"vpcRegion"` }
func (ZoneVpcArgs) ElementType ¶
func (ZoneVpcArgs) ElementType() reflect.Type
func (ZoneVpcArgs) ToZoneVpcOutput ¶
func (i ZoneVpcArgs) ToZoneVpcOutput() ZoneVpcOutput
func (ZoneVpcArgs) ToZoneVpcOutputWithContext ¶
func (i ZoneVpcArgs) ToZoneVpcOutputWithContext(ctx context.Context) ZoneVpcOutput
type ZoneVpcArray ¶
type ZoneVpcArray []ZoneVpcInput
func (ZoneVpcArray) ElementType ¶
func (ZoneVpcArray) ElementType() reflect.Type
func (ZoneVpcArray) ToZoneVpcArrayOutput ¶
func (i ZoneVpcArray) ToZoneVpcArrayOutput() ZoneVpcArrayOutput
func (ZoneVpcArray) ToZoneVpcArrayOutputWithContext ¶
func (i ZoneVpcArray) ToZoneVpcArrayOutputWithContext(ctx context.Context) ZoneVpcArrayOutput
type ZoneVpcArrayInput ¶
type ZoneVpcArrayInput interface { pulumi.Input ToZoneVpcArrayOutput() ZoneVpcArrayOutput ToZoneVpcArrayOutputWithContext(context.Context) ZoneVpcArrayOutput }
ZoneVpcArrayInput is an input type that accepts ZoneVpcArray and ZoneVpcArrayOutput values. You can construct a concrete instance of `ZoneVpcArrayInput` via:
ZoneVpcArray{ ZoneVpcArgs{...} }
type ZoneVpcArrayOutput ¶
type ZoneVpcArrayOutput struct{ *pulumi.OutputState }
func (ZoneVpcArrayOutput) ElementType ¶
func (ZoneVpcArrayOutput) ElementType() reflect.Type
func (ZoneVpcArrayOutput) Index ¶
func (o ZoneVpcArrayOutput) Index(i pulumi.IntInput) ZoneVpcOutput
func (ZoneVpcArrayOutput) ToZoneVpcArrayOutput ¶
func (o ZoneVpcArrayOutput) ToZoneVpcArrayOutput() ZoneVpcArrayOutput
func (ZoneVpcArrayOutput) ToZoneVpcArrayOutputWithContext ¶
func (o ZoneVpcArrayOutput) ToZoneVpcArrayOutputWithContext(ctx context.Context) ZoneVpcArrayOutput
type ZoneVpcInput ¶
type ZoneVpcInput interface { pulumi.Input ToZoneVpcOutput() ZoneVpcOutput ToZoneVpcOutputWithContext(context.Context) ZoneVpcOutput }
ZoneVpcInput is an input type that accepts ZoneVpcArgs and ZoneVpcOutput values. You can construct a concrete instance of `ZoneVpcInput` via:
ZoneVpcArgs{...}
type ZoneVpcOutput ¶
type ZoneVpcOutput struct{ *pulumi.OutputState }
func (ZoneVpcOutput) ElementType ¶
func (ZoneVpcOutput) ElementType() reflect.Type
func (ZoneVpcOutput) ToZoneVpcOutput ¶
func (o ZoneVpcOutput) ToZoneVpcOutput() ZoneVpcOutput
func (ZoneVpcOutput) ToZoneVpcOutputWithContext ¶
func (o ZoneVpcOutput) ToZoneVpcOutputWithContext(ctx context.Context) ZoneVpcOutput
func (ZoneVpcOutput) VpcId ¶
func (o ZoneVpcOutput) VpcId() pulumi.StringOutput
ID of the VPC to associate.
func (ZoneVpcOutput) VpcRegion ¶
func (o ZoneVpcOutput) VpcRegion() pulumi.StringPtrOutput
Region of the VPC to associate. Defaults to AWS provider region.