Struct Comment
pub struct Comment {Show 15 fields
pub uuid: Uuid,
pub post: Option<Uuid>,
pub author: Uuid,
pub text: String,
pub status: Option<Status>,
pub updu: Option<Uuid>,
pub updt: Option<NaiveDateTime>,
pub ver: Option<i32>,
pub likes: Option<Vec<Uuid>>,
pub audio: Option<Uuid>,
pub video: Option<Uuid>,
pub picture: Option<Uuid>,
pub reply_to: Option<Uuid>,
pub rstatus: Option<RStatus>,
pub date: NaiveDateTime,
}
Fields§
§uuid: Uuid
§post: Option<Uuid>
§text: String
§status: Option<Status>
§updu: Option<Uuid>
§updt: Option<NaiveDateTime>
§ver: Option<i32>
§likes: Option<Vec<Uuid>>
§audio: Option<Uuid>
§video: Option<Uuid>
§picture: Option<Uuid>
§reply_to: Option<Uuid>
§rstatus: Option<RStatus>
§date: NaiveDateTime
Implementations§
§impl Comment
impl Comment
pub fn add_like(&mut self, usr_id: Uuid)
pub fn remove_like(&mut self, usr_id: Uuid)
pub fn from_request(comment: &CommentRequest) -> Comment
pub fn to_response(&self) -> CommentResponse
pub fn to_response_list(comments: Vec<Comment>) -> Vec<CommentResponse>
Trait Implementations§
§impl<'update> AsChangeset for &'update Comment
impl<'update> AsChangeset for &'update Comment
§type Changeset = <(Option<Eq<post, <&'update Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Eq<author, <&'update Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>, Eq<text, <&'update String as AsExpression<<text as Expression>::SqlType>>::Expression>, Option<Eq<status, <&'update Status as AsExpression<<status 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<audio, <&'update Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <&'update Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <&'update Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <&'update Uuid as AsExpression<<reply_to 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 = <(Option<Eq<post, <&'update Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Eq<author, <&'update Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>, Eq<text, <&'update String as AsExpression<<text as Expression>::SqlType>>::Expression>, Option<Eq<status, <&'update Status as AsExpression<<status 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<audio, <&'update Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <&'update Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <&'update Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <&'update Uuid as AsExpression<<reply_to 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 Comment
impl<'update> AsChangeset for Comment
§type Changeset = <(Option<Eq<post, <Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>, Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>, Option<Eq<status, <Status as AsExpression<<status 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<audio, <Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <Uuid as AsExpression<<reply_to 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 = <(Option<Eq<post, <Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>, Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>, Option<Eq<status, <Status as AsExpression<<status 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<audio, <Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <Uuid as AsExpression<<reply_to 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 Comment
impl<'de> Deserialize<'de> for Comment
§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 Comment
impl<'ident> Identifiable for &'ident Comment
§impl<'insert> Insertable<table> for &'insert Comment
impl<'insert> Insertable<table> for &'insert Comment
§type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<post, <&'insert Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Option<Eq<author, <&'insert Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<text, <&'insert String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<status, <&'insert Status as AsExpression<<status 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<audio, <&'insert Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <&'insert Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <&'insert Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <&'insert Uuid as AsExpression<<reply_to 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<post, <&'insert Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Option<Eq<author, <&'insert Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<text, <&'insert String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<status, <&'insert Status as AsExpression<<status 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<audio, <&'insert Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <&'insert Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <&'insert Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <&'insert Uuid as AsExpression<<reply_to 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 Comment
impl<'insert> Insertable<table> for Comment
§type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<post, <Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Option<Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<status, <Status as AsExpression<<status 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<audio, <Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <Uuid as AsExpression<<reply_to 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<post, <Uuid as AsExpression<<post as Expression>::SqlType>>::Expression>>, Option<Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<status, <Status as AsExpression<<status 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<audio, <Uuid as AsExpression<<audio as Expression>::SqlType>>::Expression>>, Option<Eq<video, <Uuid as AsExpression<<video as Expression>::SqlType>>::Expression>>, Option<Eq<picture, <Uuid as AsExpression<<picture as Expression>::SqlType>>::Expression>>, Option<Eq<reply_to, <Uuid as AsExpression<<reply_to 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 Comment
impl MetaFields for Comment
fn update_fields(&mut self, user_id: Uuid)
fn init_fields(&mut self, user_id: Uuid)
§impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Comment
impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Comment
§impl<__DB: Backend> QueryableByName<__DB> for Commentwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB> + FromSql<SqlTypeOf<author>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<post>, __DB> + FromSql<SqlTypeOf<updu>, __DB> + FromSql<SqlTypeOf<audio>, __DB> + FromSql<SqlTypeOf<video>, __DB> + FromSql<SqlTypeOf<picture>, __DB> + FromSql<SqlTypeOf<reply_to>, __DB>,
String: FromSql<SqlTypeOf<text>, __DB>,
Option<Status>: FromSql<SqlTypeOf<status>, __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 Commentwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB> + FromSql<SqlTypeOf<author>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<post>, __DB> + FromSql<SqlTypeOf<updu>, __DB> + FromSql<SqlTypeOf<audio>, __DB> + FromSql<SqlTypeOf<video>, __DB> + FromSql<SqlTypeOf<picture>, __DB> + FromSql<SqlTypeOf<reply_to>, __DB>,
String: FromSql<SqlTypeOf<text>, __DB>,
Option<Status>: FromSql<SqlTypeOf<status>, __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 Comment
impl<'insert> UndecoratedInsertRecord<table> for Comment
Auto Trait Implementations§
impl Freeze for Comment
impl RefUnwindSafe for Comment
impl Send for Comment
impl Sync for Comment
impl Unpin for Comment
impl UnwindSafe for Comment
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.