#include <crm_internal.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <stdint.h>
#include <stdarg.h>
#include <string.h>
#include <ctype.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <glib.h>
#include <dirent.h>
#include <crm/crm.h>
#include <crm/lrmd.h>
#include <crm/lrmd_internal.h>
#include <crm/services.h>
#include <crm/common/mainloop.h>
#include <crm/common/ipc_internal.h>
#include <crm/common/remote_internal.h>
#include <crm/msg_xml.h>
#include <crm/stonith-ng.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <arpa/inet.h>
#include <netdb.h>
Go to the source code of this file.
|
| CRM_TRACE_INIT_DATA (lrmd) |
|
int | lrmd_internal_proxy_send (lrmd_t *lrmd, xmlNode *msg) |
|
void | lrmd_internal_set_proxy_callback (lrmd_t *lrmd, void *userdata, void(*callback)(lrmd_t *lrmd, void *userdata, xmlNode *msg)) |
|
void | lrmd_list_freeall (lrmd_list_t *head) |
|
lrmd_key_value_t * | lrmd_key_value_add (lrmd_key_value_t *head, const char *key, const char *value) |
|
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) |
|
lrmd_event_data_t * | lrmd_copy_event (lrmd_event_data_t *event) |
|
void | lrmd_free_event (lrmd_event_data_t *event) |
| Free an executor event. More...
|
|
int | lrmd_poll (lrmd_t *lrmd, int timeout) |
| Poll for a specified timeout period to determine if a message is ready for dispatch. More...
|
|
bool | lrmd_dispatch (lrmd_t *lrmd) |
| Use after lrmd_poll returns 1 to read and dispatch a message. More...
|
|
int | lrmd__validate_remote_settings (lrmd_t *lrmd, GHashTable *hash) |
|
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) |
|
void | lrmd_free_rsc_info (lrmd_rsc_info_t *rsc_info) |
|
void | lrmd_free_op_info (lrmd_op_info_t *op_info) |
|
lrmd_t * | lrmd_api_new (void) |
| Create a new connection to the local executor. More...
|
|
lrmd_t * | lrmd_remote_api_new (const char *nodename, const char *server, int port) |
| Create a new TLS connection to a remote executor. More...
|
|
void | lrmd_api_delete (lrmd_t *lrmd) |
| Destroy executor connection object. More...
|
|
◆ MAX_TLS_RECV_WAIT
#define MAX_TLS_RECV_WAIT 10000 |
◆ lrmd_private_t
◆ CRM_TRACE_INIT_DATA()
CRM_TRACE_INIT_DATA |
( |
lrmd |
| ) |
|
◆ lrmd__validate_remote_settings()
int lrmd__validate_remote_settings |
( |
lrmd_t * |
lrmd, |
|
|
GHashTable * |
hash |
|
) |
| |
◆ lrmd_api_delete()
void lrmd_api_delete |
( |
lrmd_t * |
lrmd | ) |
|
◆ lrmd_api_new()
Create a new connection to the local executor.
Definition at line 2194 of file lrmd_client.c.
◆ lrmd_copy_event()
◆ lrmd_copy_rsc_info()
◆ lrmd_dispatch()
bool lrmd_dispatch |
( |
lrmd_t * |
lrmd | ) |
|
Use after lrmd_poll returns 1 to read and dispatch a message.
- Parameters
-
[in,out] | lrmd | Executor connection object |
- Returns
- TRUE if connection is still up, FALSE if disconnected
Definition at line 475 of file lrmd_client.c.
◆ lrmd_free_event()
Free an executor event.
- Parameters
-
[in] | Executor | event object to free |
Definition at line 240 of file lrmd_client.c.
◆ lrmd_free_op_info()
◆ lrmd_free_rsc_info()
◆ lrmd_internal_proxy_send()
int lrmd_internal_proxy_send |
( |
lrmd_t * |
lrmd, |
|
|
xmlNode * |
msg |
|
) |
| |
◆ lrmd_internal_set_proxy_callback()
void lrmd_internal_set_proxy_callback |
( |
lrmd_t * |
lrmd, |
|
|
void * |
userdata, |
|
|
void(*)(lrmd_t *lrmd, void *userdata, xmlNode *msg) |
callback |
|
) |
| |
◆ lrmd_key_value_add()
◆ lrmd_key_value_freeall()
◆ lrmd_list_freeall()
◆ lrmd_new_event()
lrmd_event_data_t* lrmd_new_event |
( |
const char * |
rsc_id, |
|
|
const char * |
task, |
|
|
guint |
interval_ms |
|
) |
| |
Create a new lrmd_event_data_t object
- Parameters
-
[in] | rsc_id | ID of resource involved in event |
[in] | task | Action name |
[in] | interval_ms | Action interval |
- Returns
- Newly allocated and initialized lrmd_event_data_t
- Note
- This functions asserts on memory errors, so the return value is guaranteed to be non-NULL. The caller is responsible for freeing the result with lrmd_free_event().
Definition at line 194 of file lrmd_client.c.
◆ lrmd_new_rsc_info()
lrmd_rsc_info_t* lrmd_new_rsc_info |
( |
const char * |
rsc_id, |
|
|
const char * |
standard, |
|
|
const char * |
provider, |
|
|
const char * |
type |
|
) |
| |
◆ lrmd_poll()
int lrmd_poll |
( |
lrmd_t * |
lrmd, |
|
|
int |
timeout |
|
) |
| |
Poll for a specified timeout period to determine if a message is ready for dispatch.
- Return values
-
1 | msg is ready |
0 | timeout occurred |
negative | error code |
Definition at line 441 of file lrmd_client.c.
◆ lrmd_remote_api_new()
lrmd_t* lrmd_remote_api_new |
( |
const char * |
nodename, |
|
|
const char * |
server, |
|
|
int |
port |
|
) |
| |
Create a new TLS connection to a remote executor.
- Parameters
-
nodename | name of remote node identified with this connection |
server | name of server to connect to |
port | port number to connect to |
- Note
- nodename and server may be the same value.
Definition at line 2230 of file lrmd_client.c.