Skip to main content

DefaultUser

Struct DefaultUser 

Source
pub struct DefaultUser {
Show 13 fields pub id: Uuid, pub username: String, pub email: String, pub first_name: String, pub last_name: String, pub password_hash: Option<String>, pub last_login: Option<DateTime<Utc>>, pub is_active: bool, pub is_staff: bool, pub is_superuser: bool, pub date_joined: DateTime<Utc>, pub user_permissions: Vec<String>, pub groups: Vec<String>,
}
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Available on crate features auth and argon2-hasher only.
Expand description

DefaultUser struct - Django’s AbstractUser equivalent

A complete, ready-to-use user model that combines BaseUser, FullUser, and PermissionsMixin. This is the default user model provided by Reinhardt, suitable for most applications.

§Relationship with Django

This struct is equivalent to Django’s django.contrib.auth.models.AbstractUser. It provides a full-featured user model with:

  • Username-based authentication
  • Email address
  • First and last name
  • Password hashing (Argon2id by default)
  • Active/staff/superuser flags
  • Timestamps (last_login, date_joined)
  • Permissions and groups

§Database Schema

The default table name is auth_user with the following columns:

  • id (UUID, primary key)
  • username (String, unique)
  • email (String)
  • first_name (String)
  • last_name (String)
  • password_hash (Option<String>)
  • last_login (Option<DateTime<Utc>>)
  • is_active (bool)
  • is_staff (bool)
  • is_superuser (bool)
  • date_joined (DateTime<Utc>)
  • user_permissions (Vec<String>)
  • groups (Vec<String>)

§Examples

Creating a new user with automatic Argon2id password hashing:

use reinhardt_auth::{BaseUser, DefaultUser};
use uuid::Uuid;
use chrono::Utc;

let mut user = DefaultUser {
    id: Uuid::new_v4(),
    username: "alice".to_string(),
    email: "alice@example.com".to_string(),
    first_name: "Alice".to_string(),
    last_name: "Smith".to_string(),
    password_hash: None,
    last_login: None,
    is_active: true,
    is_staff: false,
    is_superuser: false,
    date_joined: Utc::now(),
    user_permissions: Vec::new(),
    groups: Vec::new(),
};

// Password is automatically hashed with Argon2id
user.set_password("securepass123").unwrap();

// Verify password
assert!(user.check_password("securepass123").unwrap());
assert!(!user.check_password("wrongpass").unwrap());

Using with permissions:

use reinhardt_auth::{DefaultUser, PermissionsMixin};
use uuid::Uuid;
use chrono::Utc;

let mut user = DefaultUser {
    id: Uuid::new_v4(),
    username: "bob".to_string(),
    email: "bob@example.com".to_string(),
    first_name: "Bob".to_string(),
    last_name: "Johnson".to_string(),
    password_hash: None,
    last_login: None,
    is_active: true,
    is_staff: true,
    is_superuser: false,
    date_joined: Utc::now(),
    user_permissions: vec![
        "blog.add_post".to_string(),
        "blog.change_post".to_string(),
    ],
    groups: vec!["editors".to_string()],
};

// Check permissions
assert!(user.has_perm("blog.add_post"));
assert!(user.has_perm("blog.change_post"));
assert!(!user.has_perm("blog.delete_post"));
assert!(user.has_module_perms("blog"));

Fields§

§id: Uuid
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Unique identifier (primary key)

§username: String
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Username (unique, used for login)

§email: String
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Email address

§first_name: String
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

First name

§last_name: String
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Last name

§password_hash: Option<String>
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Password hash (hashed with Argon2id by default)

§last_login: Option<DateTime<Utc>>
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Last login timestamp

§is_active: bool
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Whether this user account is active

§is_staff: bool
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Whether this user can access the admin site

§is_superuser: bool
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

Whether this user has all permissions (superuser)

§date_joined: DateTime<Utc>
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

When this user account was created

§user_permissions: Vec<String>
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

List of permissions (format: “app_label.permission_name”)

§groups: Vec<String>
👎Deprecated since 0.1.0-rc.15:

Use the user attribute macro to define your own user struct instead

List of groups this user belongs to

Trait Implementations§

Source§

impl User for DefaultUser

Source§

fn id(&self) -> String

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns the unique identifier for this user
Source§

fn username(&self) -> &str

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns the username for this user
Source§

fn get_username(&self) -> &str

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns the username (alias for username()) Read more
Source§

fn is_authenticated(&self) -> bool

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns whether this user is authenticated Read more
Source§

fn is_active(&self) -> bool

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns whether this user account is active Read more
Source§

fn is_admin(&self) -> bool

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns whether this user is an administrator Read more
Source§

fn is_staff(&self) -> bool

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns whether this user is a staff member Read more
Source§

fn is_superuser(&self) -> bool

👎Deprecated since 0.1.0-rc.15:

Use AuthIdentity + BaseUser/FullUser + PermissionsMixin instead

Returns whether this user is a superuser Read more
Source§

impl BaseUser for DefaultUser

Source§

type PrimaryKey = Uuid

The type of the primary key (e.g., Uuid, i64)
Source§

type Hasher = Argon2Hasher

The password hasher to use (e.g., Argon2Hasher)
Source§

fn get_username_field() -> &'static str

Returns the name of the username field Read more
Source§

fn get_username(&self) -> &str

Returns the username value
Source§

fn password_hash(&self) -> Option<&str>

Returns the hashed password, if set
Source§

fn set_password_hash(&mut self, hash: String)

Sets the hashed password
Source§

fn last_login(&self) -> Option<DateTime<Utc>>

Returns the last login time
Source§

fn set_last_login(&mut self, time: DateTime<Utc>)

Sets the last login time
Source§

fn is_active(&self) -> bool

Returns whether the user account is active
Source§

fn normalize_username(username: &str) -> String

Normalizes the username for consistent storage Read more
Source§

fn set_password(&mut self, password: &str) -> Result<(), Error>

Sets the password, hashing it first Read more
Source§

fn check_password(&self, password: &str) -> Result<bool, Error>

Checks if the given password is correct Read more
Source§

fn set_unusable_password(&mut self)

Sets an unusable password (user cannot log in with password) Read more
Source§

fn has_usable_password(&self) -> bool

Returns whether the user has a usable password Read more
Source§

fn get_session_auth_hash(&self, secret: &str) -> String

Returns a hash of the session authentication credentials Read more
Source§

impl BaseUserManager<DefaultUser> for DefaultUserManager

Source§

fn create_user<'life0, 'life1, 'life2, 'async_trait>( &'life0 mut self, username: &'life1 str, password: Option<&'life2 str>, extra: HashMap<String, Value>, ) -> Pin<Box<dyn Future<Output = Result<DefaultUser, Error>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, DefaultUserManager: 'async_trait,

Creates a new user with the given username and password Read more
Source§

fn create_superuser<'life0, 'life1, 'life2, 'async_trait>( &'life0 mut self, username: &'life1 str, password: Option<&'life2 str>, extra: HashMap<String, Value>, ) -> Pin<Box<dyn Future<Output = Result<DefaultUser, Error>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, DefaultUserManager: 'async_trait,

Creates a new superuser with the given username and password Read more
Source§

fn normalize_email(email: &str) -> String

Normalizes an email address Read more
Source§

impl Clone for DefaultUser

Source§

fn clone(&self) -> DefaultUser

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DefaultUser

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for DefaultUser

Source§

fn default() -> DefaultUser

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for DefaultUser

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<DefaultUser, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl FullUser for DefaultUser

Source§

fn username(&self) -> &str

Returns the username
Source§

fn email(&self) -> &str

Returns the email address
Source§

fn first_name(&self) -> &str

Returns the first name
Source§

fn last_name(&self) -> &str

Returns the last name
Source§

fn is_staff(&self) -> bool

Returns whether the user is a staff member Read more
Source§

fn is_superuser(&self) -> bool

Returns whether the user is a superuser Read more
Source§

fn date_joined(&self) -> DateTime<Utc>

Returns when the user account was created
Source§

fn get_full_name(&self) -> String

Returns the full name (first name + last name) Read more
Source§

fn get_short_name(&self) -> &str

Returns the short name (first name only) Read more
Source§

impl Model for DefaultUser

Source§

type PrimaryKey = Uuid

The primary key type
Source§

type Fields = DefaultUserFields

Type-safe field selector Read more
Source§

fn table_name() -> &'static str

Get the table name
Source§

fn new_fields() -> <DefaultUser as Model>::Fields

Create a new field selector instance Read more
Source§

fn primary_key(&self) -> Option<<DefaultUser as Model>::PrimaryKey>

Get the primary key value Read more
Source§

fn set_primary_key(&mut self, value: <DefaultUser as Model>::PrimaryKey)

Set the primary key value
Source§

fn primary_key_field() -> &'static str

Get the primary key field name
Source§

fn app_label() -> &'static str

Get the app label for this model Read more
Source§

fn composite_primary_key() -> Option<CompositePrimaryKey>

Get composite primary key definition if this model uses composite PK Read more
Source§

fn get_composite_pk_values(&self) -> HashMap<String, PkValue>

Get composite primary key values for this instance Read more
Source§

fn field_metadata() -> Vec<FieldInfo>

Get field metadata for inspection Read more
Source§

fn relationship_metadata() -> Vec<RelationInfo>

Get relationship metadata for inspection Read more
Source§

fn index_metadata() -> Vec<IndexInfo>

Get index metadata for inspection Read more
Source§

fn constraint_metadata() -> Vec<ConstraintInfo>

Get constraint metadata for inspection Read more
Source§

fn objects() -> Manager<Self>
where Self: Sized,

Django-style objects manager accessor Read more
Source§

fn save(&mut self) -> impl Future<Output = Result<(), Error>> + Send
where Self: Sized,

Save the model instance to the database with event dispatching Read more
Source§

fn delete(&self) -> impl Future<Output = Result<(), Error>> + Send
where Self: Sized,

Delete the model instance from the database with event dispatching Read more
Source§

impl PermissionsMixin for DefaultUser

Source§

fn is_superuser(&self) -> bool

Returns whether this user is a superuser Read more
Source§

fn user_permissions(&self) -> &[String]

Returns the list of permissions directly assigned to this user Read more
Source§

fn groups(&self) -> &[String]

Returns the list of groups this user belongs to Read more
Source§

fn get_user_permissions(&self) -> HashSet<String>

Returns all permissions directly assigned to this user Read more
Source§

fn get_group_permissions(&self) -> HashSet<String>

Returns all permissions from groups this user belongs to Read more
Source§

fn get_all_permissions(&self) -> HashSet<String>

Returns all permissions for this user (user permissions + group permissions) Read more
Source§

fn has_perm(&self, perm: &str) -> bool

Checks if this user has a specific permission Read more
Source§

fn has_perms(&self, perms: &[&str]) -> bool

Checks if this user has all of the specified permissions Read more
Source§

fn has_module_perms(&self, app_label: &str) -> bool

Checks if this user has any permission for a specific app/module Read more
Source§

impl Serialize for DefaultUser

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> AdminUser for T
where T: FullUser,

Source§

fn is_active(&self) -> bool

Whether the user account is active
Source§

fn is_staff(&self) -> bool

Whether the user is a staff member (can access admin)
Source§

fn is_superuser(&self) -> bool

Whether the user is a superuser (all permissions granted)
Source§

fn get_username(&self) -> &str

The username for audit logging
Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Any for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Source§

fn type_name(&self) -> &'static str

Source§

impl<T> AnySync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Source§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<T> IntoResult<T> for T

Source§

impl<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

Source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
Source§

impl<L> LayerExt<L> for L

Source§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
Source§

impl<T> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<R, P> ReadPrimitive<R> for P
where R: Read + ReadEndian<P>, P: Default,

Source§

fn read_from_little_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_little_endian().
Source§

fn read_from_big_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_big_endian().
Source§

fn read_from_native_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_native_endian().
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<E> ServerFnErrorAssertions<E> for E
where E: Debug,

Source§

fn should_contain_message(&self, expected: &str)
where E: Display,

Assert that the error message contains the specified text.
Source§

fn should_have_message(&self, expected: &str)
where E: Display,

Assert that the error message matches exactly.
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<S, T> Upcast<T> for S
where T: UpcastFrom<S> + ?Sized, S: ?Sized,

Source§

fn upcast(&self) -> &T
where Self: ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider ref type within the Wasm bindgen generics type system. Read more
Source§

fn upcast_into(self) -> T
where Self: Sized + ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider type within the Wasm bindgen generics type system. Read more
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,