Skip to content

Commit

Permalink
Artisan command to check in licenses from all users
Browse files Browse the repository at this point in the history
  • Loading branch information
snipe committed Aug 14, 2020
1 parent f1a6308 commit e0f6f9b
Showing 1 changed file with 94 additions and 0 deletions.
94 changes: 94 additions & 0 deletions app/Console/Commands/CheckinLicensesFromAllUsers.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
<?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 CheckinLicensesFromAllUsers extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'snipeit:checkin-from-all {--license_id=} {--notify}';

/**
* The console command description.
*
* @var string
*/
protected $description = 'Checks in licenses from all users';

/**
* 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)->first()) {
$this->error('Invalid license ID');
return false;
}

$this->info('Checking in ALL seats for '.$license->name);


$licenseSeats = LicenseSeat::where('license_id', '=', $license_id)
->whereNotNull('assigned_to')
->with('user')
->get();

$this->info(' There are ' .$licenseSeats->count(). ' seats checked out: ');

if (!$notify) {
$this->info('No mail will be sent.');
}

foreach ($licenseSeats as $seat) {
$this->info($seat->user->username .' has a license seat for '.$license->name);

if (!$notify) {
$seat->user->email = null;
}

$seat->assigned_to = null;

if ($seat->save()) {
// Log the checkin
$seat->logCheckin($license, 'Checked in via cli tool');
}




}


}
}

0 comments on commit e0f6f9b

Please sign in to comment.