1 /* 2 * Copyright 2004-2024 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_CIB_CIB_TYPES__H 11 # define PCMK__CRM_CIB_CIB_TYPES__H 12 13 # include <glib.h> // gboolean, GList 14 # include <libxml/tree.h> // xmlNode 15 # include <crm/common/ipc.h> 16 # include <crm/common/xml.h> 17 18 #ifdef __cplusplus 19 extern "C" { 20 #endif 21 22 /** 23 * \file 24 * \brief Data types for Cluster Information Base access 25 * \ingroup cib 26 */ 27 28 enum cib_variant { 29 cib_undefined = 0, 30 cib_native = 1, 31 cib_file = 2, 32 cib_remote = 3, 33 }; 34 35 enum cib_state { 36 // NOTE: sbd (as of at least 1.5.2) uses this value 37 cib_connected_command, 38 39 // NOTE: sbd (as of at least 1.5.2) uses this value 40 cib_connected_query, 41 42 cib_disconnected 43 }; 44 45 enum cib_conn_type { 46 cib_command, 47 48 // NOTE: sbd (as of at least 1.5.2) uses this value 49 cib_query, 50 51 cib_no_connection, 52 cib_command_nonblocking, 53 }; 54 55 enum cib_call_options { 56 cib_none = 0, 57 cib_verbose = (1 << 0), //!< Prefer stderr to logs 58 cib_xpath = (1 << 1), 59 cib_multiple = (1 << 2), 60 cib_can_create = (1 << 3), 61 cib_discard_reply = (1 << 4), 62 cib_no_children = (1 << 5), 63 cib_xpath_address = (1 << 6), 64 65 #if !defined(PCMK_ALLOW_DEPRECATED) || (PCMK_ALLOW_DEPRECATED == 1) 66 // NOTE: sbd (as of at least 1.5.2) uses this value 67 //! \deprecated This value will be removed in a future release 68 cib_scope_local = (1 << 8), 69 #endif // !defined(PCMK_ALLOW_DEPRECATED) || (PCMK_ALLOW_DEPRECATED == 1) 70 71 cib_dryrun = (1 << 9), 72 73 /*! 74 * \brief Process request when the client commits the active transaction 75 * 76 * Add the request to the client's active transaction instead of processing 77 * it immediately. If the client has no active transaction, or if the 78 * request is not supported in transactions, the call will fail. 79 * 80 * The request is added to the transaction synchronously, and the return 81 * value indicates whether it was added successfully. 82 * 83 * Refer to \p cib_api_operations_t:init_transaction() and 84 * \p cib_api_operations_t:end_transaction() for more details on CIB 85 * transactions. 86 */ 87 cib_transaction = (1 << 10), 88 89 /*! 90 * \brief Treat new attribute values as atomic score updates where possible 91 * 92 * This option takes effect when updating XML attributes. For an attribute 93 * named \c "name", if the new value is \c "name++" or \c "name+=X" for some 94 * score \c X, the new value is set as follows: 95 * * If attribute \c "name" is not already set to some value in the element 96 * being updated, the new value is set as a literal string. 97 * * If the new value is \c "name++", then the attribute is set to its 98 * existing value (parsed as a score) plus 1. 99 * * If the new value is \c "name+=X" for some score \c X, then the 100 * attribute is set to its existing value plus \c X, where the existing 101 * value and \c X are parsed and added as scores. 102 * 103 * Scores are integer values capped at \c INFINITY and \c -INFINITY. Refer 104 * to Pacemaker Explained and to the \c pcmk_parse_score() function for more 105 * details on scores, including how they're parsed and added. 106 * 107 * Note: This is implemented only for modify operations. 108 */ 109 cib_score_update = (1 << 11), 110 111 // NOTE: sbd (as of at least 1.5.2) uses this value 112 cib_sync_call = (1 << 12), 113 114 cib_no_mtime = (1 << 13), 115 cib_inhibit_notify = (1 << 16), 116 cib_force_diff = (1 << 28), 117 }; 118 119 typedef struct cib_s cib_t; 120 121 typedef struct cib_api_operations_s { 122 // NOTE: sbd (as of at least 1.5.2) uses this 123 // @COMPAT At compatibility break, drop name (always use crm_system_name) 124 int (*signon) (cib_t *cib, const char *name, enum cib_conn_type type); 125 126 // NOTE: sbd (as of at least 1.5.2) uses this 127 int (*signoff) (cib_t *cib); 128 129 int (*free) (cib_t *cib); 130 131 // NOTE: sbd (as of at least 1.5.2) uses this 132 int (*add_notify_callback) (cib_t *cib, const char *event, 133 void (*callback) (const char *event, 134 xmlNode *msg)); 135 136 // NOTE: sbd (as of at least 1.5.2) uses this 137 int (*del_notify_callback) (cib_t *cib, const char *event, 138 void (*callback) (const char *event, 139 xmlNode *msg)); 140 // NOTE: sbd (as of at least 1.5.2) uses this 141 int (*set_connection_dnotify) (cib_t *cib, 142 void (*dnotify) (gpointer user_data)); 143 144 // NOTE: sbd (as of at least 1.5.2) uses this 145 //! \deprecated This method will be removed and should not be used 146 int (*noop) (cib_t *cib, int call_options); 147 148 int (*ping) (cib_t *cib, xmlNode **output_data, int call_options); 149 150 // NOTE: sbd (as of at least 1.5.2) uses this 151 int (*query) (cib_t *cib, const char *section, xmlNode **output_data, 152 int call_options); 153 154 int (*query_from) (cib_t *cib, const char *host, const char *section, 155 xmlNode **output_data, int call_options); 156 157 int (*sync) (cib_t *cib, const char *section, int call_options); 158 int (*sync_from) (cib_t *cib, const char *host, const char *section, 159 int call_options); 160 int (*upgrade) (cib_t *cib, int call_options); 161 int (*bump_epoch) (cib_t *cib, int call_options); 162 163 /*! 164 * The \c <failed> element in the reply to a failed creation call is 165 * deprecated since 2.1.8. 166 */ 167 int (*create) (cib_t *cib, const char *section, xmlNode *data, 168 int call_options); 169 int (*modify) (cib_t *cib, const char *section, xmlNode *data, 170 int call_options); 171 172 int (*replace) (cib_t *cib, const char *section, xmlNode *data, 173 int call_options); 174 int (*remove) (cib_t *cib, const char *section, xmlNode *data, 175 int call_options); 176 int (*erase) (cib_t *cib, xmlNode **output_data, int call_options); 177 178 int (*register_notification) (cib_t *cib, const char *callback, 179 int enabled); 180 gboolean (*register_callback) (cib_t *cib, int call_id, int timeout, 181 gboolean only_success, void *user_data, 182 const char *callback_name, 183 void (*callback) (xmlNode*, int, int, 184 xmlNode*, void *)); 185 gboolean (*register_callback_full)(cib_t *cib, int call_id, int timeout, 186 gboolean only_success, void *user_data, 187 const char *callback_name, 188 void (*callback)(xmlNode *, int, int, 189 xmlNode *, void *), 190 void (*free_func)(void *)); 191 192 /*! 193 * \brief Set the local CIB manager as the cluster's primary instance 194 * 195 * \param[in,out] cib CIB connection 196 * \param[in] call_options Group of enum cib_call_options flags 197 * 198 * \return Legacy Pacemaker return code (in particular, pcmk_ok on success) 199 */ 200 int (*set_primary)(cib_t *cib, int call_options); 201 202 /*! 203 * \brief Set the local CIB manager as a secondary instance 204 * 205 * \param[in,out] cib CIB connection 206 * \param[in] call_options Group of enum cib_call_options flags 207 * 208 * \return Legacy Pacemaker return code (in particular, pcmk_ok on success) 209 */ 210 int (*set_secondary)(cib_t *cib, int call_options); 211 212 /*! 213 * \brief Get the given CIB connection's unique client identifier(s) 214 * 215 * These can be used to check whether this client requested the action that 216 * triggered a CIB notification. 217 * 218 * \param[in] cib CIB connection 219 * \param[out] async_id If not \p NULL, where to store asynchronous client 220 * ID 221 * \param[out] sync_id If not \p NULL, where to store synchronous client 222 * ID 223 * 224 * \return Legacy Pacemaker return code 225 * 226 * \note Some variants may have only one client for both asynchronous and 227 * synchronous requests. 228 */ 229 int (*client_id)(const cib_t *cib, const char **async_id, 230 const char **sync_id); 231 232 /*! 233 * \brief Initiate an atomic CIB transaction for this client 234 * 235 * If the client has initiated a transaction and a new request's call 236 * options contain \p cib_transaction, the new request is appended to the 237 * transaction for later processing. 238 * 239 * Supported requests are those that meet the following conditions: 240 * * can be processed synchronously (with any changes applied to a working 241 * CIB copy) 242 * * are not queries 243 * * do not involve other nodes 244 * * do not affect the state of the CIB manager itself 245 * 246 * Currently supported CIB API functions include: 247 * * \p bump_epoch() 248 * * \p create() 249 * * \p erase() 250 * * \p modify() 251 * * \p remove() 252 * * \p replace() 253 * * \p upgrade() 254 * 255 * Because the transaction is atomic, individual requests do not trigger 256 * callbacks or notifications when they are processed, and they do not 257 * receive output XML. The commit request itself can trigger callbacks and 258 * notifications if any are registered. 259 * 260 * An \c init_transaction() call is always synchronous. 261 * 262 * \param[in,out] cib CIB connection 263 * 264 * \return Legacy Pacemaker return code 265 */ 266 int (*init_transaction)(cib_t *cib); 267 268 /*! 269 * \brief End and optionally commit this client's CIB transaction 270 * 271 * When a client commits a transaction, all requests in the transaction are 272 * processed in a FIFO manner until either a request fails or all requests 273 * have been processed. Changes are applied to a working copy of the CIB. 274 * If a request fails, the transaction and working CIB copy are discarded, 275 * and an error is returned. If all requests succeed, the working CIB copy 276 * replaces the initial CIB copy. 277 * 278 * Callbacks and notifications can be triggered by the commit request itself 279 * but not by the individual requests in a transaction. 280 * 281 * An \c end_transaction() call with \p commit set to \c false is always 282 * synchronous. 283 * 284 * \param[in,out] cib CIB connection 285 * \param[in] commit If \p true, commit transaction; otherwise, 286 * discard it 287 * \param[in] call_options Group of <tt>enum cib_call_options</tt> 288 * flags 289 * 290 * \return Legacy Pacemaker return code 291 */ 292 int (*end_transaction)(cib_t *cib, bool commit, int call_options); 293 294 /*! 295 * \brief Set the user as whom all CIB requests via methods will be executed 296 * 297 * By default, the value of the \c CIB_user environment variable is used if 298 * set. Otherwise, the current effective user is used. 299 * 300 * \param[in,out] cib CIB connection 301 * \param[in] user Name of user whose permissions to use when 302 * processing requests 303 */ 304 void (*set_user)(cib_t *cib, const char *user); 305 306 int (*fetch_schemas)(cib_t *cib, xmlNode **output_data, const char *after_ver, 307 int call_options); 308 } cib_api_operations_t; 309 310 struct cib_s { 311 // NOTE: sbd (as of at least 1.5.2) uses this 312 enum cib_state state; 313 314 enum cib_conn_type type; 315 enum cib_variant variant; 316 317 int call_id; 318 int call_timeout; 319 void *variant_opaque; 320 void *delegate_fn; 321 322 GList *notify_list; 323 324 // NOTE: sbd (as of at least 1.5.2) uses this 325 cib_api_operations_t *cmds; 326 327 xmlNode *transaction; 328 329 char *user; 330 }; 331 332 #ifdef __cplusplus 333 } 334 #endif 335 336 #endif // PCMK__CRM_CIB_CIB_TYPES__H