2010-05-13 23:05:28 +02:00
/* -------------------------------------------------------------------------- */
2015-02-24 12:27:59 +01:00
/* Copyright 2002-2015, OpenNebula Project (OpenNebula.org), C12G Labs */
2010-05-13 23:05:28 +02:00
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
# ifndef OBJECT_XML_H_
# define OBJECT_XML_H_
# include <string>
# include <vector>
# include <libxml/tree.h>
# include <libxml/parser.h>
# include <libxml/xpath.h>
# include <libxml/xpathInternals.h>
using namespace std ;
/**
* This class represents a generic Object supported by a xml document .
* The class provides basic methods to query attributes , and get xml nodes
*/
class ObjectXML
{
public :
// ---------------------- Constructors ------------------------------------
ObjectXML ( ) : xml ( 0 ) , ctx ( 0 ) { } ;
/**
* Constructs an object using a XML document
*/
ObjectXML ( const string & xml_doc ) ;
/**
* Constructs an object using a XML Node . The node is copied to the new
* object
*/
ObjectXML ( const xmlNodePtr node ) ;
virtual ~ ObjectXML ( ) ;
/**
* Access Object elements using Xpath
* @ param xpath_expr the Xpath of the element
* @ return a vector with the elements
*/
vector < string > operator [ ] ( const char * xpath_expr ) ;
2011-02-25 13:54:39 +01:00
/**
* Gets and sets a xpath attribute , if the attribute is not found a default
* is used
2013-08-06 17:25:21 +02:00
* @ param value to set
2011-02-25 13:54:39 +01:00
* @ param xpath_expr of the xml element
* @ param def default value if the element is not found
2011-02-25 20:28:47 +01:00
*
* @ return - 1 if default was set
2011-02-25 13:54:39 +01:00
*/
2011-02-25 20:28:47 +01:00
int xpath ( string & value , const char * xpath_expr , const char * def ) ;
2011-02-25 13:54:39 +01:00
/**
* Gets and sets a xpath attribute , if the attribute is not found a default
* is used
2013-08-06 17:25:21 +02:00
* @ param value to set
2011-02-25 13:54:39 +01:00
* @ param xpath_expr of the xml element
* @ param def default value if the element is not found
2011-02-25 20:28:47 +01:00
*
* @ return - 1 if default was set
2011-02-25 13:54:39 +01:00
*/
2011-02-25 20:28:47 +01:00
int xpath ( int & value , const char * xpath_expr , const int & def ) ;
2011-02-25 13:54:39 +01:00
2014-10-30 17:21:27 +01:00
/**
* Gets and sets a xpath attribute , if the attribute is not found a default
* is used
* @ param value to set
* @ param xpath_expr of the xml element
* @ param def default value if the element is not found
*
* @ return - 1 if default was set
*/
int xpath ( float & value , const char * xpath_expr , const float & def ) ;
2011-02-25 15:23:46 +01:00
/**
* Gets and sets a xpath attribute , if the attribute is not found a default
2011-03-03 18:53:41 +01:00
* is used
2013-08-06 17:25:21 +02:00
* @ param value to set
2011-03-03 18:53:41 +01:00
* @ param xpath_expr of the xml element
* @ param def default value if the element is not found
*
* @ return - 1 if default was set
*/
int xpath ( unsigned int & value , const char * xpath_expr ,
const unsigned int & def ) ;
2012-12-04 13:35:45 +01:00
/**
* Gets and sets a xpath attribute , if the attribute is not found a default
* is used
2013-08-06 17:25:21 +02:00
* @ param value to set
2012-12-04 13:35:45 +01:00
* @ param xpath_expr of the xml element
* @ param def default value if the element is not found
*
* @ return - 1 if default was set
*/
int xpath ( long long & value , const char * xpath_expr ,
const long long & def ) ;
/**
* Gets and sets a xpath attribute , if the attribute is not found a default
* is used
2013-08-06 17:25:21 +02:00
* @ param value to set
2012-12-04 13:35:45 +01:00
* @ param xpath_expr of the xml element
* @ param def default value if the element is not found
*
* @ return - 1 if default was set
*/
int xpath ( unsigned long long & value , const char * xpath_expr ,
const unsigned long long & def ) ;
2011-06-30 16:04:56 +02:00
/**
* Gets and sets a xpath attribute , if the attribute is not found a default
2011-02-25 15:23:46 +01:00
* is used
* @ param value to set
* @ param xpath_expr of the xml element
* @ param def default value if the element is not found
2011-02-25 20:28:47 +01:00
*
* @ return - 1 if default was set
2011-02-25 15:23:46 +01:00
*/
2011-02-25 20:28:47 +01:00
int xpath ( time_t & value , const char * xpath_expr , const time_t & def ) ;
2011-02-25 15:23:46 +01:00
2011-02-25 14:17:41 +01:00
/**
* Gets the value of an element from an xml string
* @ param value the value of the element
* @ param xml the xml string
* @ param xpath the xpath of the target element
2013-08-06 17:25:21 +02:00
*
2011-02-25 14:17:41 +01:00
* @ return - 1 if the element was not found
*/
static int xpath_value ( string & value , const char * xml , const char * xpath ) ;
2013-08-06 17:25:21 +02:00
/**
* Search the Object for a given attribute in a set of object specific
* routes .
* @ param name of the attribute
* @ param value of the attribute
*
* @ return - 1 if the element was not found
*/
virtual int search ( const char * name , string & value ) ;
/**
* Search the Object for a given attribute in a set of object specific
* routes . integer version
*/
virtual int search ( const char * name , int & value ) ;
/**
* Search the Object for a given attribute in a set of object specific
* routes . float version
*/
virtual int search ( const char * name , float & value ) ;
2010-05-13 23:05:28 +02:00
/**
* Get xml nodes by Xpath
* @ param xpath_expr the Xpath for the elements
* @ param content nodes for the given Xpath expression . The nodes are
* returned as pointers to the object nodes .
* @ return the number of nodes found
*/
2011-03-04 22:37:21 +01:00
int get_nodes ( const char * xpath_expr , vector < xmlNodePtr > & content ) ;
2010-05-13 23:05:28 +02:00
2013-01-22 14:14:56 +01:00
/**
* Adds a copy of the node as a child of the node in the xpath expression .
* The source node must be cleaned by the caller .
*
* @ param xpath_expr Path of the parent node
* @ param node Node copy and add
* @ param new_name New name for the node copy
*
* @ return 0 on success , - 1 otherwise
*/
int add_node ( const char * xpath_expr , xmlNodePtr node , const char * new_name ) ;
2010-05-13 23:05:28 +02:00
/**
2011-07-03 01:57:39 +02:00
* Frees a vector of XMLNodes , as returned by the get_nodes function
* @ param content the vector of xmlNodePtr
*/
void free_nodes ( vector < xmlNodePtr > & content )
{
vector < xmlNodePtr > : : iterator it ;
for ( it = content . begin ( ) ; it < content . end ( ) ; it + + )
{
xmlFreeNode ( * it ) ;
}
} ;
/**
2010-05-13 23:05:28 +02:00
* Updates the object representation with a new XML document . Previous
* XML resources are freed
* @ param xml_doc the new xml document
*/
2011-02-24 18:12:26 +01:00
int update_from_str ( const string & xml_doc ) ;
2010-05-13 23:05:28 +02:00
/**
* Updates the object representation with a new XML document . Previous
* XML resources are freed
* @ param xml_doc the new xml document
*/
2011-02-24 18:12:26 +01:00
int update_from_node ( const xmlNodePtr node ) ;
2010-05-13 23:05:28 +02:00
2011-12-19 17:07:32 +01:00
/**
* Validates the xml string
*
* @ param xml_doc string to parse
* @ return 0 if the xml validates
*/
static int validate_xml ( const string & xml_doc ) ;
2013-01-30 17:49:24 +01:00
/**
* Renames the nodes given in the xpath expression
* @ param xpath_expr xpath expression to find the nodes to rename
* @ param new_name new name for the xml elements
*
* @ return the number of nodes renamed
*/
int rename_nodes ( const char * xpath_expr , const char * new_name ) ;
2010-05-14 03:32:42 +02:00
// ---------------------------------------------------------
// Lex & bison parser for requirements and rank expressions
// ---------------------------------------------------------
/**
* Evaluates a requirement expression on the given host .
* @ param requirements string
* @ param result true if the host matches the requirements
* @ param errmsg string describing the error , must be freed by the
* calling function
* @ return 0 on success
*/
int eval_bool ( const string & expr , bool & result , char * * errmsg ) ;
/**
* Evaluates a rank expression on the given host .
* @ param rank string
* @ param result of the rank evaluation
* @ param errmsg string describing the error , must be freed by the
* calling function
* @ return 0 on success
*/
int eval_arith ( const string & expr , int & result , char * * errmsg ) ;
2010-05-14 19:15:20 +02:00
/**
* Function to write the Object in an output stream
*/
friend ostream & operator < < ( ostream & os , ObjectXML & oxml )
{
xmlChar * mem ;
int size ;
xmlDocDumpMemory ( oxml . xml , & mem , & size ) ;
string str ( reinterpret_cast < char * > ( mem ) ) ;
os < < str ;
xmlFree ( mem ) ;
return os ;
} ;
2013-08-06 17:25:21 +02:00
protected :
/**
* Array of paths to look for attributes in search methods
*/
const char * * paths ;
/**
* Number of elements in paths array
*/
int num_paths ;
2010-05-13 23:05:28 +02:00
private :
/**
* XML representation of the Object
*/
xmlDocPtr xml ;
/**
* XPath Context to access Object elements
*/
xmlXPathContextPtr ctx ;
/**
* Parse a XML documents and initializes XPath contexts
*/
void xml_parse ( const string & xml_doc ) ;
2013-08-06 17:25:21 +02:00
/**
* Search the Object for a given attribute in a set of object specific
* routes .
* @ param name of the attribute
* @ results vector of attributes that matches the query
*/
void search ( const char * name , vector < string > & results ) ;
2010-05-13 23:05:28 +02:00
} ;
# endif /*OBJECT_XML_H_*/