ConfigController: do not show an exception...
...when a deployment fails
This commit is contained in:
parent
f614d75edc
commit
ade7b1415e
|
@ -59,7 +59,6 @@ class ConfigController extends ActionController
|
||||||
$this->assertPermission('director/deploy');
|
$this->assertPermission('director/deploy');
|
||||||
|
|
||||||
// TODO: require POST
|
// TODO: require POST
|
||||||
$isApiRequest = $this->getRequest()->isApiRequest();
|
|
||||||
$checksum = $this->params->get('checksum');
|
$checksum = $this->params->get('checksum');
|
||||||
if ($checksum) {
|
if ($checksum) {
|
||||||
$config = IcingaConfig::load(Util::hex2binary($checksum), $this->db());
|
$config = IcingaConfig::load(Util::hex2binary($checksum), $this->db());
|
||||||
|
@ -68,28 +67,44 @@ class ConfigController extends ActionController
|
||||||
$checksum = $config->getHexChecksum();
|
$checksum = $config->getHexChecksum();
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->api()->wipeInactiveStages($this->db());
|
try {
|
||||||
|
$this->api()->wipeInactiveStages($this->db());
|
||||||
|
} catch (Exception $e) {
|
||||||
|
$this->deploymentFailed($checksum, $e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
if ($this->api()->dumpConfig($config, $this->db())) {
|
if ($this->api()->dumpConfig($config, $this->db())) {
|
||||||
if ($isApiRequest) {
|
$this->deploymentSucceeded($checksum);
|
||||||
return $this->sendJson((object) array('checksum' => $checksum));
|
|
||||||
} else {
|
|
||||||
$url = Url::fromPath('director/config/deployments');
|
|
||||||
Notification::success(
|
|
||||||
$this->translate('Config has been submitted, validation is going on')
|
|
||||||
);
|
|
||||||
$this->redirectNow($url);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if ($isApiRequest) {
|
$this->deploymentFailed($checksum);
|
||||||
return $this->sendJsonError('Config deployment failed');
|
}
|
||||||
} else {
|
}
|
||||||
$url = Url::fromPath('director/config/show', array('checksum' => $checksum));
|
|
||||||
Notification::success(
|
protected function deploymentSucceeded($checksum)
|
||||||
$this->translate('Config deployment failed')
|
{
|
||||||
);
|
if ($this->getRequest()->isApiRequest()) {
|
||||||
$this->redirectNow($url);
|
return $this->sendJson((object) array('checksum' => $checksum));
|
||||||
}
|
} else {
|
||||||
|
$url = Url::fromPath('director/config/deployments');
|
||||||
|
Notification::success(
|
||||||
|
$this->translate('Config has been submitted, validation is going on')
|
||||||
|
);
|
||||||
|
$this->redirectNow($url);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function deploymentFailed($checksum, $error = null)
|
||||||
|
{
|
||||||
|
$extra = $error ? ': ' . $error: '';
|
||||||
|
|
||||||
|
if ($this->getRequest()->isApiRequest()) {
|
||||||
|
return $this->sendJsonError('Config deployment failed' . $extra);
|
||||||
|
} else {
|
||||||
|
$url = Url::fromPath('director/config/files', array('checksum' => $checksum));
|
||||||
|
Notification::error(
|
||||||
|
$this->translate('Config deployment failed') . $extra
|
||||||
|
);
|
||||||
|
$this->redirectNow($url);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue