szjani/predaddy

Convert to PSR-3 logger methods

Closed this issue · 5 comments

Hi @szjani

We're getting deprecated notices for warn in SimpleMessageBus.

Would your advice be to use https://github.com/szjani/lf4php-psr3 or do you plan to convert the lf4php Logger interface to Psr\Log\LoggerInterface and therefore update predaddy?

Thanks,
Doug

Hi @redthor,

I don't understand what notices you get. Which lf4php binder (lf4php-psr3?) and logging framework do you use when this issue happens?

It seems it's rather an lf4php issue than a predaddy one, but let's clarify it here.

I don't know how you got that notice, I think you may misconfigured something.

Predaddy does not depend on PSR-3, it depends on lf4php. lf4php is also an API just like PSR-3, but it has several extra features. It was designed before PSR-3 was released. It is not and never will be a PSR-3 implementation.

To use a logging framework through lf4php API, you need a logging framework of course and a proper lf4php binder. If you use monolog for instance, you can use the lf4php-monolog binder. lf4php-psr3 is also a binder which can be used for monolog (since that is a PSR-3 implementation), but PSR-3 definitely provides much less features than monolog directly, so I highly recommend to use monolog with lf4php-monolog.

Any logging framework you use, predaddy will depend on lf4php. It means it's your responsibility to pull a proper lf4php binder which will be used as a bridge between lf4php and the framework itself. If you don't define a binder as a dependency, lf4php will use NOPLoggerFactory, eventually predaddy will not log anything.

For more info please check lf4php documentation: https://github.com/szjani/lf4php

If your issue is still valid, please give some more details. Thanks.

Thanks @szjani

This is the actual error:

php.INFO: The Symfony\Bridge\Monolog\Logger::warn method inherited from the Symfony\Component\HttpKernel\Log\LoggerInterface interface is deprecated since version 2.2 and will be removed in 3.0. Use the warning() method instead, which is PSR-3 compatible.

here is part of the call stack:

{
    "stack": [
        {
            "class": "Symfony\\Component\\Debug\\ErrorHandler",
            "function": "handleError",
            "type": "->"
        },
        {
            "file": "tmp/cache/int_test/classes.php",
            "function": "trigger_error",
            "line": 3497
        },
        {
            "class": "Symfony\\Bridge\\Monolog\\Logger",
            "file": "www/vendor/lf4php/lf4php-monolog/src/lf4php/impl/MonologLoggerAdapter.php",
            "function": "warn",
            "line": 119,
            "type": "->"
        },
        {
            "class": "lf4php\\impl\\MonologLoggerAdapter",
            "file": "www/vendor/predaddy/predaddy/src/predaddy/messagehandling/SimpleMessageBus.php",
            "function": "warn",
            "line": 190,
            "type": "->"
        },
        {
            "class": "predaddy\\messagehandling\\SimpleMessageBus",
            "file": "www/vendor/predaddy/predaddy/src/predaddy/messagehandling/InterceptableMessageBus.php",
            "function": "dispatch",
            "line": 92,
            "type": "->"
        },
        {
            "class": "predaddy\\messagehandling\\InterceptableMessageBus",
            "function": "predaddy\\messagehandling\\{closure}",
            "type": "->"
        },

Should we just use your PSR-3 adapter?
Thanks

Thank you, now it's clear.

I've found the following class which extends \Monolog\Logger: https://github.com/symfony/monolog-bridge/blob/2.8/Logger.php

It is a great example of violating the Liskov Substitution Principle. The maintainers should be informed about it.

Anyway, since it is not a big deal to change in the monolog binder, I've already done it. Please use version 3.1.2: https://github.com/szjani/lf4php-monolog/releases/tag/3.1.2

Thank you for the issue. If you still have any problems, don't hesitate to repoen this issue.

great job, thanks!