Laravel Logging в Slack через прокси - PullRequest
0 голосов
/ 28 сентября 2018

Я настроил мое приложение Laravel, работающее на PHP Framework Laravel 5.7.5, для отправки уведомлений об ошибках на канал Slack.Фрагмент моего файла config / logging.php выглядит следующим образом:

'channels' => [
    'stack' => [
        'driver' => 'stack',
        'channels' => (env('APP_ENV') == 'production') ? ['single', 'slack'] : ['single'],
    ],

    'single' => [
        'driver' => 'single',
        'path' => storage_path('logs/laravel.log'),
        'level' => 'debug',
    ],

    'daily' => [
        'driver' => 'daily',
        'path' => storage_path('logs/laravel.log'),
        'level' => 'debug',
        'days' => 7,
    ],

    'slack' => [
        'driver' => 'slack',
        'url' => env('LOG_SLACK_WEBHOOK_URL'),
        'username' => 'Laravel Log',
        'emoji' => ':boom:',
        'level' => 'error',
    ],

Это прекрасно работает, когда я подключен к общедоступному Интернету (не через прокси-сервер), но мои рабочие серверы необходимо отправитьзапросы через прокси-сервер Squid и время ожидания истекают.

Как мне указать прокси-сервер для Slack Webhook, чтобы мои запросы перенаправлялись через прокси-сервер и отправлялись наSlack API?

1 Ответ

0 голосов
/ 07 февраля 2019

Я понимаю, что прошло довольно много времени, но я столкнулся с подобной проблемой, возможно, найденный материал может быть кому-то полезен.

Судя по исходному коду библиотеки https://github.com/Seldaek/monolog/blob/master/src/Monolog/Handler/SlackWebhookHandler.php

В настоящее время текущая реализация не может указать прокси.

Но вы можете определить регистратор пользовательского типа.Здесь в этой статье подробно написано, как это сделать.https://medium.com/binarcode/laravel-5-6-custom-monolog-channel-to-store-logs-in-mariadb-23da52f537e7

Я сделал это так:

//config/logging.php
'default' => env('LOG_CHANNEL', 'custom'),
....
'custom' => [
        'driver' => 'custom',
        'via' => App\Extensions\SlackCustomLogger::class,
        'level' => 'debug',
        'url' => env('SLACK_WEBHOOK_URL'),
        'username' => 'Laravel Log',
        'emoji' => ':boom:',
    ],
...

<?php

namespace App\Extensions;

use Monolog\Logger;

class SlackCustomLogger
{
    /**
     * Create a custom Monolog instance.
     *
     * @param  array  $config
     * @return \Monolog\Logger
     */
    public function __invoke(array $config)
    {
        $logger = new Logger('custom');
        $logger->pushHandler(new CustomSlackLogHandler(
            $config['url'],
            $config['channel'] ?? null,
            $config['username'] ?? 'Laravel',
            $config['attachment'] ?? true,
            $config['emoji'] ?? ':boom:',
            $config['short'] ?? false,
            $config['context'] ?? true,
            $config['level'] ?? 'debug'
        ));
        return $logger;
    }
}

<?php

namespace App\Extensions;


use Monolog\Handler\Curl\Util;
use Monolog\Handler\SlackWebhookHandler;

class CustomSlackLogHandler extends SlackWebhookHandler
{
    protected function write(array $record)
    {
        $postData = $this->getSlackRecord()->getSlackData($record);
        $postString = json_encode($postData);

        $ch = curl_init();
        $options = array(
            CURLOPT_URL => $this->getWebhookUrl(),
            CURLOPT_POST => true,
            CURLOPT_RETURNTRANSFER => true,
            CURLOPT_HTTPHEADER => array('Content-type: application/json'),
            CURLOPT_POSTFIELDS => $postString
        );

        if(getenv('PROXY', false)) {
            $options[CURLOPT_PROXY] = getenv('PROXY');
            curl_setopt($ch, CURLOPT_PROXYPORT, getenv('PROXY_PORT'));
            curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
            curl_setopt($ch, CURLOPT_PROXYUSERPWD, getenv('PROXY_USERPWD'));
        }

        if (defined('CURLOPT_SAFE_UPLOAD')) {
            $options[CURLOPT_SAFE_UPLOAD] = true;
        }

        curl_setopt_array($ch, $options);

        Util::execute($ch);
    }
}
...