<?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; }