Struct Playlist
pub struct Playlist {
pub uuid: Uuid,
pub updu: Option<Uuid>,
pub updt: Option<NaiveDateTime>,
pub ver: Option<i32>,
pub state: Option<String>,
pub user_id: Option<Uuid>,
pub current_id: Option<Uuid>,
pub audios: Option<Vec<Uuid>>,
pub rstatus: Option<RStatus>,
pub cover: Option<String>,
pub name: Option<String>,
pub date: NaiveDateTime,
}
Fields§
§uuid: Uuid
§updu: Option<Uuid>
§updt: Option<NaiveDateTime>
§ver: Option<i32>
§state: Option<String>
§user_id: Option<Uuid>
§current_id: Option<Uuid>
§audios: Option<Vec<Uuid>>
§rstatus: Option<RStatus>
§cover: Option<String>
§name: Option<String>
§date: NaiveDateTime
Implementations§
§impl Playlist
impl Playlist
pub fn add_audio(&mut self, audio_id: Uuid)
pub fn remove_audio(&mut self, audio_id: Uuid)
pub fn form_request(playlist: &PlaylistRequest) -> Playlist
pub fn to_response(&self) -> PlaylistResponse
pub fn to_response_list(playlists: Vec<Playlist>) -> Vec<PlaylistResponse>
Trait Implementations§
§impl<'update> AsChangeset for &'update Playlist
impl<'update> AsChangeset for &'update Playlist
§type Changeset = <(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<state, <&'update String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <&'update Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <&'update Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <&'update Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'update String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'update String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Eq<date, <&'update NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
type Changeset = <(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<state, <&'update String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <&'update Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <&'update Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <&'update Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'update String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'update String as AsExpression<<name 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 Playlist
impl<'update> AsChangeset for Playlist
§type Changeset = <(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<state, <String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Eq<date, <NaiveDateTime as AsExpression<<date as Expression>::SqlType>>::Expression>) as AsChangeset>::Changeset
type Changeset = <(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<state, <String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name 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 Playlist
impl<'de> Deserialize<'de> for Playlist
§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 Playlist
impl<'ident> Identifiable for &'ident Playlist
§impl<'insert> Insertable<table> for &'insert Playlist
impl<'insert> Insertable<table> for &'insert Playlist
§type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid 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<state, <&'insert String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <&'insert Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <&'insert Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <&'insert Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'insert String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'insert String as AsExpression<<name 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<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<state, <&'insert String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <&'insert Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <&'insert Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <&'insert Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <&'insert String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'insert String as AsExpression<<name 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 Playlist
impl<'insert> Insertable<table> for Playlist
§type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid 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<state, <String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name 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<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<state, <String as AsExpression<<state as Expression>::SqlType>>::Expression>>, Option<Eq<user_id, <Uuid as AsExpression<<user_id as Expression>::SqlType>>::Expression>>, Option<Eq<current_id, <Uuid as AsExpression<<current_id as Expression>::SqlType>>::Expression>>, Option<Eq<audios, <Vec<Uuid> as AsExpression<<audios as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<cover, <String as AsExpression<<cover as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name 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 Playlist
impl MetaFields for Playlist
fn update_fields(&mut self, user_id: Uuid)
fn init_fields(&mut self, user_id: Uuid)
§impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Playlist
impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Playlist
§impl<__DB: Backend> QueryableByName<__DB> for Playlistwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<updu>, __DB> + FromSql<SqlTypeOf<user_id>, __DB> + FromSql<SqlTypeOf<current_id>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<String>: FromSql<SqlTypeOf<state>, __DB> + FromSql<SqlTypeOf<cover>, __DB> + FromSql<SqlTypeOf<name>, __DB>,
Option<Vec<Uuid>>: FromSql<SqlTypeOf<audios>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
NaiveDateTime: FromSql<SqlTypeOf<date>, __DB>,
impl<__DB: Backend> QueryableByName<__DB> for Playlistwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<updu>, __DB> + FromSql<SqlTypeOf<user_id>, __DB> + FromSql<SqlTypeOf<current_id>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<String>: FromSql<SqlTypeOf<state>, __DB> + FromSql<SqlTypeOf<cover>, __DB> + FromSql<SqlTypeOf<name>, __DB>,
Option<Vec<Uuid>>: FromSql<SqlTypeOf<audios>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
NaiveDateTime: FromSql<SqlTypeOf<date>, __DB>,
impl StructuralPartialEq for Playlist
impl<'insert> UndecoratedInsertRecord<table> for Playlist
Auto Trait Implementations§
impl Freeze for Playlist
impl RefUnwindSafe for Playlist
impl Send for Playlist
impl Sync for Playlist
impl Unpin for Playlist
impl UnwindSafe for Playlist
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.