mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 16:42:54 -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);
 | |
|     }
 | |
| }
 |