Skip to main content

camel_component_api/
lib.rs

1//! camel-component-api — traits and types for building Camel components.
2//!
3//! Provides the core abstractions (`Component`, `Endpoint`, `Consumer`, `Producer`)
4//! that every rust-camel component implements. Also re-exports commonly-used types
5//! from `camel-api` and `camel-endpoint` for component convenience.
6//!
7//! Main types: `Component`, `Endpoint`, `Consumer`, `ProducerContext`, `ExchangeEnvelope`, `ComponentBundle`, `PollingConsumer`.
8//! Main modules: `component`, `endpoint`, `consumer`, `producer`, `registrar`.
9
10pub mod bundle;
11pub mod component;
12pub mod component_context;
13pub mod consumer;
14pub mod endpoint;
15pub mod producer;
16pub mod registrar;
17
18pub use bundle::ComponentBundle;
19pub use component::Component;
20pub use component_context::{ComponentContext, NoOpComponentContext};
21pub use consumer::{
22    ConcurrencyModel, Consumer, ConsumerContext, ExchangeEnvelope, SecurityContext,
23};
24pub use endpoint::{Endpoint, PollingConsumer};
25pub use producer::ProducerContext;
26pub use registrar::ComponentRegistrar;
27
28// Re-export camel-api types for component convenience
29pub use camel_api::{
30    AsyncHealthCheck, Body, BodyType, BoxProcessor, CamelError, CheckResult, Exchange,
31    HealthStatus, Message, RouteAction, RouteStatus, RuntimeCommand, RuntimeCommandBus,
32    RuntimeCommandResult, RuntimeHandle, RuntimeQuery, RuntimeQueryBus, RuntimeQueryResult,
33    StreamBody, StreamMetadata, Value,
34};
35
36// Re-export camel-endpoint types for component convenience
37pub use camel_endpoint::{UriComponents, UriConfig, parse_uri};
38// Expose a `uri` sub-module so crates using `#[uri_config(crate = "camel_component_api")]`
39// can resolve `camel_component_api::uri::parse_bool_param` etc.
40pub mod uri {
41    /// Parse a boolean URI parameter value (case-insensitive).
42    /// Accepts: "true"/"1"/"yes" → true; "false"/"0"/"no" → false.
43    pub fn parse_bool_param(s: &str) -> Result<bool, String> {
44        match s.to_lowercase().as_str() {
45            "true" | "1" | "yes" => Ok(true),
46            "false" | "0" | "no" => Ok(false),
47            _ => Err(format!("invalid boolean value: '{}'", s)),
48        }
49    }
50}