README

Route53 for libdns

godoc reference

This package implements the libdns interfaces for AWS Route53.

Authenticating

This package supports all the credential configuration methods described in the AWS Developer Guide, such as Environment Variables, EC2 Instance Profile and the AWS Credentials file located in .aws/credentials

The following IAM policy is a minimal working example to give libdns permissions to manage DNS records:

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "",
            "Effect": "Allow",
            "Action": [
                "route53:ListResourceRecordSets",
                "route53:GetChange",
                "route53:ChangeResourceRecordSets"
            ],
            "Resource": [
                "arn:aws:route53:::hostedzone/ZABCD1EFGHIL",
                "arn:aws:route53:::change/*"
            ]
        },
        {
            "Sid": "",
            "Effect": "Allow",
            "Action": [
                "route53:ListHostedZonesByName",
                "route53:ListHostedZones"
            ],
            "Resource": "*"
        }
    ]
}
Expand ▾ Collapse ▴

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Provider

type Provider struct {
	MaxRetries  int    `json:"max_retries,omitempty"`
	AccessKeyID string `json:"access_key_id"`
	SecretKey   string `json:"secret_key"`
	// contains filtered or unexported fields
}

    Provider implements the libdns interfaces for Route53

    func (*Provider) AppendRecords

    func (p *Provider) AppendRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)

      AppendRecords adds records to the zone. It returns the records that were added.

      func (*Provider) DeleteRecords

      func (p *Provider) DeleteRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)

        DeleteRecords deletes the records from the zone. If a record does not have an ID, it will be looked up. It returns the records that were deleted.

        func (*Provider) GetRecords

        func (p *Provider) GetRecords(ctx context.Context, zone string) ([]libdns.Record, error)

          GetRecords lists all the records in the zone.

          func (*Provider) NewSession

          func (p *Provider) NewSession() error

            NewSession initializes the AWS client

            func (*Provider) SetRecords

            func (p *Provider) SetRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)

              SetRecords sets the records in the zone, either by updating existing records or creating new ones. It returns the updated records.