mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-10-24 03:19:21 -04:00
153 lines
5.9 KiB
PHP
153 lines
5.9 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use Illuminate\Http\Request;
|
|
use App\Services\ImportService;
|
|
use App\Jobs\ImportData;
|
|
use Exception;
|
|
use Input;
|
|
use Redirect;
|
|
use Session;
|
|
use Utils;
|
|
use View;
|
|
use Auth;
|
|
|
|
class ImportController extends BaseController
|
|
{
|
|
public function __construct(ImportService $importService)
|
|
{
|
|
$this->importService = $importService;
|
|
}
|
|
|
|
public function doImport(Request $request)
|
|
{
|
|
if (! Auth::user()->confirmed) {
|
|
return redirect('/settings/' . ACCOUNT_IMPORT_EXPORT)->withError(trans('texts.confirm_account_to_import'));
|
|
}
|
|
|
|
$source = Input::get('source');
|
|
$files = [];
|
|
$timestamp = time();
|
|
|
|
foreach (ImportService::$entityTypes as $entityType) {
|
|
$fileName = $entityType;
|
|
if ($request->hasFile($fileName)) {
|
|
$file = $request->file($fileName);
|
|
$destinationPath = env('FILE_IMPORT_PATH') ?: storage_path() . '/import';
|
|
$extension = strtolower($file->getClientOriginalExtension());
|
|
|
|
if ($source === IMPORT_CSV) {
|
|
if ($extension != 'csv') {
|
|
return redirect()->to('/settings/' . ACCOUNT_IMPORT_EXPORT)->withError(trans('texts.invalid_file'));
|
|
}
|
|
} elseif ($source === IMPORT_JSON) {
|
|
if ($extension != 'json') {
|
|
return redirect()->to('/settings/' . ACCOUNT_IMPORT_EXPORT)->withError(trans('texts.invalid_file'));
|
|
}
|
|
} else {
|
|
if (! in_array($extension, ['csv', 'xls', 'xlsx', 'json'])) {
|
|
return redirect()->to('/settings/' . ACCOUNT_IMPORT_EXPORT)->withError(trans('texts.invalid_file'));
|
|
}
|
|
}
|
|
|
|
$newFileName = sprintf('%s_%s_%s.%s', Auth::user()->account_id, $timestamp, $fileName, $extension);
|
|
$file->move($destinationPath, $newFileName);
|
|
$files[$entityType] = $destinationPath . '/' . $newFileName;
|
|
}
|
|
}
|
|
|
|
if (! count($files)) {
|
|
Session::flash('error', trans('texts.select_file'));
|
|
return Redirect::to('/settings/' . ACCOUNT_IMPORT_EXPORT);
|
|
}
|
|
|
|
try {
|
|
if ($source === IMPORT_CSV) {
|
|
$data = $this->importService->mapCSV($files);
|
|
return View::make('accounts.import_map', [
|
|
'data' => $data,
|
|
'timestamp' => $timestamp,
|
|
]);
|
|
} elseif ($source === IMPORT_JSON) {
|
|
$includeData = filter_var(Input::get('data'), FILTER_VALIDATE_BOOLEAN);
|
|
$includeSettings = filter_var(Input::get('settings'), FILTER_VALIDATE_BOOLEAN);
|
|
if (config('queue.default') === 'sync') {
|
|
$results = $this->importService->importJSON($files[IMPORT_JSON], $includeData, $includeSettings);
|
|
$message = $this->importService->presentResults($results, $includeSettings);
|
|
} else {
|
|
$settings = [
|
|
'files' => $files,
|
|
'include_data' => $includeData,
|
|
'include_settings' => $includeSettings,
|
|
];
|
|
$this->dispatch(new ImportData(Auth::user(), IMPORT_JSON, $settings));
|
|
$message = trans('texts.import_started');
|
|
}
|
|
} else {
|
|
if (config('queue.default') === 'sync') {
|
|
$results = $this->importService->importFiles($source, $files);
|
|
$message = $this->importService->presentResults($results);
|
|
} else {
|
|
$settings = [
|
|
'files' => $files,
|
|
'source' => $source,
|
|
];
|
|
$this->dispatch(new ImportData(Auth::user(), false, $settings));
|
|
$message = trans('texts.import_started');
|
|
}
|
|
}
|
|
return redirect('/settings/' . ACCOUNT_IMPORT_EXPORT)->withWarning($message);
|
|
} catch (Exception $exception) {
|
|
Utils::logError($exception);
|
|
Session::flash('error', $exception->getMessage());
|
|
|
|
return Redirect::to('/settings/' . ACCOUNT_IMPORT_EXPORT);
|
|
}
|
|
}
|
|
|
|
public function doImportCSV()
|
|
{
|
|
try {
|
|
$map = Input::get('map');
|
|
$headers = Input::get('headers');
|
|
$timestamp = Input::get('timestamp');
|
|
|
|
if (config('queue.default') === 'sync') {
|
|
$results = $this->importService->importCSV($map, $headers, $timestamp);
|
|
$message = $this->importService->presentResults($results);
|
|
} else {
|
|
$settings = [
|
|
'timestamp' => $timestamp,
|
|
'map' => $map,
|
|
'headers' => $headers,
|
|
];
|
|
$this->dispatch(new ImportData(Auth::user(), IMPORT_CSV, $settings));
|
|
$message = trans('texts.import_started');
|
|
}
|
|
|
|
return redirect('/settings/' . ACCOUNT_IMPORT_EXPORT)->withWarning($message);
|
|
} catch (Exception $exception) {
|
|
Utils::logError($exception);
|
|
Session::flash('error', $exception->getMessage());
|
|
|
|
return Redirect::to('/settings/' . ACCOUNT_IMPORT_EXPORT);
|
|
}
|
|
}
|
|
|
|
public function cancelImport()
|
|
{
|
|
try {
|
|
$path = env('FILE_IMPORT_PATH') ?: storage_path() . '/import';
|
|
foreach ([ENTITY_CLIENT, ENTITY_INVOICE, ENTITY_PAYMENT, ENTITY_QUOTE, ENTITY_PRODUCT] as $entityType) {
|
|
$fileName = sprintf('%s/%s_%s_%s.csv', $path, Auth::user()->account_id, request()->timestamp, $entityType);
|
|
\File::delete($fileName);
|
|
}
|
|
} catch (Exception $exception) {
|
|
Utils::logError($exception);
|
|
}
|
|
|
|
return Redirect::to('/settings/' . ACCOUNT_IMPORT_EXPORT);
|
|
}
|
|
}
|