jordanpartridge / laravel-say-logger
A Laravel package that speaks your log messages using macOS text-to-speech with different voices for different log levels
Requires
- php: ^8.1
- illuminate/support: ^10.0|^11.0|^12.0
- monolog/monolog: ^3.0
- symfony/process: ^6.0|^7.0
Requires (Dev)
- orchestra/testbench: ^8.0|^9.0|^10.0
- phpunit/phpunit: ^10.0|^11.0
This package is auto-updated.
Last update: 2025-07-11 06:33:25 UTC
README
Never miss another error again! ๐ฏ
Laravel Say Logger brings audio feedback to your Laravel application by speaking your log messages using macOS text-to-speech. Different voices for different log levels mean you can hear the severity of issues without constantly checking log files.
Perfect for development environments where you want immediate audio feedback about your application's health.
โจ Features
- ๐ค Text-to-Speech Integration - Uses macOS
say
command - ๐ญ Voice Differentiation - Different voices for different log levels
- โก Async Processing - Non-blocking, won't slow down your app
- ๐ง Easy Configuration - Simple config file setup
- ๐๏ธ Toggle Control - Enable/disable via environment variable
- ๐งน Message Cleanup - Strips HTML tags and normalizes whitespace
- ๐ก๏ธ Error Handling - Graceful fallback if speech fails
๐ Installation
Install via Composer:
composer require jordanpartridge/laravel-say-logger
Publish the configuration file:
php artisan vendor:publish --provider="JordanPartridge\LaravelSayLogger\LaravelSayLoggerServiceProvider" --tag="config"
โ๏ธ Configuration
Add the say
channel to your config/logging.php
:
'channels' => [ 'stack' => [ 'driver' => 'stack', 'channels' => ['single', 'say'], // Add 'say' here ], // Add the say channel 'say' => [ 'driver' => 'say', ], ],
Configure voices in config/say-logger.php
:
return [ 'enabled' => env('SAY_LOGGER_ENABLED', true), 'voices' => [ 'debug' => 'Alex', 'info' => 'Victoria', 'notice' => 'Fred', 'warning' => 'Kathy', 'error' => 'Veena', 'critical' => 'Moira', 'alert' => 'Tessa', 'emergency' => 'Kyoko', ], ];
๐ต Fun Voice Options
Want to make debugging more entertaining? Try these musical and novelty voices:
'voices' => [ 'debug' => 'Bubbles', // Fun bubbly voice 'info' => 'Good News', // Upbeat singing 'notice' => 'Bells', // Musical bells 'warning' => 'Junior', // Kid voice 'error' => 'Cellos', // Singing cellos 'critical' => 'Bad News', // Ominous singing 'alert' => 'Trinoids', // Alien voice 'emergency' => 'Organ', // Dramatic organ ],
Available Voice Categories:
- Musical:
Cellos
,Organ
,Bells
,Good News
,Bad News
- Novelty:
Boing
,Bubbles
,Trinoids
,Bahh
,Whisper
- Character:
Junior
,Princess
,Albert
,Kathy
- Standard:
Alex
,Victoria
,Daniel
,Samantha
See all available voices: say -v '?'
Test a voice: say -v Cellos "Your error message here"
## ๐ญ Voice Examples
| Log Level | Voice | Character |
|-----------|-------|-----------|
| `debug` | Alex | Calm male voice |
| `info` | Victoria | Pleasant female voice |
| `warning` | Kathy | Concerned female voice |
| `error` | Veena | Urgent female voice |
| `critical` | Moira | Serious female voice |
| `emergency` | Kyoko | Alert female voice |
## ๐ฏ Usage
Once configured, your log messages will be automatically spoken:
```php
// These will be spoken by different voices
Log::debug('Cache cleared successfully'); // Alex
Log::info('User logged in successfully'); // Victoria
Log::warning('Low disk space detected'); // Kathy
Log::error('Database connection failed'); // Veena
Log::critical('Payment processor is down'); // Moira
Log::emergency('Security breach detected'); // Kyoko
Real-World Examples
// Database errors try { DB::connection()->getPdo(); } catch (Exception $e) { Log::error('Database connection failed: ' . $e->getMessage()); // ๐ Veena: "Database connection failed: SQLSTATE[HY000]..." } // API failures if ($response->failed()) { Log::warning('Payment API is responding slowly'); // ๐ Kathy: "Payment API is responding slowly" } // System monitoring if (disk_free_space('/') < 1000000) { Log::critical('Disk space critically low'); // ๐ Moira: "Disk space critically low" }
๐๏ธ Environment Control
Control the package via environment variables:
# Enable/disable speech SAY_LOGGER_ENABLED=true # Or disable for production SAY_LOGGER_ENABLED=false
๐ง Advanced Configuration
Custom Voice Mapping
You can customize which voice speaks for each log level:
'voices' => [ 'error' => 'Samantha', // Use Samantha for errors 'warning' => 'Daniel', // Use Daniel for warnings 'critical' => 'Fiona', // Use Fiona for critical // ... etc ],
Available macOS Voices
Check available voices on your system:
say -v "?"
Popular voices include: Alex, Victoria, Samantha, Daniel, Fiona, Karen, Moira, Tessa, Veena, Kyoko.
๐ก๏ธ Error Handling
The package includes robust error handling:
- Graceful Fallback - If
say
command fails, logging continues normally - Empty Message Protection - Won't attempt to speak empty messages
- Process Isolation - Speech failures won't affect your application
๐ฏ Use Cases
Development Environment
- Immediate Error Feedback - Hear problems as they happen
- Hands-Free Debugging - No need to constantly check logs
- Severity Awareness - Know how serious an issue is by the voice
Demo Environments
- Impressive Demonstrations - Show clients real-time error handling
- System Health Monitoring - Audio feedback for system status
Local Testing
- Test Result Feedback - Hear when tests fail
- Performance Monitoring - Audio alerts for slow queries
๐ Requirements
- PHP: ^8.1
- Laravel: ^10.0 || ^11.0
- macOS: Required for
say
command - Monolog: ^3.0
๐ค Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
๐ License
This package is open-sourced software licensed under the MIT license.
๐ Credits
- Jordan Partridge - Creator and maintainer
- Laravel Community - For the amazing framework
- Apple - For the macOS
say
command
๐ฎ Future Ideas
- Cross-platform support (Windows SAPI, Linux espeak)
- Rate limiting for repeated messages
- Custom message filtering
- Volume control per log level
- Slack/Discord integration
- Web interface for configuration
Made with โค๏ธ by Jordan Partridge
Never miss another error again! ๐ฏ