mepsd/laravel-google-chat-logger
最新稳定版本:v1.0.4
Composer 安装命令:
composer require mepsd/laravel-google-chat-logger
包简介
Send Laravel application logs to Google Chat with rich formatting, emoji support, and context data
README 文档
README
Send your Laravel application logs directly to Google Chat with rich formatting, emoji support, threading, and automatic retries.
Features 🌟
- 🎯 Easy Integration: Works with Laravel's built-in logging system
- 🧵 Message Threading: Group related logs into threads
- 🎨 Rich Formatting: Messages are beautifully formatted in Google Chat
- 🔄 Automatic Retries: Built-in retry mechanism for failed messages
- 🎯 Level-based Emojis: Different emojis for different log levels
- 🌍 Environment Aware: Includes environment information in logs
- ⚡ Performance: Configurable timeouts and retry settings
- 🚨 Exception Handling: Detailed exception formatting with stack traces
Requirements 📋
- PHP 8.1 or higher
- Laravel 10.x or 11.x
- Google Chat space with webhook access
Installation 💿
- Install the package via composer:
composer require mepsd/laravel-google-chat-logger
- Add these variables to your
.envfile:
LOG_CHANNEL=google_chat GOOGLE_CHAT_WEBHOOK_URL=your-webhook-url
- Add this to your
config/logging.phpchannels array:
'channels' => [ 'google_chat' => [ 'driver' => 'custom', 'via' => Mepsd\LaravelGoogleChatLogger\GoogleChatLogger::class, 'url' => env('GOOGLE_CHAT_WEBHOOK_URL'), 'level' => env('LOG_LEVEL', 'debug'), 'retries' => 2, // Number of retry attempts 'timeout' => 5, // Request timeout in seconds ], ],
Usage 📝
Basic Logging
// Simple info message Log::info('User registered successfully', ['user_id' => 1]); // Error with exception try { // Some code } catch (Exception $e) { Log::error('Process failed', [ 'exception' => $e, 'user_id' => 1 ]); }
Message Threading
Group related logs into threads:
// Order Processing Thread $threadKey = 'order-' . $orderId; Log::info('Order received', [ 'thread_key' => $threadKey, 'order_id' => $orderId, 'amount' => 99.99 ]); Log::info('Processing payment', [ 'thread_key' => $threadKey, 'payment_method' => 'credit_card' ]); Log::info('Order completed', [ 'thread_key' => $threadKey, 'status' => 'completed' ]); // User Activity Thread $userThread = 'user-' . $userId; Log::info('User logged in', [ 'thread_key' => $userThread, 'ip' => $request->ip() ]); Log::warning('Failed login attempt', [ 'thread_key' => $userThread, 'attempts' => 3 ]);
Exception Handling
Exceptions are automatically formatted with details:
try { // Your code } catch (Exception $e) { Log::error('Process failed', [ 'thread_key' => 'process-123', 'exception' => $e, 'additional_data' => $data ]); }
Log Levels and Emojis
Each log level has its own emoji:
- 🚨 EMERGENCY - System is unusable
- ⚠️ ALERT - Action must be taken immediately
- 🔥 CRITICAL - Critical conditions
- ❌ ERROR - Error conditions
- ⚠️ WARNING - Warning conditions
- 📝 NOTICE - Normal but significant conditions
- ℹ️ INFO - Informational messages
- 🐛 DEBUG - Debug-level messages
Message Format
Messages in Google Chat will look like:
[local] ℹ️ *INFO*
Your message here
Context: { "user_id": 123, "action": "login" }
## Configuration Options
Full configuration options:
```php
'google_chat' => [
'driver' => 'custom',
'via' => Mepsd\LaravelGoogleChatLogger\GoogleChatLogger::class,
'url' => env('GOOGLE_CHAT_WEBHOOK_URL'),
'level' => env('LOG_LEVEL', 'debug'),
'retries' => 2, // Number of retry attempts
'timeout' => 5, // Request timeout in seconds
],
Setting Up Google Chat Webhook 🔗
- Open your Google Chat space
- Click the space name to open the dropdown menu
- Select "Manage webhooks"
- Click "Add webhook"
- Name your webhook (e.g., "Laravel Logs")
- Copy the webhook URL
- Add the URL to your
.envfile
Best Practices 🎯
- Use meaningful thread keys:
'user-{id}' // For user activities 'order-{id}' // For order processing 'deploy-{date}' // For deployments 'job-{id}' // For background jobs
- Group related logs:
$threadKey = 'payment-' . $paymentId; Log::info('Starting payment', ['thread_key' => $threadKey]); Log::info('Processing', ['thread_key' => $threadKey]); Log::info('Completed', ['thread_key' => $threadKey]);
- Include context data:
Log::info('User action', [ 'thread_key' => 'user-123', 'action' => 'profile_update', 'changes' => ['name' => 'New Name'], 'ip' => $request->ip() ]);
Testing 🧪
composer test
Security 🔒
If you discover any security-related issues, please use the issue tracker.
Credits 👏
License 📄
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 30
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-02-15