user()->is(auth()->user()), 403); } $csv = Writer::createFromFileObject(new SplTempFileObject); $csv->setOutputBOM(Bom::Utf8); $firstFailedRow = $import->failedRows()->first(); $columnHeaders = $firstFailedRow ? array_keys($firstFailedRow->data) : []; $columnHeaders[] = __('filament-actions::import.failure_csv.error_header'); $csv->insertOne($columnHeaders); $import->failedRows() ->lazyById(100) ->each(fn (FailedImportRow $failedImportRow) => $csv->insertOne([ ...$failedImportRow->data, 'error' => $failedImportRow->validation_error ?? __('filament-actions::import.failure_csv.system_error'), ])); return response()->streamDownload(function () use ($csv) { foreach ($csv->chunk(1000) as $offset => $chunk) { echo $chunk; if ($offset % 1000) { flush(); } } }, __('filament-actions::import.failure_csv.file_name', [ 'import_id' => $import->getKey(), 'csv_name' => (string) str($import->file_name)->beforeLast('.')->remove('.'), ]) . '.csv', [ 'Content-Type' => 'text/csv', ]); } }