summaryrefslogtreecommitdiffstats
path: root/daemons/controld/controld_cib.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 06:53:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 06:53:20 +0000
commite5a812082ae033afb1eed82c0f2df3d0f6bdc93f (patch)
treea6716c9275b4b413f6c9194798b34b91affb3cc7 /daemons/controld/controld_cib.h
parentInitial commit. (diff)
downloadpacemaker-e5a812082ae033afb1eed82c0f2df3d0f6bdc93f.tar.xz
pacemaker-e5a812082ae033afb1eed82c0f2df3d0f6bdc93f.zip
Adding upstream version 2.1.6.upstream/2.1.6
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'daemons/controld/controld_cib.h')
-rw-r--r--daemons/controld/controld_cib.h125
1 files changed, 125 insertions, 0 deletions
diff --git a/daemons/controld/controld_cib.h b/daemons/controld/controld_cib.h
new file mode 100644
index 0000000..bd9492a
--- /dev/null
+++ b/daemons/controld/controld_cib.h
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2004-2023 the Pacemaker project contributors
+ *
+ * The version control history for this file may have further details.
+ *
+ * This source code is licensed under the GNU Lesser General Public License
+ * version 2.1 or later (LGPLv2.1+) WITHOUT ANY WARRANTY.
+ */
+
+#ifndef PCMK__CONTROLD_CIB__H
+#define PCMK__CONTROLD_CIB__H
+
+#include <crm_internal.h>
+
+#include <glib.h>
+
+#include <crm/crm.h>
+#include <crm/common/xml.h>
+#include <crm/cib/internal.h> // PCMK__CIB_REQUEST_MODIFY
+#include "controld_globals.h" // controld_globals.cib_conn
+
+static inline void
+fsa_cib_anon_update(const char *section, xmlNode *data) {
+ if (controld_globals.cib_conn == NULL) {
+ crm_err("No CIB connection available");
+ } else {
+ controld_globals.cib_conn->cmds->modify(controld_globals.cib_conn,
+ section, data,
+ cib_scope_local|cib_can_create);
+ }
+}
+
+static inline void
+fsa_cib_anon_update_discard_reply(const char *section, xmlNode *data) {
+ if (controld_globals.cib_conn == NULL) {
+ crm_err("No CIB connection available");
+ } else {
+ controld_globals.cib_conn->cmds->modify(controld_globals.cib_conn,
+ section, data,
+ cib_scope_local
+ |cib_can_create
+ |cib_discard_reply);
+ }
+}
+
+void controld_record_cib_replace_call(int call_id);
+bool controld_forget_cib_replace_call(int call_id);
+void controld_forget_all_cib_replace_calls(void);
+void controld_destroy_cib_replacements_table(void);
+
+int controld_update_cib(const char *section, xmlNode *data, int options,
+ void (*callback)(xmlNode *, int, int, xmlNode *,
+ void *));
+unsigned int cib_op_timeout(void);
+
+// Subsections of node_state
+enum controld_section_e {
+ controld_section_lrm,
+ controld_section_lrm_unlocked,
+ controld_section_attrs,
+ controld_section_all,
+ controld_section_all_unlocked
+};
+
+void controld_delete_node_state(const char *uname,
+ enum controld_section_e section, int options);
+int controld_delete_resource_history(const char *rsc_id, const char *node,
+ const char *user_name, int call_options);
+
+/* Convenience macro for registering a CIB callback
+ * (assumes that data can be freed with free())
+ */
+# define fsa_register_cib_callback(id, data, fn) do { \
+ cib_t *cib_conn = controld_globals.cib_conn; \
+ \
+ CRM_ASSERT(cib_conn != NULL); \
+ cib_conn->cmds->register_callback_full(cib_conn, id, cib_op_timeout(), \
+ FALSE, data, #fn, fn, free); \
+ } while(0)
+
+void controld_add_resource_history_xml_as(const char *func, xmlNode *parent,
+ const lrmd_rsc_info_t *rsc,
+ lrmd_event_data_t *op,
+ const char *node_name);
+
+#define controld_add_resource_history_xml(parent, rsc, op, node_name) \
+ controld_add_resource_history_xml_as(__func__, (parent), (rsc), \
+ (op), (node_name))
+
+bool controld_record_pending_op(const char *node_name,
+ const lrmd_rsc_info_t *rsc,
+ lrmd_event_data_t *op);
+
+void controld_update_resource_history(const char *node_name,
+ const lrmd_rsc_info_t *rsc,
+ lrmd_event_data_t *op, time_t lock_time);
+
+void controld_delete_action_history(const lrmd_event_data_t *op);
+
+void controld_cib_delete_last_failure(const char *rsc_id, const char *node,
+ const char *action, guint interval_ms);
+
+void controld_delete_action_history_by_key(const char *rsc_id, const char *node,
+ const char *key, int call_id);
+
+void controld_disconnect_cib_manager(void);
+
+int crmd_cib_smart_opt(void);
+
+/*!
+ * \internal
+ * \brief Check whether an action type should be recorded in the CIB
+ *
+ * \param[in] action Action type
+ *
+ * \return true if action should be recorded, false otherwise
+ */
+static inline bool
+controld_action_is_recordable(const char *action)
+{
+ return !pcmk__str_any_of(action, CRMD_ACTION_CANCEL, CRMD_ACTION_DELETE,
+ CRMD_ACTION_NOTIFY, CRMD_ACTION_METADATA, NULL);
+}
+
+#endif // PCMK__CONTROLD_CIB__H