X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FConsole%2FStorage.php;h=ea9f5ae20d2e7f2928a8606a75774b7452cda32b;hb=d4a5a8051ad34a7be72238967afb3e6b140afdc8;hp=d0a2a66637a19c831997cbded40832ec42c29dfd;hpb=e8cae804600d7dc7d21174d1bbd4476f9d65b8e0;p=friendica.git diff --git a/src/Console/Storage.php b/src/Console/Storage.php index d0a2a66637..ea9f5ae20d 100644 --- a/src/Console/Storage.php +++ b/src/Console/Storage.php @@ -1,6 +1,6 @@ getOption('v')) { $this->out('Executable: ' . $this->executable); @@ -104,7 +106,7 @@ HELP; $this->out(sprintf($rowfmt, 'Sel', 'Name')); $this->out('-----------------------'); $isregisterd = false; - foreach ($this->storageManager->listBackends() as $name => $class) { + foreach ($this->storageManager->listBackends() as $name) { $issel = ' '; if ($current && $current::getName() == $name) { $issel = '*'; @@ -126,23 +128,23 @@ HELP; protected function doSet() { - if (count($this->args) !== 2) { + if (count($this->args) !== 2 || empty($this->args[1])) { throw new CommandArgsException('Invalid arguments'); } $name = $this->args[1]; - $class = $this->storageManager->getByName($name); + try { + $class = $this->storageManager->getWritableStorageByName($name); - if ($class === '') { + if (!$this->storageManager->setBackend($class)) { + $this->out($class . ' is not a valid backend storage class.'); + return -1; + } + } catch (ReferenceStorageException $exception) { $this->out($name . ' is not a registered backend.'); return -1; } - if (!$this->storageManager->setBackend($class)) { - $this->out($class . ' is not a valid backend storage class.'); - return -1; - } - return 0; } @@ -165,6 +167,10 @@ HELP; $current = $this->storageManager->getBackend(); $total = 0; + if (is_null($current)) { + throw new StorageException(sprintf("Cannot move to legacy storage. Please select a storage backend.")); + } + do { $moved = $this->storageManager->move($current, $tables, $this->getOption('n', 5000)); if ($moved) {