1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Plugins\CoreUpdater\Commands\Update;
use Piwik\Updater\Migration;
use Piwik\Updater\UpdateObserver;
use Symfony\Component\Console\Output\OutputInterface;
/**
* UpdateObserver used to output progress of an update initiated on the command line. Prints the currently
* executing query and the total number of queries to run.
*
* @package CoreUpdater
*/
class CliUpdateObserver extends UpdateObserver
{
/**
* @var OutputInterface
*/
private $output;
/**
* @var int
*/
private $totalMigrationQueryCount;
/**
* @var int
*/
private $currentMigrationQueryExecutionCount = 0;
public function __construct(OutputInterface $output, $totalMigrationQueryCount)
{
$this->output = $output;
$this->totalMigrationQueryCount = $totalMigrationQueryCount;
}
public function onStartExecutingMigration($updateFile, Migration $migration)
{
$string = $migration->__toString();
$this->output->write(" Executing <comment>$string</comment>... ");
++$this->currentMigrationQueryExecutionCount;
}
public function onFinishedExecutingMigration($updateFile, Migration $migration)
{
$this->output->writeln("Done. <info>[{$this->currentMigrationQueryExecutionCount} / {$this->totalMigrationQueryCount}]</info>");
}
}
|