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.