infinitesoftware / is-log-bundle
Funny logger based on MongoDB
Installs: 775
Dependents: 0
Suggesters: 0
Security: 0
Type:symfony-bundle
pkg:composer/infinitesoftware/is-log-bundle
Requires
- php: >=7.1
- doctrine/mongodb-odm-bundle: ^3.3
- symfony/symfony: ^3.4
- twig/extensions: ^1.5
This package is auto-updated.
Last update: 2025-09-29 01:44:07 UTC
README
Requirements
- You should have configured MongoDB where logs will be written, using doctrine/mongodb-odm-bundle.
- twig/extensions should be installed. Do not forget in app/services.yml define a service after bundle installation: - twig.extension.intl: class: Twig_Extensions_Extension_Intl tags: - { name: twig.extension }
Installation
- composer require infinitesoftware/is-log-bundle
- Modify AppKernel.php as always: - // app/AppKernel.php // ... class AppKernel extends Kernel { // ... public function registerBundles() { $bundles = array( // ... new InfiniteSoftware\Bundle\ISLogBundle\ISLogBundle(), ); // ... } }
- Add parameters to app/config.yml: - is_log: email: 'lol@example.com' # (Not mandatory) email where log entries will be sent component_name: 'main' # (Mandatory) system's name where log is used
- In app/routing_dev.yml include: - is_log: resource: "@ISLogBundle/Resources/config/routing.yml" prefix: /log- Now you can visit the log by url: .../app_dev.php/log If you see page without css run in terminal: php bin/console assets:install --symlink 
Usage
Exists three types of log:
- SystemLog
- TraderLog
- AdminLog
- TransactionLog
To write to any of this log you need service from the bundle - ISLogManager. For example in your Action you can do:
public function indexAction(LogManager $logManager)
{
        // $logManager = $this->get('is_log.manager.log_manager');
        
        $logManager->logSysEntry(LogManager::STATUS_WARNING, 'my warning msg');
        $logManager->logAdminEntry(LogManager::STATUS_INFO, 4, 'ban', 'user is banned', null, '#test');
        $logManager->logTraderEntry(LogManager::STATUS_INFO, 13, 'log in', 'trader is logged in');
        $logManager->logTxEntry(LogManager::STATUS_INFO, 13, 'Exchange', 144, 'received', false, 'money is received');
        // Exception automatically will be written to System Log.
        // Return passed exception, so it can be thrown, e.g.
        // throw $logManager->ex(new LogicException('My exception'));
        $logManager->ex(new LogicException('My exception'));
        // ...
 }