dayemsiddiqui / langfuse-sdk
Laravel Langfuse SDK
Fund package maintenance!
Dayem Siddiqui
Requires
- php: ^8.2
- illuminate/contracts: ^10.0||^11.0||^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^10.0.0||^9.0.0||^8.22.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3||^2.0
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
- spatie/laravel-ray: ^1.35
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
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
- PRs welcome! See CONTRIBUTING.
- MIT License. See LICENSE.md.