| 12345678910111213141516171819202122232425262728293031323334353637 | package exampleimport (	"github.com/coredns/coredns/core/dnsserver"	"github.com/coredns/coredns/plugin"	"github.com/mholt/caddy")// init registers this plugin within the Caddy plugin framework. It uses "example" as the// name, and couples it to the Action "setup".func init() {	caddy.RegisterPlugin("example", caddy.Plugin{		ServerType: "dns",		Action:     setup,	})}// setup is the function that gets called when the config parser see the token "example". Setup is responsible// for parsing any extra options the example plugin may have. The first token this function sees is "example".func setup(c *caddy.Controller) error {	c.Next() // Ignore "example" and give us the next token.	if c.NextArg() {		// If there was another token, return an error, because we don't have any configuration.		// Any errors returned from this setup function should be wrapped with plugin.Error, so we		// can present a slightly nicer error message to the user.		return plugin.Error("example", c.ArgErr())	}	// Add the Plugin to CoreDNS, so Servers can use it in their plugin chain.	dnsserver.GetConfig(c).AddPlugin(func(next plugin.Handler) plugin.Handler {		return Example{Next: next}	})	// All OK, return a nil error.	return nil}
 |