systemprompt 0.6.1

Self-hosted AI governance infrastructure. The Rust library behind systemprompt.io: MCP-native tool-call governance, 6-tier RBAC, secret detection, full audit trails, SIEM-ready events. Provider-agnostic across Anthropic, OpenAI, Gemini, and local models. PostgreSQL, air-gap capable, BSL-1.1.
Documentation
//! Minimal `Extension` implementation showing the compile-time plugin model.
//!
//! Run with: `cargo run -p systemprompt --example extension --features core`

use systemprompt::extension::ExtensionContext;
use systemprompt::prelude::{Extension, ExtensionMetadata, ExtensionRouter, SchemaDefinition};

#[derive(Default)]
struct DemoExtension;

impl Extension for DemoExtension {
    fn metadata(&self) -> ExtensionMetadata {
        ExtensionMetadata {
            id: "demo-extension",
            name: "Demo Extension",
            version: env!("CARGO_PKG_VERSION"),
        }
    }

    fn schemas(&self) -> Vec<SchemaDefinition> {
        vec![SchemaDefinition::inline(
            "demo_extension_state",
            "CREATE TABLE IF NOT EXISTS demo_extension_state (id TEXT PRIMARY KEY)",
        )]
    }

    fn router(&self, _ctx: &dyn ExtensionContext) -> Option<ExtensionRouter> {
        None
    }
}

fn main() {
    tracing_subscriber::fmt::init();
    let ext = DemoExtension;
    let meta = ext.metadata();
    tracing::info!(
        id = meta.id,
        name = meta.name,
        version = meta.version,
        schemas = ext.schemas().len(),
        "registered demo extension"
    );
}