. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Http\ViewResponseTrait; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Services\TreeService; use League\Flysystem\FilesystemInterface; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function array_map; use function assert; 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 = $request->getAttribute('filesystem.data'); assert($data_filesystem instanceof FilesystemInterface); $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 = array_map(static function (array $content) { if ($content['type'] === 'dir') { return $content['path'] . '/'; } return $content['path']; }, $data_filesystem->listContents()); return $this->viewResponse('admin/clean-data', [ 'title' => I18N::translate('Clean up data folder'), 'entries' => $entries, 'protected' => $protected, ]); } }