aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2005-04-01 04:50:21 +0000
committerkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2005-04-01 04:50:21 +0000
commitf2724678a7db61e47aa26829e09c4af2b6bc825b (patch)
treed7997e78e84f89b06b34549dd0cf00f3ec10df14
parent68428cbd9d12b335eee19b3f5ed9213992576cd4 (diff)
Add 'iax2 reload' CLI command and fix peer counting with regex matches (bug #3876)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5337 f38db490-d61c-443f-a65b-d21fe96a405b
-rwxr-xr-xchannels/chan_iax2.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/channels/chan_iax2.c b/channels/chan_iax2.c
index 8ccfd8eab..29fd80f52 100755
--- a/channels/chan_iax2.c
+++ b/channels/chan_iax2.c
@@ -230,6 +230,8 @@ static int global_rtautoclear = 120;
static struct iax2_peer *realtime_peer(const char *peername);
static int reload_config(void);
+static int iax2_reload(int fd, int argc, char *argv[]);
+
struct iax2_user {
char name[80];
@@ -2003,6 +2005,10 @@ static char prune_realtime_usage[] =
"Usage: iax2 prune realtime [<peername>|all]\n"
" Prunes object(s) from the cache\n";
+static char iax2_reload_usage[] =
+"Usage: iax2 reload\n"
+" Reloads IAX configuration from iax.conf\n";
+
static struct ast_cli_entry cli_set_jitter =
{ { "iax2", "set", "jitter", NULL }, iax2_set_jitter, "Sets IAX jitter buffer", jitter_usage };
@@ -2018,6 +2024,9 @@ static struct ast_cli_entry cli_show_peer =
static struct ast_cli_entry cli_prune_realtime =
{ { "iax2", "prune", "realtime", NULL }, iax2_prune_realtime, "Prune a cached realtime lookup", prune_realtime_usage, complete_iax2_show_peer };
+static struct ast_cli_entry cli_reload =
+ { { "iax2", "reload", NULL }, iax2_reload, "Reload IAX configuration", iax2_reload_usage };
+
static unsigned int calc_rxstamp(struct chan_iax2_pvt *p, unsigned int offset);
#ifdef BRIDGE_OPTIMIZATION
@@ -4066,7 +4075,6 @@ static int iax2_show_peers(int fd, int argc, char *argv[])
char nm[20];
char status[20] = "";
char srch[2000] = "";
- total_peers++;
if (registeredonly && !peer->addr.sin_addr.s_addr)
continue;
@@ -4113,6 +4121,7 @@ static int iax2_show_peers(int fd, int argc, char *argv[])
nm,
ntohs(peer->addr.sin_port), ast_test_flag(peer, IAX_TRUNK) ? "(T)" : " ",
peer->encmethods ? "(E)" : " ", status);
+ total_peers++;
}
ast_mutex_unlock(&peerl.lock);
@@ -8458,6 +8467,11 @@ static int reload_config(void)
return 0;
}
+static int iax2_reload(int fd, int argc, char *argv[])
+{
+ return reload_config();
+}
+
int reload(void)
{
return reload_config();
@@ -8997,6 +9011,7 @@ int load_module(void)
ast_cli_register(&cli_show_stats);
ast_cli_register(&cli_show_cache);
ast_cli_register(&cli_show_peer);
+ ast_cli_register(&cli_reload);
ast_register_application(papp, iax2_prov_app, psyn, pdescrip);