pacemaker 2.1.6-6fdc9deea29
Scalable High-Availability cluster resource manager
Loading...
Searching...
No Matches
xml.h
Go to the documentation of this file.
1/*
2 * Copyright 2004-2023 the Pacemaker project contributors
3 *
4 * The version control history for this file may have further details.
5 *
6 * This source code is licensed under the GNU Lesser General Public License
7 * version 2.1 or later (LGPLv2.1+) WITHOUT ANY WARRANTY.
8 */
9
10#ifndef PCMK__CRM_COMMON_XML__H
11# define PCMK__CRM_COMMON_XML__H
12
13
14# include <stdio.h>
15# include <sys/types.h>
16# include <unistd.h>
17
18# include <stdlib.h>
19# include <errno.h>
20# include <fcntl.h>
21
22# include <libxml/tree.h>
23# include <libxml/xpath.h>
24
25# include <crm/crm.h>
26# include <crm/common/nvpair.h>
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
38/* Define compression parameters for IPC messages
39 *
40 * Compression costs a LOT, so we don't want to do it unless we're hitting
41 * message limits. Currently, we use 128KB as the threshold, because higher
42 * values don't play well with the heartbeat stack. With an earlier limit of
43 * 10KB, compressing 184 of 1071 messages accounted for 23% of the total CPU
44 * used by the cib.
45 */
46# define CRM_BZ2_BLOCKS 4
47# define CRM_BZ2_WORK 20
48# define CRM_BZ2_THRESHOLD 128 * 1024
49
50typedef const xmlChar *pcmkXmlStr;
51
52gboolean add_message_xml(xmlNode * msg, const char *field, xmlNode * xml);
53xmlNode *get_message_xml(const xmlNode *msg, const char *field);
54
55xmlDoc *getDocPtr(xmlNode * node);
56
57/*
58 * \brief xmlCopyPropList ACLs-sensitive replacement expading i++ notation
59 *
60 * The gist is the same as with \c{xmlCopyPropList(target, src->properties)}.
61 * The function exits prematurely when any attribute cannot be copied for
62 * ACLs violation. Even without bailing out, the result can possibly be
63 * incosistent with expectations in that case, hence the caller shall,
64 * aposteriori, verify that no document-level-tracked denial was indicated
65 * with \c{xml_acl_denied(target)} and drop whole such intermediate object.
66 *
67 * \param[in,out] target Element to receive attributes from #src element
68 * \param[in] src Element carrying attributes to copy over to #target
69 *
70 * \note Original commit 1c632c506 sadly haven't stated which otherwise
71 * assumed behaviours of xmlCopyPropList were missing beyond otherwise
72 * custom extensions like said ACLs and "atomic increment" (that landed
73 * later on, anyway).
74 */
75void copy_in_properties(xmlNode *target, const xmlNode *src);
76
77void expand_plus_plus(xmlNode * target, const char *name, const char *value);
78void fix_plus_plus_recursive(xmlNode * target);
79
80/*
81 * Create a node named "name" as a child of "parent"
82 * If parent is NULL, creates an unconnected node.
83 *
84 * Returns the created node
85 *
86 */
87xmlNode *create_xml_node(xmlNode * parent, const char *name);
88
89/*
90 * Create a node named "name" as a child of "parent", giving it the provided
91 * text content.
92 * If parent is NULL, creates an unconnected node.
93 *
94 * Returns the created node
95 *
96 */
97xmlNode *pcmk_create_xml_text_node(xmlNode * parent, const char *name, const char *content);
98
99/*
100 * Create a new HTML node named "element_name" as a child of "parent", giving it the
101 * provided text content. Optionally, apply a CSS #id and #class.
102 *
103 * Returns the created node.
104 */
105xmlNode *pcmk_create_html_node(xmlNode * parent, const char *element_name, const char *id,
106 const char *class_name, const char *text);
107
108/*
109 *
110 */
111void purge_diff_markers(xmlNode * a_node);
112
113/*
114 * Returns a deep copy of src_node
115 *
116 */
117xmlNode *copy_xml(xmlNode * src_node);
118
119/*
120 * Add a copy of xml_node to new_parent
121 */
122xmlNode *add_node_copy(xmlNode * new_parent, xmlNode * xml_node);
123
124/*
125 * XML I/O Functions
126 *
127 * Whitespace between tags is discarded.
128 */
129xmlNode *filename2xml(const char *filename);
130
131xmlNode *stdin2xml(void);
132
133xmlNode *string2xml(const char *input);
134
135int write_xml_fd(xmlNode * xml_node, const char *filename, int fd, gboolean compress);
136int write_xml_file(xmlNode * xml_node, const char *filename, gboolean compress);
137
138char *dump_xml_formatted(xmlNode * msg);
139char *dump_xml_formatted_with_text(xmlNode * msg);
140char *dump_xml_unformatted(xmlNode * msg);
141
142/*
143 * Diff related Functions
144 */
145xmlNode *diff_xml_object(xmlNode * left, xmlNode * right, gboolean suppress);
146
147xmlNode *subtract_xml_object(xmlNode * parent, xmlNode * left, xmlNode * right,
148 gboolean full, gboolean * changed, const char *marker);
149
150gboolean can_prune_leaf(xmlNode * xml_node);
151
152/*
153 * Searching & Modifying
154 */
155xmlNode *find_xml_node(const xmlNode *root, const char *search_path,
156 gboolean must_find);
157
158void xml_remove_prop(xmlNode * obj, const char *name);
159
160gboolean replace_xml_child(xmlNode * parent, xmlNode * child, xmlNode * update,
161 gboolean delete_only);
162
163gboolean update_xml_child(xmlNode * child, xmlNode * to_update);
164
165int find_xml_children(xmlNode ** children, xmlNode * root,
166 const char *tag, const char *field, const char *value,
167 gboolean search_matches);
168
169xmlNode *get_xpath_object(const char *xpath, xmlNode * xml_obj, int error_level);
170xmlNode *get_xpath_object_relative(const char *xpath, xmlNode * xml_obj, int error_level);
171
172static inline const char *
173crm_element_name(const xmlNode *xml)
174{
175 return xml? (const char *)(xml->name) : NULL;
176}
177
178static inline const char *
179crm_map_element_name(const xmlNode *xml)
180{
181 const char *name = crm_element_name(xml);
182
183 if (strcmp(name, "master") == 0) {
184 return "clone";
185 } else {
186 return name;
187 }
188}
189
190gboolean xml_has_children(const xmlNode * root);
191
192char *calculate_on_disk_digest(xmlNode * local_cib);
193char *calculate_operation_digest(xmlNode * local_cib, const char *version);
194char *calculate_xml_versioned_digest(xmlNode * input, gboolean sort, gboolean do_filter,
195 const char *version);
196
197/* schema-related functions (from schemas.c) */
198gboolean validate_xml(xmlNode * xml_blob, const char *validation, gboolean to_logs);
199gboolean validate_xml_verbose(xmlNode * xml_blob);
200
238int update_validation(xmlNode **xml_blob, int *best, int max,
239 gboolean transform, gboolean to_logs);
240
241int get_schema_version(const char *name);
242const char *get_schema_name(int version);
243const char *xml_latest_schema(void);
244gboolean cli_config_update(xmlNode ** xml, int *best_version, gboolean to_logs);
245
251void crm_xml_init(void);
252void crm_xml_cleanup(void);
253
254void pcmk_free_xml_subtree(xmlNode *xml);
255void free_xml(xmlNode * child);
256
257xmlNode *first_named_child(const xmlNode *parent, const char *name);
258xmlNode *crm_next_same_xml(const xmlNode *sibling);
259
260xmlNode *sorted_xml(xmlNode * input, xmlNode * parent, gboolean recursive);
261xmlXPathObjectPtr xpath_search(xmlNode * xml_top, const char *path);
262void crm_foreach_xpath_result(xmlNode *xml, const char *xpath,
263 void (*helper)(xmlNode*, void*), void *user_data);
264xmlNode *expand_idref(xmlNode * input, xmlNode * top);
265
266void freeXpathObject(xmlXPathObjectPtr xpathObj);
267xmlNode *getXpathResult(xmlXPathObjectPtr xpathObj, int index);
268void dedupXpathResults(xmlXPathObjectPtr xpathObj);
269
270static inline int numXpathResults(xmlXPathObjectPtr xpathObj)
271{
272 if(xpathObj == NULL || xpathObj->nodesetval == NULL) {
273 return 0;
274 }
275 return xpathObj->nodesetval->nodeNr;
276}
277
278bool xml_tracking_changes(xmlNode * xml);
279bool xml_document_dirty(xmlNode *xml);
280void xml_track_changes(xmlNode * xml, const char *user, xmlNode *acl_source, bool enforce_acls);
281void xml_calculate_changes(xmlNode *old_xml, xmlNode *new_xml);
282void xml_calculate_significant_changes(xmlNode *old_xml, xmlNode *new_xml);
283void xml_accept_changes(xmlNode * xml);
284bool xml_patch_versions(const xmlNode *patchset, int add[3], int del[3]);
285
286xmlNode *xml_create_patchset(
287 int format, xmlNode *source, xmlNode *target, bool *config, bool manage_version);
288int xml_apply_patchset(xmlNode *xml, xmlNode *patchset, bool check_version);
289
290void patchset_process_digest(xmlNode *patch, xmlNode *source, xmlNode *target, bool with_digest);
291
292void save_xml_to_file(xmlNode * xml, const char *desc, const char *filename);
293
294char * crm_xml_escape(const char *text);
295void crm_xml_sanitize_id(char *id);
296void crm_xml_set_id(xmlNode *xml, const char *format, ...) G_GNUC_PRINTF(2, 3);
297
298#if !defined(PCMK_ALLOW_DEPRECATED) || (PCMK_ALLOW_DEPRECATED == 1)
300#endif
301
302#ifdef __cplusplus
303}
304#endif
305
306#endif
const char * parent
Definition cib.c:25
const char * path
Definition cib.c:26
const char * name
Definition cib.c:24
uint32_t version
Definition remote.c:1
A dumping ground.
xmlNode * input
Functionality for manipulating name/value pairs.
const char * target
Definition pcmk_fence.c:29
gboolean update_xml_child(xmlNode *child, xmlNode *to_update)
Definition xml.c:2340
gboolean xml_has_children(const xmlNode *root)
Definition xml.c:1726
const char * get_schema_name(int version)
Definition schemas.c:1024
int get_schema_version(const char *name)
Definition schemas.c:1033
xmlXPathObjectPtr xpath_search(xmlNode *xml_top, const char *path)
Definition xpath.c:139
gboolean replace_xml_child(xmlNode *parent, xmlNode *child, xmlNode *update, gboolean delete_only)
Definition xml.c:2407
int update_validation(xmlNode **xml_blob, int *best, int max, gboolean transform, gboolean to_logs)
Update CIB XML to most recent schema version.
Definition schemas.c:1050
xmlNode * filename2xml(const char *filename)
Definition xml.c:1007
void dedupXpathResults(xmlXPathObjectPtr xpathObj)
Definition xpath.c:101
char * dump_xml_formatted(xmlNode *msg)
Definition xml.c:1700
xmlNode * expand_idref(xmlNode *input, xmlNode *top)
Definition xml.c:2593
gboolean validate_xml_verbose(xmlNode *xml_blob)
Definition schemas.c:679
char * calculate_on_disk_digest(xmlNode *local_cib)
Calculate and return digest of XML tree, suitable for storing on disk.
Definition digest.c:131
void crm_foreach_xpath_result(xmlNode *xml, const char *xpath, void(*helper)(xmlNode *, void *), void *user_data)
Run a supplied function for each result of an xpath search.
Definition xpath.c:173
xmlNode * first_named_child(const xmlNode *parent, const char *name)
Definition xml.c:2521
char * dump_xml_unformatted(xmlNode *msg)
Definition xml.c:1713
xmlNode * pcmk_create_xml_text_node(xmlNode *parent, const char *name, const char *content)
Definition xml.c:702
void copy_in_properties(xmlNode *target, const xmlNode *src)
Definition xml.c:481
bool xml_patch_versions(const xmlNode *patchset, int add[3], int del[3])
Definition patchset.c:572
void fix_plus_plus_recursive(xmlNode *target)
Parse integer assignment statements on this node and all its child nodes.
Definition xml.c:514
const xmlChar * pcmkXmlStr
Definition xml.h:50
char * dump_xml_formatted_with_text(xmlNode *msg)
Definition xml.c:1686
int write_xml_fd(xmlNode *xml_node, const char *filename, int fd, gboolean compress)
Write XML to a file descriptor.
Definition xml.c:1237
xmlNode * get_xpath_object(const char *xpath, xmlNode *xml_obj, int error_level)
Definition xpath.c:214
void xml_accept_changes(xmlNode *xml)
Definition xml.c:379
void patchset_process_digest(xmlNode *patch, xmlNode *source, xmlNode *target, bool with_digest)
Definition patchset.c:376
xmlNode * getXpathResult(xmlXPathObjectPtr xpathObj, int index)
Definition xpath.c:58
void crm_xml_init(void)
Initialize the CRM XML subsystem.
Definition xml.c:2562
const char * xml_latest_schema(void)
Definition schemas.c:113
void crm_xml_set_id(xmlNode *xml, const char *format,...) G_GNUC_PRINTF(2
xmlNode * crm_next_same_xml(const xmlNode *sibling)
Get next instance of same XML tag.
Definition xml.c:2547
int xml_apply_patchset(xmlNode *xml, xmlNode *patchset, bool check_version)
Definition patchset.c:1096
void xml_calculate_changes(xmlNode *old_xml, xmlNode *new_xml)
Definition xml.c:2103
gboolean cli_config_update(xmlNode **xml, int *best_version, gboolean to_logs)
Definition schemas.c:1197
void freeXpathObject(xmlXPathObjectPtr xpathObj)
Definition xpath.c:39
char * crm_xml_escape(const char *text)
Replace special characters with their XML escape sequences.
Definition xml.c:1310
gboolean add_message_xml(xmlNode *msg, const char *field, xmlNode *xml)
Definition messages.c:160
xmlNode * string2xml(const char *input)
Definition xml.c:831
void purge_diff_markers(xmlNode *a_node)
Definition patchset.c:1181
xmlDoc * getDocPtr(xmlNode *node)
Definition xml.c:647
bool xml_tracking_changes(xmlNode *xml)
Definition xml.c:285
xmlNode * stdin2xml(void)
Definition xml.c:892
int write_xml_file(xmlNode *xml_node, const char *filename, gboolean compress)
Write XML to a file.
Definition xml.c:1265
void crm_xml_cleanup(void)
Definition xml.c:2584
bool xml_document_dirty(xmlNode *xml)
Definition xml.c:292
char * calculate_xml_versioned_digest(xmlNode *input, gboolean sort, gboolean do_filter, const char *version)
Calculate and return digest of XML tree.
Definition digest.c:167
xmlNode * pcmk_create_html_node(xmlNode *parent, const char *element_name, const char *id, const char *class_name, const char *text)
Definition xml.c:714
void xml_track_changes(xmlNode *xml, const char *user, xmlNode *acl_source, bool enforce_acls)
Definition xml.c:270
void xml_calculate_significant_changes(xmlNode *old_xml, xmlNode *new_xml)
Definition xml.c:2095
void free_xml(xmlNode *child)
Definition xml.c:813
void crm_xml_sanitize_id(char *id)
Sanitize a string so it is usable as an XML ID.
Definition xml.c:1094
xmlNode * get_xpath_object_relative(const char *xpath, xmlNode *xml_obj, int error_level)
Definition xpath.c:192
xmlNode * find_xml_node(const xmlNode *root, const char *search_path, gboolean must_find)
Definition xml.c:404
xmlNode * diff_xml_object(xmlNode *left, xmlNode *right, gboolean suppress)
Definition patchset.c:1195
gboolean validate_xml(xmlNode *xml_blob, const char *validation, gboolean to_logs)
Definition schemas.c:707
xmlNode * xml_create_patchset(int format, xmlNode *source, xmlNode *target, bool *config, bool manage_version)
Definition patchset.c:319
gboolean can_prune_leaf(xmlNode *xml_node)
Definition xml.c:2117
xmlNode * add_node_copy(xmlNode *new_parent, xmlNode *xml_node)
Definition xml.c:663
xmlNode * get_message_xml(const xmlNode *msg, const char *field)
Definition messages.c:154
void pcmk_free_xml_subtree(xmlNode *xml)
Definition xml.c:736
xmlNode * copy_xml(xmlNode *src_node)
Definition xml.c:819
xmlNode * create_xml_node(xmlNode *parent, const char *name)
Definition xml.c:677
void xml_remove_prop(xmlNode *obj, const char *name)
Definition xml.c:1735
void expand_plus_plus(xmlNode *target, const char *name, const char *value)
Update current XML attribute value per parsed integer assignment statement.
Definition xml.c:548
void save_xml_to_file(xmlNode *xml, const char *desc, const char *filename)
Definition xml.c:1753
xmlNode * sorted_xml(xmlNode *input, xmlNode *parent, gboolean recursive)
Definition xml.c:2489
char * calculate_operation_digest(xmlNode *local_cib, const char *version)
Calculate and return digest of XML operation.
Definition digest.c:150
xmlNode * subtract_xml_object(xmlNode *parent, xmlNode *left, xmlNode *right, gboolean full, gboolean *changed, const char *marker)
Definition patchset.c:1244
int find_xml_children(xmlNode **children, xmlNode *root, const char *tag, const char *field, const char *value, gboolean search_matches)
Definition xml.c:2374
Deprecated Pacemaker XML API.