dayemsiddiqui/langfuse-sdk

Laravel Langfuse SDK

v1.1.0 2025-07-07 17:34 UTC

This package is auto-updated.

Last update: 2025-07-08 13:22:24 UTC


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