From 947bf4b5e63c7cf5e92a2a9ad2fdb4a5e5ff1302 Mon Sep 17 00:00:00 2001 From: Austin Best Date: Sun, 28 Jul 2024 19:29:21 -0400 Subject: [PATCH] Fix json marshal error when adding a container with no IPAMConfig --- .../www/public/classes/traits/Docker/API.php | 32 +++++++++++-------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/root/app/www/public/classes/traits/Docker/API.php b/root/app/www/public/classes/traits/Docker/API.php index 8af0cb9..0d21be9 100644 --- a/root/app/www/public/classes/traits/Docker/API.php +++ b/root/app/www/public/classes/traits/Docker/API.php @@ -110,12 +110,12 @@ public function apiCreateContainer($inspect = []) { $inspect = $inspect[0] ? $inspect[0] : $inspect; $image = $inspect['Config']['Image']; - + $containerName = ''; if ($inspect['Name']) { $containerName = str_replace('/', '', $inspect['Name']); } - + if (!$containerName && !empty($inspect['Config']['Env'])) { foreach ($inspect['Config']['Env'] as $env) { if (str_contains($env, 'HOST_CONTAINERNAME')) { @@ -124,7 +124,7 @@ public function apiCreateContainer($inspect = []) } } } - + $payload = [ 'Hostname' => $inspect['Config']['Hostname'] ? $inspect['Config']['Hostname'] : $containerName, 'Domainname' => $inspect['Config']['Domainname'], @@ -136,7 +136,7 @@ public function apiCreateContainer($inspect = []) 'StopSignal' => $inspect['Config']['StopSignal'], 'WorkingDir' => $inspect['Config']['WorkingDir'] ]; - + $payload['Env'] = $inspect['Config']['Env']; $payload['Cmd'] = $inspect['Config']['Cmd']; $payload['Healthcheck'] = $inspect['Config']['Healthcheck']; @@ -147,16 +147,20 @@ public function apiCreateContainer($inspect = []) $payload['NetworkingConfig'] = [ 'EndpointsConfig' => $inspect['NetworkSettings']['Networks'] ]; - + //-- API VALIDATION STUFF if (empty($payload['HostConfig']['PortBindings'])) { $payload['HostConfig']['PortBindings'] = null; } - + if (empty($payload['NetworkingConfig']['EndpointsConfig'])) { $payload['NetworkingConfig']['EndpointsConfig'] = null; + } else { + if (empty($payload['NetworkingConfig']['EndpointsConfig']['IPAMConfig'])) { + $payload['NetworkingConfig']['EndpointsConfig']['IPAMConfig'] = '{}'; + } } - + if (empty($payload['ExposedPorts'])) { $payload['ExposedPorts'] = null; } else { @@ -164,7 +168,7 @@ public function apiCreateContainer($inspect = []) $payload['ExposedPorts'][$port] = null; } } - + if (empty($payload['Volumes'])) { $payload['Volumes'] = null; } else { @@ -172,16 +176,16 @@ public function apiCreateContainer($inspect = []) $payload['Volumes'][$volume] = null; } } - + if (empty($payload['HostConfig']['LogConfig']['Config'])) { $payload['HostConfig']['LogConfig']['Config'] = null; } - + //-- PART OF A CONTAINER NETWORK if (str_contains($payload['HostConfig']['NetworkMode'], 'container:')) { $payload['Hostname'] = null; $payload['ExposedPorts'] = null; - + //-- MAKE SURE THE ID IS UPDATED $dependencyFile = getServerFile('dependency'); $dependencyFile = is_array($dependencyFile['file']) && !empty($dependencyFile['file']) ? $dependencyFile['file'] : []; @@ -193,7 +197,7 @@ public function apiCreateContainer($inspect = []) } } } - + if (empty($payload['HostConfig']['Mounts'])) { $payload['HostConfig']['Mounts'] = null; } else { @@ -203,7 +207,7 @@ public function apiCreateContainer($inspect = []) } } } - + if ($payload['NetworkSettings']['Networks']) { foreach ($payload['NetworkSettings']['Networks'] as $network => $networkSettings) { if ($networkSettings['Aliases']) { @@ -220,7 +224,7 @@ public function apiCreateContainer($inspect = []) } } } - + return [ 'container' => $containerName, 'endpoint' => sprintf(DockerApi::CREATE_CONTAINER, $containerName),