]> granicus.if.org Git - icinga2/blobdiff - lib/icinga/downtime.ti
Service: be handled while host is down
[icinga2] / lib / icinga / downtime.ti
index e672d98c07f3f5836a38c166c863fb4790c023f9..a55942fb048420be0b7ecd35392e5e9f349c5b4d 100644 (file)
@@ -1,45 +1,75 @@
-/******************************************************************************
- * Icinga 2                                                                   *
- * Copyright (C) 2012-2014 Icinga Development Team (http://www.icinga.org)    *
- *                                                                            *
- * This program is free software; you can redistribute it and/or              *
- * modify it under the terms of the GNU General Public License                *
- * as published by the Free Software Foundation; either version 2             *
- * of the License, or (at your option) any later version.                     *
- *                                                                            *
- * This program is distributed in the hope that it will be useful,            *
- * but WITHOUT ANY WARRANTY; without even the implied warranty of             *
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the              *
- * GNU General Public License for more details.                               *
- *                                                                            *
- * You should have received a copy of the GNU General Public License          *
- * along with this program; if not, write to the Free Software Foundation     *
- * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.             *
- ******************************************************************************/
+/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
+
+#include "base/configobject.hpp"
+#include "base/utility.hpp"
+#impl_include "icinga/service.hpp"
+
+library icinga;
 
 namespace icinga
 {
 
-safe class Downtime
+code {{{
+class DowntimeNameComposer : public NameComposer
 {
-       [state] String id;
-       [state] double entry_time;
-       [state] String author;
-       [state] String comment;
-       [state] double start_time;
-       [state] double end_time;
-       [state] double trigger_time;
-       [state] bool fixed;
-       [state] double duration;
-       [state] int triggered_by_legacy_id;
-       [state] String triggered_by;
-       [state] String scheduled_by;
-       [state] Dictionary::Ptr triggers {
-               default {{{ return make_shared<Dictionary>(); }}}
+public:
+       virtual String MakeName(const String& shortName, const Object::Ptr& context) const;
+       virtual Dictionary::Ptr ParseName(const String& name) const;
+};
+}}}
+
+class Downtime : ConfigObject < DowntimeNameComposer
+{
+       activation_priority -10;
+
+       load_after Host;
+       load_after Service;
+
+       [config, protected, required, navigation(host)] name(Host) host_name {
+               navigate {{{
+                       return Host::GetByName(GetHostName());
+               }}}
+       };
+       [config, protected, navigation(service)] String service_name {
+               track {{{
+                       if (!oldValue.IsEmpty()) {
+                               Service::Ptr service = Service::GetByNamePair(GetHostName(), oldValue);
+                               DependencyGraph::RemoveDependency(this, service.get());
+                       }
+
+                       if (!newValue.IsEmpty()) {
+                               Service::Ptr service = Service::GetByNamePair(GetHostName(), newValue);
+                               DependencyGraph::AddDependency(this, service.get());
+                       }
+               }}}
+               navigate {{{
+                       if (GetServiceName().IsEmpty())
+                               return nullptr;
+
+                       Host::Ptr host = Host::GetByName(GetHostName());
+                       return host->GetServiceByShortName(GetServiceName());
+               }}}
+       };
+
+       [config] Timestamp entry_time {
+               default {{{ return Utility::GetTime(); }}}
+       };
+       [config, required] String author;
+       [config, required] String comment;
+       [config] Timestamp start_time;
+       [config] Timestamp end_time;
+       [state] Timestamp trigger_time;
+       [config] bool fixed;
+       [config] Timestamp duration;
+       [config] String triggered_by;
+       [config] String scheduled_by;
+       [state] Array::Ptr triggers {
+               default {{{ return new Array(); }}}
        };
        [state] int legacy_id;
        [state] bool was_cancelled;
-       [state] String config_owner;
+       [config] String config_owner;
+       [config] String authoritative_zone;
 };
 
 }