mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-12 15:45:18 +00:00
Replace ast_manager_publish_message() with a more useful version.
It's much easier to just create a blob of the message. Convert some AMI events to use it. Review: https://reviewboard.asterisk.org/r/2577/ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@390268 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -1126,49 +1126,13 @@ static int stasis_system_topic_init(void)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Publish a \ref system_status_type message over \ref stasis
|
||||
*
|
||||
* \param payload The JSON payload to send with the message
|
||||
*/
|
||||
static void publish_system_message(const char *message_type, struct ast_json *obj)
|
||||
{
|
||||
RAII_VAR(struct stasis_message *, message, NULL, ao2_cleanup);
|
||||
RAII_VAR(struct ast_json_payload *, payload, NULL, ao2_cleanup);
|
||||
RAII_VAR(struct ast_json *, event_info, NULL, ast_json_unref);
|
||||
|
||||
if (!obj) {
|
||||
return;
|
||||
}
|
||||
|
||||
ast_json_ref(obj);
|
||||
event_info = ast_json_pack("{s: s, s: i, s: o}",
|
||||
"type", message_type,
|
||||
"class_type", EVENT_FLAG_SYSTEM,
|
||||
"event", obj);
|
||||
if (!event_info) {
|
||||
return;
|
||||
}
|
||||
|
||||
payload = ast_json_payload_create(event_info);
|
||||
if (!payload) {
|
||||
return;
|
||||
}
|
||||
|
||||
message = stasis_message_create(ast_manager_get_generic_type(), payload);
|
||||
if (!message) {
|
||||
return;
|
||||
}
|
||||
stasis_publish(ast_manager_get_topic(), message);
|
||||
}
|
||||
|
||||
static void publish_fully_booted(void)
|
||||
{
|
||||
RAII_VAR(struct ast_json *, json_object, NULL, ast_json_unref);
|
||||
|
||||
json_object = ast_json_pack("{s: s}",
|
||||
"Status", "Fully Booted");
|
||||
publish_system_message("FullyBooted", json_object);
|
||||
ast_manager_publish_event("FullyBooted", EVENT_FLAG_SYSTEM, json_object);
|
||||
}
|
||||
|
||||
static void ast_run_atexits(int run_cleanups)
|
||||
@@ -2028,7 +1992,7 @@ static void really_quit(int num, shutdown_nice_t niceness, int restart)
|
||||
json_object = ast_json_pack("{s: s, s: s}",
|
||||
"Shutdown", active_channels ? "Uncleanly" : "Cleanly",
|
||||
"Restart", restart ? "True" : "False");
|
||||
publish_system_message("Shutdown", json_object);
|
||||
ast_manager_publish_event("Shutdown", EVENT_FLAG_SYSTEM, json_object);
|
||||
}
|
||||
ast_verb(0, "Asterisk %s ending (%d).\n",
|
||||
active_channels ? "uncleanly" : "cleanly", num);
|
||||
|
@@ -1312,37 +1312,34 @@ static void manager_generic_msg_cb(void *data, struct stasis_subscription *sub,
|
||||
manager_event(class_type, type, "%s", ast_str_buffer(event_buffer));
|
||||
}
|
||||
|
||||
int ast_manager_publish_message(struct ast_json *obj)
|
||||
void ast_manager_publish_event(const char *type, int class_type, struct ast_json *obj)
|
||||
{
|
||||
RAII_VAR(struct stasis_message *, message, NULL, ao2_cleanup);
|
||||
RAII_VAR(struct ast_json *, event_info, NULL, ast_json_unref);
|
||||
RAII_VAR(struct ast_json_payload *, payload, NULL, ao2_cleanup);
|
||||
struct ast_json *type = ast_json_object_get(obj, "type");
|
||||
struct ast_json *class_type = ast_json_object_get(obj, "class_type");
|
||||
struct ast_json *event = ast_json_object_get(obj, "event");
|
||||
RAII_VAR(struct stasis_message *, message, NULL, ao2_cleanup);
|
||||
|
||||
if (!type) {
|
||||
ast_log(AST_LOG_ERROR, "Attempt to send generic manager event without type field\n");
|
||||
return -1;
|
||||
}
|
||||
if (!class_type) {
|
||||
ast_log(AST_LOG_ERROR, "Attempt to send generic manager event without class type field\n");
|
||||
return -1;
|
||||
}
|
||||
if (!event) {
|
||||
ast_log(AST_LOG_ERROR, "Attempt to send generic manager event without event payload\n");
|
||||
return -1;
|
||||
if (!obj) {
|
||||
return;
|
||||
}
|
||||
|
||||
payload = ast_json_payload_create(obj);
|
||||
ast_json_ref(obj);
|
||||
event_info = ast_json_pack("{s: s, s: i, s: o}",
|
||||
"type", type,
|
||||
"class_type", class_type,
|
||||
"event", obj);
|
||||
if (!event_info) {
|
||||
return;
|
||||
}
|
||||
|
||||
payload = ast_json_payload_create(event_info);
|
||||
if (!payload) {
|
||||
return -1;
|
||||
return;
|
||||
}
|
||||
message = stasis_message_create(ast_manager_get_generic_type(), payload);
|
||||
if (!message) {
|
||||
return -1;
|
||||
return;
|
||||
}
|
||||
stasis_publish(ast_manager_get_topic(), message);
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*! \brief Add a custom hook to be called when an event is fired */
|
||||
|
Reference in New Issue
Block a user