Skip to main content

Snubber Core C ABI wrapped in ctypes for Python adapters

Project description

Snubber Logo

Snubber Architecture Diagram

Catch the shock. Stop AI agents from burning tokens on infinite loops.

MIT License Rust Edition 2024 no_std compatible Build Status


Snubber: Two Products, One Safety Layer


What Is Snubber?

Snubber is the runtime safety layer for autonomous agents. It detects and blocks tool‑call loops before they burn tokens or crash your infrastructure. It works in any harness, any language, in under 70 microseconds.

We ship two products that serve different audiences:


Product 1: Snubber Core

The Engine

The Snubber Core is a C ABI library written in Rust (no_std). It does exactly one thing: it takes a tool call, checks it against a sliding window of recent calls, and returns a decision — ALLOW, WARN, BLOCK_RETRY, or BLOCK_HALT.

Key properties:

  • <2µs overhead – zero allocations in the hot path
  • <200KB binary – no runtime dependencies
  • C ABI – embeds anywhere C runs (Python, Node.js, Go, Rust, C++)

What it does:

  • Semantic loop detection (ignore_args: true) – catches the same tool with different arguments
  • Error‑aware counting (count_mode: ErrorsOnly) – ignores legitimate polling
  • Circuit breaker – per‑tool cooldown prevents retry storms
  • Output validation – regex + JSON schema on tool outputs

Who it’s for:

  • Harness developers (LangChain, CrewAI, AutoGen maintainers)
  • Systems engineers embedding safety in custom agents
  • Rust developers building agent frameworks

Distribution:

  • Crates.io: cargo add snubber
  • GitHub: snubber-rs/snubber
  • Pre‑built binaries: libsnubber.so, libsnubber.dylib, snubber.dll

Product 2: Snubber Adapters + Reference Harness

The Drop‑In Safety Layer

For developers who don’t want to build from scratch, Snubber provides ready‑to‑use adapters that wrap the core into your existing agent harness. One line of code, instant safety.

Available adapters:

  • LangChainpip install snubber-langchain
  • CrewAIpip install snubber-crewai
  • AutoGenpip install snubber-autogen
  • LangGraphpip install snubber-langgraph
  • Node.js (coming soon)npm install @snubber/langchain

Also included:

  • Snubber Harness – a complete, safety‑first Rust ReAct agent harness. It’s open‑source and serves as a reference implementation, showcasing how to build a harness with Snubber embedded as a first‑class primitive.

Who it’s for:

  • Python developers using LangChain, CrewAI, AutoGen, or LangGraph
  • Teams that want to drop safety into their existing codebase without rewriting
  • Early adopters who want to see Snubber in action before committing

Distribution:

  • PyPI: pip install snubber-*
  • npm: npm install @snubber/*
  • Docker: docker run snubber/harness

How They Work Together

┌─────────────────────────────────────────────────────────────┐
│                      YOUR APPLICATION                       │
│  ┌─────────────────────────────────────────────────────┐    │
│  │   LangChain / CrewAI / AutoGen / LangGraph         │    │
│  └─────────────────────┬───────────────────────────────┘    │
│                        │                                     │
│  ┌─────────────────────▼───────────────────────────────┐    │
│  │   Snubber Adapter (Python / JS / Go)                │    │
│  │   – Calls the C ABI core                            │    │
│  │   – Intercepts tool calls                           │    │
│  │   – Injects SYSTEM INTERCEPT messages               │    │
│  └─────────────────────┬───────────────────────────────┘    │
│                        │                                     │
│  ┌─────────────────────▼───────────────────────────────┐    │
│  │   Snubber Core (libsnubber.so)                      │    │
│  │   – Sliding window                                  │    │
│  │   – Semantic detection                              │    │
│  │   – Circuit breaker                                 │    │
│  └─────────────────────────────────────────────────────┘    │
└─────────────────────────────────────────────────────────────┘

The Value Proposition

User Problem Snubber Solution
Python developer LangChain loop detection is experimental pip install snubber-langchain – instant safety
Rust developer Need embeddable loop detection cargo add snubber – <2µs, zero allocations
Enterprise team 429 crashes, token waste Snubber blocked loops in 4 harnesses, saved 100% of tokens
Harness maintainer Want to add safety to your framework Snubber Core – C ABI, embeddable anywhere

Summary

Product What It Is Who It’s For Get It
Snubber Core C ABI library (Rust no_std) Framework devs, systems engineers cargo add snubber
Snubber Adapters Drop‑in wrappers for LangChain, CrewAI, AutoGen, LangGraph Python agent developers pip install snubber-*
Snubber Harness Reference Rust ReAct agent harness Rust developers, early adopters cargo install snubber-harness

License

MIT — use it, fork it, ship it. See LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

snubber_core-0.1.1.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

snubber_core-0.1.1-cp314-cp314-macosx_26_0_arm64.whl (344.3 kB view details)

Uploaded CPython 3.14macOS 26.0+ ARM64

File details

Details for the file snubber_core-0.1.1.tar.gz.

File metadata

  • Download URL: snubber_core-0.1.1.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.6

File hashes

Hashes for snubber_core-0.1.1.tar.gz
Algorithm Hash digest
SHA256 550c3f9443bdaea15cbe3d49ae038a7df7d193e52bed14de9317790e33b9e7c9
MD5 7ee488a94942d46d5efab1d6b69508d9
BLAKE2b-256 02fdb59cc79b10e583625db850f7fab723fb975defcc1351bac3b5121b8b70e3

See more details on using hashes here.

File details

Details for the file snubber_core-0.1.1-cp314-cp314-macosx_26_0_arm64.whl.

File metadata

File hashes

Hashes for snubber_core-0.1.1-cp314-cp314-macosx_26_0_arm64.whl
Algorithm Hash digest
SHA256 324b38ed6ce9c921c9b7d47cd4e0dff41b132d9e88e7d2a278de1794b80144a1
MD5 096ac6c0e2b472af20e1e2037183c8ab
BLAKE2b-256 7a3143bbaa63018578eead68a011128c251138acd510b1cdb2fa5144b4f175b6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page