[svn-commits] rmudgett: branch group/issue8824 r161905 - in /team/group/issue8824: ./ chann...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Mon Dec 8 16:13:05 CST 2008
Author: rmudgett
Date: Mon Dec 8 16:13:04 2008
New Revision: 161905
URL: http://svn.digium.com/view/asterisk?view=rev&rev=161905
Log:
* Addresses JIRA ABE-1747
mISDN now uses the nationalprefix and internationalprefix misdn.conf
parameters to prefix any received number from the ISDN link if that
number has the corresponding Type-Of-Number.
Modified:
team/group/issue8824/CHANGES
team/group/issue8824/channels/chan_misdn.c
team/group/issue8824/configs/misdn.conf.sample
Modified: team/group/issue8824/CHANGES
URL: http://svn.digium.com/view/asterisk/team/group/issue8824/CHANGES?view=diff&rev=161905&r1=161904&r2=161905
==============================================================================
--- team/group/issue8824/CHANGES (original)
+++ team/group/issue8824/CHANGES Mon Dec 8 16:13:04 2008
@@ -36,12 +36,15 @@
channel.
* Made misdn.conf parameter callerid accept the "name" <number> format
used by the rest of the system.
+ * Made use the nationalprefix and internationalprefix misdn.conf
+ parameters to prefix any received number from the ISDN link if that
+ number has the corresponding Type-Of-Number.
SIP channel driver (chan_sip) changes
-------------------------------------------
* The sendrpid parameter has been expanded to include the options
'rpid' and 'pai'. Setting sendrpid to 'rpid' will cause Remote-Party-ID
- header to be sent (equivalent to setting sendrpid=yes) and setting
+ header to be sent (equivalent to setting sendrpid=yes) and setting
sendrpid to 'pai' will cause P-Asserted-Identity header to be sent.
------------------------------------------------------------------------------
Modified: team/group/issue8824/channels/chan_misdn.c
URL: http://svn.digium.com/view/asterisk/team/group/issue8824/channels/chan_misdn.c?view=diff&rev=161905&r1=161904&r2=161905
==============================================================================
--- team/group/issue8824/channels/chan_misdn.c (original)
+++ team/group/issue8824/channels/chan_misdn.c Mon Dec 8 16:13:04 2008
@@ -1255,6 +1255,41 @@
break;
}
}
+
+
+
+
+/* ******************************************************************* */
+/*!
+ * \internal
+ * \brief Add a confiured prefix to the given number.
+ *
+ * \param port Logical port number
+ * \param number_type Type-of-number passed in.
+ * \param number Given number string to add prefix
+ * \param size Buffer size number string occupies.
+ *
+ * \return Nothing
+ */
+static void misdn_add_number_prefix(int port, enum mISDN_NUMBER_TYPE number_type, char *number, size_t size)
+{
+ char prefix[MISDN_MAX_NUMBER_LEN];
+ char saved_number[MISDN_MAX_NUMBER_LEN];
+
+ prefix[0] = 0;
+ switch (number_type) {
+ case NUMTYPE_INTERNATIONAL:
+ misdn_cfg_get(port, MISDN_CFG_INTERNATPREFIX, prefix, sizeof(prefix));
+ break;
+ case NUMTYPE_NATIONAL:
+ misdn_cfg_get(port, MISDN_CFG_NATPREFIX, prefix, sizeof(prefix));
+ break;
+ default:
+ return;
+ }
+ ast_copy_string(saved_number, number, sizeof(saved_number));
+ snprintf(number, size, "%s%s", prefix, saved_number);
+} /* end misdn_add_number_prefix() */
static void export_aoc_vars(int originator, struct ast_channel *ast, struct misdn_bchannel *bc)
{
@@ -2789,12 +2824,11 @@
misdn_cfg_get(bc->port, MISDN_CFG_EARLY_BCONNECT, &bc->early_bconnect, sizeof(bc->early_bconnect));
+ misdn_cfg_get(port, MISDN_CFG_DISPLAY_CONNECTED, &bc->display_connected, sizeof(bc->display_connected));
+ misdn_cfg_get(port, MISDN_CFG_DISPLAY_SETUP, &bc->display_setup, sizeof(bc->display_setup));
+
misdn_cfg_get(port, MISDN_CFG_PICKUPGROUP, &pg, sizeof(pg));
misdn_cfg_get(port, MISDN_CFG_CALLGROUP, &cg, sizeof(cg));
-
- misdn_cfg_get(port, MISDN_CFG_DISPLAY_CONNECTED, &bc->display_connected, sizeof(bc->display_connected));
- misdn_cfg_get(port, MISDN_CFG_DISPLAY_SETUP, &bc->display_setup, sizeof(bc->display_setup));
-
chan_misdn_log(5, port, " --> * CallGrp:%s PickupGrp:%s\n", ast_print_group(buf, sizeof(buf), cg), ast_print_group(buf2, sizeof(buf2), pg));
ast->pickupgroup = pg;
ast->callgroup = cg;
@@ -2838,8 +2872,6 @@
ch->overlap_dial = 0;
} else {
- char prefix[BUFFERSIZE + 1];
-
/* ORIGINATOR MISDN (incoming call) */
if (strstr(faxdetect, "incoming") || strstr(faxdetect, "both")) {
@@ -2850,42 +2882,16 @@
}
/* Add configured prefix to caller.number */
- prefix[0] = 0;
- switch (bc->caller.number_type) {
- case NUMTYPE_INTERNATIONAL:
- misdn_cfg_get(bc->port, MISDN_CFG_INTERNATPREFIX, prefix, sizeof(prefix));
- break;
- case NUMTYPE_NATIONAL:
- misdn_cfg_get(bc->port, MISDN_CFG_NATPREFIX, prefix, sizeof(prefix));
- break;
- default:
- break;
- }
- ast_copy_string(buf, bc->caller.number, sizeof(buf));
- snprintf(bc->caller.number, sizeof(bc->caller.number), "%s%s", prefix, buf);
-
- if ( ast_strlen_zero(bc->dialed.number) && !ast_strlen_zero(bc->keypad)) {
+ misdn_add_number_prefix(bc->port, bc->caller.number_type, bc->caller.number, sizeof(bc->caller.number));
+
+ if (ast_strlen_zero(bc->dialed.number) && !ast_strlen_zero(bc->keypad)) {
ast_copy_string(bc->dialed.number, bc->keypad, sizeof(bc->dialed.number));
}
/* Add configured prefix to dialed.number */
- prefix[0] = 0;
- switch (bc->dialed.number_type) {
- case NUMTYPE_INTERNATIONAL:
- misdn_cfg_get(bc->port, MISDN_CFG_INTERNATPREFIX, prefix, sizeof(prefix));
- break;
- case NUMTYPE_NATIONAL:
- misdn_cfg_get(bc->port, MISDN_CFG_NATPREFIX, prefix, sizeof(prefix));
- break;
- default:
- break;
- }
- ast_copy_string(buf, bc->dialed.number, sizeof(buf));
- snprintf(bc->dialed.number, sizeof(bc->dialed.number), "%s%s", prefix, buf);
-
- if (strcmp(bc->dialed.number, ast->exten)) {
- ast_copy_string(ast->exten, bc->dialed.number, sizeof(ast->exten));
- }
+ misdn_add_number_prefix(bc->port, bc->dialed.number_type, bc->dialed.number, sizeof(bc->dialed.number));
+
+ ast_copy_string(ast->exten, bc->dialed.number, sizeof(ast->exten));
misdn_cfg_get(bc->port, MISDN_CFG_OVERLAP_DIAL, &ch->overlap_dial, sizeof(ch->overlap_dial));
ast_mutex_init(&ch->overlap_tv_lock);
@@ -5216,6 +5222,9 @@
if (!ast_strlen_zero(bc->redirecting.from.number)) {
struct ast_party_redirecting redirecting;
+ /* Add configured prefix to redirecting.from.number */
+ misdn_add_number_prefix(bc->port, bc->redirecting.from.number_type, bc->redirecting.from.number, sizeof(bc->redirecting.from.number));
+
/* Update asterisk channel redirecting information */
ast_party_redirecting_set_init(&redirecting, &chan->redirecting);
redirecting.from.number = bc->redirecting.from.number;
@@ -5491,6 +5500,9 @@
break;
stop_indicate(ch);
+
+ /* Add configured prefix to connected.number */
+ misdn_add_number_prefix(bc->port, bc->connected.number_type, bc->connected.number, sizeof(bc->connected.number));
/* Update the connected line information on the other channel */
ast_party_connected_line_init(&connected);
Modified: team/group/issue8824/configs/misdn.conf.sample
URL: http://svn.digium.com/view/asterisk/team/group/issue8824/configs/misdn.conf.sample?view=diff&rev=161905&r1=161904&r2=161905
==============================================================================
--- team/group/issue8824/configs/misdn.conf.sample (original)
+++ team/group/issue8824/configs/misdn.conf.sample Mon Dec 8 16:13:04 2008
@@ -190,10 +190,11 @@
;
allowed_bearers=all
-; Prefixes for national and international Type-Of-Number, these are
-; put before the caller number and dialed number if a corresponding
-; dialplan is set for incoming calls. See the dialplan and localdialplan
-; options.
+; Prefixes for national and international Type-Of-Number. These are
+; inserted before any number (caller, dialed, connected, redirecting,
+; redirection) received from the ISDN link if that number has the
+; correspondng Type-Of-Number.
+; See the dialplan options.
;
; default values: nationalprefix : 0
; internationalprefix : 00
More information about the svn-commits
mailing list