<?php

namespace App\Notifications\Echomails;

use Carbon\Carbon;
use Illuminate\Support\Collection;
use Illuminate\Support\Facades\Log;

use App\Classes\{Fonts\Thick,Page};
use App\Models\{Address,Echomail,Setup};
use App\Notifications\Echomails;
use App\Traits\MessagePath;

class AbsentNodes extends Echomails
{
	use MessagePath;

	private const LOGKEY = 'NNP';

	private Echomail $mo;

	/**
	 * Report on nodes that are have been marked Idle.
	 */
	public function __construct(private Collection $aos)
	{
		parent::__construct();
	}

	/**
	 * Get the mail representation of the notification.
	 *
	 * @param mixed $notifiable
	 * @return Echomail
	 * @throws \Exception
	 */
	public function toEchomail(object $notifiable): Echomail
	{
		$echoarea = $notifiable->routeNotificationFor(static::via);
		$o = $this->setupEchomail($echoarea);
		$now = Carbon::now();

		Log::info(sprintf('%s:+ Creating NODE ABSENT echomail in [%s]',self::LOGKEY,$echoarea->name));

		$our = our_address($echoarea->domain)->last();
		$o->to = 'All';
		$o->subject = 'Status changes for nodes';
		$o->fftn_id = $our->id;
		$o->kludges->put('CHRS:','CP437 2');

		// Message
		$msg = new Page;

		$header = new Thick;
		$header->addText('Clearing Houz');
		$msg->addHeader($header,'FTN Mailer and Tosser',TRUE,0xc4);

		$msg->addText("The following nodes have had their status changed, because they are absent from the network.\r\r");

		// Nodes marked HOLD - will be marked down ...
		if (($x=$this->aos->filter(fn($item)=>$item->role & Address::NODE_HOLD))->count()) {
			$msg->addText("The following nodes have been marked HOLD:\r");

			foreach ($x as $ao)
				$msg->addText(sprintf('* %s (%s), last seen %d days ago',$ao->ftn4d,$ao->system->name,$ao->system->last_session->diffInDays($now)).($ao->contacted ? '': ' ^')."\r");

			$msg->addText("\r");
		}

		// Nodes marked DOWN - will be delisted on...
		if (($x=$this->aos->filter(fn($item)=>$item->role & Address::NODE_DOWN))->count()) {
			$msg->addText("The following nodes have been marked DOWN:\r");

			foreach ($x as $ao)
				$msg->addText(sprintf('* %s (%s), last seen %d days ago',$ao->ftn4d,$ao->system->name,$ao->system->last_session->diffInDays($now)).($ao->contacted ? '': ' ^')."\r");

			$msg->addText("\r");
		}

		// Nodes DELISTED
		if (($x=$this->aos->filter(fn($item)=>! $item->active))->count()) {
			$msg->addText("The following nodes have been DE-LISTED:\r");

			foreach ($x as $ao)
				$msg->addText(sprintf('* %s (%s), last seen %d days ago',$ao->ftn4d,$ao->system->name,$ao->system->last_session->diffInDays($now)).($ao->contacted ? '': ' ^')."\r");

			$msg->addText("\r");
		}

		if ($this->aos->filter(fn($item)=>(! $item->contacted))->count())
			$msg->addText("^ Unable to contact these nodes.\r");

		$msg->addText("\rEmails and/or Netmails have been sent to these nodes. If you can help let them know that they have outstanding mail on the Hub, that would be helpful :)");

		$o->msg = $msg->render();
		$o->set_tagline = 'When life gives you lemons, freeze them and throw them back.';
		$o->set_origin = sprintf('%s (%s)',Setup::PRODUCT_NAME,$our->ftn4d);

		$o->save();

		return $o;
	}
}