. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Http\ViewResponseTrait; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Registry; use Fisharebest\Webtrees\Services\TreeService; use League\Flysystem\Filesystem; use League\Flysystem\StorageAttributes; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function array_map; use function explode; /** * Show old files that could be deleted. */ class CleanDataFolder implements RequestHandlerInterface { use ViewResponseTrait; /** @var TreeService */ private $tree_service; /** * CleanDataFolder constructor. * * @param TreeService $tree_service */ public function __construct(TreeService $tree_service) { $this->tree_service = $tree_service; } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $data_filesystem = Registry::filesystem()->data(); $this->layout = 'layouts/administration'; $protected = [ '.htaccess', '.gitignore', 'index.php', 'config.ini.php', ]; if ($request->getAttribute('dbtype') === 'sqlite') { $protected[] = $request->getAttribute('dbname') . '.sqlite'; } // Protect the media folders foreach ($this->tree_service->all() as $tree) { $media_directory = $tree->getPreference('MEDIA_DIRECTORY'); [$folder] = explode('/', $media_directory); $protected[] = $folder . '/'; } // List the top-level contents of the data folder $entries = $data_filesystem->listContents('', Filesystem::LIST_SHALLOW) ->map(static function (StorageAttributes $attributes): string { if ($attributes->isDir()) { return $attributes->path() . '/'; } return $attributes->path(); }); return $this->viewResponse('admin/clean-data', [ 'title' => I18N::translate('Clean up data folder'), 'entries' => $entries, 'protected' => $protected, ]); } }