Struct Post
pub struct Post {Show 14 fields
pub uuid: Uuid,
pub author: Option<Uuid>,
pub title: Option<String>,
pub text: String,
pub commentable: bool,
pub blog: Uuid,
pub updu: Option<Uuid>,
pub updt: Option<NaiveDateTime>,
pub ver: Option<i32>,
pub likes: Option<Vec<Uuid>>,
pub repost: Option<Uuid>,
pub rstatus: Option<RStatus>,
pub cdt: Option<NaiveDateTime>,
pub shares: i32,
}
Fields§
§uuid: Uuid
§title: Option<String>
§text: String
§commentable: bool
§blog: Uuid
§updu: Option<Uuid>
§updt: Option<NaiveDateTime>
§ver: Option<i32>
§likes: Option<Vec<Uuid>>
§repost: Option<Uuid>
§rstatus: Option<RStatus>
§cdt: Option<NaiveDateTime>
Implementations§
§impl Post
impl Post
pub fn add_like(&mut self, usr_id: Uuid)
pub fn remove_like(&mut self, usr_id: Uuid)
pub fn from_request(post: &PostRequest) -> Post
pub fn to_response(&self) -> PostResponse
pub fn to_response_list(posts: Vec<Post>) -> Vec<PostResponse>
pub fn to_response_post_list_with_comments( posts: Vec<Post>, comments: Vec<Comment>, ) -> Vec<PostResponse>
Trait Implementations§
§impl<'update> AsChangeset for &'update Post
impl<'update> AsChangeset for &'update Post
§type Changeset = <(Option<Eq<author, <&'update Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <&'update String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Eq<text, <&'update String as AsExpression<<text as Expression>::SqlType>>::Expression>, Eq<commentable, <&'update bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Eq<blog, <&'update Uuid as AsExpression<<blog 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<repost, <&'update Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <&'update NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Eq<shares, <&'update i32 as AsExpression<<shares as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
type Changeset = <(Option<Eq<author, <&'update Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <&'update String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Eq<text, <&'update String as AsExpression<<text as Expression>::SqlType>>::Expression>, Eq<commentable, <&'update bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Eq<blog, <&'update Uuid as AsExpression<<blog 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<repost, <&'update Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <&'update NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Eq<shares, <&'update i32 as AsExpression<<shares 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 Post
impl<'update> AsChangeset for Post
§type Changeset = <(Option<Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>, Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Eq<blog, <Uuid as AsExpression<<blog 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<repost, <Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Eq<shares, <i32 as AsExpression<<shares as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
type Changeset = <(Option<Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>, Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>, Eq<blog, <Uuid as AsExpression<<blog 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<repost, <Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Eq<shares, <i32 as AsExpression<<shares 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 Post
impl<'de> Deserialize<'de> for Post
§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 Post
impl<'ident> Identifiable for &'ident Post
§impl<'insert> Insertable<table> for &'insert Post
impl<'insert> Insertable<table> for &'insert Post
§type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<author, <&'insert Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <&'insert String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Option<Eq<text, <&'insert String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <&'insert bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<blog, <&'insert Uuid as AsExpression<<blog 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<repost, <&'insert Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <&'insert NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Option<Eq<shares, <&'insert i32 as AsExpression<<shares as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<author, <&'insert Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <&'insert String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Option<Eq<text, <&'insert String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <&'insert bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<blog, <&'insert Uuid as AsExpression<<blog 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<repost, <&'insert Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <&'insert NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Option<Eq<shares, <&'insert i32 as AsExpression<<shares 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 Post
impl<'insert> Insertable<table> for Post
§type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Option<Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<blog, <Uuid as AsExpression<<blog 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<repost, <Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Option<Eq<shares, <i32 as AsExpression<<shares as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<author, <Uuid as AsExpression<<author as Expression>::SqlType>>::Expression>>, Option<Eq<title, <String as AsExpression<<title as Expression>::SqlType>>::Expression>>, Option<Eq<text, <String as AsExpression<<text as Expression>::SqlType>>::Expression>>, Option<Eq<commentable, <bool as AsExpression<<commentable as Expression>::SqlType>>::Expression>>, Option<Eq<blog, <Uuid as AsExpression<<blog 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<repost, <Uuid as AsExpression<<repost as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cdt, <NaiveDateTime as AsExpression<<cdt as Expression>::SqlType>>::Expression>>, Option<Eq<shares, <i32 as AsExpression<<shares 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 Post
impl MetaFields for Post
fn update_fields(&mut self, user_id: Uuid)
fn init_fields(&mut self, user_id: Uuid)
§impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Post
impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Post
§impl<__DB: Backend> QueryableByName<__DB> for Postwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB> + FromSql<SqlTypeOf<blog>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<author>, __DB> + FromSql<SqlTypeOf<updu>, __DB> + FromSql<SqlTypeOf<repost>, __DB>,
Option<String>: FromSql<SqlTypeOf<title>, __DB>,
String: FromSql<SqlTypeOf<text>, __DB>,
bool: FromSql<SqlTypeOf<commentable>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB> + FromSql<SqlTypeOf<cdt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<Vec<Uuid>>: FromSql<SqlTypeOf<likes>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
i32: FromSql<SqlTypeOf<shares>, __DB>,
impl<__DB: Backend> QueryableByName<__DB> for Postwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB> + FromSql<SqlTypeOf<blog>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<author>, __DB> + FromSql<SqlTypeOf<updu>, __DB> + FromSql<SqlTypeOf<repost>, __DB>,
Option<String>: FromSql<SqlTypeOf<title>, __DB>,
String: FromSql<SqlTypeOf<text>, __DB>,
bool: FromSql<SqlTypeOf<commentable>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB> + FromSql<SqlTypeOf<cdt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<Vec<Uuid>>: FromSql<SqlTypeOf<likes>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
i32: FromSql<SqlTypeOf<shares>, __DB>,
impl StructuralPartialEq for Post
impl<'insert> UndecoratedInsertRecord<table> for Post
Auto Trait Implementations§
impl Freeze for Post
impl RefUnwindSafe for Post
impl Send for Post
impl Sync for Post
impl Unpin for Post
impl UnwindSafe for Post
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.