diff options
Diffstat (limited to 'epan/dissectors/asn1/lnpdqp')
-rw-r--r-- | epan/dissectors/asn1/lnpdqp/CMakeLists.txt | 39 | ||||
-rw-r--r-- | epan/dissectors/asn1/lnpdqp/LNPDQP.asn | 66 | ||||
-rw-r--r-- | epan/dissectors/asn1/lnpdqp/lnpdqp.cnf | 45 | ||||
-rw-r--r-- | epan/dissectors/asn1/lnpdqp/packet-lnpdqp-template.c | 359 |
4 files changed, 509 insertions, 0 deletions
diff --git a/epan/dissectors/asn1/lnpdqp/CMakeLists.txt b/epan/dissectors/asn1/lnpdqp/CMakeLists.txt new file mode 100644 index 00000000..06b06715 --- /dev/null +++ b/epan/dissectors/asn1/lnpdqp/CMakeLists.txt @@ -0,0 +1,39 @@ +# CMakeLists.txt +# +# Wireshark - Network traffic analyzer +# By Gerald Combs <gerald@wireshark.org> +# Copyright 1998 Gerald Combs +# +# SPDX-License-Identifier: GPL-2.0-or-later +# + +set( PROTOCOL_NAME lnpdqp ) + +set( PROTO_OPT ) + +set( EXPORT_FILES + ${PROTOCOL_NAME}-exp.cnf +) + +set( EXT_ASN_FILE_LIST +) + +set( ASN_FILE_LIST + LNPDQP.asn +) + +set( EXTRA_DIST + ${ASN_FILE_LIST} + packet-${PROTOCOL_NAME}-template.c + ${PROTOCOL_NAME}.cnf +) + +set( SRC_FILES + ${EXTRA_DIST} + ${EXT_ASN_FILE_LIST} +) + +set( A2W_FLAGS -b ) + +ASN2WRS() + diff --git a/epan/dissectors/asn1/lnpdqp/LNPDQP.asn b/epan/dissectors/asn1/lnpdqp/LNPDQP.asn new file mode 100644 index 00000000..d9840150 --- /dev/null +++ b/epan/dissectors/asn1/lnpdqp/LNPDQP.asn @@ -0,0 +1,66 @@ +-- lnpdqp.asn +-- GR-533 i2 2001 +-- + +LNPDQP-Protocol { + itu-t identified-organization (4) etsi (0) mobileDomain (0) + gsm-Network (1) modules (3) map-OM-DataTypes (12) version13 (13)} + +DEFINITIONS + +IMPLICIT TAGS + +::= + +BEGIN + +-- ConnectionControl ::= OPERATION +-- PARAMETER [PRIVATE 18] SET { + ConnectionControlArg ::= [PRIVATE 18] SET { +-- carrierID [4] Digits, - - Note 1 +-- networkRoutingNumber [4] Digits, +-- as2wrs does not like two equal tags + digits [4] Digits, + billingIndicators [PRIVATE 65] BillingIndicators -- Note 1 + } +-- Note 1 This parameter is not used. + +-- ProvideInstruction ::= OPERATION +-- PARAMETER [PRIVATE 18] SET { + ProvideInstructionArg ::= [PRIVATE 18] SET { + calledPartyNumber [10] ServiceKey, +-- callingPartyANI [4] Digits OPTIONAL, +-- originatingLATA [4] Digits OPTIONAL, +-- as2wrs does not like two equal tags + digits [4] Digits, + oli [PRIVATE 69] OriginatingStationType + } +-- ERRORS { +-- dataUnavailable, +-- unavailableResource, +-- unexpectedComponentSequence, +-- unexpectedDataValue +-- } +-- LINKED { +-- ConnectionControl +-- } + +BillingIndicators ::= OCTET STRING (SIZE(4)) + +Digits ::= OCTET STRING (SIZE(4..9)) + +OriginatingStationType ::= OCTET STRING (SIZE(1)) + +ServiceKey ::= CHOICE { + digits [4] Digits +} + +--DataUnavailable ::= ERROR +--PARAMETER [PRIVATE 18] SET { } +-- Optional + +--UnavailableResource ::= ERROR +--PARAMETER [PRIVATE 18] SET { } +-- Optional + +END
\ No newline at end of file diff --git a/epan/dissectors/asn1/lnpdqp/lnpdqp.cnf b/epan/dissectors/asn1/lnpdqp/lnpdqp.cnf new file mode 100644 index 00000000..d9884247 --- /dev/null +++ b/epan/dissectors/asn1/lnpdqp/lnpdqp.cnf @@ -0,0 +1,45 @@ +# lnpdqp.cnf +# lnpdqp conformation file + +#.OPT +#.END + +#.PDU +ConnectionControlArg +ProvideInstructionArg + + +#.FN_BODY Digits VAL_PTR = ¶meter_tvb + tvbuff_t *parameter_tvb = NULL; + guint8 type_of_dgt; + proto_tree *subtree; + + type_of_dgt = tvb_get_guint8(tvb,offset); + switch(type_of_dgt){ + case 2: + /* Calling Party Number */ + hf_index = hf_lnpdqp_callingPartyANI; + break; + case 4: + /* Routing Number */ + hf_index = hf_lnpdqp_networkRoutingNumber; + break; + case 7: + /* Local Access and Transport Area */ + hf_index = hf_lnpdqp_originatingLATA; + break; + case 8: + /* Carrier */ + hf_index = hf_lnpdqp_carrierID; + break; + default: + break; + } +%(DEFAULT_BODY)s + if (parameter_tvb){ + subtree = proto_item_add_subtree(actx->created_item, ett_lnpdqp_digits); + dissect_lnpdqp_digits_type(parameter_tvb,actx->pinfo,subtree, actx); + } + +#.TYPE_ATTR +OriginatingStationType TYPE = FT_UINT8 DISPLAY = BASE_DEC STRINGS = VALS(lnpdqp_OriginatingStationType_vals) diff --git a/epan/dissectors/asn1/lnpdqp/packet-lnpdqp-template.c b/epan/dissectors/asn1/lnpdqp/packet-lnpdqp-template.c new file mode 100644 index 00000000..f3ecee1d --- /dev/null +++ b/epan/dissectors/asn1/lnpdqp/packet-lnpdqp-template.c @@ -0,0 +1,359 @@ +/* packet-lnpdqp-template.c + * Routines for Local Number Portability Database Query Protocol dissection + * + * SPDX-License-Identifier: GPL-2.0-or-later + * + * Ref GR-533 i2 2001 + */ + +#include "config.h" + +#include <epan/packet.h> + +#include <epan/asn1.h> +#include "packet-ber.h" + +#define PNAME "Local Number Portability Database Query" +#define PSNAME "LNPDQP" +#define PFNAME "lnpdqp" + +/* + * Operation Code is partitioned into: + * Operation Family = ConnectionControl, no Reply Required (4) + * Operation Specifier = Connect (1) + */ +#define LNPDQP_ANSI_TCAP_OPCODE_CC 0x0401 +/* + * Operation Code is partitioned into: + * Operation Family = ProvideInstruction, Reply Required (131) 0x83 + * Operation Specifier = Start (1) + */ +/* Exluding H bit */ +#define LNPDQP_ANSI_TCAP_OPCODE_PI 0x0301 + +void proto_reg_handoff_lnpdqp(void); +void proto_register_lnpdqp(void); + +/* Initialize the protocol and registered fields */ +static int proto_lnpdqp = -1; + + +static int hf_lnpdqp_type_of_digits = -1; +static int hf_lnpdqp_nature_of_number = -1; +static int hf_lnpdqp_digits_enc = -1; +static int hf_lnpdqp_np = -1; +static int hf_lnpdqp_nr_digits = -1; +static int hf_lnpdqp_bcd_digits = -1; +static int hf_lnpdqp_ia5_digits = -1; + +/* asn2wrs/the ber dissector does not handle the same tag used multiple times + * in asn1 description, do some magic to handle. + */ +static int hf_lnpdqp_networkRoutingNumber = -1; /* Digits */ +static int hf_lnpdqp_callingPartyANI = -1; /* Digits */ +static int hf_lnpdqp_originatingLATA = -1; /* Digits */ +static int hf_lnpdqp_carrierID = -1; /* Digits */ + +#include "packet-lnpdqp-hf.c" + +static int ett_lnpdqp = -1; +static int ett_lnpdqp_digitstype = -1; +static int ett_lnpdqp_digits = -1; +#include "packet-lnpdqp-ett.c" + + +/* Type of Digits (octet 1, bits A-H) */ +static const value_string lnpdqp_type_of_digits_vals[] = { + { 0, "Not Used" }, + { 1, "Dialed Number or Called Party Number" }, + { 2, "Calling Party Number" }, + { 3, "Caller Interaction" }, + { 4, "Routing Number" }, + { 5, "Billing Number" }, + { 6, "Destination Number" }, + { 7, "LATA" }, + { 8, "Carrier" }, + { 9, "Last Calling Party" }, + { 10, "Last Party Called" }, + { 11, "Calling Directory Number" }, + { 12, "VMSR Identifier" }, + { 13, "Original Called Number" }, + { 14, "Redirecting Number" }, + { 15, "Connected Number" }, + { 0, NULL } +}; + +#if 0 +XXXX Currently unused +/* Nature of Number (octet 2, bits A-H )*/ +static const true_false_string lnpdqp_na_bool_val = { + "International", + "National" +}; +static const true_false_string lnpdqp_pi_bool_val = { + "Presentation Restricted", + "Presentation Allowed" +}; +static const true_false_string lnpdqp_navail_bool_val = { + "Number is not available", + "Number is available" +}; +static const true_false_string lnpdqp_si_bool_val = { + "User provided, screening passed", + "User provided, not screened" +}; +#endif +static const value_string lnpdqp_na_vals[] = { + { 0, "National, No Presentation Restricted"}, + { 1, "International, No Presentation Restricted"}, + { 2, "National, Presentation Restricted"}, + { 3, "International, Presentation Restricted"}, + { 0, NULL } +}; +/* Encoding (octet 3, bits A-D) */ +static const value_string lnpdqp_digits_enc_vals[] = { + { 0, "Not used"}, + { 1, "BCD"}, + { 2, "IA5"}, + { 3, "Octet string"}, + { 0, NULL } +}; +/* Numbering Plan (octet 3, bits E-H) */ +static const value_string lnpdqp_np_vals[] = { + { 0, "Unknown or not applicable"}, + { 1, "ISDN Numbering Plan (ITU Rec. E.164)"}, + { 2, "Telephony Numbering (ITU-T Rec. E.164,E.163)"}, + { 3, "Data Numbering (ITU-T Rec. X.121)"}, + { 4, "Telex Numbering (ITU-T Rec. F.69)"}, + { 5, "Maritime Mobile Numbering"}, + { 6, "Land Mobile Numbering (ITU-T Rec. E.212)"}, + { 7, "Private Numbering Plan"}, + { 0, NULL } +}; + +/* + * OriginatingStationType ::= OCTET STRING (SIZE(1)) + * The following codes are used in the originating line information field: + * 00000010 } Binary values administered by the North + * to } American Numbering Administration + * 01100011 } + * Ref http://www.nanpa.com/number_resource_info/ani_ii_assignments.html + */ + +static const value_string lnpdqp_OriginatingStationType_vals[] = { + { 0, "Plain Old Telephone Service (POTS) - non-coin service requiring no special treatment"}, + { 1, "Multiparty line (more than 2) - ANI cannot be provided on 4 or 8 party lines. "}, + { 2, "ANI Failure "}, + /* 03-05 Unassigned */ + { 6, "Station Level Rating "}, + { 7, "Special Operator Handling Required"}, + /* 08-09 Unassigned */ + { 10, "Not assignable - conflict with 10X test code"}, + /* 11 Unassigned */ + /* 12-19 Not assignable - conflict with international outpulsing code */ + { 20, "Automatic Identified Outward Dialing (AIOD)"}, + /* 21-22 Unassigned */ + /* To lasy to do these */ + { 61, "Cellular/Wireless PCS (Type 1) "}, + { 62, "Cellular/Wireless PCS (Type 2) "}, + { 63, "Cellular/Wireless PCS (Roaming)"}, + { 0, NULL } +}; + +static void +dissect_lnpdqp_digits_type(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *tree _U_, asn1_ctx_t *actx _U_){ + + guint8 octet , no_of_digits; + int offset = 0; + char *digit_str; + + proto_tree *subtree; + + + subtree = proto_item_add_subtree(actx->created_item, ett_lnpdqp_digitstype); + + /* Octet 1 Type of Digits*/ + proto_tree_add_item(subtree, hf_lnpdqp_type_of_digits, tvb, offset, 1, ENC_BIG_ENDIAN); + offset++; + /* Octet 2 Nature of Number*/ + proto_tree_add_item(subtree, hf_lnpdqp_nature_of_number, tvb, offset, 1, ENC_BIG_ENDIAN); + offset++; + /* Octet 3 Numbering Plan |Encoding Scheme| */ + octet = tvb_get_guint8(tvb,offset); + proto_tree_add_item(subtree, hf_lnpdqp_np, tvb, offset, 1, ENC_BIG_ENDIAN); + proto_tree_add_item(subtree, hf_lnpdqp_digits_enc, tvb, offset, 1, ENC_BIG_ENDIAN); + offset++; + /* Octet 4 Number of Digits */ + switch ((octet&0xf)){ + case 1: + /* BCD Coding */ + no_of_digits = tvb_get_guint8(tvb,offset); + proto_tree_add_item(subtree, hf_lnpdqp_nr_digits, tvb, offset, 1, ENC_BIG_ENDIAN); + if(no_of_digits == 0) + return; + offset++; + proto_tree_add_item_ret_display_string(subtree, hf_lnpdqp_bcd_digits, tvb, offset, -1, ENC_KEYPAD_BC_TBCD, pinfo->pool, &digit_str); + proto_item_append_text(actx->created_item, " - %s", digit_str); + break; + case 2: + /* IA5 Coding */ + no_of_digits = tvb_get_guint8(tvb,offset); + proto_tree_add_item(subtree, hf_lnpdqp_nr_digits, tvb, offset, 1, ENC_BIG_ENDIAN); + if(no_of_digits == 0) + return; + offset++; + proto_tree_add_item(subtree, hf_lnpdqp_ia5_digits, tvb, offset, -1, ENC_ASCII); + proto_item_append_text(actx->created_item, " - %s", tvb_get_string_enc(pinfo->pool,tvb,offset,tvb_reported_length_remaining(tvb,offset), ENC_ASCII | ENC_NA)); + break; + default: + break; + } + +} + + +#include "packet-lnpdqp-fn.c" + +static int +dissect_lnpdqp_cc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree, void *data _U_) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + asn1_ctx_t asn1_ctx; + + asn1_ctx_init(&asn1_ctx, ASN1_ENC_BER, TRUE, pinfo); + + col_set_str(pinfo->cinfo, COL_PROTOCOL, PSNAME); + col_set_str(pinfo->cinfo, COL_INFO, "ConnectionControl"); + + + /* create display subtree for the protocol */ + item = proto_tree_add_item(parent_tree, proto_lnpdqp, tvb, 0, -1, ENC_NA); + tree = proto_item_add_subtree(item, ett_lnpdqp); + + return dissect_ConnectionControlArg_PDU(tvb, pinfo, tree, NULL); +} + +static int +dissect_lnpdqp_pi(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree, void *data _U_) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + asn1_ctx_t asn1_ctx; + + asn1_ctx_init(&asn1_ctx, ASN1_ENC_BER, TRUE, pinfo); + + col_set_str(pinfo->cinfo, COL_PROTOCOL, PSNAME); + col_set_str(pinfo->cinfo, COL_INFO, "ProvideInstruction"); + + + /* create display subtree for the protocol */ + item = proto_tree_add_item(parent_tree, proto_lnpdqp, tvb, 0, -1, ENC_NA); + tree = proto_item_add_subtree(item, ett_lnpdqp); + + return dissect_ProvideInstructionArg_PDU(tvb, pinfo, tree, NULL); + +} + + +void proto_register_lnpdqp(void) { + + /* List of fields */ + static hf_register_info hf[] = { + { &hf_lnpdqp_type_of_digits, + { "Type of Digits", "lnpdqp.type_of_digits", + FT_UINT8, BASE_DEC, VALS(lnpdqp_type_of_digits_vals), 0x0, + NULL, HFILL }}, + { &hf_lnpdqp_nature_of_number, + { "Nature of Number", "lnpdqp.na", + FT_UINT8, BASE_DEC, VALS(lnpdqp_na_vals), 0x0, + NULL, HFILL }}, + { &hf_lnpdqp_digits_enc, + { "Encoding", "lnpdqp.enc", + FT_UINT8, BASE_DEC, VALS(lnpdqp_digits_enc_vals), 0x0f, + NULL, HFILL }}, + { &hf_lnpdqp_np, + { "Numbering Plan", "lnpdqp.np", + FT_UINT8, BASE_DEC, VALS(lnpdqp_np_vals), 0xf0, + NULL, HFILL }}, + { &hf_lnpdqp_nr_digits, + { "Number of Digits", "lnpdqp.nr_digits", + FT_UINT8, BASE_DEC, NULL, 0x0, + NULL, HFILL }}, + { &hf_lnpdqp_bcd_digits, + { "BCD digits", "lnpdqp.bcd_digits", + FT_STRING, BASE_NONE, NULL, 0, + NULL, HFILL }}, + { &hf_lnpdqp_ia5_digits, + { "IA5 digits", "lnpdqp.ia5_digits", + FT_STRING, BASE_NONE, NULL, 0, + NULL, HFILL }}, + +/* asn2wrs/the ber dissector does not handle the same tag used multiple times + * in asn1 description, do some magic to handle. + */ + { &hf_lnpdqp_networkRoutingNumber, + { "networkRoutingNumber", "lnpdqp.networkRoutingNumber", + FT_BYTES, BASE_NONE, NULL, 0, + "Digits", HFILL }}, + + { &hf_lnpdqp_callingPartyANI, + { "callingPartyANI", "lnpdqp.callingPartyANI", + FT_BYTES, BASE_NONE, NULL, 0, + "Digits", HFILL }}, + { &hf_lnpdqp_originatingLATA, + { "originatingLATA", "lnpdqp.originatingLATA", + FT_BYTES, BASE_NONE, NULL, 0, + "Digits", HFILL }}, + { &hf_lnpdqp_carrierID, + { "carrierID", "lnpdqp.carrierID", + FT_BYTES, BASE_NONE, NULL, 0, + "Digits", HFILL }}, + +#include "packet-lnpdqp-hfarr.c" + }; + + /* List of subtrees */ + static gint *ett[] = { + &ett_lnpdqp, + &ett_lnpdqp_digitstype, + &ett_lnpdqp_digits, + +#include "packet-lnpdqp-ettarr.c" + }; + + /* Register protocol */ + proto_lnpdqp = proto_register_protocol(PNAME, PSNAME, PFNAME); + + + register_dissector("lnpdqp_cc", dissect_lnpdqp_cc, proto_lnpdqp); + register_dissector("lnpdqp_pi", dissect_lnpdqp_pi, proto_lnpdqp); + + /* Register fields and subtrees */ + proto_register_field_array(proto_lnpdqp, hf, array_length(hf)); + proto_register_subtree_array(ett, array_length(ett)); + +} +void proto_reg_handoff_lnpdqp(void) { + + static dissector_handle_t lnpdqp_cc_handle, lnpdqp_pi_handle; + + lnpdqp_cc_handle = find_dissector("lnpdqp_cc"); + lnpdqp_pi_handle = find_dissector("lnpdqp_pi"); + + dissector_add_uint("ansi_tcap.nat.opcode", LNPDQP_ANSI_TCAP_OPCODE_CC, lnpdqp_cc_handle); + dissector_add_uint("ansi_tcap.nat.opcode", LNPDQP_ANSI_TCAP_OPCODE_PI, lnpdqp_pi_handle); + +} +/* +* Editor modelines +* +* Local Variables: +* c-basic-offset: 4 +* tab-width: 8 +* indent-tabs-mode: nil +* End: +* +* ex: set shiftwidth=4 tabstop=8 expandtab: +* :indentSize=4:tabSize=8:noTabs=true: +*/ |