diff --git a/include/crm/cib.h b/include/crm/cib.h
index b7c81db32d..8fcc257d08 100644
--- a/include/crm/cib.h
+++ b/include/crm/cib.h
@@ -1,66 +1,66 @@
 /*
  * Copyright 2004-2024 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__CRM_CIB__H
 #  define PCMK__CRM_CIB__H
 
 #  include <glib.h>             // gboolean
 #  include <crm/common/ipc.h>
 #  include <crm/common/xml.h>
 #  include <crm/cib/cib_types.h>
 #  include <crm/cib/util.h>
 
 #ifdef __cplusplus
 extern "C" {
 #endif
 
 /**
  * \file
  * \brief Cluster Configuration
  * \ingroup cib
  */
 
 // Use compare_version() for doing comparisons
 #  define CIB_FEATURE_SET "2.0"
 
 /* Core functions */
 
 // NOTE: sbd (as of at least 1.5.2) uses this
 cib_t *cib_new(void);
 
 cib_t *cib_native_new(void);
 cib_t *cib_file_new(const char *filename);
 cib_t *cib_remote_new(const char *server, const char *user, const char *passwd, int port,
                       gboolean encrypted);
 
 cib_t *cib_new_no_shadow(void);
 char *get_shadow_file(const char *name);
 cib_t *cib_shadow_new(const char *name);
 
 void cib_free_notify(cib_t *cib);
 void cib_free_callbacks(cib_t *cib);
 
 // NOTE: sbd (as of at least 1.5.2) uses this
 void cib_delete(cib_t * cib);
 
 void cib_dump_pending_callbacks(void);
 int num_cib_op_callbacks(void);
 void remove_cib_op_callback(int call_id, gboolean all_callbacks);
 
-#  define CIB_LIBRARY "libcib.so.27"
+#define CIB_LIBRARY "libcib.so.54"
 
 #ifdef __cplusplus
 }
 #endif
 
 #if !defined(PCMK_ALLOW_DEPRECATED) || (PCMK_ALLOW_DEPRECATED == 1)
 #include <crm/cib_compat.h>
 #endif
 
 #endif
diff --git a/include/crm/stonith-ng.h b/include/crm/stonith-ng.h
index be84b2bba1..3ae6388573 100644
--- a/include/crm/stonith-ng.h
+++ b/include/crm/stonith-ng.h
@@ -1,715 +1,715 @@
 /*
  * Copyright 2004-2024 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__CRM_STONITH_NG__H
 #  define PCMK__CRM_STONITH_NG__H
 
 #ifdef __cplusplus
 extern "C" {
 #endif
 
 /**
  * \file
  * \brief Fencing aka. STONITH
  * \ingroup fencing
  */
 
 /* IMPORTANT: DLM source code includes this file directly, without having access
  * to other Pacemaker headers on its include path, so this file should *not*
  * include any other Pacemaker headers. (DLM might be updated to avoid the
  * issue, but we should still follow this guideline for a long time after.)
  */
 
 #  include <dlfcn.h>
 #  include <errno.h>
 #  include <stdbool.h>  // bool
 #  include <stdint.h>   // uint32_t
 #  include <time.h>     // time_t
 
 /* *INDENT-OFF* */
 enum stonith_state {
     stonith_connected_command,
     stonith_connected_query,
     stonith_disconnected,
 };
 
 //! Flags that can be set in call options for API requests
 enum stonith_call_options {
     //! No options
     st_opt_none                 = 0,
 
 #if !defined(PCMK_ALLOW_DEPRECATED) || (PCMK_ALLOW_DEPRECATED == 1)
     //! \deprecated Unused
     st_opt_verbose              = (1 << 0),
 #endif
 
     //! The fencing target is allowed to execute the request
     st_opt_allow_self_fencing   = (1 << 1),
 
 #if !defined(PCMK_ALLOW_DEPRECATED) || (PCMK_ALLOW_DEPRECATED == 1)
     //! \deprecated Use st_opt_allow_self_fencing instead
     st_opt_allow_suicide        = st_opt_allow_self_fencing,
 #endif
 
     // Used internally to indicate that request is manual fence confirmation
     //! \internal Do not use
     st_opt_manual_ack           = (1 << 3),
 
     //! Do not return any reply from server
     st_opt_discard_reply        = (1 << 4),
 
     // Used internally to indicate that request requires a fencing topology
     //! \internal Do not use
     st_opt_topology             = (1 << 6),
 
 #if !defined(PCMK_ALLOW_DEPRECATED) || (PCMK_ALLOW_DEPRECATED == 1)
     //! \deprecated Unused
     st_opt_scope_local          = (1 << 8),
 #endif
 
     //! Interpret target as node cluster layer ID instead of name
     st_opt_cs_nodeid            = (1 << 9),
 
     //! Wait for request to be completed before returning
     st_opt_sync_call            = (1 << 12),
 
     //! Request that server send an update with optimal callback timeout
     st_opt_timeout_updates      = (1 << 13),
 
     //! Invoke callback only if request succeeded
     st_opt_report_only_success  = (1 << 14),
 
     //! For a fence history request, request that the history be cleared
     st_opt_cleanup              = (1 << 19),
 
     //! For a fence history request, broadcast the request to all nodes
     st_opt_broadcast            = (1 << 20),
 };
 
 /*! Order matters here, do not change values */
 enum op_state
 {
     st_query,
     st_exec,
     st_done,
     st_duplicate,
     st_failed,
 };
 
 // Supported fence agent interface standards
 enum stonith_namespace {
     st_namespace_invalid,
     st_namespace_any,
     st_namespace_internal,  // Implemented internally by Pacemaker
 
     /* Neither of these projects are active any longer, but the fence agent
      * interfaces they created are still in use and supported by Pacemaker.
      */
     st_namespace_rhcs,      // Red Hat Cluster Suite compatible
     st_namespace_lha,       // Linux-HA compatible
 };
 
 enum stonith_namespace stonith_text2namespace(const char *namespace_s);
 const char *stonith_namespace2text(enum stonith_namespace st_namespace);
 enum stonith_namespace stonith_get_namespace(const char *agent,
                                              const char *namespace_s);
 
 typedef struct stonith_key_value_s {
     char *key;
     char *value;
         struct stonith_key_value_s *next;
 } stonith_key_value_t;
 
 typedef struct stonith_history_s {
     char *target;
     char *action;
     char *origin;
     char *delegate;
     char *client;
     int state;
     time_t completed;
     struct stonith_history_s *next;
     long completed_nsec;
     char *exit_reason;
 } stonith_history_t;
 
 typedef struct stonith_s stonith_t;
 
 typedef struct stonith_event_s {
     char *id;
     char *operation;
     int result;
     char *origin;
     char *target;
     char *action;
     char *executioner;
 
     char *device;
 
     /*! The name of the client that initiated the action. */
     char *client_origin;
 
     //! \internal This field should be treated as internal to Pacemaker
     void *opaque;
 } stonith_event_t;
 
 typedef struct stonith_callback_data_s {
     int rc;
     int call_id;
     void *userdata;
 
     //! \internal This field should be treated as internal to Pacemaker
     void *opaque;
 } stonith_callback_data_t;
 
 typedef struct stonith_api_operations_s
 {
     /*!
      * \brief Destroy a fencer connection
      *
      * \param[in,out] st  Fencer connection to destroy
      */
     int (*free) (stonith_t *st);
 
     /*!
      * \brief Connect to the local fencer
      *
      * \param[in,out] st          Fencer connection to connect
      * \param[in]     name        Client name to use
      * \param[out]    stonith_fd  If NULL, use a main loop, otherwise
      *                            store IPC file descriptor here
      *
      * \return Legacy Pacemaker return code
      */
     int (*connect) (stonith_t *st, const char *name, int *stonith_fd);
 
     /*!
      * \brief Disconnect from the local stonith daemon.
      *
      * \param[in,out] st  Fencer connection to disconnect
      *
      * \return Legacy Pacemaker return code
      */
     int (*disconnect)(stonith_t *st);
 
     /*!
      * \brief Unregister a fence device with the local fencer
      *
      * \param[in,out] st       Fencer connection to disconnect
      * \param[in]     options  Group of enum stonith_call_options
      * \param[in]     name     ID of fence device to unregister
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*remove_device)(stonith_t *st, int options, const char *name);
 
     /*!
      * \brief Register a fence device with the local fencer
      *
      * \param[in,out] st           Fencer connection to use
      * \param[in]     options      Group of enum stonith_call_options
      * \param[in]     id           ID of fence device to register
      * \param[in]     namespace_s  Type of fence agent to search for ("redhat"
      *                             or "stonith-ng" for RHCS-style, "internal"
      *                             for Pacemaker-internal devices, "heartbeat"
      *                             for LHA-style, or "any" or NULL for any)
      * \param[in]     agent        Name of fence agent for device
      * \param[in]     params       Fence agent parameters for device
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*register_device)(stonith_t *st, int options, const char *id,
                            const char *namespace_s, const char *agent,
                            const stonith_key_value_t *params);
 
     /*!
      * \brief Unregister a fencing level for specified node with local fencer
      *
      * \param[in,out] st       Fencer connection to use
      * \param[in]     options  Group of enum stonith_call_options
      * \param[in]     node     Target node to unregister level for
      * \param[in]     level    Topology level number to unregister
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*remove_level)(stonith_t *st, int options, const char *node,
                         int level);
 
     /*!
      * \brief Register a fencing level for specified node with local fencer
      *
      * \param[in,out] st           Fencer connection to use
      * \param[in]     options      Group of enum stonith_call_options
      * \param[in]     node         Target node to register level for
      * \param[in]     level        Topology level number to register
      * \param[in]     device_list  Devices to register in level
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*register_level)(stonith_t *st, int options, const char *node,
                           int level, const stonith_key_value_t *device_list);
 
     /*!
      * \brief Retrieve a fence agent's metadata
      *
      * \param[in,out] stonith       Fencer connection
      * \param[in]     call_options  Group of enum stonith_call_options
      *                              (currently ignored)
      * \param[in]     agent         Fence agent to query
      * \param[in]     namespace_s   Type of fence agent to search for ("redhat"
      *                              or "stonith-ng" for RHCS-style, "internal"
      *                              for Pacemaker-internal devices, "heartbeat"
      *                              for LHA-style, or "any" or NULL for any)
      * \param[out]    output        Where to store metadata
      * \param[in]     timeout_sec   Error if not complete within this time
      *
      * \return Legacy Pacemaker return code
      * \note The caller is responsible for freeing *output using free().
      */
     int (*metadata)(stonith_t *stonith, int call_options, const char *agent,
                     const char *namespace_s, char **output, int timeout_sec);
 
     /*!
      * \brief Retrieve a list of installed fence agents
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      *                              (currently ignored)
      * \param[in]     namespace_s   Type of fence agents to list ("redhat"
      *                              or "stonith-ng" for RHCS-style, "internal" for
      *                              Pacemaker-internal devices, "heartbeat" for
      *                              LHA-style, or "any" or NULL for all)
      * \param[out]    devices       Where to store agent list
      * \param[in]     timeout       Error if unable to complete within this
      *                              (currently ignored)
      *
      * \return Number of items in list on success, or negative errno otherwise
      * \note The caller is responsible for freeing the returned list with
      *       stonith_key_value_freeall().
      */
     int (*list_agents)(stonith_t *stonith, int call_options,
                        const char *namespace_s, stonith_key_value_t **devices,
                        int timeout);
 
     /*!
      * \brief Get the output of a fence device's list action
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     id            Fence device ID to run list for
      * \param[out]    list_info     Where to store list output
      * \param[in]     timeout       Error if unable to complete within this
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*list)(stonith_t *stonith, int call_options, const char *id,
                 char **list_info, int timeout);
 
     /*!
      * \brief Check whether a fence device is reachable by monitor action
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     id            Fence device ID to run monitor for
      * \param[in]     timeout       Error if unable to complete within this
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*monitor)(stonith_t *stonith, int call_options, const char *id,
                    int timeout);
 
     /*!
      * \brief Check whether a fence device target is reachable by status action
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     id            Fence device ID to run status for
      * \param[in]     port          Fence target to run status for
      * \param[in]     timeout       Error if unable to complete within this
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*status)(stonith_t *stonith, int call_options, const char *id,
                   const char *port, int timeout);
 
     /*!
      * \brief List registered fence devices
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     target        Fence target to run status for
      * \param[out]    devices       Where to store list of fence devices
      * \param[in]     timeout       Error if unable to complete within this
      *
      * \note If node is provided, only devices that can fence the node id
      *       will be returned.
      *
      * \return Number of items in list on success, or negative errno otherwise
      */
     int (*query)(stonith_t *stonith, int call_options, const char *target,
                  stonith_key_value_t **devices, int timeout);
 
     /*!
      * \brief Request that a target get fenced
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     node          Fence target
      * \param[in]     action        "on", "off", or "reboot"
      * \param[in]     timeout       Default per-device timeout to use with
      *                              each executed device
      * \param[in]     tolerance     Accept result of identical fence action
      *                              completed within this time
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*fence)(stonith_t *stonith, int call_options, const char *node,
                  const char *action, int timeout, int tolerance);
 
     /*!
      * \brief Manually confirm that a node has been fenced
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     target        Fence target
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*confirm)(stonith_t *stonith, int call_options, const char *target);
 
     /*!
      * \brief List fencing actions that have occurred for a target
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     node          Fence target
      * \param[out]    history       Where to store list of fencing actions
      * \param[in]     timeout       Error if unable to complete within this
      *
      * \return Legacy Pacemaker return code
      */
     int (*history)(stonith_t *stonith, int call_options, const char *node,
                    stonith_history_t **history, int timeout);
 
     /*!
      * \brief Register a callback for fence notifications
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     event         Event to register for
      * \param[in]     callback      Callback to register
      *
      * \return Legacy Pacemaker return code
      */
     int (*register_notification)(stonith_t *stonith, const char *event,
                                  void (*callback)(stonith_t *st,
                                                   stonith_event_t *e));
 
     /*!
      * \brief Unregister callbacks for fence notifications
      *
      * \param[in,out] stonith  Fencer connection to use
      * \param[in]     event    Event to unregister callbacks for (NULL for all)
      *
      * \return Legacy Pacemaker return code
      */
     int (*remove_notification)(stonith_t *stonith, const char *event);
 
     /*!
      * \brief Register a callback for an asynchronous fencing result
      *
      * \param[in,out] stonith        Fencer connection to use
      * \param[in]     call_id        Call ID to register callback for
      * \param[in]     timeout        Error if result not received in this time
      * \param[in]     options        Group of enum stonith_call_options
      *                               (respects \c st_opt_timeout_updates and
      *                               \c st_opt_report_only_success)
      * \param[in,out] user_data      Pointer to pass to callback
      * \param[in]     callback_name  Unique identifier for callback
      * \param[in]     callback       Callback to register (may be called
      *                               immediately if \p call_id indicates error)
      *
      * \return \c TRUE on success, \c FALSE if call_id indicates error,
      *         or -EINVAL if \p stonith is not valid
      */
     int (*register_callback)(stonith_t *stonith, int call_id, int timeout,
                              int options, void *user_data,
                              const char *callback_name,
                              void (*callback)(stonith_t *st,
                                               stonith_callback_data_t *data));
 
     /*!
      * \brief Unregister callbacks for asynchronous fencing results
      *
      * \param[in,out] stonith        Fencer connection to use
      * \param[in]     call_id        If \p all_callbacks is false, call ID
      *                               to unregister callback for
      * \param[in]     all_callbacks  If true, unregister all callbacks
      *
      * \return pcmk_ok
      */
     int (*remove_callback)(stonith_t *stonith, int call_id, bool all_callbacks);
 
     /*!
      * \brief Unregister fencing level for specified node, pattern or attribute
      *
      * \param[in,out] st       Fencer connection to use
      * \param[in]     options  Group of enum stonith_call_options
      * \param[in]     node     If not NULL, unregister level targeting this node
      * \param[in]     pattern  If not NULL, unregister level targeting nodes
      *                         whose names match this regular expression
      * \param[in]     attr     If this and \p value are not NULL, unregister
      *                         level targeting nodes with this node attribute
      *                         set to \p value
      * \param[in]     value    If this and \p attr are not NULL, unregister
      *                         level targeting nodes with node attribute \p attr
      *                         set to this
      * \param[in]     level    Topology level number to remove
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      * \note The caller should set only one of \p node, \p pattern, or \p attr
      *       and \p value.
      */
     int (*remove_level_full)(stonith_t *st, int options,
                              const char *node, const char *pattern,
                              const char *attr, const char *value, int level);
 
     /*!
      * \brief Register fencing level for specified node, pattern or attribute
      *
      * \param[in,out] st           Fencer connection to use
      * \param[in]     options      Group of enum stonith_call_options
      * \param[in]     node         If not NULL, register level targeting this
      *                             node by name
      * \param[in]     pattern      If not NULL, register level targeting nodes
      *                             whose names match this regular expression
      * \param[in]     attr         If this and \p value are not NULL, register
      *                             level targeting nodes with this node
      *                             attribute set to \p value
      * \param[in]     value        If this and \p attr are not NULL, register
      *                             level targeting nodes with node attribute
      *                             \p attr set to this
      * \param[in]     level        Topology level number to remove
      * \param[in]     device_list  Devices to use in level
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      *
      * \note The caller should set only one of node, pattern or attr/value.
      */
     int (*register_level_full)(stonith_t *st, int options,
                                const char *node, const char *pattern,
                                const char *attr, const char *value, int level,
                                const stonith_key_value_t *device_list);
 
     /*!
      * \brief Validate an arbitrary stonith device configuration
      *
      * \param[in,out] st            Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     rsc_id        ID used to replace CIB secrets in \p params
      * \param[in]     namespace_s   Type of fence agent to validate ("redhat"
      *                              or "stonith-ng" for RHCS-style, "internal"
      *                              for Pacemaker-internal devices, "heartbeat"
      *                              for LHA-style, or "any" or NULL for any)
      * \param[in]     agent         Fence agent to validate
      * \param[in]     params        Configuration parameters to pass to agent
      * \param[in]     timeout       Fail if no response within this many seconds
      * \param[out]    output        If non-NULL, where to store any agent output
      * \param[out]    error_output  If non-NULL, where to store agent error output
      *
      * \return pcmk_ok if validation succeeds, -errno otherwise
      * \note If pcmk_ok is returned, the caller is responsible for freeing
      *       the output (if requested) with free().
      */
     int (*validate)(stonith_t *st, int call_options, const char *rsc_id,
                     const char *namespace_s, const char *agent,
                     const stonith_key_value_t *params, int timeout,
                     char **output, char **error_output);
 
     /*!
      * \brief Request delayed fencing of a target
      *
      * \param[in,out] stonith       Fencer connection to use
      * \param[in]     call_options  Group of enum stonith_call_options
      * \param[in]     node          Fence target
      * \param[in]     action        "on", "off", or "reboot"
      * \param[in]     timeout       Default per-device timeout to use with
      *                              each executed device
      * \param[in]     tolerance     Accept result of identical fence action
      *                              completed within this time
      * \param[in]     delay         Execute fencing after this delay (-1
      *                              disables any delay from pcmk_delay_base
      *                              and pcmk_delay_max)
      *
      * \return pcmk_ok (if synchronous) or positive call ID (if asynchronous)
      *         on success, otherwise a negative legacy Pacemaker return code
      */
     int (*fence_with_delay)(stonith_t *stonith, int call_options,
                             const char *node, const char *action, int timeout,
                             int tolerance, int delay);
 
 } stonith_api_operations_t;
 
 struct stonith_s {
     enum stonith_state state;
     int call_id;
     void *st_private;
     stonith_api_operations_t *cmds;
 };
 /* *INDENT-ON* */
 
 /* Core functions */
 stonith_t *stonith_api_new(void);
 void stonith_api_delete(stonith_t * st);
 
 void stonith_dump_pending_callbacks(stonith_t * st);
 
 bool stonith_dispatch(stonith_t * st);
 
 stonith_key_value_t *stonith_key_value_add(stonith_key_value_t * kvp, const char *key,
                                            const char *value);
 void stonith_key_value_freeall(stonith_key_value_t * kvp, int keys, int values);
 
 void stonith_history_free(stonith_history_t *history);
 
 // Convenience functions
 int stonith_api_connect_retry(stonith_t *st, const char *name,
                               int max_attempts);
 const char *stonith_op_state_str(enum op_state state);
 
 /* Basic helpers that allows nodes to be fenced and the history to be
  * queried without mainloop or the caller understanding the full API
  *
  * At least one of nodeid and uname are required
  *
  * NOTE: DLM uses both of these
  */
 int stonith_api_kick(uint32_t nodeid, const char *uname, int timeout, bool off);
 time_t stonith_api_time(uint32_t nodeid, const char *uname, bool in_progress);
 
 /*
  * Helpers for using the above functions without install-time dependencies
  *
  * Usage:
  *  #include <crm/stonith-ng.h>
  *
  * To turn a node off by corosync nodeid:
  *  stonith_api_kick_helper(nodeid, 120, 1);
  *
  * To check the last fence date/time (also by nodeid):
  *  last = stonith_api_time_helper(nodeid, 0);
  *
  * To check if fencing is in progress:
  *  if(stonith_api_time_helper(nodeid, 1) > 0) { ... }
  *
  * eg.
 
  #include <stdio.h>
  #include <time.h>
  #include <crm/stonith-ng.h>
  int
  main(int argc, char ** argv)
  {
      int rc = 0;
      int nodeid = 102;
 
      rc = stonith_api_time_helper(nodeid, 0);
      printf("%d last fenced at %s\n", nodeid, ctime(rc));
 
      rc = stonith_api_kick_helper(nodeid, 120, 1);
      printf("%d fence result: %d\n", nodeid, rc);
 
      rc = stonith_api_time_helper(nodeid, 0);
      printf("%d last fenced at %s\n", nodeid, ctime(rc));
 
      return 0;
  }
 
  */
 
-#  define STONITH_LIBRARY "libstonithd.so.26"
+#define STONITH_LIBRARY "libstonithd.so.56"
 
 typedef int (*st_api_kick_fn) (int nodeid, const char *uname, int timeout, bool off);
 typedef time_t (*st_api_time_fn) (int nodeid, const char *uname, bool in_progress);
 
 static inline int
 stonith_api_kick_helper(uint32_t nodeid, int timeout, bool off)
 {
     static void *st_library = NULL;
     static st_api_kick_fn st_kick_fn;
 
     if (st_library == NULL) {
         st_library = dlopen(STONITH_LIBRARY, RTLD_LAZY);
     }
     if (st_library && st_kick_fn == NULL) {
         st_kick_fn = (st_api_kick_fn) dlsym(st_library, "stonith_api_kick");
     }
     if (st_kick_fn == NULL) {
 #ifdef ELIBACC
         return -ELIBACC;
 #else
         return -ENOSYS;
 #endif
     }
 
     return (*st_kick_fn) (nodeid, NULL, timeout, off);
 }
 
 static inline time_t
 stonith_api_time_helper(uint32_t nodeid, bool in_progress)
 {
     static void *st_library = NULL;
     static st_api_time_fn st_time_fn;
 
     if (st_library == NULL) {
         st_library = dlopen(STONITH_LIBRARY, RTLD_LAZY);
     }
     if (st_library && st_time_fn == NULL) {
         st_time_fn = (st_api_time_fn) dlsym(st_library, "stonith_api_time");
     }
     if (st_time_fn == NULL) {
         return 0;
     }
 
     return (*st_time_fn) (nodeid, NULL, in_progress);
 }
 
 /**
  * Does the given agent describe a stonith resource that can exist?
  *
  * \param[in] agent     What is the name of the agent?
  * \param[in] timeout   Timeout to use when querying.  If 0 is given,
  *                      use a default of 120.
  *
  * \return A boolean
  */
 bool stonith_agent_exists(const char *agent, int timeout);
 
 /*!
  * \brief Turn fence action into a more readable string
  *
  * \param[in] action  Fence action
  */
 const char *stonith_action_str(const char *action);
 
 #ifdef __cplusplus
 }
 #endif
 
 #endif