mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-24 04:03:34 -08:00
f999c797e5
Some licenses, such as windows licenses, are machine specific. This commit allows an extra field to be added to the license importer to allow these licenses to be imported and attached directly to an asset
399 lines
14 KiB
PHP
399 lines
14 KiB
PHP
<?php
|
|
namespace App\Console\Commands;
|
|
|
|
use Illuminate\Console\Command;
|
|
use Symfony\Component\Console\Input\InputOption;
|
|
use Symfony\Component\Console\Input\InputArgument;
|
|
use League\Csv\Reader;
|
|
use App\Models\User;
|
|
use App\Models\Supplier;
|
|
use App\Models\License;
|
|
use App\Models\LicenseSeat;
|
|
use App\Models\Asset;
|
|
|
|
class LicenseImportCommand extends Command
|
|
{
|
|
|
|
/**
|
|
* The console command name.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $name = 'snipeit:license-import';
|
|
|
|
/**
|
|
* The console command description.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $description = 'Import Licenses from CSV';
|
|
|
|
/**
|
|
* Create a new command instance.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* Execute the console command.
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function fire()
|
|
{
|
|
$filename = $this->argument('filename');
|
|
|
|
|
|
if (!$this->option('testrun')=='true') {
|
|
$this->comment('======= Importing Licenses from '.$filename.' =========');
|
|
} else {
|
|
$this->comment('====== TEST ONLY License Import for '.$filename.' ====');
|
|
$this->comment('============== NO DATA WILL BE WRITTEN ==============');
|
|
}
|
|
|
|
if (! ini_get("auto_detect_line_endings")) {
|
|
ini_set("auto_detect_line_endings", '1');
|
|
}
|
|
|
|
$csv = Reader::createFromPath($this->argument('filename'));
|
|
$csv->setNewline("\r\n");
|
|
$csv->setOffset(1);
|
|
$duplicates = '';
|
|
|
|
// Loop through the records
|
|
$nbInsert = $csv->each(function ($row) use ($duplicates) {
|
|
$status_id = 1;
|
|
|
|
// Let's just map some of these entries to more user friendly words
|
|
|
|
if (array_key_exists('0', $row)) {
|
|
$user_name = trim($row[0]);
|
|
} else {
|
|
$user_name = '';
|
|
}
|
|
|
|
if (array_key_exists('1', $row)) {
|
|
$user_email = trim($row[1]);
|
|
} else {
|
|
$user_email = '';
|
|
}
|
|
|
|
if (array_key_exists('2', $row)) {
|
|
$user_username = trim($row[2]);
|
|
} else {
|
|
$user_username = '';
|
|
}
|
|
|
|
if (array_key_exists('3', $row)) {
|
|
$user_license_name = trim($row[3]);
|
|
} else {
|
|
$user_license_name = '';
|
|
}
|
|
|
|
if (array_key_exists('4', $row)) {
|
|
$user_license_serial = trim($row[4]);
|
|
} else {
|
|
$user_license_serial = '';
|
|
}
|
|
|
|
if (array_key_exists('5', $row)) {
|
|
$user_licensed_to_name = trim($row[5]);
|
|
} else {
|
|
$user_licensed_to_name = '';
|
|
}
|
|
|
|
if (array_key_exists('6', $row)) {
|
|
$user_licensed_to_email = trim($row[6]);
|
|
} else {
|
|
$user_licensed_to_email = '';
|
|
}
|
|
|
|
if (array_key_exists('7', $row)) {
|
|
$user_license_seats = trim($row[7]);
|
|
} else {
|
|
$user_license_seats = '';
|
|
}
|
|
|
|
if (array_key_exists('8', $row)) {
|
|
$user_license_reassignable = trim($row[8]);
|
|
if ($user_license_reassignable!='') {
|
|
if ((strtolower($user_license_reassignable)=='yes') || (strtolower($user_license_reassignable)=='true') || ($user_license_reassignable=='1')) {
|
|
$user_license_reassignable = 1;
|
|
}
|
|
} else {
|
|
$user_license_reassignable = 0;
|
|
}
|
|
} else {
|
|
$user_license_reassignable = 0;
|
|
}
|
|
|
|
if (array_key_exists('9', $row)) {
|
|
$user_license_supplier = trim($row[9]);
|
|
} else {
|
|
$user_license_supplier = '';
|
|
}
|
|
|
|
if (array_key_exists('10', $row)) {
|
|
$user_license_maintained = trim($row[10]);
|
|
|
|
if ($user_license_maintained!='') {
|
|
if ((strtolower($user_license_maintained)=='yes') || (strtolower($user_license_maintained)=='true') || ($user_license_maintained=='1')) {
|
|
$user_license_maintained = 1;
|
|
}
|
|
} else {
|
|
$user_license_maintained = 0;
|
|
}
|
|
|
|
|
|
} else {
|
|
$user_license_maintained = '';
|
|
}
|
|
|
|
if (array_key_exists('11', $row)) {
|
|
$user_license_notes = trim($row[11]);
|
|
} else {
|
|
$user_license_notes = '';
|
|
}
|
|
|
|
if (array_key_exists('12', $row)) {
|
|
if ($row[12]!='') {
|
|
$user_license_purchase_date = date("Y-m-d 00:00:01", strtotime($row[12]));
|
|
} else {
|
|
$user_license_purchase_date = '';
|
|
}
|
|
} else {
|
|
$user_license_purchase_date = 0;
|
|
}
|
|
|
|
if (array_key_exists('13', $row)) {
|
|
$user_licensed_to_asset = trim($row[13]);
|
|
} else {
|
|
$user_licensed_to_asset = '';
|
|
}
|
|
|
|
// A number was given instead of a name
|
|
if (is_numeric($user_name)) {
|
|
$this->comment('User '.$user_name.' is not a name - assume this user already exists');
|
|
$user_username = '';
|
|
// No name was given
|
|
|
|
} elseif ($user_name=='') {
|
|
$this->comment('No user data provided - skipping user creation, just adding license');
|
|
$first_name = '';
|
|
$last_name = '';
|
|
$user_username = '';
|
|
|
|
} else {
|
|
|
|
$name = explode(" ", $user_name);
|
|
$first_name = $name[0];
|
|
$email_last_name = '';
|
|
$email_prefix = $first_name;
|
|
|
|
if (!array_key_exists(1, $name)) {
|
|
$last_name='';
|
|
$email_last_name = $last_name;
|
|
$email_prefix = $first_name;
|
|
} else {
|
|
$last_name = str_replace($first_name, '', $user_name);
|
|
|
|
if ($this->option('email_format')=='filastname') {
|
|
$email_last_name.=str_replace(' ', '', $last_name);
|
|
$email_prefix = $first_name[0].$email_last_name;
|
|
|
|
} elseif ($this->option('email_format')=='firstname.lastname') {
|
|
$email_last_name.=str_replace(' ', '', $last_name);
|
|
$email_prefix = $first_name.'.'.$email_last_name;
|
|
|
|
} elseif ($this->option('email_format')=='firstname') {
|
|
$email_last_name.=str_replace(' ', '', $last_name);
|
|
$email_prefix = $first_name;
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
$user_username = $email_prefix;
|
|
|
|
// Generate an email based on their name if no email address is given
|
|
if ($user_email=='') {
|
|
if ($first_name=='Unknown') {
|
|
$status_id = 7;
|
|
}
|
|
$email = strtolower($email_prefix).'@'.$this->option('domain');
|
|
$user_email = str_replace("'", '', $email);
|
|
}
|
|
}
|
|
|
|
$this->comment('Full Name: '.$user_name);
|
|
$this->comment('First Name: '.$first_name);
|
|
$this->comment('Last Name: '.$last_name);
|
|
$this->comment('Username: '.$user_username);
|
|
$this->comment('Email: '.$user_email);
|
|
$this->comment('License Name: '.$user_license_name);
|
|
$this->comment('Serial No: '.$user_license_serial);
|
|
$this->comment('Licensed To Name: '.$user_licensed_to_name);
|
|
$this->comment('Licensed To Email: '.$user_licensed_to_email);
|
|
$this->comment('Seats: '.$user_license_seats);
|
|
$this->comment('Reassignable: '.$user_license_reassignable);
|
|
$this->comment('Supplier: '.$user_license_supplier);
|
|
$this->comment('Maintained: '.$user_license_maintained);
|
|
$this->comment('Notes: '.$user_license_notes);
|
|
$this->comment('Purchase Date: '.$user_license_purchase_date);
|
|
$this->comment('Asset ID: '.$user_licensed_to_asset);
|
|
|
|
$this->comment('------------- Action Summary ----------------');
|
|
|
|
if ($user_username!='') {
|
|
if ($user = User::where('username', $user_username)->whereNotNull('username')->first()) {
|
|
$this->comment('User '.$user_username.' already exists');
|
|
} else {
|
|
|
|
$user = new \App\Models\User;
|
|
$password = substr(str_shuffle("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 20);
|
|
|
|
$user->first_name = $first_name;
|
|
$user->last_name = $last_name;
|
|
$user->username = $user_username;
|
|
$user->email = $user_email;
|
|
$user->permissions = '{user":1}';
|
|
$user->password = bcrypt($password);
|
|
$user->activated = 1;
|
|
if ($user->save()) {
|
|
$this->comment('User '.$first_name.' created');
|
|
} else {
|
|
$this->error('ERROR CREATING User '.$first_name.' '.$last_name);
|
|
$this->error($user->getErrors());
|
|
}
|
|
|
|
$this->comment('User '.$first_name.' created');
|
|
}
|
|
} else {
|
|
$user = new User;
|
|
$user->user_id = null;
|
|
}
|
|
|
|
|
|
// Check for the supplier match and create it if it doesn't exist
|
|
if ($supplier = Supplier::where('name', $user_license_supplier)->first()) {
|
|
$this->comment('Supplier '.$user_license_supplier.' already exists');
|
|
} else {
|
|
$supplier = new Supplier();
|
|
$supplier->name = e($user_license_supplier);
|
|
$supplier->user_id = 1;
|
|
|
|
if ($supplier->save()) {
|
|
$this->comment('Supplier '.$user_license_supplier.' was created');
|
|
} else {
|
|
$this->comment('Something went wrong! Supplier '.$user_license_supplier.' was NOT created');
|
|
}
|
|
|
|
}
|
|
|
|
|
|
// Add the license
|
|
$license = new License();
|
|
$license->name = e($user_license_name);
|
|
if ($user_license_purchase_date!='') {
|
|
$license->purchase_date = $user_license_purchase_date;
|
|
} else {
|
|
$license->purchase_date = null;
|
|
}
|
|
$license->serial = e($user_license_serial);
|
|
$license->seats = e($user_license_seats);
|
|
$license->supplier_id = $supplier->id;
|
|
$license->user_id = 1;
|
|
if ($user_license_purchase_date!='') {
|
|
$license->purchase_date = $user_license_purchase_date;
|
|
} else {
|
|
$license->purchase_date = null;
|
|
}
|
|
$license->license_name = $user_licensed_to_name;
|
|
$license->license_email = $user_licensed_to_email;
|
|
$license->notes = e($user_license_notes);
|
|
|
|
if ($license->save()) {
|
|
$this->comment('License '.$user_license_name.' with serial number '.$user_license_serial.' was created');
|
|
|
|
|
|
$license_seat_created = 0;
|
|
|
|
for ($x = 0; $x < $user_license_seats; $x++) {
|
|
// Create the license seat entries
|
|
$license_seat = new LicenseSeat();
|
|
$license_seat->license_id = $license->id;
|
|
|
|
// Only assign the first seat to the user
|
|
if ($x==0) {
|
|
$license_seat->assigned_to = $user->id;
|
|
} else {
|
|
$license_seat->assigned_to = null;
|
|
}
|
|
|
|
if($user_licensed_to_asset) {
|
|
$asset = Asset::where('asset_tag', $user_licensed_to_asset)->first();
|
|
if($asset) {
|
|
$license_seat->asset_id = $asset->id;
|
|
}
|
|
}
|
|
|
|
if ($license_seat->save()) {
|
|
$license_seat_created++;
|
|
}
|
|
}
|
|
|
|
if ($license_seat_created > 0) {
|
|
$this->comment($license_seat_created.' seats were created');
|
|
} else {
|
|
$this->comment('Something went wrong! NO seats for '.$user_license_name.' were created');
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
$this->comment('Something went wrong! License '.$user_license_name.' was NOT created');
|
|
}
|
|
|
|
|
|
$this->comment('=====================================');
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
/**
|
|
* Get the console command arguments.
|
|
*
|
|
* @return array
|
|
*/
|
|
protected function getArguments()
|
|
{
|
|
return array(
|
|
array('filename', InputArgument::REQUIRED, 'File for the CSV import.'),
|
|
);
|
|
}
|
|
|
|
|
|
/**
|
|
* Get the console command options.
|
|
*
|
|
* @return array
|
|
*/
|
|
protected function getOptions()
|
|
{
|
|
return array(
|
|
array('domain', null, InputOption::VALUE_REQUIRED, 'Email domain for generated email addresses.', null),
|
|
array('email_format', null, InputOption::VALUE_REQUIRED, 'The format of the email addresses that should be generated. Options are firstname.lastname, firstname, filastname', null),
|
|
array('testrun', null, InputOption::VALUE_REQUIRED, 'Test the output without writing to the database or not.', null),
|
|
);
|
|
}
|
|
}
|