定制 adachsoft/prompt-template-lib 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

adachsoft/prompt-template-lib

最新稳定版本:v0.3.0

Composer 安装命令:

composer require adachsoft/prompt-template-lib

包简介

PHP library for rendering function-based prompt templates with extensible SPI and safe file access

README 文档

README

Small PHP library for rendering function-based prompt templates.

It lets you define template tags that call PHP functions (SPI implementations) with arguments.

Requirements

  • PHP >= 8.3
  • Composer

Installation

composer require adachsoft/prompt-template-lib

Basic usage

<?php

declare(strict_types=1);

require __DIR__ . '/vendor/autoload.php';

use AdachSoft\PromptTemplateLib\PublicApi\PromptEngineFactory;
use AdachSoft\PromptTemplateLib\Spi\PromptFunctionInterface;

$engine = PromptEngineFactory::createDefault(__DIR__);

$engine->registerFunction(new class implements PromptFunctionInterface {
    public function getName(): string
    {
        return 'user_name';
    }

    public function execute(array $arguments): string
    {
        return 'Example User';
    }
});

echo $engine->render("Hello <user_name>, today is <datetime('Y-m-d')>.");

Function tag syntax

By default the engine uses angle bracket tags like <user_name>.

To avoid conflicts with other markup (for example <role>...</role>), you can change the syntax using FunctionTagSyntax:

  • <function_name(...)> (default)
  • [function_name(...)]
  • {{function_name(...)}}
use AdachSoft\PromptTemplateLib\PublicApi\FunctionTagSyntax;
use AdachSoft\PromptTemplateLib\PublicApi\PromptEngineFactory;

$engine = PromptEngineFactory::createDefault(
    __DIR__,
    FunctionTagSyntax::SquareBrackets,
);

$template = '<role>system</role> Hello [user_name].';
echo $engine->render($template);

PTL directive comments (stripped)

You can add internal comments to your templates using PTL directive comments:

  • <!--ptl: ... -->

These comments are stripped before parsing and rendering. This means any function tags placed inside a PTL comment will not be executed.

Examples:

<!--ptl: This comment will be removed -->
Hello <user_name>!

Inline:

Hello <!--ptl: hidden note --> <user_name>!

Multi-line:

<!--ptl: hidden note
second line
third line -->
Hello <user_name>!

Standard functions

PromptEngineFactory::createDefault() registers standard functions:

  • datetime
    • <datetime> or <datetime('Y-m-d')>
  • file_read
    • <file_read('relative/path.txt')>
  • include
    • <include('relative/path.txt')>
    • Reads the file and renders its content as a template.
    • Protects against recursive includes and enforces a max include depth.

Overriding standard functions

You can override any standard function (datetime, file_read, include) by passing your own implementations to the factory. When a custom function has the same name, the standard one is not registered.

use AdachSoft\PromptTemplateLib\PublicApi\FunctionTagSyntax;
use AdachSoft\PromptTemplateLib\PublicApi\PromptEngineFactory;

$engine = PromptEngineFactory::createDefault(
    __DIR__,
    FunctionTagSyntax::AngleBrackets,
    [new MyCustomDateTimeFunction()],
);

Context Management

The library supports a rendering context (key-value store) that can be accessed by custom functions.

Setting context

You can pass an initial context when creating the engine:

$engine = PromptEngineFactory::createDefault(
    __DIR__,
    initialContext: ['user_id' => 123, 'env' => 'production']
);

Or update it later:

$engine->setContextValue('user_id', 456);
$engine->setContext(['user_id' => 789, 'role' => 'admin']);

Accessing context in functions

To access the context inside a custom function, implement PromptEngineAwareFunctionInterface. The engine will automatically inject itself into your function.

use AdachSoft\PromptTemplateLib\PublicApi\PromptEngineInterface;
use AdachSoft\PromptTemplateLib\Spi\PromptEngineAwareFunctionInterface;

class MyContextAwareFunction implements PromptEngineAwareFunctionInterface
{
    private ?PromptEngineInterface $engine = null;

    public function setPromptEngine(PromptEngineInterface $engine): void
    {
        $this->engine = $engine;
    }

    public function getName(): string
    {
        return 'get_user_id';
    }

    public function execute(array $arguments): string
    {
        return (string) $this->engine->getContextValue('user_id', 'guest');
    }
}

Error handling

The library exposes dedicated exceptions in AdachSoft\PromptTemplateLib\PublicApi\Exception (for example UnknownFunctionException, TemplateSyntaxException, FunctionExecutionException).

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-15

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固