The documentation you are viewing is for an older version of this component.
            Switch to the latest (v5) version.
        
The following conforms to the PSR-3: Logger Interface document.
The log levels are in order of priority/importance:
Although the plain Logger in dot-log is not fully compatible with PSR-3, it provides a way to log all of these message types.
The following example has three file writers using filters:
FileWriter - All messages are logged in /log/dk.logOnlyWarningsWriter - Only warnings are logged in /log/warnings.logWarningOrHigherWriter - All important messages (warnings or critical) are logged in /log/important_messages.log<?php
return [
    'dot_log' => [
        'loggers' => [
            'my_logger' => [
                'writers' => [
                    'FileWriter' => [
                        'name' => 'FileWriter',
                        'priority' => \Dot\Log\Logger::ALERT,
                        'options' => [
                            'stream' => __DIR__ . '/../../log/dk.log',
                            'filters' => [
                                'allMessages' => [
                                    'name' => 'priority',
                                    'options' => [
                                        'operator' => '>=', 
                                        'priority' => \Dot\Log\Logger::EMERG,
                                    ]
                                ],
                            ],
                        ],
                    ],
                    // Only warnings
                    'OnlyWarningsWriter' => [
                        'name' => 'stream',
                        'priority' => \Dot\Log\Logger::ALERT,
                        'options' => [
                            'stream' => __DIR__ . '/../../log/warnings_only.log',
                            'filters' => [
                                'warningOnly' => [
                                    'name' => 'priority',
                                    'options' => [
                                        'operator' => '==',
                                        'priority' => \Dot\Log\Logger::WARN,
                                    ],
                                ],
                            ],
                        ],
                    ],
                    // Warnings and more important messages
                    'WarningOrHigherWriter' => [
                        'name' => 'stream',
                        'priority' => \Dot\Log\Logger::ALERT,
                        'options' => [
                            'stream' => __DIR__ . '/../../log/important_messages.log',
                            'filters' => [
                                'importantMessages' => [
                                    'name' => 'priority',
                                    'options' => [
                                        // note, the smaller the priority, the more important the message
                                        // 0 - emergency, 1 - alert, 2- error, 3 - warn, etc.
                                        'operator' => '<=',
                                        'priority' => \Dot\Log\Logger::WARN,
                                    ],
                                ],
                            ],
                        ],
                    ],
                ],
            ],
        ],
    ],
];As in the writer configuration, the developer can optionally use keys for associating the filters with a name.
The operator for more important messages is
<=, this is because the number representation is smaller for a more important message type.
The filter added on the first writer is equivalent to not setting a filter, but it was added to illustrate the usage of the operator to explicitly allow all messages.