Blame SOURCES/014-feature-set.patch

23c78e
From 0700a4814a598d0e2e9bd54f970c6d3ff66184df Mon Sep 17 00:00:00 2001
23c78e
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
23c78e
Date: Tue, 24 Nov 2020 16:17:34 +0100
23c78e
Subject: [PATCH 1/2] Refactor: move stonith__register_messages() call from
23c78e
 pcmk__out_prologue() to the calling functions
23c78e
23c78e
---
23c78e
 lib/pacemaker/pcmk_fence.c  | 14 ++++++++++++++
23c78e
 lib/pacemaker/pcmk_output.c |  1 -
23c78e
 2 files changed, 14 insertions(+), 1 deletion(-)
23c78e
23c78e
diff --git a/lib/pacemaker/pcmk_fence.c b/lib/pacemaker/pcmk_fence.c
23c78e
index 7beedff..d591379 100644
23c78e
--- a/lib/pacemaker/pcmk_fence.c
23c78e
+++ b/lib/pacemaker/pcmk_fence.c
23c78e
@@ -247,6 +247,8 @@ pcmk_fence_history(xmlNodePtr *xml, stonith_t *st, char *target, unsigned int ti
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
+    stonith__register_messages(out);
23c78e
+
23c78e
     out->quiet = quiet;
23c78e
 
23c78e
     rc = pcmk__fence_history(out, st, target, timeout, verbose, broadcast, cleanup);
23c78e
@@ -287,6 +289,8 @@ pcmk_fence_installed(xmlNodePtr *xml, stonith_t *st, unsigned int timeout) {
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
+    stonith__register_messages(out);
23c78e
+
23c78e
     rc = pcmk__fence_installed(out, st, timeout);
23c78e
     pcmk__out_epilogue(out, xml, rc);
23c78e
     return rc;
23c78e
@@ -321,6 +325,8 @@ pcmk_fence_last(xmlNodePtr *xml, const char *target, bool as_nodeid) {
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
+    stonith__register_messages(out);
23c78e
+
23c78e
     rc = pcmk__fence_last(out, target, as_nodeid);
23c78e
     pcmk__out_epilogue(out, xml, rc);
23c78e
     return rc;
23c78e
@@ -364,6 +370,8 @@ pcmk_fence_list_targets(xmlNodePtr *xml, stonith_t *st, const char *device_id,
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
+    stonith__register_messages(out);
23c78e
+
23c78e
     rc = pcmk__fence_list_targets(out, st, device_id, timeout);
23c78e
     pcmk__out_epilogue(out, xml, rc);
23c78e
     return rc;
23c78e
@@ -398,6 +406,8 @@ pcmk_fence_metadata(xmlNodePtr *xml, stonith_t *st, char *agent,
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
+    stonith__register_messages(out);
23c78e
+
23c78e
     rc = pcmk__fence_metadata(out, st, agent, timeout);
23c78e
     pcmk__out_epilogue(out, xml, rc);
23c78e
     return rc;
23c78e
@@ -442,6 +452,8 @@ pcmk_fence_registered(xmlNodePtr *xml, stonith_t *st, char *target,
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
+    stonith__register_messages(out);
23c78e
+
23c78e
     rc = pcmk__fence_registered(out, st, target, timeout);
23c78e
     pcmk__out_epilogue(out, xml, rc);
23c78e
     return rc;
23c78e
@@ -501,6 +513,8 @@ pcmk_fence_validate(xmlNodePtr *xml, stonith_t *st, const char *agent,
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
+    stonith__register_messages(out);
23c78e
+
23c78e
     rc = pcmk__fence_validate(out, st, agent, id, params, timeout);
23c78e
     pcmk__out_epilogue(out, xml, rc);
23c78e
     return rc;
23c78e
diff --git a/lib/pacemaker/pcmk_output.c b/lib/pacemaker/pcmk_output.c
23c78e
index 74a7c59..a637031 100644
23c78e
--- a/lib/pacemaker/pcmk_output.c
23c78e
+++ b/lib/pacemaker/pcmk_output.c
23c78e
@@ -34,7 +34,6 @@ pcmk__out_prologue(pcmk__output_t **out, xmlNodePtr *xml) {
23c78e
         return rc;
23c78e
     }
23c78e
 
23c78e
-    stonith__register_messages(*out);
23c78e
     return rc;
23c78e
 }
23c78e
 
23c78e
-- 
23c78e
1.8.3.1
23c78e
23c78e
23c78e
From 27677a6d03ba42aeb0d6a971df9d9b8861232903 Mon Sep 17 00:00:00 2001
23c78e
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
23c78e
Date: Tue, 24 Nov 2020 16:19:59 +0100
23c78e
Subject: [PATCH 2/2] API: libpacemaker: add public API functions for cluster
23c78e
 queries
23c78e
23c78e
---
23c78e
 include/pacemaker.h                  | 45 +++++++++++++++++++++-
23c78e
 lib/pacemaker/pcmk_cluster_queries.c | 75 ++++++++++++++++++++++++++++++++++++
23c78e
 2 files changed, 118 insertions(+), 2 deletions(-)
23c78e
23c78e
diff --git a/include/pacemaker.h b/include/pacemaker.h
23c78e
index a1e76d0..b2a73cd 100644
23c78e
--- a/include/pacemaker.h
23c78e
+++ b/include/pacemaker.h
23c78e
@@ -14,8 +14,6 @@
23c78e
 extern "C" {
23c78e
 #endif
23c78e
 
23c78e
-#ifdef BUILD_PUBLIC_LIBPACEMAKER
23c78e
-
23c78e
 /**
23c78e
  * \file
23c78e
  * \brief High Level API
23c78e
@@ -26,6 +24,49 @@ extern "C" {
23c78e
 #  include <libxml/tree.h>
23c78e
 
23c78e
 /*!
23c78e
+ * \brief Get controller status
23c78e
+ *
23c78e
+ * \param[in,out] xml                The destination for the result, as an XML tree.
23c78e
+ * \param[in]     dest_node          Destination node for request
23c78e
+ * \param[in]     message_timeout_ms Message timeout
23c78e
+ *
23c78e
+ * \return Standard Pacemaker return code
23c78e
+ */
23c78e
+int pcmk_controller_status(xmlNodePtr *xml, char *dest_node, unsigned int message_timeout_ms);
23c78e
+
23c78e
+/*!
23c78e
+ * \brief Get designated controller
23c78e
+ *
23c78e
+ * \param[in,out] xml                The destination for the result, as an XML tree.
23c78e
+ * \param[in]     message_timeout_ms Message timeout
23c78e
+ *
23c78e
+ * \return Standard Pacemaker return code
23c78e
+ */
23c78e
+int pcmk_designated_controller(xmlNodePtr *xml, unsigned int message_timeout_ms);
23c78e
+
23c78e
+/*!
23c78e
+ * \brief Get pacemakerd status
23c78e
+ *
23c78e
+ * \param[in,out] xml                The destination for the result, as an XML tree.
23c78e
+ * \param[in]     ipc_name           IPC name for request
23c78e
+ * \param[in]     message_timeout_ms Message timeout
23c78e
+ *
23c78e
+ * \return Standard Pacemaker return code
23c78e
+ */
23c78e
+int pcmk_pacemakerd_status(xmlNodePtr *xml, char *ipc_name, unsigned int message_timeout_ms);
23c78e
+
23c78e
+#ifdef BUILD_PUBLIC_LIBPACEMAKER
23c78e
+
23c78e
+/*!
23c78e
+ * \brief Get nodes list
23c78e
+ *
23c78e
+ * \param[in,out] xml                The destination for the result, as an XML tree.
23c78e
+ *
23c78e
+ * \return Standard Pacemaker return code
23c78e
+ */
23c78e
+int pcmk_list_nodes(xmlNodePtr *xml);
23c78e
+
23c78e
+/*!
23c78e
  * \brief Perform a STONITH action.
23c78e
  *
23c78e
  * \param[in] st        A connection to the STONITH API.
23c78e
diff --git a/lib/pacemaker/pcmk_cluster_queries.c b/lib/pacemaker/pcmk_cluster_queries.c
23c78e
index 8d729eb..c705b7f 100644
23c78e
--- a/lib/pacemaker/pcmk_cluster_queries.c
23c78e
+++ b/lib/pacemaker/pcmk_cluster_queries.c
23c78e
@@ -1,6 +1,7 @@
23c78e
 #include <glib.h>               // gboolean, GMainLoop, etc.
23c78e
 #include <libxml/tree.h>        // xmlNode
23c78e
 
23c78e
+#include <pacemaker.h>
23c78e
 #include <pacemaker-internal.h>
23c78e
 
23c78e
 #include <crm/crm.h>
23c78e
@@ -282,6 +283,24 @@ pcmk__controller_status(pcmk__output_t *out, char *dest_node, guint message_time
23c78e
 }
23c78e
 
23c78e
 int
23c78e
+pcmk_controller_status(xmlNodePtr *xml, char *dest_node, unsigned int message_timeout_ms)
23c78e
+{
23c78e
+    pcmk__output_t *out = NULL;
23c78e
+    int rc = pcmk_rc_ok;
23c78e
+
23c78e
+    rc = pcmk__out_prologue(&out, xml);
23c78e
+    if (rc != pcmk_rc_ok) {
23c78e
+        return rc;
23c78e
+    }
23c78e
+
23c78e
+    pcmk__register_lib_messages(out);
23c78e
+
23c78e
+    rc = pcmk__controller_status(out, dest_node, (guint) message_timeout_ms);
23c78e
+    pcmk__out_epilogue(out, xml, rc);
23c78e
+    return rc;
23c78e
+}
23c78e
+
23c78e
+int
23c78e
 pcmk__designated_controller(pcmk__output_t *out, guint message_timeout_ms)
23c78e
 {
23c78e
     data_t data = {
23c78e
@@ -309,6 +328,24 @@ pcmk__designated_controller(pcmk__output_t *out, guint message_timeout_ms)
23c78e
 }
23c78e
 
23c78e
 int
23c78e
+pcmk_designated_controller(xmlNodePtr *xml, unsigned int message_timeout_ms)
23c78e
+{
23c78e
+    pcmk__output_t *out = NULL;
23c78e
+    int rc = pcmk_rc_ok;
23c78e
+
23c78e
+    rc = pcmk__out_prologue(&out, xml);
23c78e
+    if (rc != pcmk_rc_ok) {
23c78e
+        return rc;
23c78e
+    }
23c78e
+
23c78e
+    pcmk__register_lib_messages(out);
23c78e
+
23c78e
+    rc = pcmk__designated_controller(out, (guint) message_timeout_ms);
23c78e
+    pcmk__out_epilogue(out, xml, rc);
23c78e
+    return rc;
23c78e
+}
23c78e
+
23c78e
+int
23c78e
 pcmk__pacemakerd_status(pcmk__output_t *out, char *ipc_name, guint message_timeout_ms)
23c78e
 {
23c78e
     data_t data = {
23c78e
@@ -335,6 +372,24 @@ pcmk__pacemakerd_status(pcmk__output_t *out, char *ipc_name, guint message_timeo
23c78e
     return data.rc;
23c78e
 }
23c78e
 
23c78e
+int
23c78e
+pcmk_pacemakerd_status(xmlNodePtr *xml, char *ipc_name, unsigned int message_timeout_ms)
23c78e
+{
23c78e
+    pcmk__output_t *out = NULL;
23c78e
+    int rc = pcmk_rc_ok;
23c78e
+
23c78e
+    rc = pcmk__out_prologue(&out, xml);
23c78e
+    if (rc != pcmk_rc_ok) {
23c78e
+        return rc;
23c78e
+    }
23c78e
+
23c78e
+    pcmk__register_lib_messages(out);
23c78e
+
23c78e
+    rc = pcmk__pacemakerd_status(out, ipc_name, (guint) message_timeout_ms);
23c78e
+    pcmk__out_epilogue(out, xml, rc);
23c78e
+    return rc;
23c78e
+}
23c78e
+
23c78e
 // \return Standard Pacemaker return code
23c78e
 int
23c78e
 pcmk__list_nodes(pcmk__output_t *out, gboolean BASH_EXPORT)
23c78e
@@ -361,6 +416,26 @@ pcmk__list_nodes(pcmk__output_t *out, gboolean BASH_EXPORT)
23c78e
     return pcmk_legacy2rc(rc);
23c78e
 }
23c78e
 
23c78e
+#ifdef BUILD_PUBLIC_LIBPACEMAKER
23c78e
+int
23c78e
+pcmk_list_nodes(xmlNodePtr *xml)
23c78e
+{
23c78e
+    pcmk__output_t *out = NULL;
23c78e
+    int rc = pcmk_rc_ok;
23c78e
+
23c78e
+    rc = pcmk__out_prologue(&out, xml);
23c78e
+    if (rc != pcmk_rc_ok) {
23c78e
+        return rc;
23c78e
+    }
23c78e
+
23c78e
+    pcmk__register_lib_messages(out);
23c78e
+
23c78e
+    rc = pcmk__list_nodes(out, FALSE);
23c78e
+    pcmk__out_epilogue(out, xml, rc);
23c78e
+    return rc;
23c78e
+}
23c78e
+#endif
23c78e
+
23c78e
 // remove when parameters removed from tools/crmadmin.c
23c78e
 int
23c78e
 pcmk__shutdown_controller(pcmk__output_t *out, char *dest_node)
23c78e
-- 
23c78e
1.8.3.1
23c78e