DHA: make extract_dialogue_portion() safe for asn1_NOVALUE

This commit is contained in:
Harald Welte 2013-06-09 16:19:19 +02:00
parent 0afe128c20
commit 0a00ca8a20
1 changed files with 12 additions and 6 deletions

View File

@ -840,16 +840,22 @@ extract_begin_dialogue_portion(UserData) when is_record(UserData, 'TR-user-data'
extract_begin_dialogue_portion(_DialoguePortion) ->
#'TC-BEGIN'{}.
extract_dialogue_portion(UserData, undefined) when is_record(UserData, 'TR-user-data'),
UserData#'TR-user-data'.dialoguePortion /= undefined ->
% if AC is undefined and dialogue portion present -> abort
extract_dialogue_portion(UserData, undefined) when is_record(UserData, 'TR-user-data') and
(UserData#'TR-user-data'.dialoguePortion /= undefined) and
(UserData#'TR-user-data'.dialoguePortion /= asn1_NOVALUE) ->
%% Dialogue portion included? (yes) AC mode set? (no)
abort;
extract_dialogue_portion(UserData, _AppContextName) when not is_record(UserData, 'TR-user-data'),
UserData#'TR-user-data'.dialoguePortion == undefined ->
% if dialogue portion is not present but App context name is set -> abort
extract_dialogue_portion(UserData, _AppContextName) when not is_record(UserData, 'TR-user-data') or
(UserData#'TR-user-data'.dialoguePortion == undefined) or
(UserData#'TR-user-data'.dialoguePortion == asn1_NOVALUE) ->
%% Dialogue portion included? (no) AC mode set? (yes)
abort;
extract_dialogue_portion(UserData, _AppContextName) when is_record(UserData, 'TR-user-data'),
UserData#'TR-user-data'.dialoguePortion /= undefined ->
% if dialogue portion is present and AppContext name is set -> decode dialogue and proceed
extract_dialogue_portion(UserData, _AppContextName) when is_record(UserData, 'TR-user-data') and
(UserData#'TR-user-data'.dialoguePortion /= undefined) and
(UserData#'TR-user-data'.dialoguePortion /= asn1_NOVALUE) ->
%% Extract dialogue portion
%{'EXTERNAL', {syntax,{0,0,17,773,1,1,1}}, _, DlgPDU} = UserData#'TR-user-data'.dialoguePortion,
% some implementations seem to be broken and not send the 'symtax' part?!?