mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-11 22:07:29 -08:00
Added more detail and dryrun to assigned_to vs log checker script
This commit is contained in:
parent
e110a7b15e
commit
0b4a13156f
|
@ -13,14 +13,22 @@ class FixMismatchedAssetsAndLogs extends Command
|
||||||
*
|
*
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
protected $signature = 'snipeit:fix-assets-and-logs';
|
protected $signature = 'snipeit:fix-assets-and-logs {--dryrun : Run the sync process but don\'t update the database}';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command description.
|
* The console command description.
|
||||||
*
|
*
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
protected $description = 'Command description';
|
protected $description = 'This script attempts to check the log table and check that the assets.assigned_to matches the last checkout.';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Is dry-run?
|
||||||
|
*
|
||||||
|
* @var bool
|
||||||
|
*/
|
||||||
|
private $dryrun = false;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new command instance.
|
* Create a new command instance.
|
||||||
|
@ -40,8 +48,16 @@ class FixMismatchedAssetsAndLogs extends Command
|
||||||
public function handle()
|
public function handle()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if ($this->option('dryrun')) {
|
||||||
|
$this->dryrun = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->dryrun) {
|
||||||
|
$this->info('This is a DRY RUN - no changes will be saved.' );
|
||||||
|
}
|
||||||
|
|
||||||
$mismatch_count = 0;
|
$mismatch_count = 0;
|
||||||
$assets = Asset::whereNotNull('assigned_to')->get();
|
$assets = Asset::whereNotNull('assigned_to')->where('assigned_type', '=', 'App\\Models\\User')->get();
|
||||||
foreach ($assets as $asset) {
|
foreach ($assets as $asset) {
|
||||||
|
|
||||||
// get the last checkout of the asset
|
// get the last checkout of the asset
|
||||||
|
@ -59,16 +75,22 @@ class FixMismatchedAssetsAndLogs extends Command
|
||||||
->orderBy('created_at', 'DESC')
|
->orderBy('created_at', 'DESC')
|
||||||
->first()) {
|
->first()) {
|
||||||
|
|
||||||
// $this->info($checkout_log->id.' is checked out to '.$checkout_log->target_type.' '.$checkout_log->target_id.' and there is no subsequent checkin log.');
|
|
||||||
|
|
||||||
|
|
||||||
//print_r($asset);
|
//print_r($asset);
|
||||||
if ($checkout_log->target_id != $asset->assigned_to) {
|
if ($checkout_log->target_id != $asset->assigned_to) {
|
||||||
$this->error('Log ID: '.$checkout_log->id.' -- Asset ID '. $checkout_log->item_id.' SHOULD BE checked out to User '.$checkout_log->target_id.' but its assigned_to is '.$asset->assigned_to );
|
$this->error('Log ID: '.$checkout_log->id.' -- Asset ID '. $checkout_log->item_id.' SHOULD BE checked out to User '.$checkout_log->target_id.' but its assigned_to is '.$asset->assigned_to );
|
||||||
|
|
||||||
|
if (!$this->dryrun) {
|
||||||
|
$asset->assigned_to = $checkout_log->target_id;
|
||||||
|
if ($asset->save()) {
|
||||||
|
$this->info('Asset record updated.');
|
||||||
|
} else {
|
||||||
|
$this->errro('Error updating asset: '.$asset->getErrors());
|
||||||
|
}
|
||||||
|
}
|
||||||
$mismatch_count++;
|
$mismatch_count++;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$this->info('Asset ID '.$asset->id.': There is a checkin '.$checkin_log->created_at.' after this checkout '.$checkout_log->created_at);
|
//$this->info('Asset ID '.$asset->id.': There is a checkin '.$checkin_log->created_at.' after this checkout '.$checkout_log->created_at);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue