mirror of
https://github.com/appwrite/appwrite
synced 2026-05-23 08:58:35 +00:00
chore: added migration script
This commit is contained in:
parent
0dba22c606
commit
c1b613e5bd
2 changed files with 84 additions and 0 deletions
|
|
@ -92,6 +92,7 @@ abstract class Migration
|
||||||
'1.5.11' => 'V20',
|
'1.5.11' => 'V20',
|
||||||
'1.6.0' => 'V21',
|
'1.6.0' => 'V21',
|
||||||
'1.6.1' => 'V21',
|
'1.6.1' => 'V21',
|
||||||
|
'1.6.2' => 'V22',
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
83
src/Appwrite/Migration/Version/V22.php
Normal file
83
src/Appwrite/Migration/Version/V22.php
Normal file
|
|
@ -0,0 +1,83 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Appwrite\Migration\Version;
|
||||||
|
|
||||||
|
use Appwrite\Migration\Migration;
|
||||||
|
use Exception;
|
||||||
|
use Throwable;
|
||||||
|
use Utopia\CLI\Console;
|
||||||
|
use Utopia\Database\Database;
|
||||||
|
|
||||||
|
class V22 extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @throws Throwable
|
||||||
|
*/
|
||||||
|
public function execute(): void
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Disable SubQueries for Performance.
|
||||||
|
*/
|
||||||
|
foreach (['subQueryIndexes', 'subQueryPlatforms', 'subQueryDomains', 'subQueryKeys', 'subQueryWebhooks', 'subQuerySessions', 'subQueryTokens', 'subQueryMemberships', 'subQueryVariables', 'subQueryChallenges', 'subQueryProjectVariables', 'subQueryTargets', 'subQueryTopicTargets'] as $name) {
|
||||||
|
Database::addFilter(
|
||||||
|
$name,
|
||||||
|
fn () => null,
|
||||||
|
fn () => []
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
Console::info('Migrating Collections');
|
||||||
|
$this->migrateCollections();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Migrate Collections.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @throws Exception|Throwable
|
||||||
|
*/
|
||||||
|
private function migrateCollections(): void
|
||||||
|
{
|
||||||
|
$internalProjectId = $this->project->getInternalId();
|
||||||
|
$collectionType = match ($internalProjectId) {
|
||||||
|
'console' => 'console',
|
||||||
|
default => 'projects',
|
||||||
|
};
|
||||||
|
|
||||||
|
$collections = $this->collections[$collectionType];
|
||||||
|
foreach ($collections as $collection) {
|
||||||
|
$id = $collection['$id'];
|
||||||
|
|
||||||
|
Console::log("Migrating Collection \"{$id}\"");
|
||||||
|
|
||||||
|
$this->projectDB->setNamespace("_$internalProjectId");
|
||||||
|
|
||||||
|
switch ($id) {
|
||||||
|
case 'installations':
|
||||||
|
// Create personalAccessToken attribute
|
||||||
|
try {
|
||||||
|
$this->createAttributeFromCollection($this->projectDB, $id, 'personalAccessToken');
|
||||||
|
} catch (Throwable $th) {
|
||||||
|
Console::warning("'personalAccessToken' from {$id}: {$th->getMessage()}");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create personalAccessTokenExpiry attribute
|
||||||
|
try {
|
||||||
|
$this->createAttributeFromCollection($this->projectDB, $id, 'personalAccessTokenExpiry');
|
||||||
|
} catch (Throwable $th) {
|
||||||
|
Console::warning("'personalAccessTokenExpiry' from {$id}: {$th->getMessage()}");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create personalRefreshToken attribute
|
||||||
|
try {
|
||||||
|
$this->createAttributeFromCollection($this->projectDB, $id, 'personalRefreshToken');
|
||||||
|
} catch (Throwable $th) {
|
||||||
|
Console::warning("'personalRefreshToken' from {$id}: {$th->getMessage()}");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
usleep(50000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in a new issue