caddydns_powerdns

package module
v1.0.9 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 31, 2022 License: MIT Imports: 5 Imported by: 0

README

DEVELOPER INSTRUCTIONS:

  • Update module name in go.mod
  • Update dependencies to latest versions
  • Update name and year in license
  • Customize configuration and Caddyfile parsing
  • Update godocs / comments (especially provider name and nuances)
  • Update README and remove this section

PowerDNS module for Caddy

This package contains a DNS provider module for Caddy. It can be used to manage DNS records with PowerDNS.

PowerDNS

dns.providers.powerdns

Config examples

To use this module for the ACME DNS challenge, configure the ACME issuer in your Caddy JSON like so:

{
	"module": "acme",
	"challenges": {
		"dns": {
			"provider": {
				"name": "powerdns",
				"api_token": "POWERDNS_API_TOKEN",
                "server_url": "https://your.powerdns.com",
                "server_id": "localhost"
			}
		}
	}
}

or with the Caddyfile:

# globally
{
	acme_dns powerdns {
				api_token POWERDNS_API_TOKEN
                server_url https://your.powerdns.com
                server_id localhost
	}
}
# one site
tls {
	dns powerdns {
				api_token POWERDNS_API_TOKEN
                server_url https://your.powerdns.com
                server_id localhost
	}
}

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Provider

type Provider struct{ *powerdns.Provider }

Provider lets Caddy read and manipulate DNS records hosted by this DNS provider.

func (Provider) CaddyModule

func (Provider) CaddyModule() caddy.ModuleInfo

CaddyModule returns the Caddy module information.

func (*Provider) Provision

func (p *Provider) Provision(ctx caddy.Context) error

Provision sets up the module. Implements caddy.Provisioner.

func (*Provider) UnmarshalCaddyfile

func (p *Provider) UnmarshalCaddyfile(d *caddyfile.Dispenser) error

UnmarshalCaddyfile sets up the DNS provider from Caddyfile tokens. Syntax:

providername [<api_token>] {
    api_token <api_token>
}

**THIS IS JUST AN EXAMPLE AND NEEDS TO BE CUSTOMIZED.**

func (*Provider) Validate

func (p *Provider) Validate() error

Validate validates the config. Implements caddy.Validator.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL