Add Docker container management methods and update Livewire component

This commit is contained in:
Andras Bacsai
2024-02-16 23:09:35 +01:00
parent f8c86769a7
commit 7d6bd10cca
3 changed files with 181 additions and 47 deletions

View File

@@ -225,6 +225,29 @@ class Server extends BaseModel
$services = $this->services();
return $applications->concat($databases)->concat($services->get());
}
public function stopUnmanaged($id) {
return instant_remote_process(["docker stop -t 0 $id"], $this);
}
public function restartUnmanaged($id) {
return instant_remote_process(["docker restart $id"], $this);
}
public function startUnmanaged($id) {
return instant_remote_process(["docker start $id"], $this);
}
public function loadUnmanagedContainers()
{
$containers = instant_remote_process(["docker ps -a --format '{{json .}}' "], $this);
$containers = format_docker_command_output_to_json($containers);
$containers = $containers->map(function ($container) {
$labels = data_get($container, 'Labels');
if (!str($labels)->contains("coolify.managed")) {
return $container;
}
return null;
});
$containers = $containers->filter();
return collect($containers);
}
public function hasDefinedResources()
{
$applications = $this->applications()->count() > 0;
@@ -246,7 +269,7 @@ class Server extends BaseModel
$mariadbs = data_get($standaloneDocker, 'mariadbs', collect([]));
return $postgresqls->concat($redis)->concat($mongodbs)->concat($mysqls)->concat($mariadbs);
})->filter(function ($item) {
return data_get($item,'name') === 'coolify-db';
return data_get($item, 'name') === 'coolify-db';
})->flatten();
}
public function applications()