mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-15 07:47:26 -08:00
dbbb7680d9
Do not check out a piece of software if it’s already been checked out to the user
113 lines
3 KiB
PHP
113 lines
3 KiB
PHP
<?php
|
|
|
|
namespace App\Console\Commands;
|
|
|
|
use App\Models\LicenseSeat;
|
|
use Illuminate\Console\Command;
|
|
use App\Models\User;
|
|
use App\Models\License;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
class CheckoutLicenseToAllUsers extends Command
|
|
{
|
|
/**
|
|
* The name and signature of the console command.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $signature = 'snipeit:checkout-to-all {--license_id=} {--notify}';
|
|
|
|
/**
|
|
* The console command description.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $description = 'Command description';
|
|
|
|
/**
|
|
* Create a new command instance.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* Execute the console command.
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function handle()
|
|
{
|
|
|
|
$license_id = $this->option('license_id');
|
|
$notify = $this->option('notify');
|
|
|
|
if (!$license_id) {
|
|
$this->error('ERROR: License ID is required.');
|
|
return false;
|
|
}
|
|
|
|
|
|
if (!$license = License::where('id','=',$license_id)->with('assignedusers')->first()) {
|
|
$this->error('Invalid license ID');
|
|
return false;
|
|
}
|
|
|
|
$users = User::whereNull('deleted_at')->with('licenses')->get();
|
|
|
|
if ($users->count() > $license->getAvailSeatsCountAttribute()) {
|
|
$this->info('You do not have enough free seats to complete this task, so we will check out as many as we can. ');
|
|
}
|
|
|
|
$this->info('Checking out '.$users->count().' of '.$license->getAvailSeatsCountAttribute().' seats for '.$license->name);
|
|
|
|
if (!$notify) {
|
|
$this->info('No mail will be sent.');
|
|
}
|
|
|
|
foreach ($users as $user) {
|
|
|
|
// Check to make sure this user doesn't already have this license checked out
|
|
// to them
|
|
|
|
if ($user->licenses->where('id', '=', $license_id)->count()) {
|
|
$this->info($user->username .' already has this license checked out to them. Skipping... ');
|
|
continue;
|
|
}
|
|
|
|
|
|
// If the license is valid, check that there is an available seat
|
|
if ($license->availCount()->count() < 1) {
|
|
$this->error('ERROR: No available seats');
|
|
return false;
|
|
}
|
|
|
|
$this->info($license->availCount()->count().' seats left');
|
|
// Get the seat ID
|
|
$licenseSeat = $license->freeSeat();
|
|
|
|
|
|
// Update the seat with checkout info,
|
|
$licenseSeat->assigned_to = $user->id;
|
|
if ($licenseSeat->save()) {
|
|
|
|
// Temporarily null the user's email address so we don't send mail if we're not supposed to
|
|
if (!$notify) {
|
|
$user->email = null;
|
|
}
|
|
|
|
// Log the checkout
|
|
$licenseSeat->logCheckout('Checked out via cli tool', $user);
|
|
$this->info('License '.$license_id.' seat '.$licenseSeat->id.' checked out to '.$user->username);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
}
|