mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-26 22:01:04 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
| .\" Generated by Mmark Markdown Processer - mmark.miek.nl
 | |
| .TH "COREDNS-METADATA" 7 "March 2020" "CoreDNS" "CoreDNS Plugins"
 | |
| 
 | |
| .SH "NAME"
 | |
| .PP
 | |
| \fImetadata\fP - enables a metadata collector.
 | |
| 
 | |
| .SH "DESCRIPTION"
 | |
| .PP
 | |
| By enabling \fImetadata\fP any plugin that implements metadata.Provider
 | |
| interface
 | |
| \[la]https://godoc.org/github.com/coredns/coredns/plugin/metadata#Provider\[ra] will be called for
 | |
| each DNS query, at the beginning of the process for that query, in order to add its own metadata to
 | |
| context.
 | |
| 
 | |
| .PP
 | |
| The metadata collected will be available for all plugins, via the Context parameter provided in the
 | |
| ServeDNS function. The package (code) documentation has examples on how to inspect and retrieve
 | |
| metadata a plugin might be interested in.
 | |
| 
 | |
| .PP
 | |
| The metadata is added by setting a label with a value in the context. These labels should be named
 | |
| \fB\fCplugin/NAME\fR, where \fBNAME\fP is something descriptive. The only hard requirement the \fImetadata\fP
 | |
| plugin enforces is that the labels contain a slash. See the documentation for
 | |
| \fB\fCmetadata.SetValueFunc\fR.
 | |
| 
 | |
| .PP
 | |
| The value stored is a string. The empty string signals "no metadata". See the documentation for
 | |
| \fB\fCmetadata.ValueFunc\fR on how to retrieve this.
 | |
| 
 | |
| .SH "SYNTAX"
 | |
| .PP
 | |
| .RS
 | |
| 
 | |
| .nf
 | |
| metadata [ZONES... ]
 | |
| 
 | |
| .fi
 | |
| .RE
 | |
| 
 | |
| .IP \(bu 4
 | |
| \fBZONES\fP zones metadata should be invoked for.
 | |
| 
 | |
| 
 | |
| .SH "PLUGINS"
 | |
| .PP
 | |
| \fB\fCmetadata.Provider\fR interface needs to be implemented by each plugin willing to provide metadata
 | |
| information for other plugins. It will be called by metadata and gather the information from all
 | |
| plugins in context.
 | |
| 
 | |
| .PP
 | |
| Note: this method should work quickly, because it is called for every request.
 | |
| 
 | |
| .SH "EXAMPLES"
 | |
| .PP
 | |
| The \fIrewrite\fP plugin uses meta data to rewrite requests.
 | |
| 
 | |
| .SH "ALSO SEE"
 | |
| .PP
 | |
| The Provider interface
 | |
| \[la]https://godoc.org/github.com/coredns/coredns/plugin/metadata#Provider\[ra] and
 | |
| the package level
 | |
| \[la]https://godoc.org/github.com/coredns/coredns/plugin/metadata\[ra] documentation.
 | |
| 
 |