mirror of https://github.com/Icinga/icinga2.git
parent
6fc4efccc7
commit
c91154a14c
|
@ -368,7 +368,7 @@ void IcingaDB::InsertObjectDependencies(const ConfigObject::Ptr& object, const S
|
||||||
{
|
{
|
||||||
String objectKey = GetObjectIdentifier(object);
|
String objectKey = GetObjectIdentifier(object);
|
||||||
CustomVarObject::Ptr customVarObject = dynamic_pointer_cast<CustomVarObject>(object);
|
CustomVarObject::Ptr customVarObject = dynamic_pointer_cast<CustomVarObject>(object);
|
||||||
String envId = CalculateCheckSumString(GetEnvironment());
|
String envId = SHA1(GetEnvironment());
|
||||||
auto* configUpdates (runtimeUpdate ? &publishes["icinga:config:update"] : nullptr);
|
auto* configUpdates (runtimeUpdate ? &publishes["icinga:config:update"] : nullptr);
|
||||||
|
|
||||||
if (customVarObject) {
|
if (customVarObject) {
|
||||||
|
@ -847,8 +847,8 @@ void IcingaDB::SendConfigUpdate(const ConfigObject::Ptr& object, bool runtimeUpd
|
||||||
// for IcingaDB.
|
// for IcingaDB.
|
||||||
bool IcingaDB::PrepareObject(const ConfigObject::Ptr& object, Dictionary::Ptr& attributes, Dictionary::Ptr& checksums)
|
bool IcingaDB::PrepareObject(const ConfigObject::Ptr& object, Dictionary::Ptr& attributes, Dictionary::Ptr& checksums)
|
||||||
{
|
{
|
||||||
attributes->Set("name_checksum", CalculateCheckSumString(object->GetName()));
|
attributes->Set("name_checksum", SHA1(object->GetName()));
|
||||||
attributes->Set("environment_id", CalculateCheckSumString(GetEnvironment()));
|
attributes->Set("environment_id", SHA1(GetEnvironment()));
|
||||||
attributes->Set("name", object->GetName());
|
attributes->Set("name", object->GetName());
|
||||||
|
|
||||||
Zone::Ptr ObjectsZone = static_pointer_cast<Zone>(object->GetZone());
|
Zone::Ptr ObjectsZone = static_pointer_cast<Zone>(object->GetZone());
|
||||||
|
@ -923,11 +923,11 @@ bool IcingaDB::PrepareObject(const ConfigObject::Ptr& object, Dictionary::Ptr& a
|
||||||
String notesUrl = checkable->GetNotesUrl();
|
String notesUrl = checkable->GetNotesUrl();
|
||||||
String iconImage = checkable->GetIconImage();
|
String iconImage = checkable->GetIconImage();
|
||||||
if (!actionUrl.IsEmpty())
|
if (!actionUrl.IsEmpty())
|
||||||
attributes->Set("action_url_id", HashValue(new Array({CalculateCheckSumString(GetEnvironment()), actionUrl})));
|
attributes->Set("action_url_id", HashValue(new Array({SHA1(GetEnvironment()), actionUrl})));
|
||||||
if (!notesUrl.IsEmpty())
|
if (!notesUrl.IsEmpty())
|
||||||
attributes->Set("notes_url_id", HashValue(new Array({CalculateCheckSumString(GetEnvironment()), notesUrl})));
|
attributes->Set("notes_url_id", HashValue(new Array({SHA1(GetEnvironment()), notesUrl})));
|
||||||
if (!iconImage.IsEmpty())
|
if (!iconImage.IsEmpty())
|
||||||
attributes->Set("icon_image_id", HashValue(new Array({CalculateCheckSumString(GetEnvironment()), iconImage})));
|
attributes->Set("icon_image_id", HashValue(new Array({SHA1(GetEnvironment()), iconImage})));
|
||||||
|
|
||||||
|
|
||||||
Host::Ptr host;
|
Host::Ptr host;
|
||||||
|
@ -1765,7 +1765,7 @@ Dictionary::Ptr IcingaDB::SerializeState(const Checkable::Ptr& checkable)
|
||||||
tie(host, service) = GetHostService(checkable);
|
tie(host, service) = GetHostService(checkable);
|
||||||
|
|
||||||
attrs->Set("id", GetObjectIdentifier(checkable));;
|
attrs->Set("id", GetObjectIdentifier(checkable));;
|
||||||
attrs->Set("environment_id", CalculateCheckSumString(GetEnvironment()));
|
attrs->Set("environment_id", SHA1(GetEnvironment()));
|
||||||
attrs->Set("state_type", checkable->HasBeenChecked() ? checkable->GetStateType() : StateTypeHard);
|
attrs->Set("state_type", checkable->HasBeenChecked() ? checkable->GetStateType() : StateTypeHard);
|
||||||
|
|
||||||
// TODO: last_hard/soft_state should be "previous".
|
// TODO: last_hard/soft_state should be "previous".
|
||||||
|
|
|
@ -75,11 +75,6 @@ String IcingaDB::GetObjectIdentifier(const ConfigObject::Ptr& object)
|
||||||
return HashValue((Array::Ptr)new Array({GetEnvironment(), object->GetName()}));
|
return HashValue((Array::Ptr)new Array({GetEnvironment(), object->GetName()}));
|
||||||
}
|
}
|
||||||
|
|
||||||
String IcingaDB::CalculateCheckSumString(const String& str)
|
|
||||||
{
|
|
||||||
return SHA1(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
String IcingaDB::CalculateCheckSumProperties(const ConfigObject::Ptr& object, const std::set<String>& propertiesBlacklist)
|
String IcingaDB::CalculateCheckSumProperties(const ConfigObject::Ptr& object, const std::set<String>& propertiesBlacklist)
|
||||||
{
|
{
|
||||||
//TODO: consider precision of 6 for double values; use specific config fields for hashing?
|
//TODO: consider precision of 6 for double values; use specific config fields for hashing?
|
||||||
|
|
|
@ -83,7 +83,6 @@ private:
|
||||||
|
|
||||||
static String GetObjectIdentifier(const ConfigObject::Ptr& object);
|
static String GetObjectIdentifier(const ConfigObject::Ptr& object);
|
||||||
static String GetEnvironment();
|
static String GetEnvironment();
|
||||||
static String CalculateCheckSumString(const String& str);
|
|
||||||
static String CalculateCheckSumProperties(const ConfigObject::Ptr& object, const std::set<String>& propertiesBlacklist);
|
static String CalculateCheckSumProperties(const ConfigObject::Ptr& object, const std::set<String>& propertiesBlacklist);
|
||||||
static String CalculateCheckSumMetadata(const ConfigObject::Ptr& object);
|
static String CalculateCheckSumMetadata(const ConfigObject::Ptr& object);
|
||||||
static String CalculateCheckSumVars(const CustomVarObject::Ptr& object);
|
static String CalculateCheckSumVars(const CustomVarObject::Ptr& object);
|
||||||
|
|
Loading…
Reference in New Issue