Browse Source

Update "storage" console command

add support to move data in 'attach' table
pull/6482/head
fabrixxm 2 years ago
committed by Hypolite Petovan
parent
commit
24d7ffa3fe
3 changed files with 21 additions and 5 deletions
  1. +18
    -2
      src/Core/Console/Storage.php
  2. +2
    -2
      src/Core/StorageManager.php
  3. +1
    -1
      src/Model/Attach.php

+ 18
- 2
src/Core/Console/Storage.php View File

@ -19,9 +19,18 @@ class Storage extends \Asika\SimpleConsole\Console
console storage - manage storage backend and stored data
Synopsis
bin/console storage [-h|--help|-?] [-v]
Show this help
bin/console storage list
List avaiable storage backends
bin/console storage set <name>
bin/console storage move
Set current storage backend
name storage backend to use. see "list".
bin/console storage move [table]
Move stored data to current storage backend.
table one of "photo" or "attach". default to both
HELP;
return $help;
}
@ -105,9 +114,16 @@ HELP;
protected function do_move()
{
if (count($this->args) !== 1) {
$table = null;
if (count($this->args) < 1 || count($this->args) > 2) {
throw new CommandArgsException('Invalid arguments');
}
if (count($this->args) == 2) {
$table = strtolower($this->args[1]);
if (!in_array($table, ['photo', 'attach'])) {
throw new CommandArgsException('Invalid table');
}
}
$current = StorageManager::getBackend();
$r = StorageManager::move($current);


+ 2
- 2
src/Core/StorageManager.php View File

@ -110,7 +110,7 @@ class StorageManager
* This method cannot move to legacy in-table `data` field.
*
* @param string $dest Destination storage class name
* @param array $tables Tables to look in for resources. Optional, defaults to ['photo']
* @param array $tables Tables to look in for resources. Optional, defaults to ['photo', 'attach']
*
* @retur int Number of moved resources
*/
@ -121,7 +121,7 @@ class StorageManager
}
if (is_null($tables)) {
$tables = ['photo'];
$tables = ['photo', 'attach'];
}
$moved = 0;


+ 1
- 1
src/Model/Attach.php View File

@ -224,7 +224,7 @@ class Attach extends BaseObject
$data = @file_get_contents($src);
return self::store($data, $uid, $filename, '', null, $allow_cid, $allow_gid, $deny_cid, $deny_gid);
return self::store($data, $uid, $filename, '', null, $allow_cid, $allow_gid, $deny_cid, $deny_gid);
}


Loading…
Cancel
Save