10 #ifndef PCMK__CRM_LRMD__H 11 # define PCMK__CRM_LRMD__H 38 #define LRMD_PROTOCOL_VERSION "1.1" 46 #define LRMD_MIN_PROTOCOL_VERSION "1.0" 49 #define DEFAULT_REMOTE_KEY_LOCATION PACEMAKER_CONFIG_DIR "/authkey" 50 #define ALT_REMOTE_KEY_LOCATION "/etc/corosync/authkey" 51 #define DEFAULT_REMOTE_PORT 3121 52 #define DEFAULT_REMOTE_USERNAME "lrmd" 54 #define F_LRMD_OPERATION "lrmd_op" 55 #define F_LRMD_CLIENTNAME "lrmd_clientname" 56 #define F_LRMD_IS_IPC_PROVIDER "lrmd_is_ipc_provider" 57 #define F_LRMD_CLIENTID "lrmd_clientid" 58 #define F_LRMD_PROTOCOL_VERSION "lrmd_protocol_version" 59 #define F_LRMD_REMOTE_MSG_TYPE "lrmd_remote_msg_type" 60 #define F_LRMD_REMOTE_MSG_ID "lrmd_remote_msg_id" 61 #define F_LRMD_CALLBACK_TOKEN "lrmd_async_id" 62 #define F_LRMD_CALLID "lrmd_callid" 63 #define F_LRMD_CALLOPTS "lrmd_callopt" 64 #define F_LRMD_CALLDATA "lrmd_calldata" 65 #define F_LRMD_RC "lrmd_rc" 66 #define F_LRMD_EXEC_RC "lrmd_exec_rc" 67 #define F_LRMD_OP_STATUS "lrmd_exec_op_status" 68 #define F_LRMD_TIMEOUT "lrmd_timeout" 69 #define F_LRMD_WATCHDOG "lrmd_watchdog" 70 #define F_LRMD_CLASS "lrmd_class" 71 #define F_LRMD_PROVIDER "lrmd_provider" 72 #define F_LRMD_TYPE "lrmd_type" 73 #define F_LRMD_ORIGIN "lrmd_origin" 75 #define F_LRMD_RSC_RUN_TIME "lrmd_run_time" 76 #define F_LRMD_RSC_RCCHANGE_TIME "lrmd_rcchange_time" 77 #define F_LRMD_RSC_EXEC_TIME "lrmd_exec_time" 78 #define F_LRMD_RSC_QUEUE_TIME "lrmd_queue_time" 80 #define F_LRMD_RSC_ID "lrmd_rsc_id" 81 #define F_LRMD_RSC_ACTION "lrmd_rsc_action" 82 #define F_LRMD_RSC_USERDATA_STR "lrmd_rsc_userdata_str" 83 #define F_LRMD_RSC_OUTPUT "lrmd_rsc_output" 84 #define F_LRMD_RSC_EXIT_REASON "lrmd_rsc_exit_reason" 85 #define F_LRMD_RSC_START_DELAY "lrmd_rsc_start_delay" 86 #define F_LRMD_RSC_INTERVAL "lrmd_rsc_interval" 87 #define F_LRMD_RSC_DELETED "lrmd_rsc_deleted" 88 #define F_LRMD_RSC "lrmd_rsc" 90 #define F_LRMD_ALERT_ID "lrmd_alert_id" 91 #define F_LRMD_ALERT_PATH "lrmd_alert_path" 92 #define F_LRMD_ALERT "lrmd_alert" 94 #define LRMD_OP_RSC_REG "lrmd_rsc_register" 95 #define LRMD_OP_RSC_EXEC "lrmd_rsc_exec" 96 #define LRMD_OP_RSC_CANCEL "lrmd_rsc_cancel" 97 #define LRMD_OP_RSC_UNREG "lrmd_rsc_unregister" 98 #define LRMD_OP_RSC_INFO "lrmd_rsc_info" 99 #define LRMD_OP_RSC_METADATA "lrmd_rsc_metadata" 100 #define LRMD_OP_POKE "lrmd_rsc_poke" 101 #define LRMD_OP_NEW_CLIENT "lrmd_rsc_new_client" 102 #define LRMD_OP_CHECK "lrmd_check" 103 #define LRMD_OP_ALERT_EXEC "lrmd_alert_exec" 104 #define LRMD_OP_GET_RECURRING "lrmd_get_recurring" 106 #define LRMD_IPC_OP_NEW "new" 107 #define LRMD_IPC_OP_DESTROY "destroy" 108 #define LRMD_IPC_OP_EVENT "event" 109 #define LRMD_IPC_OP_REQUEST "request" 110 #define LRMD_IPC_OP_RESPONSE "response" 111 #define LRMD_IPC_OP_SHUTDOWN_REQ "shutdown_req" 112 #define LRMD_IPC_OP_SHUTDOWN_ACK "shutdown_ack" 113 #define LRMD_IPC_OP_SHUTDOWN_NACK "shutdown_nack" 115 #define F_LRMD_IPC_OP "lrmd_ipc_op" 116 #define F_LRMD_IPC_IPC_SERVER "lrmd_ipc_server" 117 #define F_LRMD_IPC_SESSION "lrmd_ipc_session" 118 #define F_LRMD_IPC_CLIENT "lrmd_ipc_client" 119 #define F_LRMD_IPC_USER "lrmd_ipc_user" 120 #define F_LRMD_IPC_MSG "lrmd_ipc_msg" 121 #define F_LRMD_IPC_MSG_ID "lrmd_ipc_msg_id" 122 #define F_LRMD_IPC_MSG_FLAGS "lrmd_ipc_msg_flags" 124 #define T_LRMD "lrmd" 125 #define T_LRMD_REPLY "lrmd_reply" 126 #define T_LRMD_NOTIFY "lrmd_notify" 127 #define T_LRMD_IPC_PROXY "lrmd_ipc_proxy" 128 #define T_LRMD_RSC_OP "lrmd_rsc_op" 289 const char *provider,
const char *
type);
377 const char *provider,
const char *agent,
457 const char *userdata, guint interval_ms,
int timeout,
504 const char *provider,
const char *agent,
522 const char *standard,
const char *provider);
571 const char *alert_path,
int timeout,
591 const char *provider,
const char *agent,
602 static inline const char *
611 return "exec_complete";
struct lrmd_rsc_info_s lrmd_rsc_info_t
ocf_exitcode
Exit status codes for resource agents.
int(* get_recurring_ops)(lrmd_t *lrmd, const char *rsc_id, int timeout_ms, enum lrmd_call_options options, GList **output)
Retrieve recurring operations registered for a resource.
int(* connect_async)(lrmd_t *lrmd, const char *client_name, int timeout)
Initiate an executor connection without blocking.
void(* lrmd_event_callback)(lrmd_event_data_t *event)
void lrmd_free_op_info(lrmd_op_info_t *op_info)
void lrmd_list_freeall(lrmd_list_t *head)
void lrmd_free_event(lrmd_event_data_t *event)
Free an executor event.
struct lrmd_event_data_s lrmd_event_data_t
enum crm_ais_msg_types type
int(* cancel)(lrmd_t *lrmd, const char *rsc_id, const char *action, guint interval_ms)
Cancel a recurring resource action.
lrmd_t * lrmd_remote_api_new(const char *nodename, const char *server, int port)
Create a new TLS connection to a remote executor.
Send notifications for recurring operations only when the result changes.
struct lrmd_api_operations_s lrmd_api_operations_t
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)
Request execution of a resource action.
lrmd_rsc_info_t * lrmd_new_rsc_info(const char *rsc_id, const char *standard, const char *provider, const char *type)
lrmd_rsc_info_t * lrmd_copy_rsc_info(lrmd_rsc_info_t *rsc_info)
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.
int(* poke_connection)(lrmd_t *lrmd)
Poke executor connection to verify it is still active.
struct lrmd_list_s * next
int(* connect)(lrmd_t *lrmd, const char *client_name, int *fd)
Connect to an executor.
lrmd_t * lrmd_api_new(void)
Create a new connection to the local executor.
bool lrmd_dispatch(lrmd_t *lrmd)
Use after lrmd_poll returns 1 to read and dispatch a message.
lrmd_key_value_t * lrmd_key_value_add(lrmd_key_value_t *kvp, const char *key, const char *value)
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)
Retrieve resource agent metadata synchronously with parameters.
Notify only the client that made the request (rather than all clients)
struct lrmd_key_value_s * next
int(* list_agents)(lrmd_t *lrmd, lrmd_list_t **agents, const char *standard, const char *provider)
Retrieve a list of installed resource agents.
int(* unregister_rsc)(lrmd_t *lrmd, const char *rsc_id, enum lrmd_call_options options)
Unregister a resource from the executor.
int(* disconnect)(lrmd_t *lrmd)
Disconnect from the executor.
void lrmd_key_value_freeall(lrmd_key_value_t *head)
lrmd_event_data_t * lrmd_new_event(const char *rsc_id, const char *task, guint interval_ms)
struct lrmd_key_value_s lrmd_key_value_t
const char * remote_nodename
lrmd_api_operations_t * cmds
enum lrmd_callback_event type
int(* list_standards)(lrmd_t *lrmd, lrmd_list_t **standards)
Retrieve a list of supported standards.
lrmd_event_data_t * lrmd_copy_event(lrmd_event_data_t *event)
int lrmd_poll(lrmd_t *lrmd, int timeout)
Check whether a message is available on an executor connection.
int(* list_ocf_providers)(lrmd_t *lrmd, const char *agent, lrmd_list_t **providers)
Retrieve a list of resource agent providers.
struct lrmd_list_s lrmd_list_t
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.
void lrmd_free_rsc_info(lrmd_rsc_info_t *rsc_info)
struct lrmd_op_info_s lrmd_op_info_t
void lrmd_api_delete(lrmd_t *lrmd)
Destroy executor connection object.
int(* is_connected)(lrmd_t *lrmd)
Check whether connection to executor daemon is (still) active.
int(* get_metadata)(lrmd_t *lrmd, const char *standard, const char *provider, const char *agent, char **output, enum lrmd_call_options options)
Retrieve resource agent metadata synchronously.
void(* set_callback)(lrmd_t *lrmd, lrmd_event_callback callback)
Set a callback for executor events.