mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-25 12:41:16 -08:00
Merge remote-tracking branch 'origin/v3' into v3-master
This commit is contained in:
commit
5daaa24a07
|
@ -1,5 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
namespace App\Console\Commands;
|
namespace App\Console\Commands;
|
||||||
|
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use App\Models\Location;
|
use App\Models\Location;
|
||||||
use App\Models\Category;
|
use App\Models\Category;
|
||||||
|
@ -13,7 +14,8 @@ use Symfony\Component\Console\Input\InputArgument;
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
use League\Csv\Reader;
|
use League\Csv\Reader;
|
||||||
|
|
||||||
class AssetImportCommand extends Command {
|
class AssetImportCommand extends Command
|
||||||
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command name.
|
* The console command name.
|
||||||
|
@ -72,91 +74,91 @@ class AssetImportCommand extends Command {
|
||||||
// Let's just map some of these entries to more user friendly words
|
// Let's just map some of these entries to more user friendly words
|
||||||
|
|
||||||
// User's name
|
// User's name
|
||||||
if (array_key_exists('0',$row)) {
|
if (array_key_exists('0', $row)) {
|
||||||
$user_name = trim($row[0]);
|
$user_name = trim($row[0]);
|
||||||
} else {
|
} else {
|
||||||
$user_name = '';
|
$user_name = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// User's email
|
// User's email
|
||||||
if (array_key_exists('1',$row)) {
|
if (array_key_exists('1', $row)) {
|
||||||
$user_email = trim($row[1]);
|
$user_email = trim($row[1]);
|
||||||
} else {
|
} else {
|
||||||
$user_email = '';
|
$user_email = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// User's email
|
// User's email
|
||||||
if (array_key_exists('2',$row)) {
|
if (array_key_exists('2', $row)) {
|
||||||
$user_username = trim($row[2]);
|
$user_username = trim($row[2]);
|
||||||
} else {
|
} else {
|
||||||
$user_username = '';
|
$user_username = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset Name
|
// Asset Name
|
||||||
if (array_key_exists('3',$row)) {
|
if (array_key_exists('3', $row)) {
|
||||||
$user_asset_asset_name = trim($row[3]);
|
$user_asset_asset_name = trim($row[3]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_asset_name = '';
|
$user_asset_asset_name = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset Category
|
// Asset Category
|
||||||
if (array_key_exists('4',$row)) {
|
if (array_key_exists('4', $row)) {
|
||||||
$user_asset_category = trim($row[4]);
|
$user_asset_category = trim($row[4]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_category = '';
|
$user_asset_category = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset Name
|
// Asset Name
|
||||||
if (array_key_exists('5',$row)) {
|
if (array_key_exists('5', $row)) {
|
||||||
$user_asset_name = trim($row[5]);
|
$user_asset_name = trim($row[5]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_name = '';
|
$user_asset_name = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset Manufacturer
|
// Asset Manufacturer
|
||||||
if (array_key_exists('6',$row)) {
|
if (array_key_exists('6', $row)) {
|
||||||
$user_asset_mfgr = trim($row[6]);
|
$user_asset_mfgr = trim($row[6]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_mfgr = '';
|
$user_asset_mfgr = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset model number
|
// Asset model number
|
||||||
if (array_key_exists('7',$row)) {
|
if (array_key_exists('7', $row)) {
|
||||||
$user_asset_modelno = trim($row[7]);
|
$user_asset_modelno = trim($row[7]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_modelno = '';
|
$user_asset_modelno = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset serial number
|
// Asset serial number
|
||||||
if (array_key_exists('8',$row)) {
|
if (array_key_exists('8', $row)) {
|
||||||
$user_asset_serial = trim($row[8]);
|
$user_asset_serial = trim($row[8]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_serial = '';
|
$user_asset_serial = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset tag
|
// Asset tag
|
||||||
if (array_key_exists('9',$row)) {
|
if (array_key_exists('9', $row)) {
|
||||||
$user_asset_tag = trim($row[9]);
|
$user_asset_tag = trim($row[9]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_tag = '';
|
$user_asset_tag = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset location
|
// Asset location
|
||||||
if (array_key_exists('10',$row)) {
|
if (array_key_exists('10', $row)) {
|
||||||
$user_asset_location = trim($row[10]);
|
$user_asset_location = trim($row[10]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_location = '';
|
$user_asset_location = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset notes
|
// Asset notes
|
||||||
if (array_key_exists('11',$row)) {
|
if (array_key_exists('11', $row)) {
|
||||||
$user_asset_notes = trim($row[11]);
|
$user_asset_notes = trim($row[11]);
|
||||||
} else {
|
} else {
|
||||||
$user_asset_notes = '';
|
$user_asset_notes = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset purchase date
|
// Asset purchase date
|
||||||
if (array_key_exists('12',$row)) {
|
if (array_key_exists('12', $row)) {
|
||||||
if ($row[12]!='') {
|
if ($row[12]!='') {
|
||||||
$user_asset_purchase_date = date("Y-m-d 00:00:01", strtotime($row[12]));
|
$user_asset_purchase_date = date("Y-m-d 00:00:01", strtotime($row[12]));
|
||||||
} else {
|
} else {
|
||||||
|
@ -167,7 +169,7 @@ class AssetImportCommand extends Command {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset purchase cost
|
// Asset purchase cost
|
||||||
if (array_key_exists('13',$row)) {
|
if (array_key_exists('13', $row)) {
|
||||||
if ($row[13]!='') {
|
if ($row[13]!='') {
|
||||||
$user_asset_purchase_cost = trim($row[13]);
|
$user_asset_purchase_cost = trim($row[13]);
|
||||||
} else {
|
} else {
|
||||||
|
@ -178,7 +180,7 @@ class AssetImportCommand extends Command {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Asset Company Name
|
// Asset Company Name
|
||||||
if (array_key_exists('14',$row)) {
|
if (array_key_exists('14', $row)) {
|
||||||
if ($row[14]!='') {
|
if ($row[14]!='') {
|
||||||
$user_asset_company_name = trim($row[14]);
|
$user_asset_company_name = trim($row[14]);
|
||||||
} else {
|
} else {
|
||||||
|
@ -277,8 +279,7 @@ class AssetImportCommand extends Command {
|
||||||
|
|
||||||
$location = new Location();
|
$location = new Location();
|
||||||
|
|
||||||
if ($user_asset_location!='')
|
if ($user_asset_location!='') {
|
||||||
{
|
|
||||||
$location->name = e($user_asset_location);
|
$location->name = e($user_asset_location);
|
||||||
$location->address = '';
|
$location->address = '';
|
||||||
$location->city = '';
|
$location->city = '';
|
||||||
|
@ -295,14 +296,10 @@ class AssetImportCommand extends Command {
|
||||||
$this->error($location->getErrors());
|
$this->error($location->getErrors());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
$this->comment('Location '.$user_asset_location.' was (not) created - test run only');
|
$this->comment('Location '.$user_asset_location.' was (not) created - test run only');
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
$this->comment('No location given, so none created.');
|
$this->comment('No location given, so none created.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -463,6 +460,4 @@ class AssetImportCommand extends Command {
|
||||||
array('testrun', null, InputOption::VALUE_REQUIRED, 'Test the output without writing to the database or not.', null),
|
array('testrun', null, InputOption::VALUE_REQUIRED, 'Test the output without writing to the database or not.', null),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@ namespace App\Console\Commands;
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
use App\Models\Setting;
|
use App\Models\Setting;
|
||||||
|
|
||||||
|
|
||||||
class DisableLDAP extends Command
|
class DisableLDAP extends Command
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -10,7 +10,8 @@ use App\Models\Supplier;
|
||||||
use App\Models\License;
|
use App\Models\License;
|
||||||
use App\Models\LicenseSeat;
|
use App\Models\LicenseSeat;
|
||||||
|
|
||||||
class LicenseImportCommand extends Command {
|
class LicenseImportCommand extends Command
|
||||||
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command name.
|
* The console command name.
|
||||||
|
@ -68,55 +69,55 @@ class LicenseImportCommand extends Command {
|
||||||
|
|
||||||
// Let's just map some of these entries to more user friendly words
|
// Let's just map some of these entries to more user friendly words
|
||||||
|
|
||||||
if (array_key_exists('0',$row)) {
|
if (array_key_exists('0', $row)) {
|
||||||
$user_name = trim($row[0]);
|
$user_name = trim($row[0]);
|
||||||
} else {
|
} else {
|
||||||
$user_name = '';
|
$user_name = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('1',$row)) {
|
if (array_key_exists('1', $row)) {
|
||||||
$user_email = trim($row[1]);
|
$user_email = trim($row[1]);
|
||||||
} else {
|
} else {
|
||||||
$user_email = '';
|
$user_email = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('2',$row)) {
|
if (array_key_exists('2', $row)) {
|
||||||
$user_username = trim($row[2]);
|
$user_username = trim($row[2]);
|
||||||
} else {
|
} else {
|
||||||
$user_username = '';
|
$user_username = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('3',$row)) {
|
if (array_key_exists('3', $row)) {
|
||||||
$user_license_name = trim($row[3]);
|
$user_license_name = trim($row[3]);
|
||||||
} else {
|
} else {
|
||||||
$user_license_name = '';
|
$user_license_name = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('4',$row)) {
|
if (array_key_exists('4', $row)) {
|
||||||
$user_license_serial = trim($row[4]);
|
$user_license_serial = trim($row[4]);
|
||||||
} else {
|
} else {
|
||||||
$user_license_serial = '';
|
$user_license_serial = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('5',$row)) {
|
if (array_key_exists('5', $row)) {
|
||||||
$user_licensed_to_name = trim($row[5]);
|
$user_licensed_to_name = trim($row[5]);
|
||||||
} else {
|
} else {
|
||||||
$user_licensed_to_name = '';
|
$user_licensed_to_name = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('6',$row)) {
|
if (array_key_exists('6', $row)) {
|
||||||
$user_licensed_to_email = trim($row[6]);
|
$user_licensed_to_email = trim($row[6]);
|
||||||
} else {
|
} else {
|
||||||
$user_licensed_to_email = '';
|
$user_licensed_to_email = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('7',$row)) {
|
if (array_key_exists('7', $row)) {
|
||||||
$user_license_seats = trim($row[7]);
|
$user_license_seats = trim($row[7]);
|
||||||
} else {
|
} else {
|
||||||
$user_license_seats = '';
|
$user_license_seats = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('8',$row)) {
|
if (array_key_exists('8', $row)) {
|
||||||
$user_license_reassignable = trim($row[8]);
|
$user_license_reassignable = trim($row[8]);
|
||||||
if ($user_license_reassignable!='') {
|
if ($user_license_reassignable!='') {
|
||||||
if ((strtolower($user_license_reassignable)=='yes') || (strtolower($user_license_reassignable)=='true') || ($user_license_reassignable=='1')) {
|
if ((strtolower($user_license_reassignable)=='yes') || (strtolower($user_license_reassignable)=='true') || ($user_license_reassignable=='1')) {
|
||||||
|
@ -129,13 +130,13 @@ class LicenseImportCommand extends Command {
|
||||||
$user_license_reassignable = 0;
|
$user_license_reassignable = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('9',$row)) {
|
if (array_key_exists('9', $row)) {
|
||||||
$user_license_supplier = trim($row[9]);
|
$user_license_supplier = trim($row[9]);
|
||||||
} else {
|
} else {
|
||||||
$user_license_supplier = '';
|
$user_license_supplier = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('10',$row)) {
|
if (array_key_exists('10', $row)) {
|
||||||
$user_license_maintained = trim($row[10]);
|
$user_license_maintained = trim($row[10]);
|
||||||
|
|
||||||
if ($user_license_maintained!='') {
|
if ($user_license_maintained!='') {
|
||||||
|
@ -151,13 +152,13 @@ class LicenseImportCommand extends Command {
|
||||||
$user_license_maintained = '';
|
$user_license_maintained = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('11',$row)) {
|
if (array_key_exists('11', $row)) {
|
||||||
$user_license_notes = trim($row[11]);
|
$user_license_notes = trim($row[11]);
|
||||||
} else {
|
} else {
|
||||||
$user_license_notes = '';
|
$user_license_notes = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('12',$row)) {
|
if (array_key_exists('12', $row)) {
|
||||||
if ($row[12]!='') {
|
if ($row[12]!='') {
|
||||||
$user_license_purchase_date = date("Y-m-d 00:00:01", strtotime($row[12]));
|
$user_license_purchase_date = date("Y-m-d 00:00:01", strtotime($row[12]));
|
||||||
} else {
|
} else {
|
||||||
|
@ -191,18 +192,18 @@ class LicenseImportCommand extends Command {
|
||||||
$email_last_name = $last_name;
|
$email_last_name = $last_name;
|
||||||
$email_prefix = $first_name;
|
$email_prefix = $first_name;
|
||||||
} else {
|
} else {
|
||||||
$last_name = str_replace($first_name,'',$user_name);
|
$last_name = str_replace($first_name, '', $user_name);
|
||||||
|
|
||||||
if ($this->option('email_format')=='filastname') {
|
if ($this->option('email_format')=='filastname') {
|
||||||
$email_last_name.=str_replace(' ','',$last_name);
|
$email_last_name.=str_replace(' ', '', $last_name);
|
||||||
$email_prefix = $first_name[0].$email_last_name;
|
$email_prefix = $first_name[0].$email_last_name;
|
||||||
|
|
||||||
} elseif ($this->option('email_format')=='firstname.lastname') {
|
} elseif ($this->option('email_format')=='firstname.lastname') {
|
||||||
$email_last_name.=str_replace(' ','',$last_name);
|
$email_last_name.=str_replace(' ', '', $last_name);
|
||||||
$email_prefix = $first_name.'.'.$email_last_name;
|
$email_prefix = $first_name.'.'.$email_last_name;
|
||||||
|
|
||||||
} elseif ($this->option('email_format')=='firstname') {
|
} elseif ($this->option('email_format')=='firstname') {
|
||||||
$email_last_name.=str_replace(' ','',$last_name);
|
$email_last_name.=str_replace(' ', '', $last_name);
|
||||||
$email_prefix = $first_name;
|
$email_prefix = $first_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -218,7 +219,7 @@ class LicenseImportCommand extends Command {
|
||||||
$status_id = 7;
|
$status_id = 7;
|
||||||
}
|
}
|
||||||
$email = strtolower($email_prefix).'@'.$this->option('domain');
|
$email = strtolower($email_prefix).'@'.$this->option('domain');
|
||||||
$user_email = str_replace("'",'',$email);
|
$user_email = str_replace("'", '', $email);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -379,6 +380,4 @@ class LicenseImportCommand extends Command {
|
||||||
array('testrun', null, InputOption::VALUE_REQUIRED, 'Test the output without writing to the database or not.', null),
|
array('testrun', null, InputOption::VALUE_REQUIRED, 'Test the output without writing to the database or not.', null),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,7 +27,8 @@ ini_set('memory_limit', '500M');
|
||||||
/**
|
/**
|
||||||
* Class ObjectImportCommand
|
* Class ObjectImportCommand
|
||||||
*/
|
*/
|
||||||
class ObjectImportCommand extends Command {
|
class ObjectImportCommand extends Command
|
||||||
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command name.
|
* The console command name.
|
||||||
|
@ -63,7 +64,7 @@ class ObjectImportCommand extends Command {
|
||||||
$filename = $this->argument('filename');
|
$filename = $this->argument('filename');
|
||||||
|
|
||||||
|
|
||||||
if(!$this->option('web-importer')) {
|
if (!$this->option('web-importer')) {
|
||||||
$logFile = $this->option('logfile');
|
$logFile = $this->option('logfile');
|
||||||
\Log::useFiles($logFile);
|
\Log::useFiles($logFile);
|
||||||
if ($this->option('testrun')) {
|
if ($this->option('testrun')) {
|
||||||
|
@ -84,8 +85,7 @@ class ObjectImportCommand extends Command {
|
||||||
$results = $csv->fetchAssoc();
|
$results = $csv->fetchAssoc();
|
||||||
$newarray = null;
|
$newarray = null;
|
||||||
|
|
||||||
foreach ($results as $index => $arraytoNormalize)
|
foreach ($results as $index => $arraytoNormalize) {
|
||||||
{
|
|
||||||
$internalnewarray = array_change_key_case($arraytoNormalize);
|
$internalnewarray = array_change_key_case($arraytoNormalize);
|
||||||
$newarray[$index] = $internalnewarray;
|
$newarray[$index] = $internalnewarray;
|
||||||
}
|
}
|
||||||
|
@ -104,17 +104,17 @@ class ObjectImportCommand extends Command {
|
||||||
$this->consumables = Consumable::All(['name']);
|
$this->consumables = Consumable::All(['name']);
|
||||||
$this->customfields = CustomField::All(['name']);
|
$this->customfields = CustomField::All(['name']);
|
||||||
$bar = null;
|
$bar = null;
|
||||||
if(!$this->option('web-importer')) {
|
if (!$this->option('web-importer')) {
|
||||||
$bar = $this->output->createProgressBar(count($newarray));
|
$bar = $this->output->createProgressBar(count($newarray));
|
||||||
}
|
}
|
||||||
// Loop through the records
|
// Loop through the records
|
||||||
DB::transaction(function() use (&$newarray, $bar){
|
DB::transaction(function () use (&$newarray, $bar) {
|
||||||
Model::unguard();
|
Model::unguard();
|
||||||
$item_type = strtolower($this->option('item-type'));
|
$item_type = strtolower($this->option('item-type'));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
foreach( $newarray as $row ) {
|
foreach ($newarray as $row) {
|
||||||
|
|
||||||
// Let's just map some of these entries to more user friendly words
|
// Let's just map some of these entries to more user friendly words
|
||||||
|
|
||||||
|
@ -139,10 +139,13 @@ class ObjectImportCommand extends Command {
|
||||||
$item["notes"] = $this->array_smart_fetch($row, "notes");
|
$item["notes"] = $this->array_smart_fetch($row, "notes");
|
||||||
$item["quantity"] = $this->array_smart_fetch($row, "quantity");
|
$item["quantity"] = $this->array_smart_fetch($row, "quantity");
|
||||||
$item["requestable"] = $this->array_smart_fetch($row, "requestable");
|
$item["requestable"] = $this->array_smart_fetch($row, "requestable");
|
||||||
|
$item["asset_tag"] = $this->array_smart_fetch($row, "asset tag");
|
||||||
|
|
||||||
|
|
||||||
$this->current_assetId = $item["item_name"];
|
$this->current_assetId = $item["item_name"];
|
||||||
|
if ($item["asset_tag"] != '') {
|
||||||
|
$this->current_assetId = $item["asset_tag"];
|
||||||
|
}
|
||||||
$this->log('Category: ' . $item_category);
|
$this->log('Category: ' . $item_category);
|
||||||
$this->log('Location: ' . $item_location);
|
$this->log('Location: ' . $item_location);
|
||||||
$this->log('Purchase Date: ' . $item["purchase_date"]);
|
$this->log('Purchase Date: ' . $item["purchase_date"]);
|
||||||
|
@ -182,34 +185,32 @@ class ObjectImportCommand extends Command {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!$this->option('web-importer')) {
|
if (!$this->option('web-importer')) {
|
||||||
$bar->advance();
|
$bar->advance();
|
||||||
}
|
}
|
||||||
$this->log('------------- Action Summary ----------------');
|
$this->log('------------- Action Summary ----------------');
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
if(!$this->option('web-importer')) {
|
if (!$this->option('web-importer')) {
|
||||||
$bar->finish();
|
$bar->finish();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$this->log('=====================================');
|
$this->log('=====================================');
|
||||||
if(!$this->option('web-importer'))
|
if (!$this->option('web-importer')) {
|
||||||
{
|
if (!empty($this->errors)) {
|
||||||
if(!empty($this->errors)) {
|
|
||||||
$this->comment("The following Errors were encountered.");
|
$this->comment("The following Errors were encountered.");
|
||||||
foreach($this->errors as $asset => $error)
|
foreach ($this->errors as $asset => $error) {
|
||||||
{
|
|
||||||
$this->comment('Error: Item: ' . $asset . 'failed validation: ' . json_encode($error));
|
$this->comment('Error: Item: ' . $asset . 'failed validation: ' . json_encode($error));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$this->comment("All Items imported successfully!");
|
$this->comment("All Items imported successfully!");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if(empty($this->errors))
|
if (empty($this->errors)) {
|
||||||
return 0;
|
return 0;
|
||||||
else {
|
} else {
|
||||||
$this->comment(json_encode($this->errors)); //Send a big string to the
|
$this->comment(json_encode($this->errors)); //Send a big string to the
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -226,9 +227,10 @@ class ObjectImportCommand extends Command {
|
||||||
|
|
||||||
public function jsonError($field, $errorString)
|
public function jsonError($field, $errorString)
|
||||||
{
|
{
|
||||||
$this->errors[$this->current_assetId] = array($field => $errorString);
|
$this->errors[$this->current_assetId][$field] = $errorString;
|
||||||
if($this->option('verbose'))
|
if ($this->option('verbose')) {
|
||||||
parent::error($errorString);
|
parent::error($field . $errorString);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -242,16 +244,15 @@ class ObjectImportCommand extends Command {
|
||||||
*/
|
*/
|
||||||
private function log($string, $level = 'info')
|
private function log($string, $level = 'info')
|
||||||
{
|
{
|
||||||
if($this->option('web-importer'))
|
if ($this->option('web-importer')) {
|
||||||
return;
|
return;
|
||||||
if($level === 'warning')
|
}
|
||||||
{
|
if ($level === 'warning') {
|
||||||
\Log::warning($string);
|
\Log::warning($string);
|
||||||
$this->comment($string);
|
$this->comment($string);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
\Log::Info($string);
|
\Log::Info($string);
|
||||||
if($this->option('verbose')) {
|
if ($this->option('verbose')) {
|
||||||
$this->comment($string);
|
$this->comment($string);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -267,8 +268,9 @@ class ObjectImportCommand extends Command {
|
||||||
* @param $default string
|
* @param $default string
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function array_smart_fetch(Array $array, $key, $default = '') {
|
public function array_smart_fetch(array $array, $key, $default = '')
|
||||||
return array_key_exists($key,$array) ? e(trim($array[ $key ])) : $default;
|
{
|
||||||
|
return array_key_exists($key, $array) ? e(trim($array[ $key ])) : $default;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -280,9 +282,10 @@ class ObjectImportCommand extends Command {
|
||||||
* @param $array array
|
* @param $array array
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
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])) : '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -304,10 +307,12 @@ class ObjectImportCommand extends Command {
|
||||||
|
|
||||||
$asset_model_name = $this->array_smart_fetch($row, "model name");
|
$asset_model_name = $this->array_smart_fetch($row, "model name");
|
||||||
$asset_modelno = $this->array_smart_fetch($row, "model number");
|
$asset_modelno = $this->array_smart_fetch($row, "model number");
|
||||||
if(empty($asset_model_name))
|
if (empty($asset_model_name)) {
|
||||||
$asset_model_name='Unknown';
|
$asset_model_name='Unknown';
|
||||||
if(empty($asset_modelno))
|
}
|
||||||
|
if (empty($asset_modelno)) {
|
||||||
$asset_modelno='';
|
$asset_modelno='';
|
||||||
|
}
|
||||||
$this->log('Model Name: ' . $asset_model_name);
|
$this->log('Model Name: ' . $asset_model_name);
|
||||||
$this->log('Model No: ' . $asset_modelno);
|
$this->log('Model No: ' . $asset_modelno);
|
||||||
|
|
||||||
|
@ -316,8 +321,7 @@ class ObjectImportCommand extends Command {
|
||||||
if ((strcasecmp($tempmodel->name, $asset_model_name) == 0)
|
if ((strcasecmp($tempmodel->name, $asset_model_name) == 0)
|
||||||
&& $tempmodel->modelno == $asset_modelno
|
&& $tempmodel->modelno == $asset_modelno
|
||||||
&& $tempmodel->category_id == $category->id
|
&& $tempmodel->category_id == $category->id
|
||||||
&& $tempmodel->manufacturer_id == $manufacturer->id )
|
&& $tempmodel->manufacturer_id == $manufacturer->id ) {
|
||||||
{
|
|
||||||
$this->log('A matching model ' . $asset_model_name . ' with model number ' . $asset_modelno . ' already exists');
|
$this->log('A matching model ' . $asset_model_name . ' with model number ' . $asset_modelno . ' already exists');
|
||||||
return $tempmodel;
|
return $tempmodel;
|
||||||
}
|
}
|
||||||
|
@ -330,7 +334,7 @@ class ObjectImportCommand extends Command {
|
||||||
$asset_model->user_id = $this->option('user_id');
|
$asset_model->user_id = $this->option('user_id');
|
||||||
|
|
||||||
|
|
||||||
if(!$this->option('testrun')) {
|
if (!$this->option('testrun')) {
|
||||||
if ($asset_model->save()) {
|
if ($asset_model->save()) {
|
||||||
$this->asset_models->add($asset_model);
|
$this->asset_models->add($asset_model);
|
||||||
$this->log('Asset Model ' . $asset_model_name . ' with model number ' . $asset_modelno . ' was created');
|
$this->log('Asset Model ' . $asset_model_name . ' with model number ' . $asset_modelno . ' was created');
|
||||||
|
@ -359,11 +363,12 @@ class ObjectImportCommand extends Command {
|
||||||
*/
|
*/
|
||||||
public function createOrFetchCategory($asset_category, $item_type)
|
public function createOrFetchCategory($asset_category, $item_type)
|
||||||
{
|
{
|
||||||
if (empty($asset_category))
|
if (empty($asset_category)) {
|
||||||
$asset_category = 'Unnamed Category';
|
$asset_category = 'Unnamed Category';
|
||||||
|
}
|
||||||
|
|
||||||
foreach($this->categories as $tempcategory) {
|
foreach ($this->categories as $tempcategory) {
|
||||||
if( (strcasecmp($tempcategory->name, $asset_category) == 0) && $tempcategory->category_type === $item_type) {
|
if ((strcasecmp($tempcategory->name, $asset_category) == 0) && $tempcategory->category_type === $item_type) {
|
||||||
$this->log('Category ' . $asset_category . ' already exists');
|
$this->log('Category ' . $asset_category . ' already exists');
|
||||||
return $tempcategory;
|
return $tempcategory;
|
||||||
}
|
}
|
||||||
|
@ -376,7 +381,7 @@ class ObjectImportCommand extends Command {
|
||||||
$category->user_id = $this->option('user_id');
|
$category->user_id = $this->option('user_id');
|
||||||
|
|
||||||
|
|
||||||
if(!$this->option('testrun')) {
|
if (!$this->option('testrun')) {
|
||||||
if ($category->save()) {
|
if ($category->save()) {
|
||||||
$this->categories->add($category);
|
$this->categories->add($category);
|
||||||
$this->log('Category ' . $asset_category . ' was created');
|
$this->log('Category ' . $asset_category . ' was created');
|
||||||
|
@ -414,7 +419,7 @@ class ObjectImportCommand extends Command {
|
||||||
$company = new Company();
|
$company = new Company();
|
||||||
$company->name = $asset_company_name;
|
$company->name = $asset_company_name;
|
||||||
|
|
||||||
if(!$this->option('testrun')) {
|
if (!$this->option('testrun')) {
|
||||||
if ($company->save()) {
|
if ($company->save()) {
|
||||||
$this->companies->add($company);
|
$this->companies->add($company);
|
||||||
$this->log('Company ' . $asset_company_name . ' was created');
|
$this->log('Company ' . $asset_company_name . ' was created');
|
||||||
|
@ -438,10 +443,11 @@ class ObjectImportCommand extends Command {
|
||||||
*/
|
*/
|
||||||
public function createOrFetchStatusLabel($asset_statuslabel_name)
|
public function createOrFetchStatusLabel($asset_statuslabel_name)
|
||||||
{
|
{
|
||||||
if(empty($asset_statuslabel_name))
|
if (empty($asset_statuslabel_name)) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
foreach ($this->status_labels as $tempstatus) {
|
foreach ($this->status_labels as $tempstatus) {
|
||||||
if (strcasecmp($tempstatus->name, $asset_statuslabel_name) == 0 ) {
|
if (strcasecmp($tempstatus->name, $asset_statuslabel_name) == 0) {
|
||||||
$this->log('A matching Status ' . $asset_statuslabel_name . ' already exists');
|
$this->log('A matching Status ' . $asset_statuslabel_name . ' already exists');
|
||||||
return $tempstatus;
|
return $tempstatus;
|
||||||
}
|
}
|
||||||
|
@ -450,7 +456,7 @@ class ObjectImportCommand extends Command {
|
||||||
$status->name = $asset_statuslabel_name;
|
$status->name = $asset_statuslabel_name;
|
||||||
|
|
||||||
|
|
||||||
if(!$this->option('testrun')) {
|
if (!$this->option('testrun')) {
|
||||||
if ($status->save()) {
|
if ($status->save()) {
|
||||||
$this->status_labels->add($status);
|
$this->status_labels->add($status);
|
||||||
$this->log('Status ' . $asset_statuslabel_name . ' was created');
|
$this->log('Status ' . $asset_statuslabel_name . ' was created');
|
||||||
|
@ -481,13 +487,13 @@ class ObjectImportCommand extends Command {
|
||||||
{
|
{
|
||||||
$asset_mfgr = $this->array_smart_fetch($row, "manufacturer");
|
$asset_mfgr = $this->array_smart_fetch($row, "manufacturer");
|
||||||
|
|
||||||
if(empty($asset_mfgr)) {
|
if (empty($asset_mfgr)) {
|
||||||
$asset_mfgr='Unknown';
|
$asset_mfgr='Unknown';
|
||||||
}
|
}
|
||||||
$this->log('Manufacturer ID: ' . $asset_mfgr);
|
$this->log('Manufacturer ID: ' . $asset_mfgr);
|
||||||
|
|
||||||
foreach ($this->manufacturers as $tempmanufacturer) {
|
foreach ($this->manufacturers as $tempmanufacturer) {
|
||||||
if (strcasecmp($tempmanufacturer->name, $asset_mfgr) == 0 ) {
|
if (strcasecmp($tempmanufacturer->name, $asset_mfgr) == 0) {
|
||||||
$this->log('Manufacturer ' . $asset_mfgr . ' already exists') ;
|
$this->log('Manufacturer ' . $asset_mfgr . ' already exists') ;
|
||||||
return $tempmanufacturer;
|
return $tempmanufacturer;
|
||||||
}
|
}
|
||||||
|
@ -529,8 +535,8 @@ class ObjectImportCommand extends Command {
|
||||||
*/
|
*/
|
||||||
public function createOrFetchLocation($asset_location)
|
public function createOrFetchLocation($asset_location)
|
||||||
{
|
{
|
||||||
foreach($this->locations as $templocation) {
|
foreach ($this->locations as $templocation) {
|
||||||
if( strcasecmp($templocation->name, $asset_location) == 0 ) {
|
if (strcasecmp($templocation->name, $asset_location) == 0) {
|
||||||
$this->log('Location ' . $asset_location . ' already exists');
|
$this->log('Location ' . $asset_location . ' already exists');
|
||||||
return $templocation;
|
return $templocation;
|
||||||
}
|
}
|
||||||
|
@ -579,8 +585,9 @@ class ObjectImportCommand extends Command {
|
||||||
public function createOrFetchSupplier(array $row)
|
public function createOrFetchSupplier(array $row)
|
||||||
{
|
{
|
||||||
$supplier_name = $this->array_smart_fetch($row, "supplier");
|
$supplier_name = $this->array_smart_fetch($row, "supplier");
|
||||||
if(empty($supplier_name))
|
if (empty($supplier_name)) {
|
||||||
$supplier_name='Unknown';
|
$supplier_name='Unknown';
|
||||||
|
}
|
||||||
foreach ($this->suppliers as $tempsupplier) {
|
foreach ($this->suppliers as $tempsupplier) {
|
||||||
if (strcasecmp($tempsupplier->name, $supplier_name) == 0) {
|
if (strcasecmp($tempsupplier->name, $supplier_name) == 0) {
|
||||||
$this->log('A matching Company ' . $supplier_name . ' already exists');
|
$this->log('A matching Company ' . $supplier_name . ' already exists');
|
||||||
|
@ -592,7 +599,7 @@ class ObjectImportCommand extends Command {
|
||||||
$supplier->name = $supplier_name;
|
$supplier->name = $supplier_name;
|
||||||
$supplier->user_id = $this->option('user_id');
|
$supplier->user_id = $this->option('user_id');
|
||||||
|
|
||||||
if(!$this->option('testrun')) {
|
if (!$this->option('testrun')) {
|
||||||
if ($supplier->save()) {
|
if ($supplier->save()) {
|
||||||
$this->suppliers->add($supplier);
|
$this->suppliers->add($supplier);
|
||||||
$this->log('Supplier ' . $supplier_name . ' was created');
|
$this->log('Supplier ' . $supplier_name . ' was created');
|
||||||
|
@ -666,15 +673,16 @@ class ObjectImportCommand extends Command {
|
||||||
$this->log('Email: ' . $user_email);
|
$this->log('Email: ' . $user_email);
|
||||||
$this->log('--- End User Data ---');
|
$this->log('--- End User Data ---');
|
||||||
|
|
||||||
if($this->option('testrun'))
|
if ($this->option('testrun')) {
|
||||||
return new User;
|
return new User;
|
||||||
|
}
|
||||||
|
|
||||||
if (!empty($user_username)) {
|
if (!empty($user_username)) {
|
||||||
if ($user = User::MatchEmailOrUsername($user_username, $user_email)
|
if ($user = User::MatchEmailOrUsername($user_username, $user_email)
|
||||||
->whereNotNull('username')->first()) {
|
->whereNotNull('username')->first()) {
|
||||||
|
|
||||||
$this->log('User '.$user_username.' already exists');
|
$this->log('User '.$user_username.' already exists');
|
||||||
} else if(( $first_name != '') && ($last_name != '') && ($user_username != '')) {
|
} elseif (( $first_name != '') && ($last_name != '') && ($user_username != '')) {
|
||||||
$user = new \App\Models\User;
|
$user = new \App\Models\User;
|
||||||
$password = substr(str_shuffle("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 20);
|
$password = substr(str_shuffle("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 20);
|
||||||
|
|
||||||
|
@ -709,35 +717,31 @@ class ObjectImportCommand extends Command {
|
||||||
* @param array $row
|
* @param array $row
|
||||||
* @param array $item
|
* @param array $item
|
||||||
*/
|
*/
|
||||||
public function createAssetIfNotExists(array $row, array $item )
|
public function createAssetIfNotExists(array $row, array $item)
|
||||||
{
|
{
|
||||||
$asset_serial = $this->array_smart_fetch($row, "serial number");
|
$asset_serial = $this->array_smart_fetch($row, "serial number");
|
||||||
$asset_tag = $this->array_smart_fetch($row, "asset tag");
|
|
||||||
$asset_image = $this->array_smart_fetch($row, "image");
|
$asset_image = $this->array_smart_fetch($row, "image");
|
||||||
$asset_warranty_months = intval($this->array_smart_fetch($row, "warranty months"));
|
$asset_warranty_months = intval($this->array_smart_fetch($row, "warranty months"));
|
||||||
if(empty($asset_warranty_months)) {
|
if (empty($asset_warranty_months)) {
|
||||||
$asset_warranty_months = null;
|
$asset_warranty_months = null;
|
||||||
}
|
}
|
||||||
// Check for the asset model match and create it if it doesn't exist
|
// Check for the asset model match and create it if it doesn't exist
|
||||||
$asset_model = $this->createOrFetchAssetModel($row, $item["category"], $item["manufacturer"]);
|
$asset_model = $this->createOrFetchAssetModel($row, $item["category"], $item["manufacturer"]);
|
||||||
$supplier = $this->createOrFetchSupplier($row);
|
$supplier = $this->createOrFetchSupplier($row);
|
||||||
|
|
||||||
$this->current_assetId = $asset_tag;
|
|
||||||
|
|
||||||
$this->log('Serial No: '.$asset_serial);
|
$this->log('Serial No: '.$asset_serial);
|
||||||
$this->log('Asset Tag: '.$asset_tag);
|
$this->log('Asset Tag: '.$item['asset_tag']);
|
||||||
$this->log('Notes: '.$item["notes"]);
|
$this->log('Notes: '.$item["notes"]);
|
||||||
$this->log('Warranty Months: ' . $asset_warranty_months);
|
$this->log('Warranty Months: ' . $asset_warranty_months);
|
||||||
|
|
||||||
foreach ($this->assets as $tempasset) {
|
foreach ($this->assets as $tempasset) {
|
||||||
if (strcasecmp($tempasset->asset_tag, $asset_tag ) == 0 ) {
|
if (strcasecmp($tempasset->asset_tag, $item['asset_tag']) == 0) {
|
||||||
$this->log('A matching Asset ' . $asset_tag . ' already exists');
|
$this->log('A matching Asset ' . $item['asset_tag'] . ' already exists');
|
||||||
// $this->comment('A matching Asset ' . $asset_tag . ' already exists');
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if($item["status_label"]) {
|
if ($item["status_label"]) {
|
||||||
$status_id = $item["status_label"]->id;
|
$status_id = $item["status_label"]->id;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
@ -754,7 +758,7 @@ class ObjectImportCommand extends Command {
|
||||||
$asset->purchase_date = null;
|
$asset->purchase_date = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( array_key_exists('custom_fields', $item)) {
|
if (array_key_exists('custom_fields', $item)) {
|
||||||
foreach ($item['custom_fields'] as $custom_field => $val) {
|
foreach ($item['custom_fields'] as $custom_field => $val) {
|
||||||
$asset->{$custom_field} = $val;
|
$asset->{$custom_field} = $val;
|
||||||
}
|
}
|
||||||
|
@ -762,30 +766,35 @@ class ObjectImportCommand extends Command {
|
||||||
|
|
||||||
if (!empty($item["purchase_cost"])) {
|
if (!empty($item["purchase_cost"])) {
|
||||||
//TODO How to generalize this for not USD?
|
//TODO How to generalize this for not USD?
|
||||||
$purchase_cost = substr($item["purchase_cost"],0,1) === '$' ? substr($item["purchase_cost"],1) : $item["purchase_cost"];
|
$purchase_cost = substr($item["purchase_cost"], 0, 1) === '$' ? substr($item["purchase_cost"], 1) : $item["purchase_cost"];
|
||||||
$asset->purchase_cost = number_format($purchase_cost,2);
|
$asset->purchase_cost = number_format($purchase_cost, 2);
|
||||||
$this->log("Asset cost parsed: " . $asset->purchase_cost);
|
$this->log("Asset cost parsed: " . $asset->purchase_cost);
|
||||||
} else {
|
} else {
|
||||||
$asset->purchase_cost = 0.00;
|
$asset->purchase_cost = 0.00;
|
||||||
}
|
}
|
||||||
$asset->serial = $asset_serial;
|
$asset->serial = $asset_serial;
|
||||||
$asset->asset_tag = $asset_tag;
|
$asset->asset_tag = $item['asset_tag'];
|
||||||
$asset->warranty_months = $asset_warranty_months;
|
$asset->warranty_months = $asset_warranty_months;
|
||||||
|
|
||||||
if($asset_model)
|
if ($asset_model) {
|
||||||
$asset->model_id = $asset_model->id;
|
$asset->model_id = $asset_model->id;
|
||||||
if($item["user"])
|
}
|
||||||
|
if ($item["user"]) {
|
||||||
$asset->assigned_to = $item["user"]->id;
|
$asset->assigned_to = $item["user"]->id;
|
||||||
if($item["location"])
|
}
|
||||||
|
if ($item["location"]) {
|
||||||
$asset->rtd_location_id = $item["location"]->id;
|
$asset->rtd_location_id = $item["location"]->id;
|
||||||
|
}
|
||||||
$asset->user_id = $this->option('user_id');
|
$asset->user_id = $this->option('user_id');
|
||||||
$this->log("status_id: " . $status_id);
|
$this->log("status_id: " . $status_id);
|
||||||
$asset->status_id = $status_id;
|
$asset->status_id = $status_id;
|
||||||
if($item["company"])
|
if ($item["company"]) {
|
||||||
$asset->company_id = $item["company"]->id;
|
$asset->company_id = $item["company"]->id;
|
||||||
|
}
|
||||||
$asset->order_number = $item["order_number"];
|
$asset->order_number = $item["order_number"];
|
||||||
if($supplier)
|
if ($supplier) {
|
||||||
$asset->supplier_id = $supplier->id;
|
$asset->supplier_id = $supplier->id;
|
||||||
|
}
|
||||||
$asset->notes = $item["notes"];
|
$asset->notes = $item["notes"];
|
||||||
$asset->image = $asset_image;
|
$asset->image = $asset_image;
|
||||||
$this->assets->add($asset);
|
$this->assets->add($asset);
|
||||||
|
@ -811,11 +820,11 @@ class ObjectImportCommand extends Command {
|
||||||
* @since 3.0
|
* @since 3.0
|
||||||
* @param $item array
|
* @param $item array
|
||||||
*/
|
*/
|
||||||
public function createAccessoryIfNotExists(array $item )
|
public function createAccessoryIfNotExists(array $item)
|
||||||
{
|
{
|
||||||
$this->log("Creating Accessory");
|
$this->log("Creating Accessory");
|
||||||
foreach ($this->accessories as $tempaccessory) {
|
foreach ($this->accessories as $tempaccessory) {
|
||||||
if (strcasecmp($tempaccessory->name, $item["item_name"] ) == 0 ) {
|
if (strcasecmp($tempaccessory->name, $item["item_name"]) == 0) {
|
||||||
$this->log('A matching Accessory ' . $item["item_name"] . ' already exists. ');
|
$this->log('A matching Accessory ' . $item["item_name"] . ' already exists. ');
|
||||||
// FUTURE: Adjust quantity on import maybe?
|
// FUTURE: Adjust quantity on import maybe?
|
||||||
return;
|
return;
|
||||||
|
@ -831,25 +840,28 @@ class ObjectImportCommand extends Command {
|
||||||
$accessory->purchase_date = null;
|
$accessory->purchase_date = null;
|
||||||
}
|
}
|
||||||
if (!empty($item["purchase_cost"])) {
|
if (!empty($item["purchase_cost"])) {
|
||||||
$accessory->purchase_cost = number_format(e($item["purchase_cost"]),2);
|
$accessory->purchase_cost = number_format(e($item["purchase_cost"]), 2);
|
||||||
} else {
|
} else {
|
||||||
$accessory->purchase_cost = 0.00;
|
$accessory->purchase_cost = 0.00;
|
||||||
}
|
}
|
||||||
if($item["location"])
|
if ($item["location"]) {
|
||||||
$accessory->location_id = $item["location"]->id;
|
$accessory->location_id = $item["location"]->id;
|
||||||
|
}
|
||||||
$accessory->user_id = $this->option('user_id');
|
$accessory->user_id = $this->option('user_id');
|
||||||
if($item["company"])
|
if ($item["company"]) {
|
||||||
$accessory->company_id = $item["company"]->id;
|
$accessory->company_id = $item["company"]->id;
|
||||||
|
}
|
||||||
$accessory->order_number = $item["order_number"];
|
$accessory->order_number = $item["order_number"];
|
||||||
if($item["category"])
|
if ($item["category"]) {
|
||||||
$accessory->category_id = $item["category"]->id;
|
$accessory->category_id = $item["category"]->id;
|
||||||
|
}
|
||||||
|
|
||||||
//TODO: Implement
|
//TODO: Implement
|
||||||
// $accessory->notes = e($item_notes);
|
// $accessory->notes = e($item_notes);
|
||||||
$accessory->requestable = filter_var($item["requestable"], FILTER_VALIDATE_BOOLEAN);
|
$accessory->requestable = filter_var($item["requestable"], FILTER_VALIDATE_BOOLEAN);
|
||||||
|
|
||||||
//Must have at least zero of the item if we import it.
|
//Must have at least zero of the item if we import it.
|
||||||
if($item["quantity"] > -1) {
|
if ($item["quantity"] > -1) {
|
||||||
$accessory->qty = $item["quantity"];
|
$accessory->qty = $item["quantity"];
|
||||||
} else {
|
} else {
|
||||||
$accessory->qty = 1;
|
$accessory->qty = 1;
|
||||||
|
@ -880,8 +892,8 @@ class ObjectImportCommand extends Command {
|
||||||
public function createConsumableIfNotExists(array $item)
|
public function createConsumableIfNotExists(array $item)
|
||||||
{
|
{
|
||||||
$this->log("Creating Consumable");
|
$this->log("Creating Consumable");
|
||||||
foreach($this->consumables as $tempconsumable) {
|
foreach ($this->consumables as $tempconsumable) {
|
||||||
if(strcasecmp($tempconsumable->name, $item["item_name"]) == 0) {
|
if (strcasecmp($tempconsumable->name, $item["item_name"]) == 0) {
|
||||||
$this->log("A matching consumable " . $item["item_name"] . " already exists");
|
$this->log("A matching consumable " . $item["item_name"] . " already exists");
|
||||||
//TODO: Adjust quantity if different maybe?
|
//TODO: Adjust quantity if different maybe?
|
||||||
return;
|
return;
|
||||||
|
@ -891,14 +903,14 @@ class ObjectImportCommand extends Command {
|
||||||
$consumable = new Consumable();
|
$consumable = new Consumable();
|
||||||
$consumable->name = $item["item_name"];
|
$consumable->name = $item["item_name"];
|
||||||
|
|
||||||
if(!empty($item["purchase_date"])) {
|
if (!empty($item["purchase_date"])) {
|
||||||
$consumable->purchase_date = $item["purchase_date"];
|
$consumable->purchase_date = $item["purchase_date"];
|
||||||
} else {
|
} else {
|
||||||
$consumable->purchase_date = null;
|
$consumable->purchase_date = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!empty($item["purchase_cost"])) {
|
if (!empty($item["purchase_cost"])) {
|
||||||
$consumable->purchase_cost = number_format(e($item["purchase_cost"]),2);
|
$consumable->purchase_cost = number_format(e($item["purchase_cost"]), 2);
|
||||||
} else {
|
} else {
|
||||||
$consumable->purchase_cost = 0.00;
|
$consumable->purchase_cost = 0.00;
|
||||||
}
|
}
|
||||||
|
@ -911,14 +923,14 @@ class ObjectImportCommand extends Command {
|
||||||
//$consumable->notes= e($item_notes);
|
//$consumable->notes= e($item_notes);
|
||||||
$consumable->requestable = filter_var($item["requestable"], FILTER_VALIDATE_BOOLEAN);
|
$consumable->requestable = filter_var($item["requestable"], FILTER_VALIDATE_BOOLEAN);
|
||||||
|
|
||||||
if($item["quantity"] > -1) {
|
if ($item["quantity"] > -1) {
|
||||||
$consumable->qty = $item["quantity"];
|
$consumable->qty = $item["quantity"];
|
||||||
} else {
|
} else {
|
||||||
$consumable->qty = 1;
|
$consumable->qty = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!$this->option("testrun")) {
|
if (!$this->option("testrun")) {
|
||||||
if($consumable->save()) {
|
if ($consumable->save()) {
|
||||||
$this->log("Consumable " . $item["item_name"] . ' was created');
|
$this->log("Consumable " . $item["item_name"] . ' was created');
|
||||||
// $this->comment("Consumable " . $item["item_name"] . ' was created');
|
// $this->comment("Consumable " . $item["item_name"] . ' was created');
|
||||||
|
|
||||||
|
@ -965,7 +977,4 @@ class ObjectImportCommand extends Command {
|
||||||
);
|
);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ class PaveIt extends Command
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
protected $signature = 'snipeit:pave
|
protected $signature = 'snipeit:pave
|
||||||
{--soft: Perform a "Soft" Delete, leaving all migrations, table structure, and the first user in place.}';
|
{--soft : Perform a "Soft" Delete, leaving all migrations, table structure, and the first user in place.}';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command description.
|
* The console command description.
|
||||||
|
@ -55,10 +55,8 @@ class PaveIt extends Command
|
||||||
*/
|
*/
|
||||||
public function handle()
|
public function handle()
|
||||||
{
|
{
|
||||||
if ($this->confirm("\n****************************************************\nTHIS WILL DELETE ALL OF THE DATA IN YOUR DATABASE. \nThere is NO undo. This WILL destroy ALL of your data. \n****************************************************\n\nDo you wish to continue? No backsies! [y|N]"))
|
if ($this->confirm("\n****************************************************\nTHIS WILL DELETE ALL OF THE DATA IN YOUR DATABASE. \nThere is NO undo. This WILL destroy ALL of your data. \n****************************************************\n\nDo you wish to continue? No backsies! [y|N]")) {
|
||||||
{
|
if ($this->option('soft')) {
|
||||||
if( $this->option('soft'))
|
|
||||||
{
|
|
||||||
Accessory::getQuery()->delete();
|
Accessory::getQuery()->delete();
|
||||||
Asset::getQuery()->delete();
|
Asset::getQuery()->delete();
|
||||||
Category::getQuery()->delete();
|
Category::getQuery()->delete();
|
||||||
|
|
|
@ -140,7 +140,7 @@ class Purge extends Command
|
||||||
$supplier->forceDelete();
|
$supplier->forceDelete();
|
||||||
}
|
}
|
||||||
|
|
||||||
$users = User::whereNotNull('deleted_at')->where('show_in_list','!=','0')->withTrashed()->get();
|
$users = User::whereNotNull('deleted_at')->where('show_in_list', '!=', '0')->withTrashed()->get();
|
||||||
$this->info($users->count().' users purged.');
|
$this->info($users->count().' users purged.');
|
||||||
$user_assoc = 0;
|
$user_assoc = 0;
|
||||||
foreach ($users as $user) {
|
foreach ($users as $user) {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace App\Console\Commands;
|
namespace App\Console\Commands;
|
||||||
|
|
||||||
use App\Models\Asset;
|
use App\Models\Asset;
|
||||||
use App\Models\License;
|
use App\Models\License;
|
||||||
use App\Models\Setting;
|
use App\Models\Setting;
|
||||||
|
@ -8,7 +9,8 @@ use DB;
|
||||||
|
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
|
|
||||||
class SendExpirationAlerts extends Command {
|
class SendExpirationAlerts extends Command
|
||||||
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command name.
|
* The console command name.
|
||||||
|
@ -99,7 +101,7 @@ class SendExpirationAlerts extends Command {
|
||||||
|
|
||||||
if (count($expiring_assets) > 0) {
|
if (count($expiring_assets) > 0) {
|
||||||
\Mail::send('emails.expiring-assets-report', $asset_data, function ($m) {
|
\Mail::send('emails.expiring-assets-report', $asset_data, function ($m) {
|
||||||
$m->to(explode(',',Setting::getSettings()->alert_email), Setting::getSettings()->site_name);
|
$m->to(explode(',', Setting::getSettings()->alert_email), Setting::getSettings()->site_name);
|
||||||
$m->subject('Expiring Assets Report');
|
$m->subject('Expiring Assets Report');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -107,7 +109,7 @@ class SendExpirationAlerts extends Command {
|
||||||
|
|
||||||
if (count($expiring_licenses) > 0) {
|
if (count($expiring_licenses) > 0) {
|
||||||
\Mail::send('emails.expiring-licenses-report', $license_data, function ($m) {
|
\Mail::send('emails.expiring-licenses-report', $license_data, function ($m) {
|
||||||
$m->to(explode(',',Setting::getSettings()->alert_email), Setting::getSettings()->site_name);
|
$m->to(explode(',', Setting::getSettings()->alert_email), Setting::getSettings()->site_name);
|
||||||
$m->subject('Expiring Licenses Report');
|
$m->subject('Expiring Licenses Report');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -128,9 +130,4 @@ class SendExpirationAlerts extends Command {
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,7 +49,7 @@ class SendInventoryAlerts extends Command
|
||||||
|
|
||||||
if (count($data['data']) > 0) {
|
if (count($data['data']) > 0) {
|
||||||
\Mail::send('emails.low-inventory', $data, function ($m) {
|
\Mail::send('emails.low-inventory', $data, function ($m) {
|
||||||
$m->to(explode(',',Setting::getSettings()->alert_email), Setting::getSettings()->site_name);
|
$m->to(explode(',', Setting::getSettings()->alert_email), Setting::getSettings()->site_name);
|
||||||
$m->subject('Low Inventory Report');
|
$m->subject('Low Inventory Report');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -65,5 +65,4 @@ class SendInventoryAlerts extends Command
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,8 @@ namespace App\Console\Commands;
|
||||||
|
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
|
|
||||||
class SystemBackup extends Command {
|
class SystemBackup extends Command
|
||||||
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command name.
|
* The console command name.
|
||||||
|
@ -41,7 +42,4 @@ class SystemBackup extends Command {
|
||||||
$this->call('backup:run');
|
$this->call('backup:run');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,8 @@ use Symfony\Component\Console\Input\InputArgument;
|
||||||
|
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
|
|
||||||
class Versioning extends Command {
|
class Versioning extends Command
|
||||||
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command name.
|
* The console command name.
|
||||||
|
|
|
@ -322,6 +322,7 @@ class AccessoriesController extends Controller
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$admin_user = Auth::user();
|
||||||
$settings = Setting::getSettings();
|
$settings = Setting::getSettings();
|
||||||
|
|
||||||
if ($settings->slack_endpoint) {
|
if ($settings->slack_endpoint) {
|
||||||
|
|
|
@ -80,16 +80,17 @@ class AssetsController extends Controller
|
||||||
* @since [v3.0]
|
* @since [v3.0]
|
||||||
* @return Redirect
|
* @return Redirect
|
||||||
*/
|
*/
|
||||||
public function getAssetByTag() {
|
public function getAssetByTag()
|
||||||
|
{
|
||||||
if (Input::get('topsearch')=="true") {
|
if (Input::get('topsearch')=="true") {
|
||||||
$topsearch = true;
|
$topsearch = true;
|
||||||
} else {
|
} else {
|
||||||
$topsearch = false;
|
$topsearch = false;
|
||||||
}
|
}
|
||||||
if ($asset = Asset::where('asset_tag','=',Input::get('assetTag'))->first()) {
|
if ($asset = Asset::where('asset_tag', '=', Input::get('assetTag'))->first()) {
|
||||||
return redirect()->route('view/hardware', $asset->id)->with('topsearch', $topsearch);
|
return redirect()->route('view/hardware', $asset->id)->with('topsearch', $topsearch);
|
||||||
}
|
}
|
||||||
return redirect()->to('hardware')->with('error',trans('admin/hardware/message.does_not_exist'));
|
return redirect()->to('hardware')->with('error', trans('admin/hardware/message.does_not_exist'));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -211,8 +212,8 @@ class AssetsController extends Controller
|
||||||
if (Input::has('image')) {
|
if (Input::has('image')) {
|
||||||
$image = Input::get('image');
|
$image = Input::get('image');
|
||||||
$header = explode(';', $image, 2)[0];
|
$header = explode(';', $image, 2)[0];
|
||||||
$extension = substr( $header, strpos($header, '/')+1);
|
$extension = substr($header, strpos($header, '/')+1);
|
||||||
$image = substr( $image, strpos($image, ',')+1);
|
$image = substr($image, strpos($image, ',')+1);
|
||||||
|
|
||||||
$file_name = str_random(25).".".$extension;
|
$file_name = str_random(25).".".$extension;
|
||||||
$path = public_path('uploads/assets/'.$file_name);
|
$path = public_path('uploads/assets/'.$file_name);
|
||||||
|
@ -231,9 +232,8 @@ class AssetsController extends Controller
|
||||||
// FIXME: No idea why this is returning a Builder error on db_column_name.
|
// FIXME: No idea why this is returning a Builder error on db_column_name.
|
||||||
// Need to investigate and fix. Using static method for now.
|
// Need to investigate and fix. Using static method for now.
|
||||||
$model = AssetModel::find($request->get('model_id'));
|
$model = AssetModel::find($request->get('model_id'));
|
||||||
if($model->fieldset)
|
if ($model->fieldset) {
|
||||||
{
|
foreach ($model->fieldset->fields as $field) {
|
||||||
foreach($model->fieldset->fields as $field) {
|
|
||||||
$asset->{\App\Models\CustomField::name_to_db_name($field->name)} = e($request->input(\App\Models\CustomField::name_to_db_name($field->name)));
|
$asset->{\App\Models\CustomField::name_to_db_name($field->name)} = e($request->input(\App\Models\CustomField::name_to_db_name($field->name)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -254,8 +254,9 @@ class AssetsController extends Controller
|
||||||
\Session::flash('success', trans('admin/hardware/message.create.success'));
|
\Session::flash('success', trans('admin/hardware/message.create.success'));
|
||||||
return response()->json(['redirect_url' => route('hardware')]);
|
return response()->json(['redirect_url' => route('hardware')]);
|
||||||
}
|
}
|
||||||
|
\Input::flash();
|
||||||
return response()->json(['errors' => $asset->getErrors()]);
|
\Session::flash('errors', $asset->getErrors());
|
||||||
|
return response()->json(['errors' => $asset->getErrors()], 500);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -383,8 +384,8 @@ class AssetsController extends Controller
|
||||||
if (Input::has('image')) {
|
if (Input::has('image')) {
|
||||||
$image = $request->input('image');
|
$image = $request->input('image');
|
||||||
$header = explode(';', $image, 2)[0];
|
$header = explode(';', $image, 2)[0];
|
||||||
$extension = substr( $header, strpos($header, '/')+1);
|
$extension = substr($header, strpos($header, '/')+1);
|
||||||
$image = substr( $image, strpos($image, ',')+1);
|
$image = substr($image, strpos($image, ',')+1);
|
||||||
|
|
||||||
$file_name = str_random(25).".".$extension;
|
$file_name = str_random(25).".".$extension;
|
||||||
$path = public_path('uploads/assets/'.$file_name);
|
$path = public_path('uploads/assets/'.$file_name);
|
||||||
|
@ -401,13 +402,12 @@ class AssetsController extends Controller
|
||||||
// FIXME: No idea why this is returning a Builder error on db_column_name.
|
// FIXME: No idea why this is returning a Builder error on db_column_name.
|
||||||
// Need to investigate and fix. Using static method for now.
|
// Need to investigate and fix. Using static method for now.
|
||||||
$model = AssetModel::find($request->get('model_id'));
|
$model = AssetModel::find($request->get('model_id'));
|
||||||
if($model->fieldset)
|
if ($model->fieldset) {
|
||||||
{
|
foreach ($model->fieldset->fields as $field) {
|
||||||
foreach($model->fieldset->fields as $field) {
|
|
||||||
$asset->{\App\Models\CustomField::name_to_db_name($field->name)} = e($request->input(\App\Models\CustomField::name_to_db_name($field->name)));
|
$asset->{\App\Models\CustomField::name_to_db_name($field->name)} = e($request->input(\App\Models\CustomField::name_to_db_name($field->name)));
|
||||||
// LOG::debug($field->name);
|
// LOG::debug($field->name);
|
||||||
// LOG::debug(\App\Models\CustomField::name_to_db_name($field->name));
|
// LOG::debug(\App\Models\CustomField::name_to_db_name($field->name));
|
||||||
// LOG::debug($field->db_column_name());
|
// LOG::debug($field->db_column_name());
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -417,8 +417,9 @@ class AssetsController extends Controller
|
||||||
\Session::flash('success', trans('admin/hardware/message.update.success'));
|
\Session::flash('success', trans('admin/hardware/message.update.success'));
|
||||||
return response()->json(['redirect_url' => route("view/hardware", $assetId)]);
|
return response()->json(['redirect_url' => route("view/hardware", $assetId)]);
|
||||||
}
|
}
|
||||||
|
\Input::flash();
|
||||||
return response()->json(['errors' => $asset->getErrors()]);
|
\Session::flash('errors', $asset->getErrors());
|
||||||
|
return response()->json(['errors' => $asset->getErrors()], 500);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -611,7 +612,7 @@ class AssetsController extends Controller
|
||||||
'fields' => [
|
'fields' => [
|
||||||
[
|
[
|
||||||
'title' => 'Checked In:',
|
'title' => 'Checked In:',
|
||||||
'value' => strtoupper($logaction->asset_type).' asset <'.config('app.url').'/hardware/'.$asset->id.'/view'.'|'.e($asset->showAssetName()).'> checked in by <'.config('app.url').'/hardware/'.$asset->id.'/view'.'|'.e(Auth::user()->fullName()).'>.'
|
'value' => strtoupper($logaction->asset_type).' asset <'.config('app.url').'/hardware/'.$asset->id.'/view'.'|'.e($asset->showAssetName()).'> checked in by <'.config('app.url').'/admin/users/'.Auth::user()->id.'/view'.'|'.e(Auth::user()->fullName()).'>.'
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'title' => 'Note:',
|
'title' => 'Note:',
|
||||||
|
@ -776,8 +777,9 @@ class AssetsController extends Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if the uploads directory exists. If not, try to create it.
|
// Check if the uploads directory exists. If not, try to create it.
|
||||||
if(!file_exists($path))
|
if (!file_exists($path)) {
|
||||||
mkdir($path, 0755);
|
mkdir($path, 0755);
|
||||||
|
}
|
||||||
if ($handle = opendir($path)) {
|
if ($handle = opendir($path)) {
|
||||||
|
|
||||||
/* This is the correct way to loop over the directory. */
|
/* This is the correct way to loop over the directory. */
|
||||||
|
@ -874,19 +876,21 @@ class AssetsController extends Controller
|
||||||
return redirect()->to('hardware')->with('error', trans('general.insufficient_permissions'));
|
return redirect()->to('hardware')->with('error', trans('general.insufficient_permissions'));
|
||||||
}
|
}
|
||||||
|
|
||||||
$return = Artisan::call('snipeit:import',
|
$return = Artisan::call(
|
||||||
|
'snipeit:import',
|
||||||
['filename'=> config('app.private_uploads').'/imports/assets/'.$filename,
|
['filename'=> config('app.private_uploads').'/imports/assets/'.$filename,
|
||||||
'--email_format'=>'firstname.lastname',
|
'--email_format'=>'firstname.lastname',
|
||||||
'--username_format'=>'firstname.lastname',
|
'--username_format'=>'firstname.lastname',
|
||||||
'--web-importer' => true,
|
'--web-importer' => true,
|
||||||
'--user_id' => Auth::user()->id
|
'--user_id' => Auth::user()->id
|
||||||
]);
|
]
|
||||||
|
);
|
||||||
$display_output = Artisan::output();
|
$display_output = Artisan::output();
|
||||||
$file = config('app.private_uploads').'/imports/assets/'.str_replace('.csv', '', $filename).'-output-'.date("Y-m-d-his").'.txt';
|
$file = config('app.private_uploads').'/imports/assets/'.str_replace('.csv', '', $filename).'-output-'.date("Y-m-d-his").'.txt';
|
||||||
file_put_contents($file, $display_output);
|
file_put_contents($file, $display_output);
|
||||||
if( $return === 0) //Success
|
if ($return === 0) { //Success
|
||||||
return redirect()->to('hardware')->with('success', trans('admin/hardware/message.import.success'));
|
return redirect()->to('hardware')->with('success', trans('admin/hardware/message.import.success'));
|
||||||
else if( $return === 1) { // Failure
|
} elseif ($return === 1) { // Failure
|
||||||
return redirect()->back()->with('import_errors', json_decode($display_output))->with('error', trans('admin/hardware/message.import.error'));
|
return redirect()->back()->with('import_errors', json_decode($display_output))->with('error', trans('admin/hardware/message.import.error'));
|
||||||
}
|
}
|
||||||
dd("Shouldn't be here");
|
dd("Shouldn't be here");
|
||||||
|
@ -962,7 +966,7 @@ class AssetsController extends Controller
|
||||||
} elseif (isset($asset->id)) {
|
} elseif (isset($asset->id)) {
|
||||||
|
|
||||||
// Restore the asset
|
// Restore the asset
|
||||||
Asset::withTrashed()->where('id',$assetId)->restore();
|
Asset::withTrashed()->where('id', $assetId)->restore();
|
||||||
return redirect()->route('hardware')->with('success', trans('admin/hardware/message.restore.success'));
|
return redirect()->route('hardware')->with('success', trans('admin/hardware/message.restore.success'));
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -244,7 +244,7 @@ class CategoriesController extends Controller
|
||||||
public function getDatatable()
|
public function getDatatable()
|
||||||
{
|
{
|
||||||
// Grab all the categories
|
// Grab all the categories
|
||||||
$categories = Category::with('assets', 'accessories', 'consumables','components');
|
$categories = Category::with('assets', 'accessories', 'consumables', 'components');
|
||||||
|
|
||||||
if (Input::has('search')) {
|
if (Input::has('search')) {
|
||||||
$categories = $categories->TextSearch(e(Input::get('search')));
|
$categories = $categories->TextSearch(e(Input::get('search')));
|
||||||
|
@ -300,7 +300,8 @@ class CategoriesController extends Controller
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDataViewAssets($categoryID) {
|
public function getDataViewAssets($categoryID)
|
||||||
|
{
|
||||||
|
|
||||||
$category = Category::with('assets.company')->find($categoryID);
|
$category = Category::with('assets.company')->find($categoryID);
|
||||||
$category_assets = $category->assets();
|
$category_assets = $category->assets();
|
||||||
|
@ -369,7 +370,8 @@ class CategoriesController extends Controller
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public function getDataViewAccessories($categoryID) {
|
public function getDataViewAccessories($categoryID)
|
||||||
|
{
|
||||||
|
|
||||||
$category = Category::with('accessories.company')->find($categoryID);
|
$category = Category::with('accessories.company')->find($categoryID);
|
||||||
$category_assets = $category->accessories;
|
$category_assets = $category->accessories;
|
||||||
|
@ -422,7 +424,8 @@ class CategoriesController extends Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getDataViewConsumables($categoryID) {
|
public function getDataViewConsumables($categoryID)
|
||||||
|
{
|
||||||
|
|
||||||
$category = Category::with('accessories.company')->find($categoryID);
|
$category = Category::with('accessories.company')->find($categoryID);
|
||||||
$category_assets = $category->consumables;
|
$category_assets = $category->consumables;
|
||||||
|
@ -474,7 +477,8 @@ class CategoriesController extends Controller
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDataViewComponent($categoryID) {
|
public function getDataViewComponent($categoryID)
|
||||||
|
{
|
||||||
|
|
||||||
$category = Category::with('accessories.company')->find($categoryID);
|
$category = Category::with('accessories.company')->find($categoryID);
|
||||||
$category_assets = $category->components;
|
$category_assets = $category->components;
|
||||||
|
@ -525,7 +529,4 @@ class CategoriesController extends Controller
|
||||||
$data = array('total' => $count, 'rows' => $rows);
|
$data = array('total' => $count, 'rows' => $rows);
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -260,7 +260,8 @@ class CustomFieldsController extends Controller
|
||||||
* @since [v3.0]
|
* @since [v3.0]
|
||||||
* @return Array
|
* @return Array
|
||||||
*/
|
*/
|
||||||
public function postReorder($id) {
|
public function postReorder($id)
|
||||||
|
{
|
||||||
$fieldset=CustomFieldset::find($id);
|
$fieldset=CustomFieldset::find($id);
|
||||||
$fields = array();
|
$fields = array();
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,6 @@ use Str;
|
||||||
use View;
|
use View;
|
||||||
use Auth;
|
use Auth;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This controller handles all actions related to Depreciations for
|
* This controller handles all actions related to Depreciations for
|
||||||
* the Snipe-IT Asset Management application.
|
* the Snipe-IT Asset Management application.
|
||||||
|
|
|
@ -93,7 +93,7 @@ class GroupsController extends Controller
|
||||||
$permissions = config('permissions');
|
$permissions = config('permissions');
|
||||||
$groupPermissions = $group->decodePermissions();
|
$groupPermissions = $group->decodePermissions();
|
||||||
$selected_array = Helper::selectedPermissionsArray($permissions, $groupPermissions);
|
$selected_array = Helper::selectedPermissionsArray($permissions, $groupPermissions);
|
||||||
return View::make('groups/edit', compact('group', 'permissions','selected_array','groupPermissions'));
|
return View::make('groups/edit', compact('group', 'permissions', 'selected_array', 'groupPermissions'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -156,7 +156,7 @@ class LicensesController extends Controller
|
||||||
|
|
||||||
$insertedId = $license->id;
|
$insertedId = $license->id;
|
||||||
// Save the license seat data
|
// Save the license seat data
|
||||||
DB::transaction(function() use (&$insertedId,&$license) {
|
DB::transaction(function () use (&$insertedId, &$license) {
|
||||||
for ($x=0; $x<$license->seats; $x++) {
|
for ($x=0; $x<$license->seats; $x++) {
|
||||||
$license_seat = new LicenseSeat();
|
$license_seat = new LicenseSeat();
|
||||||
$license_seat->license_id = $insertedId;
|
$license_seat->license_id = $insertedId;
|
||||||
|
|
|
@ -370,7 +370,7 @@ class LocationsController extends Controller
|
||||||
public function getDataViewUsers($locationID)
|
public function getDataViewUsers($locationID)
|
||||||
{
|
{
|
||||||
$location = Location::find($locationID);
|
$location = Location::find($locationID);
|
||||||
$users = User::where('location_id','=',$location->id);
|
$users = User::where('location_id', '=', $location->id);
|
||||||
|
|
||||||
if (Input::has('search')) {
|
if (Input::has('search')) {
|
||||||
$users = $users->TextSearch(e(Input::get('search')));
|
$users = $users->TextSearch(e(Input::get('search')));
|
||||||
|
|
|
@ -110,7 +110,7 @@ class ReportsController extends Controller
|
||||||
->orderBy('created_at', 'DESC')
|
->orderBy('created_at', 'DESC')
|
||||||
->get();
|
->get();
|
||||||
|
|
||||||
return View::make('reports/asset', compact('assets'))->with('settings',$settings);
|
return View::make('reports/asset', compact('assets'))->with('settings', $settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -49,7 +49,7 @@ class SettingsController extends Controller
|
||||||
$start_settings['db_error'] = $e->getMessage();
|
$start_settings['db_error'] = $e->getMessage();
|
||||||
}
|
}
|
||||||
|
|
||||||
$protocol = array_key_exists('HTTPS',$_SERVER) && ( $_SERVER['HTTPS'] == "on") ? 'https://' : 'http://';
|
$protocol = array_key_exists('HTTPS', $_SERVER) && ( $_SERVER['HTTPS'] == "on") ? 'https://' : 'http://';
|
||||||
|
|
||||||
|
|
||||||
$pageURL = $protocol;
|
$pageURL = $protocol;
|
||||||
|
@ -97,7 +97,7 @@ class SettingsController extends Controller
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(function_exists('posix_getpwuid')) { // Probably Linux
|
if (function_exists('posix_getpwuid')) { // Probably Linux
|
||||||
$owner = posix_getpwuid(fileowner($_SERVER["SCRIPT_FILENAME"]));
|
$owner = posix_getpwuid(fileowner($_SERVER["SCRIPT_FILENAME"]));
|
||||||
$start_settings['owner'] = $owner['name'];
|
$start_settings['owner'] = $owner['name'];
|
||||||
} else { // Windows
|
} else { // Windows
|
||||||
|
@ -552,7 +552,7 @@ class SettingsController extends Controller
|
||||||
{
|
{
|
||||||
if (!config('app.lock_passwords')) {
|
if (!config('app.lock_passwords')) {
|
||||||
if (Input::get('confirm_purge')=='DELETE') {
|
if (Input::get('confirm_purge')=='DELETE') {
|
||||||
Artisan::call('snipeit:purge',['--force'=>'true','--no-interaction'=>true]);
|
Artisan::call('snipeit:purge', ['--force'=>'true','--no-interaction'=>true]);
|
||||||
$output = Artisan::output();
|
$output = Artisan::output();
|
||||||
return View::make('settings/purge')
|
return View::make('settings/purge')
|
||||||
->with('output', $output)->with('success', trans('admin/settings/message.purge.success'));
|
->with('output', $output)->with('success', trans('admin/settings/message.purge.success'));
|
||||||
|
|
|
@ -33,7 +33,6 @@ use URL;
|
||||||
use View;
|
use View;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This controller handles all actions related to Users for
|
* This controller handles all actions related to Users for
|
||||||
* the Snipe-IT Asset Management application.
|
* the Snipe-IT Asset Management application.
|
||||||
|
@ -431,7 +430,7 @@ class UsersController extends Controller
|
||||||
|
|
||||||
//print_r($licenses);
|
//print_r($licenses);
|
||||||
|
|
||||||
$users = User::whereIn('id', $user_raw_array)->with('groups', 'assets', 'licenses','accessories')->get();
|
$users = User::whereIn('id', $user_raw_array)->with('groups', 'assets', 'licenses', 'accessories')->get();
|
||||||
// $users = Company::scopeCompanyables($users)->get();
|
// $users = Company::scopeCompanyables($users)->get();
|
||||||
|
|
||||||
return View::make('users/confirm-bulk-delete', compact('users', 'statuslabel_list'));
|
return View::make('users/confirm-bulk-delete', compact('users', 'statuslabel_list'));
|
||||||
|
@ -523,7 +522,7 @@ class UsersController extends Controller
|
||||||
$logaction->logaction('checkin from');
|
$logaction->logaction('checkin from');
|
||||||
}
|
}
|
||||||
|
|
||||||
LicenseSeat::whereIn('id', $license_array)->update(['assigned_to' => NULL]);
|
LicenseSeat::whereIn('id', $license_array)->update(['assigned_to' => null]);
|
||||||
|
|
||||||
foreach ($users as $user) {
|
foreach ($users as $user) {
|
||||||
$user->accessories()->sync(array());
|
$user->accessories()->sync(array());
|
||||||
|
@ -562,10 +561,10 @@ class UsersController extends Controller
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
// Restore the user
|
// Restore the user
|
||||||
if (User::withTrashed()->where('id',$id)->restore()) {
|
if (User::withTrashed()->where('id', $id)->restore()) {
|
||||||
return redirect()->route('users')->with('success', trans('admin/users/message.success.restored'));
|
return redirect()->route('users')->with('success', trans('admin/users/message.success.restored'));
|
||||||
} else {
|
} else {
|
||||||
return redirect()->route('users')->with('error','User could not be restored.');
|
return redirect()->route('users')->with('error', 'User could not be restored.');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -698,8 +697,8 @@ class UsersController extends Controller
|
||||||
->with('company_list', $company_list)
|
->with('company_list', $company_list)
|
||||||
->with('manager_list', $manager_list)
|
->with('manager_list', $manager_list)
|
||||||
->with('user', $user)
|
->with('user', $user)
|
||||||
->with('groups',$groups)
|
->with('groups', $groups)
|
||||||
->with('userGroups',$userGroups)
|
->with('userGroups', $userGroups)
|
||||||
->with('clone_user', $user_to_clone);
|
->with('clone_user', $user_to_clone);
|
||||||
} catch (UserNotFoundException $e) {
|
} catch (UserNotFoundException $e) {
|
||||||
// Prepare the error message
|
// Prepare the error message
|
||||||
|
|
|
@ -59,7 +59,7 @@ class ViewAssetsController extends Controller
|
||||||
public function getRequestableIndex()
|
public function getRequestableIndex()
|
||||||
{
|
{
|
||||||
|
|
||||||
$assets = Asset::with('model', 'defaultLoc', 'assetloc','assigneduser')->Hardware()->RequestableAssets()->get();
|
$assets = Asset::with('model', 'defaultLoc', 'assetloc', 'assigneduser')->Hardware()->RequestableAssets()->get();
|
||||||
|
|
||||||
return View::make('account/requestable-assets', compact('user', 'assets'));
|
return View::make('account/requestable-assets', compact('user', 'assets'));
|
||||||
}
|
}
|
||||||
|
@ -143,7 +143,7 @@ class ViewAssetsController extends Controller
|
||||||
public function getAcceptAsset($logID = null)
|
public function getAcceptAsset($logID = null)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (!$findlog = DB::table('asset_logs')->where('id','=',$logID)->first()) {
|
if (!$findlog = DB::table('asset_logs')->where('id', '=', $logID)->first()) {
|
||||||
echo 'no record';
|
echo 'no record';
|
||||||
//return redirect()->to('account')->with('error', trans('admin/hardware/message.does_not_exist'));
|
//return redirect()->to('account')->with('error', trans('admin/hardware/message.does_not_exist'));
|
||||||
}
|
}
|
||||||
|
@ -189,7 +189,7 @@ class ViewAssetsController extends Controller
|
||||||
{
|
{
|
||||||
|
|
||||||
// Check if the asset exists
|
// Check if the asset exists
|
||||||
if (is_null($findlog = DB::table('asset_logs')->where('id','=',$logID)->first())) {
|
if (is_null($findlog = DB::table('asset_logs')->where('id', '=', $logID)->first())) {
|
||||||
// Redirect to the asset management page
|
// Redirect to the asset management page
|
||||||
return redirect()->to('account/view-assets')->with('error', trans('admin/hardware/message.does_not_exist'));
|
return redirect()->to('account/view-assets')->with('error', trans('admin/hardware/message.does_not_exist'));
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ class CheckForSetup
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (!$request->is('setup*')) {
|
if (!$request->is('setup*')) {
|
||||||
return redirect(config('app.url').'/setup')->with('Request',$request);
|
return redirect(config('app.url').'/setup')->with('Request', $request);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $next($request);
|
return $next($request);
|
||||||
|
|
|
@ -7,7 +7,6 @@ use Config;
|
||||||
use Route;
|
use Route;
|
||||||
use Gate;
|
use Gate;
|
||||||
|
|
||||||
|
|
||||||
class CheckPermissions
|
class CheckPermissions
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -5,6 +5,7 @@ namespace App\Http\Requests;
|
||||||
use App\Http\Requests\Request;
|
use App\Http\Requests\Request;
|
||||||
use App\Models\AssetModel;
|
use App\Models\AssetModel;
|
||||||
use Session;
|
use Session;
|
||||||
|
|
||||||
class AssetRequest extends Request
|
class AssetRequest extends Request
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
|
@ -40,8 +41,7 @@ class AssetRequest extends Request
|
||||||
|
|
||||||
$model = AssetModel::find($this->request->get('model_id'));
|
$model = AssetModel::find($this->request->get('model_id'));
|
||||||
|
|
||||||
if (($model) && ($model->fieldset))
|
if (($model) && ($model->fieldset)) {
|
||||||
{
|
|
||||||
$rules += $model->fieldset->validation_rules();
|
$rules += $model->fieldset->validation_rules();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -138,14 +138,22 @@ Route::group([ 'prefix' => 'api', 'middleware' => 'auth' ], function () {
|
||||||
Route::group([ 'prefix' => 'categories' ], function () {
|
Route::group([ 'prefix' => 'categories' ], function () {
|
||||||
|
|
||||||
Route::get('list', [ 'as' => 'api.categories.list', 'uses' => 'CategoriesController@getDatatable' ]);
|
Route::get('list', [ 'as' => 'api.categories.list', 'uses' => 'CategoriesController@getDatatable' ]);
|
||||||
Route::get( '{categoryID}/asset/view',
|
Route::get(
|
||||||
[ 'as' => 'api.categories.asset.view', 'uses' => 'CategoriesController@getDataViewAssets' ] );
|
'{categoryID}/asset/view',
|
||||||
Route::get( '{categoryID}/accessory/view',
|
[ 'as' => 'api.categories.asset.view', 'uses' => 'CategoriesController@getDataViewAssets' ]
|
||||||
[ 'as' => 'api.categories.accessory.view', 'uses' => 'CategoriesController@getDataViewAccessories' ] );
|
);
|
||||||
Route::get( '{categoryID}/consumable/view',
|
Route::get(
|
||||||
[ 'as' => 'api.categories.consumable.view', 'uses' => 'CategoriesController@getDataViewConsumables' ] );
|
'{categoryID}/accessory/view',
|
||||||
Route::get( '{categoryID}/component/view',
|
[ 'as' => 'api.categories.accessory.view', 'uses' => 'CategoriesController@getDataViewAccessories' ]
|
||||||
[ 'as' => 'api.categories.component.view', 'uses' => 'CategoriesController@getDataViewComponent' ] );
|
);
|
||||||
|
Route::get(
|
||||||
|
'{categoryID}/consumable/view',
|
||||||
|
[ 'as' => 'api.categories.consumable.view', 'uses' => 'CategoriesController@getDataViewConsumables' ]
|
||||||
|
);
|
||||||
|
Route::get(
|
||||||
|
'{categoryID}/component/view',
|
||||||
|
[ 'as' => 'api.categories.component.view', 'uses' => 'CategoriesController@getDataViewComponent' ]
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
/*-- Suppliers API (mostly for creating new ones in-line while creating an asset) --*/
|
/*-- Suppliers API (mostly for creating new ones in-line while creating an asset) --*/
|
||||||
|
|
|
@ -172,8 +172,9 @@ class Asset extends Depreciable
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getDetailedNameAttribute() {
|
public function getDetailedNameAttribute()
|
||||||
if($this->assigned_user) {
|
{
|
||||||
|
if ($this->assigned_user) {
|
||||||
$user_name = $user->fullName();
|
$user_name = $user->fullName();
|
||||||
} else {
|
} else {
|
||||||
$user_name = "Unassigned";
|
$user_name = "Unassigned";
|
||||||
|
@ -542,13 +543,13 @@ class Asset extends Depreciable
|
||||||
|
|
||||||
public function scopeAssetsByLocation($query, $location)
|
public function scopeAssetsByLocation($query, $location)
|
||||||
{
|
{
|
||||||
return $query->where(function ($query) use ($location)
|
return $query->where(function ($query) use ($location) {
|
||||||
{
|
|
||||||
$query->whereHas('assigneduser', function ($query) use ($location)
|
$query->whereHas('assigneduser', function ($query) use ($location) {
|
||||||
{
|
|
||||||
$query->where('users.location_id', '=', $location->id);
|
$query->where('users.location_id', '=', $location->id);
|
||||||
})->orWhere(function ($query) use ($location)
|
})->orWhere(function ($query) use ($location) {
|
||||||
{
|
|
||||||
$query->where('assets.rtd_location_id', '=', $location->id);
|
$query->where('assets.rtd_location_id', '=', $location->id);
|
||||||
$query->whereNull('assets.assigned_to');
|
$query->whereNull('assets.assigned_to');
|
||||||
});
|
});
|
||||||
|
|
|
@ -37,7 +37,4 @@ class Group extends Model
|
||||||
{
|
{
|
||||||
return json_decode($this->permissions, true);
|
return json_decode($this->permissions, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,8 @@ class Setting extends Model
|
||||||
return $static_cache;
|
return $static_cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function setupCompleted() {
|
public static function setupCompleted()
|
||||||
|
{
|
||||||
|
|
||||||
$users_table_exists = Schema::hasTable('users');
|
$users_table_exists = Schema::hasTable('users');
|
||||||
$settings_table_exists = Schema::hasTable('settings');
|
$settings_table_exists = Schema::hasTable('settings');
|
||||||
|
|
|
@ -56,7 +56,7 @@ class User extends Model implements AuthenticatableContract, CanResetPasswordCon
|
||||||
$user_permissions = json_decode($this->permissions, true);
|
$user_permissions = json_decode($this->permissions, true);
|
||||||
|
|
||||||
//If the user is explicitly granted, return false
|
//If the user is explicitly granted, return false
|
||||||
if (($user_permissions!='') && ((array_key_exists($section, $user_permissions)) && ($user_permissions[$section]=='1')) ) {
|
if (($user_permissions!='') && ((array_key_exists($section, $user_permissions)) && ($user_permissions[$section]=='1'))) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,7 +76,8 @@ class User extends Model implements AuthenticatableContract, CanResetPasswordCon
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function isSuperUser() {
|
public function isSuperUser()
|
||||||
|
{
|
||||||
if (!$user_permissions = json_decode($this->permissions, true)) {
|
if (!$user_permissions = json_decode($this->permissions, true)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -79,16 +79,18 @@
|
||||||
<th>Errors</th>
|
<th>Errors</th>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
@foreach (session('import_errors') as $asset => $error)
|
@foreach (session('import_errors') as $asset => $itemErrors)
|
||||||
<tr>
|
<tr>
|
||||||
<td> {{ $asset }}</td>
|
<td> {{ $asset }}</td>
|
||||||
@foreach ($error as $field => $values )
|
<td>
|
||||||
<td> <span><b>{{ $field }}:</b>
|
@foreach ($itemErrors as $field => $values )
|
||||||
|
<b>{{ $field }}:</b>
|
||||||
@foreach( $values as $errorString)
|
@foreach( $values as $errorString)
|
||||||
<span>{{$errorString[0]}} </span>
|
<span>{{$errorString[0]}} </span>
|
||||||
@endforeach
|
@endforeach
|
||||||
</td>
|
<br />
|
||||||
@endforeach
|
@endforeach
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endforeach
|
@endforeach
|
||||||
</tbody>
|
</tbody>
|
||||||
|
|
|
@ -249,10 +249,14 @@
|
||||||
<td>{{ trans('admin/hardware/form.notes') }}</td>
|
<td>{{ trans('admin/hardware/form.notes') }}</td>
|
||||||
<td>{{ $asset->notes }}</td>
|
<td>{{ $asset->notes }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
@if ($asset->created_at)
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{ trans('general.created_at') }}</td>
|
<td>{{ trans('general.created_at') }}</td>
|
||||||
<td>{{ $asset->created_at->format('F j, Y h:iA') }}</td>
|
<td>
|
||||||
|
{{ $user->created_at->format('F j, Y h:iA') }}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
@endif
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div> <!-- /table-responsive -->
|
</div> <!-- /table-responsive -->
|
||||||
|
|
|
@ -111,10 +111,14 @@
|
||||||
<td>{{ $user->userloc->name }}</td>
|
<td>{{ $user->userloc->name }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endif
|
@endif
|
||||||
|
@if ($user->created_at)
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{ trans('general.created_at') }}</td>
|
<td>{{ trans('general.created_at') }}</td>
|
||||||
<td>{{ $user->created_at->format('F j, Y h:iA') }}</td>
|
<td>
|
||||||
|
{{ $user->created_at->format('F j, Y h:iA') }}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
@endif
|
||||||
|
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue