Fix Docker async launch, email SUBSTRING_INDEX (SQLite), postfix sudo writes

- Docker app launch now runs docker compose up -d in background (nohup &)
  so the API returns immediately instead of timing out during image pulls
- EmailManager syncPostfix: replace MySQL SUBSTRING_INDEX with SQLite SUBSTR/INSTR
- EmailManager syncPostfix: write postfix files via sudo tee (www-data permission fix)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-06-09 22:15:40 +00:00
parent b90ef41677
commit 1ac9728fd7
2 changed files with 25 additions and 13 deletions
+9 -4
View File
@@ -397,10 +397,15 @@ SH;
$yaml = $this->generateComposeYaml($appKey, $domain, $params);
$stack = $this->createStack($accountId, "{$appKey}-{$domain}", $yaml);
// Write stack and start it
$out = $this->composeAction((int)$stack['id'], 'up');
novacpx_log('info', "DockerManager: launched {$appKey} for account {$accountId} on {$domain}");
return ['stack_id' => $stack['id'], 'dir' => $stack['dir'], 'output' => $out];
// Pull images and start stack in background (image pulls can take minutes)
$dir = $stack['dir'];
$stackId = (int)$stack['id'];
$logFile = escapeshellarg("/tmp/novacpx-stack-{$stackId}.log");
$compose = escapeshellarg("{$dir}/docker-compose.yml");
shell_exec("nohup sudo docker compose -f {$compose} up -d > {$logFile} 2>&1 &");
$this->db->execute("UPDATE docker_compose_stacks SET status='starting' WHERE id=?", [$stackId]);
novacpx_log('info', "DockerManager: launching {$appKey} for account {$accountId} on {$domain} (async)");
return ['stack_id' => $stackId, 'dir' => $dir, 'output' => 'Launching in background — refresh in a moment to see status'];
}
private function generateComposeYaml(string $appKey, string $domain, array $p): string {