2023-05-24 14:26:50 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
2023-11-23 21:02:30 +01:00
|
|
|
use Illuminate\Support\Carbon;
|
2023-05-24 14:26:50 +02:00
|
|
|
|
|
|
|
class ApplicationDeploymentQueue extends Model
|
|
|
|
{
|
2023-06-30 15:57:40 +02:00
|
|
|
protected $guarded = [];
|
2023-11-23 21:02:30 +01:00
|
|
|
|
2024-05-15 11:31:03 +02:00
|
|
|
public function setStatus(string $status)
|
|
|
|
{
|
2023-12-04 15:08:24 +01:00
|
|
|
$this->update([
|
|
|
|
'status' => $status,
|
|
|
|
]);
|
|
|
|
}
|
2023-11-27 11:54:55 +01:00
|
|
|
public function getOutput($name)
|
|
|
|
{
|
2023-11-23 21:02:30 +01:00
|
|
|
if (!$this->logs) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
return collect(json_decode($this->logs))->where('name', $name)->first()?->output ?? null;
|
|
|
|
}
|
2024-05-15 11:31:03 +02:00
|
|
|
public function commitMessage()
|
|
|
|
{
|
|
|
|
if (empty($this->commit_message) || is_null($this->commit_message)) {
|
|
|
|
return null;
|
|
|
|
}
|
2024-05-15 12:35:28 +02:00
|
|
|
return str($this->commit_message)->trim()->limit(50)->value();
|
2024-05-15 11:31:03 +02:00
|
|
|
}
|
2023-11-23 21:02:30 +01:00
|
|
|
public function addLogEntry(string $message, string $type = 'stdout', bool $hidden = false)
|
|
|
|
{
|
|
|
|
if ($type === 'error') {
|
|
|
|
$type = 'stderr';
|
|
|
|
}
|
2023-11-27 11:54:55 +01:00
|
|
|
$message = str($message)->trim();
|
|
|
|
if ($message->startsWith('╔')) {
|
|
|
|
$message = "\n" . $message;
|
|
|
|
}
|
2023-11-23 21:02:30 +01:00
|
|
|
$newLogEntry = [
|
|
|
|
'command' => null,
|
2023-11-27 11:54:55 +01:00
|
|
|
'output' => remove_iip($message),
|
2023-11-23 21:02:30 +01:00
|
|
|
'type' => $type,
|
|
|
|
'timestamp' => Carbon::now('UTC'),
|
|
|
|
'hidden' => $hidden,
|
|
|
|
'batch' => 1,
|
|
|
|
];
|
|
|
|
if ($this->logs) {
|
|
|
|
$previousLogs = json_decode($this->logs, associative: true, flags: JSON_THROW_ON_ERROR);
|
|
|
|
$newLogEntry['order'] = count($previousLogs) + 1;
|
|
|
|
$previousLogs[] = $newLogEntry;
|
|
|
|
$this->update([
|
|
|
|
'logs' => json_encode($previousLogs, flags: JSON_THROW_ON_ERROR),
|
|
|
|
]);
|
|
|
|
} else {
|
|
|
|
$this->update([
|
|
|
|
'logs' => json_encode([$newLogEntry], flags: JSON_THROW_ON_ERROR),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|
2023-05-24 14:26:50 +02:00
|
|
|
}
|