mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-13 06:47:46 -08:00
44683c784f
* Major code simplification of the importers. Move towards using Model::fill and Model::update rather than reinventing the wheel. This makes the updating/creating logic a lot clearer, and allows for the deletion of a lot of code. Also allows for supporting of more fields in the future really easily. * Cleanup constructors and use setters instead. * Set the LC_MONETARY locale, and use it to strip currency symbols in Helper::parseFloat() * Move licenseseat creation/deletion logic into an event handler on the model rather than the controller. * Move the logging of parsed values to array_smart_fetch rather than writing it out everywhere * Move to storing dates as carbon rather than strings. Allows for the parsing of more arbitrary strings from the importer * Add a license importer with support for checking out to users or assets. * Make a directory for sample/mock import csvs and populate it * Adjust how we store/retrieve dates to fix some issues the tests found.
81 lines
2.5 KiB
PHP
81 lines
2.5 KiB
PHP
<?php
|
|
|
|
namespace App\Importer;
|
|
|
|
use App\Models\Asset;
|
|
use App\Models\Component;
|
|
|
|
class ComponentImporter extends ItemImporter
|
|
{
|
|
protected $components;
|
|
public function __construct($filename)
|
|
{
|
|
parent::__construct($filename);
|
|
$this->components = Component::all();
|
|
}
|
|
|
|
protected function handle($row)
|
|
{
|
|
parent::handle($row);
|
|
$this->createComponentIfNotExists();
|
|
}
|
|
|
|
/**
|
|
* Create a component if a duplicate does not exist
|
|
*
|
|
* @author Daniel Melzter
|
|
* @since 3.0
|
|
*/
|
|
public function createComponentIfNotExists()
|
|
{
|
|
$component = null;
|
|
$editingComponent = false;
|
|
$this->log("Creating Component");
|
|
$componentId = $this->components->search(function ($key) {
|
|
return strcasecmp($key->name, $this->item['name']) == 0;
|
|
});
|
|
|
|
if ($componentId !== false) {
|
|
$editingComponent = true;
|
|
$this->log('A matching Component ' . $this->item["name"] . ' already exists. ');
|
|
if (!$this->updating) {
|
|
$this->log("Skipping Component");
|
|
return;
|
|
}
|
|
$this->log("Updating Component");
|
|
$component = $this->components[$componentId];
|
|
$component->update($this->sanitizeItemFor($component));
|
|
if (!$this->testRun) {
|
|
$component->save();
|
|
}
|
|
return;
|
|
}
|
|
$this->log("No matching component, creating one");
|
|
$component = new Component;
|
|
$component->fill($$this->sanitizeItemForStoring($component));
|
|
|
|
if ($this->testRun) {
|
|
$this->log('TEST RUN - Component ' . $this->item["name"] . ' not created');
|
|
return;
|
|
}
|
|
|
|
if ($component->save()) {
|
|
$component->logCreate('Imported using CSV Importer');
|
|
$this->log("Component " . $this->item["name"] . ' was created');
|
|
|
|
// If we have an asset tag, checkout to that asset.
|
|
if (isset($this->item['asset_tag']) && ($asset = Asset::where('asset_tag', $this->item['asset_tag'])->first())) {
|
|
$component->assets()->attach($component->id, [
|
|
'component_id' => $component->id,
|
|
'user_id' => $this->user_id,
|
|
'created_at' => date('Y-m-d H:i:s'),
|
|
'assigned_qty' => 1, // Only assign the first one to the asset
|
|
'asset_id' => $asset->id
|
|
]);
|
|
}
|
|
return;
|
|
}
|
|
$this->jsonError($component, 'Component');
|
|
}
|
|
}
|