icinga2/lib/config/configitem.h

103 lines
3.4 KiB
C
Raw Normal View History

/******************************************************************************
* 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. *
******************************************************************************/
#ifndef CONFIGITEM_H
#define CONFIGITEM_H
2013-03-17 20:19:29 +01:00
#include "config/i2-config.h"
#include "config/aexpression.h"
2013-03-16 21:18:53 +01:00
#include "base/dynamicobject.h"
namespace icinga
{
enum ValidationType
{
ValidateNone,
ValidateOnly,
ValidateStart
};
2012-09-17 14:47:43 +02:00
/**
2012-09-19 12:32:39 +02:00
* A configuration item. Non-abstract configuration items can be used to
* create configuration objects at runtime.
2012-09-17 14:47:43 +02:00
*
* @ingroup config
*/
class I2_CONFIG_API ConfigItem : public Object {
public:
DECLARE_PTR_TYPEDEFS(ConfigItem);
ConfigItem(const String& type, const String& name, bool abstract,
const AExpression::Ptr& exprl, const DebugInfo& debuginfo,
const Dictionary::Ptr& scope);
String GetType(void) const;
String GetName(void) const;
bool IsAbstract(void) const;
std::vector<ConfigItem::Ptr> GetParents(void) const;
AExpression::Ptr GetExpressionList(void) const;
2013-12-03 09:59:21 +01:00
Dictionary::Ptr GetProperties(void);
2013-03-02 09:07:47 +01:00
DynamicObject::Ptr Commit(void);
void Register(void);
DebugInfo GetDebugInfo(void) const;
Dictionary::Ptr GetScope(void) const;
2012-09-19 12:32:39 +02:00
static ConfigItem::Ptr GetObject(const String& type,
const String& name);
static bool HasObject(const String& type, const String& name);
2013-09-24 13:13:14 +02:00
void ValidateItem(void);
static bool ActivateItems(ValidationType validate);
static void DiscardItems(void);
private:
2012-09-19 12:32:39 +02:00
String m_Type; /**< The object type. */
String m_Name; /**< The name. */
bool m_Abstract; /**< Whether this is a template. */
2013-10-16 13:37:54 +02:00
bool m_Validated; /** Whether this object has been validated. */
2012-07-06 14:33:10 +02:00
AExpression::Ptr m_ExpressionList;
Dictionary::Ptr m_Properties;
std::vector<String> m_ParentNames; /**< The names of parent configuration
2012-09-19 12:32:39 +02:00
items. */
DebugInfo m_DebugInfo; /**< Debug information. */
Dictionary::Ptr m_Scope; /**< variable scope. */
DynamicObject::Ptr m_Object;
2013-03-15 18:21:29 +01:00
static boost::mutex m_Mutex;
2013-02-17 19:14:34 +01:00
typedef std::map<std::pair<String, String>, ConfigItem::Ptr> ItemMap;
2012-09-19 12:32:39 +02:00
static ItemMap m_Items; /**< All registered configuration items. */
static ConfigItem::Ptr GetObjectUnlocked(const String& type,
const String& name);
};
}
#endif /* CONFIGITEM_H */