承接 thedomeffm/monolog-discord-handler-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

thedomeffm/monolog-discord-handler-bundle

最新稳定版本:v1.0.0

Composer 安装命令:

composer require thedomeffm/monolog-discord-handler-bundle

包简介

Monolog handler to push your logs to discord via webhook

README 文档

README

Adds a handler to monolog which can post your logs directly via discord webhook to your discord server channel.

Note

Discord has a character limit of 2000 (or 4000 when you have nitro). The message will get truncated when needed.

Installation

composer require thedomeffm/monolog-discord-handler-bundle

Configure the bundle

I've not added a recipe (or whatever I need to create 🤷), so you need to create the config by yourself.

# .env
DISCORD_WEBHOOK_URL="<your webhook url>"

Minimal

# config/packages/thedomeffm_monolog_discord_handler.yaml
thedomeffm_monolog_discord_handler:
    discord:
        webhook_url: "%env(DISCORD_WEBHOOK_URL)%"

Maximal

Note

Have in mind that json_pretty_print makes the message longer, and you'll reach the discord char limit easier!

# config/packages/thedomeffm_monolog_discord_handler.yaml
thedomeffm_monolog_discord_handler:
    discord:
        webhook_url: "%env(DISCORD_WEBHOOK_URL)%"

    formatting:
        characters_limit: 2000
        date_format: 'd.m.Y H:i:s'
        json_pretty_print: false

Configure monolog

Add the "service" handler

# monolog.yaml
monolog:
    handlers:
        # your other handlers...
        discord:
            type: service
            id: thedomeffm_monolog_discord_handler

Here is an example how a production config could look like:

# monolog.yaml
when@prod:
    monolog:
        handlers:
            main:
                type: fingers_crossed
                action_level: error
                handler: main_group
                excluded_http_codes: [404, 405]
                buffer_size: 50

            main_group:
                type: group
                members: ['error_stream', 'discord']

            error_stream:
                type: stream
                path: php://stderr
                level: debug
                formatter: monolog.formatter.json

            discord:
                type: service
                id: thedomeffm_monolog_discord_handler

            # your other handler...

Override the message content

Unhappy with my opinionated message design? Then decorate the factory. You can pass strings or the Text class into the Discord message.

// ...
use Monolog\LogRecord;
use Symfony\Component\DependencyInjection\Attribute\AsDecorator;
use TheDomeFfm\MonologDiscordHandlerBundle\Message\DiscordMessage;
use TheDomeFfm\MonologDiscordHandlerBundle\Message\DiscordMessageFactoryInterface;
use TheDomeFfm\MonologDiscordHandlerBundle\Message\Syntax;
use TheDomeFfm\MonologDiscordHandlerBundle\Message\Text;

#[AsDecorator(decorates: 'thedomeffm_monolog_discord_message_factory')]
class CustomMessageFactory implements DiscordMessageFactoryInterface
{
    public function createFromLogRecord(LogRecord $record): DiscordMessage
    {
        $message = new DiscordMessage();

        $message->append('# :x: Ohh noo an error!\n');
        $message->append(Text::create(Syntax::Code, $record->message)->render());

        return $message;
    }
}

custom discord error message from error log

统计信息

  • 总下载量: 2.36k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-12-03