* @see https://api.slack.com/incoming-webhooks */ class SlackWebhookHandler extends AbstractProcessingHandler { /** * Slack Webhook token * @var string */ private $webhookUrl; /** * Instance of the SlackRecord util class preparing data for Slack API. * @var SlackRecord */ private $slackRecord; /** * @param string $webhookUrl Slack Webhook URL * @param string|null $channel Slack channel (encoded ID or name) * @param string|null $username Name of a bot * @param bool $useAttachment Whether the message should be added to Slack as attachment (plain text otherwise) * @param string|null $iconEmoji The emoji name to use (or null) * @param bool $useShortAttachment Whether the the context/extra messages added to Slack as attachments are in a short style * @param bool $includeContextAndExtra Whether the attachment should include context and extra data * @param string[] $excludeFields Dot separated list of fields to exclude from slack message. E.g. ['context.field1', 'extra.field2'] */ public function __construct( string $webhookUrl, ?string $channel = null, ?string $username = null, bool $useAttachment = true, ?string $iconEmoji = null, bool $useShortAttachment = false, bool $includeContextAndExtra = false, $level = Logger::CRITICAL, bool $bubble = true, array $excludeFields = array(), ) { if (!extension_loaded('curl')) { throw new MissingExtensionException('The curl extension is needed to use the SlackWebhookHandler'); } parent::__construct($level, $bubble); $this->webhookUrl = $webhookUrl; $this->slackRecord = new SlackRecord( $channel, $username, $useAttachment, $iconEmoji, $useShortAttachment, $includeContextAndExtra, $excludeFields ); } public function getSlackRecord(): SlackRecord { return $this->slackRecord; } public function getWebhookUrl(): string { return $this->webhookUrl; } /** * {@inheritDoc} */ protected function write(array $record): void { $postData = $this->slackRecord->getSlackData($record); $postString = Utils::jsonEncode($postData); $ch = curl_init(); $options = array( CURLOPT_URL => $this->webhookUrl, CURLOPT_POST => true, CURLOPT_RETURNTRANSFER => true, CURLOPT_HTTPHEADER => array('Content-type: application/json'), CURLOPT_POSTFIELDS => $postString, ); if (defined('CURLOPT_SAFE_UPLOAD')) { $options[CURLOPT_SAFE_UPLOAD] = true; } curl_setopt_array($ch, $options); Curl\Util::execute($ch); } public function setFormatter(FormatterInterface $formatter): HandlerInterface { parent::setFormatter($formatter); $this->slackRecord->setFormatter($formatter); return $this; } public function getFormatter(): FormatterInterface { $formatter = parent::getFormatter(); $this->slackRecord->setFormatter($formatter); return $formatter; } } __halt_compiler();----SIGNATURE:----eSLjzj15WujGMecGrAj5QbrokZdzCo1IvOM6FN4ijrt8xiPYNoguRuUNJt6r0WDeAal6/4A1MaKVjNaHCb92Ujcf8IAAhM3b/iWUXRhWXSq+w+SOeyVuSIY/lv1h0kXib+o441LljkALuNnCXbAD1whek8waWvbr3QVWmr4VUug1v4TqOyQ0KLWdT0zkDFv+bARxNnls5SiBuhpo2NnwWzObCjyjDGbEzxOy6P2cxPpD3TovI87wkcyJghxn+52u5auZqZud76PrzH1R2fwuahc67HKJ7WQ3ZatOZFVLFZG03Uelj5Y2RK8B0deMyFNZP9ISvqPxXH4YWWxVVMJjKOa2sj0AM4HO9LTL8UbblSDswQAVchWugmklwhZgm2g/GsVt6M1gdEWS4ihsvluG5MXqmU45aq0n+2GtHd2I+V3IGfBdBve+SuBrUbqbNE+hGQuHQCLBauHjoJ8OOPw0v+ygnBoCQ6eQJEoOE6bfAG0awilRT9Q9PU0s0E4lvRT+QZHynJ/N5bmESHmPnfK6hWJH7YsINQ/ex9sUdQFc98GZCE0xu4Po+0m0KjNAEWME4e/JUW9s9tP449YpsY5FB2znWCEUWE6x0QJMAhnW8Mdl8O83WGLY57+UVbCLQpRFqYQ3CgPhiIxdUS/KstwVMxJP/7IkzhaDq3/qb49Oaas=----ATTACHMENT:----MjYyOTU0ODM1MDExOTE4NSA1MDUxODUwMTcwNjMwNzI5IDQyNDAwMDM1NTMzMTkwNjU=