...
Package watcher
Overview ▹
Index ▹
Variables
var Change_State_name = map[int32]string{
0: "EXISTS",
1: "DOES_NOT_EXIST",
2: "INITIAL_STATE_SKIPPED",
3: "ERROR",
}
var Change_State_value = map[string]int32{
"EXISTS": 0,
"DOES_NOT_EXIST": 1,
"INITIAL_STATE_SKIPPED": 2,
"ERROR": 3,
}
func RegisterWatcherServer ¶
func RegisterWatcherServer(s *grpc.Server, srv WatcherServer)
type Change ¶
A Change indicates the most recent state of an element.
type Change struct {
// Name of the element, interpreted relative to the entity's actual
// name. "" refers to the entity itself. The element name is a valid
// UTF-8 string.
Element string `protobuf:"bytes,1,opt,name=element" json:"element,omitempty"`
// The state of the `element`.
State Change_State `protobuf:"varint,2,opt,name=state,enum=google.watcher.v1.Change_State" json:"state,omitempty"`
// The actual change data. This field is present only when `state() == EXISTS`
// or `state() == ERROR`. Please see [google.protobuf.Any][google.protobuf.Any] about how to use
// the Any type.
Data *google_protobuf1.Any `protobuf:"bytes,6,opt,name=data" json:"data,omitempty"`
// If present, provides a compact representation of all the messages that have
// been received by the caller for the given entity, e.g., it could be a
// sequence number or a multi-part timestamp/version vector. This marker can
// be provided in the Request message, allowing the caller to resume the stream
// watching at a specific point without fetching the initial state.
ResumeMarker []byte `protobuf:"bytes,4,opt,name=resume_marker,json=resumeMarker,proto3" json:"resume_marker,omitempty"`
// If true, this Change is followed by more Changes that are in the same group
// as this Change.
Continued bool `protobuf:"varint,5,opt,name=continued" json:"continued,omitempty"`
}
func (*Change) Descriptor ¶
func (*Change) Descriptor() ([]byte, []int)
func (*Change) GetContinued ¶
func (m *Change) GetContinued() bool
func (*Change) GetData ¶
func (m *Change) GetData() *google_protobuf1.Any
func (*Change) GetElement ¶
func (m *Change) GetElement() string
func (*Change) GetResumeMarker ¶
func (m *Change) GetResumeMarker() []byte
func (*Change) GetState ¶
func (m *Change) GetState() Change_State
func (*Change) ProtoMessage ¶
func (*Change) ProtoMessage()
func (*Change) Reset ¶
func (m *Change) Reset()
func (*Change) String ¶
func (m *Change) String() string
type ChangeBatch ¶
A batch of Change messages.
type ChangeBatch struct {
// A list of Change messages.
Changes []*Change `protobuf:"bytes,1,rep,name=changes" json:"changes,omitempty"`
}
func (*ChangeBatch) Descriptor ¶
func (*ChangeBatch) Descriptor() ([]byte, []int)
func (*ChangeBatch) GetChanges ¶
func (m *ChangeBatch) GetChanges() []*Change
func (*ChangeBatch) ProtoMessage ¶
func (*ChangeBatch) ProtoMessage()
func (*ChangeBatch) Reset ¶
func (m *ChangeBatch) Reset()
func (*ChangeBatch) String ¶
func (m *ChangeBatch) String() string
type Change_State ¶
A reported value can be in one of the following states:
type Change_State int32
const (
// The element exists and its full value is included in data.
Change_EXISTS Change_State = 0
// The element does not exist.
Change_DOES_NOT_EXIST Change_State = 1
// Element may or may not exist. Used only for initial state delivery when
// the client is not interested in fetching the initial state. See the
// "Initial State" section above.
Change_INITIAL_STATE_SKIPPED Change_State = 2
// The element may exist, but some error has occurred. More information is
// available in the data field - the value is a serialized Status
// proto (from [google.rpc.Status][])
Change_ERROR Change_State = 3
)
func (Change_State) EnumDescriptor ¶
func (Change_State) EnumDescriptor() ([]byte, []int)
func (Change_State) String ¶
func (x Change_State) String() string
type Request ¶
The message used by the client to register interest in an entity.
type Request struct {
// The `target` value **must** be a valid URL path pointing to an entity
// to watch. Note that the service name **must** be
// removed from the target field (e.g., the target field must say
// "/foo/bar", not "myservice.googleapis.com/foo/bar"). A client is
// also allowed to pass system-specific parameters in the URL that
// are only obeyed by some implementations. Some parameters will be
// implementation-specific. However, some have predefined meaning
// and are listed here:
//
// * recursive = true|false [default=false]
// If set to true, indicates that the client wants to watch all elements
// of entities in the subtree rooted at the entity's name in `target`. For
// descendants that are not the immediate children of the target, the
// `Change.element` will contain slashes.
//
// Note that some namespaces and entities will not support recursive
// watching. When watching such an entity, a client must not set recursive
// to true. Otherwise, it will receive an `UNIMPLEMENTED` error.
//
// Normal URL encoding must be used inside `target`. For example, if a query
// parameter name or value, or the non-query parameter portion of `target`
// contains a special character, it must be %-encoded. We recommend that
// clients and servers use their runtime's URL library to produce and consume
// target values.
Target string `protobuf:"bytes,1,opt,name=target" json:"target,omitempty"`
// The `resume_marker` specifies how much of the existing underlying state is
// delivered to the client when the watch request is received by the
// system. The client can set this marker in one of the following ways to get
// different semantics:
//
// * Parameter is not specified or has the value "".
// Semantics: Fetch initial state.
// The client wants the entity's initial state to be delivered. See the
// description in "Initial State".
//
// * Parameter is set to the string "now" (UTF-8 encoding).
// Semantics: Fetch new changes only.
// The client just wants to get the changes received by the system after
// the watch point. The system may deliver changes from before the watch
// point as well.
//
// * Parameter is set to a value received in an earlier
// `Change.resume_marker` field while watching the same entity.
// Semantics: Resume from a specific point.
// The client wants to receive the changes from a specific point; this
// value must correspond to a value received in the `Change.resume_marker`
// field. The system may deliver changes from before the `resume_marker`
// as well. If the system cannot resume the stream from this point (e.g.,
// if it is too far behind in the stream), it can raise the
// `FAILED_PRECONDITION` error.
//
// An implementation MUST support an unspecified parameter and the
// empty string "" marker (initial state fetching) and the "now" marker.
// It need not support resuming from a specific point.
ResumeMarker []byte `protobuf:"bytes,2,opt,name=resume_marker,json=resumeMarker,proto3" json:"resume_marker,omitempty"`
}
func (*Request) Descriptor ¶
func (*Request) Descriptor() ([]byte, []int)
func (*Request) GetResumeMarker ¶
func (m *Request) GetResumeMarker() []byte
func (*Request) GetTarget ¶
func (m *Request) GetTarget() string
func (*Request) ProtoMessage ¶
func (*Request) ProtoMessage()
func (*Request) Reset ¶
func (m *Request) Reset()
func (*Request) String ¶
func (m *Request) String() string
type WatcherClient ¶
type WatcherClient interface {
// Start a streaming RPC to get watch information from the server.
Watch(ctx context.Context, in *Request, opts ...grpc.CallOption) (Watcher_WatchClient, error)
}
func NewWatcherClient ¶
func NewWatcherClient(cc *grpc.ClientConn) WatcherClient
type WatcherServer ¶
type WatcherServer interface {
// Start a streaming RPC to get watch information from the server.
Watch(*Request, Watcher_WatchServer) error
}
type Watcher_WatchClient ¶
type Watcher_WatchClient interface {
Recv() (*ChangeBatch, error)
grpc.ClientStream
}
type Watcher_WatchServer ¶
type Watcher_WatchServer interface {
Send(*ChangeBatch) error
grpc.ServerStream
}
ActiveGo 1.8