Skip to main content

ChildWorkflowContext

Struct ChildWorkflowContext 

Source
#[non_exhaustive]
pub struct ChildWorkflowContext { pub run_ctx: Arc<dyn RunContext>, pub extra_plugin_dirs: Vec<String>, pub workflow_run_id: String, pub model: Option<String>, pub exec_config: WorkflowExecConfig, pub inputs: HashMap<String, String>, pub event_sinks: Arc<[Arc<dyn EventSink>]>, }
Expand description

Subset of ExecutionState exposed to ChildWorkflowRunner implementations.

The full ExecutionState carries the engine’s mutable runtime — registries, accumulators, schema resolver, position pointer, cancellation token — none of which a harness needs to spawn a child workflow run. Passing it across the trait boundary makes every ExecutionState field rename or restructuring a breaking change for every ChildWorkflowRunner implementor.

ChildWorkflowContext is the narrow, stable surface: every field listed here is something the bridge actually reads when constructing the child run. Build via ExecutionState::child_workflow_context.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§run_ctx: Arc<dyn RunContext>§extra_plugin_dirs: Vec<String>§workflow_run_id: String§model: Option<String>§exec_config: WorkflowExecConfig§inputs: HashMap<String, String>§event_sinks: Arc<[Arc<dyn EventSink>]>

Implementations§

Source§

impl ChildWorkflowContext

Source

pub fn new( run_ctx: Arc<dyn RunContext>, extra_plugin_dirs: Vec<String>, workflow_run_id: String, model: Option<String>, exec_config: WorkflowExecConfig, inputs: HashMap<String, String>, event_sinks: Arc<[Arc<dyn EventSink>]>, ) -> Self

Examples found in repository?
examples/logging_child_runner.rs (lines 93-101)
90fn main() {
91    let runner = LoggingChildRunner;
92    let ctx = Arc::new(StubCtx(std::env::temp_dir()));
93    let parent_ctx = ChildWorkflowContext::new(
94        Arc::clone(&ctx) as Arc<dyn RunContext>,
95        vec![],
96        "parent-run-001".into(),
97        None,
98        WorkflowExecConfig::default(),
99        HashMap::new(),
100        Arc::from(vec![]),
101    );
102    let params = ChildWorkflowInput {
103        inputs: HashMap::new(),
104        iteration: 0,
105        as_identity: None,
106        depth: 1,
107        parent_step_id: None,
108        cancellation: CancellationToken::new(),
109    };
110    let result = runner
111        .execute_child("child-workflow", &parent_ctx, params)
112        .expect("execute_child failed");
113    println!("succeeded: {}", result.all_succeeded);
114}

Trait Implementations§

Source§

impl Clone for ChildWorkflowContext

Source§

fn clone(&self) -> ChildWorkflowContext

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more