robbiekibler / laravel-posthog-logs
Send Laravel logs to PostHog using OpenTelemetry OTLP format
Fund package maintenance!
:vendor_name
Installs: 9
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/robbiekibler/laravel-posthog-logs
Requires
- php: ^8.2
- guzzlehttp/guzzle: ^7.0
- illuminate/contracts: ^10.0||^11.0||^12.0
- illuminate/log: ^10.0||^11.0||^12.0
- illuminate/support: ^10.0||^11.0||^12.0
- monolog/monolog: ^3.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.8
- orchestra/testbench: ^10.0.0||^9.0.0||^8.0.0
- pestphp/pest: ^3.0||^4.0
- pestphp/pest-plugin-arch: ^3.0||^4.0
- pestphp/pest-plugin-laravel: ^3.0||^4.0
- phpstan/extension-installer: ^1.4
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
This package is auto-updated.
Last update: 2026-02-03 01:05:13 UTC
README
Send your Laravel application logs to PostHog using the OpenTelemetry OTLP format. Just add the package, configure your environment variables, and your logs are automatically available in PostHog.
Installation
Install the package via Composer:
composer require robbiekibler/laravel-posthog-logs
Configuration
Quick Start
Add these environment variables to your .env file:
POSTHOG_API_KEY=phc_your_project_api_key POSTHOG_HOST=us.i.posthog.com
Security Note: Use a project API key (starts with
phc_), not a personal API key. Project API keys have limited scope and are safe for server-side usage.
Then add the posthog channel to your config/logging.php:
'channels' => [ // ... other channels 'posthog' => [ 'driver' => 'posthog', ], ],
To use PostHog as your default log channel, or as part of a stack:
// Use PostHog as default 'default' => env('LOG_CHANNEL', 'posthog'), // Or add to a stack 'stack' => [ 'driver' => 'stack', 'channels' => ['single', 'posthog'], ],
Environment Variables
| Variable | Description | Default |
|---|---|---|
POSTHOG_API_KEY |
Your PostHog project API key | (required) |
POSTHOG_HOST |
PostHog host (us.i.posthog.com, eu.i.posthog.com, or self-hosted) |
us.i.posthog.com |
POSTHOG_SERVICE_NAME |
Service name for log identification | APP_NAME |
POSTHOG_ENVIRONMENT |
Deployment environment | APP_ENV |
POSTHOG_LOG_LEVEL |
Minimum log level to send | debug |
POSTHOG_LOGS_ENABLED |
Enable/disable sending logs | true |
POSTHOG_BATCH_ENABLED |
Enable batching of logs | true |
POSTHOG_BATCH_MAX_SIZE |
Maximum logs per batch | 100 |
Publishing Config (Optional)
To customize all options, publish the config file:
php artisan vendor:publish --tag="posthog-logs-config"
Testing Your Configuration
Verify your setup is working by running the test command:
php artisan posthog:test
This will display your current configuration and send a test log entry to PostHog. You can customize the test message:
php artisan posthog:test --message="Hello from my app!"
Usage
Once configured, use Laravel's standard logging:
use Illuminate\Support\Facades\Log; // Basic logging Log::info('User logged in'); Log::warning('Rate limit approaching'); Log::error('Payment failed', ['order_id' => 123]); // With context Log::channel('posthog')->info('Order created', [ 'order_id' => $order->id, 'customer_id' => $customer->id, 'total' => $order->total, ]);
Trace Correlation
If you're using distributed tracing, you can include trace context:
Log::info('Processing request', [ 'trace_id' => $traceId, 'span_id' => $spanId, 'user_id' => $userId, ]);
Log Levels
The package maps Laravel/Monolog log levels to OpenTelemetry severity:
| Laravel Level | OTLP Severity |
|---|---|
| debug | DEBUG (5) |
| info | INFO (9) |
| notice | INFO (10) |
| warning | WARN (13) |
| error | ERROR (17) |
| critical | ERROR (18) |
| alert | FATAL (21) |
| emergency | FATAL (22) |
Viewing Logs in PostHog
- Go to your PostHog dashboard
- Navigate to Logs in the sidebar
- Filter by service name, environment, or log level
- Click on individual logs to see full context and attributes
Advanced Configuration
Channel-Level Overrides
Override settings per channel in config/logging.php:
'posthog' => [ 'driver' => 'posthog', 'level' => 'warning', // Only send warnings and above 'service_name' => 'my-api', 'environment' => 'staging', ],
Custom Resource Attributes
Add custom attributes to all logs via config:
// config/posthog-logs.php 'resource_attributes' => [ 'team.name' => 'backend', 'version' => '1.2.3', ],
Disable in Tests
# .env.testing POSTHOG_LOGS_ENABLED=false
Performance Considerations
Logs are sent to PostHog via synchronous HTTP requests. The package includes:
- Batching: Logs are batched (default: 100 per batch) to reduce HTTP overhead
- Timeouts: Short timeouts (5s request, 2s connect) to prevent blocking
- Retries: Automatic retry with exponential backoff for transient failures
- Overflow Protection: Oldest logs are dropped if the batch overflows due to send failures
For high-throughput applications, consider:
- Using a log stack with a fast local channel (e.g.,
single) as primary - Adjusting batch size via
POSTHOG_BATCH_MAX_SIZE - Setting a higher minimum log level in production via
POSTHOG_LOG_LEVEL
Testing
composer test
Changelog
Please see CHANGELOG for recent changes.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.