ham_action_notify_signal()
Add a notify-signal action to a condition
Synopsis:
#include <ha/ham.h>
ham_action_t *ham_action_notify_signal(
                ham_condition_t *chdl,
                const char *aname,
                int reserved,
                pid_t topid,
                int signum,
                int code,
                int value,
                unsigned flags);
Arguments:
- chdl
- The HAM condition handle to which the action is added.
- aname
- The name of the action to add.
- reserved
- Set this argument to 0.
- topid
- The process ID of the targeted process.
- signum
- Signum specifies the signal to deliver.
- code
- The code of the signal to deliver.
- value
- The value of the signal to deliver.
- flags
- The flags indicating how the action should be operated. See below.
Library:
libham
Description:
This function adds an action to a given condition. The action will deliver a signal notification to the process given in topid.
The handle (chdl) is obtained either:
- 
            from one of the ham_condition*() functions to add conditions
            or: 
- by calling any of the ham_condition_handle() functions to request a handle to a specific condition.
The action is executed when the appropriate condition is triggered.
The signal in signum with the given value will be delivered to the process pid. This can also be used to terminate processes by sending them appropriate signals like SIGTERM, SIGKILL etc.
Currently the following flags are defined:
- HREARMAFTERRESTART
- Indicates that the action is to be automatically rearmed after the entity that it belongs to is restarted.
- HACTIONBREAKONFAIL
- Indicates that if this action were to fail, and it is part of a list of actions, none of the actions following this one in the list of actions will be executed.
- HACTIONKEEPONFAIL
- Indicates that the action will be retained even if it fails. The default behavior is to remove failed actions. Nevertheless, if the condition that this action is associated with is not retained, the action will get automatically removed.
Users can specify what will be done if an action fails. By adding action fail actions to a list associated with an action, users can determine what will be done in the case of an action failure. For every action that fails, the corresponding action fail list will be executed. Certain actions (e.g., ham_action_log() and ham_action_heartbeat_healthy()) never fail. For more details, refer to the appropriate section in the HAM API reference for the ham_action_fail_*() calls.
Returns:
A valid handle to an action to a condition, or NULL if an error occurred (errno is set).
Errors:
- EBADF
- Couldn't connect to the HAM.
- EEXIST
- The name provided for the action already exists.
- EINVAL
- 
                The name given in aname is invalid (e.g., it
                contains the 
 character) or is NULL./
- ENAMETOOLONG
- 
                The name given is too long, (i.e., it exceeds
                _POSIX_PATH_MAX, defined in <limits.h>).
                Note:The combined name length of an entity, condition, or action is also limited by _POSIX_PATH_MAX.
- ENOENT
- There's no action of the name aname in a condition cname defined in an entity ename in the HAM's current context.
- ENOMEM
- Not enough memory to create a new handle.
In addition to the above errors, the HAM returns any error it encounters while servicing this request.
Classification:
| Safety: | |
|---|---|
| Cancellation point | No | 
| Signal handler | No | 
| Thread | Yes | 
