定制 dayemsiddiqui/langfuse-sdk 二次开发

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

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

dayemsiddiqui/langfuse-sdk

最新稳定版本:v1.1.0

Composer 安装命令:

composer require dayemsiddiqui/langfuse-sdk

包简介

Laravel Langfuse SDK

README 文档

README

Latest Version on Packagist GitHub Tests Action Status Total Downloads

A simple Laravel package for working with Langfuse prompts. Fetch, compile, and test AI prompts with ease.

🚀 Quick Start

  1. Install:
composer require dayemsiddiqui/langfuse-sdk
  1. Add your API keys to `.env:
LANGFUSE_PUBLIC_KEY=your_public_key_here
LANGFUSE_SECRET_KEY=your_secret_key_here
LANGFUSE_HOST=https://cloud.langfuse.com
  1. Use in your code:
use dayemsiddiqui\Langfuse\Langfuse;

$langfuse = new Langfuse();

// Get a raw prompt
echo $langfuse->getPrompt('welcome')->raw();


// Compile a prompt with variables
echo $langfuse->getPrompt('greeting')->compile(['name' => 'Alice']);

✨ Features

  • Fetch prompts from Langfuse by name
  • Compile prompts with variables (e.g. {{name}})
  • Detailed error messages for missing variables
  • Elegant testing with LangfuseFake::fake() (see below)

🧑‍💻 Usage

Get a Prompt

$prompt = $langfuse->getPrompt('welcome')->raw();
// "Hello {{name}}"

Compile a Prompt

$compiled = $langfuse->getPrompt('greeting')->compile(['name' => 'Alice']);
// "Hello Alice!"

Handle Missing Variables

If you try to compile a prompt and dont provide all the required variables in a prompt you will get a MissingPromptVariablesException

try {
    $langfuse->getPrompt('profile')->compile(['name' => 'John']);
} catch (\dayemsiddiqui\Langfuse\Exceptions\MissingPromptVariablesException $e) {
    echo $e->getMessage();
}

🧪 Testing (Just like Queue::fake())

Testing your code is easy and elegant!

1. Fake Langfuse in your tests

use dayemsiddiqui\Langfuse\Testing\LangfuseFake;
use dayemsiddiqui\Langfuse\Langfuse;

LangfuseFake::fake([
    'greeting' => 'Hello {{name}}!',
    'farewell' => 'Goodbye {{name}}!'
]);

$langfuse = app(Langfuse::class);

// This will use the fake prompt, no HTTP requests!
echo $langfuse->getPrompt('greeting')->compile(['name' => 'Test']); // "Hello Test!"

2. Make assertions

LangfuseFake::getFake()->assertPromptRequested('greeting');
LangfuseFake::getFake()->assertPromptRequestedTimes('greeting', 1);
LangfuseFake::getFake()->assertNoPromptsRequested();

3. Chainable API

LangfuseFake::fake()
    ->addPrompt('foo', 'Foo {{bar}}')
    ->addPrompt('baz', 'Baz {{qux}}')
    ->throwOnMissing();

4. Use the trait for auto-setup

use dayemsiddiqui\Langfuse\Testing\WithLangfuseFake;

uses(WithLangfuseFake::class);

it('fakes prompts', function () {
    $fake = $this->getLangfuseFake();
    $fake->addPrompt('test', 'Test prompt');
    $langfuse = app(Langfuse::class);
    expect($langfuse->getPrompt('test')->raw())->toBe('Test prompt');
});

📚 API Reference (Short)

  • getPrompt($name) → returns a PromptBuilder
  • PromptBuilder->raw() → get raw prompt
  • PromptBuilder->compile($vars) → compile with variables
  • LangfuseFake::fake([...]) → fake prompts in tests
  • LangfuseFake::getFake()->assertPromptRequested($name) → assert prompt was used

📝 Advanced

  • Dependency Injection: Works with Laravel's container, so you can type-hint Langfuse in your services.
  • Custom Exception: Get missing variables, provided variables, prompt name/content from the exception.
  • Supports both {{name}} and {{ name }} syntax.

🛠️ Development

  • Run tests: composer run test
  • Format code: composer format
  • Static analysis: composer analyse

🤝 Contributing & License

🙏 Credits

统计信息

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

GitHub 信息

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

其他信息

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