aboutsummaryrefslogtreecommitdiffstats
path: root/channels
diff options
context:
space:
mode:
authorrmudgett <rmudgett@f38db490-d61c-443f-a65b-d21fe96a405b>2010-09-30 19:28:36 +0000
committerrmudgett <rmudgett@f38db490-d61c-443f-a65b-d21fe96a405b>2010-09-30 19:28:36 +0000
commit1310db776a5daa975d3ea2445edd8aca0aeed130 (patch)
tree294d0941d35b75b5e5876237b182f708d18350aa /channels
parent30a41632d36fe0d5b17ab2dec2b88c78f581714b (diff)
Merged revision 289547 from
https://origsvn.digium.com/svn/asterisk/be/branches/C.3-bier .......... r289547 | rmudgett | 2010-09-30 14:16:36 -0500 (Thu, 30 Sep 2010) | 10 lines In chan_misdn, the DivertingLegInformation2 DivertingNr is garbage when the number is restricted. The same thing happens with DivertingLegInformation1 DivertedTo number. The misdn_PresentedNumberUnscreened_extract() extracted the Unscreened PartyNumber field unconditionally. It now checks the presented number unscreened type to see if the PartyNumber was even present. JIRA ABE-2595 .......... git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.8@289549 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_misdn.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/channels/chan_misdn.c b/channels/chan_misdn.c
index ed41c25c3..2dee0ee7e 100644
--- a/channels/chan_misdn.c
+++ b/channels/chan_misdn.c
@@ -2454,7 +2454,20 @@ static void misdn_PresentedNumberUnscreened_extract(struct misdn_party_id *id, c
{
id->presentation = PresentedNumberUnscreened_to_misdn_pres(presented->Type);
id->screening = 0;/* unscreened */
- misdn_PartyNumber_extract(id, &presented->Unscreened);
+ switch (presented->Type) {
+ case 0:/* presentationAllowedNumber */
+ case 3:/* presentationRestrictedNumber */
+ misdn_PartyNumber_extract(id, &presented->Unscreened);
+ break;
+ case 1:/* presentationRestricted */
+ case 2:/* numberNotAvailableDueToInterworking */
+ default:
+ /* Number not present (And uninitialized so do not even look at it!) */
+ id->number_type = NUMTYPE_UNKNOWN;
+ id->number_plan = NUMPLAN_ISDN;
+ id->number[0] = 0;
+ break;
+ }
}
#endif /* defined(AST_MISDN_ENHANCEMENTS) */