blazen 0.1.152

Blazen - A Rust-native AI workflow engine with event-driven orchestration
Documentation
//! # `Blazen`
//!
//! A high-performance, event-driven workflow framework for Rust.
//!
//! `Blazen` models computation as a directed graph of *steps* connected by
//! typed *events*. The runtime maintains an internal event queue, routing
//! events to matching step handlers and spawning them concurrently until a
//! [`StopEvent`] terminates the workflow.
//!
//! ## Quick start
//!
//! ```rust,ignore
//! use blazen::prelude::*;
//!
//! #[derive(Debug, Clone, Serialize, Deserialize, Event)]
//! struct GreetEvent { name: String }
//!
//! #[step]
//! async fn greet(event: StartEvent, _ctx: Context) -> Result<StopEvent, WorkflowError> {
//!     let name = event.data["name"].as_str().unwrap_or("World");
//!     Ok(StopEvent { result: serde_json::json!({ "greeting": format!("Hello, {}!", name) }) })
//! }
//!
//! #[tokio::main]
//! async fn main() -> anyhow::Result<()> {
//!     let workflow = WorkflowBuilder::new("greeter")
//!         .step(greet_registration())
//!         .build()?;
//!     let result = workflow.run(serde_json::json!({ "name": "Zach" })).await?.result().await?.event;
//!     println!("{}", result.to_json());
//!     Ok(())
//! }
//! ```
//!
//! ## Feature flags
//!
//! | Feature | Description |
//! |---------|-------------|
//! | `llm` (default) | LLM provider integrations |
//! | `openai` | OpenAI + OpenAI-compatible providers |
//! | `anthropic` | Anthropic Claude provider |
//! | `persist` | Checkpoint storage via `redb` |
//! | `telemetry` | Observability, tracing spans, and workflow history |
//! | `all` | Everything |

// ---------------------------------------------------------------------------
// Core re-exports
// ---------------------------------------------------------------------------

// Events: traits and built-in types.
pub use blazen_events::{
    AnyEvent, DynamicEvent, Event, EventEnvelope, InputRequestEvent, InputResponseEvent,
    StartEvent, StopEvent, intern_event_type, register_event_deserializer, try_deserialize_event,
};

// Macros: derive and attribute macros.
pub use blazen_macros::{Event, step};

// Core: workflow engine types.
pub use blazen_core::{
    BytesWrapper, Context, InputHandlerFn, Result, StateValue, StepFn, StepOutput,
    StepRegistration, Workflow, WorkflowBuilder, WorkflowError, WorkflowHandler,
};

// Serde: needed by derive(Event) expansion and examples.
pub use serde;
pub use serde_json;

// ---------------------------------------------------------------------------
// Optional modules
// ---------------------------------------------------------------------------

/// LLM provider integrations (requires `llm` feature).
#[cfg(feature = "llm")]
pub mod llm {
    pub use blazen_llm::*;
}

/// Checkpoint persistence (requires `persist` feature).
#[cfg(feature = "persist")]
pub mod persist {
    pub use blazen_persist::*;
}

// Top-level re-exports of key persist types for convenience.
#[cfg(feature = "persist")]
pub use blazen_persist::{CheckpointStore, WorkflowCheckpoint};

/// Multi-workflow pipeline orchestration (requires `pipeline` feature).
#[cfg(feature = "pipeline")]
pub mod pipeline {
    pub use blazen_pipeline::*;
}

/// Prompt template management (requires `prompts` feature).
#[cfg(feature = "prompts")]
pub mod prompts {
    pub use blazen_prompts::*;
}

/// Observability and telemetry (requires `telemetry` feature).
#[cfg(feature = "telemetry")]
pub use blazen_telemetry as telemetry;

// ---------------------------------------------------------------------------
// Prelude
// ---------------------------------------------------------------------------

/// Convenient wildcard import for common types and traits.
///
/// ```rust,ignore
/// use blazen::prelude::*;
/// ```
pub mod prelude {
    // Event traits and built-in events.
    pub use blazen_events::{
        AnyEvent, Event, InputRequestEvent, InputResponseEvent, StartEvent, StopEvent,
    };

    // Derive and attribute macros.
    pub use blazen_macros::{Event, step};

    // Core workflow types.
    pub use blazen_core::{
        Context, InputHandlerFn, Result, StateValue, StepOutput, StepRegistration, Workflow,
        WorkflowBuilder, WorkflowError, WorkflowHandler,
    };

    // Serde derives (needed for #[derive(Event)] to work).
    pub use serde::{Deserialize, Serialize};

    // JSON value construction.
    pub use serde_json;
}