pub struct Task {Show 14 fields
pub id: String,
pub execution_id: String,
pub workflow_id: String,
pub node_id: String,
pub status: TaskStatus,
pub created_at: i64,
pub started_at: Option<i64>,
pub completed_at: Option<i64>,
pub input: NodeInput,
pub output: Option<NodeOutput>,
pub error: Option<String>,
pub context: ExecutionContext,
node: OnceCell<Node>,
workflow: OnceCell<Arc<Workflow>>,
}Expand description
Unified task structure that replaces both TaskRecord and WorkflowTask
Fields§
§id: String§execution_id: String§workflow_id: String§node_id: String§status: TaskStatus§created_at: i64§started_at: Option<i64>§completed_at: Option<i64>§input: NodeInput§output: Option<NodeOutput>§error: Option<String>§context: ExecutionContext§node: OnceCell<Node>§workflow: OnceCell<Arc<Workflow>>Implementations§
Source§impl Task
impl Task
Sourcepub fn new(
execution_id: String,
workflow_id: String,
node_id: String,
input: NodeInput,
context: ExecutionContext,
) -> Self
pub fn new( execution_id: String, workflow_id: String, node_id: String, input: NodeInput, context: ExecutionContext, ) -> Self
Create a new task
Sourcepub fn get_node(&self, storage: &Storage) -> Result<&Node>
pub fn get_node(&self, storage: &Storage) -> Result<&Node>
Get the node for this task (lazy-loaded)
Sourcepub fn get_workflow(&self, storage: &Storage) -> Result<Arc<Workflow>>
pub fn get_workflow(&self, storage: &Storage) -> Result<Arc<Workflow>>
Get the workflow for this task (lazy-loaded and shared)
Sourcepub fn set_workflow(&self, workflow: Arc<Workflow>) -> Result<(), Arc<Workflow>>
pub fn set_workflow(&self, workflow: Arc<Workflow>) -> Result<(), Arc<Workflow>>
Pre-populate the workflow Arc to avoid lazy loading from storage This is useful when creating tasks from a workflow that’s already in memory
Sourcepub fn complete(&mut self, output: NodeOutput)
pub fn complete(&mut self, output: NodeOutput)
Mark task as completed
Sourcepub fn for_single_node(node: Node, input: NodeInput) -> Self
pub fn for_single_node(node: Node, input: NodeInput) -> Self
Create a task for a single node execution (no workflow context)
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Task
impl<'de> Deserialize<'de> for Task
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 Task
impl TS for Task
Source§type WithoutGenerics = Task
type WithoutGenerics = Task
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 = Task
type OptionInnerType = Task
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 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 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.
§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
Resolves all dependencies of this type recursively.
§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 more§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 more§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 more§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
§fn default_output_path() -> Option<PathBuf>
fn default_output_path() -> Option<PathBuf>
Returns the output path to where
T should be exported. Read moreAuto Trait Implementations§
impl !Freeze for Task
impl !RefUnwindSafe for Task
impl Send for Task
impl Sync for Task
impl Unpin for Task
impl !UnwindSafe for Task
Blanket Implementations§
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