root/include/crm/fencing/internal.h

/* [previous][next][first][last][top][bottom][index][help] */

INCLUDED FROM


DEFINITIONS

This source file includes following definitions.
  1. stonith__op_state_pending

   1 /*
   2  * Copyright 2011-2021 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 STONITH_NG_INTERNAL__H
  11 #  define STONITH_NG_INTERNAL__H
  12 
  13 #  include <glib.h>
  14 #  include <crm/common/ipc.h>
  15 #  include <crm/common/xml.h>
  16 #  include <crm/common/output_internal.h>
  17 #  include <crm/stonith-ng.h>
  18 
  19 enum st_device_flags
  20 {
  21     st_device_supports_list   = 0x0001,
  22     st_device_supports_status = 0x0002,
  23     st_device_supports_reboot = 0x0004,
  24     st_device_supports_parameter_plug = 0x0008,
  25     st_device_supports_parameter_port = 0x0010,
  26 };
  27 
  28 #define stonith__set_device_flags(device_flags, device_id, flags_to_set) do { \
  29         device_flags = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE,      \
  30                                           "Fence device", device_id,          \
  31                                           (device_flags), (flags_to_set),     \
  32                                           #flags_to_set);                     \
  33     } while (0)
  34 
  35 #define stonith__set_call_options(st_call_opts, call_for, flags_to_set) do { \
  36         st_call_opts = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE,     \
  37                                           "Fencer call", (call_for),         \
  38                                           (st_call_opts), (flags_to_set),    \
  39                                           #flags_to_set);                    \
  40     } while (0)
  41 
  42 #define stonith__clear_call_options(st_call_opts, call_for, flags_to_clear) do { \
  43         st_call_opts = pcmk__clear_flags_as(__func__, __LINE__, LOG_TRACE,     \
  44                                             "Fencer call", (call_for),         \
  45                                             (st_call_opts), (flags_to_clear),  \
  46                                             #flags_to_clear);                  \
  47     } while (0)
  48 
  49 struct stonith_action_s;
  50 typedef struct stonith_action_s stonith_action_t;
  51 
  52 stonith_action_t *stonith_action_create(const char *agent,
  53                                         const char *_action,
  54                                         const char *victim,
  55                                         uint32_t victim_nodeid,
  56                                         int timeout,
  57                                         GHashTable * device_args,
  58                                         GHashTable * port_map,
  59                                         const char * host_arg);
  60 void stonith__destroy_action(stonith_action_t *action);
  61 void stonith__action_result(stonith_action_t *action, int *rc, char **output,
  62                             char **error_output);
  63 
  64 int
  65 stonith_action_execute_async(stonith_action_t * action,
  66                              void *userdata,
  67                              void (*done) (GPid pid, int rc, const char *output,
  68                                            gpointer user_data),
  69                              void (*fork_cb) (GPid pid, gpointer user_data));
  70 
  71 int stonith__execute(stonith_action_t *action);
  72 
  73 xmlNode *create_level_registration_xml(const char *node, const char *pattern,
  74                                        const char *attr, const char *value,
  75                                        int level,
  76                                        stonith_key_value_t *device_list);
  77 
  78 xmlNode *create_device_registration_xml(const char *id,
  79                                         enum stonith_namespace namespace,
  80                                         const char *agent,
  81                                         stonith_key_value_t *params,
  82                                         const char *rsc_provides);
  83 
  84 void stonith__register_messages(pcmk__output_t *out);
  85 
  86 GList *stonith__parse_targets(const char *hosts);
  87 
  88 gboolean stonith__later_succeeded(stonith_history_t *event, stonith_history_t *top_history);
  89 stonith_history_t *stonith__sort_history(stonith_history_t *history);
  90 
  91 void stonith__device_parameter_flags(uint32_t *device_flags,
  92                                      const char *device_name,
  93                                      xmlNode *metadata);
  94 
  95 #  define ST_LEVEL_MAX 10
  96 
  97 #  define F_STONITH_CLIENTID      "st_clientid"
  98 #  define F_STONITH_CALLOPTS      "st_callopt"
  99 #  define F_STONITH_CALLID        "st_callid"
 100 #  define F_STONITH_CALLDATA      "st_calldata"
 101 #  define F_STONITH_OPERATION     "st_op"
 102 #  define F_STONITH_TARGET        "st_target"
 103 #  define F_STONITH_REMOTE_OP_ID  "st_remote_op"
 104 #  define F_STONITH_REMOTE_OP_ID_RELAY  "st_remote_op_relay"
 105 #  define F_STONITH_RC            "st_rc"
 106 /*! Timeout period per a device execution */
 107 #  define F_STONITH_TIMEOUT       "st_timeout"
 108 #  define F_STONITH_TOLERANCE     "st_tolerance"
 109 #  define F_STONITH_DELAY         "st_delay"
 110 /*! Action specific timeout period returned in query of fencing devices. */
 111 #  define F_STONITH_ACTION_TIMEOUT       "st_action_timeout"
 112 /*! Host in query result is not allowed to run this action */
 113 #  define F_STONITH_ACTION_DISALLOWED     "st_action_disallowed"
 114 /*! Maximum of random fencing delay for a device */
 115 #  define F_STONITH_DELAY_MAX            "st_delay_max"
 116 /*! Base delay used for a fencing delay */
 117 #  define F_STONITH_DELAY_BASE           "st_delay_base"
 118 /*! Has this device been verified using a monitor type
 119  *  operation (monitor, list, status) */
 120 #  define F_STONITH_DEVICE_VERIFIED   "st_monitor_verified"
 121 /*! device is required for this action */
 122 #  define F_STONITH_DEVICE_REQUIRED   "st_required"
 123 /*! number of available devices in query result */
 124 #  define F_STONITH_AVAILABLE_DEVICES "st-available-devices"
 125 #  define F_STONITH_CALLBACK_TOKEN    "st_async_id"
 126 #  define F_STONITH_CLIENTNAME        "st_clientname"
 127 #  define F_STONITH_CLIENTNODE        "st_clientnode"
 128 #  define F_STONITH_NOTIFY_ACTIVATE   "st_notify_activate"
 129 #  define F_STONITH_NOTIFY_DEACTIVATE "st_notify_deactivate"
 130 #  define F_STONITH_DELEGATE      "st_delegate"
 131 /*! The node initiating the stonith operation.  If an operation
 132  * is relayed, this is the last node the operation lands on. When
 133  * in standalone mode, origin is the client's id that originated the
 134  * operation. */
 135 #  define F_STONITH_ORIGIN        "st_origin"
 136 #  define F_STONITH_HISTORY_LIST  "st_history"
 137 #  define F_STONITH_DATE          "st_date"
 138 #  define F_STONITH_STATE         "st_state"
 139 #  define F_STONITH_ACTIVE        "st_active"
 140 #  define F_STONITH_DIFFERENTIAL  "st_differential"
 141 
 142 #  define F_STONITH_DEVICE        "st_device_id"
 143 #  define F_STONITH_ACTION        "st_device_action"
 144 #  define F_STONITH_MERGED        "st_op_merged"
 145 
 146 #  define T_STONITH_NG        "stonith-ng"
 147 #  define T_STONITH_REPLY     "st-reply"
 148 /*! For async operations, an event from the server containing
 149  * the total amount of time the server is allowing for the operation
 150  * to take place is returned to the client. */
 151 #  define T_STONITH_TIMEOUT_VALUE "st-async-timeout-value"
 152 #  define T_STONITH_NOTIFY    "st_notify"
 153 
 154 #  define STONITH_ATTR_ACTION_OP   "action"
 155 
 156 #  define STONITH_OP_EXEC        "st_execute"
 157 #  define STONITH_OP_TIMEOUT_UPDATE        "st_timeout_update"
 158 #  define STONITH_OP_QUERY       "st_query"
 159 #  define STONITH_OP_FENCE       "st_fence"
 160 #  define STONITH_OP_RELAY       "st_relay"
 161 #  define STONITH_OP_DEVICE_ADD      "st_device_register"
 162 #  define STONITH_OP_DEVICE_DEL      "st_device_remove"
 163 #  define STONITH_OP_FENCE_HISTORY   "st_fence_history"
 164 #  define STONITH_OP_LEVEL_ADD       "st_level_add"
 165 #  define STONITH_OP_LEVEL_DEL       "st_level_remove"
 166 
 167 #  define STONITH_WATCHDOG_AGENT  "#watchdog"
 168 
 169 #  ifdef HAVE_STONITH_STONITH_H
 170 // utilities from st_lha.c
 171 int stonith__list_lha_agents(stonith_key_value_t **devices);
 172 int stonith__lha_metadata(const char *agent, int timeout, char **output);
 173 bool stonith__agent_is_lha(const char *agent);
 174 int stonith__lha_validate(stonith_t *st, int call_options, const char *target,
 175                           const char *agent, GHashTable *params,
 176                           int timeout, char **output, char **error_output);
 177 #  endif
 178 
 179 // utilities from st_rhcs.c
 180 int stonith__list_rhcs_agents(stonith_key_value_t **devices);
 181 int stonith__rhcs_metadata(const char *agent, int timeout, char **output);
 182 bool stonith__agent_is_rhcs(const char *agent);
 183 int stonith__rhcs_validate(stonith_t *st, int call_options, const char *target,
 184                            const char *agent, GHashTable *params, const char *host_arg,
 185                            int timeout, char **output, char **error_output);
 186 
 187 /* Exported for crm_mon to reference */
 188 int stonith__failed_history(pcmk__output_t *out, va_list args);
 189 int stonith__history(pcmk__output_t *out, va_list args);
 190 int stonith__full_history(pcmk__output_t *out, va_list args);
 191 int stonith__pending_actions(pcmk__output_t *out, va_list args);
 192 
 193 stonith_history_t *stonith__first_matching_event(stonith_history_t *history,
 194                                                  bool (*matching_fn)(stonith_history_t *, void *),
 195                                                  void *user_data);
 196 bool stonith__event_state_pending(stonith_history_t *history, void *user_data);
 197 bool stonith__event_state_eq(stonith_history_t *history, void *user_data);
 198 bool stonith__event_state_neq(stonith_history_t *history, void *user_data);
 199 
 200 /*!
 201  * \internal
 202  * \brief Is a fencing operation in pending state?
 203  *
 204  * \param[in] state     State as enum op_state value
 205  *
 206  * \return A boolean
 207  */
 208 static inline bool
 209 stonith__op_state_pending(enum op_state state)
     /* [previous][next][first][last][top][bottom][index][help] */
 210 {
 211     return state != st_failed && state != st_done;
 212 }
 213 
 214 #endif

/* [previous][next][first][last][top][bottom][index][help] */