Struct Album
pub struct Album {Show 15 fields
pub uuid: Uuid,
pub name: String,
pub access: String,
pub type_t: Option<String>,
pub owner: Uuid,
pub status: Option<Status>,
pub description: Option<String>,
pub cover: Option<String>,
pub commentable: bool,
pub updu: Option<Uuid>,
pub updt: Option<NaiveDateTime>,
pub ver: Option<i32>,
pub likes: Option<Vec<Uuid>>,
pub rstatus: Option<RStatus>,
pub date: NaiveDateTime,
}
Fields§
§uuid: Uuid
§name: String
§access: String
§type_t: Option<String>
§owner: Uuid
§status: Option<Status>
§description: Option<String>
§cover: Option<String>
§commentable: bool
§updu: Option<Uuid>
§updt: Option<NaiveDateTime>
§ver: Option<i32>
§likes: Option<Vec<Uuid>>
§rstatus: Option<RStatus>
§date: NaiveDateTime
Implementations§
§impl Album
impl Album
pub fn add_like(&mut self, usr_id: Uuid)
pub fn remove_like(&mut self, usr_id: Uuid)
pub fn from_request(album: &AlbumRequest) -> Album
pub fn to_response(&self) -> AlbumResponse
pub fn to_response_list(albums: Vec<Album>) -> Vec<AlbumResponse>
Trait Implementations§
§impl<'update> AsChangeset for &'update Album
impl<'update> AsChangeset for &'update Album
§type Changeset = <(Eq<name, <&'update String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<access, <&'update String as AsExpression<<access as Expression>::SqlType>>::Expression>, Option<Eq<type_t, <&'update String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Eq<owner, <&'update Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>, Option<Eq<status, <&'update Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <&'update String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'update String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Eq<commentable, <&'update bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Option<Eq<updu, <&'update Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'update NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'update i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <&'update Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<date, <&'update NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
type Changeset = <(Eq<name, <&'update String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<access, <&'update String as AsExpression<<access as Expression>::SqlType>>::Expression>, Option<Eq<type_t, <&'update String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Eq<owner, <&'update Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>, Option<Eq<status, <&'update Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <&'update String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'update String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Eq<commentable, <&'update bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Option<Eq<updu, <&'update Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'update NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'update i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <&'update Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<date, <&'update NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
The update statement this type represents
§fn as_changeset(self) -> Self::Changeset
fn as_changeset(self) -> Self::Changeset
Convert
self
into the actual update statement being executed§impl<'update> AsChangeset for Album
impl<'update> AsChangeset for Album
§type Changeset = <(Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<access, <String as AsExpression<<access as Expression>::SqlType>>::Expression>, Option<Eq<type_t, <String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Eq<owner, <Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>, Option<Eq<status, <Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<date, <NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
type Changeset = <(Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<access, <String as AsExpression<<access as Expression>::SqlType>>::Expression>, Option<Eq<type_t, <String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Eq<owner, <Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>, Option<Eq<status, <Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<date, <NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
The update statement this type represents
§fn as_changeset(self) -> Self::Changeset
fn as_changeset(self) -> Self::Changeset
Convert
self
into the actual update statement being executed§impl<'de> Deserialize<'de> for Album
impl<'de> Deserialize<'de> for Album
§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
§impl<'ident> Identifiable for &'ident Album
impl<'ident> Identifiable for &'ident Album
§impl<'insert> Insertable<table> for &'insert Album
impl<'insert> Insertable<table> for &'insert Album
§type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'insert String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<access, <&'insert String as AsExpression<<access as Expression>::SqlType>>::Expression>>, Option<Eq<type_t, <&'insert String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Option<Eq<owner, <&'insert Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>>, Option<Eq<status, <&'insert Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <&'insert String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'insert String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <&'insert bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <&'insert Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'insert NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'insert i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <&'insert Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<date, <&'insert NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'insert String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<access, <&'insert String as AsExpression<<access as Expression>::SqlType>>::Expression>>, Option<Eq<type_t, <&'insert String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Option<Eq<owner, <&'insert Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>>, Option<Eq<status, <&'insert Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <&'insert String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'insert String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <&'insert bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <&'insert Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'insert NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'insert i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <&'insert Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<date, <&'insert NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
The
VALUES
clause to insert these records Read moreSource§fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
Insert
self
into a given table. Read more§impl<'insert> Insertable<table> for Album
impl<'insert> Insertable<table> for Album
§type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<access, <String as AsExpression<<access as Expression>::SqlType>>::Expression>>, Option<Eq<type_t, <String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Option<Eq<owner, <Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>>, Option<Eq<status, <Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<date, <NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<access, <String as AsExpression<<access as Expression>::SqlType>>::Expression>>, Option<Eq<type_t, <String as AsExpression<<type_t as Expression>::SqlType>>::Expression>>, Option<Eq<owner, <Uuid as AsExpression<<owner as Expression>::SqlType>>::Expression>>, Option<Eq<status, <Status as AsExpression<<status as Expression>::SqlType>>::Expression>>, Option<Eq<description, <String as AsExpression<<description as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<likes, <Vec<Uuid> as AsExpression<<likes as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<date, <NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
The
VALUES
clause to insert these records Read moreSource§fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
Insert
self
into a given table. Read more§impl MetaFields for Album
impl MetaFields for Album
fn update_fields(&mut self, user_id: Uuid)
fn init_fields(&mut self, user_id: Uuid)
§impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Album
impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Album
§impl<__DB: Backend> QueryableByName<__DB> for Albumwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB> + FromSql<SqlTypeOf<owner>, __DB>,
String: FromSql<SqlTypeOf<name>, __DB> + FromSql<SqlTypeOf<access>, __DB>,
Option<String>: FromSql<SqlTypeOf<type_t>, __DB> + FromSql<SqlTypeOf<description>, __DB> + FromSql<SqlTypeOf<cover>, __DB>,
Option<Status>: FromSql<SqlTypeOf<status>, __DB>,
bool: FromSql<SqlTypeOf<commentable>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<updu>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<Vec<Uuid>>: FromSql<SqlTypeOf<likes>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
NaiveDateTime: FromSql<SqlTypeOf<date>, __DB>,
impl<__DB: Backend> QueryableByName<__DB> for Albumwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB> + FromSql<SqlTypeOf<owner>, __DB>,
String: FromSql<SqlTypeOf<name>, __DB> + FromSql<SqlTypeOf<access>, __DB>,
Option<String>: FromSql<SqlTypeOf<type_t>, __DB> + FromSql<SqlTypeOf<description>, __DB> + FromSql<SqlTypeOf<cover>, __DB>,
Option<Status>: FromSql<SqlTypeOf<status>, __DB>,
bool: FromSql<SqlTypeOf<commentable>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<updu>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<Vec<Uuid>>: FromSql<SqlTypeOf<likes>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
NaiveDateTime: FromSql<SqlTypeOf<date>, __DB>,
impl StructuralPartialEq for Album
impl<'insert> UndecoratedInsertRecord<table> for Album
Auto Trait Implementations§
impl Freeze for Album
impl RefUnwindSafe for Album
impl Send for Album
impl Sync for Album
impl Unpin for Album
impl UnwindSafe for Album
Blanket Implementations§
Source§impl<Src, Scheme> ApproxFrom<Src, Scheme> for Srcwhere
Scheme: ApproxScheme,
impl<Src, Scheme> ApproxFrom<Src, Scheme> for Srcwhere
Scheme: ApproxScheme,
Source§fn approx_from(src: Src) -> Result<Src, <Src as ApproxFrom<Src, Scheme>>::Err>
fn approx_from(src: Src) -> Result<Src, <Src as ApproxFrom<Src, Scheme>>::Err>
Convert the given value into an approximately equivalent representation.
Source§impl<Dst, Src, Scheme> ApproxInto<Dst, Scheme> for Srcwhere
Dst: ApproxFrom<Src, Scheme>,
Scheme: ApproxScheme,
impl<Dst, Src, Scheme> ApproxInto<Dst, Scheme> for Srcwhere
Dst: ApproxFrom<Src, Scheme>,
Scheme: ApproxScheme,
Source§type Err = <Dst as ApproxFrom<Src, Scheme>>::Err
type Err = <Dst as ApproxFrom<Src, Scheme>>::Err
The error type produced by a failed conversion.
Source§fn approx_into(self) -> Result<Dst, <Src as ApproxInto<Dst, Scheme>>::Err>
fn approx_into(self) -> Result<Dst, <Src as ApproxInto<Dst, Scheme>>::Err>
Convert the subject into an approximately equivalent representation.
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,
Source§impl<T, Dst> ConvAsUtil<Dst> for T
impl<T, Dst> ConvAsUtil<Dst> for T
Source§impl<T> ConvUtil for T
impl<T> ConvUtil for T
Source§fn approx_as<Dst>(self) -> Result<Dst, Self::Err>where
Self: Sized + ApproxInto<Dst>,
fn approx_as<Dst>(self) -> Result<Dst, Self::Err>where
Self: Sized + ApproxInto<Dst>,
Approximate the subject to a given type with the default scheme.
Source§fn approx_as_by<Dst, Scheme>(self) -> Result<Dst, Self::Err>
fn approx_as_by<Dst, Scheme>(self) -> Result<Dst, Self::Err>
Approximate the subject to a given type with a specific scheme.
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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 moreSource§impl<T> IntoSql for T
impl<T> IntoSql for T
Source§fn into_sql<T>(self) -> Self::Expressionwhere
Self: Sized + AsExpression<T>,
fn into_sql<T>(self) -> Self::Expressionwhere
Self: Sized + AsExpression<T>,
Convert
self
to an expression for Diesel’s query builder. Read moreSource§fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expressionwhere
&'a Self: AsExpression<T>,
fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expressionwhere
&'a Self: AsExpression<T>,
Convert
&self
to an expression for Diesel’s query builder. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<R, P> ReadPrimitive<R> for P
impl<R, P> ReadPrimitive<R> for P
Source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
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§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self
is actually part of its subset T
(and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self
to the equivalent element of its superset.