hn/typo3-agent 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

hn/typo3-agent

Composer 安装命令:

composer require hn/typo3-agent

包简介

TYPO3 extension that integrates an AI agent directly into TYPO3, using the MCP ToolRegistry for native tool execution with an OpenAI-compatible LLM API

README 文档

README

Integrates an AI agent directly into TYPO3 by calling the MCP ToolRegistry natively from PHP and communicating with an OpenAI-compatible LLM API. Editors create task records in the List module, and a CLI command processes them through an agent loop.

Installation

composer require hn/typo3-agent

Then activate the extension in TYPO3 backend or via CLI:

bin/typo3 extension:activate agent

Configuration

Go to Settings > Extension Configuration > agent and configure:

Setting Default Description
apiUrl https://openrouter.ai/api/v1/ OpenAI-compatible API base URL
apiKey (empty) API key for authentication
model anthropic/claude-haiku-4-5 Model identifier
systemPrompt (built-in) System prompt for the agent
maxIterations 20 Safety limit for the agent loop

Provider Examples

OpenRouter (default — access to many models):

apiUrl: https://openrouter.ai/api/v1/
model: anthropic/claude-haiku-4-5

OpenAI:

apiUrl: https://api.openai.com/v1/
model: gpt-5.2

Any OpenAI-compatible API:

apiUrl: https://your-provider.com/v1/
model: your-model-id

Usage

Creating Tasks

  1. Open the List module in TYPO3 backend
  2. Navigate to the page you want the agent to work on
  3. Create a new Agent Task record
  4. Fill in the Title and Prompt fields
  5. Save the record (status defaults to "Pending")

The task's pid (page ID) provides context — the agent automatically loads information about that page. The task's cruser_id determines which backend user's permissions the agent uses for tool execution.

Note: TYPO3 13.4 no longer auto-populates cruser_id via DataHandler. When cruser_id is 0 (default), the agent falls back to admin context. To run the agent as a specific user, set cruser_id manually on the task record.

Agent Instructions

Editors can maintain reusable instructions for the agent — tone of voice, wording rules, or how to handle specific content elements or records — as Agent Instruction records (tx_agent_instruction). This follows the progressive-disclosure idea of the SKILL.md open standard: the agent is its own harness, so the extension implements the pattern itself (provider-neutral — the OpenAI-compatible chat API has no native skills parameter).

Each instruction has a mode:

  • Always — the body is appended to the agent's system prompt for every new chat (global base rules). Use sparingly for guidance that always applies.
  • On demand — only the name and the "when to use" hint go into the prompt as a short index; the agent loads the full body via the GetInstruction tool when it is about to produce the relevant kind of content. This keeps the prompt small and scales to many instructions.

Note: Instructions are baked into the conversation at creation time, so they apply to newly started chats — chats already in progress keep the prompt they were created with.

Each record has:

Field Description
Name Short label, shown in the prompt index and the read-only panel
Mode Always (in every prompt) or On demand (loaded via GetInstruction)
When to use Short hint shown in the prompt index so the agent knows when an on-demand instruction applies
Instruction content The guidance itself — authored as rich text; converted to plain text/Markdown before it reaches the LLM
Hidden / Start / Stop Standard visibility controls to stage or retire instructions without deleting them

Where to keep them: create a dedicated folder (SysFolder) and store the instruction records there.

Restricting who may edit (native TYPO3 permissions): the extension does not hard-code a group. Instead, grant editing to the desired backend group via the standard access mechanism:

  1. Edit the backend group in Backend Users > Groups.
  2. Under Access Lists > Tables (modify), enable Agent Instruction.
  3. Give the group access to the SysFolder that holds the records (DB mounts / page permissions).

Groups without modify rights can still read the instructions, so they remain visible in the List module and in the chat info panel.

Viewing: the instructions appear in a collapsible panel at the top of the AI chat (both the chat list and individual chats), and — like any record — in the List module.

Running the Agent

Process all pending tasks:

bin/typo3 agent:run

Process a specific task by UID:

bin/typo3 agent:run --task=42

Limit the number of tasks processed:

bin/typo3 agent:run --limit=5

Task Lifecycle

Status Value Description
Pending 0 Ready to be picked up by agent:run
In Progress 1 Currently being processed
Ended 2 Agent finished, result available
Failed 3 Error occurred, messages preserved

Resuming Failed Tasks

When a task fails, its conversation state (messages) is preserved. To resume:

  1. Fix the underlying issue (API key, network, etc.)
  2. Set the task status back to "Pending" in the backend
  3. Run agent:run again — it resumes from the last saved messages

Or resume directly: bin/typo3 agent:run --task=42

Scheduler

The agent:run command is schedulable — you can set it up as a recurring task in the TYPO3 Scheduler to automatically process pending tasks.

Architecture

The extension uses the ToolRegistry from hn/typo3-mcp-server to access TYPO3 tools (GetPage, GetPageTree, Search, ReadTable, WriteTable, etc.) natively from PHP without MCP protocol overhead.

The messages JSON field in each task record stores the full OpenAI messages array — the complete conversation state. This enables resumability and future chat-like interfaces.

Development

Run the functional tests:

composer install
composer test

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: GPL-2.0-or-later
  • 更新时间: 2026-07-01

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固