dayemsiddiqui/langfuse-sdk
最新稳定版本:v1.1.0
Composer 安装命令:
composer require dayemsiddiqui/langfuse-sdk
包简介
Laravel Langfuse SDK
README 文档
README
A simple Laravel package for working with Langfuse prompts. Fetch, compile, and test AI prompts with ease.
🚀 Quick Start
- Install:
composer require dayemsiddiqui/langfuse-sdk
- 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
- 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 PromptBuilderPromptBuilder->raw()→ get raw promptPromptBuilder->compile($vars)→ compile with variablesLangfuseFake::fake([...])→ fake prompts in testsLangfuseFake::getFake()->assertPromptRequested($name)→ assert prompt was used
📝 Advanced
- Dependency Injection: Works with Laravel's container, so you can type-hint
Langfusein 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
- PRs welcome! See CONTRIBUTING.
- MIT License. See LICENSE.md.
🙏 Credits
统计信息
- 总下载量: 489
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-07-07