summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/command/maintenance/repair.php13
-rw-r--r--lib/private/repair.php46
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;
}
+
}