coolify/app/Http/Livewire/Project/Shared/GetLogs.php

53 lines
1.6 KiB
PHP
Raw Normal View History

2023-10-02 13:38:16 +02:00
<?php
namespace App\Http\Livewire\Project\Shared;
use App\Models\Server;
use Illuminate\Support\Facades\Process;
use Livewire\Component;
class GetLogs extends Component
{
public string $outputs = '';
public string $errors = '';
public Server $server;
public ?string $container = null;
public ?bool $streamLogs = false;
2023-10-19 13:32:03 +02:00
public ?bool $showTimeStamps = true;
2023-10-02 14:01:54 +02:00
public int $numberOfLines = 100;
2023-10-02 13:38:16 +02:00
public function doSomethingWithThisChunkOfOutput($output)
{
$this->outputs .= removeAnsiColors($output);
2023-10-02 13:38:16 +02:00
}
public function instantSave()
{
}
public function getLogs($refresh = false)
{
if ($this->container) {
2023-10-19 13:32:03 +02:00
if ($this->showTimeStamps) {
$sshCommand = generateSshCommand($this->server, "docker logs -n {$this->numberOfLines} -t {$this->container}");
} else {
$sshCommand = generateSshCommand($this->server, "docker logs -n {$this->numberOfLines} {$this->container}");
}
2023-10-02 13:38:16 +02:00
if ($refresh) {
$this->outputs = '';
}
Process::run($sshCommand, function (string $type, string $output) {
$this->doSomethingWithThisChunkOfOutput($output);
});
if ($this->showTimeStamps) {
$this->outputs = str($this->outputs)->split('/\n/')->sort(function ($a, $b) {
$a = explode(' ', $a);
$b = explode(' ', $b);
return $a[0] <=> $b[0];
})->join("\n");
}
2023-10-02 13:38:16 +02:00
}
}
public function render()
{
return view('livewire.project.shared.get-logs');
}
}