monolog-bundle icon indicating copy to clipboard operation
monolog-bundle copied to clipboard

Add support for new handlers

Open Seldaek opened this issue 12 years ago • 27 comments

Missing handlers:

  • [x] mongodb
  • [ ] couchdb / doctrinecouchdb
  • [x] elasticsearch / elastica
  • [ ] dynamodb
  • [x] syslogd
  • [x] loggly
  • [x] browserconsole (might need to be made the default in the standard edition if it works well)
  • [x] filter
  • [x] flowdock
  • [x] rollbar
  • [x] whatfailuregroup
  • [ ] mandrill
  • [x] slack
  • [ ] fleephook
  • [x] sampling

Seldaek avatar Apr 23 '12 16:04 Seldaek

It looks like ChromePHP and Gelf support are now included, so I'd like to add support for the MongoDB handler, but I'm not sure of the best approach. Following the existing handler config would give something like:

<?php
// ..... snip ....

case 'mongodb':
    $definition->setArguments(array(
        new \Mongo($handler['host']),
        $handler['database'],
        $handler['collection'],
        $handler['level'],
        $handler['bubble'],
    ));
    break;

and allow a config like:

monolog:
    handlers:
        main:
            type:  stream
            path:  %kernel.logs_dir%/%kernel.environment%.log
            level: debug
        mongo:
            type: mongodb
            host: mongodb://localhost:27017
            database: logs
            collection: prod
            level: debug
            bubble: true

Creating the Mongo instance there is clearly not the correct way to do it, but I don't know the Service or DI layers well enough to know how to inject it correctly? Also, if I'm using Doctrine MongoDB ODM, it would be nice to be able to reuse the connection thats already been configured for that so that I don't have to maintain two separate configs.

Any ideas?

wheelsandcogs avatar Jul 23 '12 13:07 wheelsandcogs

We could have an id: @foo.bar instead of host: mongodb://localhost:27017 (though that should also remain possible IMO if you only use mongo for logging). If it's provided you just use a new Reference($handler['id']) instead of that new Mongo.

You can look at the Gelf config for inspiration: https://github.com/symfony/MonologBundle/blob/master/DependencyInjection/MonologExtension.php#L133-148

Seldaek avatar Aug 09 '12 23:08 Seldaek

@Seldaek I've tried to implement this as you described, however I end up with a circular reference.

The problem is that Doctrine\MongoDB\Connection only returns a \Mongo object after it has been initialised (with the method initialize and that at that point Doctrine requires a Monolog logger.

Any suggestions how this can be implemented?

florianeckerstorfer avatar Sep 17 '12 15:09 florianeckerstorfer

@florianeckerstorfer you have to use a mongo connection with logging disabled if you want to get it from the doctrine connection.

stof avatar Sep 17 '12 16:09 stof

Is anyone working in mongodb handler?

pacoVela avatar Oct 03 '13 11:10 pacoVela

I don't think so. I looked into it but it seemed non-trivial to wire up the doctrine mongo stuff etc so I gave up. If you'd like to give it a shot it would be much appreciated.

Seldaek avatar Oct 03 '13 15:10 Seldaek

I'm wondering if doctrine is really necessary here. We can make the connection with a simple service, or directly with host/port/user/pass params. So you can use the same params for doctrine and monolog configurations, but it's only a matter of taste.

I agree with you that it is not trivial to do it with doctrine.

pacoVela avatar Oct 04 '13 14:10 pacoVela

My concern was duplicating the config if you were already using doctrine, and possibly the overhead of having another connection just for logging. Obviously it would be nicer to re-use the existing config and connection if possible, but I'd rather have a working mongodb handler with extra config than no handler at all.

wheelsandcogs avatar Oct 04 '13 14:10 wheelsandcogs

Using params you don't have to repeat the literals for database host, and user... So you're true, the only caveat here is the overhead by the existence of another connection. In my case this is needed because we use a server just for logs.

pacoVela avatar Oct 08 '13 10:10 pacoVela

I have the mongodb basic implementation ready to merge, (without doctrine stuff). https://github.com/pacoVela/MonologBundle

pacoVela avatar Oct 09 '13 07:10 pacoVela

It looks like the list in the initial description isn't up to date anymore?

kingcrunch avatar May 13 '14 18:05 kingcrunch

@KingCrunch care to elaborate? I usually try to update it but maybe I missed one.

Seldaek avatar May 14 '14 06:05 Seldaek

@Seldaek I meant the list in this PR (above). I cannot edit that.

kingcrunch avatar May 14 '14 09:05 kingcrunch

Yes I can update it but what is not up to date exactly?

Seldaek avatar May 14 '14 09:05 Seldaek

I will add here the errbit / airbrake handler if its possible.

emgiezet avatar Jun 03 '14 15:06 emgiezet

@emgiezet not sure what these have to do with monolog? Are there handlers out there somewhere that I don't know of?

Seldaek avatar Jun 03 '14 16:06 Seldaek

I've just submitted https://github.com/symfony/MonologBundle/pull/92 for Slack support. Also submitted https://github.com/Seldaek/monolog/pull/377 @Seldaek to add support to monolog SlackHandler for the emoji icons used by Slack.

Example conifg:

slack:
            type: slack
            token: xxxxxxx
            channel: C9342CD
            bot_name: YourBotName
            use_attachment: true
            icon_emoji: monkey_face
            level: error

fotomerchant avatar Aug 22 '14 05:08 fotomerchant

Support for the WhatFailureGroupHandler is in #107.

mpdude avatar Oct 28 '14 10:10 mpdude

Is there any way Rocket.Chat can be added to this list?

moonbeamglitterblossom avatar Sep 08 '20 09:09 moonbeamglitterblossom

I found a RocketChat Monolog handler that may simplify integration with Symfony: https://github.com/exileed/rocketchat-monolog by @exileed

PSF1 avatar Nov 09 '21 16:11 PSF1

I'm working in a RocketChat integration pull request.

PSF1 avatar Nov 10 '21 11:11 PSF1

Monolog project don't want add RocketChat support into main project: https://github.com/Seldaek/monolog/issues/1310 Could monolog-bundle reference the @exileed's handler?

PSF1 avatar Nov 10 '21 11:11 PSF1

Define a service for your handler and use the service type in the MonologBundle config

stof avatar Nov 10 '21 11:11 stof

This way? https://symfony.com/doc/current/logging/handlers.html

# config/packages/prod/monolog.yaml
monolog:
    handlers:
        es:
            type: service
            id: Symfony\Bridge\Monolog\Handler\ElasticsearchLogstashHandler

PSF1 avatar Nov 10 '21 12:11 PSF1

yes, exactly.

stof avatar Nov 10 '21 12:11 stof

Thx so much :_ D

I have it working with less problems...

PSF1 avatar Nov 10 '21 12:11 PSF1

Support for SamplingHandler is in #471

Okhoshi avatar Nov 06 '23 14:11 Okhoshi