pacemaker 2.1.1-77db578727
Scalable High-Availability cluster resource manager
Loading...
Searching...
No Matches
internal.h
Go to the documentation of this file.
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>
17# include <crm/stonith-ng.h>
18
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
49struct stonith_action_s;
50typedef struct stonith_action_s stonith_action_t;
51
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);
61void stonith__action_result(stonith_action_t *action, int *rc, char **output,
62 char **error_output);
63
64int
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
72
73xmlNode *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
78xmlNode *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
85
86GList *stonith__parse_targets(const char *hosts);
87
90
91void 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"
107# define F_STONITH_TIMEOUT "st_timeout"
108# define F_STONITH_TOLERANCE "st_tolerance"
109# define F_STONITH_DELAY "st_delay"
111# define F_STONITH_ACTION_TIMEOUT "st_action_timeout"
113# define F_STONITH_ACTION_DISALLOWED "st_action_disallowed"
115# define F_STONITH_DELAY_MAX "st_delay_max"
117# define F_STONITH_DELAY_BASE "st_delay_base"
120# define F_STONITH_DEVICE_VERIFIED "st_monitor_verified"
122# define F_STONITH_DEVICE_REQUIRED "st_required"
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"
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"
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
172int stonith__lha_metadata(const char *agent, int timeout, char **output);
173bool stonith__agent_is_lha(const char *agent);
174int 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
181int stonith__rhcs_metadata(const char *agent, int timeout, char **output);
182bool stonith__agent_is_rhcs(const char *agent);
183int 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 */
189int stonith__history(pcmk__output_t *out, va_list args);
190int stonith__full_history(pcmk__output_t *out, va_list args);
192
194 bool (*matching_fn)(stonith_history_t *, void *),
195 void *user_data);
196bool stonith__event_state_pending(stonith_history_t *history, void *user_data);
197bool stonith__event_state_eq(stonith_history_t *history, void *user_data);
198bool stonith__event_state_neq(stonith_history_t *history, void *user_data);
199
208static inline bool
209stonith__op_state_pending(enum op_state state)
210{
211 return state != st_failed && state != st_done;
212}
213
214#endif
uint32_t pid
Definition cpg.c:1
bool stonith__agent_is_rhcs(const char *agent)
Definition st_rhcs.c:233
int stonith__rhcs_validate(stonith_t *st, int call_options, const char *target, const char *agent, GHashTable *params, const char *host_arg, int timeout, char **output, char **error_output)
Definition st_rhcs.c:244
bool stonith__event_state_pending(stonith_history_t *history, void *user_data)
Definition st_client.c:2639
int stonith__pending_actions(pcmk__output_t *out, va_list args)
st_device_flags
Definition internal.h:20
@ 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
GList * stonith__parse_targets(const char *hosts)
Definition st_client.c:2489
void stonith__destroy_action(stonith_action_t *action)
Definition st_client.c:575
bool stonith__event_state_neq(stonith_history_t *history, void *user_data)
Definition st_client.c:2651
void stonith__device_parameter_flags(uint32_t *device_flags, const char *device_name, xmlNode *metadata)
Definition st_client.c:2657
bool stonith__event_state_eq(stonith_history_t *history, void *user_data)
Definition st_client.c:2645
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:2625
stonith_action_t * stonith_action_create(const char *agent, const char *_action, const char *victim, uint32_t victim_nodeid, int timeout, GHashTable *device_args, GHashTable *port_map, const char *host_arg)
Definition st_client.c:635
int stonith_action_execute_async(stonith_action_t *action, void *userdata, void(*done)(GPid pid, int rc, const char *output, gpointer user_data), void(*fork_cb)(GPid pid, gpointer user_data))
Definition st_client.c:863
gboolean stonith__later_succeeded(stonith_history_t *event, stonith_history_t *top_history)
Definition st_client.c:2529
int stonith__failed_history(pcmk__output_t *out, va_list args)
void stonith__action_result(stonith_action_t *action, int *rc, char **output, char **error_output)
Definition st_client.c:606
stonith_history_t * stonith__sort_history(stonith_history_t *history)
Definition st_client.c:2560
int stonith__execute(stonith_action_t *action)
Definition st_client.c:890
struct stonith_action_s stonith_action_t
Definition internal.h:50
xmlNode * create_device_registration_xml(const char *id, enum stonith_namespace namespace, const char *agent, stonith_key_value_t *params, const char *rsc_provides)
Definition st_client.c:275
int stonith__history(pcmk__output_t *out, va_list args)
Definition st_output.c:66
xmlNode * create_level_registration_xml(const char *node, const char *pattern, const char *attr, const char *value, int level, stonith_key_value_t *device_list)
Definition st_client.c:395
int stonith__full_history(pcmk__output_t *out, va_list args)
int stonith__rhcs_metadata(const char *agent, int timeout, char **output)
Execute RHCS-compatible agent's meta-data action.
Definition st_rhcs.c:207
void stonith__register_messages(pcmk__output_t *out)
Definition st_output.c:468
int stonith__list_rhcs_agents(stonith_key_value_t **devices)
Definition st_rhcs.c:33
IPC interface to Pacemaker daemons.
Formatted output for pacemaker tools.
unsigned int timeout
Definition pcmk_fence.c:32
stonith_t * st
Definition pcmk_fence.c:28
const char * action
Definition pcmk_fence.c:30
int rc
Definition pcmk_fence.c:35
const char * target
Definition pcmk_fence.c:29
int stonith__lha_metadata(const char *agent, int timeout, char **output)
Definition st_lha.c:177
int stonith__list_lha_agents(stonith_key_value_t **devices)
Definition st_lha.c:108
int stonith__lha_validate(stonith_t *st, int call_options, const char *target, const char *agent, GHashTable *params, int timeout, char **output, char **error_output)
Definition st_lha.c:276
bool stonith__agent_is_lha(const char *agent)
Determine namespace of a fence agent.
Definition st_lha.c:81
Fencing aka. STONITH.
stonith_namespace
Definition stonith-ng.h:81
op_state
Definition stonith-ng.h:72
@ st_failed
Definition stonith-ng.h:77
@ st_done
Definition stonith-ng.h:75
This structure contains everything that makes up a single output formatter.
Wrappers for and extensions to libxml2.