2021-07-16 00:54:23 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Jobs;
|
|
|
|
|
|
|
|
use Illuminate\Bus\Queueable;
|
|
|
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
|
|
|
use Illuminate\Foundation\Bus\Dispatchable;
|
|
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
|
|
use Illuminate\Queue\SerializesModels;
|
2021-07-24 00:53:35 +10:00
|
|
|
use Illuminate\Support\Facades\Log;
|
2021-07-16 00:54:23 +10:00
|
|
|
|
2021-07-24 00:53:35 +10:00
|
|
|
use App\Classes\FTN\{Message,Process};
|
2021-08-24 23:42:03 +10:00
|
|
|
use App\Models\{Echoarea,Echomail,Netmail,Setup};
|
2021-07-16 00:54:23 +10:00
|
|
|
|
2021-09-06 23:39:32 +10:00
|
|
|
class MessageProcess implements ShouldQueue
|
2021-07-16 00:54:23 +10:00
|
|
|
{
|
2021-09-12 00:07:02 +10:00
|
|
|
private const LOGKEY = 'JMP';
|
2021-08-19 00:20:34 +10:00
|
|
|
|
2021-07-16 00:54:23 +10:00
|
|
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
|
|
|
|
|
|
|
private Message $msg;
|
2021-09-11 00:38:11 +10:00
|
|
|
private bool $skipbot;
|
2021-07-16 00:54:23 +10:00
|
|
|
|
2021-09-11 00:38:11 +10:00
|
|
|
public function __construct(Message $msg,bool $skipbot=FALSE)
|
2021-07-16 00:54:23 +10:00
|
|
|
{
|
|
|
|
// Some checks
|
|
|
|
$this->msg = $msg;
|
2021-09-11 00:38:11 +10:00
|
|
|
$this->skipbot = $skipbot;
|
2021-07-16 00:54:23 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-09-06 23:39:32 +10:00
|
|
|
* When calling MessageProcess - we assume that the packet is from a valid source
|
2021-07-16 00:54:23 +10:00
|
|
|
*/
|
|
|
|
public function handle()
|
|
|
|
{
|
|
|
|
// Load our details
|
|
|
|
$ftns = Setup::findOrFail(config('app.id'))->system->addresses;
|
|
|
|
|
|
|
|
// If we are a netmail
|
|
|
|
if ($this->msg->isNetmail()) {
|
|
|
|
// @todo Enable checks to reject old messages
|
2021-07-24 00:53:35 +10:00
|
|
|
// @todo Enable checks to reject duplicate
|
|
|
|
// @todo Enable checks to see if this is a file request or file send
|
2021-07-16 00:54:23 +10:00
|
|
|
|
|
|
|
// Determine if the message is to this system, or in transit
|
2021-07-18 22:10:21 +10:00
|
|
|
if ($ftns->search(function($item) { return $this->msg->tftn == $item->ftn; }) !== FALSE) {
|
2021-07-16 00:54:23 +10:00
|
|
|
// @todo Check if it is a duplicate message
|
|
|
|
// @todo Check if the message is from a system we know about
|
|
|
|
|
|
|
|
$processed = FALSE;
|
|
|
|
|
|
|
|
// If the message is to a bot, we'll process it
|
2021-09-11 00:38:11 +10:00
|
|
|
if (! $this->skipbot)
|
|
|
|
foreach (config('process.robots') as $class) {
|
|
|
|
if ($processed = $class::handle($this->msg)) {
|
|
|
|
break;
|
|
|
|
}
|
2021-07-16 00:54:23 +10:00
|
|
|
}
|
|
|
|
|
2021-08-15 00:21:04 +10:00
|
|
|
// We'll ignore messages from *fix users
|
|
|
|
if (in_array(strtolower($this->msg->user_from),['filefix','areafix'])) {
|
|
|
|
Log::info(sprintf('Ignoring Netmail to the Hub from (%s) [%s] - its from a bot.',$this->msg->user_from,$this->msg->fftn));
|
|
|
|
|
2021-09-12 22:14:04 +10:00
|
|
|
$o = $this->create_netmail($this->msg);
|
2021-08-15 00:21:04 +10:00
|
|
|
$o->local = TRUE;
|
|
|
|
|
|
|
|
$o->save();
|
|
|
|
|
|
|
|
$processed = TRUE;
|
|
|
|
}
|
|
|
|
|
2021-07-16 00:54:23 +10:00
|
|
|
// If not processed, no users here!
|
|
|
|
if (! $processed) {
|
2021-07-24 00:53:35 +10:00
|
|
|
$reject = [
|
|
|
|
'ÚÄ¿ÚÄ¿ ÂÚÄ¿ÚÄ¿Ú¿',
|
|
|
|
'³ ³ÄÙ ³³ÄÙ³ ³ ',
|
|
|
|
'Á ÀÄÙÀÄÙÀÄÙÀÄÙ Á '
|
|
|
|
];
|
|
|
|
|
|
|
|
Log::info(sprintf('Netmail to the Hub from (%s) [%s] but no users here.',$this->msg->user_from,$this->msg->fftn));
|
|
|
|
|
|
|
|
$reply = "Your Netmail was not processed by the hub and cannot be delivered to anybody (as there are no users here).\r";
|
|
|
|
|
|
|
|
$reply .= "\r";
|
|
|
|
$reply .= "\r";
|
|
|
|
$reply .= "This is your original message:\r";
|
|
|
|
$reply .= "------------------------------ BEING MESSAGE ------------------------------\r";
|
|
|
|
$reply .= sprintf("TO: %s\r",$this->msg->user_to);
|
|
|
|
$reply .= sprintf("SUBJECT: %s\r",$this->msg->subject);
|
|
|
|
$reply .= $this->msg->message;
|
|
|
|
$reply .= "------------------------------ CONTROL LINES ------------------------------\r";
|
|
|
|
$reply .= sprintf("DATE: %s\r",$this->msg->date->format('Y-m-d H:i:s'));
|
|
|
|
$reply .= sprintf("MSGID: %s\r",$this->msg->msgid);
|
|
|
|
|
|
|
|
foreach ($this->msg->kludge as $k=>$v)
|
|
|
|
$reply .= sprintf("@%s: %s\n",strtoupper($k),$v);
|
|
|
|
foreach ($this->msg->via as $via)
|
|
|
|
$reply .= sprintf("VIA: %s\n",$via);
|
|
|
|
|
|
|
|
$reply .= "------------------------------ END MESSAGE ------------------------------\r";
|
|
|
|
|
2021-09-11 23:32:10 +10:00
|
|
|
$o = new Netmail;
|
2021-07-24 00:53:35 +10:00
|
|
|
$o->to = $this->msg->user_from;
|
|
|
|
$o->from = Setup::PRODUCT_NAME;
|
|
|
|
$o->subject = 'Message Undeliverable - '.$this->msg->msgid;
|
2021-07-31 00:35:52 +10:00
|
|
|
$o->datetime = $this->msg->date;
|
|
|
|
$o->tzoffset = $this->msg->date->utcOffset();
|
|
|
|
|
|
|
|
$o->cost = 0;
|
|
|
|
$o->flags = Message::FLAG_LOCAL;
|
|
|
|
|
2021-07-24 00:53:35 +10:00
|
|
|
$o->fftn_id = ($x=$this->msg->tftn_o) ? $x->id : NULL;
|
|
|
|
$o->tftn_id = ($x=$this->msg->fftn_o) ? $x->id : NULL;
|
|
|
|
$o->reply = $this->msg->msgid;
|
2021-07-31 00:35:52 +10:00
|
|
|
$o->msg = Process::format_msg($reply,$reject);
|
2021-07-24 00:53:35 +10:00
|
|
|
|
|
|
|
$o->tagline = 'Do you think it was fate which brought us together? Nah, bad luck :(';
|
2021-07-31 00:35:52 +10:00
|
|
|
$o->tearline = sprintf('%s (%04X)',Setup::PRODUCT_NAME,Setup::PRODUCT_ID);
|
2021-07-24 00:53:35 +10:00
|
|
|
$o->save();
|
2021-07-16 00:54:23 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
// If in transit, store for collection
|
|
|
|
} else {
|
2021-07-24 00:53:35 +10:00
|
|
|
Log::info(sprintf('Netmail [%s] in transit to (%s) [%s] from (%s) [%s].',
|
|
|
|
$this->msg->msgid,
|
|
|
|
$this->msg->user_to,$this->msg->tftn,
|
|
|
|
$this->msg->user_from,$this->msg->fftn,
|
|
|
|
));
|
|
|
|
|
2021-07-16 00:54:23 +10:00
|
|
|
// @todo Check if the message is to a system we know about
|
|
|
|
// @todo In transit loop checking
|
|
|
|
// @todo In transit TRACE response
|
|
|
|
|
2021-09-12 22:14:04 +10:00
|
|
|
$o = $this->create_netmail($this->msg);
|
2021-07-24 00:53:35 +10:00
|
|
|
$o->save();
|
2021-07-16 00:54:23 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
// Else we are echomail
|
|
|
|
} else {
|
2021-08-11 23:45:30 +10:00
|
|
|
$ea = Echoarea::where('name',$this->msg->echoarea)
|
2021-08-22 16:25:43 +10:00
|
|
|
->where('domain_id',$this->msg->fboss_o->zone->domain_id)
|
2021-08-11 23:45:30 +10:00
|
|
|
->single();
|
|
|
|
|
2021-08-19 00:20:34 +10:00
|
|
|
// Check for duplicate messages
|
|
|
|
if ($this->msg->msgid) {
|
|
|
|
$o = Echomail::where('msgid',$this->msg->msgid)->single();
|
|
|
|
|
|
|
|
if ($o) {
|
|
|
|
Log::alert(sprintf('%s:! Ignoring duplicate echomail [%s] in [%s] from (%s) [%s] to (%s).',
|
|
|
|
self::LOGKEY,
|
|
|
|
$this->msg->msgid,
|
|
|
|
$this->msg->echoarea,
|
|
|
|
$this->msg->user_to,$this->msg->tftn,
|
|
|
|
$this->msg->user_from,
|
|
|
|
));
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-31 00:35:52 +10:00
|
|
|
// @todo Can the sender create it if it doesnt exist?
|
2021-08-19 23:35:48 +10:00
|
|
|
// @todo Can the sender send messages to this area?
|
2021-07-31 00:35:52 +10:00
|
|
|
// - Create it, or
|
|
|
|
// - Else record in bad area
|
2021-07-16 00:54:23 +10:00
|
|
|
|
|
|
|
// We know about this area, store it
|
2021-07-31 00:35:52 +10:00
|
|
|
$o = new Echomail;
|
|
|
|
$o->to = $this->msg->user_to;
|
|
|
|
$o->from = $this->msg->user_from;
|
|
|
|
$o->subject = $this->msg->subject;
|
|
|
|
$o->datetime = $this->msg->date;
|
|
|
|
$o->tzoffset = $this->msg->date->utcOffset();
|
|
|
|
|
2021-08-22 16:25:43 +10:00
|
|
|
$o->fftn_id = ($x=$this->msg->fboss_o) ? $x->id : NULL;
|
2021-08-11 23:45:30 +10:00
|
|
|
$o->echoarea_id = $ea?->id;
|
2021-07-31 00:35:52 +10:00
|
|
|
$o->msgid = $this->msg->msgid;
|
|
|
|
|
|
|
|
$o->msg = $this->msg->message_src;
|
2021-08-29 23:58:12 +10:00
|
|
|
$o->path = $this->msg->pathaddress->jsonSerialize();
|
2021-08-19 23:35:48 +10:00
|
|
|
$o->rogue_path = $this->msg->rogue_path->jsonSerialize();
|
2021-08-29 23:58:12 +10:00
|
|
|
$o->seenby = $this->msg->seenaddress->jsonSerialize();
|
|
|
|
$o->rogue_seen = $this->msg->rogue_seen->jsonSerialize();
|
2021-08-19 23:35:48 +10:00
|
|
|
$o->toexport = TRUE;
|
2021-07-31 00:35:52 +10:00
|
|
|
|
|
|
|
$o->save();
|
|
|
|
|
2021-08-19 23:35:48 +10:00
|
|
|
Log::info(sprintf('%s: - Echomail [%s] in [%s] from (%s) [%s] to (%s) - [%s].',
|
|
|
|
self::LOGKEY,
|
|
|
|
$this->msg->msgid,
|
|
|
|
$this->msg->echoarea,
|
2021-09-12 00:07:02 +10:00
|
|
|
$this->msg->user_from,$this->msg->fftn,
|
|
|
|
$this->msg->user_to,
|
2021-08-19 23:35:48 +10:00
|
|
|
$o->id,
|
|
|
|
));
|
|
|
|
|
2021-09-13 23:02:39 +10:00
|
|
|
// If the message is to a bot, but not rescanned, or purposely skipbot set, we'll process it
|
|
|
|
if ((! $this->skipbot) && (! $this->msg->rescanned->count()))
|
2021-09-11 00:38:11 +10:00
|
|
|
foreach (config('process.echomail') as $class) {
|
|
|
|
if ($class::handle($this->msg)) {
|
|
|
|
break;
|
|
|
|
}
|
2021-07-31 00:35:52 +10:00
|
|
|
}
|
2021-07-16 00:54:23 +10:00
|
|
|
}
|
|
|
|
}
|
2021-09-12 22:14:04 +10:00
|
|
|
|
|
|
|
private function create_netmail(Message $msg): Netmail
|
|
|
|
{
|
|
|
|
$o = new Netmail;
|
|
|
|
$o->to = $msg->user_to;
|
|
|
|
$o->from = $msg->user_from;
|
|
|
|
|
|
|
|
$o->fftn_id = ($x=$msg->fftn_o) ? $x->id : NULL;
|
|
|
|
$o->tftn_id = ($x=$msg->tftn_o) ? $x->id : NULL;
|
|
|
|
|
|
|
|
$o->datetime = $msg->date;
|
|
|
|
$o->tzoffset = $msg->date->utcOffset();
|
|
|
|
|
|
|
|
$o->flags = $msg->flags;
|
|
|
|
$o->cost = $msg->cost;
|
|
|
|
$o->msgid = $msg->msgid;
|
|
|
|
|
|
|
|
$o->subject = $msg->subject;
|
|
|
|
$o->msg = $msg->message_src;
|
|
|
|
|
|
|
|
return $o;
|
|
|
|
}
|
2021-07-16 00:54:23 +10:00
|
|
|
}
|