NodesNew also now sends an Echomail
All checks were successful
Create Docker Image / Build Docker Image (x86_64) (push) Successful in 37s
Create Docker Image / Build Docker Image (arm64) (push) Successful in 1m34s
Create Docker Image / Final Docker Image Manifest (push) Successful in 10s

This commit is contained in:
Deon George 2024-12-08 21:38:10 +11:00
parent f4ee2e1a51
commit 46cf488337
4 changed files with 145 additions and 21 deletions

View File

@ -2,6 +2,7 @@
namespace App\Jobs;
use Carbon\Carbon;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
@ -19,7 +20,9 @@ class AddressIdleDomain implements ShouldQueue
*/
public function handle(): void
{
foreach (Domain::whereNotNull('nodestatus_id')->cursor() as $do)
foreach (Domain::whereNotNull('nodestatus_id')->cursor() as $do) {
AddressIdle::dispatch($do);
NodesNew::dispatch($do,Carbon::now()->subWeek()->startOfDay());
}
}
}

View File

@ -12,7 +12,8 @@ use Illuminate\Support\Facades\Log;
use Illuminate\Support\Facades\Notification;
use App\Models\{Address,Domain};
use App\Notifications\Netmails\NodesNew as NotificationNodesNew;
use App\Notifications\Echomails\NodesNew as NodesNewEchomail;
use App\Notifications\Netmails\NodesNew as NodesNewNetmail;
class NodesNew implements ShouldQueue
{
@ -21,7 +22,7 @@ class NodesNew implements ShouldQueue
private const LOGKEY = 'JNN';
private ?Carbon $since; // New nodes since this date
private Address $ao; // Domain we are processing
private ?Address $ao; // Domain we are processing
private Domain $do; // Domain we are processing
/**
@ -39,7 +40,7 @@ class NodesNew implements ShouldQueue
*/
public function handle(): void
{
$since = ($this->since ?: Carbon::parse('last saturday'))->startOfDay();
$since = ($this->since ?: Carbon::parse('last monday'))->startOfDay();
$result = Address::FTN()
->ActiveFTN()
@ -48,18 +49,19 @@ class NodesNew implements ShouldQueue
->join('system_zone',['system_zone.system_id'=>'systems.id','system_zone.zone_id'=>'zones.id'])
->whereIn('zones.id',$this->do->zones->pluck('id'))
->where('systems.active',TRUE)
->where('systems.created_at','>=',$since)
->where('addresses.created_at','>=',$since)
->orderBy('addresses.created_at')
->get();
if ($result->count()) {
Log::notice(sprintf('%s:- Sending new nodes since [%s] (%d)',self::LOGKEY,$since,$result->count()));
Notification::route('netmail',$this->ao->withoutRelations())
->notify(new NotificationNodesNew(
$since,
$result,
));
if ($this->ao)
Notification::route('netmail',$this->ao->withoutRelations())
->notify(new NodesNewNetmail($since,$result));
else
Notification::route('echomail',$this->do->nodestatus_echoarea)
->notify(new NodesNewEchomail($since,$result));
} else
Log::notice(sprintf('%s:- No nodes since [%s]',self::LOGKEY,$since));

View File

@ -0,0 +1,114 @@
<?php
namespace App\Notifications\Echomails;
use Carbon\Carbon;
use Illuminate\Bus\Queueable;
use Illuminate\Database\Eloquent\Collection;
use Illuminate\Support\Facades\Log;
use App\Notifications\Echomails;
use App\Models\{Address,Echomail};
use App\Traits\PageTemplate;
class NodesNew extends Echomails //implements ShouldQueue
{
use Queueable,PageTemplate;
private const LOGKEY = 'NNN';
private Carbon $since;
private Collection $list;
/**
* Create a new notification instance.
*/
public function __construct(Carbon $since,Collection $list)
{
parent::__construct();
$this->list = $list;
$this->since = $since;
}
public function toEchomail(object $notifiable): Echomail
{
$echoarea = $notifiable->routeNotificationFor(static::via);
$o = $this->setupEchomail($echoarea);
Log::info(sprintf('%s:+ Sending a NEW NODE LIST to echoarea [%s]',self::LOGKEY,$echoarea->name));
$o->subject = sprintf('Here is a list of new nodes on clrghouz since %s',$this->since->format('Y-m-d'));
$our = our_address($echoarea->domain)->last();
$o->to = 'All';
$o->subject = 'New nodes to '.$echoarea->domain->name;
$o->fftn_id = $our->id;
$o->kludges->put('CHRS:','CP437 2');
$o->msg = $this->report();
$o->set_tagline = 'All aboard!';
$o->save();
return $o;
}
/**
* Return the rendered new nodes report.
*/
public function report(): string
{
// Message
$msg = $this->page(FALSE,'new nodes');
$msg->addText("Hi Everyone,\r\r")
->addText(sprintf("The following new system have been defined on clrghouz since %s.\r\r",$this->since->format('Y-m-d')));
$this->list->loadMissing(['system']);
$space = str_repeat(' ',$this->list->pluck('ftn4d')->max(fn($item)=>strlen($item))+2);
$c = 0;
foreach ($this->list as $oo) {
if ($c++)
$msg->addText("\r");
$msg->addText(sprintf("* %s - %s (%s) from %s.\r",$oo->ftn4D,$oo->system->sysop,$oo->system->name,$oo->system->location));
$msg->addText(sprintf("%s Address registered: %s\r\r",$space,$oo->created_at->format('Y-m-d')));
if ($oo->system->method) {
switch ($oo->system->method) {
case 23:
$msg->addText(sprintf("%s - BBS is available TELNET [%s:%d]\r",$space,$oo->system->address,$oo->system->port));
break;
case 22:
$msg->addText(sprintf("%s - BBS is available SSH [%s:%d]\r",$space,$oo->system->address,$oo->system->port));
break;
case 519:
$msg->addText(sprintf("%s - BBS is available RLOGIN [%s:%d]\r",$space,$oo->system->address,$oo->system->port));
break;
default:
$msg->addText(sprintf("%s - No Details available for connecting to BBS\r",$space));
}
}
if ($oo->system->mailers->count()) {
$msg->addText("\r");
$msg->addText(sprintf("%s - Mail can be sent using:\r",$space));
foreach ($oo->system->mailers as $mo) {
$msg->addText(sprintf("%s * %s [%s:%d]\r",$space,$mo->name,$oo->system->address,$mo->pivot->port));
}
} else {
$msg->addText(sprintf("%s - No mailer information provided, so will be PRIVATE\r",$space));
}
}
return $msg->render();
}
}

View File

@ -32,9 +32,6 @@ class NodesNew extends Netmails //implements ShouldQueue
$this->since = $since;
}
/**
* Get the mail representation of the notification.
*/
public function toNetmail(object $notifiable): Netmail
{
$o = $this->setupNetmail($notifiable);
@ -42,14 +39,27 @@ class NodesNew extends Netmails //implements ShouldQueue
Log::info(sprintf('%s:+ Sending a NEW NODE LIST to [%s] at address [%s]',self::LOGKEY,$ao->system->sysop,$ao->ftn));
$o->subject = sprintf('Here is a list of new nodes on clrghouz since %s',$x=$this->since->format('Y-m-d'));
$o->subject = sprintf('Here is a list of new nodes on clrghouz since %s',$this->since->format('Y-m-d'));
$o->flags = (Message::FLAG_LOCAL|Message::FLAG_PRIVATE|Message::FLAG_CRASH);
$o->msg = $this->report($ao);
$o->set_tagline = 'All aboard!';
$o->save();
return $o;
}
/**
* Return the rendered new nodes report.
*/
public function report(Address $ao): string
{
// Message
$msg = $this->page(FALSE,'new nodes');
$msg->addText(sprintf("Hi %s,\r\r",$ao->system->sysop))
->addText(sprintf("The following new system have been defined on clrghouz since %s.\r\r",$x));
->addText(sprintf("The following new system have been defined on clrghouz since %s.\r\r",$this->since->format('Y-m-d')));
$this->list->loadMissing(['system']);
@ -95,11 +105,6 @@ class NodesNew extends Netmails //implements ShouldQueue
}
}
$o->msg = $msg->render();
$o->set_tagline = 'All aboard!';
$o->save();
return $o;
return $msg->render();
}
}