pacemaker 2.1.5-a3f44794f94
Scalable High-Availability cluster resource manager
crmcommon_private.h
Go to the documentation of this file.
1/*
2 * Copyright 2018-2022 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 CRMCOMMON_PRIVATE__H
11# define 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#include <glib.h> // GList
21#include <libxml/tree.h> // xmlNode, xmlAttr
22#include <qb/qbipcc.h> // struct qb_ipc_response_header
23
24// Decent chunk size for processing large amounts of data
25#define PCMK__BUFFER_SIZE 4096
26
27#if defined(PCMK__UNIT_TESTING)
28#undef G_GNUC_INTERNAL
29#define G_GNUC_INTERNAL
30#endif
31
32/* When deleting portions of an XML tree, we keep a record so we can know later
33 * (e.g. when checking differences) that something was deleted.
34 */
35typedef struct pcmk__deleted_xml_s {
36 char *path;
39
40typedef struct xml_node_private_s {
41 long check;
42 uint32_t flags;
44
45typedef struct xml_doc_private_s {
46 long check;
47 uint32_t flags;
48 char *user;
49 GList *acls;
50 GList *deleted_objs; // List of pcmk__deleted_xml_t
52
53#define pcmk__set_xml_flags(xml_priv, flags_to_set) do { \
54 (xml_priv)->flags = pcmk__set_flags_as(__func__, __LINE__, \
55 LOG_NEVER, "XML", "XML node", (xml_priv)->flags, \
56 (flags_to_set), #flags_to_set); \
57 } while (0)
58
59#define pcmk__clear_xml_flags(xml_priv, flags_to_clear) do { \
60 (xml_priv)->flags = pcmk__clear_flags_as(__func__, __LINE__, \
61 LOG_NEVER, "XML", "XML node", (xml_priv)->flags, \
62 (flags_to_clear), #flags_to_clear); \
63 } while (0)
64
65G_GNUC_INTERNAL
66void pcmk__xml2text(xmlNodePtr data, int options, GString *buffer, int depth);
67
68G_GNUC_INTERNAL
69bool pcmk__tracking_xml_changes(xmlNode *xml, bool lazy);
70
71G_GNUC_INTERNAL
72void pcmk__mark_xml_created(xmlNode *xml);
73
74G_GNUC_INTERNAL
75int pcmk__xml_position(const xmlNode *xml,
76 enum xml_private_flags ignore_if_set);
77
78G_GNUC_INTERNAL
79xmlNode *pcmk__xml_match(const xmlNode *haystack, const xmlNode *needle,
80 bool exact);
81
82G_GNUC_INTERNAL
83void pcmk__xml_log(int log_level, const char *file, const char *function,
84 int line, const char *prefix, const xmlNode *data, int depth,
85 int options);
86
87G_GNUC_INTERNAL
88void pcmk__xml_update(xmlNode *parent, xmlNode *target, xmlNode *update,
89 bool as_diff);
90
91G_GNUC_INTERNAL
92xmlNode *pcmk__xc_match(const xmlNode *root, const xmlNode *search_comment,
93 bool exact);
94
95G_GNUC_INTERNAL
96void pcmk__xc_update(xmlNode *parent, xmlNode *target, xmlNode *update);
97
98G_GNUC_INTERNAL
99void pcmk__free_acls(GList *acls);
100
101G_GNUC_INTERNAL
102void pcmk__unpack_acl(xmlNode *source, xmlNode *target, const char *user);
103
104G_GNUC_INTERNAL
105bool pcmk__is_user_in_group(const char *user, const char *group);
106
107G_GNUC_INTERNAL
108void pcmk__apply_acl(xmlNode *xml);
109
110G_GNUC_INTERNAL
111void pcmk__apply_creation_acl(xmlNode *xml, bool check_top);
112
113G_GNUC_INTERNAL
114void pcmk__mark_xml_attr_dirty(xmlAttr *a);
115
116G_GNUC_INTERNAL
117bool pcmk__xa_filterable(const char *name);
118
119static inline const char *
120pcmk__xml_attr_value(const xmlAttr *attr)
121{
122 return ((attr == NULL) || (attr->children == NULL))? NULL
123 : (const char *) attr->children->content;
124}
125
126/*
127 * IPC
128 */
129
130#define PCMK__IPC_VERSION 1
131
132#define PCMK__CONTROLD_API_MAJOR "1"
133#define PCMK__CONTROLD_API_MINOR "0"
134
135// IPC behavior that varies by daemon
136typedef struct pcmk__ipc_methods_s {
146
153 void (*free_data)(void *api_data);
154
170
180 bool (*reply_expected)(pcmk_ipc_api_t *api, xmlNode *request);
181
191 bool (*dispatch)(pcmk_ipc_api_t *api, xmlNode *msg);
192
201
202// Implementation of pcmk_ipc_api_t
204 enum pcmk_ipc_server server; // Daemon this IPC API instance is for
205 enum pcmk_ipc_dispatch dispatch_type; // How replies should be dispatched
206 size_t ipc_size_max; // maximum IPC buffer size
207 crm_ipc_t *ipc; // IPC connection
208 mainloop_io_t *mainloop_io; // If using mainloop, I/O source for IPC
209 bool free_on_disconnect; // Whether disconnect should free object
210 pcmk_ipc_callback_t cb; // Caller-registered callback (if any)
211 void *user_data; // Caller-registered data (if any)
212 void *api_data; // For daemon-specific use
213 pcmk__ipc_methods_t *cmds; // Behavior that varies by daemon
214};
215
216typedef struct pcmk__ipc_header_s {
217 struct qb_ipc_response_header qb;
220 uint32_t flags;
221 uint8_t version;
223
224G_GNUC_INTERNAL
225int pcmk__send_ipc_request(pcmk_ipc_api_t *api, xmlNode *request);
226
227G_GNUC_INTERNAL
229 enum pcmk_ipc_event event_type,
230 crm_exit_t status, void *event_data);
231
232G_GNUC_INTERNAL
233unsigned int pcmk__ipc_buffer_size(unsigned int max);
234
235G_GNUC_INTERNAL
237
238G_GNUC_INTERNAL
240
241G_GNUC_INTERNAL
243
244G_GNUC_INTERNAL
246
247G_GNUC_INTERNAL
249
250
251/*
252 * Logging
253 */
254
290int pcmk__crm_ipc_is_authentic_process(qb_ipcc_connection_t *qb_ipc, int sock,
291 uid_t refuid, gid_t refgid,
292 pid_t *gotpid, uid_t *gotuid,
293 gid_t *gotgid);
294
295
296/*
297 * Utils
298 */
299#define PCMK__PW_BUFFER_LEN 500
300
301
302#endif // CRMCOMMON_PRIVATE__H
const char * parent
Definition: cib.c:25
const char * name
Definition: cib.c:24
char data[0]
Definition: cpg.c:10
G_GNUC_INTERNAL xmlNode * pcmk__xc_match(const xmlNode *root, const xmlNode *search_comment, bool exact)
Definition: xml.c:2569
G_GNUC_INTERNAL void pcmk__apply_acl(xmlNode *xml)
Definition: acl.c:224
struct pcmk__ipc_header_s pcmk__ipc_header_t
G_GNUC_INTERNAL void pcmk__xc_update(xmlNode *parent, xmlNode *target, xmlNode *update)
Definition: xml.c:2618
G_GNUC_INTERNAL void pcmk__xml_update(xmlNode *parent, xmlNode *target, xmlNode *update, bool as_diff)
Definition: xml.c:2649
struct pcmk__ipc_methods_s pcmk__ipc_methods_t
G_GNUC_INTERNAL int pcmk__send_ipc_request(pcmk_ipc_api_t *api, xmlNode *request)
Definition: ipc_client.c:619
G_GNUC_INTERNAL void pcmk__unpack_acl(xmlNode *source, xmlNode *target, const char *user)
Definition: acl.c:288
G_GNUC_INTERNAL bool pcmk__tracking_xml_changes(xmlNode *xml, bool lazy)
Definition: xml.c:49
G_GNUC_INTERNAL void pcmk__free_acls(GList *acls)
Definition: acl.c:44
G_GNUC_INTERNAL unsigned int pcmk__ipc_buffer_size(unsigned int max)
Definition: ipc_common.c:31
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__attrd_api_methods(void)
Definition: ipc_attrd.c:117
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__pacemakerd_api_methods(void)
G_GNUC_INTERNAL void pcmk__mark_xml_attr_dirty(xmlAttr *a)
Definition: xml.c:163
G_GNUC_INTERNAL int pcmk__xml_position(const xmlNode *xml, enum xml_private_flags ignore_if_set)
Definition: xml.c:340
G_GNUC_INTERNAL bool pcmk__valid_ipc_header(const pcmk__ipc_header_t *header)
Definition: ipc_common.c:81
G_GNUC_INTERNAL void pcmk__apply_creation_acl(xmlNode *xml, bool check_top)
Definition: acl.c:571
int pcmk__crm_ipc_is_authentic_process(qb_ipcc_connection_t *qb_ipc, int sock, uid_t refuid, gid_t refgid, pid_t *gotpid, uid_t *gotuid, gid_t *gotgid)
Check the authenticity of the IPC socket peer process.
Definition: ipc_client.c:1364
G_GNUC_INTERNAL void pcmk__mark_xml_created(xmlNode *xml)
Definition: xml.c:145
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
G_GNUC_INTERNAL bool pcmk__xa_filterable(const char *name)
Definition: digest.c:237
G_GNUC_INTERNAL xmlNode * pcmk__xml_match(const xmlNode *haystack, const xmlNode *needle, bool exact)
Definition: xml.c:394
G_GNUC_INTERNAL void pcmk__xml2text(xmlNodePtr data, int options, GString *buffer, int depth)
Definition: xml.c:1982
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__controld_api_methods(void)
Definition: ipc_controld.c:262
G_GNUC_INTERNAL bool pcmk__is_user_in_group(const char *user, const char *group)
Definition: utils.c:54
G_GNUC_INTERNAL pcmk__ipc_methods_t * pcmk__schedulerd_api_methods(void)
G_GNUC_INTERNAL void pcmk__xml_log(int log_level, const char *file, const char *function, int line, const char *prefix, const xmlNode *data, int depth, int options)
Definition: xml.c:1623
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:146
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:111
pcmk_ipc_event
Possible event types that an IPC event callback can be called for.
Definition: ipc.h:80
pcmk_ipc_server
Available IPC interfaces.
Definition: ipc.h:69
pcmk_ipc_dispatch
How IPC replies should be dispatched.
Definition: ipc.h:88
struct crm_ipc_s crm_ipc_t
Definition: ipc.h:165
struct mainloop_io_s mainloop_io_t
Definition: mainloop.h:33
const char * target
Definition: pcmk_fence.c:29
enum crm_exit_e crm_exit_t
struct qb_ipc_response_header qb
int(* new_data)(pcmk_ipc_api_t *api)
void(* free_data)(void *api_data)
bool(* dispatch)(pcmk_ipc_api_t *api, xmlNode *msg)
void(* post_disconnect)(pcmk_ipc_api_t *api)
bool(* reply_expected)(pcmk_ipc_api_t *api, xmlNode *request)
int(* post_connect)(pcmk_ipc_api_t *api)
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
xml_private_flags
Definition: xml_internal.h:320