Skip to content

Commit

Permalink
docs: update docs for watch client
Browse files Browse the repository at this point in the history
Signed-off-by: bsbds <[email protected]>
  • Loading branch information
bsbds committed Jul 28, 2023
1 parent b174bb3 commit d405a37
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 13 deletions.
6 changes: 3 additions & 3 deletions xline-client/src/clients/watch.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ pub struct WatchClient {
}

impl WatchClient {
/// Create a new maintenance client
/// Creates a new maintenance client
#[inline]
#[must_use]
pub fn new(channel: Channel, token: Option<String>) -> Self {
Expand All @@ -40,11 +40,11 @@ impl WatchClient {
///
/// # Errors
///
/// If the RPC client fails to send request
/// This function will return an error if the RPC client fails to send request
///
/// # Panics
///
/// If the RPC server returns the wrong value
/// This function will panic if the RPC server doesn't return a create watch response
#[inline]
pub async fn watch(
&mut self,
Expand Down
30 changes: 20 additions & 10 deletions xline-client/src/types/watch.rs
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,9 @@ pub struct WatchRequest {
}

impl WatchRequest {
/// New `WatchRequest`
/// Creates a New `WatchRequest`
///
/// `key` is the key to register for watching.
#[inline]
#[must_use]
pub fn new(key: impl Into<Vec<u8>>) -> Self {
Expand All @@ -118,7 +120,7 @@ impl WatchRequest {
}
}

/// Set `key` and `range_end` when with prefix
/// If set, Xline will watch all keys with the matching prefix
#[inline]
#[must_use]
pub fn with_prefix(mut self) -> Self {
Expand All @@ -131,7 +133,7 @@ impl WatchRequest {
self
}

/// Set `key` and `range_end` when with from key
/// If set, Xline will watch all keys that are equal or greater than the given key
#[inline]
#[must_use]
pub fn with_from_key(mut self) -> Self {
Expand All @@ -142,55 +144,63 @@ impl WatchRequest {
self
}

/// Set `range_end`
/// `range_end` is the end of the range [key, `range_end`) to watch. If `range_end` is not given,
/// only the key argument is watched. If `range_end` is equal to '\0', all keys greater than
/// or equal to the key argument are watched.
/// If the `range_end` is one bit larger than the given key,
/// then all keys with the prefix (the given key) will be watched.
#[inline]
#[must_use]
pub fn with_range_end(mut self, range_end: impl Into<Vec<u8>>) -> Self {
self.inner.range_end = range_end.into();
self
}

/// Set `start_revision`
/// Sets the start revision to watch from (inclusive). No `start_revision` is "now".
#[inline]
#[must_use]
pub const fn with_start_revision(mut self, revision: i64) -> Self {
self.inner.start_revision = revision;
self
}

/// Set `progress_notify`
/// `progress_notify` is set so that the Xline server will periodically send a `WatchResponse` with no events to the new watcher if there are no recent events. It is useful when clients wish to recover a disconnected watcher starting from a recent known revision. The xline server may decide how often it will send notifications based on current load.
#[inline]
#[must_use]
pub const fn with_progress_notify(mut self) -> Self {
self.inner.progress_notify = true;
self
}

/// Set `filters`
/// filters filter the events at server side before it sends back to the watcher.
#[inline]
#[must_use]
pub fn with_filters(mut self, filters: impl Into<Vec<WatchFilterType>>) -> Self {
self.inner.filters = filters.into().into_iter().map(Into::into).collect();
self
}

/// Set `prev_kv`
/// If `prev_kv` is set, created watcher gets the previous KV before the event happens.
/// If the previous KV is already compacted, nothing will be returned.
#[inline]
#[must_use]
pub const fn with_prev_kv(mut self) -> Self {
self.inner.prev_kv = true;
self
}

/// Set `watch_id`
/// If `watch_id` is provided and non-zero, it will be assigned to this watcher.
/// this can be used ensure that ordering is correct when creating multiple
/// watchers on the same stream. Creating a watcher with an ID already in
/// use on the stream will cause an error to be returned.
#[inline]
#[must_use]
pub const fn with_watch_id(mut self, watch_id: i64) -> Self {
self.inner.watch_id = watch_id;
self
}

/// Set `fragment`
/// fragment enables splitting large revisions into multiple watch responses.
#[inline]
#[must_use]
pub const fn with_fragment(mut self) -> Self {
Expand Down

0 comments on commit d405a37

Please sign in to comment.