jordanpartridge/laravel-say-logger

A Laravel package that speaks your log messages using macOS text-to-speech with different voices for different log levels

v1.0.0 2025-07-11 04:00 UTC

This package is auto-updated.

Last update: 2025-07-11 06:33:25 UTC


README

Latest Version License PHP Version

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! ๐ŸŽฏ