Struct backend::model::entity::Users

source ·
pub struct Users {
    pub id: Uuid,
    pub salutation: Salutation,
    pub title: Option<String>,
    pub country: String,
    pub phone: Option<String>,
    pub website: Option<String>,
    pub organization: Option<String>,
    pub experience: Option<Experience>,
    pub membership: Option<Membership>,
    pub member_years: Option<Vec<Option<i32>>>,
    pub member_since: Option<NaiveDate>,
    pub permacoins: Option<Vec<Option<i32>>>,
}
Expand description

The Users entity.

Fields§

§id: Uuid

The id of the user from Keycloak.

§salutation: Salutation

The preferred salutation of the user.

§title: Option<String>

The title(s) of the user.

§country: String

The current country of the user.

§phone: Option<String>

The phone number of the user.

§website: Option<String>

The website of the user.

§organization: Option<String>

The organization the user belongs to.

§experience: Option<Experience>

The experience level in permaculture of the user.

§membership: Option<Membership>

The membership type of the user.

§member_years: Option<Vec<Option<i32>>>

A collection of years in which the user was a member.

§member_since: Option<NaiveDate>

The date since when the user is a member.

§permacoins: Option<Vec<Option<i32>>>

The amount of permacoins the user earned in each year as a member.

Implementations§

source§

impl Users

source

pub async fn create( user_data: UsersDto, user_id: Uuid, conn: &mut AsyncPgConnection, ) -> QueryResult<UsersDto>

Create a user data entry for a new user.

§Errors
  • Unknown, diesel doesn’t say why it might error.

Trait Implementations§

source§

impl From<(UsersDto, Uuid)> for Users

source§

fn from((user_data, user_id): (UsersDto, Uuid)) -> Self

Converts to this type from the input type.
source§

impl From<Users> for UsersDto

source§

fn from(user_data: Users) -> Self

Converts to this type from the input type.
source§

impl HasTable for Users

§

type Table = table

The table this type is associated with.
source§

fn table() -> Self::Table

Returns the table this type is associated with.
source§

impl<'ident> Identifiable for &'ident Users

§

type Id = &'ident Uuid

The type of this struct’s identifier. Read more
source§

fn id(self) -> Self::Id

Returns the identifier for this record. Read more
source§

impl<'insert> Insertable<table> for &'insert Users

§

type Values = <(Option<Grouped<Eq<id, <&'insert Uuid as AsExpression<<id as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<salutation, <&'insert Salutation as AsExpression<<salutation as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<title, <&'insert String as AsExpression<<title as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<country, <&'insert String as AsExpression<<country as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<phone, <&'insert String as AsExpression<<phone as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<website, <&'insert String as AsExpression<<website as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<organization, <&'insert String as AsExpression<<organization as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<experience, <&'insert Experience as AsExpression<<experience as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<membership, <&'insert Membership as AsExpression<<membership as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<member_years, <&'insert Vec<Option<i32>> as AsExpression<<member_years as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<member_since, <&'insert NaiveDate as AsExpression<<member_since as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<permacoins, <&'insert Vec<Option<i32>> as AsExpression<<permacoins as Expression>::SqlType>>::Expression>>>) as Insertable<table>>::Values

The VALUES clause to insert these records Read more
source§

fn values( self, ) -> <(Option<Eq<id, &'insert Uuid>>, Option<Eq<salutation, &'insert Salutation>>, Option<Eq<title, &'insert String>>, Option<Eq<country, &'insert String>>, Option<Eq<phone, &'insert String>>, Option<Eq<website, &'insert String>>, Option<Eq<organization, &'insert String>>, Option<Eq<experience, &'insert Experience>>, Option<Eq<membership, &'insert Membership>>, Option<Eq<member_years, &'insert Vec<Option<i32>>>>, Option<Eq<member_since, &'insert NaiveDate>>, Option<Eq<permacoins, &'insert Vec<Option<i32>>>>) as Insertable<table>>::Values

Construct Self::Values Read more
source§

fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>
where T: Table, Self: Sized,

Insert self into a given table. Read more
source§

impl Insertable<table> for Users

§

type Values = <(Option<Grouped<Eq<id, <Uuid as AsExpression<<id as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<salutation, <Salutation as AsExpression<<salutation as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<title, <String as AsExpression<<title as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<country, <String as AsExpression<<country as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<phone, <String as AsExpression<<phone as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<website, <String as AsExpression<<website as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<organization, <String as AsExpression<<organization as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<experience, <Experience as AsExpression<<experience as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<membership, <Membership as AsExpression<<membership as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<member_years, <Vec<Option<i32>> as AsExpression<<member_years as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<member_since, <NaiveDate as AsExpression<<member_since as Expression>::SqlType>>::Expression>>>, Option<Grouped<Eq<permacoins, <Vec<Option<i32>> as AsExpression<<permacoins as Expression>::SqlType>>::Expression>>>) as Insertable<table>>::Values

The VALUES clause to insert these records Read more
source§

fn values( self, ) -> <(Option<Eq<id, Uuid>>, Option<Eq<salutation, Salutation>>, Option<Eq<title, String>>, Option<Eq<country, String>>, Option<Eq<phone, String>>, Option<Eq<website, String>>, Option<Eq<organization, String>>, Option<Eq<experience, Experience>>, Option<Eq<membership, Membership>>, Option<Eq<member_years, Vec<Option<i32>>>>, Option<Eq<member_since, NaiveDate>>, Option<Eq<permacoins, Vec<Option<i32>>>>) as Insertable<table>>::Values

Construct Self::Values Read more
source§

fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>
where T: Table, Self: Sized,

Insert self into a given table. Read more
source§

impl<__DB: Backend, __ST0, __ST1, __ST2, __ST3, __ST4, __ST5, __ST6, __ST7, __ST8, __ST9, __ST10, __ST11> Queryable<(__ST0, __ST1, __ST2, __ST3, __ST4, __ST5, __ST6, __ST7, __ST8, __ST9, __ST10, __ST11), __DB> for Users

§

type Row = (Uuid, Salutation, Option<String>, String, Option<String>, Option<String>, Option<String>, Option<Experience>, Option<Membership>, Option<Vec<Option<i32>>>, Option<NaiveDate>, Option<Vec<Option<i32>>>)

The Rust type you’d like to map from. Read more
source§

fn build(row: Self::Row) -> Result<Self>

Construct an instance of this type
source§

impl UndecoratedInsertRecord<table> for Users

Auto Trait Implementations§

§

impl Freeze for Users

§

impl RefUnwindSafe for Users

§

impl Send for Users

§

impl Sync for Users

§

impl Unpin for Users

§

impl UnwindSafe for Users

Blanket Implementations§

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> 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> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

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> IntoSql for T

source§

fn into_sql<T>(self) -> Self::Expression

Convert self to an expression for Diesel’s query builder. Read more
source§

fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression

Convert &self to an expression for Diesel’s query builder. Read more
source§

impl<T> Paginate for T

source§

fn paginate(self, page: Option<i32>) -> PaginatedQuery<T>

Return a paginated version of a query for a specific page number.
source§

impl<T, Conn> RunQueryDsl<Conn> for T

source§

fn execute<'conn, 'query>( self, conn: &'conn mut Conn, ) -> <Conn as AsyncConnection>::ExecuteFuture<'conn, 'query>
where Conn: AsyncConnection + Send, Self: ExecuteDsl<Conn> + 'query,

Executes the given command, returning the number of rows affected. Read more
source§

fn load<'query, 'conn, U>( self, conn: &'conn mut Conn, ) -> AndThen<Self::LoadFuture<'conn>, TryCollect<Self::Stream<'conn>, Vec<U>>, fn(_: Self::Stream<'conn>) -> TryCollect<Self::Stream<'conn>, Vec<U>>>
where U: Send, Conn: AsyncConnection, Self: LoadQuery<'query, Conn, U> + 'query,

Executes the given query, returning a Vec with the returned rows. Read more
source§

fn load_stream<'conn, 'query, U>( self, conn: &'conn mut Conn, ) -> Self::LoadFuture<'conn>
where Conn: AsyncConnection, U: 'conn, Self: LoadQuery<'query, Conn, U> + 'query,

Executes the given query, returning a Stream with the returned rows. Read more
source§

fn get_result<'query, 'conn, U>( self, conn: &'conn mut Conn, ) -> AndThen<Self::LoadFuture<'conn>, Map<StreamFuture<Pin<Box<Self::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<Self::Stream<'conn>>>)) -> Result<U, Error>>, fn(_: Self::Stream<'conn>) -> Map<StreamFuture<Pin<Box<Self::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<Self::Stream<'conn>>>)) -> Result<U, Error>>>
where U: Send + 'conn, Conn: AsyncConnection, Self: LoadQuery<'query, Conn, U> + 'query,

Runs the command, and returns the affected row. Read more
source§

fn get_results<'query, 'conn, U>( self, conn: &'conn mut Conn, ) -> AndThen<Self::LoadFuture<'conn>, TryCollect<Self::Stream<'conn>, Vec<U>>, fn(_: Self::Stream<'conn>) -> TryCollect<Self::Stream<'conn>, Vec<U>>>
where U: Send, Conn: AsyncConnection, Self: LoadQuery<'query, Conn, U> + 'query,

Runs the command, returning an Vec with the affected rows. Read more
source§

fn first<'query, 'conn, U>( self, conn: &'conn mut Conn, ) -> AndThen<<Self::Output as LoadQuery<'query, Conn, U>>::LoadFuture<'conn>, Map<StreamFuture<Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>)) -> Result<U, Error>>, fn(_: <Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>) -> Map<StreamFuture<Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>)) -> Result<U, Error>>>
where U: Send + 'conn, Conn: AsyncConnection, Self: LimitDsl, Self::Output: LoadQuery<'query, Conn, U> + Send + 'query,

Attempts to load a single record. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T, ST, DB> StaticallySizedRow<ST, DB> for T
where ST: SqlTypeOrSelectable + TupleSize, T: Queryable<ST, DB>, DB: Backend,

source§

const FIELD_COUNT: usize = <ST as crate::util::TupleSize>::SIZE

The number of fields that this type will consume.
source§

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

§

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>,

§

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