mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-03 18:53:13 -05:00 
			
		
		
		
	* Add part 1 watch functionality. (squashed) * add funcs for service/endpoint fqdns * add endpoints watch * document exposed funcs * only send subset deltas * locking for watch map * tests and docs * add pod watch * remove debugs prints * feedback part 1 * add error reporting to proto * inform clients of server stop+errors * add grpc options param * use proper context * Review feedback: * Removed client (will move to another repo) * Use new log functions * Change watchChan to be for string not []string * Rework how k8s plugin stores watch tracking info to simplify * Normalize the qname on watch request * Add blank line back * Revert another spurious change * Fix tests * Add stop channel. Fix tests. Better docs for plugin interface. * fmt.Printf -> log.Warningf * Move from dnsserver to plugin/pkg/watch * gofmt * remove dead client watches * sate linter * linter omg
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Protocol Buffer
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Protocol Buffer
		
	
	
	
	
	
syntax = "proto3";
 | 
						|
 | 
						|
package coredns.dns;
 | 
						|
option go_package = "pb";
 | 
						|
 | 
						|
message DnsPacket {
 | 
						|
	bytes msg = 1;
 | 
						|
}
 | 
						|
 | 
						|
service DnsService {
 | 
						|
	rpc Query (DnsPacket) returns (DnsPacket);
 | 
						|
	rpc Watch (stream WatchRequest) returns (stream WatchResponse);
 | 
						|
}
 | 
						|
 | 
						|
message WatchRequest {
 | 
						|
  // request_union is a request to either create a new watcher or cancel an existing watcher.
 | 
						|
  oneof request_union {
 | 
						|
    WatchCreateRequest create_request = 1;
 | 
						|
    WatchCancelRequest cancel_request = 2;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
message WatchCreateRequest {
 | 
						|
  DnsPacket query = 1;
 | 
						|
}
 | 
						|
 | 
						|
message WatchCancelRequest {
 | 
						|
  // watch_id is the watcher id to cancel
 | 
						|
  int64 watch_id = 1;
 | 
						|
}
 | 
						|
 | 
						|
message WatchResponse {
 | 
						|
	// watch_id is the ID of the watcher that corresponds to the response.
 | 
						|
	int64 watch_id = 1;
 | 
						|
 | 
						|
	// created is set to true if the response is for a create watch request.
 | 
						|
	// The client should record the watch_id and expect to receive DNS replies
 | 
						|
	// from the same stream.
 | 
						|
	// All replies sent to the created watcher will attach with the same watch_id.
 | 
						|
	bool created = 2;
 | 
						|
 | 
						|
	// canceled is set to true if the response is for a cancel watch request.
 | 
						|
	// No further events will be sent to the canceled watcher.
 | 
						|
	bool canceled = 3;
 | 
						|
 | 
						|
	string qname = 4;
 | 
						|
 | 
						|
	string err = 5;
 | 
						|
}
 |