diff options
-rw-r--r-- | core/command/maintenance/repair.php | 13 | ||||
-rw-r--r-- | lib/private/repair.php | 46 |
2 files changed, 56 insertions, 3 deletions
diff --git a/core/command/maintenance/repair.php b/core/command/maintenance/repair.php index 310c01fbe2a..43ae6479eb0 100644 --- a/core/command/maintenance/repair.php +++ b/core/command/maintenance/repair.php @@ -33,9 +33,22 @@ class Repair extends Command { } protected function execute(InputInterface $input, OutputInterface $output) { + \OC_DB::enableCaching(false); + $maintenanceMode = \OC_Config::getValue('maintenance', false); + \OC_Config::setValue('maintenance', true); + $this->repair->listen('\OC\Repair', 'step', function ($description) use ($output) { $output->writeln(' - ' . $description); }); + $this->repair->listen('\OC\Repair', 'info', function ($description) use ($output) { + $output->writeln(' - ' . $description); + }); + $this->repair->listen('\OC\Repair', 'error', function ($description) use ($output) { + $output->writeln(' - ERROR: ' . $description); + }); + $this->repair->run(); + + \OC_Config::setValue('maintenance', $maintenanceMode); } } diff --git a/lib/private/repair.php b/lib/private/repair.php index e9de3baa7ce..4a155c403a6 100644 --- a/lib/private/repair.php +++ b/lib/private/repair.php @@ -11,11 +11,51 @@ namespace OC; use OC\Hooks\BasicEmitter; class Repair extends BasicEmitter { + private $stepClasses; + /** - * run a series of repair steps for common problems - * progress can be reported by emitting \OC\Repair::step events + * Creates a new repair step runner + * + * @param array $stepClasses optional list of step classes + */ + public function __construct($stepClasses = array()) { + $this->stepClasses = $stepClasses; + } + + /** + * Run a series of repair steps for common problems */ public function run() { - $this->emit('\OC\Repair', 'step', array('No repair steps configured at the moment')); + $steps = array(); + + // instantiate all classes, just to make + // sure they all exist before starting + foreach ($this->stepClasses as $className) { + $steps[] = new $className(); + } + + $self = $this; + // run each repair step + foreach ($steps as $step) { + $this->emit('\OC\Repair', 'step', array($step->getName())); + + $step->listen('\OC\Repair', 'error', function ($description) use ($self) { + $self->emit('\OC\Repair', 'error', array($description)); + }); + $step->listen('\OC\Repair', 'info', function ($description) use ($self) { + $self->emit('\OC\Repair', 'info', array($description)); + }); + $step->run(); + } + } + + /** + * Add repair step class + * + * @param string $className name of a repair step class + */ + public function addStep($className) { + $this->stepClasses[] = $className; } + } |