mirror of
https://github.com/snipe/snipe-it.git
synced 2024-12-31 16:37: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
54 lines
1.6 KiB
PHP
54 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace App\Importer;
|
|
|
|
use App\Helpers\Helper;
|
|
use App\Models\Consumable;
|
|
|
|
class ConsumableImporter extends ItemImporter
|
|
{
|
|
public function __construct($filename)
|
|
{
|
|
parent::__construct($filename);
|
|
}
|
|
|
|
protected function handle($row)
|
|
{
|
|
parent::handle($row); // TODO: Change the autogenerated stub
|
|
$this->createConsumableIfNotExists();
|
|
}
|
|
|
|
/**
|
|
* Create a consumable if a duplicate does not exist
|
|
*
|
|
* @author Daniel Melzter
|
|
* @since 3.0
|
|
*/
|
|
public function createConsumableIfNotExists()
|
|
{
|
|
$consumable = Consumable::where('name', $this->item['name'])->first();
|
|
if ($consumable) {
|
|
if (!$this->updating) {
|
|
$this->log('A matching Consumable ' . $this->item["name"] . ' already exists. ');
|
|
return;
|
|
}
|
|
$this->log('Updating Consumable');
|
|
$consumable->update($this->sanitizeItemForUpdating($consumable));
|
|
$consumable->save();
|
|
return;
|
|
}
|
|
$this->log("No matching consumable, creating one");
|
|
$consumable = new Consumable();
|
|
$consumable->fill($this->sanitizeItemForStoring($consumable));
|
|
//FIXME: this disables model validation. Need to find a way to avoid double-logs without breaking everything.
|
|
$consumable->unsetEventDispatcher();
|
|
if ($consumable->save()) {
|
|
$consumable->logCreate('Imported using CSV Importer');
|
|
$this->log("Consumable " . $this->item["name"] . ' was created');
|
|
return;
|
|
}
|
|
$this->logError($consumable, 'Consumable');
|
|
return;
|
|
}
|
|
}
|