Importer fixes v2 (#3524)

* Pave the imports table

* Format error response if file is the wrong type.

* If a custom field doesn't exist, don't insert a blank string into the custom fields table

* CustomField::db_column_name can return the stored name in the db.  It's slugified when that value is set initially.  This fixes a weird issue where _1 was replaced with _xx
This commit is contained in:
Daniel Meltzer 2017-05-03 14:14:35 -05:00 committed by snipe
parent f6be7caaeb
commit e9b056f66c
5 changed files with 11 additions and 8 deletions

View file

@ -72,6 +72,7 @@ class PaveIt extends Command
Statuslabel::getQuery()->delete(); Statuslabel::getQuery()->delete();
Supplier::getQuery()->delete(); Supplier::getQuery()->delete();
Group::getQuery()->delete(); Group::getQuery()->delete();
Import::getQuery()->delete();
DB::statement('delete from accessories_users'); DB::statement('delete from accessories_users');
DB::statement('delete from asset_logs'); DB::statement('delete from asset_logs');
@ -131,6 +132,7 @@ class PaveIt extends Command
\DB::statement('drop table IF EXISTS throttle'); \DB::statement('drop table IF EXISTS throttle');
\DB::statement('drop table IF EXISTS users_groups'); \DB::statement('drop table IF EXISTS users_groups');
\DB::statement('drop table IF EXISTS users'); \DB::statement('drop table IF EXISTS users');
\DB::statement('drop table IF EXISTS imports');
} }
} }
} }

View file

@ -45,7 +45,6 @@ class ImportController extends Controller
$results = []; $results = [];
$import = new Import; $import = new Import;
foreach ($files as $file) { foreach ($files as $file) {
if (!in_array($file->getMimeType(), array( if (!in_array($file->getMimeType(), array(
'application/vnd.ms-excel', 'application/vnd.ms-excel',
'text/csv', 'text/csv',
@ -53,7 +52,7 @@ class ImportController extends Controller
'text/comma-separated-values', 'text/comma-separated-values',
'text/tsv'))) { 'text/tsv'))) {
$results['error']='File type must be CSV'; $results['error']='File type must be CSV';
return $results; return response()->json(Helper::formatStandardApiResponse('error', null, $results['error']), 500);
} }
$date = date('Y-m-d-his'); $date = date('Y-m-d-his');
@ -132,7 +131,7 @@ class ImportController extends Controller
try { try {
unlink(config('app.private_uploads').'/imports/'.$import->file_path); unlink(config('app.private_uploads').'/imports/'.$import->file_path);
$import->delete(); $import->delete();
return response()->json(Helper::formatStandardApiResponse('success', null, trans('message.import.file_delete_success'))); return response()->json(Helper::formatStandardApiResponse('success', null, trans('admin/hardware/message.import.file_delete_success')));
} catch (\Exception $e) { } catch (\Exception $e) {
return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/hardware/message.import.file_delete_error')), 500); return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/hardware/message.import.file_delete_error')), 500);
} }

View file

@ -24,8 +24,10 @@ class AssetImporter extends ItemImporter
parent::handle($row); parent::handle($row);
foreach ($this->customFields as $customField) { foreach ($this->customFields as $customField) {
if ($this->item['custom_fields'][$customField->db_column_name()] = $this->array_smart_custom_field_fetch($row, $customField)) { $customFieldValue = $this->array_smart_custom_field_fetch($row, $customField);
$this->log('Custom Field '. $customField->name.': '.$this->array_smart_custom_field_fetch($row, $customField)); if ($customFieldValue) {
$this->item['custom_fields'][$customField->db_column_name()] = $customFieldValue;
$this->log('Custom Field '. $customField->name.': '.$customFieldValue);
} }
} }
@ -87,7 +89,6 @@ class AssetImporter extends ItemImporter
$asset->{$custom_field} = $val; $asset->{$custom_field} = $val;
} }
} }
if (!$this->testRun) { if (!$this->testRun) {
if ($asset->save()) { if ($asset->save()) {
$asset->logCreate('Imported using csv importer'); $asset->logCreate('Imported using csv importer');

View file

@ -133,7 +133,7 @@ abstract class Importer
public function array_smart_custom_field_fetch(array $array, $key) public function array_smart_custom_field_fetch(array $array, $key)
{ {
$index_name = strtolower($key->name); $index_name = strtolower($key->name);
return array_key_exists($index_name, $array) ? e(trim($array[$index_name])) : ''; return array_key_exists($index_name, $array) ? e(trim($array[$index_name])) : false;
} }
protected function log($string) protected function log($string)

View file

@ -101,7 +101,8 @@ class CustomField extends Model
public function db_column_name() public function db_column_name()
{ {
return self::convertUnicodeDbSlug(); return $this->db_column;
// return self::convertUnicodeDbSlug();
} }
//mutators for 'format' attribute //mutators for 'format' attribute