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
changes/78/78/1
Jason Parker 13 years ago
parent 39d5e40cd5
commit a1494300c9

@ -475,17 +475,18 @@ struct ast_json;
/*! /*!
* \since 12 * \since 12
* \brief Publish a generic \ref stasis_message_type to the \ref stasis_topic for AMI * \brief Publish an event to AMI
*
* \param type The type of AMI event to publish
* \param class_type The class on which to publish the event
* \param obj The event data to be published.
* *
* Publishes a message to the \ref stasis message bus solely for the consumption of AMI. * Publishes a message to the \ref stasis message bus solely for the consumption of AMI.
* The message will be of the type provided by \ref ast_manager_get_type, and will be * The message will be of the type provided by \ref ast_manager_get_type, and will be
* published to the topic provided by \ref ast_manager_get_topic. As such, the JSON must * published to the topic provided by \ref ast_manager_get_topic. As such, the JSON must
* be constructed as defined by the \ref ast_manager_get_type message. * be constructed as defined by the \ref ast_manager_get_type message.
*
* \retval 0 on success
* \retval -1 on failure
*/ */
int ast_manager_publish_message(struct ast_json *json); void ast_manager_publish_event(const char *type, int class_type, struct ast_json *obj);
/*! /*!
* \since 12 * \since 12

@ -1126,49 +1126,13 @@ static int stasis_system_topic_init(void)
return 0; 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) static void publish_fully_booted(void)
{ {
RAII_VAR(struct ast_json *, json_object, NULL, ast_json_unref); RAII_VAR(struct ast_json *, json_object, NULL, ast_json_unref);
json_object = ast_json_pack("{s: s}", json_object = ast_json_pack("{s: s}",
"Status", "Fully Booted"); "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) 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}", json_object = ast_json_pack("{s: s, s: s}",
"Shutdown", active_channels ? "Uncleanly" : "Cleanly", "Shutdown", active_channels ? "Uncleanly" : "Cleanly",
"Restart", restart ? "True" : "False"); "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", ast_verb(0, "Asterisk %s ending (%d).\n",
active_channels ? "uncleanly" : "cleanly", num); 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)); 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); RAII_VAR(struct ast_json_payload *, payload, NULL, ao2_cleanup);
struct ast_json *type = ast_json_object_get(obj, "type"); RAII_VAR(struct stasis_message *, message, NULL, ao2_cleanup);
struct ast_json *class_type = ast_json_object_get(obj, "class_type");
struct ast_json *event = ast_json_object_get(obj, "event");
if (!type) { if (!obj) {
ast_log(AST_LOG_ERROR, "Attempt to send generic manager event without type field\n"); return;
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"); ast_json_ref(obj);
return -1; 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(obj); payload = ast_json_payload_create(event_info);
if (!payload) { if (!payload) {
return -1; return;
} }
message = stasis_message_create(ast_manager_get_generic_type(), payload); message = stasis_message_create(ast_manager_get_generic_type(), payload);
if (!message) { if (!message) {
return -1; return;
} }
stasis_publish(ast_manager_get_topic(), message); stasis_publish(ast_manager_get_topic(), message);
return 0;
} }
/*! \brief Add a custom hook to be called when an event is fired */ /*! \brief Add a custom hook to be called when an event is fired */

Loading…
Cancel
Save