#!/usr/bin/env php . */ \define('INSTALLDIR', \dirname(__DIR__)); \define('PUBLICDIR', INSTALLDIR . \DIRECTORY_SEPARATOR . 'public'); $shortoptions = 'y'; $longoptions = ['yes']; $helptext = <<<'END_OF_HELP' clean_file_table.php [options] Deletes all local files where the filename cannot be found in the filesystem. -y --yes do not wait for confirmation Will print '.' for each file, except for deleted ones which are marked as 'x'. END_OF_HELP; require_once INSTALLDIR . '/scripts/commandline.inc'; if (!have_option('y', 'yes')) { echo 'About to delete local file entries where the file cannot be found. Are you sure? [y/N] '; $response = fgets(\STDIN); if (mb_strtolower(trim($response)) != 'y') { echo "Aborting.\n"; exit(0); } } echo 'Deleting'; $file = new File(); // Select local files $file->whereAdd('filename IS NOT NULL'); $file->whereAdd('url IS NULL', 'AND'); if ($file->find()) { while ($file->fetch()) { try { $file->getPath(); echo '.'; } catch (FileNotFoundException $e) { $file->delete(); echo 'x'; } } } echo "\nDONE.\n";