Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
itismadness afb9fc8a4f wrap getLanguage call with try/catch and fallback to en default 4 lat temu
bin Include all necessary dependencies 6 lat temu
scripts complete more major work for 0.9.0 release 4 lat temu
src wrap getLanguage call with try/catch and fallback to en default 4 lat temu
tests improve handling of unknown non-UTF8 EAC logs 4 lat temu
.gitignore improve translations of it an pl 4 lat temu
.travis.yml fix deploy for travis 4 lat temu
LICENSE.md Add license and two additional log testcases 6 lat temu
README.md update usage example in README 4 lat temu
composer.json 0.9.3 4 lat temu
composer.lock v0.9.2 release 4 lat temu
phpcs.xml Massive refactor of logchecker 4 lat temu
phpstan.neon Massive refactor of logchecker 4 lat temu
phpunit.xml complete more major work for 0.9.0 release 4 lat temu

README.md

Logchecker

A CD rip logchecker, used for analyzing the generated logs for any problems that would potentially indicate a non-perfect rip was produced. Of course, just because a log doesn’t score a perfect 100% does not mean that the produced rip isn’t bit perfect, it’s just less likely. While this library can largely run on both Linux and Windows, validating of checksums is only really supported for Linux.

While this library will analyze most parts of a log, unfortunately it cannot properly validate the checksums for all types of logs. This is due to creators of these programs making their logchecker closed source and involves some amount of custom mathematical work to produce it. Therefore, we have to fallback on external methods to validate the checksums of EAC and XLD. If the logchecker detects that we do not have the necessary programs, then we will just skip this external step and assume the checksum is valid. For setting up the necessary programs to validate the checksum, see below for the given program you care about.

Requirements

  • PHP 7.0+

Optional Requirements

pip3 install cchardet eac-logchecker xld-logchecker

Standalone

Installation

Go to our releases and grab the logchecker.phar file. Download this file, and then it can executed via CLI by running php logchecker.phar. Alternatively, if you chmod +x logchecker.phar, it can be executed directly by doing ./logchecker.phar.

To install it globally, run:

mv logchecker.phar /usr/local/bin/logchecker
chmod +x /usr/local/bin/logchecker

Usage

$ logchecker --help
Usage:
  analyze [options] [--] <file>

Arguments:
  file                  Log file to analyze

Options:
      --output          Print the HTML log text
  -h, --help            Display this help message
  -q, --quiet           Do not output any message
  -V, --version         Display this application version
      --ansi            Force ANSI output
      --no-ansi         Disable ANSI output
  -n, --no-interaction  Do not ask any interactive question
  -file, --out=OUT      File to write HTML log text to
  -v|vv|vvv, --verbose  Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug

Help:
  This command analyzes a log file

$ logchecker tests/logs/wgdbcm.log
Score   : 57
Checksum: checksum_missing
Details :
    [Notice] Translated log from Русский (Russian) to English.
    EAC version older than 0.99 (-30 points)
    Could not verify read mode (-1 point)
    Could not verify read offset (-1 point)
    Could not verify null samples
    Could not verify gap handling (-10 points)
    Could not verify id3 tag setting (-1 point)

Code

<?php

$logchecker = new OrpheusNET\Logchecker\Logchecker();
$logchecker->add_file('path/to/file.log');
list($score, $details, $checksum_state, $log_text) = $logchecker->parse();

Library Usage

Installation

composer require orpheusnet/logchecker

Usage

<?php

require __DIR__ . '/vendor/autoload.php';

use OrpheusNET\Logchecker\Logchecker;

$logchecker = new Logchecker();
$logchecker->newFile('/path/to/log/file');
$logchecker->parse();
print('Ripper   : ' . $logchecker->getRipper() . "\n");
print('Version  : ' . $logchecker->getRipperVersion() . "\n");
print('Score    : ' . $logchecker->getScore() . "\n");
print('Checksum : ' . $logchecker->getChecksumState() . "\n");
print("\nDetails:\n");
foreach ($logchecker->getDetails() as $detail) {
    print("  {$detail}\n");
}
print("\nLog Text:\n\n{$logchecker->getLog()}");

Building

To build your own phar, you can checkout this repository, and then run the bin/compile script. To do this, run the following commands:

git clone https://github.com/OPSnet/Logchecker
cd Logchecker
composer install
php -d phar.readonly=0 bin/compile