Metadata-Version: 2.4
Name: brimley
Version: 0.9.0
Summary: A lightweight, file-based function execution engine.
License-Expression: Apache-2.0
License-File: LICENSE
Keywords: mcp,tools,function-execution,ai-tooling,llm
Author: Bill Spratley
Author-email: billspratley@gmail.com
Requires-Python: >=3.10,<4.0
Classifier: Development Status :: 3 - Alpha
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Provides-Extra: fastmcp
Provides-Extra: security
Requires-Dist: fastmcp (>=3.1.1,<4.0.0) ; extra == "fastmcp"
Requires-Dist: httpx (>=0.27.0)
Requires-Dist: jinja2 (>=3.1)
Requires-Dist: llm-guard (>=0.3.0) ; extra == "security"
Requires-Dist: loguru (>=0.7.2)
Requires-Dist: prompt_toolkit (>=3.0)
Requires-Dist: pydantic (>=2.0)
Requires-Dist: pydantic-settings (>=2.0)
Requires-Dist: pyyaml (>=6.0)
Requires-Dist: rich (>=13.0)
Requires-Dist: sqlalchemy (>=2.0.46)
Requires-Dist: typer (>=0.12)
Project-URL: Changelog, https://github.com/farkelheizen/brimley/blob/main/CHANGELOG.md
Project-URL: Homepage, https://github.com/farkelheizen/brimley
Project-URL: Issues, https://github.com/farkelheizen/brimley/issues
Project-URL: Source, https://github.com/farkelheizen/brimley
Description-Content-Type: text/markdown

# Brimley

Application server for function-based AI tooling, focused on faster iteration loops.

> Status: Brimley is not yet ready for production use. It is aimed at improving the MCP development workflow and is still under active development.

Brimley is an application server that discovers, validates, and executes function-based AI tooling. It owns its own process and event loop, providing three operating modes: an interactive **REPL** for development, a headless **MCP server** for production, and a one-shot **invoke** mode for scripting and CI. The core focus is reducing the change/test loop during MCP tool development: change code → reload → re-test.

## Design goals

- **Faster iteration loop:** author tools in `.py`, `.sql`, `.md`, and `.yaml` files and execute them immediately, without a full redeploy cycle.
- **Safer change workflow:** discovery is AST-first for Python (no import-time execution during scan), with diagnostics instead of immediate process termination.
- **Live runtime ergonomics:** use a thin REPL client attached to a daemon-owned runtime, with optional watch-mode reload.
- **MCP integration path:** expose selected functions as MCP tools via FastMCP when needed.
- **Declarative HTTP and CLI integration (0.7+):** wrap external APIs and shell commands as first-class Brimley functions using YAML — no boilerplate code required.
- **Managed dependency injection (0.8+):** `@provider`, `Depends()`, `@on_startup`/`@on_shutdown` hooks, and `BrimleyContainer` with singleton and request scopes — shared resources with proper lifecycle semantics.
- **Application server ownership (0.9+):** Brimley owns its process and event loop. No embedding inside other Python applications — integrate externally via MCP.
- **Operations clarity:** built-in reload diagnostics, runtime error surfacing, and explicit daemon lifecycle controls.

## Architectural approach

Brimley is an **application server** — it always owns its process and event loop. It separates **tool authoring/execution semantics** from **MCP transport hosting**:

- Brimley handles discovery, schemas, argument resolution, execution, reload policy, and diagnostics.
- FastMCP (optional) handles MCP server transport.

Keeping function logic separate from transport makes it reusable across all three operating modes:

| Mode | Command | Purpose |
|---|---|---|
| **REPL** | `brimley repl` | Interactive development with hot-reload, admin commands, and optional embedded MCP. |
| **MCP Server** | `brimley mcp-serve` | Headless production mode — serves tools over SSE/stdio. |
| **Invoke** | `brimley invoke <name>` | One-shot function execution for scripting, CI, and debugging. No background services are started. |

> **Note:** Embedding Brimley as a library inside another Python application (e.g., importing into FastAPI) is not supported. External applications integrate with Brimley via MCP as a sidecar process.

## Quick Start

### 1) Install

```bash
poetry install
```

Optional MCP support:

```bash
poetry install -E fastmcp
```

### 2) Add `brimley.yaml`

```yaml
brimley:
  app_name: "Brimley App"

config:
  support_email: "support@example.com"

state:
  request_count: 0

databases:
  default:
    connector: sqlite
    url: "sqlite:///./data.db"

auto_reload:
  enabled: true

mcp:
  host: 127.0.0.1
  port: 8000
```

### 3) Add a Python function (`calc.py`)

```python
from brimley import function

@function(mcpType="tool")
def calculate_tax(amount: float, rate: float = 8.25) -> float:
    return round(amount * (rate / 100.0), 2)
```

### 4) Run REPL

```bash
PYTHONPATH=src poetry run brimley repl --root .
```

### 5) Invoke once from CLI

```bash
PYTHONPATH=src poetry run brimley invoke calculate_tax --root . --input "{amount: 100, rate: 8.25}"
```

## Core CLI Commands

- `brimley repl --root . [--mcp|--no-mcp] [--watch|--no-watch]`
- `brimley repl --root . --shutdown-daemon`
- `brimley mcp-serve --root . [--watch|--no-watch] [--host HOST] [--port PORT]`
- `brimley invoke <function_name> --root . --input "{...}"`
- `brimley build --root . [--output PATH]`
- `brimley validate --root . [--format text|json] [--fail-on warning|error] [--output PATH]`
- `brimley schema-convert --in schema.yaml --out fieldspec.yaml [--allow-lossy]`

## MCP Integration

Mark a function as an MCP tool:

- Python: `@function(mcpType="tool")`
- SQL/Template/API/CLI frontmatter: 

```yaml
mcp:
  type: tool
```

API and CLI functions defined in `.yaml` files are first-class MCP tools. See [API Functions](docs/brimley-api-functions.md) and [CLI Functions](docs/brimley-cli-functions.md).

Then serve tools with:

```bash
PYTHONPATH=src poetry run brimley mcp-serve --root .
```

## Runtime Model (0.9 architecture baseline)

Brimley is an application server that owns its process and event loop. It does not support being embedded as a library inside another Python application.

- **REPL mode:** Thin client attached to a daemon-owned runtime. Daemon owns state, watcher lifecycle, and optional embedded MCP hosting.
- **MCP server mode:** Headless process serving tools over SSE/stdio via FastMCP.
- **Invoke mode:** One-shot function execution — no daemon, no background services, no task scheduler.
- `/detach` leaves daemon running; `/quit` (or `--shutdown-daemon`) terminates daemon session.
- Reload is partitioned and diagnostics-driven; schema-shape tool changes require MCP client reconnect.

## Documentation Map

- [High-level design](docs/brimley-high-level-design.md)
- [CLI & REPL harness](docs/brimley-cli-and-repl-harness.md)
- [Configuration](docs/brimley-configuration.md)
- [Discovery & loader spec](docs/brimley-discovery-and-loader-specification.md)
- [MCP integration](docs/brimley-model-context-protocol-integration.md)
- [API Functions](docs/brimley-api-functions.md) *(0.7+)*
- [CLI Functions](docs/brimley-cli-functions.md) *(0.7+)*
- [Secrets](docs/brimley-secrets.md) *(0.7+)*
- [Security — Threat Model](docs/security/brimley-0.7-threat-model.md) *(0.7+)*
- [Dependency Injection & Managed Objects](docs/roadmap/brimley-0.8-dependency-injection-and-managed-objects.md) *(0.8+)*
- [Application Server Boundary & Managed Tasks](docs/roadmap/brimley-0.9-application-server-and-managed-tasks.md) *(0.9+)*

