info('This will only rebuild the cache for track files which exist on disk; non-existent files will be skipped.'); if ($this->option('force') || $this->confirm('Are you sure you want to rebuild the filesize cache? [y|N]', false) ) { TrackFile::chunk(200, function ($trackFiles) { $this->info('========== Start Chunk =========='); foreach ($trackFiles as $trackFile) { $file = $trackFile->getFile(); if (File::exists($file)) { $size = File::size($file); $this->info('ID ' . $trackFile->id . ' processed - ' . $size . ' bytes'); } else { $size = null; $this->info('ID ' . $trackFile->id . ' skipped'); } $trackFile->filesize = $size; $trackFile->update(); } $this->info('=========== End Chunk ==========='); }); $this->info('Rebuild complete. Exiting.'); } else { $this->info('Rebuild cancelled. Exiting.'); } } }