pacemaker 3.0.1-16e74fc4da
Scalable High-Availability cluster resource manager
Loading...
Searching...
No Matches
internal.h
Go to the documentation of this file.
1/*
2 * Copyright 2011-2025 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 PCMK__CRM_FENCING_INTERNAL__H
11#define PCMK__CRM_FENCING_INTERNAL__H
12
13#include <stdbool.h> // bool
14
15#include <glib.h>
16#include <crm/common/ipc.h>
17#include <crm/common/xml.h>
20#include <crm/stonith-ng.h>
21
22#ifdef __cplusplus
23extern "C" {
24#endif
25
27void stonith__api_free(stonith_t *stonith_api);
28int stonith__api_dispatch(stonith_t *stonith_api);
29
30int stonith__api_connect_retry(stonith_t *stonith, const char *name,
31 int max_attempts);
32
33bool stonith__agent_exists(const char *name);
34
36 const char *key, const char *value);
38 bool values);
39
40#define stonith__set_call_options(st_call_opts, call_for, flags_to_set) do { \
41 st_call_opts = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE, \
42 "Fencer call", (call_for), \
43 (st_call_opts), (flags_to_set), \
44 #flags_to_set); \
45 } while (0)
46
47#define stonith__clear_call_options(st_call_opts, call_for, flags_to_clear) do { \
48 st_call_opts = pcmk__clear_flags_as(__func__, __LINE__, LOG_TRACE, \
49 "Fencer call", (call_for), \
50 (st_call_opts), (flags_to_clear), \
51 #flags_to_clear); \
52 } while (0)
53
54struct stonith_action_s;
55typedef struct stonith_action_s stonith_action_t;
56
58 const char *action_name,
59 const char *target,
60 int timeout_sec,
61 GHashTable *device_args,
62 GHashTable *port_map,
63 const char *host_arg);
67void stonith__xe_set_result(xmlNode *xml, const pcmk__action_result_t *result);
68void stonith__xe_get_result(const xmlNode *xml, pcmk__action_result_t *result);
69xmlNode *stonith__find_xe_with_result(xmlNode *xml);
70
72 void (*done) (int pid,
74 void *user_data),
75 void (*fork_cb) (int pid, void *user_data));
76
77int stonith__metadata_async(const char *agent, int timeout_sec,
78 void (*callback)(int pid,
80 void *user_data),
81 void *user_data);
82
83xmlNode *create_level_registration_xml(const char *node, const char *pattern,
84 const char *attr, const char *value,
85 int level,
86 const stonith_key_value_t *device_list);
87
88xmlNode *create_device_registration_xml(const char *id,
89 enum stonith_namespace standard,
90 const char *agent,
91 const stonith_key_value_t *params,
92 const char *rsc_provides);
93
95
96GList *stonith__parse_targets(const char *hosts);
97
99const char *stonith__later_succeeded(const stonith_history_t *event,
100 const stonith_history_t *top_history);
102
103const char *stonith__default_host_arg(xmlNode *metadata);
104
105/* Only 1-9 is allowed for fencing topology levels,
106 * however, 0 is used to unregister all levels in
107 * unregister requests.
108 */
109# define ST__LEVEL_COUNT 10
110
111# define STONITH_ATTR_ACTION_OP "action"
112
113# define STONITH_OP_EXEC "st_execute"
114# define STONITH_OP_TIMEOUT_UPDATE "st_timeout_update"
115# define STONITH_OP_QUERY "st_query"
116# define STONITH_OP_FENCE "st_fence"
117# define STONITH_OP_RELAY "st_relay"
118# define STONITH_OP_DEVICE_ADD "st_device_register"
119# define STONITH_OP_DEVICE_DEL "st_device_remove"
120# define STONITH_OP_FENCE_HISTORY "st_fence_history"
121# define STONITH_OP_LEVEL_ADD "st_level_add"
122# define STONITH_OP_LEVEL_DEL "st_level_remove"
123# define STONITH_OP_NOTIFY "st_notify"
124# define STONITH_OP_POKE "poke"
125
126
127# define STONITH_WATCHDOG_AGENT "fence_watchdog"
128/* Don't change 2 below as it would break rolling upgrade */
129# define STONITH_WATCHDOG_AGENT_INTERNAL "#watchdog"
130# define STONITH_WATCHDOG_ID "watchdog"
131
133 bool (*matching_fn)(stonith_history_t *, void *),
134 void *user_data);
135bool stonith__event_state_pending(stonith_history_t *history, void *user_data);
136bool stonith__event_state_eq(stonith_history_t *history, void *user_data);
137bool stonith__event_state_neq(stonith_history_t *history, void *user_data);
138
139int stonith__legacy2status(int rc);
140
144
147const char *stonith__event_exit_reason(const stonith_event_t *event);
150 bool full_history,
151 const char *later_succeeded,
152 uint32_t show_opts);
153
154const char *stonith__op_state_text(enum op_state state);
155
164static inline bool
165stonith__op_state_pending(enum op_state state)
166{
167 return state != st_failed && state != st_done;
168}
169
170gboolean stonith__watchdog_fencing_enabled_for_node(const char *node);
172
188int stonith__validate(stonith_t *st, int call_options, const char *rsc_id,
189 const char *agent, GHashTable *params, int timeout_sec,
190 char **output, char **error_output);
191
192#ifdef __cplusplus
193}
194#endif
195
196#endif // PCMK__CRM_FENCING_INTERNAL__H
const char * name
Definition cib.c:26
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:2562
const char * stonith__default_host_arg(xmlNode *metadata)
Definition st_client.c:2529
gboolean stonith__watchdog_fencing_enabled_for_node(const char *node)
Definition st_client.c:241
const char * stonith__exit_reason(const stonith_callback_data_t *data)
Definition st_client.c:2667
int stonith__api_connect_retry(stonith_t *stonith, const char *name, int max_attempts)
Definition st_client.c:1958
int stonith__legacy2status(int rc)
Definition st_actions.c:390
char * stonith__event_description(const stonith_event_t *event)
Definition st_client.c:2746
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:679
bool stonith__event_state_pending(stonith_history_t *history, void *user_data)
Definition st_client.c:2476
gchar * stonith__history_description(const stonith_history_t *event, bool full_history, const char *later_succeeded, uint32_t show_opts)
Definition st_output.c:109
GList * stonith__parse_targets(const char *hosts)
Definition st_client.c:2300
void stonith__destroy_action(stonith_action_t *action)
Definition st_actions.c:206
bool stonith__event_state_neq(stonith_history_t *history, void *user_data)
Definition st_client.c:2488
bool stonith__event_state_eq(stonith_history_t *history, void *user_data)
Definition st_client.c:2482
xmlNode * create_device_registration_xml(const char *id, enum stonith_namespace standard, const char *agent, const stonith_key_value_t *params, const char *rsc_provides)
Definition st_client.c:303
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:425
void stonith__api_free(stonith_t *stonith_api)
Definition st_client.c:1939
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:2462
int stonith__exit_status(const stonith_callback_data_t *data)
Definition st_client.c:2633
stonith_key_value_t * stonith__key_value_add(stonith_key_value_t *head, const char *key, const char *value)
Definition st_client.c:1995
bool stonith__agent_exists(const char *name)
Definition st_client.c:2168
stonith_history_t * stonith__sort_history(stonith_history_t *history)
Definition st_client.c:2387
pcmk__action_result_t * stonith__action_result(stonith_action_t *action)
Definition st_actions.c:231
xmlNode * stonith__find_xe_with_result(xmlNode *xml)
Definition st_actions.c:459
gboolean stonith__watchdog_fencing_enabled_for_node_api(stonith_t *st, const char *node)
Definition st_client.c:182
struct stonith_action_s stonith_action_t
Definition internal.h:55
void stonith__xe_get_result(const xmlNode *xml, pcmk__action_result_t *result)
Definition st_actions.c:483
int stonith__validate(stonith_t *st, int call_options, const char *rsc_id, const char *agent, GHashTable *params, int timeout_sec, char **output, char **error_output)
Definition st_client.c:1742
int stonith__execution_status(const stonith_callback_data_t *data)
Definition st_client.c:2650
int stonith__api_dispatch(stonith_t *stonith_api)
Definition st_client.c:1677
int stonith__result2rc(const pcmk__action_result_t *result)
Definition st_actions.c:316
void stonith__xe_set_result(xmlNode *xml, const pcmk__action_result_t *result)
Definition st_actions.c:420
void stonith__key_value_freeall(stonith_key_value_t *head, bool keys, bool values)
Definition st_client.c:2033
int stonith__event_exit_status(const stonith_event_t *event)
Definition st_client.c:2684
const char * stonith__op_state_text(enum op_state state)
Definition st_client.c:2442
void stonith__history_free(stonith_history_t *head)
Definition st_client.c:776
int stonith__event_execution_status(const stonith_event_t *event)
Definition st_client.c:2704
const char * stonith__later_succeeded(const stonith_history_t *event, const stonith_history_t *top_history)
Definition st_client.c:2347
const char * stonith__event_exit_reason(const stonith_event_t *event)
Definition st_client.c:2724
stonith_t * stonith__api_new(void)
Definition st_client.c:1866
void stonith__register_messages(pcmk__output_t *out)
Definition st_output.c:623
stonith_action_t * stonith__action_create(const char *agent, const char *action_name, const char *target, int timeout_sec, GHashTable *device_args, GHashTable *port_map, const char *host_arg)
Definition st_actions.c:253
IPC interface to Pacemaker daemons.
Formatted output for pacemaker tools.
stonith_t * st
Definition pcmk_fence.c:30
const char * action
Definition pcmk_fence.c:32
pcmk__action_result_t result
Definition pcmk_fence.c:37
const char * target
Definition pcmk_fence.c:31
Fencing aka. STONITH.
stonith_namespace
Supported fence agent interface standards.
Definition stonith-ng.h:138
op_state
Fencing operation states.
Definition stonith-ng.h:125
@ st_failed
Definition stonith-ng.h:130
@ st_done
Definition stonith-ng.h:128
This structure contains everything that makes up a single output formatter.
Data for an asynchronous fencing request callback.
Definition stonith-ng.h:216
Fencing event.
Definition stonith-ng.h:194
Fencing history entry.
Definition stonith-ng.h:173
Key-value pair list node.
Definition stonith-ng.h:162
Fencer API connection object.
Definition stonith-ng.h:657
Wrappers for and extensions to libxml2.