pub struct UserState {
pub profile: UserInfo,
pub known_users: HashMap<String, UserInfo>,
pub documents: HashMap<String, DocInfo>,
}Expand description
State associated with a user, synchronized via Automerge.
Fields§
§profile: UserInfoThe user’s own profile information.
known_users: HashMap<String, UserInfo>All users referenced in document permissions, keyed by user ID.
documents: HashMap<String, DocInfo>The document refs accessible to the user, keyed by ref UUID string.
We cannot use the Uuid type here because Automerge requires the keys to have a AsRef<str> impl.
Implementations§
Source§impl UserState
impl UserState
Sourcepub fn reconcile_into(&self, doc: &mut Automerge) -> Result<(), AppError>
pub fn reconcile_into(&self, doc: &mut Automerge) -> Result<(), AppError>
Reconcile this UserState into an Automerge document, returning an AppError on failure.
Sourcepub fn recompute_used_by(&mut self)
pub fn recompute_used_by(&mut self)
Recomputes the used_by field of every DocInfo from the depends_on fields.
A document appears in the used_by list of every document it depends on.
This should be called whenever the document map is mutated (initial load,
upsert, or revoke) so that the used_by vecs stay consistent.
Trait Implementations§
Source§impl Arbitrary for UserState
impl Arbitrary for UserState
Source§type Parameters = ()
type Parameters = ()
The type of parameters that
arbitrary_with accepts for configuration
of the generated Strategy. Parameters must implement Default.Source§type Strategy = BoxedStrategy<UserState>
type Strategy = BoxedStrategy<UserState>
The type of
Strategy used to generate values of type Self.Source§fn arbitrary_with(_args: Self::Parameters) -> Self::Strategy
fn arbitrary_with(_args: Self::Parameters) -> Self::Strategy
Source§impl Hydrate for UserState
impl Hydrate for UserState
fn hydrate_map<D: ReadDoc>(doc: &D, obj: &ObjId) -> Result<Self, HydrateError>
fn hydrate<D>(doc: &D, obj: &ExId, prop: Prop<'_>) -> Result<Self, HydrateError>where
D: ReadDoc,
fn hydrate_scalar(s: Cow<'_, ScalarValue>) -> Result<Self, HydrateError>
fn hydrate_bool(_b: bool) -> Result<Self, HydrateError>
fn hydrate_bytes(_bytes: &[u8]) -> Result<Self, HydrateError>
fn hydrate_f64(_f: f64) -> Result<Self, HydrateError>
fn hydrate_counter(_c: i64) -> Result<Self, HydrateError>
fn hydrate_int(_i: i64) -> Result<Self, HydrateError>
fn hydrate_uint(_u: u64) -> Result<Self, HydrateError>
fn hydrate_string(_string: &str) -> Result<Self, HydrateError>
fn hydrate_timestamp(_t: i64) -> Result<Self, HydrateError>
fn hydrate_unknown(_type_code: u8, _bytes: &[u8]) -> Result<Self, HydrateError>
fn hydrate_seq<D>(_doc: &D, _obj: &ExId) -> Result<Self, HydrateError>where
D: ReadDoc,
fn hydrate_text<D>(_doc: &D, _obj: &ExId) -> Result<Self, HydrateError>where
D: ReadDoc,
fn hydrate_none() -> Result<Self, HydrateError>
Source§impl Reconcile for UserState
impl Reconcile for UserState
Source§fn reconcile<__R123: Reconciler>(
&self,
reconciler: __R123,
) -> Result<(), __R123::Error>
fn reconcile<__R123: Reconciler>( &self, reconciler: __R123, ) -> Result<(), __R123::Error>
Reconcile this item with the document Read more
§fn hydrate_key<'a, D>(
doc: &D,
obj: &ExId,
prop: Prop<'_>,
) -> Result<LoadKey<Self::Key<'a>>, ReconcileError>where
D: ReadDoc,
fn hydrate_key<'a, D>(
doc: &D,
obj: &ExId,
prop: Prop<'_>,
) -> Result<LoadKey<Self::Key<'a>>, ReconcileError>where
D: ReadDoc,
Hydrate the key for this Object Read more
Source§impl TS for UserState
impl TS for UserState
Source§type WithoutGenerics = UserState
type WithoutGenerics = UserState
If this type does not have generic parameters, then
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or ().
The only requirement for these dummy types is that EXPORT_TO must be None. Read moreSource§type OptionInnerType = UserState
type OptionInnerType = UserState
If the implementing type is
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn docs() -> Option<String>
fn docs() -> Option<String>
JSDoc comment to describe this type in TypeScript - when
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn decl_concrete() -> String
fn decl_concrete() -> String
Declaration of this type using the supplied generic arguments.
The resulting TypeScript definition will not be generic. For that, see
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl() -> String
fn decl() -> String
Declaration of this type, e.g.
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline() -> String
fn inline() -> String
Formats this types definition in TypeScript, e.g
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened() -> String
fn inline_flattened() -> String
Flatten a type declaration.
This function will panic if the type cannot be flattened.
This function will panic if the type cannot be flattened.
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all type parameters of this type.
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
Returns the output path to where
The returned path does not include the base directory from
T should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all dependency of this type.
§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
Resolves all dependencies of this type recursively.
§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem.
To export this type together with all of its dependencies, use [
TS::export_all]. Read more§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem, together with all of its dependencies.
To export only this type, without its dependencies, use [
To export only this type, without its dependencies, use [
TS::export]. Read more§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
Manually export this type into the given directory, together with all of its dependencies.
To export only this type, without its dependencies, use [
To export only this type, without its dependencies, use [
TS::export]. Read more§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
§fn default_output_path() -> Option<PathBuf>
fn default_output_path() -> Option<PathBuf>
Returns the output path to where
T should be exported. Read moreimpl Eq for UserState
impl StructuralPartialEq for UserState
Auto Trait Implementations§
impl Freeze for UserState
impl RefUnwindSafe for UserState
impl Send for UserState
impl Sync for UserState
impl Unpin for UserState
impl UnwindSafe for UserState
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.§impl<Ctx> FromRequestExtensions<Ctx> for Ctxwhere
Ctx: Send,
impl<Ctx> FromRequestExtensions<Ctx> for Ctxwhere
Ctx: Send,
§async fn from_request_extensions(
ctx: Ctx,
_extensions: Extensions,
) -> Result<Ctx, RpcError>
async fn from_request_extensions( ctx: Ctx, _extensions: Extensions, ) -> Result<Ctx, RpcError>
Using the provided context and extensions, build a new extension.
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more