pacemaker
2.1.3-ea053b43a
Scalable High-Availability cluster resource manager
|
Services API. More...
#include <glib.h>
#include <stdio.h>
#include <stdint.h>
#include <string.h>
#include <stdbool.h>
#include <sys/types.h>
#include <crm_config.h>
#include "common/results.h"
#include <crm/services_compat.h>
Go to the source code of this file.
Data Structures | |
struct | svc_action_s |
Object for executing external actions. More... | |
Macros | |
#define | SYSTEMCTL "/bin/systemctl" |
#define | PCMK_RESOURCE_CLASS_OCF "ocf" |
#define | PCMK_RESOURCE_CLASS_SERVICE "service" |
#define | PCMK_RESOURCE_CLASS_LSB "lsb" |
#define | PCMK_RESOURCE_CLASS_SYSTEMD "systemd" |
#define | PCMK_RESOURCE_CLASS_UPSTART "upstart" |
#define | PCMK_RESOURCE_CLASS_NAGIOS "nagios" |
#define | PCMK_RESOURCE_CLASS_STONITH "stonith" |
#define | PCMK_RESOURCE_CLASS_ALERT "alert" |
#define | PCMK_OCF_REASON_PREFIX "ocf-exit-reason:" |
#define | PCMK_DEFAULT_AGENT_VERSION "0.1" |
Typedefs | |
typedef struct svc_action_private_s | svc_action_private_t |
typedef struct svc_action_s | svc_action_t |
Object for executing external actions. More... | |
Enumerations | |
enum | lsb_exitcode { PCMK_LSB_OK = 0, PCMK_LSB_UNKNOWN_ERROR = 1, PCMK_LSB_INVALID_PARAM = 2, PCMK_LSB_UNIMPLEMENT_FEATURE = 3, PCMK_LSB_INSUFFICIENT_PRIV = 4, PCMK_LSB_NOT_INSTALLED = 5, PCMK_LSB_NOT_CONFIGURED = 6, PCMK_LSB_NOT_RUNNING = 7 } |
enum | lsb_status_exitcode { PCMK_LSB_STATUS_OK = 0, PCMK_LSB_STATUS_VAR_PID = 1, PCMK_LSB_STATUS_VAR_LOCK = 2, PCMK_LSB_STATUS_NOT_RUNNING = 3, PCMK_LSB_STATUS_UNKNOWN = 4, PCMK_LSB_STATUS_NOT_INSTALLED = 150, PCMK_LSB_STATUS_INSUFFICIENT_PRIV = 151 } |
enum | nagios_exitcode { NAGIOS_STATE_OK = 0, NAGIOS_STATE_WARNING = 1, NAGIOS_STATE_CRITICAL = 2, NAGIOS_STATE_UNKNOWN = 3, NAGIOS_INSUFFICIENT_PRIV = 100, NAGIOS_STATE_DEPENDENT = 4, NAGIOS_NOT_INSTALLED = 101 } |
enum | svc_action_flags { SVC_ACTION_LEAVE_GROUP = 0x01, SVC_ACTION_NON_BLOCKED = 0x02 } |
Functions | |
GList * | get_directory_list (const char *root, gboolean files, gboolean executable) |
Get a list of files or directories in a given path. More... | |
GList * | resources_list_providers (const char *standard) |
Get a list of providers. More... | |
GList * | resources_list_agents (const char *standard, const char *provider) |
Get a list of resource agents. More... | |
GList * | resources_list_standards (void) |
gboolean | resources_agent_exists (const char *standard, const char *provider, const char *agent) |
svc_action_t * | resources_action_create (const char *name, const char *standard, const char *provider, const char *agent, const char *action, guint interval_ms, int timeout, GHashTable *params, enum svc_action_flags flags) |
Create a new resource action. More... | |
gboolean | services_action_kick (const char *name, const char *action, guint interval_ms) |
const char * | resources_find_service_class (const char *agent) |
Find first service class that can provide a specified agent. More... | |
svc_action_t * | services_action_create_generic (const char *exec, const char *args[]) |
void | services_action_cleanup (svc_action_t *op) |
void | services_action_free (svc_action_t *op) |
int | services_action_user (svc_action_t *op, const char *user) |
Set the user and group that an action will execute as. More... | |
gboolean | services_action_sync (svc_action_t *op) |
gboolean | services_action_async_fork_notify (svc_action_t *op, void(*action_callback)(svc_action_t *), void(*action_fork_callback)(svc_action_t *)) |
Run an action asynchronously, with callback after process is forked. More... | |
gboolean | services_action_async (svc_action_t *op, void(*action_callback)(svc_action_t *)) |
Run an action asynchronously. More... | |
gboolean | services_action_cancel (const char *name, const char *action, guint interval_ms) |
Cancel a recurring action. More... | |
svc_action_t * | services_alert_create (const char *id, const char *exec, int timeout, GHashTable *params, int sequence, void *cb_data) |
Create an alert agent action. More... | |
gboolean | services_alert_async (svc_action_t *action, void(*cb)(svc_action_t *op)) |
Execute an alert agent action. More... | |
enum ocf_exitcode | services_result2ocf (const char *standard, const char *action, int exit_status) |
Services API.
Definition in file services.h.
#define PCMK_DEFAULT_AGENT_VERSION "0.1" |
Definition at line 55 of file services.h.
#define PCMK_OCF_REASON_PREFIX "ocf-exit-reason:" |
Definition at line 52 of file services.h.
#define PCMK_RESOURCE_CLASS_ALERT "alert" |
Definition at line 46 of file services.h.
#define PCMK_RESOURCE_CLASS_LSB "lsb" |
Definition at line 41 of file services.h.
#define PCMK_RESOURCE_CLASS_NAGIOS "nagios" |
Definition at line 44 of file services.h.
#define PCMK_RESOURCE_CLASS_OCF "ocf" |
Definition at line 39 of file services.h.
#define PCMK_RESOURCE_CLASS_SERVICE "service" |
Definition at line 40 of file services.h.
#define PCMK_RESOURCE_CLASS_STONITH "stonith" |
Definition at line 45 of file services.h.
#define PCMK_RESOURCE_CLASS_SYSTEMD "systemd" |
Definition at line 42 of file services.h.
#define PCMK_RESOURCE_CLASS_UPSTART "upstart" |
Definition at line 43 of file services.h.
#define SYSTEMCTL "/bin/systemctl" |
Definition at line 35 of file services.h.
typedef struct svc_action_private_s svc_action_private_t |
Definition at line 107 of file services.h.
typedef struct svc_action_s svc_action_t |
Object for executing external actions.
enum lsb_exitcode |
Enumerator | |
---|---|
PCMK_LSB_OK | |
PCMK_LSB_UNKNOWN_ERROR | |
PCMK_LSB_INVALID_PARAM | |
PCMK_LSB_UNIMPLEMENT_FEATURE | |
PCMK_LSB_INSUFFICIENT_PRIV | |
PCMK_LSB_NOT_INSTALLED | |
PCMK_LSB_NOT_CONFIGURED | |
PCMK_LSB_NOT_RUNNING |
Definition at line 57 of file services.h.
enum lsb_status_exitcode |
Enumerator | |
---|---|
PCMK_LSB_STATUS_OK | |
PCMK_LSB_STATUS_VAR_PID | |
PCMK_LSB_STATUS_VAR_LOCK | |
PCMK_LSB_STATUS_NOT_RUNNING | |
PCMK_LSB_STATUS_UNKNOWN | |
PCMK_LSB_STATUS_NOT_INSTALLED | |
PCMK_LSB_STATUS_INSUFFICIENT_PRIV |
Definition at line 71 of file services.h.
enum nagios_exitcode |
Enumerator | |
---|---|
NAGIOS_STATE_OK | |
NAGIOS_STATE_WARNING | |
NAGIOS_STATE_CRITICAL | |
NAGIOS_STATE_UNKNOWN | |
NAGIOS_INSUFFICIENT_PRIV | |
NAGIOS_STATE_DEPENDENT | |
NAGIOS_NOT_INSTALLED |
|
Definition at line 83 of file services.h.
enum svc_action_flags |
Enumerator | |
---|---|
SVC_ACTION_LEAVE_GROUP | |
SVC_ACTION_NON_BLOCKED |
Definition at line 101 of file services.h.
GList* get_directory_list | ( | const char * | root, |
gboolean | files, | ||
gboolean | executable | ||
) |
Get a list of files or directories in a given path.
[in] | root | full path to a directory to read |
[in] | files | return list of files if TRUE or directories if FALSE |
[in] | executable | if TRUE and files is TRUE, only return executable files |
Definition at line 1055 of file services.c.
svc_action_t* resources_action_create | ( | const char * | name, |
const char * | standard, | ||
const char * | provider, | ||
const char * | agent, | ||
const char * | action, | ||
guint | interval_ms, | ||
int | timeout, | ||
GHashTable * | params, | ||
enum svc_action_flags | flags | ||
) |
Create a new resource action.
[in] | name | Name of resource |
[in] | standard | Resource agent standard (ocf, lsb, etc.) |
[in] | provider | Resource agent provider |
[in] | agent | Resource agent name |
[in] | action | action (start, stop, monitor, etc.) |
[in] | interval_ms | How often to repeat this action (if 0, execute once) |
[in] | timeout | Consider action failed if it does not complete in this many milliseconds |
[in] | params | Action parameters |
Definition at line 335 of file services.c.
gboolean resources_agent_exists | ( | const char * | standard, |
const char * | provider, | ||
const char * | agent | ||
) |
Does the given standard, provider, and agent describe a resource that can exist?
[in] | standard | Which class of agent does the resource belong to? |
[in] | provider | What provides the agent (NULL for most standards)? |
[in] | agent | What is the name of the agent? |
Definition at line 1175 of file services.c.
const char* resources_find_service_class | ( | const char * | agent | ) |
Find first service class that can provide a specified agent.
[in] | agent | Name of agent to search for |
Definition at line 72 of file services.c.
GList* resources_list_agents | ( | const char * | standard, |
const char * | provider | ||
) |
Get a list of resource agents.
[in] | standard | list agents using this standard (e.g. ocf, lsb, etc.) (or NULL for all) |
[in] | provider | list agents from this provider (or NULL for all) |
Definition at line 1119 of file services.c.
GList* resources_list_providers | ( | const char * | standard | ) |
Get a list of providers.
[in] | standard | list providers of this standard (e.g. ocf, lsb, etc.) |
Definition at line 1109 of file services.c.
GList* resources_list_standards | ( | void | ) |
Get list of available standards
Definition at line 1061 of file services.c.
gboolean services_action_async | ( | svc_action_t * | op, |
void(*)(svc_action_t *) | action_callback | ||
) |
Run an action asynchronously.
[in] | op | Action to run |
[in] | action_callback | Function to call when the action completes (if NULL, any previously set callback will continue to be used) |
TRUE | if the caller should not free or otherwise use op again, because one of these conditions is true: |
op
is NULL.action_callback
has not been called (it will be called when the action completes).op
and has been re-initiated asynchronously, and op
has been freed.op
will be blocked until it completes.action_callback
has been called, and op
has been freed.FALSE | if is still valid, because the action cannot be initiated, and is a recurring action that is not being cancelled. action_callback has been called, and a timer has been set for the next invocation of op . |
Definition at line 901 of file services.c.
gboolean services_action_async_fork_notify | ( | svc_action_t * | op, |
void(*)(svc_action_t *) | action_callback, | ||
void(*)(svc_action_t *) | action_fork_callback | ||
) |
Run an action asynchronously, with callback after process is forked.
[in] | op | Action to run |
[in] | action_callback | Function to call when the action completes (if NULL, any previously set callback will continue to be used) |
[in] | action_fork_callback | Function to call after action process forks (if NULL, any previously set callback will continue to be used) |
TRUE | if the caller should not free or otherwise use op again, because one of these conditions is true: |
op
is NULL.action_fork_callback
has been called, but action_callback
has not (it will be called when the action completes).op
and has been re-initiated asynchronously, and op
has been freed.op
will be blocked until it completes.action_fork_callback
has not been called, but action_callback
has, and op
has been freed.FALSE | if is still valid, because the action cannot be initiated, and is a recurring action that is not being cancelled. action_fork_callback has not been called, but action_callback has, and a timer has been set for the next invocation of op . |
Definition at line 867 of file services.c.
gboolean services_action_cancel | ( | const char * | name, |
const char * | action, | ||
guint | interval_ms | ||
) |
Cancel a recurring action.
[in] | name | Name of resource that operation is for |
[in] | action | Name of operation to cancel |
[in] | interval_ms | Interval of operation to cancel |
Definition at line 664 of file services.c.
void services_action_cleanup | ( | svc_action_t * | op | ) |
Definition at line 501 of file services.c.
svc_action_t* services_action_create_generic | ( | const char * | exec, |
const char * | args[] | ||
) |
Utilize services API to execute an arbitrary command.
This API has useful infrastructure in place to be able to run a command in the background and get notified via a callback when the command finishes.
[in] | exec | command to execute |
[in] | args | arguments to the command, NULL terminated |
Definition at line 356 of file services.c.
void services_action_free | ( | svc_action_t * | op | ) |
Definition at line 585 of file services.c.
gboolean services_action_kick | ( | const char * | name, |
const char * | action, | ||
guint | interval_ms | ||
) |
Kick a recurring action so it is scheduled immediately for re-execution
Definition at line 732 of file services.c.
gboolean services_action_sync | ( | svc_action_t * | op | ) |
Definition at line 1020 of file services.c.
int services_action_user | ( | svc_action_t * | op, |
const char * | user | ||
) |
Set the user and group that an action will execute as.
[in,out] | action | Action to modify |
[in] | user | Name of user to execute action as |
[in] | group | Name of group to execute action as |
Definition at line 445 of file services.c.
gboolean services_alert_async | ( | svc_action_t * | action, |
void(*)(svc_action_t *op) | cb | ||
) |
Execute an alert agent action.
[in] | action | Action to execute |
[in] | cb | Function to call when action completes |
Definition at line 465 of file services.c.
svc_action_t* services_alert_create | ( | const char * | id, |
const char * | exec, | ||
int | timeout, | ||
GHashTable * | params, | ||
int | sequence, | ||
void * | cb_data | ||
) |
Create an alert agent action.
[in] | id | Alert ID |
[in] | exec | Path to alert agent executable |
[in] | timeout | Action timeout |
[in] | params | Parameters to use with action |
[in] | sequence | Action sequence number |
[in] | cb_data | Data to pass to callback function |
Definition at line 413 of file services.c.
enum ocf_exitcode services_result2ocf | ( | const char * | standard, |
const char * | action, | ||
int | exit_status | ||
) |
Definition at line 550 of file services.c.