pub struct Draft {
pub id: Uuid,
pub task_attempt_id: Uuid,
pub draft_type: DraftType,
pub retry_process_id: Option<Uuid>,
pub prompt: String,
pub queued: bool,
pub sending: bool,
pub variant: Option<String>,
pub image_ids: Option<Vec<Uuid>>,
pub created_at: DateTime<Utc>,
pub updated_at: DateTime<Utc>,
pub version: i64,
}Fields§
§id: Uuid§task_attempt_id: Uuid§draft_type: DraftType§retry_process_id: Option<Uuid>§prompt: String§queued: bool§sending: bool§variant: Option<String>§image_ids: Option<Vec<Uuid>>§created_at: DateTime<Utc>§updated_at: DateTime<Utc>§version: i64Implementations§
Source§impl Draft
impl Draft
pub async fn find_by_rowid( pool: &SqlitePool, rowid: i64, ) -> Result<Option<Self>, Error>
pub async fn find_by_task_attempt_and_type( pool: &SqlitePool, task_attempt_id: Uuid, draft_type: DraftType, ) -> Result<Option<Self>, Error>
pub async fn upsert( pool: &SqlitePool, data: &UpsertDraft, ) -> Result<Self, Error>
pub async fn clear_after_send( pool: &SqlitePool, task_attempt_id: Uuid, draft_type: DraftType, ) -> Result<(), Error>
pub async fn delete_by_task_attempt_and_type( pool: &SqlitePool, task_attempt_id: Uuid, draft_type: DraftType, ) -> Result<(), Error>
Sourcepub async fn try_mark_sending(
pool: &SqlitePool,
task_attempt_id: Uuid,
draft_type: DraftType,
) -> Result<bool, Error>
pub async fn try_mark_sending( pool: &SqlitePool, task_attempt_id: Uuid, draft_type: DraftType, ) -> Result<bool, Error>
Attempt to atomically mark this draft as “sending” if it’s currently queued and non-empty. Returns true if the row was updated (we acquired the send lock), false otherwise.
Sourcepub async fn update_partial(
pool: &SqlitePool,
task_attempt_id: Uuid,
draft_type: DraftType,
prompt: Option<String>,
variant: Option<Option<String>>,
image_ids: Option<Vec<Uuid>>,
retry_process_id: Option<Uuid>,
) -> Result<(), Error>
pub async fn update_partial( pool: &SqlitePool, task_attempt_id: Uuid, draft_type: DraftType, prompt: Option<String>, variant: Option<Option<String>>, image_ids: Option<Vec<Uuid>>, retry_process_id: Option<Uuid>, ) -> Result<(), Error>
Partial update on a draft by attempt and type. Updates only provided fields
and bumps updated_at and version when any change occurs.
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Draft
impl<'de> Deserialize<'de> for Draft
Source§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
Source§impl TS for Draft
impl TS for Draft
Source§type WithoutGenerics = Draft
type WithoutGenerics = Draft
If this type does not have generic parameters, then
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or ().
The only requirement for these dummy types is that EXPORT_TO must be None. Read moreSource§type OptionInnerType = Draft
type OptionInnerType = Draft
If the implementing type is
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn decl_concrete() -> String
fn decl_concrete() -> String
Declaration of this type using the supplied generic arguments.
The resulting TypeScript definition will not be generic. For that, see
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl() -> String
fn decl() -> String
Declaration of this type, e.g.
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline() -> String
fn inline() -> String
Formats this types definition in TypeScript, e.g
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened() -> String
fn inline_flattened() -> String
Flatten a type declaration.
This function will panic if the type cannot be flattened.
This function will panic if the type cannot be flattened.
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all type parameters of this type.
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
Returns the output path to where
The returned path does not include the base directory from
T should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all dependency of this type.
Source§fn docs() -> Option<String>
fn docs() -> Option<String>
JSDoc comment to describe this type in TypeScript - when
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
Resolves all dependencies of this type recursively.
Source§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem.
To export this type together with all of its dependencies, use
TS::export_all. Read moreSource§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
Manually export this type into the given directory, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
Auto Trait Implementations§
impl Freeze for Draft
impl RefUnwindSafe for Draft
impl Send for Draft
impl Sync for Draft
impl Unpin for Draft
impl UnwindSafe for Draft
Blanket Implementations§
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§unsafe fn clone_to_uninit(&self, dest: *mut u8)
unsafe fn clone_to_uninit(&self, dest: *mut u8)
🔬This is a nightly-only experimental API. (
clone_to_uninit)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 more