lander931 / log-reader
Log Reader
v1.0.0
2018-09-08 12:35 UTC
Requires
- php: >=5.4
Requires (Dev)
- php: ^5.4
- phpunit/phpunit: ^4
This package is auto-updated.
Last update: 2024-04-08 21:48:13 UTC
README
Описание
log-reader позволяет считывать лог файлы. В результате вы получаете массив, содержимое которого вы сами определили.
Пример результата
array(2) {
[0] => object(LogEntity) {
["date"] => "2018-01-01"
["time"] => "15:00:00"
["message"] => "log 1"
}
[1] => object(LogEntity) {
["date"] => "2018-01-01"
["time"] => "15:00:05"
["message"] => "log 2"
}
}
Объект LogEntity это пример, вы можете формировать любой результат, из любых своих объектов.
Установка
php composer require lander931/log-reader
Использование
Пример исходного лога
2018-01-01 15:00:00 log 1
2018-01-01 15:00:05 log 2
Чтение лога
Передать в LogReader::read содержимое файла лога, и функцию разбиения лога на части, функция должна вернуть массив.
$reader = LogReader::read($log_content, function($text) { return explode("\n", $text); })
Фомирование результата
Для формирования результата, используйте buildEntries. На вход, функция принимает текст одной записи лога. В функции вы должны обработать текст одной записи лога, сформировать и вернуть результат в любом виде (например объект или массив).
$reader->buildEntries(function ($log){ $pattern = "/\[(\d{4}-\d{2}-\d{2}) (\d{2}:\d{2}:\d{2})\] (.+)/"; preg_match_all($pattern, $log, $matches, PREG_SET_ORDER); $date = $matches[0][1]; $time = $matches[0][2]; $message = $matches[0][3]; return new LogEntity($date, $time, $message); });
Получение результата
$res = $reader->getEntries();
Если вы не обрабатывали каждую запить лога, то вернётся массив разбитого на частии лога.