db()); Benchmark::measure('Rendering config'); if ($config->hasBeenModified()) { Benchmark::measure('Config rendered, storing to db'); $config->store(); Benchmark::measure('All done'); $checksum = $config->getHexChecksum(); printf( "New config with checksum %s has been generated\n", $checksum ); } else { $checksum = $config->getHexChecksum(); printf( "Config with checksum %s already exists\n", $checksum ); } } /** * Deploy the current configuration * * Does nothing if config didn't change unless you provide * the --force parameter */ public function deployAction() { $api = $this->api(); $db = $this->db(); $checksum = $this->params->get('checksum'); if ($checksum) { $config = IcingaConfig::load(Util::hex2binary($checksum), $db); } else { $config = IcingaConfig::generate($db); $checksum = $config->getHexChecksum(); } $api->wipeInactiveStages($db); $current = $api->getActiveChecksum($db); if ($current === $checksum) { if ($this->params->get('force')) { echo "Config matches active stage, deploying anyway\n"; } else { echo "Config matches active stage, nothing to do\n"; return; } } else { if ($api->dumpConfig($config, $db)) { printf("Config '%s' has been deployed\n", $checksum); } else { $this->fail( sprintf("Failed to deploy config '%s'\n", $checksum) ); } } } public function filesAction() { } public function fileAction() { } }