pacemaker 3.0.1-16e74fc4da
Scalable High-Availability cluster resource manager
Loading...
Searching...
No Matches
crmcommon_private.h
Go to the documentation of this file.
1/*
2 * Copyright 2018-2025 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__COMMON_CRMCOMMON_PRIVATE__H
11#define PCMK__COMMON_CRMCOMMON_PRIVATE__H
12
13/* This header is for the sole use of libcrmcommon, so that functions can be
14 * declared with G_GNUC_INTERNAL for efficiency.
15 */
16
17#include <stdint.h> // uint8_t, uint32_t
18#include <stdbool.h> // bool
19#include <sys/types.h> // size_t
20
21#include <glib.h> // G_GNUC_INTERNAL, G_GNUC_PRINTF, gchar, etc.
22#include <libxml/tree.h> // xmlNode, xmlAttr
23#include <libxml/xmlstring.h> // xmlChar
24#include <qb/qbipcc.h> // struct qb_ipc_response_header
25
26#include <crm/common/ipc.h> // pcmk_ipc_api_t, crm_ipc_t, etc.
27#include <crm/common/iso8601.h> // crm_time_t
28#include <crm/common/logging.h> // LOG_NEVER
29#include <crm/common/mainloop.h> // mainloop_io_t
30#include <crm/common/output_internal.h> // pcmk__output_t
31#include <crm/common/results.h> // crm_exit_t
32#include <crm/common/rules.h> // pcmk_rule_input_t
33#include <crm/common/xml_internal.h> // enum pcmk__xml_flags
34
35#ifdef __cplusplus
36extern "C" {
37#endif
38
39// Decent chunk size for processing large amounts of data
40#define PCMK__BUFFER_SIZE 4096
41
42#if defined(PCMK__UNIT_TESTING)
43#undef G_GNUC_INTERNAL
44#define G_GNUC_INTERNAL
45#endif
46
66
71typedef struct xml_node_private_s {
72 uint32_t check;
73 uint32_t flags;
74 xmlNode *match;
76
81typedef struct xml_doc_private_s {
82 uint32_t check;
83 uint32_t flags;
84 char *acl_user;
85
87 GList *acls;
88
92
93// XML private data magic numbers
94#define PCMK__XML_DOC_PRIVATE_MAGIC 0x81726354UL
95#define PCMK__XML_NODE_PRIVATE_MAGIC 0x54637281UL
96
97// XML entity references
98#define PCMK__XML_ENTITY_AMP "&amp;"
99#define PCMK__XML_ENTITY_GT "&gt;"
100#define PCMK__XML_ENTITY_LT "&lt;"
101#define PCMK__XML_ENTITY_QUOT "&quot;"
102
103#define pcmk__set_xml_flags(xml_priv, flags_to_set) do { \
104 (xml_priv)->flags = pcmk__set_flags_as(__func__, __LINE__, \
105 LOG_NEVER, "XML", "XML node", (xml_priv)->flags, \
106 (flags_to_set), #flags_to_set); \
107 } while (0)
108
109#define pcmk__clear_xml_flags(xml_priv, flags_to_clear) do { \
110 (xml_priv)->flags = pcmk__clear_flags_as(__func__, __LINE__, \
111 LOG_NEVER, "XML", "XML node", (xml_priv)->flags, \
112 (flags_to_clear), #flags_to_clear); \
113 } while (0)
114
115G_GNUC_INTERNAL
116const char *pcmk__xml_element_type_text(xmlElementType type);
117
118G_GNUC_INTERNAL
119bool pcmk__xml_reset_node_flags(xmlNode *xml, void *user_data);
120
121G_GNUC_INTERNAL
122void pcmk__xml_set_parent_flags(xmlNode *xml, uint64_t flags);
123
124G_GNUC_INTERNAL
125void pcmk__xml_new_private_data(xmlNode *xml);
126
127G_GNUC_INTERNAL
128void pcmk__xml_free_private_data(xmlNode *xml);
129
130G_GNUC_INTERNAL
131void pcmk__xml_free_node(xmlNode *xml);
132
133G_GNUC_INTERNAL
134xmlDoc *pcmk__xml_new_doc(void);
135
136G_GNUC_INTERNAL
137int pcmk__xml_position(const xmlNode *xml, enum pcmk__xml_flags ignore_if_set);
138
139G_GNUC_INTERNAL
140bool pcmk__xc_matches(const xmlNode *comment1, const xmlNode *comment2);
141
142G_GNUC_INTERNAL
143void pcmk__xc_update(xmlNode *parent, xmlNode *target, xmlNode *update);
144
145G_GNUC_INTERNAL
146void pcmk__free_acls(GList *acls);
147
148G_GNUC_INTERNAL
149void pcmk__unpack_acl(xmlNode *source, xmlNode *target, const char *user);
150
151G_GNUC_INTERNAL
152bool pcmk__is_user_in_group(const char *user, const char *group);
153
154G_GNUC_INTERNAL
155void pcmk__apply_acl(xmlNode *xml);
156
157G_GNUC_INTERNAL
158void pcmk__apply_creation_acl(xmlNode *xml, bool check_top);
159
160G_GNUC_INTERNAL
161int pcmk__xa_remove(xmlAttr *attr, bool force);
162
163G_GNUC_INTERNAL
164void pcmk__mark_xml_attr_dirty(xmlAttr *a);
165
166G_GNUC_INTERNAL
167bool pcmk__xa_filterable(const char *name);
168
169G_GNUC_INTERNAL
170void pcmk__log_xmllib_err(void *ctx, const char *fmt, ...)
171G_GNUC_PRINTF(2, 3);
172
173G_GNUC_INTERNAL
174void pcmk__mark_xml_node_dirty(xmlNode *xml);
175
176G_GNUC_INTERNAL
177bool pcmk__marked_as_deleted(xmlAttrPtr a, void *user_data);
178
179G_GNUC_INTERNAL
180void pcmk__dump_xml_attr(const xmlAttr *attr, GString *buffer);
181
182G_GNUC_INTERNAL
183int pcmk__xe_set_score(xmlNode *target, const char *name, const char *value);
184
185G_GNUC_INTERNAL
186bool pcmk__xml_is_name_start_char(const char *utf8, int *len);
187
188G_GNUC_INTERNAL
189bool pcmk__xml_is_name_char(const char *utf8, int *len);
190
191/*
192 * Date/times
193 */
194
195// For use with pcmk__add_time_from_xml()
206
207G_GNUC_INTERNAL
208const char *pcmk__time_component_attr(enum pcmk__time_component component);
209
210G_GNUC_INTERNAL
212 const xmlNode *xml);
213
214G_GNUC_INTERNAL
216
217
218/*
219 * IPC
220 */
221
222#define PCMK__IPC_VERSION 1
223
224#define PCMK__CONTROLD_API_MAJOR "1"
225#define PCMK__CONTROLD_API_MINOR "0"
226
227// IPC behavior that varies by daemon
228typedef struct pcmk__ipc_methods_s {
238
245 void (*free_data)(void *api_data);
246
262
272 bool (*reply_expected)(pcmk_ipc_api_t *api, const xmlNode *request);
273
283 bool (*dispatch)(pcmk_ipc_api_t *api, xmlNode *msg);
284
293
294// Implementation of pcmk_ipc_api_t
296 enum pcmk_ipc_server server; // Daemon this IPC API instance is for
297 enum pcmk_ipc_dispatch dispatch_type; // How replies should be dispatched
298 crm_ipc_t *ipc; // IPC connection
299 mainloop_io_t *mainloop_io; // If using mainloop, I/O source for IPC
300 bool free_on_disconnect; // Whether disconnect should free object
301 pcmk_ipc_callback_t cb; // Caller-registered callback (if any)
302 void *user_data; // Caller-registered data (if any)
303 void *api_data; // For daemon-specific use
304 pcmk__ipc_methods_t *cmds; // Behavior that varies by daemon
305};
306
307typedef struct pcmk__ipc_header_s {
308 struct qb_ipc_response_header qb;
309 uint32_t size;
310 uint32_t flags;
311 uint8_t version;
312 uint16_t part_id; // If this is a multipart message, which part is this?
314
315G_GNUC_INTERNAL
316int pcmk__send_ipc_request(pcmk_ipc_api_t *api, const xmlNode *request);
317
318G_GNUC_INTERNAL
320 enum pcmk_ipc_event event_type,
321 crm_exit_t status, void *event_data);
322
323G_GNUC_INTERNAL
325
326G_GNUC_INTERNAL
328
329G_GNUC_INTERNAL
331
332G_GNUC_INTERNAL
334
335G_GNUC_INTERNAL
337
338
339/*
340 * Logging
341 */
342
344#define PCMK__XML_PREFIX_CREATED "++"
345
347#define PCMK__XML_PREFIX_DELETED "--"
348
350#define PCMK__XML_PREFIX_MODIFIED "+ "
351
353#define PCMK__XML_PREFIX_MOVED "+~"
354
355/*
356 * Output
357 */
358G_GNUC_INTERNAL
359int pcmk__bare_output_new(pcmk__output_t **out, const char *fmt_name,
360 const char *filename, char **argv);
361
362G_GNUC_INTERNAL
364
365G_GNUC_INTERNAL
367
368G_GNUC_INTERNAL
370
371/*
372 * Rules
373 */
374
375// How node attribute values may be compared in rules
387
388// How node attribute values may be parsed in rules
396
397// Where to obtain reference value for a node attribute comparison
404
405G_GNUC_INTERNAL
406enum pcmk__comparison pcmk__parse_comparison(const char *op);
407
408G_GNUC_INTERNAL
409enum pcmk__type pcmk__parse_type(const char *type, enum pcmk__comparison op,
410 const char *value1, const char *value2);
411
412G_GNUC_INTERNAL
413enum pcmk__reference_source pcmk__parse_source(const char *source);
414
415G_GNUC_INTERNAL
416int pcmk__cmp_by_type(const char *value1, const char *value2,
417 enum pcmk__type type);
418
419G_GNUC_INTERNAL
420int pcmk__unpack_duration(const xmlNode *duration, const crm_time_t *start,
421 crm_time_t **end);
422
423G_GNUC_INTERNAL
424int pcmk__evaluate_date_spec(const xmlNode *date_spec, const crm_time_t *now);
425
426G_GNUC_INTERNAL
427int pcmk__evaluate_attr_expression(const xmlNode *expression,
428 const pcmk_rule_input_t *rule_input);
429
430G_GNUC_INTERNAL
431int pcmk__evaluate_rsc_expression(const xmlNode *expr,
432 const pcmk_rule_input_t *rule_input);
433
434G_GNUC_INTERNAL
435int pcmk__evaluate_op_expression(const xmlNode *expr,
436 const pcmk_rule_input_t *rule_input);
437
438
439/*
440 * Utils
441 */
442#define PCMK__PW_BUFFER_LEN 500
443
444
445/*
446 * Schemas
447 */
448typedef struct {
449 unsigned char v[2];
451
456
471
472G_GNUC_INTERNAL
473GList *pcmk__find_x_0_schema(void);
474
475#ifdef __cplusplus
476}
477#endif
478
479#endif // PCMK__COMMON_CRMCOMMON_PRIVATE__H
const char * parent
Definition cib.c:27
const char * name
Definition cib.c:26
uint64_t flags
Definition remote.c:3
Scheduler API for rules.
enum pcmk_ipc_server type
Definition cpg.c:3
G_GNUC_INTERNAL int pcmk__xa_remove(xmlAttr *attr, bool force)
Definition xml_attr.c:45
G_GNUC_INTERNAL void pcmk__apply_acl(xmlNode *xml)
Definition acl.c:216
G_GNUC_INTERNAL enum pcmk__reference_source pcmk__parse_source(const char *source)
Definition rules.c:805
G_GNUC_INTERNAL void pcmk__set_time_if_earlier(crm_time_t *target, const crm_time_t *source)
Definition iso8601.c:1461
G_GNUC_INTERNAL xmlDoc * pcmk__xml_new_doc(void)
Definition xml.c:499
@ pcmk__type_integer
@ pcmk__type_unknown
@ pcmk__type_version
@ pcmk__type_number
@ pcmk__type_string
struct pcmk__ipc_header_s pcmk__ipc_header_t
G_GNUC_INTERNAL int pcmk__send_ipc_request(pcmk_ipc_api_t *api, const xmlNode *request)
Definition ipc_client.c:684
G_GNUC_INTERNAL const char * pcmk__xml_element_type_text(xmlElementType type)
Definition xml.c:41
G_GNUC_INTERNAL int pcmk__evaluate_rsc_expression(const xmlNode *expr, const pcmk_rule_input_t *rule_input)
Definition rules.c:1110
G_GNUC_INTERNAL int pcmk__evaluate_date_spec(const xmlNode *date_spec, const crm_time_t *now)
Definition rules.c:155
G_GNUC_INTERNAL bool pcmk__marked_as_deleted(xmlAttrPtr a, void *user_data)
Definition xml_attr.c:89
G_GNUC_INTERNAL void pcmk__xc_update(xmlNode *parent, xmlNode *target, xmlNode *update)
G_GNUC_INTERNAL bool pcmk__xml_reset_node_flags(xmlNode *xml, void *user_data)
Definition xml.c:180
G_GNUC_INTERNAL int pcmk__evaluate_op_expression(const xmlNode *expr, const pcmk_rule_input_t *rule_input)
Definition rules.c:1179
G_GNUC_INTERNAL void pcmk__xml_free_private_data(xmlNode *xml)
Definition xml.c:399
struct pcmk__ipc_methods_s pcmk__ipc_methods_t
G_GNUC_INTERNAL void pcmk__unpack_acl(xmlNode *source, xmlNode *target, const char *user)
Definition acl.c:315
G_GNUC_INTERNAL int pcmk__evaluate_attr_expression(const xmlNode *expression, const pcmk_rule_input_t *rule_input)
Definition rules.c:958
G_GNUC_INTERNAL void pcmk__free_acls(GList *acls)
Definition acl.c:45
G_GNUC_INTERNAL int pcmk__add_time_from_xml(crm_time_t *t, enum pcmk__time_component component, const xmlNode *xml)
Definition iso8601.c:1615
G_GNUC_INTERNAL int pcmk__xe_set_score(xmlNode *target, const char *name, const char *value)
G_GNUC_INTERNAL bool pcmk__xc_matches(const xmlNode *comment1, const xmlNode *comment2)
Definition xml_comment.c:54
G_GNUC_INTERNAL int pcmk__bare_output_new(pcmk__output_t **out, const char *fmt_name, const char *filename, char **argv)
Definition output.c:63
G_GNUC_INTERNAL void pcmk__xml_free_node(xmlNode *xml)
Definition xml.c:716
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__attrd_api_methods(void)
Definition ipc_attrd.c:116
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__pacemakerd_api_methods(void)
G_GNUC_INTERNAL void pcmk__register_option_messages(pcmk__output_t *out)
G_GNUC_INTERNAL bool pcmk__xml_is_name_char(const char *utf8, int *len)
Definition xml.c:611
G_GNUC_INTERNAL bool pcmk__output_text_get_fancy(pcmk__output_t *out)
G_GNUC_INTERNAL void pcmk__xml_set_parent_flags(xmlNode *xml, uint64_t flags)
Definition xml.c:109
pcmk__schema_validator
@ pcmk__schema_validator_rng
@ pcmk__schema_validator_none
G_GNUC_INTERNAL void pcmk__mark_xml_attr_dirty(xmlAttr *a)
Definition xml_attr.c:77
G_GNUC_INTERNAL enum pcmk__comparison pcmk__parse_comparison(const char *op)
Definition rules.c:652
G_GNUC_INTERNAL void pcmk__xml_new_private_data(xmlNode *xml)
Definition xml.c:387
G_GNUC_INTERNAL void pcmk__dump_xml_attr(const xmlAttr *attr, GString *buffer)
Definition xml_attr.c:108
G_GNUC_INTERNAL bool pcmk__valid_ipc_header(const pcmk__ipc_header_t *header)
Definition ipc_common.c:45
G_GNUC_INTERNAL enum pcmk__type pcmk__parse_type(const char *type, enum pcmk__comparison op, const char *value1, const char *value2)
Definition rules.c:694
G_GNUC_INTERNAL void pcmk__register_patchset_messages(pcmk__output_t *out)
pcmk__reference_source
@ pcmk__source_unknown
@ pcmk__source_literal
@ pcmk__source_meta_attrs
@ pcmk__source_instance_attrs
G_GNUC_INTERNAL void pcmk__apply_creation_acl(xmlNode *xml, bool check_top)
Definition acl.c:612
G_GNUC_INTERNAL void G_GNUC_INTERNAL void pcmk__mark_xml_node_dirty(xmlNode *xml)
Definition xml.c:159
G_GNUC_INTERNAL int pcmk__cmp_by_type(const char *value1, const char *value2, enum pcmk__type type)
Definition rules.c:743
G_GNUC_INTERNAL const char * pcmk__time_component_attr(enum pcmk__time_component component)
Definition iso8601.c:1534
struct xml_doc_private_s xml_doc_private_t
struct pcmk__deleted_xml_s pcmk__deleted_xml_t
struct xml_node_private_s xml_node_private_t
pcmk__comparison
@ pcmk__comparison_gt
@ pcmk__comparison_lte
@ pcmk__comparison_unknown
@ pcmk__comparison_ne
@ pcmk__comparison_eq
@ pcmk__comparison_defined
@ pcmk__comparison_gte
@ pcmk__comparison_undefined
@ pcmk__comparison_lt
G_GNUC_INTERNAL bool pcmk__xml_is_name_start_char(const char *utf8, int *len)
Definition xml.c:540
G_GNUC_INTERNAL bool pcmk__xa_filterable(const char *name)
Definition digest.c:232
G_GNUC_INTERNAL int pcmk__xml_position(const xmlNode *xml, enum pcmk__xml_flags ignore_if_set)
Definition xml.c:414
pcmk__time_component
@ pcmk__time_hours
@ pcmk__time_minutes
@ pcmk__time_seconds
@ pcmk__time_days
@ pcmk__time_years
@ pcmk__time_unknown
@ pcmk__time_months
@ pcmk__time_weeks
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__controld_api_methods(void)
G_GNUC_INTERNAL bool pcmk__is_user_in_group(const char *user, const char *group)
Definition utils.c:71
G_GNUC_INTERNAL void pcmk__log_xmllib_err(void *ctx, const char *fmt,...) G_GNUC_PRINTF(2
G_GNUC_INTERNAL GList * pcmk__find_x_0_schema(void)
Definition schemas.c:115
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__schedulerd_api_methods(void)
G_GNUC_INTERNAL int pcmk__unpack_duration(const xmlNode *duration, const crm_time_t *start, crm_time_t **end)
Definition rules.c:246
G_GNUC_INTERNAL void pcmk__call_ipc_callback(pcmk_ipc_api_t *api, enum pcmk_ipc_event event_type, crm_exit_t status, void *event_data)
Definition ipc_client.c:144
IPC interface to Pacemaker daemons.
void(* pcmk_ipc_callback_t)(pcmk_ipc_api_t *api, enum pcmk_ipc_event event_type, crm_exit_t status, void *event_data, void *user_data)
Callback function type for Pacemaker daemon IPC APIs.
Definition ipc.h:98
pcmk_ipc_event
Possible event types that an IPC event callback can be called for.
Definition ipc.h:61
pcmk_ipc_server
Available IPC interfaces.
Definition ipc.h:48
pcmk_ipc_dispatch
How IPC replies should be dispatched.
Definition ipc.h:74
struct crm_ipc_s crm_ipc_t
Definition ipc.h:159
ISO_8601 Date handling.
struct crm_time_s crm_time_t
Definition iso8601.h:32
Wrappers for and extensions to libqb logging.
Wrappers for and extensions to glib mainloop.
struct mainloop_io_s mainloop_io_t
Definition mainloop.h:41
Formatted output for pacemaker tools.
const char * target
Definition pcmk_fence.c:31
Function and executable result codes.
enum crm_exit_e crm_exit_t
Exit status codes for tools and daemons.
int position
Position of the deleted node among its siblings.
gchar * path
XPath expression identifying the deleted node.
struct qb_ipc_response_header qb
int(* new_data)(pcmk_ipc_api_t *api)
bool(* reply_expected)(pcmk_ipc_api_t *api, const xmlNode *request)
void(* free_data)(void *api_data)
bool(* dispatch)(pcmk_ipc_api_t *api, xmlNode *msg)
void(* post_disconnect)(pcmk_ipc_api_t *api)
int(* post_connect)(pcmk_ipc_api_t *api)
This structure contains everything that makes up a single output formatter.
pcmk__schema_version_t version
enum pcmk__schema_validator validator
enum pcmk_ipc_dispatch dispatch_type
mainloop_io_t * mainloop_io
pcmk__ipc_methods_t * cmds
pcmk_ipc_callback_t cb
enum pcmk_ipc_server server
Data used to evaluate a rule (any NULL items are ignored)
Definition rules.h:57
GList * deleted_objs
XML nodes marked as deleted (list of pcmk__deleted_xml_t)
char * acl_user
User affected by acls (for logging)
GList * acls
ACLs to check requested changes against (list of xml_acl_t)
uint32_t check
Magic number for checking integrity.
uint32_t flags
Group of enum pcmk__xml_flags
uint32_t check
Magic number for checking integrity.
uint32_t flags
Group of enum pcmk__xml_flags
xmlNode * match
Pointer to matching node (defined by caller)
pcmk__xml_flags