]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
Added support for passing CLI commands to boost sigmod module
authordavidy <dyatsin@sangoma.com>
Wed, 7 Apr 2010 15:22:25 +0000 (11:22 -0400)
committerdavidy <dyatsin@sangoma.com>
Wed, 7 Apr 2010 15:22:25 +0000 (11:22 -0400)
libs/freetdm/src/ftmod/ftmod_sangoma_boost/ftmod_sangoma_boost.c
libs/freetdm/src/ftmod/ftmod_sangoma_boost/sangoma_boost_interface.h

index baaa3018189c991bbe7ab6edd001e2c5c68b15c8..a258184d014b866384c9ecdd641d6b3dca7ec146 100644 (file)
@@ -60,6 +60,9 @@ static time_t congestion_timeouts[MAX_TRUNK_GROUPS];
 
 static ftdm_sangoma_boost_trunkgroup_t *g_trunkgroups[MAX_TRUNK_GROUPS];
 
+static ftdm_io_interface_t ftdm_sangoma_boost_interface;
+static ftdm_status_t ftdm_sangoma_boost_list_sigmods(ftdm_stream_handle_t *stream);
+
 #define BOOST_QUEUE_SIZE 500
 
 /* get freetdm span and chan depending on the span mode */
@@ -1762,6 +1765,81 @@ end:
        return NULL;
 }
 
+
+#define FTDM_BOOST_SYNTAX "list sigmods | <sigmod_name> <command>"
+/**
+ * \brief API function to kill or debug a sangoma_boost span
+ * \param stream API stream handler
+ * \param data String containing argurments
+ * \return Flags
+ */
+static FIO_API_FUNCTION(ftdm_sangoma_boost_api)
+{
+       char *mycmd = NULL, *argv[10] = { 0 };
+       int argc = 0;
+
+       if (data) {
+               mycmd = ftdm_strdup(data);
+               argc = ftdm_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
+       }
+
+       if (argc > 1) {
+               if (!strcasecmp(argv[0], "list")) {
+                       if (!strcasecmp(argv[1], "sigmods")) {
+                               if (ftdm_sangoma_boost_list_sigmods(stream) != FTDM_SUCCESS) {
+                                       stream->write_function(stream, "%s: -ERR failed to execute cmd\n", __FILE__);
+                                       goto done;
+                               }
+                               goto done;
+                       }
+               } else {
+                       boost_sigmod_interface_t *sigmod_iface = NULL;
+                       sigmod_iface = hashtable_search(g_boost_modules_hash, argv[0]);
+                       if (sigmod_iface) {
+                               char *p = strchr(data, ' ');
+                               if (++p) {
+                                       char* mydup = strdup(p);
+                                       if(sigmod_iface->exec_api == NULL) {
+                                               stream->write_function(stream, "%s does not support api functions\n", sigmod_iface->name);
+                                               goto done;
+                                       }
+                                       //stream->write_function(stream, "sigmod:%s command:%s\n", sigmod_iface->name, mydup);
+                                       if (sigmod_iface->exec_api(stream, mydup) != FTDM_SUCCESS) {
+                                               stream->write_function(stream, "-ERR:failed to execute command:%s\n", mydup);
+                                       }
+                                       free(mydup);
+                               }
+                               
+                               goto done;
+                       } else {
+                               stream->write_function(stream, "-ERR: Could not find sigmod %s\n", argv[0]);
+                       }
+               }
+       }
+       stream->write_function(stream, "-ERR: Usage: %s\n", FTDM_BOOST_SYNTAX);
+done:
+       ftdm_safe_free(mycmd);
+       return FTDM_SUCCESS;
+}
+
+/**
+ * \brief Loads sangoma_boost IO module
+ * \param fio FreeTDM IO interface
+ * \return Success
+ */
+static FIO_IO_LOAD_FUNCTION(ftdm_sangoma_boost_io_init)
+{
+       assert(fio != NULL);
+       memset(&ftdm_sangoma_boost_interface, 0, sizeof(ftdm_sangoma_boost_interface));
+
+       ftdm_sangoma_boost_interface.name = "boost";
+       ftdm_sangoma_boost_interface.api = ftdm_sangoma_boost_api;
+
+       *fio = &ftdm_sangoma_boost_interface;
+
+       return FTDM_SUCCESS;
+}
+
 /**
  * \brief Loads sangoma boost signaling module
  * \param fio FreeTDM IO interface
@@ -2250,12 +2328,31 @@ static FIO_CONFIGURE_SPAN_SIGNALING_FUNCTION(ftdm_sangoma_boost_configure_span)
        return FTDM_SUCCESS;
 }
 
+static ftdm_status_t ftdm_sangoma_boost_list_sigmods(ftdm_stream_handle_t *stream)
+{
+       ftdm_hash_iterator_t *i = NULL;
+       boost_sigmod_interface_t *sigmod_iface = NULL;
+       const void *key = NULL;
+       void *val = NULL;
+
+       stream->write_function(stream, "List of loaded sigmod modules:\n");
+       for (i = hashtable_first(g_boost_modules_hash); i; i = hashtable_next(i)) {
+               hashtable_this(i, &key, NULL, &val);
+               if (key && val) {
+                       sigmod_iface = val;
+                       stream->write_function(stream, "  %s\n", sigmod_iface->name);
+               }
+       }
+       stream->write_function(stream, "\n");
+       return FTDM_SUCCESS;
+}
+
 /**
  * \brief FreeTDM sangoma boost signaling module definition
  */
 EX_DECLARE_DATA ftdm_module_t ftdm_module = { 
        /*.name =*/ "sangoma_boost",
-       /*.io_load =*/ NULL,
+       /*.io_load =*/ ftdm_sangoma_boost_io_init,
        /*.io_unload =*/ NULL,
        /*.sig_load = */ ftdm_sangoma_boost_init,
        /*.sig_configure =*/ NULL,
index b555e24338c07b3d410169ac21f126611f76fa8f..d7ad6de84f9f4646a29345c5d6d15bfdc6baff9b 100644 (file)
@@ -37,7 +37,6 @@
 
 #include "freetdm.h"
 
-
 #ifdef __cplusplus
 extern "C" {
 #endif
@@ -180,6 +179,15 @@ typedef ftdm_status_t (*boost_on_load_func_t) BOOST_ON_LOAD_ARGS;
 typedef ftdm_status_t (*boost_on_unload_func_t) BOOST_ON_UNLOAD_ARGS;
 #define BOOST_ON_UNLOAD_FUNCTION(name) ftdm_status_t name BOOST_ON_UNLOAD_ARGS 
 
+/*!
+       \brief Called when user wants to execute sigmod api function
+       \return FTDM_SUCCESS or FTDM_FAIL
+ */
+#define BOOST_API_ARGS (ftdm_stream_handle_t *stream, char *cmd)
+typedef ftdm_status_t (*boost_api_func_t) BOOST_API_ARGS;
+#define BOOST_API_FUNCTION(name) ftdm_status_t name BOOST_API_ARGS
+
+
 /*! 
   \brief The boost signaling module interface 
  */
@@ -212,6 +220,8 @@ typedef struct boost_sigmod_interface_s {
        boost_on_load_func_t on_load;
        /*! \brief the module is about to be unloaded */
        boost_on_unload_func_t on_unload;
+       /*! \brief module api function */
+       boost_api_func_t  exec_api;
        /*! \brief private pointer for the interface user */
        void *pvt;
 } boost_sigmod_interface_t;