pub struct ExecutionContext {
pub workflow_id: String,
pub execution_id: String,
pub data: HashMap<String, Value>,
pub secret_storage: Option<Arc<SecretStorage>>,
pub python_manager: Option<Arc<PythonManager>>,
}Fields§
§workflow_id: String§execution_id: String§data: HashMap<String, Value>Unified data storage with namespace prefixes:
- trigger.* : Trigger outputs
- node.* : Node outputs
- var.* : User variables
- config.* : Global configuration
secret_storage: Option<Arc<SecretStorage>>§python_manager: Option<Arc<PythonManager>>Implementations§
Source§impl ExecutionContext
impl ExecutionContext
pub fn new(workflow_id: String) -> Self
Sourcepub fn with_execution_id(workflow_id: String, execution_id: String) -> Self
pub fn with_execution_id(workflow_id: String, execution_id: String) -> Self
Create execution context with specific execution_id (for test executions)
pub fn with_secret_storage(self, storage: Arc<SecretStorage>) -> Self
pub fn with_python_manager(self, manager: Arc<PythonManager>) -> Self
pub fn ensure_secret_storage(&mut self, storage: &Storage)
Sourcepub fn set(&mut self, key: &str, value: Value)
pub fn set(&mut self, key: &str, value: Value)
Set data directly (recommended, key must include namespace)
Sourcepub fn get(&self, key: &str) -> Option<&Value>
pub fn get(&self, key: &str) -> Option<&Value>
Get data directly (recommended, key must include namespace)
Sourcepub fn set_var(&mut self, name: &str, value: Value)
pub fn set_var(&mut self, name: &str, value: Value)
Set variable (convenience method, automatically adds var. prefix)
Sourcepub fn get_var(&self, name: &str) -> Option<&Value>
pub fn get_var(&self, name: &str) -> Option<&Value>
Get variable (convenience method, automatically adds var. prefix)
Sourcepub fn set_node(&mut self, id: &str, output: Value)
pub fn set_node(&mut self, id: &str, output: Value)
Set node output (convenience method, automatically adds node. prefix)
Sourcepub fn get_node(&self, id: &str) -> Option<&Value>
pub fn get_node(&self, id: &str) -> Option<&Value>
Get node output (convenience method, automatically adds node. prefix)
pub fn interpolate_value(&self, value: &Value) -> Value
fn resolve_path(&self, path: &str) -> Option<Value>
Navigate nested fields in Value object
Trait Implementations§
Source§impl Clone for ExecutionContext
impl Clone for ExecutionContext
Source§fn clone(&self) -> ExecutionContext
fn clone(&self) -> ExecutionContext
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for ExecutionContext
impl Debug for ExecutionContext
Source§impl<'de> Deserialize<'de> for ExecutionContext
impl<'de> Deserialize<'de> for ExecutionContext
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 Serialize for ExecutionContext
impl Serialize for ExecutionContext
Source§impl TS for ExecutionContext
impl TS for ExecutionContext
Source§type WithoutGenerics = ExecutionContext
type WithoutGenerics = ExecutionContext
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 = ExecutionContext
type OptionInnerType = ExecutionContext
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.
§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 = ".."] attributes§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 ExecutionContext
impl !RefUnwindSafe for ExecutionContext
impl Send for ExecutionContext
impl Sync for ExecutionContext
impl Unpin for ExecutionContext
impl !UnwindSafe for ExecutionContext
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