123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- <?php
- declare(strict_types=1);
- /**
- * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace OCP\UserMigration;
- use OCP\Files\Folder;
- /**
- * @since 24.0.0
- */
- interface IImportSource {
- /**
- * @since 24.0.0
- */
- public const PATH_USER = 'user.json';
- /**
- * Reads a file from the export
- *
- * @param string $path Full path to the file in the export archive.
- * @return string The full content of the file.
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function getFileContents(string $path): string;
- /**
- * Reads a file from the export as a stream
- *
- * @param string $path Full path to the file in the export archive.
- * @return resource A stream resource to read from to get the file content.
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function getFileAsStream(string $path);
- /**
- * List the files of a folder
- *
- * @param string $path Full path to the folder in the export archive.
- * @return array The list of files.
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function getFolderListing(string $path): array;
- /**
- * Test if a path exists, which may be a file or a folder
- *
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function pathExists(string $path): bool;
- /**
- * Copy files from the export to a Folder
- *
- * Folder $destination folder to copy into
- * string $sourcePath path in the export archive
- *
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function copyToFolder(Folder $destination, string $sourcePath): void;
- /**
- * @return array<string,int> Migrators and their versions from the export archive.
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function getMigratorVersions(): array;
- /**
- * @return ?int Version for this migrator from the export archive. Null means migrator missing.
- * @throws UserMigrationException
- * @param string $migrator Migrator id (as returned by IMigrator::getId)
- *
- * @since 24.0.0
- */
- public function getMigratorVersion(string $migrator): ?int;
- /**
- * Get original uid of the imported account
- *
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function getOriginalUid(): string;
- /**
- * Called after import is complete
- *
- * @throws UserMigrationException
- *
- * @since 24.0.0
- */
- public function close(): void;
- }
|