mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-31 02:03:20 -04:00 
			
		
		
		
	* introduce new interface "dnsserver.Viewer", that allows a plugin implementing it to decide if a query should be routed into its server block. * add new plugin "view", that uses the new interface to enable a user to define expression based conditions that must be met for a query to be routed to its server block. Signed-off-by: Chris O'Haver <cohaver@infoblox.com>
		
			
				
	
	
		
			38 lines
		
	
	
		
			1013 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			1013 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package metrics
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"github.com/coredns/coredns/core/dnsserver"
 | |
| )
 | |
| 
 | |
| // WithServer returns the current server handling the request. It returns the
 | |
| // server listening address: <scheme>://[<bind>]:<port> Normally this is
 | |
| // something like "dns://:53", but if the bind plugin is used, i.e. "bind
 | |
| // 127.0.0.53", it will be "dns://127.0.0.53:53", etc. If not address is found
 | |
| // the empty string is returned.
 | |
| //
 | |
| // Basic usage with a metric:
 | |
| //
 | |
| // <metric>.WithLabelValues(metrics.WithServer(ctx), labels..).Add(1)
 | |
| func WithServer(ctx context.Context) string {
 | |
| 	srv := ctx.Value(dnsserver.Key{})
 | |
| 	if srv == nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	return srv.(*dnsserver.Server).Addr
 | |
| }
 | |
| 
 | |
| // WithView returns the name of the view currently handling the request, if a view is defined.
 | |
| //
 | |
| // Basic usage with a metric:
 | |
| //
 | |
| // <metric>.WithLabelValues(metrics.WithView(ctx), labels..).Add(1)
 | |
| func WithView(ctx context.Context) string {
 | |
| 	v := ctx.Value(dnsserver.ViewKey{})
 | |
| 	if v == nil {
 | |
| 		return ""
 | |
| 	}
 | |
| 	return v.(string)
 | |
| }
 |