diff --git a/lib/base/configobject.ti b/lib/base/configobject.ti index 209807629..3aa6cc79c 100644 --- a/lib/base/configobject.ti +++ b/lib/base/configobject.ti @@ -73,6 +73,7 @@ abstract class ConfigObject : ConfigObjectBase }; [config, internal, get_protected] String type (TypeNameV); [config] name(Zone) zone (ZoneName); + [config] String module; [config, internal, get_protected] Array::Ptr templates; [get_protected] bool active; [get_protected] bool paused { diff --git a/lib/cli/daemonutility.cpp b/lib/cli/daemonutility.cpp index 49cf2c528..e98133387 100644 --- a/lib/cli/daemonutility.cpp +++ b/lib/cli/daemonutility.cpp @@ -28,7 +28,7 @@ using namespace icinga; -bool ExecuteExpression(Expression *expression) +static bool ExecuteExpression(Expression *expression) { if (!expression) return false; @@ -44,7 +44,7 @@ bool ExecuteExpression(Expression *expression) return true; } -void IncludeZoneDirRecursive(const String& path, bool& success) +static void IncludeZoneDirRecursive(const String& path, const String& module, bool& success) { String zoneName = Utility::BaseName(path); @@ -52,20 +52,35 @@ void IncludeZoneDirRecursive(const String& path, bool& success) ConfigCompiler::RegisterZoneDir("_etc", path, zoneName); std::vector expressions; - Utility::GlobRecursive(path, "*.conf", boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, zoneName), GlobFile); + Utility::GlobRecursive(path, "*.conf", boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, zoneName, module), GlobFile); DictExpression expr(expressions); if (!ExecuteExpression(&expr)) success = false; } -void IncludeNonLocalZone(const String& zonePath, bool& success) +static void IncludeNonLocalZone(const String& zonePath, const String& module, bool& success) { String etcPath = Application::GetZonesDir() + "/" + Utility::BaseName(zonePath); if (Utility::PathExists(etcPath) || Utility::PathExists(zonePath + "/.authoritative")) return; - IncludeZoneDirRecursive(zonePath, success); + IncludeZoneDirRecursive(zonePath, module, success); +} + +static void IncludeModule(const String& modulePath, bool& success) +{ + String moduleName = Utility::BaseName(modulePath); + + if (Utility::PathExists(modulePath + "/include.conf")) { + Expression *expr = ConfigCompiler::CompileFile(modulePath + "/include.conf", + true, String(), moduleName); + + if (!ExecuteExpression(expr)) + success = false; + + delete expr; + } } bool DaemonUtility::ValidateConfigFiles(const std::vector& configs, const String& objectsFile) @@ -76,7 +91,7 @@ bool DaemonUtility::ValidateConfigFiles(const std::vector& configs, if (!configs.empty()) { BOOST_FOREACH(const String& configPath, configs) { - Expression *expression = ConfigCompiler::CompileFile(configPath); + Expression *expression = ConfigCompiler::CompileFile(configPath, true, String(), "_etc"); success = ExecuteExpression(expression); delete expression; if (!success) @@ -90,26 +105,21 @@ bool DaemonUtility::ValidateConfigFiles(const std::vector& configs, String zonesEtcDir = Application::GetZonesDir(); if (!zonesEtcDir.IsEmpty() && Utility::PathExists(zonesEtcDir)) - Utility::Glob(zonesEtcDir + "/*", boost::bind(&IncludeZoneDirRecursive, _1, boost::ref(success)), GlobDirectory); + Utility::Glob(zonesEtcDir + "/*", boost::bind(&IncludeZoneDirRecursive, _1, "_etc", boost::ref(success)), GlobDirectory); if (!success) return false; String zonesVarDir = Application::GetLocalStateDir() + "/lib/icinga2/api/zones"; if (Utility::PathExists(zonesVarDir)) - Utility::Glob(zonesVarDir + "/*", boost::bind(&IncludeNonLocalZone, _1, boost::ref(success)), GlobDirectory); + Utility::Glob(zonesVarDir + "/*", boost::bind(&IncludeNonLocalZone, _1, "_cluster", boost::ref(success)), GlobDirectory); if (!success) return false; String modulesVarDir = Application::GetLocalStateDir() + "/lib/icinga2/api/modules"; - if (Utility::PathExists(modulesVarDir)) { - std::vector expressions; - Utility::Glob(modulesVarDir + "/*/include.conf", boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, ""), GlobFile); - DictExpression expr(expressions); - if (!ExecuteExpression(&expr)) - success = false; - } + if (Utility::PathExists(modulesVarDir)) + Utility::Glob(modulesVarDir + "/*", boost::bind(&IncludeModule, _1, boost::ref(success)), GlobDirectory); if (!success) return false; diff --git a/lib/config/applyrule.cpp b/lib/config/applyrule.cpp index 9909791f6..a0b7e5c8e 100644 --- a/lib/config/applyrule.cpp +++ b/lib/config/applyrule.cpp @@ -28,9 +28,9 @@ ApplyRule::RuleMap ApplyRule::m_Rules; ApplyRule::TypeMap ApplyRule::m_Types; ApplyRule::ApplyRule(const String& targetType, const String& name, const boost::shared_ptr& expression, - const boost::shared_ptr& filter, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, + const boost::shared_ptr& filter, const String& module, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, const DebugInfo& di, const Dictionary::Ptr& scope) - : m_TargetType(targetType), m_Name(name), m_Expression(expression), m_Filter(filter), m_FKVar(fkvar), + : m_TargetType(targetType), m_Name(name), m_Expression(expression), m_Filter(filter), m_Module(module), m_FKVar(fkvar), m_FVVar(fvvar), m_FTerm(fterm), m_DebugInfo(di), m_Scope(scope), m_HasMatches(false) { } @@ -54,6 +54,11 @@ boost::shared_ptr ApplyRule::GetFilter(void) const return m_Filter; } +String ApplyRule::GetModule(void) const +{ + return m_Module; +} + String ApplyRule::GetFKVar(void) const { return m_FKVar; @@ -80,10 +85,10 @@ Dictionary::Ptr ApplyRule::GetScope(void) const } void ApplyRule::AddRule(const String& sourceType, const String& targetType, const String& name, - const boost::shared_ptr& expression, const boost::shared_ptr& filter, const String& fkvar, + const boost::shared_ptr& expression, const boost::shared_ptr& filter, const String& module, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, const DebugInfo& di, const Dictionary::Ptr& scope) { - m_Rules[sourceType].push_back(ApplyRule(targetType, name, expression, filter, fkvar, fvvar, fterm, di, scope)); + m_Rules[sourceType].push_back(ApplyRule(targetType, name, expression, filter, module, fkvar, fvvar, fterm, di, scope)); } bool ApplyRule::EvaluateFilter(ScriptFrame& frame) const diff --git a/lib/config/applyrule.hpp b/lib/config/applyrule.hpp index cac23c153..db79f0244 100644 --- a/lib/config/applyrule.hpp +++ b/lib/config/applyrule.hpp @@ -41,6 +41,7 @@ public: String GetName(void) const; boost::shared_ptr GetExpression(void) const; boost::shared_ptr GetFilter(void) const; + String GetModule(void) const; String GetFKVar(void) const; String GetFVVar(void) const; boost::shared_ptr GetFTerm(void) const; @@ -52,7 +53,7 @@ public: bool EvaluateFilter(ScriptFrame& frame) const; static void AddRule(const String& sourceType, const String& targetType, const String& name, const boost::shared_ptr& expression, - const boost::shared_ptr& filter, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, const DebugInfo& di, const Dictionary::Ptr& scope); + const boost::shared_ptr& filter, const String& module, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, const DebugInfo& di, const Dictionary::Ptr& scope); static std::vector& GetRules(const String& type); static void RegisterType(const String& sourceType, const std::vector& targetTypes); @@ -68,6 +69,7 @@ private: String m_Name; boost::shared_ptr m_Expression; boost::shared_ptr m_Filter; + String m_Module; String m_FKVar; String m_FVVar; boost::shared_ptr m_FTerm; @@ -79,7 +81,7 @@ private: static RuleMap m_Rules; ApplyRule(const String& targetType, const String& name, const boost::shared_ptr& expression, - const boost::shared_ptr& filter, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, + const boost::shared_ptr& filter, const String& module, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, const DebugInfo& di, const Dictionary::Ptr& scope); }; diff --git a/lib/config/config_parser.yy b/lib/config/config_parser.yy index 7fbfc625c..f713aefad 100644 --- a/lib/config/config_parser.yy +++ b/lib/config/config_parser.yy @@ -384,7 +384,7 @@ object: BOOST_THROW_EXCEPTION(ScriptError("object rule 'ignore' is missing 'assign' for type '" + type + "'", DebugInfoRange(@2, @4))); } - $$ = new ObjectExpression(abstract, type, $4, filter, context->GetZone(), $5, $6, DebugInfoRange(@2, @5)); + $$ = new ObjectExpression(abstract, type, $4, filter, context->GetZone(), context->GetModule(), $5, $6, DebugInfoRange(@2, @5)); } ; @@ -1017,7 +1017,7 @@ apply: Expression *fterm = context->m_FTerm.top(); context->m_FTerm.pop(); - $$ = new ApplyExpression(type, target, $4, filter, fkvar, fvvar, fterm, $7, $8, DebugInfoRange(@2, @7)); + $$ = new ApplyExpression(type, target, $4, filter, context->GetModule(), fkvar, fvvar, fterm, $7, $8, DebugInfoRange(@2, @7)); } ; diff --git a/lib/config/configcompiler.cpp b/lib/config/configcompiler.cpp index 161319c67..b678b735d 100644 --- a/lib/config/configcompiler.cpp +++ b/lib/config/configcompiler.cpp @@ -40,8 +40,10 @@ std::map > ConfigCompiler::m_ZoneDirs; * @param input Input stream for the configuration file. * @param zone The zone. */ -ConfigCompiler::ConfigCompiler(const String& path, std::istream *input, const String& zone) - : m_Path(path), m_Input(input), m_Zone(zone), m_Eof(false), m_OpenBraces(0), m_IgnoreNewlines(0) +ConfigCompiler::ConfigCompiler(const String& path, std::istream *input, + const String& zone, const String& module) + : m_Path(path), m_Input(input), m_Zone(zone), m_Module(module), + m_Eof(false), m_OpenBraces(0), m_IgnoreNewlines(0) { InitializeScanner(); } @@ -98,9 +100,20 @@ String ConfigCompiler::GetZone(void) const return m_Zone; } -void ConfigCompiler::CollectIncludes(std::vector& expressions, const String& file, const String& zone) +void ConfigCompiler::SetModule(const String& module) { - expressions.push_back(CompileFile(file, true, zone)); + m_Module = module; +} + +String ConfigCompiler::GetModule(void) const +{ + return m_Module; +} + +void ConfigCompiler::CollectIncludes(std::vector& expressions, + const String& file, const String& zone, const String& module) +{ + expressions.push_back(CompileFile(file, true, zone, module)); } /** @@ -134,7 +147,7 @@ Expression *ConfigCompiler::HandleInclude(const String& include, bool search, co std::vector expressions; - if (!Utility::Glob(includePath, boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, m_Zone), GlobFile) && includePath.FindFirstOf("*?") == String::NPos) { + if (!Utility::Glob(includePath, boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, m_Zone, m_Module), GlobFile) && includePath.FindFirstOf("*?") == String::NPos) { std::ostringstream msgbuf; msgbuf << "Include file '" + include + "' does not exist"; BOOST_THROW_EXCEPTION(ScriptError(msgbuf.str(), debuginfo)); @@ -162,7 +175,7 @@ Expression *ConfigCompiler::HandleIncludeRecursive(const String& path, const Str ppath = Utility::DirName(GetPath()) + "/" + path; std::vector expressions; - Utility::GlobRecursive(ppath, pattern, boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, m_Zone), GlobFile); + Utility::GlobRecursive(ppath, pattern, boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, m_Zone, m_Module), GlobFile); return new DictExpression(expressions); } @@ -179,7 +192,7 @@ void ConfigCompiler::HandleIncludeZone(const String& tag, const String& path, co RegisterZoneDir(tag, ppath, zoneName); - Utility::GlobRecursive(ppath, pattern, boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, zoneName), GlobFile); + Utility::GlobRecursive(ppath, pattern, boost::bind(&ConfigCompiler::CollectIncludes, boost::ref(expressions), _1, zoneName, m_Module), GlobFile); } /** @@ -232,13 +245,14 @@ void ConfigCompiler::CompileHelper(void) * @param stream The input stream. * @returns Configuration items. */ -Expression *ConfigCompiler::CompileStream(const String& path, std::istream *stream, bool async, const String& zone) +Expression *ConfigCompiler::CompileStream(const String& path, + std::istream *stream, bool async, const String& zone, const String& module) { CONTEXT("Compiling configuration stream with name '" + path + "'"); stream->exceptions(std::istream::badbit); - ConfigCompiler* ctx = new ConfigCompiler(path, stream, zone); + ConfigCompiler* ctx = new ConfigCompiler(path, stream, zone, module); if (async) { boost::shared_future > ftr = boost::shared_future >(ctx->m_Promise.get_future()); @@ -266,7 +280,8 @@ Expression *ConfigCompiler::CompileStream(const String& path, std::istream *stre * @param path The path. * @returns Configuration items. */ -Expression *ConfigCompiler::CompileFile(const String& path, bool async, const String& zone) +Expression *ConfigCompiler::CompileFile(const String& path, bool async, + const String& zone, const String& module) { CONTEXT("Compiling configuration file '" + path + "'"); @@ -282,7 +297,7 @@ Expression *ConfigCompiler::CompileFile(const String& path, bool async, const St Log(LogInformation, "ConfigCompiler") << "Compiling config file: " << path; - return CompileStream(path, stream, async, zone); + return CompileStream(path, stream, async, zone, module); } /** @@ -292,10 +307,11 @@ Expression *ConfigCompiler::CompileFile(const String& path, bool async, const St * @param text The text. * @returns Configuration items. */ -Expression *ConfigCompiler::CompileText(const String& path, const String& text, bool async, const String& zone) +Expression *ConfigCompiler::CompileText(const String& path, const String& text, + bool async, const String& zone, const String& module) { std::stringstream *stream = new std::stringstream(text); - return CompileStream(path, stream, async, zone); + return CompileStream(path, stream, async, zone, module); } /** diff --git a/lib/config/configcompiler.hpp b/lib/config/configcompiler.hpp index 0d72b9ac2..d1513a24d 100644 --- a/lib/config/configcompiler.hpp +++ b/lib/config/configcompiler.hpp @@ -79,14 +79,18 @@ struct ZoneFragment class I2_CONFIG_API ConfigCompiler { public: - explicit ConfigCompiler(const String& path, std::istream *input, const String& zone = String()); + explicit ConfigCompiler(const String& path, std::istream *input, + const String& zone = String(), const String& module = String()); virtual ~ConfigCompiler(void); Expression *Compile(void); - static Expression *CompileStream(const String& path, std::istream *stream, bool async = true, const String& zone = String()); - static Expression *CompileFile(const String& path, bool async = true, const String& zone = String()); - static Expression *CompileText(const String& path, const String& text, bool async = true, const String& zone = String()); + static Expression *CompileStream(const String& path, std::istream *stream, + bool async = true, const String& zone = String(), const String& module = String()); + static Expression *CompileFile(const String& path, bool async = true, + const String& zone = String(), const String& module = String()); + static Expression *CompileText(const String& path, const String& text, + bool async = true, const String& zone = String(), const String& module = String()); static void AddIncludeSearchDir(const String& dir); @@ -94,8 +98,12 @@ public: void SetZone(const String& zone); String GetZone(void) const; + + void SetModule(const String& module); + String GetModule(void) const; - static void CollectIncludes(std::vector& expressions, const String& file, const String& zone); + static void CollectIncludes(std::vector& expressions, + const String& file, const String& zone, const String& module); /* internally used methods */ Expression *HandleInclude(const String& include, bool search, const DebugInfo& debuginfo = DebugInfo()); @@ -117,6 +125,7 @@ private: String m_Path; std::istream *m_Input; String m_Zone; + String m_Module; void *m_Scanner; diff --git a/lib/config/configitem.cpp b/lib/config/configitem.cpp index 6652cdd8e..42b82fa3f 100644 --- a/lib/config/configitem.cpp +++ b/lib/config/configitem.cpp @@ -62,10 +62,11 @@ ConfigItem::ConfigItem(const String& type, const String& name, bool abstract, const boost::shared_ptr& exprl, const boost::shared_ptr& filter, const DebugInfo& debuginfo, const Dictionary::Ptr& scope, - const String& zone) + const String& zone, const String& module) : m_Type(type), m_Name(name), m_Abstract(abstract), m_Expression(exprl), m_Filter(filter), - m_DebugInfo(debuginfo), m_Scope(scope), m_Zone(zone) + m_DebugInfo(debuginfo), m_Scope(scope), m_Zone(zone), + m_Module(module) { } @@ -170,6 +171,7 @@ ConfigObject::Ptr ConfigItem::Commit(bool discard) dobj->SetDebugInfo(m_DebugInfo); dobj->SetTypeNameV(m_Type); dobj->SetZoneName(m_Zone); + dobj->SetModule(m_Module); dobj->SetName(m_Name); DebugHint debugHints; diff --git a/lib/config/configitem.hpp b/lib/config/configitem.hpp index 9513df9df..8e98d33e4 100644 --- a/lib/config/configitem.hpp +++ b/lib/config/configitem.hpp @@ -42,7 +42,8 @@ public: const boost::shared_ptr& exprl, const boost::shared_ptr& filter, const DebugInfo& debuginfo, - const Dictionary::Ptr& scope, const String& zone); + const Dictionary::Ptr& scope, const String& zone, + const String& module); String GetType(void) const; String GetName(void) const; @@ -60,8 +61,6 @@ public: DebugInfo GetDebugInfo(void) const; Dictionary::Ptr GetScope(void) const; - String GetZone(void) const; - static ConfigItem::Ptr GetObject(const String& type, const String& name); @@ -82,6 +81,7 @@ private: DebugInfo m_DebugInfo; /**< Debug information. */ Dictionary::Ptr m_Scope; /**< variable scope. */ String m_Zone; /**< The zone. */ + String m_Module; ConfigObject::Ptr m_Object; diff --git a/lib/config/configitembuilder.cpp b/lib/config/configitembuilder.cpp index 9cf208575..c10da1da2 100644 --- a/lib/config/configitembuilder.cpp +++ b/lib/config/configitembuilder.cpp @@ -65,6 +65,11 @@ void ConfigItemBuilder::SetZone(const String& zone) m_Zone = zone; } +void ConfigItemBuilder::SetModule(const String& module) +{ + m_Module = module; +} + void ConfigItemBuilder::AddExpression(Expression *expr) { m_Expressions.push_back(expr); @@ -111,6 +116,6 @@ ConfigItem::Ptr ConfigItemBuilder::Compile(void) exprl->MakeInline(); return new ConfigItem(m_Type, m_Name, m_Abstract, exprl, m_Filter, - m_DebugInfo, m_Scope, m_Zone); + m_DebugInfo, m_Scope, m_Zone, m_Module); } diff --git a/lib/config/configitembuilder.hpp b/lib/config/configitembuilder.hpp index 5bc93ffdf..9e11d52af 100644 --- a/lib/config/configitembuilder.hpp +++ b/lib/config/configitembuilder.hpp @@ -47,6 +47,7 @@ public: void SetAbstract(bool abstract); void SetScope(const Dictionary::Ptr& scope); void SetZone(const String& zone); + void SetModule(const String& module); void AddExpression(Expression *expr); void SetFilter(const boost::shared_ptr& filter); @@ -62,6 +63,7 @@ private: DebugInfo m_DebugInfo; /**< Debug information. */ Dictionary::Ptr m_Scope; /**< variable scope. */ String m_Zone; /**< The zone. */ + String m_Module; /**< The module name. */ }; } diff --git a/lib/config/expression.cpp b/lib/config/expression.cpp index f251910f9..65d910bcc 100644 --- a/lib/config/expression.cpp +++ b/lib/config/expression.cpp @@ -740,7 +740,7 @@ ExpressionResult ApplyExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dhin CHECK_RESULT(nameres); return VMOps::NewApply(frame, m_Type, m_Target, nameres.GetValue(), m_Filter, - m_FKVar, m_FVVar, m_FTerm, m_ClosedVars, m_Expression, m_DebugInfo); + m_Module, m_FKVar, m_FVVar, m_FTerm, m_ClosedVars, m_Expression, m_DebugInfo); } ExpressionResult ObjectExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dhint) const @@ -758,7 +758,7 @@ ExpressionResult ObjectExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dhi } return VMOps::NewObject(frame, m_Abstract, m_Type, name, m_Filter, m_Zone, - m_ClosedVars, m_Expression, m_DebugInfo); + m_Module, m_ClosedVars, m_Expression, m_DebugInfo); } ExpressionResult ForExpression::DoEvaluate(ScriptFrame& frame, DebugHint *dhint) const diff --git a/lib/config/expression.hpp b/lib/config/expression.hpp index a9bc37951..acb9803d3 100644 --- a/lib/config/expression.hpp +++ b/lib/config/expression.hpp @@ -807,11 +807,11 @@ class I2_CONFIG_API ApplyExpression : public DebuggableExpression { public: ApplyExpression(const String& type, const String& target, Expression *name, - Expression *filter, const String& fkvar, const String& fvvar, + Expression *filter, const String& module, const String& fkvar, const String& fvvar, Expression *fterm, std::map *closedVars, Expression *expression, const DebugInfo& debugInfo = DebugInfo()) : DebuggableExpression(debugInfo), m_Type(type), m_Target(target), - m_Name(name), m_Filter(filter), m_FKVar(fkvar), m_FVVar(fvvar), + m_Name(name), m_Filter(filter), m_Module(module), m_FKVar(fkvar), m_FVVar(fvvar), m_FTerm(fterm), m_ClosedVars(closedVars), m_Expression(expression) { } @@ -828,6 +828,7 @@ private: String m_Target; Expression *m_Name; boost::shared_ptr m_Filter; + String m_Module; String m_FKVar; String m_FVVar; boost::shared_ptr m_FTerm; @@ -839,10 +840,10 @@ class I2_CONFIG_API ObjectExpression : public DebuggableExpression { public: ObjectExpression(bool abstract, const String& type, Expression *name, Expression *filter, - const String& zone, std::map *closedVars, + const String& zone, const String& module, std::map *closedVars, Expression *expression, const DebugInfo& debugInfo = DebugInfo()) : DebuggableExpression(debugInfo), m_Abstract(abstract), m_Type(type), - m_Name(name), m_Filter(filter), m_Zone(zone), m_ClosedVars(closedVars), m_Expression(expression) + m_Name(name), m_Filter(filter), m_Zone(zone), m_Module(module), m_ClosedVars(closedVars), m_Expression(expression) { } ~ObjectExpression(void) @@ -859,6 +860,7 @@ private: Expression *m_Name; boost::shared_ptr m_Filter; String m_Zone; + String m_Module; std::map *m_ClosedVars; boost::shared_ptr m_Expression; }; diff --git a/lib/config/vmops.hpp b/lib/config/vmops.hpp index 5f9d7c605..71cddee9e 100644 --- a/lib/config/vmops.hpp +++ b/lib/config/vmops.hpp @@ -105,17 +105,17 @@ public: } static inline Value NewApply(ScriptFrame& frame, const String& type, const String& target, const String& name, const boost::shared_ptr& filter, - const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, std::map *closedVars, + const String& module, const String& fkvar, const String& fvvar, const boost::shared_ptr& fterm, std::map *closedVars, const boost::shared_ptr& expression, const DebugInfo& debugInfo = DebugInfo()) { - ApplyRule::AddRule(type, target, name, expression, filter, fkvar, + ApplyRule::AddRule(type, target, name, expression, filter, module, fkvar, fvvar, fterm, debugInfo, EvaluateClosedVars(frame, closedVars)); return Empty; } static inline Value NewObject(ScriptFrame& frame, bool abstract, const String& type, const String& name, const boost::shared_ptr& filter, - const String& zone, std::map *closedVars, const boost::shared_ptr& expression, const DebugInfo& debugInfo = DebugInfo()) + const String& zone, const String& module, std::map *closedVars, const boost::shared_ptr& expression, const DebugInfo& debugInfo = DebugInfo()) { ConfigItemBuilder::Ptr item = new ConfigItemBuilder(debugInfo); @@ -147,6 +147,7 @@ public: item->SetAbstract(abstract); item->SetScope(EvaluateClosedVars(frame, closedVars)); item->SetZone(zone); + item->SetModule(module); item->SetFilter(filter); item->Compile()->Register(); diff --git a/lib/icinga/dependency-apply.cpp b/lib/icinga/dependency-apply.cpp index 8f650fd7a..61635d0e1 100644 --- a/lib/icinga/dependency-apply.cpp +++ b/lib/icinga/dependency-apply.cpp @@ -71,6 +71,8 @@ bool Dependency::EvaluateApplyRuleInstance(const Checkable::Ptr& checkable, cons if (!zone.IsEmpty()) builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "zone"), OpSetLiteral, MakeLiteral(zone), di)); + builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "module"), OpSetLiteral, MakeLiteral(rule.GetModule()), di)); + builder->AddExpression(new OwnedExpression(rule.GetExpression())); ConfigItem::Ptr dependencyItem = builder->Compile(); diff --git a/lib/icinga/notification-apply.cpp b/lib/icinga/notification-apply.cpp index 9d46b49d7..61df51cb1 100644 --- a/lib/icinga/notification-apply.cpp +++ b/lib/icinga/notification-apply.cpp @@ -70,6 +70,8 @@ bool Notification::EvaluateApplyRuleInstance(const Checkable::Ptr& checkable, co if (!zone.IsEmpty()) builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "zone"), OpSetLiteral, MakeLiteral(zone), di)); + builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "module"), OpSetLiteral, MakeLiteral(rule.GetModule()), di)); + builder->AddExpression(new OwnedExpression(rule.GetExpression())); ConfigItem::Ptr notificationItem = builder->Compile(); diff --git a/lib/icinga/scheduleddowntime-apply.cpp b/lib/icinga/scheduleddowntime-apply.cpp index 9088d7bb1..cc416b4c5 100644 --- a/lib/icinga/scheduleddowntime-apply.cpp +++ b/lib/icinga/scheduleddowntime-apply.cpp @@ -69,6 +69,8 @@ bool ScheduledDowntime::EvaluateApplyRuleInstance(const Checkable::Ptr& checkabl if (!zone.IsEmpty()) builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "zone"), OpSetLiteral, MakeLiteral(zone), di)); + builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "module"), OpSetLiteral, MakeLiteral(rule.GetModule()), di)); + builder->AddExpression(new OwnedExpression(rule.GetExpression())); ConfigItem::Ptr downtimeItem = builder->Compile(); diff --git a/lib/icinga/service-apply.cpp b/lib/icinga/service-apply.cpp index b6373c5e1..545f0e677 100644 --- a/lib/icinga/service-apply.cpp +++ b/lib/icinga/service-apply.cpp @@ -63,6 +63,8 @@ bool Service::EvaluateApplyRuleInstance(const Host::Ptr& host, const String& nam if (!zone.IsEmpty()) builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "zone"), OpSetLiteral, MakeLiteral(zone), di)); + builder->AddExpression(new SetExpression(MakeIndexer(ScopeThis, "module"), OpSetLiteral, MakeLiteral(rule.GetModule()), di)); + builder->AddExpression(new OwnedExpression(rule.GetExpression())); ConfigItem::Ptr serviceItem = builder->Compile();