Skip to main content

KernelConfig

Struct KernelConfig 

Source
pub struct KernelConfig {
    pub keypair: Keypair,
    pub ca_public_keys: Vec<PublicKey>,
    pub max_delegation_depth: u32,
    pub policy_hash: String,
    pub allow_sampling: bool,
    pub allow_sampling_tool_use: bool,
    pub allow_elicitation: bool,
    pub max_stream_duration_secs: u64,
    pub max_stream_total_bytes: u64,
    pub require_web3_evidence: bool,
    pub checkpoint_batch_size: u64,
    pub retention_config: Option<RetentionConfig>,
}
Expand description

Configuration for the Chio Runtime Kernel.

Fields§

§keypair: Keypair

Ed25519 keypair for signing receipts and issuing capabilities.

§ca_public_keys: Vec<PublicKey>

Public keys of trusted Capability Authorities.

§max_delegation_depth: u32

Maximum allowed delegation depth.

§policy_hash: String

SHA-256 hash of the active policy (embedded in receipts).

§allow_sampling: bool

Whether nested sampling requests are allowed at all.

§allow_sampling_tool_use: bool

Whether sampling requests may include tool-use affordances.

§allow_elicitation: bool

Whether nested elicitation requests are allowed.

§max_stream_duration_secs: u64

Maximum total wall-clock duration permitted for one streamed tool result.

§max_stream_total_bytes: u64

Maximum total canonical payload size permitted for one streamed tool result.

§require_web3_evidence: bool

Whether durable receipts and kernel-signed checkpoints are mandatory prerequisites for this deployment.

§checkpoint_batch_size: u64

Number of receipts between Merkle checkpoint snapshots. Default: 100.

Set to 0 to disable automatic checkpointing for deployments that do not require web3 evidence.

§retention_config: Option<RetentionConfig>

Optional receipt retention configuration.

When None (default), retention is disabled and receipts accumulate indefinitely. When Some(config), the kernel will archive receipts that exceed the time or size threshold.

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> 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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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<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