Files
Scheduler/app/Jobs/RunBot.php
Oskar-Mikael 6a72b7150b
All checks were successful
Deploy App / deploy (push) Successful in 11s
Show error
2025-08-31 22:41:48 +02:00

48 lines
1.1 KiB
PHP

<?php
namespace App\Jobs;
use App\Models\Bot;
use App\Models\BotLog;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Queue\Queueable;
class RunBot implements ShouldQueue
{
use Queueable;
/**
* Create a new job instance.
*/
public function __construct(private int $bot_id, private int $log_id) {}
/**
* Execute the job.
*/
public function handle(): void
{
$bot = Bot::findOrFail($this->bot_id);
$log = BotLog::findOrFail($this->log_id);
try {
$class = new $bot->class($bot->config ?? []);
$class->run();
// Update the log entry on success
$log->update([
'finished_at' => now(),
'status' => 'success',
// 'output' => is_string($result) ? $result : json_encode($result, JSON_PRETTY_PRINT),
]);
} catch (\Throwable $e) {
// Log the error in the bot log
$log->update([
'finished_at' => now(),
'status' => 'failed',
'error' => $e->getMessage(),
]);
}
}
}