mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-01 00:47:27 -08:00
0e980f7229
* Hotfix: Disabling the event dispatcher broke model validation. This resulted in invalid data being imported. Reenable the event dispatcher for now--this causes double logs, but at least validates properly. * Actually disable the event dispatcher. * Sign in where necessary to fix the importer unit test. This catches the issues found manually in 4912
55 lines
1.6 KiB
PHP
55 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace App\Importer;
|
|
|
|
use App\Helpers\Helper;
|
|
use App\Models\Accessory;
|
|
|
|
class AccessoryImporter extends ItemImporter
|
|
{
|
|
public function __construct($filename)
|
|
{
|
|
parent::__construct($filename);
|
|
}
|
|
|
|
protected function handle($row)
|
|
{
|
|
parent::handle($row); // TODO: Change the autogenerated stub
|
|
$this->createAccessoryIfNotExists();
|
|
}
|
|
|
|
/**
|
|
* Create an accessory if a duplicate does not exist
|
|
*
|
|
* @author Daniel Melzter
|
|
* @since 3.0
|
|
*/
|
|
public function createAccessoryIfNotExists()
|
|
{
|
|
$accessory = Accessory::where('name', $this->item['name'])->first();
|
|
if ($accessory) {
|
|
if (!$this->updating) {
|
|
$this->log('A matching Accessory ' . $this->item["name"] . ' already exists. ');
|
|
return;
|
|
}
|
|
|
|
$this->log('Updating Accessory');
|
|
$accessory->update($this->sanitizeItemForUpdating($accessory));
|
|
$accessory->save();
|
|
return;
|
|
}
|
|
$this->log("No Matching Accessory, Creating a new one");
|
|
$accessory = new Accessory();
|
|
$accessory->fill($this->sanitizeItemForStoring($accessory));
|
|
|
|
//FIXME: this disables model validation. Need to find a way to avoid double-logs without breaking everything.
|
|
// $accessory->unsetEventDispatcher();
|
|
if ($accessory->save()) {
|
|
$accessory->logCreate('Imported using CSV Importer');
|
|
$this->log('Accessory ' . $this->item["name"] . ' was created');
|
|
return;
|
|
}
|
|
$this->logError($accessory, 'Accessory');
|
|
}
|
|
}
|