* 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
49 lines
1.2 KiB
Protocol Buffer
49 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;
|
|
}
|