ConfigController: do not show an exception...

...when a deployment fails
This commit is contained in:
Thomas Gelf 2016-12-14 14:56:22 +01:00
parent f614d75edc
commit ade7b1415e
1 changed files with 35 additions and 20 deletions

View File

@ -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);
} }
} }