From 2d2da9b7d7abd4d0133492dd344288e9abd45a72 Mon Sep 17 00:00:00 2001 From: Alexander Piskun <13381981+bigcat88@users.noreply.github.com> Date: Thu, 31 Oct 2024 19:06:47 +0200 Subject: [PATCH] Stopping of docker containers when ExApp is disabling. Backport. (#435) Added stopping of docker containers when ExApp is disabling. Timeout of enable/disable increased to 60. Manual backport of https://github.com/nextcloud/app_api/pull/430 Signed-off-by: Alexander Piskun --- lib/Service/AppAPIService.php | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/lib/Service/AppAPIService.php b/lib/Service/AppAPIService.php index e006d62e..5618c735 100644 --- a/lib/Service/AppAPIService.php +++ b/lib/Service/AppAPIService.php @@ -43,6 +43,7 @@ public function __construct( private readonly DockerActions $dockerActions, private readonly ManualActions $manualActions, private readonly AppAPICommonService $commonService, + private readonly DaemonConfigService $daemonConfigService, ) { $this->client = $clientService->newClient(); } @@ -556,7 +557,13 @@ public function getExAppDomain(ExApp $exApp): string { */ public function enableExApp(ExApp $exApp): bool { if ($this->exAppService->enableExAppInternal($exApp)) { - $exAppEnabled = $this->requestToExApp($exApp, '/enabled?enabled=1', null, 'PUT', options: ['timeout' => 30]); + if ($exApp->getAcceptsDeployId() === $this->dockerActions->getAcceptsDeployId()) { + $daemonConfig = $this->daemonConfigService->getDaemonConfigByName($exApp->getDaemonConfigName()); + $this->dockerActions->initGuzzleClient($daemonConfig); + $this->dockerActions->startContainer($this->dockerActions->buildDockerUrl($daemonConfig), $this->dockerActions->buildExAppContainerName($exApp->getAppid())); + } + + $exAppEnabled = $this->requestToExApp($exApp, '/enabled?enabled=1', null, 'PUT', options: ['timeout' => 60]); if ($exAppEnabled instanceof IResponse) { $response = json_decode($exAppEnabled->getBody(), true); if (!empty($response['error'])) { @@ -579,7 +586,7 @@ public function enableExApp(ExApp $exApp): bool { */ public function disableExApp(ExApp $exApp): bool { $result = true; - $exAppDisabled = $this->requestToExApp($exApp, '/enabled?enabled=0', null, 'PUT', options: ['timeout' => 30]); + $exAppDisabled = $this->requestToExApp($exApp, '/enabled?enabled=0', null, 'PUT', options: ['timeout' => 60]); if ($exAppDisabled instanceof IResponse) { $response = json_decode($exAppDisabled->getBody(), true); if (isset($response['error']) && strlen($response['error']) !== 0) { @@ -590,6 +597,11 @@ public function disableExApp(ExApp $exApp): bool { $this->logger->error(sprintf('Failed to disable ExApp %s. Error: %s', $exApp->getAppid(), $exAppDisabled['error'])); $result = false; } + if ($exApp->getAcceptsDeployId() === $this->dockerActions->getAcceptsDeployId()) { + $daemonConfig = $this->daemonConfigService->getDaemonConfigByName($exApp->getDaemonConfigName()); + $this->dockerActions->initGuzzleClient($daemonConfig); + $this->dockerActions->stopContainer($this->dockerActions->buildDockerUrl($daemonConfig), $this->dockerActions->buildExAppContainerName($exApp->getAppid())); + } $this->exAppService->disableExAppInternal($exApp); return $result; }