pacemaker 2.1.8-2.1.8
Scalable High-Availability cluster resource manager
Loading...
Searching...
No Matches
internal.h
Go to the documentation of this file.
1/*
2 * Copyright 2011-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 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>
17# include <crm/stonith-ng.h>
18
28
29#define stonith__set_device_flags(device_flags, device_id, flags_to_set) do { \
30 device_flags = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE, \
31 "Fence device", device_id, \
32 (device_flags), (flags_to_set), \
33 #flags_to_set); \
34 } while (0)
35
36#define stonith__set_call_options(st_call_opts, call_for, flags_to_set) do { \
37 st_call_opts = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE, \
38 "Fencer call", (call_for), \
39 (st_call_opts), (flags_to_set), \
40 #flags_to_set); \
41 } while (0)
42
43#define stonith__clear_call_options(st_call_opts, call_for, flags_to_clear) do { \
44 st_call_opts = pcmk__clear_flags_as(__func__, __LINE__, LOG_TRACE, \
45 "Fencer call", (call_for), \
46 (st_call_opts), (flags_to_clear), \
47 #flags_to_clear); \
48 } while (0)
49
50struct stonith_action_s;
51typedef struct stonith_action_s stonith_action_t;
52
54 const char *action_name,
55 const char *target,
56 uint32_t target_nodeid,
57 int timeout_sec,
58 GHashTable *device_args,
59 GHashTable *port_map,
60 const char *host_arg);
64void stonith__xe_set_result(xmlNode *xml, const pcmk__action_result_t *result);
65void stonith__xe_get_result(const xmlNode *xml, pcmk__action_result_t *result);
66xmlNode *stonith__find_xe_with_result(xmlNode *xml);
67
69 void (*done) (int pid,
71 void *user_data),
72 void (*fork_cb) (int pid, void *user_data));
73
74int stonith__metadata_async(const char *agent, int timeout_sec,
75 void (*callback)(int pid,
77 void *user_data),
78 void *user_data);
79
80xmlNode *create_level_registration_xml(const char *node, const char *pattern,
81 const char *attr, const char *value,
82 int level,
83 const stonith_key_value_t *device_list);
84
85xmlNode *create_device_registration_xml(const char *id,
86 enum stonith_namespace namespace,
87 const char *agent,
88 const stonith_key_value_t *params,
89 const char *rsc_provides);
90
92
93GList *stonith__parse_targets(const char *hosts);
94
95const char *stonith__later_succeeded(const stonith_history_t *event,
96 const stonith_history_t *top_history);
98
99void stonith__device_parameter_flags(uint32_t *device_flags,
100 const char *device_name,
101 xmlNode *metadata);
102
103/* Only 1-9 is allowed for fencing topology levels,
104 * however, 0 is used to unregister all levels in
105 * unregister requests.
106 */
107# define ST__LEVEL_COUNT 10
108
109// @COMPAT Deprecated since 1.1.17 (and see T773 to drop it)
110# define STONITH_ATTR_ACTION_OP "action"
111
112# define STONITH_OP_EXEC "st_execute"
113# define STONITH_OP_TIMEOUT_UPDATE "st_timeout_update"
114# define STONITH_OP_QUERY "st_query"
115# define STONITH_OP_FENCE "st_fence"
116# define STONITH_OP_RELAY "st_relay"
117# define STONITH_OP_DEVICE_ADD "st_device_register"
118# define STONITH_OP_DEVICE_DEL "st_device_remove"
119# define STONITH_OP_FENCE_HISTORY "st_fence_history"
120# define STONITH_OP_LEVEL_ADD "st_level_add"
121# define STONITH_OP_LEVEL_DEL "st_level_remove"
122# define STONITH_OP_NOTIFY "st_notify"
123# define STONITH_OP_POKE "poke"
124
125
126# define STONITH_WATCHDOG_AGENT "fence_watchdog"
127/* Don't change 2 below as it would break rolling upgrade */
128# define STONITH_WATCHDOG_AGENT_INTERNAL "#watchdog"
129# define STONITH_WATCHDOG_ID "watchdog"
130
132 bool (*matching_fn)(stonith_history_t *, void *),
133 void *user_data);
134bool stonith__event_state_pending(stonith_history_t *history, void *user_data);
135bool stonith__event_state_eq(stonith_history_t *history, void *user_data);
136bool stonith__event_state_neq(stonith_history_t *history, void *user_data);
137
138int stonith__legacy2status(int rc);
139
143
146const char *stonith__event_exit_reason(const stonith_event_t *event);
149 bool full_history,
150 const char *later_succeeded,
151 uint32_t show_opts);
152
161static inline bool
162stonith__op_state_pending(enum op_state state)
163{
164 return state != st_failed && state != st_done;
165}
166
167gboolean stonith__watchdog_fencing_enabled_for_node(const char *node);
169
170#endif
char data[0]
Definition cpg.c:10
uint32_t pid
Definition cpg.c:1
int stonith__metadata_async(const char *agent, int timeout_sec, void(*callback)(int pid, const pcmk__action_result_t *result, void *user_data), void *user_data)
Definition st_client.c:2465
gboolean stonith__watchdog_fencing_enabled_for_node(const char *node)
Definition st_client.c:231
const char * stonith__exit_reason(const stonith_callback_data_t *data)
Definition st_client.c:2570
int stonith__legacy2status(int rc)
Definition st_actions.c:400
char * stonith__event_description(const stonith_event_t *event)
Definition st_client.c:2649
int stonith__execute_async(stonith_action_t *action, void *userdata, void(*done)(int pid, const pcmk__action_result_t *result, void *user_data), void(*fork_cb)(int pid, void *user_data))
Definition st_actions.c:667
xmlNode * create_device_registration_xml(const char *id, enum stonith_namespace namespace, const char *agent, const stonith_key_value_t *params, const char *rsc_provides)
Definition st_client.c:293
bool stonith__event_state_pending(stonith_history_t *history, void *user_data)
Definition st_client.c:2386
st_device_flags
Definition internal.h:19
@ st_device_supports_none
Definition internal.h:20
@ st_device_supports_on
Definition internal.h:26
@ st_device_supports_parameter_port
Definition internal.h:25
@ st_device_supports_status
Definition internal.h:22
@ st_device_supports_list
Definition internal.h:21
@ st_device_supports_parameter_plug
Definition internal.h:24
@ st_device_supports_reboot
Definition internal.h:23
gchar * stonith__history_description(const stonith_history_t *event, bool full_history, const char *later_succeeded, uint32_t show_opts)
Definition st_output.c:89
GList * stonith__parse_targets(const char *hosts)
Definition st_client.c:2221
void stonith__destroy_action(stonith_action_t *action)
Definition st_actions.c:215
bool stonith__event_state_neq(stonith_history_t *history, void *user_data)
Definition st_client.c:2398
void stonith__device_parameter_flags(uint32_t *device_flags, const char *device_name, xmlNode *metadata)
Definition st_client.c:2404
stonith_action_t * stonith__action_create(const char *agent, const char *action_name, const char *target, uint32_t target_nodeid, int timeout_sec, GHashTable *device_args, GHashTable *port_map, const char *host_arg)
Definition st_actions.c:263
bool stonith__event_state_eq(stonith_history_t *history, void *user_data)
Definition st_client.c:2392
xmlNode * create_level_registration_xml(const char *node, const char *pattern, const char *attr, const char *value, int level, const stonith_key_value_t *device_list)
Definition st_client.c:417
stonith_history_t * stonith__first_matching_event(stonith_history_t *history, bool(*matching_fn)(stonith_history_t *, void *), void *user_data)
Definition st_client.c:2372
int stonith__exit_status(const stonith_callback_data_t *data)
Definition st_client.c:2536
stonith_history_t * stonith__sort_history(stonith_history_t *history)
Definition st_client.c:2305
pcmk__action_result_t * stonith__action_result(stonith_action_t *action)
Definition st_actions.c:240
xmlNode * stonith__find_xe_with_result(xmlNode *xml)
Definition st_actions.c:469
gboolean stonith__watchdog_fencing_enabled_for_node_api(stonith_t *st, const char *node)
Definition st_client.c:172
struct stonith_action_s stonith_action_t
Definition internal.h:51
void stonith__xe_get_result(const xmlNode *xml, pcmk__action_result_t *result)
Definition st_actions.c:490
int stonith__execution_status(const stonith_callback_data_t *data)
Definition st_client.c:2553
int stonith__result2rc(const pcmk__action_result_t *result)
Definition st_actions.c:326
void stonith__xe_set_result(xmlNode *xml, const pcmk__action_result_t *result)
Definition st_actions.c:430
int stonith__event_exit_status(const stonith_event_t *event)
Definition st_client.c:2587
int stonith__event_execution_status(const stonith_event_t *event)
Definition st_client.c:2607
const char * stonith__later_succeeded(const stonith_history_t *event, const stonith_history_t *top_history)
Definition st_client.c:2265
const char * stonith__event_exit_reason(const stonith_event_t *event)
Definition st_client.c:2627
void stonith__register_messages(pcmk__output_t *out)
Definition st_output.c:604
IPC interface to Pacemaker daemons.
Formatted output for pacemaker tools.
stonith_t * st
Definition pcmk_fence.c:28
const char * action
Definition pcmk_fence.c:30
pcmk__action_result_t result
Definition pcmk_fence.c:35
const char * target
Definition pcmk_fence.c:29
Fencing aka. STONITH.
stonith_namespace
Definition stonith-ng.h:76
op_state
Definition stonith-ng.h:67
@ st_failed
Definition stonith-ng.h:72
@ st_done
Definition stonith-ng.h:70
This structure contains everything that makes up a single output formatter.
Wrappers for and extensions to libxml2.