Kea
1.9.9-git
|
The Element
class represents a piece of data, used by the command channel and configuration parts.
More...
#include <data.h>
Classes | |
struct | Position |
Represents the position of the data element within a configuration string. More... | |
Public Types | |
enum | types { integer, real, boolean, null, string, list, map, any } |
Public Member Functions | |
virtual | ~Element () |
const Position & | getPosition () const |
Returns position where the data element's value starts in a configuration string. More... | |
int | getType () const |
std::string | str () const |
Returns a string representing the Element and all its child elements; note that this is different from stringValue(), which only returns the single value of a StringElement. More... | |
std::string | toWire () const |
Returns the wireformat for the Element and all its child elements. More... | |
void | toWire (std::ostream &out) const |
pure virtuals, every derived class must implement these | |
virtual bool | equals (const Element &other) const =0 |
virtual void | toJSON (std::ostream &ss) const =0 |
Converts the Element to JSON format and appends it to the given stringstream. More... | |
Type-specific getters | |
These functions only work on their corresponding Element type. For all other types, a TypeError is thrown. If you want an exception-safe getter method, use getValue() below | |
virtual int64_t | intValue () const |
virtual double | doubleValue () const |
virtual bool | boolValue () const |
virtual std::string | stringValue () const |
virtual const std::vector< ElementPtr > & | listValue () const |
virtual const std::map< std::string, ConstElementPtr > & | mapValue () const |
Exception-safe getters | |
The getValue() functions return false if the given reference is of another type than the element contains By default it always returns false; the derived classes override the function for their type, copying their data to the given reference and returning true | |
virtual bool | getValue (int64_t &t) const |
virtual bool | getValue (double &t) const |
virtual bool | getValue (bool &t) const |
virtual bool | getValue (std::string &t) const |
virtual bool | getValue (std::vector< ElementPtr > &t) const |
virtual bool | getValue (std::map< std::string, ConstElementPtr > &t) const |
Exception-safe setters. | |
Return false if the Element is not the right type. Set the value and return true if the Elements is of the correct type Notes: Read notes of IntElement definition about the use of long long int, long int and int. | |
virtual bool | setValue (const long long int v) |
bool | setValue (const long int i) |
bool | setValue (const int i) |
virtual bool | setValue (const double v) |
virtual bool | setValue (const bool t) |
virtual bool | setValue (const std::string &v) |
virtual bool | setValue (const std::vector< ElementPtr > &v) |
virtual bool | setValue (const std::map< std::string, ConstElementPtr > &v) |
ListElement functions | |
If the Element on which these functions are called are not an instance of ListElement, a TypeError exception is thrown. | |
virtual ConstElementPtr | get (const int i) const |
Returns the ElementPtr at the given index. More... | |
virtual ElementPtr | getNonConst (const int i) const |
returns element as non-const pointer More... | |
virtual void | set (const size_t i, ElementPtr element) |
Sets the ElementPtr at the given index. More... | |
virtual void | add (ElementPtr element) |
Adds an ElementPtr to the list. More... | |
virtual void | remove (const int i) |
Removes the element at the given position. More... | |
virtual size_t | size () const |
Returns the number of elements in the list. More... | |
virtual bool | empty () const |
Return true if there are no elements in the list. More... | |
MapElement functions | |
If the Element on which these functions are called are not an instance of MapElement, a TypeError exception is thrown. | |
virtual ConstElementPtr | get (const std::string &name) const |
Returns the ElementPtr at the given key. More... | |
virtual void | set (const std::string &name, ConstElementPtr element) |
Sets the ElementPtr at the given key. More... | |
virtual void | remove (const std::string &name) |
Remove the ElementPtr at the given key. More... | |
virtual bool | contains (const std::string &name) const |
Checks if there is data at the given key. More... | |
virtual ConstElementPtr | find (const std::string &identifier) const |
Recursively finds any data at the given identifier. More... | |
virtual bool | find (const std::string &identifier, ConstElementPtr &t) const |
See Element::find() More... | |
Static Public Member Functions | |
static const Position & | ZERO_POSITION () |
Returns Position object with line_ and pos_ set to 0, and with an empty file name. More... | |
Direct factory functions | |
These functions simply wrap the given data directly in an Element object, and return a reference to it, in the form of an These factory functions are exception-free (unless there is no memory available, in which case bad_alloc is raised by the underlying system). (Note that that is different from an NullElement, which represents an empty value, and is created with Element::create()) Notes: Read notes of IntElement definition about the use of long long int, long int and int. | |
static ElementPtr | create (const Position &pos=ZERO_POSITION()) |
static ElementPtr | create (const long long int i, const Position &pos=ZERO_POSITION()) |
static ElementPtr | create (const int i, const Position &pos=ZERO_POSITION()) |
static ElementPtr | create (const long int i, const Position &pos=ZERO_POSITION()) |
static ElementPtr | create (const double d, const Position &pos=ZERO_POSITION()) |
static ElementPtr | create (const bool b, const Position &pos=ZERO_POSITION()) |
static ElementPtr | create (const std::string &s, const Position &pos=ZERO_POSITION()) |
static ElementPtr | create (const char *s, const Position &pos=ZERO_POSITION()) |
static ElementPtr | createList (const Position &pos=ZERO_POSITION()) |
Creates an empty ListElement type ElementPtr. More... | |
static ElementPtr | createMap (const Position &pos=ZERO_POSITION()) |
Creates an empty MapElement type ElementPtr. More... | |
Compound factory functions | |
static ElementPtr | fromJSON (const std::string &in, bool preproc=false) |
These functions will parse the given string (JSON) representation of a compound element. More... | |
static ElementPtr | fromJSON (std::istream &in, bool preproc=false) |
Creates an Element from the given input stream containing JSON formatted data. More... | |
static ElementPtr | fromJSON (std::istream &in, const std::string &file_name, bool preproc=false) |
Creates an Element from the given input stream containing JSON formatted data. More... | |
static ElementPtr | fromJSON (std::istream &in, const std::string &file, int &line, int &pos) |
Creates an Element from the given input stream, where we keep track of the location in the stream for error reporting. More... | |
static ElementPtr | fromJSONFile (const std::string &file_name, bool preproc=false) |
Reads contents of specified file and interprets it as JSON. More... | |
Type name conversion functions | |
static std::string | typeToName (Element::types type) |
Returns the name of the given type as a string. More... | |
static Element::types | nameToType (const std::string &type_name) |
Converts the string to the corresponding type Throws a TypeError if the name is unknown. More... | |
static void | preprocess (std::istream &in, std::stringstream &out) |
input text preprocessor More... | |
Wire format factory functions | |
static ElementPtr | fromWire (std::stringstream &in, int length) |
These function pparse the wireformat at the given stringstream (of the given length). More... | |
static ElementPtr | fromWire (const std::string &s) |
Creates an Element from the wire format in the given string Since the wire format is JSON, this is the same as fromJSON, and could be removed. More... | |
Protected Member Functions | |
Element (int t, const Position &pos=ZERO_POSITION()) | |
Constructor. More... | |
The Element
class represents a piece of data, used by the command channel and configuration parts.
An Element
can contain simple types (int, real, string, bool and None), and composite types (list and string->element maps)
Elements should in calling functions usually be referenced through an ElementPtr
, which can be created using the factory functions Element::create()
and Element::fromJSON()
Notes to developers: Element is a base class, implemented by a specific subclass for each type (IntElement, BoolElement, etc). Element does define all functions for all types, and defaults to raising a TypeError
for functions that are not supported for the type in question.
|
inlineprotected |
|
virtual |
Adds an ElementPtr to the list.
element | The ElementPtr to add |
Reimplemented in isc::data::ListElement.
Definition at line 145 of file data.cc.
References throwTypeError.
|
inlinevirtual |
Reimplemented in isc::data::BoolElement.
Definition at line 215 of file data.h.
References throwTypeError.
Referenced by isc::data::BoolElement::equals().
|
virtual |
Checks if there is data at the given key.
name | The key of the Element checked for existence |
Reimplemented in isc::data::MapElement.
Definition at line 180 of file data.cc.
References throwTypeError.
Referenced by isc::data::MapElement::equals().
|
static |
Definition at line 222 of file data.cc.
Referenced by isc::data::StampedValue::create(), isc::ha::CommandCreator::createDHCPDisable(), isc::ha::CommandCreator::createDHCPEnable(), isc::ha::CommandCreator::createLease4GetPage(), isc::ha::CommandCreator::createLease4Update(), isc::ha::CommandCreator::createLease6GetPage(), isc::ha::CommandCreator::createLease6Update(), isc::ha::CommandCreator::createMaintenanceNotify(), isc::dhcp::CfgHostsList::externalize(), isc::dhcp::PacketQueue< Pkt6Ptr >::getInfo(), isc::dhcp::PacketQueueRing< Pkt6Ptr >::getInfo(), isc::stats::Observation::getJSON(), isc::data::StampedElement::getMetadata(), isc::dhcp::BaseNetworkParser::moveReservationMode(), isc::dhcp::DHCPQueueControlParser::parse(), isc::dhcp::CfgMACSource::toElement(), isc::dhcp::Cfg4o6::toElement(), isc::dhcp::SharedNetwork4::toElement(), isc::db::DatabaseConnection::toElement(), isc::dhcp::SharedNetwork6::toElement(), isc::dhcp::CfgOptionDef::toElementWithMetadata(), and isc::dhcp::CfgOption::toElementWithMetadata().
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
Creates an empty ListElement type ElementPtr.
pos | A structure holding position of the data element value in the configuration string. It is used for error logging purposes. |
Definition at line 262 of file data.cc.
Referenced by isc::dhcp::CfgHostsList::add(), isc::ha::CommandCreator::createLease6BulkApply(), isc::dhcp::CfgHostsList::externalize(), isc::dhcp::CfgHostsList::get(), isc::stats::Observation::getJSON(), isc::data::StampedElement::getMetadata(), isc::dhcp::CfgMACSource::toElement(), isc::dhcp::CfgSharedNetworks< SharedNetwork4Ptr, SharedNetwork4Collection >::toElement(), isc::dhcp::CfgHostDbAccess::toElement(), isc::dhcp::SharedNetwork4::toElement(), isc::dhcp::SharedNetwork6::toElement(), isc::dhcp::CfgOptionDef::toElementWithMetadata(), and isc::dhcp::CfgOption::toElementWithMetadata().
|
static |
Creates an empty MapElement type ElementPtr.
pos | A structure holding position of the data element value in the configuration string. It is used for error logging purposes. |
Definition at line 267 of file data.cc.
Referenced by isc::dhcp::SrvConfig::clearConfiguredGlobals(), isc::ha::CommandCreator::createDHCPDisable(), isc::ha::CommandCreator::createDHCPEnable(), isc::ha::CommandCreator::createLease4GetPage(), isc::ha::CommandCreator::createLease6BulkApply(), isc::ha::CommandCreator::createLease6GetPage(), isc::ha::CommandCreator::createMaintenanceNotify(), isc::dhcp::CfgHostsList::externalize(), isc::dhcp::PacketQueue< Pkt6Ptr >::getInfo(), isc::data::StampedElement::getMetadata(), isc::dhcp::SimpleParser6::setAllDefaults(), isc::dhcp::SimpleParser4::setAllDefaults(), isc::dhcp::Cfg4o6::toElement(), isc::db::DatabaseConnection::toElement(), isc::dhcp::CfgOptionDef::toElementWithMetadata(), and isc::dhcp::CfgOption::toElementWithMetadata().
|
inlinevirtual |
Reimplemented in isc::data::DoubleElement.
Definition at line 213 of file data.h.
References throwTypeError.
Referenced by isc::data::DoubleElement::equals().
|
virtual |
Return true if there are no elements in the list.
Reimplemented in isc::data::MapElement, and isc::data::ListElement.
Definition at line 160 of file data.cc.
References throwTypeError.
|
pure virtual |
Implemented in isc::data::MapElement, isc::data::ListElement, isc::data::StringElement, isc::data::NullElement, isc::data::BoolElement, isc::data::DoubleElement, and isc::data::IntElement.
Referenced by isc::data::operator!=(), and isc::data::operator==().
|
virtual |
Recursively finds any data at the given identifier.
The identifier is a /-separated list of names of nested maps, with the last name being the leaf that is returned.
For instance, if you have a MapElement that contains another MapElement at the key "foo", and that second MapElement contains Another Element at key "bar", the identifier for that last element from the first is "foo/bar".
identifier | The identifier of the element to find |
Reimplemented in isc::data::MapElement.
Definition at line 185 of file data.cc.
References throwTypeError.
|
virtual |
See Element::find()
identifier | The identifier of the element to find |
t | Reference to store the resulting ElementPtr, if found. |
Reimplemented in isc::data::MapElement.
|
static |
These functions will parse the given string (JSON) representation of a compound element.
If there is a parse error, an exception of the type isc::data::JSONError is thrown. Creates an Element from the given JSON string
in | The string to parse the element from |
preproc | specified whether preprocessing (e.g. comment removal) should be performed |
Definition at line 740 of file data.cc.
Referenced by isc::dhcp_ddns::NameChangeRequest::fromJSON(), and user_chk::UserFile::makeUser().
|
static |
Creates an Element from the given input stream containing JSON formatted data.
in | The string to parse the element from |
preproc | specified whether preprocessing (e.g. comment removal) should be performed |
JSONError |
|
static |
Creates an Element from the given input stream containing JSON formatted data.
in | The string to parse the element from |
file_name | specified input file name (used in error reporting) |
preproc | specified whether preprocessing (e.g. comment removal) should be performed |
JSONError |
JSONError |
|
static |
Creates an Element from the given input stream, where we keep track of the location in the stream for error reporting.
in | The string to parse the element from. |
file | The input file name. |
line | A reference to the int where the function keeps track of the current line. |
pos | A reference to the int where the function keeps track of the current position within the current line. |
JSONError |
JSONError |
Definition at line 670 of file data.cc.
References isc_throw.
|
static |
Reads contents of specified file and interprets it as JSON.
file_name | name of the file to read |
preproc | specified whether preprocessing (e.g. comment removal) should be performed |
Definition at line 759 of file data.cc.
References isc::db::error, and isc_throw.
|
static |
These function pparse the wireformat at the given stringstream (of the given length).
If there is a parse error an exception of the type isc::cc::DecodeError is raised. Creates an Element from the wire format in the given stringstream of the given length. Since the wire format is JSON, this is the same as fromJSON, and could be removed.
in | The input stringstream. |
length | The length of the wireformat data in the stream |
|
static |
|
virtual |
Returns the ElementPtr at the given index.
If the index is out of bounds, this function throws an std::out_of_range exception.
i | The position of the ElementPtr to return |
Reimplemented in isc::data::ListElement.
Definition at line 130 of file data.cc.
References throwTypeError.
Referenced by isc::data::ListElement::equals(), and isc::data::MapElement::equals().
|
virtual |
Returns the ElementPtr at the given key.
name | The key of the Element to return |
Reimplemented in isc::data::MapElement.
Definition at line 165 of file data.cc.
References throwTypeError.
|
virtual |
returns element as non-const pointer
i | The position of the ElementPtr to retrieve |
Reimplemented in isc::data::ListElement.
Definition at line 135 of file data.cc.
References throwTypeError.
|
inline |
|
inline |
Definition at line 156 of file data.h.
Referenced by isc::data::IntElement::equals(), isc::data::DoubleElement::equals(), isc::data::BoolElement::equals(), isc::data::NullElement::equals(), isc::data::StringElement::equals(), isc::data::ListElement::equals(), and isc::data::MapElement::equals().
|
virtual |
Reimplemented in isc::data::IntElement.
|
virtual |
Reimplemented in isc::data::DoubleElement.
|
virtual |
Reimplemented in isc::data::BoolElement.
|
virtual |
Reimplemented in isc::data::StringElement.
|
virtual |
Reimplemented in isc::data::ListElement.
|
virtual |
Reimplemented in isc::data::MapElement.
|
inlinevirtual |
Reimplemented in isc::data::IntElement.
Definition at line 211 of file data.h.
References throwTypeError.
Referenced by isc::data::IntElement::equals().
|
inlinevirtual |
Reimplemented in isc::data::ListElement.
Definition at line 219 of file data.h.
References throwTypeError.
|
inlinevirtual |
Reimplemented in isc::data::MapElement.
Definition at line 223 of file data.h.
References throwTypeError.
|
static |
|
static |
input text preprocessor
This method performs preprocessing of the input stream (which is expected to contain a text version of to be parsed JSON). For now the sole supported operation is bash-style (line starting with #) comment removal, but it will be extended later to cover more cases (C, C++ style comments, file inclusions, maybe macro replacements?).
This method processes the whole input stream. It reads all contents of the input stream, filters the content and returns the result in a different stream.
in | input stream to be preprocessed |
out | output stream (filtered content will be written here) |
|
virtual |
Removes the element at the given position.
If the index is out of nothing happens.
i | The index of the element to remove. |
Reimplemented in isc::data::ListElement.
Definition at line 150 of file data.cc.
References throwTypeError.
Referenced by isc::yang::AdaptorConfig::sanitizeDatabase(), and isc::yang::AdaptorConfig::sanitizeRelaySuppliedOptions().
|
virtual |
Remove the ElementPtr at the given key.
name | The key of the Element to remove |
Reimplemented in isc::data::MapElement.
Definition at line 175 of file data.cc.
References throwTypeError.
|
virtual |
Sets the ElementPtr at the given index.
If the index is out of bounds, this function throws an std::out_of_range exception.
i | The position of the ElementPtr to set |
element | The ElementPtr to set at the position |
Reimplemented in isc::data::ListElement.
Definition at line 140 of file data.cc.
References throwTypeError.
|
virtual |
Sets the ElementPtr at the given key.
name | The key of the Element to set |
element | The ElementPtr to set at the given key. |
Reimplemented in isc::data::MapElement.
Definition at line 170 of file data.cc.
References throwTypeError.
|
virtual |
Reimplemented in isc::data::IntElement.
|
inline |
Definition at line 257 of file data.h.
References setValue().
Referenced by setValue().
|
inline |
Definition at line 258 of file data.h.
References setValue().
Referenced by setValue().
|
virtual |
Reimplemented in isc::data::DoubleElement.
|
virtual |
Reimplemented in isc::data::BoolElement.
|
virtual |
Reimplemented in isc::data::StringElement.
|
virtual |
Reimplemented in isc::data::ListElement.
|
virtual |
Reimplemented in isc::data::MapElement.
|
virtual |
Returns the number of elements in the list.
Reimplemented in isc::data::MapElement, and isc::data::ListElement.
Definition at line 155 of file data.cc.
References throwTypeError.
Referenced by isc::data::ListElement::equals(), and isc::data::MapElement::equals().
std::string isc::data::Element::str | ( | ) | const |
Returns a string representing the Element and all its child elements; note that this is different from stringValue(), which only returns the single value of a StringElement.
The resulting string will contain the Element in JSON format.
Definition at line 51 of file data.cc.
Referenced by isc::data::operator<<().
|
inlinevirtual |
Reimplemented in isc::data::StringElement.
Definition at line 217 of file data.h.
References throwTypeError.
Referenced by isc::data::StringElement::equals().
|
pure virtual |
Converts the Element to JSON format and appends it to the given stringstream.
Implemented in isc::data::MapElement, isc::data::ListElement, isc::data::StringElement, isc::data::NullElement, isc::data::BoolElement, isc::data::DoubleElement, and isc::data::IntElement.
std::string isc::data::Element::toWire | ( | ) | const |
|
static |
Returns the name of the given type as a string.
type | The type to return the name of |
Definition at line 597 of file data.cc.
Referenced by isc::data::StampedValue::create().
|
inlinestatic |
Returns Position
object with line_ and pos_ set to 0, and with an empty file name.
The object containing two zeros is a default for most of the methods creating Element
objects. The returned value is static so as it is not created everytime the function with the default position argument is called.
Definition at line 120 of file data.h.
Referenced by isc::dhcp::ValueStorage< ValueType >::getPosition().