mirror of
https://github.com/appwrite/appwrite
synced 2026-05-24 09:28:40 +00:00
get project db key by region
This commit is contained in:
parent
29e169fe95
commit
00fc34a2a4
1 changed files with 17 additions and 21 deletions
|
|
@ -17,9 +17,6 @@ use Utopia\Validator\Text;
|
||||||
|
|
||||||
class Migrate extends Action
|
class Migrate extends Action
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @var Redis
|
|
||||||
*/
|
|
||||||
protected Redis $redis;
|
protected Redis $redis;
|
||||||
|
|
||||||
public static function getName(): string
|
public static function getName(): string
|
||||||
|
|
@ -38,20 +35,10 @@ class Migrate extends Action
|
||||||
->inject('register')
|
->inject('register')
|
||||||
->callback(fn ($version, $dbForConsole, $getProjectDB, Registry $register) => $this->action($version, $dbForConsole, $getProjectDB, $register));
|
->callback(fn ($version, $dbForConsole, $getProjectDB, Registry $register) => $this->action($version, $dbForConsole, $getProjectDB, $register));
|
||||||
|
|
||||||
$this->redis = new Redis();
|
|
||||||
$this->redis->connect(
|
|
||||||
System::getEnv('_APP_REDIS_HOST', null),
|
|
||||||
System::getEnv('_APP_REDIS_PORT', 6379),
|
|
||||||
3,
|
|
||||||
null,
|
|
||||||
10
|
|
||||||
);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function clearProjectsCache(Document $project)
|
private function clearProjectsCache(Document $project)
|
||||||
{
|
{
|
||||||
|
|
||||||
try {
|
try {
|
||||||
do {
|
do {
|
||||||
$iterator = null;
|
$iterator = null;
|
||||||
|
|
@ -64,24 +51,33 @@ class Migrate extends Action
|
||||||
}
|
}
|
||||||
} while ($iterator > 0);
|
} while ($iterator > 0);
|
||||||
|
|
||||||
|
|
||||||
} catch (\Throwable $th) {
|
} catch (\Throwable $th) {
|
||||||
Console::error('Failed to clear project ("' . $project->getId() . '") cache with error: ' . $th->getMessage());
|
Console::error('Failed to clear project ("'.$project->getId().'") cache with error: '.$th->getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function action(string $version, Database $dbForConsole, callable $getProjectDB, Registry $register)
|
public function action(string $version, Database $dbForConsole, callable $getProjectDB, Registry $register)
|
||||||
{
|
{
|
||||||
Authorization::disable();
|
Authorization::disable();
|
||||||
if (!array_key_exists($version, Migration::$versions)) {
|
if (! array_key_exists($version, Migration::$versions)) {
|
||||||
Console::error("Version {$version} not found.");
|
Console::error("Version {$version} not found.");
|
||||||
Console::exit(1);
|
Console::exit(1);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->redis = new Redis();
|
||||||
|
$this->redis->connect(
|
||||||
|
System::getEnv('_APP_REDIS_HOST', null),
|
||||||
|
System::getEnv('_APP_REDIS_PORT', 6379),
|
||||||
|
3,
|
||||||
|
null,
|
||||||
|
10
|
||||||
|
);
|
||||||
|
|
||||||
$app = new App('UTC');
|
$app = new App('UTC');
|
||||||
|
|
||||||
Console::success('Starting Data Migration to version ' . $version);
|
Console::success('Starting Data Migration to version '.$version);
|
||||||
|
|
||||||
$console = $app->getResource('console');
|
$console = $app->getResource('console');
|
||||||
|
|
||||||
|
|
@ -101,11 +97,11 @@ class Migrate extends Action
|
||||||
$totalProjects = $dbForConsole->count('projects') + 1;
|
$totalProjects = $dbForConsole->count('projects') + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$class = 'Appwrite\\Migration\\Version\\' . Migration::$versions[$version];
|
$class = 'Appwrite\\Migration\\Version\\'.Migration::$versions[$version];
|
||||||
/** @var Migration $migration */
|
/** @var Migration $migration */
|
||||||
$migration = new $class();
|
$migration = new $class();
|
||||||
|
|
||||||
while (!empty($projects)) {
|
while (! empty($projects)) {
|
||||||
foreach ($projects as $project) {
|
foreach ($projects as $project) {
|
||||||
/**
|
/**
|
||||||
* Skip user projects with id 'console'
|
* Skip user projects with id 'console'
|
||||||
|
|
@ -126,7 +122,7 @@ class Migrate extends Action
|
||||||
->setPDO($register->get('db', true))
|
->setPDO($register->get('db', true))
|
||||||
->execute();
|
->execute();
|
||||||
} catch (\Throwable $th) {
|
} catch (\Throwable $th) {
|
||||||
Console::error('Failed to update project ("' . $project->getId() . '") version with error: ' . $th->getMessage());
|
Console::error('Failed to update project ("'.$project->getId().'") version with error: '.$th->getMessage());
|
||||||
throw $th;
|
throw $th;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -139,7 +135,7 @@ class Migrate extends Action
|
||||||
$offset = $offset + $limit;
|
$offset = $offset + $limit;
|
||||||
$count = $count + $sum;
|
$count = $count + $sum;
|
||||||
|
|
||||||
Console::log('Migrated ' . $count . '/' . $totalProjects . ' projects...');
|
Console::log('Migrated '.$count.'/'.$totalProjects.' projects...');
|
||||||
}
|
}
|
||||||
|
|
||||||
Console::success('Data Migration Completed');
|
Console::success('Data Migration Completed');
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue