thecoder/laravel-monolog-telegram
最新稳定版本:v2.5.3
Composer 安装命令:
composer require thecoder/laravel-monolog-telegram
包简介
Telegram Handler for Monolog
README 文档
README
ScreenShot
❓ Why Another Logger?
Logging should be more than just saving data — it should drive action. Here’s why 🔔 Telegram Handler for Monolog 📝 is a game-changer:
- 🚀 Real-Time Feedback – Instantly receive logs in your Telegram chat.
- 🧠 Actionable Insights – Include useful context for quick understanding.
- 🛡️ No Need for Sentry or Third-Party Services
- ⚡ Immediate Alerts – Be notified of issues the moment they happen.
- 👥 Team Collaboration – Share logs in group chats for quick follow-up.
- 🧩 Easy Customization – Use PHP attributes to control log routing.
🎯 Installation
Install via Composer:
composer require thecoder/laravel-monolog-telegram
⚙️ Usage
Update your config/logging.php file to configure the Telegram logging channel.
⏳ Running Logs in a Queue
If a queue name is set, logs will be processed asynchronously in the specified queue. Otherwise, they will run synchronously.
🔧 Configuration Example
Modify your config/logging.php file:
use TheCoder\MonologTelegram\Attributes\EmergencyAttribute; use TheCoder\MonologTelegram\Attributes\CriticalAttribute; use TheCoder\MonologTelegram\Attributes\ImportantAttribute; use TheCoder\MonologTelegram\Attributes\DebugAttribute; use TheCoder\MonologTelegram\Attributes\InformationAttribute; use TheCoder\MonologTelegram\Attributes\LowPriorityAttribute; return [ 'channels' => [ 'stack' => [ 'driver' => 'stack', 'channels' => ['single', 'telegram'], ], 'telegram' => [ 'driver' => 'monolog', 'level' => 'debug', 'handler' => TheCoder\MonologTelegram\TelegramBotHandler::class, 'handler_with' => [ 'token' => env('LOG_TELEGRAM_BOT_TOKEN'), 'chat_id' => env('LOG_TELEGRAM_CHAT_ID'), 'topic_id' => env('LOG_TELEGRAM_TOPIC_ID', null), 'bot_api' => env('LOG_TELEGRAM_BOT_API', 'https://api.telegram.org/bot'), 'proxy' => env('LOG_TELEGRAM_BOT_PROXY', null), 'queue' => env('LOG_TELEGRAM_QUEUE', null), 'timeout' => env('LOG_TELEGRAM_TIMEOUT', 5), 'topics_level' => [ EmergencyAttribute::class => env('LOG_TELEGRAM_EMERGENCY_ATTRIBUTE_TOPIC_ID', null), CriticalAttribute::class => env('LOG_TELEGRAM_CRITICAL_ATTRIBUTE_TOPIC_ID', null), ImportantAttribute::class => env('LOG_TELEGRAM_IMPORTANT_ATTRIBUTE_TOPIC_ID', null), DebugAttribute::class => env('LOG_TELEGRAM_DEBUG_ATTRIBUTE_TOPIC_ID', null), InformationAttribute::class => env('LOG_TELEGRAM_INFORMATION_ATTRIBUTE_TOPIC_ID', null), LowPriorityAttribute::class => env('LOG_TELEGRAM_LOWPRIORITY_ATTRIBUTE_TOPIC_ID', null), ] ], 'formatter' => TheCoder\MonologTelegram\TelegramFormatter::class, 'formatter_with' => [ 'tags' => env('LOG_TELEGRAM_TAGS', null), ], ], ], ];
🏷️ Topic-Based Logging
You can assign a PHP Attribute (Annotation) to controller methods, command handlers, or job handlers, enabling topic-based logging. The package will use the first detected attribute to determine the topic for logging messages.
💡 Example:
📌 Controller Method:
namespace App\Http\Controllers\NewWeb; use App\Http\Controllers\Controller; use Illuminate\Http\Request; use TheCoder\MonologTelegram\Attributes\EmergencyAttribute; class HomeController extends Controller { #[EmergencyAttribute] public function index(Request $request) { // Your logic here } }
⚡ Command or Job Handler:
namespace App\Jobs; use Illuminate\Bus\Queueable; use Illuminate\Contracts\Queue\ShouldBeQueued; use Illuminate\Foundation\Bus\Dispatchable; use TheCoder\MonologTelegram\Attributes\CriticalAttribute; class ProcessData implements ShouldBeQueued { use Dispatchable, Queueable; #[CriticalAttribute] public function handle() { // Job processing logic } }
⚙️ Livewire Component Route:
<form wire:submit.prevent="save">
class CreatePost extends Component { #[CriticalAttribute] public function save() { } public function render() { return view('livewire.create-post'); } }
🔄 Customizing Log Settings at Runtime
You can dynamically set the bot token, chat ID, and topic ID while logging:
logger('message', [ 'token' => 'your_bot_token', 'chat_id' => 'your_chat_id', 'topic_id' => 'your_topic_id' ]);
📜 Environment Variables
Ensure the following variables are set in your .env file:
LOG_TELEGRAM_BOT_TOKEN= LOG_TELEGRAM_CHAT_ID= # 🏷️ If using chat groups with topic support, define the topic ID LOG_TELEGRAM_TOPIC_ID= # 🌍 Optional: Change the API endpoint (default is Telegram's official API) LOG_TELEGRAM_BOT_API='https://api.telegram.org/bot' # 🛡️ Optional: Use a proxy (e.g., Tor for restricted regions) LOG_TELEGRAM_BOT_PROXY='socks5h://localhost:9050' # 🔥 Topic Level Configurations LOG_TELEGRAM_EMERGENCY_ATTRIBUTE_TOPIC_ID= LOG_TELEGRAM_CRITICAL_ATTRIBUTE_TOPIC_ID= LOG_TELEGRAM_IMPORTANT_ATTRIBUTE_TOPIC_ID= LOG_TELEGRAM_DEBUG_ATTRIBUTE_TOPIC_ID= LOG_TELEGRAM_INFORMATION_ATTRIBUTE_TOPIC_ID= LOG_TELEGRAM_LOWPRIORITY_ATTRIBUTE_TOPIC_ID=
📄 License
This package is open-source and available under the MIT License. 🏆
统计信息
- 总下载量: 35.79k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 28
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-11-14
