Documentation Index
Fetch the complete documentation index at: https://docs.agentscope.io/llms.txt
Use this file to discover all available pages before exploring further.
Overview
Tools are how an agent acts on the world — running shell commands, reading files, calling APIs. Each tool exposes itself to the LLM as a JSON Schema, and the agent invokes it through a unified streaming interface. AgentScope organizes tool-related building blocks under three concepts:- Tool — any class that satisfies the
ToolBaseinterface, including the built-ins shipped with AgentScope and theFunctionTool/MCPTooladapters that wrap plain functions or MCP-server tools. - Toolkit — the container that registers tools, MCP clients, and skills, exposes their JSON schemas to the model, and dispatches each tool call to the right tool object.
- Tool Group — a named bundle of tools, MCP clients, and skills that can be activated or deactivated as a unit. The agent toggles groups at runtime via the built-in meta tool to keep its context focused.
Toolkit created with tools alone exposes those tools in the special "basic" group, which is always active. Adding mcps, skills_or_loaders, or extra tool_groups extends what the agent can reach — see the sections below.
Python Tool
A Python tool is any object satisfying theToolBase interface. AgentScope ships built-in tools for common operations and exposes the same interface for developers to build custom tools.
ToolBase Interface
ToolBase is the abstract base class every tool satisfies. The tables below list its attributes and methods.
Attributes that describe the tool to the agent and the runtime:
| Attribute | Type | Description |
|---|---|---|
name | str | The tool name presented to the agent |
description | str | Agent-oriented description of what the tool does |
input_schema | dict | JSON Schema defining the tool’s parameters |
is_concurrency_safe | bool | Whether the tool is safe to call in parallel |
is_read_only | bool | Whether the tool only reads data without side effects |
is_external_tool | bool | If True, execution is delegated externally (see Define External Execution Tool) |
is_state_injected | bool | If True, the agent state is injected via the _agent_state argument |
is_mcp | bool | Whether the tool comes from an MCP server |
mcp_name | str | None | The MCP server name when is_mcp is True |
| Method | Required | Description |
|---|---|---|
check_permissions(tool_input, context) | Yes | Runtime permission check before execution; returns PermissionDecision |
match_rule(rule_content, tool_input) | Optional | Custom rule-matching logic for the permission system; returns bool |
generate_suggestions(tool_input) | Optional | Generate suggested permission rules from a tool call; returns list[PermissionRule] |
__call__(**kwargs) | Optional | The tool’s execution logic; returns ToolChunk or AsyncGenerator[ToolChunk, None]. Not required for external execution tools. |
Use Built-in Tools
AgentScope ships a set of ready-to-use tools covering common agent operations. Instantiate them and pass intoToolkit(tools=[...]):
| Tool | Description | Read-only |
|---|---|---|
Bash | Execute shell commands | No |
Read | Read file contents with line numbers | Yes |
Write | Create or overwrite files | No |
Edit | Perform exact string replacements in files | No |
Glob | Find files by glob pattern | Yes |
Grep | Search file contents using ripgrep | Yes |
TaskCreate | Create a structured task for progress tracking | No |
TaskGet | Retrieve task details by ID | Yes |
TaskList | List all tasks and their status | Yes |
TaskUpdate | Update task status or metadata | No |
Two more tools — the
reset_tools meta tool and the Skill viewer — are auto-registered by Toolkit whenever extra tool groups or skills exist. Developers do not instantiate them directly. See Manage Tools Agentically and Skill.Bash
TheBash tool executes shell commands and returns stdout/stderr. It implements every optional interface method to provide fine-grained permission control.
check_permissions() runs a layered safety analysis on the command string:
- Injection risk detection — flags dynamic shell structures (
$(...), backticks, process substitution) that cannot be statically analyzed → ASK - Read-only command detection — auto-allows safe commands (
git status,ls,cat,grep,docker ps, etc.), including compound commands where every subcommand is read-only → ALLOW - Dangerous command patterns — detects destructive operations (e.g.
chmod 777,mkfs) → ASK - Sed constraint check — blocks in-place
sed -iagainst dangerous files → ASK - Dangerous path protection — checks if the command operates on sensitive config files (
.bashrc,.ssh/,.env) → ASK - Dangerous removal detection — catches
rm/rmdirtargeting critical system paths (/,~,/usr) → ASK - ACCEPT_EDITS mode — auto-allows filesystem commands (
mkdir,touch,rm,mv,cp,sed) when this mode is active → ALLOW
match_rule() uses prefix-based wildcard matching against the command string:
| Pattern | Matches | Does not match |
|---|---|---|
npm run:* | npm run build, npm run test | npm install |
git commit:* | git commit -m "fix" | git push |
rm:* | rm file.txt, rm -rf /tmp/x | ls |
generate_suggestions() extracts the command prefix (first two tokens) and proposes a prefix rule. For example, git commit -m "fix bug" produces the suggestion git commit:*.
The constructor accepts optional extra entries for the dangerous-path lists:
File Tools (Read, Write, Edit)
The file tools enforce a read-before-write rule:Write and Edit require the target file to have been read via Read first. This prevents blind overwrites and ensures the agent always operates on current content.
| Tool | Operation | Key behavior |
|---|---|---|
Read | Read file contents | Returns content with line numbers; supports offset/limit for large files; results cached in agent state |
Write | Create or overwrite a file | Fails if the file exists but has not been read first |
Edit | Replace exact strings in a file | Fails if old_string is not found or is not unique (unless replace_all=True); requires prior read |
check_permissions() — Write and Edit share the same permission logic:
- Dangerous path protection (bypass-immune) — operations on sensitive files (
.bashrc,.env,.ssh/) always trigger ASK, even in BYPASS mode - ACCEPT_EDITS mode — auto-allows operations on files within configured working directories
- PASSTHROUGH — falls through to the permission engine for rule matching
Read is read-only and always returns PASSTHROUGH (the engine handles EXPLORE-mode auto-allow).
match_rule() — all three tools use fnmatch glob matching against the file_path argument:
| Pattern | Matches |
|---|---|
src/** | Any file under src/ |
src/**/*.py | Python files under src/ |
config.json | Exact file match |
generate_suggestions() proposes a glob covering the parent directory. For example, editing /project/src/main.py produces the suggestion src/**.
Create Custom Tool
To create a custom tool, subclassToolBase, declare its schema, and implement check_permissions and __call__:
Wrap Function as Tool
For lightweight cases that don’t justify a full subclass, wrap a plain Python function with theFunctionTool adapter. It auto-extracts the tool name from func.__name__, the description from the function docstring, and the input schema from type hints.
FunctionTool accepts overrides when the auto-extracted defaults are not what you want:
| Argument | Type | Description |
|---|---|---|
func | Callable | The Python function to wrap |
name | str | None | Override the tool name (defaults to func.__name__) |
description | str | None | Override the description (defaults to the docstring) |
is_concurrency_safe | bool | Whether parallel calls are safe (default True) |
is_read_only | bool | Whether the function has side effects (default False) |
is_state_injected | bool | Whether the agent state is injected as _agent_state (default False) |
Wrapped functions default to
ASK permission behavior — the user must explicitly allow each call. Subclass ToolBase directly when you need custom permission logic.Define External Execution Tool
An external execution tool delegates its actual execution outside the agent runtime — typically to a human operator or an external system. When the agent calls one, it emits aRequireExternalExecutionEvent and pauses until the result is delivered via ExternalExecutionResultEvent.
This pattern underlies the human-in-the-loop workflow, where certain actions require human approval or manual execution.
To create an external execution tool, set is_external_tool = True. There is no need to implement __call__:
MCP
AgentScope integrates with Model Context Protocol (MCP) servers, letting an agent reach any MCP-compatible tool provider. The framework handles protocol negotiation, tool discovery, and result conversion automatically. Two connection modes are supported:- Stateful (STDIO or HTTP) — persistent session with explicit
connect()/close()lifecycle - Stateless (HTTP only) — ephemeral session created per tool call, no lifecycle management needed
mcp__{server_name}__{tool_name} to avoid name collisions, and tools annotated with readOnlyHint are auto-allowed by the permission system.
Register MCP Tool
Build one or moreMCPClient instances and pass them to Toolkit(mcps=[...]). Stateful clients must be connected before the toolkit is constructed.
enable_tools or disable_tools on the client itself:
Toolkit, call await client.list_tools() to retrieve a list of MCPTool adapters and use them like any other ToolBase instance.
Skill
Skills are markdown-based instruction sets that extend agent capabilities without writing new tool code. Each skill is a directory containing aSKILL.md file with frontmatter metadata and detailed instructions.
Unlike tools, skills are not callable directly. The agent uses the auto-registered Skill viewer tool to read a skill’s instructions, then follows those instructions using its existing tools.
Register Skill
Pass skill sources to theToolkit constructor through skills_or_loaders. Each entry can be a directory path string, a Skill object, or a SkillLoaderBase subclass:
How Skill Works
When aToolkit is constructed with skills, the registration and lookup flow runs in two phases.
At initialization:
- The toolkit scans every registered skill source and collects each skill’s name, description, and directory.
- It auto-registers the built-in
Skillviewer tool. - It composes a system-prompt fragment listing the available skills (name and description only) and instructing the agent to invoke the
Skillviewer to read the full content.
- The agent picks a skill by name and calls the
Skillviewer. - The viewer reads the corresponding
SKILL.mdand returns its full markdown. - The agent follows those instructions using its already-equipped tools.
Skills are not tools — the agent cannot call a skill directly. It must first use the
Skill viewer to read the instructions, then execute the steps described within using its other tools.Manage Tools Agentically
The built-in meta tool (reset_tools) lets the agent self-manage which tool groups are active at runtime. This keeps its context focused — only tools relevant to the current task are exposed.
Define Tool Group
AToolGroup is a named bundle of tools, MCP clients, and skills. Pass groups to Toolkit(tool_groups=[...]). The reserved "basic" group is created automatically from the constructor’s top-level tools, mcps, and skills_or_loaders arguments and is always active.
ToolGroup accepts the same tools, mcps, and skills_or_loaders arguments as the toolkit, plus a description shown to the agent in the meta tool schema and an optional instructions string returned when the group is activated.
Use Meta Tool
When at least one non-basic tool group exists,Toolkit auto-registers reset_tools and exposes its schema to the agent. Each non-basic group becomes a boolean field on that schema, and the agent calls the meta tool with the desired final state.
The behavior at runtime:
- Tools in the
"basic"group are always exposed; they are never affected by the meta tool. - Each call to
reset_toolsoverwrites the activated set — any non-basic group not explicitly set toTruebecomes inactive, regardless of its previous state. - For each group transitioning to active, its
instructions(when provided) are concatenated and returned in the meta tool’s response, telling the agent how to use that group properly. - Tools from inactive groups are hidden from the agent’s tool schema, freeing context space for the active set.
Further Reading
Agent
How agents orchestrate tool calls in the ReAct loop
Permission System
Fine-grained control over which tools can execute and when
Middleware
Intercept and transform tool calls with onion-style middleware
Human-in-the-Loop
External execution tools and human approval workflows