| English | 中文 |
|---|---|
| 📗 English Docs · Pick path · Getting Started · Architecture · Env Reference · Contributing | 📘 中文文档 · 选择路径 · 入门指南 · 架构说明 · 环境变量 · 贡献指南 |
Default (recommended): pip install skilllite → OS-level sandbox + MCP in Cursor, Claude Desktop, OpenCode, or your own agent. You do not need the desktop app or the full SkillLite agent loop to get the core value.
One repository ships several entry points. Each row links to the English hub; 中文 is on that page if you prefer it.
| Goal | First stop |
|---|---|
| Sandbox & MCP (recommended) — secure skills in an existing IDE or agent | Path 2 — Sandbox & MCP |
Full stack — skilllite CLI, Python SDK, evolution, optional Swarm |
Path 3 — Full stack |
| Desktop GUI (optional) — SkillLite Assistant: local chat, evolution UI, IDE layout | Path 1 — Desktop |
A lightweight secure Self-evolution engine built in Rust, featuring a built-in native system-level sandbox, zero dependencies, and fully local execution.
We built the most secure skill sandbox in the ecosystem (20/20 security score). Then we realized: the real value isn't just safe execution — it's safe evolution.
┌──────────────────────────────────────────────────────────────┐
│ Self-Evolving Engine(自进化引擎) │
│ │
│ Immutable Core (compiled into binary, never self-modifies) │
│ ├─ Agent loop, LLM orchestration, tool execution │
│ ├─ Config, metadata, path validation │
│ └─ Evolution engine: feedback → reflect → evolve → verify │
│ │
│ Evolvable Data (local files, auto-improves over use) │
│ ├─ Prompts — system / planning / execution prompts │
│ ├─ Memory — task patterns, tool effects, failure lessons │
│ └─ Skills — auto-generated skills from repeated patterns │
│ ▼ │
│ all evolved artifacts must pass ▼ │
├──────────────────────────────────────────────────────────────┤
│ Security Sandbox(安全沙箱) │
│ │
│ Full-chain defense across the entire skill lifecycle: │
│ ├─ Install-time: static scan + LLM analysis + supply-chain │
│ ├─ Pre-execution: two-phase confirm + integrity check │
│ └─ Runtime: OS-native isolation (Seatbelt / bwrap / seccomp)│
│ ├─ Process-exec whitelist, FS / network / IPC lockdown │
│ └─ Resource limits (CPU / mem / fork / fsize) │
└──────────────────────────────────────────────────────────────┘
Why two layers, not one? Evolution without safety is reckless — evolved skills could exfiltrate data or consume unbounded resources. Safety without evolution is static — the Agent never improves. SkillLite welds them together: the evolution engine produces new prompts, memory, and skills; the sandbox layer ensures every evolved artifact passes L3 security scanning + OS-level isolation before execution. Evolution is auditable, rollbackable, and never modifies the core binary.
| skilllite (Evolution) | skilllite-sandbox (lightweight) | |
|---|---|---|
| Binary size | ~6.2 MB | ~3.6 MB |
| Startup RSS | ~4 MB | ~3.9 MB |
| Agent mode RSS (chat / agent-rpc) | ~11 MB | — |
| Sandbox execution RSS | ~11 MB | ~10 MB |
Measured on macOS ARM64, release build. Sandbox RSS is dominated by the embedded Python process.
Use the full stack or just the sandbox:
skilllitegives you evolution + agent + sandbox.skilllite-sandboxis a standalone binary (or MCP server) that any agent framework can adopt — no need to buy into the full SkillLite stack.
Many products now advertise self-adapting or self-evolving agents. SkillLite’s stance is narrower and easier to keep accurate over time: prompts, memory, and skills may evolve, but they stay behind the same immutable core and full-chain sandbox as everything else — install-time scan, pre-execution gates, OS-level isolation, and governance (thresholds, backlog, rollback). Evolved artifacts are not exempt: they pass the same L3 checks + sandbox as manually installed skills.
Most sandbox solutions only provide runtime isolation. SkillLite defends across the entire skill lifecycle — three layers in a single binary:
┌─────────────────────────────────────────────────┐
│ Layer 1 — Install-time Scanning │
│ ├─ Static rule scan (regex pattern matching) │
│ ├─ LLM-assisted analysis (suspicious → confirm) │
│ └─ Supply-chain audit (PyPI / OSV vuln DB) │
├─────────────────────────────────────────────────┤
│ Layer 2 — Pre-execution Authorization │
│ ├─ Two-phase confirm (scan → user OK → run) │
│ └─ Integrity check (hash tamper detection) │
├─────────────────────────────────────────────────┤
│ Layer 3 — Runtime Sandbox │
│ ├─ OS-native isolation (Seatbelt / bwrap) │
│ ├─ Process-exec whitelist (interpreter only) │
│ ├─ Filesystem / network / IPC lockdown │
│ └─ Resource limits (rlimit CPU/mem/fork/fsize) │
└─────────────────────────────────────────────────┘
| Capability | SkillLite | E2B | Docker | Claude SRT | Pyodide |
|---|---|---|---|---|---|
| Install-time scanning | ✅ | — | — | — | — |
| Static code analysis | ✅ | — | — | — | — |
| Supply-chain audit | ✅ | — | — | — | — |
| Process-exec whitelist | ✅ | — | — | — | — |
| IPC / kernel lockdown | ✅ | — | — | — | — |
| Filesystem isolation | ✅ | partial | partial | partial | ✅ |
| Network isolation | ✅ | ✅ | — | ✅ | ✅ |
| Resource limits | ✅ | ✅ | partial | partial | partial |
| Runtime sandbox | ✅ | ✅ | ✅ | ✅ | ✅ |
| Zero-dependency install | ✅ | — | — | — | — |
| Offline capable | ✅ | — | partial | ✅ | ✅ |
| Platform | Blocked | Score |
|---|---|---|
| SkillLite (Level 3) | 20/20 | 100% |
| Pyodide | 7/20 | 35% |
| Claude SRT | 7.5/20 | 37.5% |
| Docker (default) | 2/20 | 10% |
Full 20-item security test breakdown
| Test Item | SkillLite | Docker | Pyodide | Claude SRT |
|---|---|---|---|---|
| File System | ||||
| Read /etc/passwd | ✅ Blocked | ❌ Allowed | ✅ Blocked | ❌ Allowed |
| Read SSH private key | ✅ Blocked | ✅ Blocked | ✅ Blocked | ✅ Blocked |
| Write to /tmp dir | ✅ Blocked | ❌ Allowed | ❌ Allowed | ✅ Blocked |
| Directory traversal | ✅ Blocked | ❌ Allowed | ✅ Blocked | ❌ Allowed |
| List root directory | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
| Network | ||||
| Send HTTP request | ✅ Blocked | ❌ Allowed | ✅ Blocked | ✅ Blocked |
| DNS query | ✅ Blocked | ❌ Allowed | ❌ Allowed | ✅ Blocked |
| Listen port | ✅ Blocked | ❌ Allowed | ❌ Allowed | ✅ Blocked |
| Process | ||||
| Execute os.system() | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
| Execute subprocess | ✅ Blocked | ❌ Allowed | ✅ Blocked | ❌ Allowed |
| Enumerate processes | ✅ Blocked | ❌ Allowed | ❌ Allowed | ✅ Blocked |
| Send process signal | ✅ Blocked | ❌ Allowed | ✅ Blocked | |
| Resource Limits | ||||
| Memory bomb | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
| Fork bomb | ✅ Blocked | ❌ Allowed | ✅ Blocked | ❌ Allowed |
| CPU intensive compute | ✅ Blocked | ✅ Blocked | ❌ Allowed | ✅ Blocked |
| Code Injection | ||||
| Dynamic import os | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
| Use eval/exec | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
| Modify built-in funcs | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
| Information Leakage | ||||
| Read environment vars | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
| Get system info | ✅ Blocked | ❌ Allowed | ❌ Allowed | ❌ Allowed |
# Reproduce: run security comparison tests
cd benchmark && python3 security_vs.py| Dimension | SkillLite | Docker | Pyodide | SRT |
|---|---|---|---|---|
| Warm Start | 40 ms | 194 ms | 672 ms | 596 ms |
| Cold Start | 492 ms | 120s | ~5s | ~1s |
| Memory | ~10 MB | ~100 MB | ~50 MB | ~84 MB |
| Deployment | Single binary | Requires daemon | Requires Node.js | Requires installation |
3-5x faster execution, 10x lower memory footprint vs Docker/SRT.
Benchmarking standard: SkillLite avoids the MicroVM layer entirely for local code execution: no guest kernel, VM monitor, image, or sandbox service stack. Its focused no-Python sandbox launch benchmark runs at 111 ms avg / 113 ms P95 with ~1.14 MB child peak RSS. This is process RSS, not directly comparable to MicroVM VMM-overhead/PSS figures. Real Python skill execution is reported separately: ~40 ms warm, ~492 ms cold, and ~10 MB RSS.
Performance benchmark details & commands
The root benchmark/ results are primarily produced by Python scripts that exercise Python skill execution. For no-Python measurements, only the focused skilllite-sandbox launch-path microbenchmark is documented here to avoid mixing it with Python E2E results.
No-Python skilllite-sandbox launch-path data (/usr/bin/true, 200 iterations, macOS ARM64):
| Metric | Native Spawn | skilllite-sandbox |
Sandbox Overhead |
|---|---|---|---|
| Avg latency | 0.806 ms | 111.296 ms | +110.490 ms |
| P50 latency | 0.757 ms | 112.020 ms | +111.263 ms |
| P95 latency | 1.063 ms | 113.385 ms | +112.322 ms |
| Child peak RSS | 1.016 MB | 1.141 MB | +0.125 MB |
cd benchmark/
python benchmark_runner.py --compare-levels --compare-ipc -n 100 -c 10
# Cold start comparison
python benchmark_runner.py --cold-start --compare-ipc
# Full test: cold start + high concurrency
python benchmark_runner.py --cold-start --cold-iterations 20 --compare-levels --compare-ipc -o results.json
# Optional no-Python skilllite-sandbox launch-path microbenchmark
./run_benchmark.sh --core-onlySee benchmark/README.md for full documentation.
In one sentence: Other agent frameworks are smart but unsafe, or safe but static. SkillLite is both — an Agent that gets measurably better over time, with every evolved artifact security-constrained by an OS-native sandbox.
- vs Agent frameworks (AutoGen, CrewAI, LangGraph): They provide orchestration but no built-in evolution or sandbox. SkillLite evolves autonomously and executes safely.
- vs Sandbox tools (E2B, Docker, Claude SRT): They provide isolation but no intelligence layer. SkillLite adds a full agent loop + self-evolution on top.
- vs Evolution platforms (OpenClaw Foundry, EvoAgentX): They enable evolution but without security constraints on evolved artifacts. SkillLite enforces L3 scanning + OS sandbox on everything it evolves.
Claude/Anthropic's Claude Code Sandbox uses the same underlying sandbox tech (Seatbelt + bubblewrap). See Architecture Comparison for a detailed side-by-side analysis.
pip install skilllite
skilllite init # sandbox binary + skills/ + download skills
skilllite list # verify installationUse SkillLite as a sandbox + MCP server inside an agent you already run (Cursor, Claude Desktop, OpenCode, etc.):
pip install "skilllite[mcp]" # if your platform needs MCP extras
skilllite init
skilllite mcp # stdio MCP server for the IDEWire the host: skilllite init-cursor · skilllite init-opencode. Step-by-step: Path 2 — Sandbox & MCP · MCP tutorial.
Zero-config quick start (auto-detect LLM, setup skills, launch chat):
skilllite quickstartfrom skilllite import chat
result = chat("Calculate 15 * 27", skills_dir="skills")
print(result)Or use the CLI: skilllite chat
cp .env.example .env # Edit: BASE_URL, API_KEY, MODEL| File | Description |
|---|---|
| .env.example | Quick start template |
| .env.example.full | Full variable list |
| docs/en/ENV_REFERENCE.md | Complete reference |
Platform Support: macOS, Linux, and Windows (via WSL2 Bridge).
| Tutorial | Time | Description |
|---|---|---|
| 01. Basic Usage | 5 min | Simplest examples, one-line execution |
| 02. Skill Management | 10 min | Create and manage skills |
| 03. Agentic Loop | 15 min | Multi-turn conversations and tool calls |
| 04. LangChain Integration | 15 min | Integration with LangChain framework |
| 05. LlamaIndex Integration | 15 min | RAG + skill execution |
| 06. MCP Server | 10 min | Claude Desktop integration |
| 07. OpenCode Integration | 10 min | One-command OpenCode integration |
Repository: github.com/EXboys/evotown — evolution testing platform for evolution effect validation; any engine that can run under your harness and report into Evotown (HTTP ingest) works — SkillLite is a common option, not a requirement. A local clone for combined development may live at ./evotown/ (often gitignored in minimal checkouts).
Engine integration (draft): independent runners push results into Evotown over HTTP. Canonical docs on Evotown: ingest API v0.1 · OpenAPI. Mirror in this repo (SkillLite contributors): English · 中文 · OpenAPI.
from skilllite import run_skill
result = run_skill("./skills/calculator", '{"operation": "add", "a": 15, "b": 27}')
print(result["text"])skilllite add owner/repo # Add all skills from a GitHub repo
skilllite add owner/repo@skill-name # Add a specific skill by name
skilllite add ./local-path # Add from local directory
skilllite add ./downloaded-skill.zip # Add from a downloaded local ZIP package
skilllite import-openclaw-skills # Import from OpenClaw-style dirs (workspace/skills, ~/.openclaw/skills, …)
skilllite claw migrate --dry-run # OpenClaw → SkillLite: skills, SOUL/MEMORY Markdown, optional secrets
skilllite list # List all installed skills
skilllite remove <skill-name> # Remove an installed skillpip install langchain-skilllite # LangChain adapterfrom langchain_skilllite import SkillLiteToolkit
from langgraph.prebuilt import create_react_agent
tools = SkillLiteToolkit.from_directory(
"./skills",
sandbox_level=3, # 1=no sandbox, 2=sandbox only, 3=sandbox+scan
confirmation_callback=lambda report, sid: input("Continue? [y/N]: ").lower() == 'y'
)
agent = create_react_agent(ChatOpenAI(model="gpt-4"), tools)See 05. LlamaIndex Integration for LlamaIndex usage.
| Level | Description |
|---|---|
| 1 | No sandbox — direct execution |
| 2 | Sandbox isolation only |
| 3 | Sandbox + static security scan (requires confirmation for high-severity issues) |
| Provider | base_url |
|---|---|
| OpenAI | https://api.openai.com/v1 |
| DeepSeek | https://api.deepseek.com/v1 |
| Qwen | https://dashscope.aliyuncs.com/compatible-mode/v1 |
| Moonshot | https://api.moonshot.cn/v1 |
| Ollama (Local) | http://localhost:11434/v1 |
Each Skill is a directory with a SKILL.md:
my-skill/
├── SKILL.md # Skill metadata (required)
├── scripts/main.py # Entry script
├── references/ # Reference documents (optional)
└── assets/ # Resource files (optional)
SKILL.md example
---
name: my-skill
description: My custom Skill that does something useful.
license: MIT
compatibility: Requires Python 3.x with requests library, network access
metadata:
author: your-name
version: "1.0"
---
# My Skill
Detailed description of the Skill.
## Input Parameters
- `query`: Input query string (required)
## Output Format
Returns JSON result.Dependencies are declared in
compatibility(notrequirements.txt). Entry point is auto-detected (main.py>main.js>main.ts>main.sh).
SkillLite is a Cargo workspace of focused, composable crates. Each crate has a single responsibility and can be compiled independently.
skilllite/ Dependency Flow
├── Cargo.toml ────────────────────────────
├── skilllite/ (main binary) skilllite (CLI entry point)
│ ├── skilllite-commands
└── crates/ │ ├── skilllite-evolution ──┐
├── skilllite-core/ │ ├── skilllite-sandbox ────┤
├── skilllite-sandbox/ │ └── skilllite-agent (opt) │
├── skilllite-evolution/ ├── skilllite-agent │
├── skilllite-executor/ │ ├── skilllite-evolution │
├── skilllite-agent/ │ ├── skilllite-sandbox │
├── skilllite-commands/ │ └── skilllite-executor │
├── skilllite-swarm/ ├── skilllite-swarm │
├── skilllite-artifact/ ├── skilllite-artifact │
└── skilllite-assistant/ └───────────┬──────────────────┘
skilllite-core (foundation)
| Crate | Role | Layer |
|---|---|---|
| skilllite-core | Foundation — config, skill metadata, path validation, observability | Shared |
| skilllite-sandbox | Security Sandbox — OS-native isolation (Seatbelt / bwrap / seccomp), static scan, supply-chain audit, resource limits. Independently deliverable as skilllite-sandbox binary |
🔒 Sandbox |
| skilllite-evolution | Self-Evolving Engine — feedback collection → reflection → evolution → quality gate → audit. Drives prompt / memory / skill evolution | 🧬 Evolution |
| skilllite-executor | Session management — transcript logging, memory storage, vector search (opt) | Agent |
| skilllite-agent | LLM Agent loop — multi-turn chat, tool orchestration, planning | Agent |
| skilllite-commands | CLI command implementations — wires crates into skilllite binary |
CLI |
| skilllite-swarm | P2P mesh — mDNS discovery, peer routing, distributed task dispatch | Network |
| skilllite-artifact | Run-scoped artifact storage — local dir (agent default), optional HTTP server/client (skilllite artifact-serve when artifact_http is enabled) |
Storage / HTTP |
| skilllite-assistant | Desktop app — Tauri 2 + React, standalone GUI | App |
Two independently deliverable binaries:
skilllite(full: evolution + agent + sandbox) andskilllite-sandbox(lightweight: sandbox + MCP only, ~3.6 MB). The sandbox has zero dependency on the agent or evolution crates — other frameworks (LangChain, AutoGen, CrewAI, etc.) can embed it directly via CLI, MCP, or as a Rust crate.
- python-sdk (
pip install skilllite) — Thin bridge (~770 lines of Python underpython-sdk/skilllite/), zero runtime deps - langchain-skilllite (
pip install langchain-skilllite) — LangChain / LangGraph adapter
CLI Commands
| Command | Description |
|---|---|
skilllite init |
Initialize project (skills/ + download skills + dependencies + audit) |
skilllite quickstart |
Zero-config: detect LLM, setup skills, launch chat |
skilllite chat |
Interactive agent chat (or --message for single-shot) |
skilllite add owner/repo |
Add skills from GitHub, a local folder, or a local ZIP package |
skilllite import-openclaw-skills |
Copy skills from OpenClaw-style paths into skills/ (see --dry-run, --skill-conflict) |
skilllite claw migrate |
Migrate OpenClaw-style skills, persona/memory Markdown, and optional allowlisted .env keys (alias: skilllite migrate openclaw) |
skilllite remove <name> |
Remove an installed skill |
skilllite list |
List installed skills |
skilllite show <name> |
Show skill details |
skilllite run <dir> '<json>' |
Execute a skill directly |
skilllite scan <dir> |
Scan skill for security issues |
skilllite evolution status |
View evolution metrics and history |
skilllite evolution backlog |
Query backlog proposals (status/risk/ROI/acceptance_status) |
skilllite evolution run |
Force-trigger evolution cycle |
skilllite mcp |
Start MCP server (Cursor/Claude Desktop) |
skilllite serve |
Start IPC daemon (stdio JSON-RPC) |
skilllite artifact-serve |
Run-scoped artifact HTTP server (bind requires SKILLLITE_ARTIFACT_SERVE_ALLOW=1) |
skilllite init-cursor |
Initialize Cursor IDE integration |
skilllite init-opencode |
Initialize OpenCode integration |
skilllite clean-env |
Clean cached runtime environments |
skilllite reindex |
Re-index all installed skills |
skilllite wiki init |
Initialize or repair the Markdown-only project Repo Wiki at .skilllite/wiki/ |
skilllite wiki ingest <path> |
Ingest a local file into .skilllite/wiki/raw/ and auto-compile by default (--no-compile skips refresh) |
skilllite wiki compile |
Manually compile raw/ sources into structured wiki/ articles with source fingerprints |
skilllite wiki status |
Report stale, uncompiled, missing-source, and up-to-date wiki sources without writing files |
skilllite wiki record-lesson |
Record a user-confirmed chat/Assistant lesson with experience and optimization guidance into raw/, then auto-compile |
skilllite wiki query "<q>" |
Query Repo Wiki Markdown content; stale sources auto-refresh unless --no-compile is set (--quick indexes, --deep all Markdown) |
skilllite wiki lint |
Validate Repo Wiki structure, indexes, frontmatter, sources, and links |
Note: for default
skillsmode, ifskills/is missing and.skills/exists, SkillLite automatically falls back to.skills/. When bothskills/<name>and.skills/<name>exist, commands print a duplicate-name warning to improve observability. Workspace skill discovery also supports.agents/skills/and.claude/skills/as canonical search roots.skilllite initalso creates a project-local Repo Wiki at.skilllite/wiki/. The wiki is plain Markdown (_index.md,config.md,log.md,raw/,wiki/,lessons/,output/) and does not use SQLite. Existing chat memory remains under the normal chat data root. Repo Wiki freshness is tracked with source fingerprints;ingestandquerycan refresh compiled articles, whilestatusonly reports freshness. Chat/Assistant runs can emit awiki_update_suggestionafter replans or repeated tool failures. The suggestion is prompt-only; Wiki content is written only after user confirmation throughskilllite wiki record-lesson. Recorded lessons useWhat Happened,Root Cause,Optimization, andNext Timesections instead of storing full transcripts.
Build from Source
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
source ~/.cargo/env| Package | Binary | Command | Description |
|---|---|---|---|
| skilllite | skilllite | cargo build -p skilllite |
Full (Evolution + Agent + Sandbox + MCP; includes artifact-serve code, bind requires SKILLLITE_ARTIFACT_SERVE_ALLOW=1) |
| skilllite | skilllite | cargo build -p skilllite --features memory_vector |
Full + vector memory search |
| skilllite | skilllite | cargo build -p skilllite --no-default-features |
Minimal: run/exec/bash/scan only |
| skilllite | skilllite-sandbox | cargo build -p skilllite --bin skilllite-sandbox --no-default-features --features sandbox_binary |
Sandbox + MCP only |
| Command | What you get |
|---|---|
cargo install --path skilllite |
skilllite — full |
cargo install --path skilllite --features memory_vector |
skilllite — full + vector memory |
cargo install --path skilllite --bin skilllite-sandbox --no-default-features --features sandbox_binary |
skilllite-sandbox — sandbox + MCP only |
Default features = sandbox, audit, agent, swarm, artifact_http. Vector memory (memory_vector) is not in default. skilllite artifact-serve is compiled in but refuses to bind unless SKILLLITE_ARTIFACT_SERVE_ALLOW=1 is set (reduces accidental exposure).
OpenCode Integration
pip install skilllite
skilllite init-opencode # Auto-configure OpenCode MCP
opencodeThe init-opencode command automatically detects the best way to start the MCP server, creates opencode.json, and discovers your skills.
Desktop Assistant (skilllite-assistant) — optional
Optional official GUI — not required if you only need sandbox/MCP in another IDE or agent.
SkillLite Assistant is the native desktop app (Tauri 2 + React) on top of the same skilllite engine (agent-rpc). Installers (dmg / msi / AppImage) ship on GitHub Releases (desktop builds may appear shortly after the main release artifacts). Optional GUI — see Pick your path → Desktop if you want the assistant app instead of MCP-only integration. In the skills side panel, you can now either paste a source or choose a local ZIP package via the native file picker, the list shows installed skills even when they are bash-tool or other non-script packages, and each skill row surfaces type / trust / dependency hints.
Tauri 2 + React Desktop, located at crates/skilllite-assistant/:
cd crates/skilllite-assistant
npm install
npm run tauri dev # dev mode (HMR)
npm run tauri buildChat input behavior: Enter inserts a new line; submit by clicking the Send button.
Saving Model & API merges the current model, optional API base, and key into a local profile list; the chat footer can switch among saved profiles that include a key.
Gateway / inbound HTTP in Settings → Workspace & sandbox can now start and stop a local managed skilllite gateway serve child process directly from the desktop app, while still exposing the external CLI command for terminal/systemd supervision. If the configured bind is already served by an external healthy gateway, the page reports that external-running state instead of only surfacing a bind-collision failure.
MiniMax M2 / M2.7 (OpenAI-compatible api.minimax.io): some streams put incremental assistant text in choices[].delta.reasoning_details[].text (string or { "value": "…" }) while delta.content stays empty. The bundled agent forwards those chunks to the desktop chat. After tools finish, the “substantial assistant text?” gate now uses the same visibility sanitizer as the UI (not raw length), so long thinking-only wrappers no longer skip the tool-result summary fallback on follow-up turns.
Optional IDE three-pane layout (toolbar IDE or Settings → Workspace & sandbox → IDE three-pane main window): workspace file tree, editor, and chat; Sessions tab keeps the session list. Drag the vertical splitters between panes to resize (widths persist). Heavy folders like node_modules / target are skipped; macOS .DS_Store and Windows Thumbs.db are omitted from the file tree; non‑UTF‑8 files show a clear in‑editor error instead of a raw decode failure. Sensitive paths match write rules (e.g. .env blocked). Turn off IDE layout to bring back the right-hand status panel. The center editor supports Markdown preview (with an edit tab) and read-only preview for common images and videos via the Tauri asset protocol. In chat, read_file results use a short (~5-line) scrollable preview; click the preview to open the file in IDE layout when a path is known, or the fullscreen reader otherwise. list_directory output uses the same-height scrollable tree preview.
Pending execution confirmations live inside the collapsible internal steps timeline (it auto-expands when action is required; you can enable auto-allow execution confirmations in Settings → Agent budget or under the input on trusted machines).
For tool outcomes marked as partial_success or failure, the assistant shows a multi-option recovery prompt, including 【启动进化】 to enqueue a governed capability-evolution backlog proposal.
Default agent prompts bias toward implementing missing capabilities (scripts, run_command, small skills) instead of flatly refusing browser/desktop-style requests when no dedicated skill exists. App upgrades that bump the prompt seed version may overwrite ~/.skilllite/chat/prompts/*.md when the on-disk file differs from the new bundled template (including upgrades from older stock); back up those files if you customized them.
Uninstall: Settings → Uninstall & data (remove the app only or wipe local assistant data; see the assistant README).
Windows: background subprocesses (bundled engine checks, Life Pulse, runtime probes, and agent run_command shells) are started with CREATE_NO_WINDOW, so you should not see empty Command Prompt windows flashing during normal use.
SkillLite's sandbox hardening experience was contributed to ZeroClaw via issue #4812 and adopted in PR #4821, improving its native sandbox security posture (seccomp, capability dropping, fail-closed backend selection).
Lockdown networking for MCP-style stacks was contributed to ai-jail in PR #16: repeatable --allow-tcp-port / config allow_tcp_ports can permit outbound TCP to listed ports while staying in lockdown (Landlock V4 ConnectTcp rules when the network namespace is shared), with behavior unchanged when no ports are configured.
MIT — See THIRD_PARTY_LICENSES.md for third-party details.
- Pick your path — Sandbox/MCP (recommended) vs full stack vs optional desktop
- Getting Started — Installation and quick start guide
- Channel and Gateway — Inbound webhook,
SKILLLITE_CHANNEL_*, Assistant (EN); 中文 - Changelog — Version history and upgrade notes
- Environment Variables Reference — Complete env var documentation
- Architecture — Project architecture and design
- Architecture Comparison — Claude Code vs OpenClaw vs OpenCode vs SkillLite(中文)
- Contributing Guide — How to contribute



