pacemaker 2.1.1-77db578727
Scalable High-Availability cluster resource manager
Loading...
Searching...
No Matches
lrmd.h
Go to the documentation of this file.
1/*
2 * Copyright 2012-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 LRMD__H
11# define LRMD__H
12
13#ifdef __cplusplus
14extern "C" {
15#endif
16
22#include <stdbool.h> // bool
23#include <glib.h> // guint, GList
24#include <crm_config.h>
25#include <crm/services.h>
26
27typedef struct lrmd_s lrmd_t;
33
34/* This should be bumped every time there is an incompatible change that
35 * prevents older clients from connecting to this version of the server.
36 */
37#define LRMD_PROTOCOL_VERSION "1.1"
38
39/* This is the version that the client version will actually be compared
40 * against. This should be identical to LRMD_PROTOCOL_VERSION. However, we
41 * accidentally bumped LRMD_PROTOCOL_VERSION in 6424a647 (1.1.15) when we didn't
42 * need to, so for now it's different. If we ever have a truly incompatible
43 * bump, we can drop this and compare against LRMD_PROTOCOL_VERSION.
44 */
45#define LRMD_MIN_PROTOCOL_VERSION "1.0"
46
47/* *INDENT-OFF* */
48#define DEFAULT_REMOTE_KEY_LOCATION PACEMAKER_CONFIG_DIR "/authkey"
49#define ALT_REMOTE_KEY_LOCATION "/etc/corosync/authkey"
50#define DEFAULT_REMOTE_PORT 3121
51#define DEFAULT_REMOTE_USERNAME "lrmd"
52
53#define F_LRMD_OPERATION "lrmd_op"
54#define F_LRMD_CLIENTNAME "lrmd_clientname"
55#define F_LRMD_IS_IPC_PROVIDER "lrmd_is_ipc_provider"
56#define F_LRMD_CLIENTID "lrmd_clientid"
57#define F_LRMD_PROTOCOL_VERSION "lrmd_protocol_version"
58#define F_LRMD_REMOTE_MSG_TYPE "lrmd_remote_msg_type"
59#define F_LRMD_REMOTE_MSG_ID "lrmd_remote_msg_id"
60#define F_LRMD_CALLBACK_TOKEN "lrmd_async_id"
61#define F_LRMD_CALLID "lrmd_callid"
62#define F_LRMD_CALLOPTS "lrmd_callopt"
63#define F_LRMD_CALLDATA "lrmd_calldata"
64#define F_LRMD_RC "lrmd_rc"
65#define F_LRMD_EXEC_RC "lrmd_exec_rc"
66#define F_LRMD_OP_STATUS "lrmd_exec_op_status"
67#define F_LRMD_TIMEOUT "lrmd_timeout"
68#define F_LRMD_WATCHDOG "lrmd_watchdog"
69#define F_LRMD_CLASS "lrmd_class"
70#define F_LRMD_PROVIDER "lrmd_provider"
71#define F_LRMD_TYPE "lrmd_type"
72#define F_LRMD_ORIGIN "lrmd_origin"
73
74#define F_LRMD_RSC_RUN_TIME "lrmd_run_time"
75#define F_LRMD_RSC_RCCHANGE_TIME "lrmd_rcchange_time"
76#define F_LRMD_RSC_EXEC_TIME "lrmd_exec_time"
77#define F_LRMD_RSC_QUEUE_TIME "lrmd_queue_time"
78
79#define F_LRMD_RSC_ID "lrmd_rsc_id"
80#define F_LRMD_RSC_ACTION "lrmd_rsc_action"
81#define F_LRMD_RSC_USERDATA_STR "lrmd_rsc_userdata_str"
82#define F_LRMD_RSC_OUTPUT "lrmd_rsc_output"
83#define F_LRMD_RSC_EXIT_REASON "lrmd_rsc_exit_reason"
84#define F_LRMD_RSC_START_DELAY "lrmd_rsc_start_delay"
85#define F_LRMD_RSC_INTERVAL "lrmd_rsc_interval"
86#define F_LRMD_RSC_DELETED "lrmd_rsc_deleted"
87#define F_LRMD_RSC "lrmd_rsc"
88
89#define F_LRMD_ALERT_ID "lrmd_alert_id"
90#define F_LRMD_ALERT_PATH "lrmd_alert_path"
91#define F_LRMD_ALERT "lrmd_alert"
92
93#define LRMD_OP_RSC_REG "lrmd_rsc_register"
94#define LRMD_OP_RSC_EXEC "lrmd_rsc_exec"
95#define LRMD_OP_RSC_CANCEL "lrmd_rsc_cancel"
96#define LRMD_OP_RSC_UNREG "lrmd_rsc_unregister"
97#define LRMD_OP_RSC_INFO "lrmd_rsc_info"
98#define LRMD_OP_RSC_METADATA "lrmd_rsc_metadata"
99#define LRMD_OP_POKE "lrmd_rsc_poke"
100#define LRMD_OP_NEW_CLIENT "lrmd_rsc_new_client"
101#define LRMD_OP_CHECK "lrmd_check"
102#define LRMD_OP_ALERT_EXEC "lrmd_alert_exec"
103#define LRMD_OP_GET_RECURRING "lrmd_get_recurring"
104
105#define LRMD_IPC_OP_NEW "new"
106#define LRMD_IPC_OP_DESTROY "destroy"
107#define LRMD_IPC_OP_EVENT "event"
108#define LRMD_IPC_OP_REQUEST "request"
109#define LRMD_IPC_OP_RESPONSE "response"
110#define LRMD_IPC_OP_SHUTDOWN_REQ "shutdown_req"
111#define LRMD_IPC_OP_SHUTDOWN_ACK "shutdown_ack"
112#define LRMD_IPC_OP_SHUTDOWN_NACK "shutdown_nack"
113
114#define F_LRMD_IPC_OP "lrmd_ipc_op"
115#define F_LRMD_IPC_IPC_SERVER "lrmd_ipc_server"
116#define F_LRMD_IPC_SESSION "lrmd_ipc_session"
117#define F_LRMD_IPC_CLIENT "lrmd_ipc_client"
118#define F_LRMD_IPC_USER "lrmd_ipc_user"
119#define F_LRMD_IPC_MSG "lrmd_ipc_msg"
120#define F_LRMD_IPC_MSG_ID "lrmd_ipc_msg_id"
121#define F_LRMD_IPC_MSG_FLAGS "lrmd_ipc_msg_flags"
122
123#define T_LRMD "lrmd"
124#define T_LRMD_REPLY "lrmd_reply"
125#define T_LRMD_NOTIFY "lrmd_notify"
126#define T_LRMD_IPC_PROXY "lrmd_ipc_proxy"
127#define T_LRMD_RSC_OP "lrmd_rsc_op"
128/* *INDENT-ON* */
129
133lrmd_t *lrmd_api_new(void);
134
144lrmd_t *lrmd_remote_api_new(const char *nodename, const char *server, int port);
145
153bool lrmd_dispatch(lrmd_t * lrmd);
154
162int lrmd_poll(lrmd_t * lrmd, int timeout);
163
167void lrmd_api_delete(lrmd_t * lrmd);
168lrmd_key_value_t *lrmd_key_value_add(lrmd_key_value_t * kvp, const char *key, const char *value);
169
170/* *INDENT-OFF* */
171/* Reserved for future use */
173 lrmd_opt_none = 0x00000000,
174 /* lrmd_opt_sync_call = 0x00000001, //Not implemented, patches welcome. */
184};
185
195
196/* *INDENT-ON* */
197
198typedef struct lrmd_event_data_s {
201
203 const char *rsc_id;
205 const char *op_type;
207 const char *user_data;
208
219
225 const char *output;
227 unsigned int t_run;
229 unsigned int t_rcchange;
231 unsigned int exec_time;
233 unsigned int queue_time;
234
237
238 /* This is a GHashTable containing the
239 * parameters given to the operation */
240 void *params;
241
245 const char *remote_nodename;
246
248 const char *exit_reason;
250
251lrmd_event_data_t *lrmd_new_event(const char *rsc_id, const char *task,
252 guint interval_ms);
255
256typedef struct lrmd_rsc_info_s {
257 char *id;
258 char *type;
259 char *standard;
260 char *provider;
262
269
270lrmd_rsc_info_t *lrmd_new_rsc_info(const char *rsc_id, const char *standard,
271 const char *provider, const char *type);
273void lrmd_free_rsc_info(lrmd_rsc_info_t * rsc_info);
274void lrmd_free_op_info(lrmd_op_info_t *op_info);
275
276typedef void (*lrmd_event_callback) (lrmd_event_data_t * event);
277
278typedef struct lrmd_list_s {
279 const char *val;
282
283void lrmd_list_freeall(lrmd_list_t * head);
285
286typedef struct lrmd_api_operations_s {
292 int (*connect) (lrmd_t * lrmd, const char *client_name, int *fd);
293
301 int (*connect_async) (lrmd_t * lrmd, const char *client_name, int timeout /*ms */ );
302
309 int (*is_connected) (lrmd_t * lrmd);
310
318 int (*poke_connection) (lrmd_t * lrmd);
319
325 int (*disconnect) (lrmd_t * lrmd);
326
334 int (*register_rsc) (lrmd_t * lrmd,
335 const char *rsc_id,
336 const char *standard,
337 const char *provider, const char *agent, enum lrmd_call_options options);
338
345 lrmd_rsc_info_t *(*get_rsc_info) (lrmd_t * lrmd,
346 const char *rsc_id, enum lrmd_call_options options);
347
353 int (*get_recurring_ops) (lrmd_t *lrmd, const char *rsc_id, int timeout_ms,
354 enum lrmd_call_options options, GList **output);
355
368 int (*unregister_rsc) (lrmd_t * lrmd, const char *rsc_id, enum lrmd_call_options options);
369
373 void (*set_callback) (lrmd_t * lrmd, lrmd_event_callback callback);
374
388 int (*exec) (lrmd_t * lrmd, const char *rsc_id, const char *action, const char *userdata, /* userdata string given back in event notification */
389 guint interval_ms,
390 int timeout, /* ms */
391 int start_delay, /* ms */
392 enum lrmd_call_options options, lrmd_key_value_t * params); /* ownership of params is given up to api here */
393
407 int (*cancel) (lrmd_t *lrmd, const char *rsc_id, const char *action,
408 guint interval_ms);
409
432 int (*get_metadata) (lrmd_t * lrmd,
433 const char *standard,
434 const char *provider,
435 const char *agent, char **output, enum lrmd_call_options options);
436
446 int (*list_agents) (lrmd_t * lrmd, lrmd_list_t ** agents,
447 const char *standard, const char *provider);
448
459 int (*list_ocf_providers) (lrmd_t * lrmd, const char *agent, lrmd_list_t ** providers);
460
469 int (*list_standards) (lrmd_t * lrmd, lrmd_list_t ** standards);
470
482 int (*exec_alert) (lrmd_t *lrmd, const char *alert_id,
483 const char *alert_path, int timeout, /* ms */
484 lrmd_key_value_t *params); /* ownership of params is given up to api here */
485
503 int (*get_metadata_params) (lrmd_t *lrmd, const char *standard,
504 const char *provider, const char *agent,
505 char **output, enum lrmd_call_options options,
506 lrmd_key_value_t *params);
507
509
514
515static inline const char *
516lrmd_event_type2str(enum lrmd_callback_event type)
517{
518 switch (type) {
520 return "register";
522 return "unregister";
524 return "exec_complete";
526 return "disconnect";
528 return "connect";
529 case lrmd_event_poke:
530 return "poke";
532 return "new_client";
533 }
534 return "unknown";
535}
536
537#ifdef __cplusplus
538}
539#endif
540
541#endif
enum crm_ais_msg_types type
Definition cpg.c:3
struct lrmd_list_s lrmd_list_t
struct lrmd_rsc_info_s lrmd_rsc_info_t
struct lrmd_op_info_s lrmd_op_info_t
lrmd_rsc_info_t * lrmd_copy_rsc_info(lrmd_rsc_info_t *rsc_info)
lrmd_call_options
Definition lrmd.h:172
@ lrmd_opt_notify_changes_only
Definition lrmd.h:183
@ lrmd_opt_drop_recurring
Definition lrmd.h:181
@ lrmd_opt_notify_orig_only
Definition lrmd.h:176
@ lrmd_opt_none
Definition lrmd.h:173
lrmd_key_value_t * lrmd_key_value_add(lrmd_key_value_t *kvp, const char *key, const char *value)
struct lrmd_event_data_s lrmd_event_data_t
void lrmd_key_value_freeall(lrmd_key_value_t *head)
struct lrmd_api_operations_s lrmd_api_operations_t
bool lrmd_dispatch(lrmd_t *lrmd)
Use after lrmd_poll returns 1 to read and dispatch a message.
void lrmd_free_op_info(lrmd_op_info_t *op_info)
lrmd_callback_event
Definition lrmd.h:186
@ lrmd_event_new_client
Definition lrmd.h:193
@ lrmd_event_connect
Definition lrmd.h:191
@ lrmd_event_unregister
Definition lrmd.h:188
@ lrmd_event_exec_complete
Definition lrmd.h:189
@ lrmd_event_register
Definition lrmd.h:187
@ lrmd_event_poke
Definition lrmd.h:192
@ lrmd_event_disconnect
Definition lrmd.h:190
void lrmd_api_delete(lrmd_t *lrmd)
Destroy executor connection object.
void lrmd_list_freeall(lrmd_list_t *head)
lrmd_t * lrmd_remote_api_new(const char *nodename, const char *server, int port)
Create a new TLS connection to a remote executor.
lrmd_rsc_info_t * lrmd_new_rsc_info(const char *rsc_id, const char *standard, const char *provider, const char *type)
void lrmd_free_event(lrmd_event_data_t *event)
Free an executor event.
struct lrmd_key_value_s lrmd_key_value_t
void lrmd_free_rsc_info(lrmd_rsc_info_t *rsc_info)
lrmd_t * lrmd_api_new(void)
Create a new connection to the local executor.
lrmd_event_data_t * lrmd_new_event(const char *rsc_id, const char *task, guint interval_ms)
void(* lrmd_event_callback)(lrmd_event_data_t *event)
Definition lrmd.h:276
int lrmd_poll(lrmd_t *lrmd, int timeout)
Poll for a specified timeout period to determine if a message is ready for dispatch.
lrmd_event_data_t * lrmd_copy_event(lrmd_event_data_t *event)
unsigned int timeout
Definition pcmk_fence.c:32
const char * action
Definition pcmk_fence.c:30
ocf_exitcode
Definition results.h:150
Services API.
int(* get_metadata_params)(lrmd_t *lrmd, const char *standard, const char *provider, const char *agent, char **output, enum lrmd_call_options options, lrmd_key_value_t *params)
Get resource metadata for a resource agent, passing parameters.
Definition lrmd.h:503
int(* cancel)(lrmd_t *lrmd, const char *rsc_id, const char *action, guint interval_ms)
Cancel a recurring command.
Definition lrmd.h:407
int(* connect_async)(lrmd_t *lrmd, const char *client_name, int timeout)
Initiate an executor connection without blocking.
Definition lrmd.h:301
int(* get_metadata)(lrmd_t *lrmd, const char *standard, const char *provider, const char *agent, char **output, enum lrmd_call_options options)
Get resource metadata for a specified resource agent.
Definition lrmd.h:432
int(* list_standards)(lrmd_t *lrmd, lrmd_list_t **standards)
Retrieve a list of standards supported by this machine/installation.
Definition lrmd.h:469
int(* list_agents)(lrmd_t *lrmd, lrmd_list_t **agents, const char *standard, const char *provider)
Retrieve a list of installed resource agents.
Definition lrmd.h:446
int(* disconnect)(lrmd_t *lrmd)
Disconnect from the executor.
Definition lrmd.h:325
int(* list_ocf_providers)(lrmd_t *lrmd, const char *agent, lrmd_list_t **providers)
Retrieve a list of resource agent providers.
Definition lrmd.h:459
int(* exec_alert)(lrmd_t *lrmd, const char *alert_id, const char *alert_path, int timeout, lrmd_key_value_t *params)
Execute an alert agent.
Definition lrmd.h:482
int(* connect)(lrmd_t *lrmd, const char *client_name, int *fd)
Connect to an executor.
Definition lrmd.h:292
int(* exec)(lrmd_t *lrmd, const char *rsc_id, const char *action, const char *userdata, guint interval_ms, int timeout, int start_delay, enum lrmd_call_options options, lrmd_key_value_t *params)
Issue a command on a resource.
Definition lrmd.h:388
int(* get_recurring_ops)(lrmd_t *lrmd, const char *rsc_id, int timeout_ms, enum lrmd_call_options options, GList **output)
Retrieve registered recurring operations.
Definition lrmd.h:353
int(* register_rsc)(lrmd_t *lrmd, const char *rsc_id, const char *standard, const char *provider, const char *agent, enum lrmd_call_options options)
Register a resource with the executor.
Definition lrmd.h:334
int(* is_connected)(lrmd_t *lrmd)
Is connected to lrmd daemon?
Definition lrmd.h:309
int(* poke_connection)(lrmd_t *lrmd)
Poke executor connection to verify it is still capable of serving requests.
Definition lrmd.h:318
int(* unregister_rsc)(lrmd_t *lrmd, const char *rsc_id, enum lrmd_call_options options)
Unregister a resource from the executor.
Definition lrmd.h:368
void(* set_callback)(lrmd_t *lrmd, lrmd_event_callback callback)
Set a callback for executor events.
Definition lrmd.h:373
const char * op_type
Definition lrmd.h:205
unsigned int t_run
Definition lrmd.h:227
unsigned int t_rcchange
Definition lrmd.h:229
const char * remote_nodename
Definition lrmd.h:245
const char * exit_reason
Definition lrmd.h:248
const char * user_data
Definition lrmd.h:207
const char * output
Definition lrmd.h:225
unsigned int exec_time
Definition lrmd.h:231
enum lrmd_callback_event type
Definition lrmd.h:200
enum ocf_exitcode rc
Definition lrmd.h:221
unsigned int queue_time
Definition lrmd.h:233
void * params
Definition lrmd.h:240
guint interval_ms
Definition lrmd.h:214
int connection_rc
Definition lrmd.h:236
const char * rsc_id
Definition lrmd.h:203
char * key
Definition lrmd.h:29
struct lrmd_key_value_s * next
Definition lrmd.h:31
char * value
Definition lrmd.h:30
const char * val
Definition lrmd.h:279
struct lrmd_list_s * next
Definition lrmd.h:280
char * timeout_ms_s
Definition lrmd.h:267
char * rsc_id
Definition lrmd.h:264
char * interval_ms_s
Definition lrmd.h:266
char * action
Definition lrmd.h:265
char * id
Definition lrmd.h:257
char * standard
Definition lrmd.h:259
char * type
Definition lrmd.h:258
char * provider
Definition lrmd.h:260
Definition lrmd.h:510
void * lrmd_private
Definition lrmd.h:512
lrmd_api_operations_t * cmds
Definition lrmd.h:511