clrghouz/app/Console/Commands/PacketInfo.php

83 lines
2.5 KiB
PHP
Raw Normal View History

2021-08-12 13:15:45 +00:00
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
2022-11-13 13:29:55 +00:00
use Illuminate\Support\Arr;
2021-08-12 13:15:45 +00:00
2022-11-13 13:29:55 +00:00
use App\Classes\File;
2021-08-12 13:15:45 +00:00
use App\Classes\FTN\Packet;
use App\Models\System;
2021-08-12 13:15:45 +00:00
class PacketInfo extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'packet:info'
2022-11-13 13:29:55 +00:00
.' {file : Packet to process}'
.' {system? : Zone the packet is from}';
2021-08-12 13:15:45 +00:00
/**
* The console command description.
*
* @var string
*/
protected $description = 'Packet Information';
/**
* Execute the console command.
*
* @return mixed
* @throws \App\Classes\FTN\InvalidPacketException
*/
public function handle()
{
2022-11-13 13:29:55 +00:00
$f = new File($this->argument('file'));
$s = $this->argument('system') ? System::where('name',$this->argument('zone'))->singleOrFail() : NULL;
2021-08-12 13:15:45 +00:00
2022-11-13 13:29:55 +00:00
foreach ($f as $packet) {
$pkt = Packet::process($packet,$x=$f->itemName(),$f->itemSize(),$s);
2021-08-12 13:15:45 +00:00
2022-11-13 13:29:55 +00:00
$this->alert(sprintf('File Name: %s',$x));
2021-08-12 13:15:45 +00:00
2022-11-13 13:29:55 +00:00
$this->info(sprintf('Packet Type: %s',$pkt->type));
$this->info(sprintf('From: %s to %s',$pkt->fftn,$pkt->tftn));
$this->info(sprintf('Dated: %s',$pkt->date));
$this->info(sprintf('Password: %s (%s)',$pkt->password,$pkt->password ? 'SET' : 'NOT set'));
$this->info(sprintf('Messages: %d',$pkt->messages->count()));
$this->info(sprintf('Tosser %d (%s) version %s',$pkt->software->code,$pkt->software->name,$pkt->software_ver));
$this->info(sprintf('Capabilities: %x',$pkt->capability));
$this->info(sprintf('Has Errors: %s',$pkt->errors->count() ? 'YES' : 'No'));
$this->info(sprintf('Messages: %d',$pkt->count()));
foreach ($pkt as $msg) {
$this->warn(sprintf('- Date: %s',$msg->date));
$this->warn(sprintf(' - FLAGS: %s',$msg->flags()->filter()->keys()->join(', ')));
$this->warn(sprintf(' - From: %s (%s)',$msg->user_from,$msg->fftn));
$this->warn(sprintf(' - To: %s (%s)',$msg->user_to,$msg->tftn));
$this->warn(sprintf(' - Subject: %s',$msg->subject));
if ($msg->errors)
foreach ($msg->errors->errors()->all() as $error)
$this->line(' - '.$error);
}
foreach ($pkt->errors as $msg) {
$this->error(sprintf('- Date: %s',$msg->date));
$this->error(sprintf(' - FLAGS: %s',$msg->flags()->filter()->keys()->join(', ')));
$this->error(sprintf(' - From: %s (%s)',$msg->user_from,$msg->fftn));
$this->error(sprintf(' - To: %s (%s)',$msg->user_to,$msg->tftn));
$this->error(sprintf(' - Subject: %s',$msg->subject));
2021-08-13 13:46:48 +00:00
foreach ($msg->errors->errors()->all() as $error)
$this->line(' - '.$error);
2022-11-13 13:29:55 +00:00
}
2021-08-13 13:46:48 +00:00
2022-11-13 13:29:55 +00:00
$this->line("\n");
2021-08-12 13:15:45 +00:00
}
}
}