From b37050f3d3ecbb161d46d677e3fba9d4fe10f023 Mon Sep 17 00:00:00 2001 From: fogelito Date: Wed, 9 Oct 2024 12:24:09 +0300 Subject: [PATCH 1/2] Return if fails --- src/Migration/Sources/Appwrite.php | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/Migration/Sources/Appwrite.php b/src/Migration/Sources/Appwrite.php index 44392d5..ca14951 100644 --- a/src/Migration/Sources/Appwrite.php +++ b/src/Migration/Sources/Appwrite.php @@ -541,6 +541,8 @@ protected function exportGroupDatabases(int $batchSize, array $resources): void previous: $e ) ); + + return; } try { @@ -557,6 +559,8 @@ protected function exportGroupDatabases(int $batchSize, array $resources): void previous: $e ) ); + + return; } try { @@ -573,6 +577,8 @@ protected function exportGroupDatabases(int $batchSize, array $resources): void previous: $e ) ); + + return; } try { @@ -589,6 +595,8 @@ protected function exportGroupDatabases(int $batchSize, array $resources): void previous: $e ) ); + + return; } try { @@ -605,6 +613,8 @@ protected function exportGroupDatabases(int $batchSize, array $resources): void previous: $e ) ); + + return; } } From b230c8b1e78749eb7b881763d2e5a4e11797dc50 Mon Sep 17 00:00:00 2001 From: fogelito Date: Wed, 9 Oct 2024 12:40:48 +0300 Subject: [PATCH 2/2] validate UID --- src/Migration/Destinations/Appwrite.php | 37 ++++++++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/src/Migration/Destinations/Appwrite.php b/src/Migration/Destinations/Appwrite.php index f9c38e5..4c971f3 100644 --- a/src/Migration/Destinations/Appwrite.php +++ b/src/Migration/Destinations/Appwrite.php @@ -25,6 +25,7 @@ use Utopia\Database\Query; use Utopia\Database\Validator\Index as IndexValidator; use Utopia\Database\Validator\Structure; +use Utopia\Database\Validator\UID; use Utopia\Migration\Destination; use Utopia\Migration\Exception; use Utopia\Migration\Resource; @@ -302,7 +303,7 @@ public function importDatabaseResource(Resource $resource, bool $isLast): Resour /** * @throws AuthorizationException * @throws StructureException - * @throws DatabaseException + * @throws DatabaseException|Exception */ protected function createDatabase(Database $resource): bool { @@ -310,6 +311,17 @@ protected function createDatabase(Database $resource): bool ? ID::unique() : $resource->getId(); + $validator = new UID(); + + if ($validator->isValid($resourceId)) { + throw new Exception( + resourceName: $resource->getName(), + resourceGroup: $resource->getGroup(), + resourceId: $resource->getId(), + message: $validator->getDescription(), + ); + } + $resource->setId($resourceId); $database = $this->database->createDocument('databases', new UtopiaDocument([ @@ -354,6 +366,17 @@ protected function createCollection(Collection $resource): bool ? ID::unique() : $resource->getId(); + $validator = new UID(); + + if ($validator->isValid($resourceId)) { + throw new Exception( + resourceName: $resource->getName(), + resourceGroup: $resource->getGroup(), + resourceId: $resource->getId(), + message: $validator->getDescription(), + ); + } + $resource->setId($resourceId); $database = $this->database->getDocument( @@ -865,9 +888,21 @@ protected function createIndex(Index $resource): bool * @throws AuthorizationException * @throws DatabaseException * @throws StructureException + * @throws Exception */ protected function createDocument(Document $resource, bool $isLast): bool { + $validator = new UID(); + + if ($validator->isValid($resource->getId())) { + throw new Exception( + resourceName: $resource->getName(), + resourceGroup: $resource->getGroup(), + resourceId: $resource->getId(), + message: $validator->getDescription(), + ); + } + // Check if document has already been created $exists = \array_key_exists( $resource->getId(),