Method and system for processing a transaction

Abstract
A method of, and system for, processing payment for a transaction is provided. The method includes providing a user with an option to select payment for the transaction from an account associated with a communication line via which an electronic terminal is connected to a communication network. The communication line is typically a subscriber line and, accordingly, the account is a telephone account associated with the subscriber line. When a user transacts with a vendor for goods and/or services, the user may request to process payment using the telephone account instead of using a credit or debit card. The method includes investigating data using the telephone number associated with the subscriber line and, selectively approving the transaction dependent upon an outcome of the investigation. The invention extends to a transaction processor interface and to and a transaction validation module. The invention also extends to computer program products including the invention.
Description
FIELD OF THE INVENTION

The present invention relates generally to transaction processing and, more specifically, to processing a transaction between a vendor and a user via an electronic terminal connected by a communication line to a communication network.


BACKGROUND OF THE INVENTION

An increasing number of vendors are offering goods and/or services which may be purchased via a communication network such as a telecommunication network. For example, a purchaser may conduct a transaction via a subscriber line using a landline telephone or a personal computer via the Internet. Conventionally, credit or debit card details are furnished by the purchaser to the vendor to effect payment for the goods and/or services. As many purchasers are hesitant to supply credit or debit card details over a communication network, an alternate method of payment would be advantageous. However, if an alternate method is used, verification of the payment method should preferably take place prior to concluding the transaction.


SUMMARY OF THE INVENTION

In accordance with the invention, there is provided a method of processing payment for a transaction, the method including:


providing a user with an option, via an electronic terminal, to select payment for the transaction from an account associated with a communication line to which the electronic terminal is connected;


receiving a user request entered into the terminal to process payment from the account;


investigating data associated with the communication line; and selectively approving the transaction dependent upon an outcome of the investigation.


Further in accordance with the invention, there is provided a method of modifying a financial instrument record, the method including:


receiving transaction data entered into an electronic terminal connected via a communication line to a communication network;


obtaining a unique identifier associated with the communication line; and


combining the unique identifier and the transaction data to form a financial instrument record.


Still further in accordance with the invention, there is provided a method of validating a transaction conducted using an electronic terminal connected via a subscriber line to an electronic network, the method including:


receiving a financial instrument record associated with the transaction;


extracting a unique identifier from the financial instrument record, the unique identifier being associated with the communication line; and


interrogating at least one database based on the unique identifier to obtain data associated with the subscriber line and selectively generating a validation status.


The invention extends to a transaction processing system for processing a transaction between a vendor and an electronic terminal connected via a communication line to a communication network, the system including:


an application interface for providing a user, via the electronic terminal, with an option to select payment for the transaction from an account associated with the communication line, and receiving a user request entered into the terminal to process payment from the account; and


a modification module connected to the application interface, the modification module generating a record which includes a unique identifier associated with the communication line and communicating the record to a validation module which validates the transaction based on data associated with the unique identifier.


The invention also extends to a transaction processor interface for processing payment of a transaction, the interface including:


an application interface for providing a user with an option, via an electronic terminal, to select payment for the transaction from an account associated with a communication line to which the electronic terminal is connected, and for receiving a user request entered into the electronic terminal to process payment from the account; and


a modification module for creating a financial instrument record which includes a unique identifier associated with the communication line.


The invention extends further to a transaction validation module for validating a transaction conducted using an electronic terminal connected via a communication line to an electronic network, the module including:


an extraction module for extracting a unique identifier from a financial instrument record associated with a transaction, the unique identifier being associated with the communication line; and


a processor module for interrogating at least one database based on the unique identifier to obtain data associated with the communication line and selectively generating a validation status.


Further in accordance with the invention, there is provided a computer program product including a medium readable by a processor, the medium carrying instructions which, when executed by the processor, cause the processor to:


provide a user with an option, via an electronic terminal, to select payment for a transaction from an account associated with a communication line to which the electronic terminal is connected;


receive a user request entered into the terminal to process payment from the account;


investigate data associated with the communication line; and


selectively approve the transaction dependent upon an outcome of the investigation.


Still further in accordance with the invention, there is provided a computer program product including a medium readable by a processor, the medium carrying instructions which, when executed by the processor, cause the processor to:


receive transaction data entered into an electronic terminal connected via a communication line to a communication network;


obtain a unique identifier associated with the communication line; and


combine the unique identifier and the transaction data to form a financial instrument record.


Still further in accordance with the invention, there is provided a computer program product including a medium readable by a processor, the medium carrying instructions which, when executed by the processor, cause the processor to:


receive a financial instrument record associated with a transaction conducted using an electronic terminal connected via a subscriber line connected to a communication network;


extract a unique identifier from the financial instrument record, the unique identifier being associated with the communication line; and


interrogate at least one database based on the unique identifier to obtain data associated with the unique identifier and selectively generate a validation status.


Other features of the present invention will be apparent from the accompanying drawings and from the detailed description which follows.




BRIEF DESCRIPTION OF THE DRAWINGS

The invention is now described, by way of non-limiting example, with reference to the accompanying diagrammatic drawings.


In the drawings,



FIG. 1 shows a schematic block diagram of a system, in accordance with the invention, for processing a transaction;



FIG. 2 shows a schematic block diagram of a method used in the prior art to process a transaction electronically;



FIG. 3 shows a schematic block diagram of a method, in accordance with the invention, for processing a transaction;



FIG. 4 shows a schematic block diagram of a billing cycle used in the method of FIG. 3;



FIG. 5 shows a schematic block diagram of functional modules, also in accordance with the invention, used by a vendor;



FIG. 6 shows a schematic block diagram of transaction validation and processing modules, also in accordance with the invention, used in the system;



FIG. 7 shows a schematic representation of a client interface in the form of an electronic terminal used to conduct the transaction;



FIG. 8 shows a schematic representation of a screen display or layout provided at the client interface;



FIG. 9 shows a schematic representation of a further screen layout provided at the client interface;



FIG. 10 shows a schematic representation of a screen display at the client interface for choosing a payment method;



FIG. 11 shows a schematic representation of a screen display at the client interface for confirming a billing telephone number (BTN);



FIG. 12 shows a schematic representation of a screen display at the client which is displayed whilst validation of the client telephone number takes place;



FIG. 13 shows a schematic representation of a flow diagram illustrating the validation process;



FIG. 14 shows a schematic flow diagram of a bill cycle transaction event;



FIG. 15 shows a more detailed schematic block diagram of the transaction validation and processing modules of FIG. 6;



FIG. 16 shows a schematic representation of a sample telephone bill platform or account which the system automatically updates; and



FIGS. 13-15 show schematic flow charts of the validation method or procedure carried out by the validation module of FIGS. 6 and 15.




DETAILED DESCRIPTION

Referring to the drawings, reference numeral 20 general indicates a system for processing payment of a transaction. The system 20 includes a merchant or vendor 22, a plurality of client interfaces in the form of electronic terminals 24 (only 1 of which is shown in the drawings), a plurality of telephone companies (Telcos) 26 (only 1 of which is shown in the drawings), and a transaction validation and processing facility 28 including a transaction validation and processing module 30 (see FIG. 6), also in accordance to the invention. The vendor 22 includes a transaction processor interface defined by an application interface and modification module 32 (see FIG. 5) and, as will be described in more detail below, the system 20 with its transaction validation and processing module 30 allows a user to purchase goods and/or services from the vendor 22 via the electronic terminal 24 in such a fashion so that charges for the transaction are included in a telephone account 34 (see FIG. 16) of the user.


The system 20 is typically configured for use in an Internet environment in which a plurality of vendors 22 offer goods and/or services for sale on the Internet via the electronic terminals 24 which are typically personal computers (PCs). It is important to appreciate that the modules 30, 32 describe functional modules or capabilities which may be implemented by a variety of different hardware and software combinations.


Conventionally, and as shown in FIG. 2, in order to procure payment for goods and/or services, a user or purchaser using the electronic terminal 24 enters financial card details, e.g., credit card, debit card, or any other financial instrument details, which are then communicated (see line 38 in FIG. 2) to a vendor, as shown at 40, which then communicates with a credit card gateway 42. The credit card gateway 42 may then either accept or reject the transaction. However, many users are unwilling to submit financial card information to vendors, inter alia, for security reasons. Further, many users who have access to the Internet do not in fact possess financial cards (hereinafter referred to as credit cards) and are thus unable to transact via the Internet.


Referring in particular to FIG. 3 of the drawings, in one embodiment of the invention the system 20 receives transaction data 44 which is then formatted substantially to resemble a conventional credit card transaction 46 which is then converted or modified and payment for the transaction is included in a telephone bill or account as shown at block 48. As will be described in more detail below, each particular transaction or billing event is not immediately included in the telephone account 34 at the Telco 26, but during a billing cycle (see FIG. 4) which occurs periodically, e.g., daily, weekly, monthly or at any other interval. Accordingly, communications 50 take place during billing events between the transaction validation and processing facility 28 and the vendor 22 and a record of each transaction is kept at the facility 28 as shown by block 52 in FIG. 4. The facility 28, with its transaction validation and processing module 30, in an automated fashion at the end of a billing cycle, processes the transactions into the relevant telephone accounts at the relevant Telcos 26 as shown at block 54.


Referring in particular to FIG. 5 of the drawings, the vendor 22 uses the application interface and modification module 32 to interface to the communication network, typically the Internet, so that the user may communicate with the vendor 22 via the electronic terminal 24. The module 32 includes an application interface (API) 56, a customer management system (CMS) 58, an automatic number identification (ANI) module 60, a modification module 62, and a communication module 64. The communication module 64 is configured to communicate with the transaction validation and processing module 30, which is typically located offsite. In use, the API 56 provides the electronic terminal 24 with a user interface whereby the user can purchase goods and/or services and this may be provided in a conventional fashion. Once the user has selected the goods and/or services he or she wishes to purchase, the API 56 communicates a display screen or form 66 to the electronic terminal 24 as shown in FIG. 8. Typically, the API 56 requests the user to enter into the form 66 name, address, city, state, zip, day time phone number, evening phone number, or the like information. Typically, the evening phone number defines a billing telephone number (BTN) which is associated with the telephone account 34. Thereafter, the various terms and or conditions of the transaction are communicated to the user in the form of a display screen 68 as shown in FIG. 9. The user is then compelled either to accept or decline the terms by activating buttons 70, 72 respectively, typically by means of a mouse or pointing device in a conventional fashion.


Once the user has accepted the terms, the API 56 then provides the user with a display screen 74 which allows the user to select various different methods of payment for the transaction. For example, the display screen 74 includes a “Visa” button 76, a “MasterCard” button 78, “American Express” button 80, and a “bank account” button 82. However, unlike conventional systems, the system 20 provides the user with a “phone bill” button 84 whereby the user can charge the transaction to the telephone account 34 (see FIG. 16).


If the user selects the option to pay via the telephone account 34 by activating the “phone bill” button 84, the API 56 then provides the user with a screen display 86 (see FIG. 11) which requests the user to confirm the BTN associated with the telephone account 34. The screen display 86 includes a “yes” button 88 for the user to confirm the telephone number which is shown at 90, and a “no” button 92 which is activated in the event of the telephone number being incorrect. If the telephone number shown at 90 is incorrect, the user then is prompted to re-enter a corrected telephone number. Once the user has activated the “yes” button 88, the API 56 then communicates a display screen 94 to the electronic terminal 24 to advise the user that he or she should wait while the request is authorized. It is to be appreciated however that the description above is merely an example of how a user may be provided with various interfaces to allow the user to select a mode or method of payment associated with the telephone account 34. Those skilled in the art will appreciate that user data may be obtained in a variety of different ways. For example, an application may be downloaded to the electronic terminal 24 which requests and obtains the relevant data from the user and which is then subsequently communicated to the vendor 22.


The BTN which the user enters into the form 66 should correspond with the subscriber line 96 (see FIG. 1) via which the electronic terminal 24 is connected to the communication network. Accordingly, the ANI module 60 automatically identifies or determines the telephone number of the subscriber line 96 so that a comparison between the two can be made. The BTN thus defines a unique identifier associated with the communication line and with which the telephone account 34 corresponds.


The user's request, via the electronic terminal 24 and via the subscriber line 96 (which may be any communication line associated with the account 34), is then communicated to the CMS 58 which then formats the request to form a request record with information provided by the user via the electronic terminal 24 (see block 98 in FIG. 13). As shown at decision step 100, the module 32 checks to determine whether or not a credit card number is present in the record and, if so, the record is communicated to a credit card gateway for processing in a conventional fashion and the procedure terminates as shown at step 102. This situation typically arises when the user has not selected the telephone account option by activating the “phone bill” button 84 but, instead, selected one of the other methods of payment, e.g., the “Visa” button 76, the “MasterCard” button 78, the “American Express” button 80, or the “bank account” button 82.


However, if the “phone bill” button 84 has been activated and a credit card number is not present in the record, the CMS 58, in combination with the modification module 62, modifies the credit card record to include the telephone number identified by the ANI module 60. Accordingly, the credit card or financial record communicated from the vendor 22 to the transaction validation and processing facility 28 substantially resembles a conventional or industry standard credit card record except that, instead of a credit card number, the telephone number associated with the subscriber line 96 is included (see step 104). In the embodiment of the invention in which the credit card number has been replaced with the telephone number, and as the record substantially resembles and industry standard credit card record, existing or conventional customer management systems may be used to process the transaction. Thus, the CMS 58 may be a conventional customer management system.


The application interface and modification module 32 of the vendor 22, communicates the transaction record to the transaction validation and processing module 30 of the facility 28 via the communication module 64. The module 30 then receives the record as shown at step 106 whereafter it is processed. The transaction validation and processing module 30 (see FIG. 6) includes a line number extraction module 108, a processor module 110, and an OBF exchange interface 112. It is important to appreciate that the application interface and modification module 32 and the transaction validation and processing module 30 may be defined by one or more servers which are programmed appropriately. Thus, the blocks or modules may represent functional components of software running on the server. Typically, each vendor 22 has a server programmed and configured to implement the application interface and modification module 32 and the vendors 22 are connected via a communications network to a central transaction processing and validation facility 28. Accordingly the servers at the facility 28 may receive validation and processing requests from a plurality of different offsite servers provided at different vendors 22.


The processor module 110 first checks, at step 114, if all the information required for validation has been furnished by the vendor 22 and, if not, the request is returned to vendor 22 as shown in step 116. If, however, all the information required by the module 30 is present in the record, the credit card record received is then parsed and the billing telephone number (BTN) is extracted from the credit card record and formatted into a validation request as shown at step 118. Thereafter, as described more detail in FIGS. 13 and 14, the module 30 performs various checks during which the subscriber line 96 is validated (see step 120). If the BTN progresses to a LIDB interrogation step (as described in more detail below with reference to steps 264 to 286 in FIG. 17), the request is then reformatted into a LIDB request to obtain LIDB response information (see step 122). The LIDB database 124 (see FIG. 13) is then interrogated and the LIDB response is received and parsed for relevant information whereafter it is reformatted into a BTN validation request as shown at step 126. Thereafter, and as described in more detail below with reference to FIGS. 18 and 19, the processor module 110 performs further validation checks (see step 128 in FIG. 13 and steps 296 to 338 in FIGS. 18 and 19). Once the request has been investigated, the various databases have been interrogated, and the results retrieved therefrom processed, the processor module 110 then translates the validation response in to a credit card authorization response format, which is typically a conventional or industry standard format so that an industry standard or conventional CMS 58 can process the response. The response is then communicated from the facility 28 to the vendor 22 (see step 130). The CMS 58 then receives the reformatted response, updates purchase data, and creates an account for the user as shown in step 132. Thereafter, the API 56 communicates a display screen 134 to the electronic terminal 24 which thanks the user for ordering the good and/or services. Each transaction defines a billing event which is recorded at the vendor 22 and, together with other billing events, is communicated to the facility 28 at the end of a billing cycle (see block 136). Typically, this marks the end of the BTN validation procedure from the credit card authorization record translation as shown at block 138.


The method described above broadly translates a record requiring validation from an existing financial instrument form, e.g., a credit card form, to a form that is suitable to be validated based on a unique identifier associated with the subscriber line 96. Although the description above, and the more detailed description below, describe the translation from a credit card record to an appropriate record to validate a ANI/BTN, it is to be appreciated that any data associated with a financial instrument may be translated into a BTN format and, in response to validation of the BTN, the transaction may be processed. Further, the validation of the BTN may take place one or more times during the life cycle of a transaction. For example, the validation process may be executed when the user or customer request the transaction to be included in the telephone account 34 as described above and, when the facility 28 receives a plurality of billing events or transactions at the end of a bill cycle, the facility 28 may once again validate the transaction.


In certain embodiments, the user or purchaser drives an authorization event in order to establish whether or not the transaction can be billed to the telephone account 34. In this case, the Billing Telephone Number (BTN) defines the credit instrument requiring authorization for billing. The CMS 58 may then drive the request to the facility 28 in the same format as it would to a Credit Card Authorization System. An example of the conversion of a credit card billing request to a BTN validation record is described in more detail below.


1. Credit Card Authorization Request to Billing Telephone Number Validation Request

Credit Card Authorization Request Record99m999999123456.........2022269329Ebillittestregistration 12345 Main Street apt 12 AnyCity   CA950510789202226932930155919920002695Billing Telephone Number Validation Request Record99m999999999999202226932912345Main StreetCA 9505107892022269329Credit CardBilling TelephoneAuthorization RecordNumber Validation RecordPositionFieldExamplePositonFieldExample 1-15Tracking99m999999123456 1-15Tracking99m999999123456IDID16-35CREDIT #202226932916-25ANI*202226932936-65NAMEEbillittestregistration 66-105ADDRESS112345 Main Street26-56ADDRESS112345 Main Street106-125ADDRESS2Apt 12126-155CITYAny City156-157STATECA57-58STATECA158-163ZIP9505159-63ZIP95051164-168Zip + 4078964-67Zip + 40789169-178BTN202226932968-77BTN2022269329179-188EVENING #3015591992189-195AMOUNT0002695


2. Billing Telephone Number Validation to a LIDB Request Record


If the Phone number passes a series of validation checks, it will then be checked against the LIDB database. In order to do that, the record must be translated in to a format specific for the LIDB process.

Billing Telephone Number Validation Request Record99m999999123456202226932912345Main StreetCA 9505107892022269392LIDB Request RecordDR1100333333330200021234561010914132401;;102022269329Billing TelephoneNumber Validation RecordLIDB Request RecordPositonFieldFieldPositonFieldExample 1-15Tracking ID99m9999991234561-2MESSAGE IDDR16-25ANI*20222693293-6FIELD BIT MAP1100 7-14CUST ID3333333326-56ADDRESS112345 Main Street15-18MESSAGE TYPE020019-20TRANS TYPE0221-26SEQ #12345657-58STATECA27-27DATA INDICATOR159-63ZIP9505128-33DATE01091464-67Zip + 4078934-39TIME13240168-77BTN202226932940-42END OF HEADER;;43-45ACCT # LENGTH1046-55ACCT #2022269329


3. LIDB Response Record to a BTN Validation Record


Once the information is received from LIDB, the record must be translated back into a format that the Phone Number Validation System can read so the process can continue with additional checks to the phone number.

LIDB Response RecordDR0210333333330200021234561010914132416;;20222693292019417998Billing Telephone Number Validation Request Record99m999999123456202226932912345Main StreetCA 95051078920222693292019417998LIDB Response RecordBilling Telephone Number Validation RecordPositonFieldExamplePositonFieldExample1-2MESSAGE IDDR 1-15Tracking ID99m9999991234563-6FIELD BIT MAP021016-25ANI*2022269329 7-14CUST ID3333333315-18MESSAGE TYPE020026-56ADDRESS112345 Main Street19-20TRANS TYPE0221-26SEQ #12345627-27DATA INDICATOR157-58STATECA28-33DATE01091459-63ZIP9505134-39TIME13241664-67Zip + 4078940-42END OF HEADER;;68-77BTN202226939243-52ACCT #202226932953-55RESPONSE CDOE20178-80RESPONSE CDOE20156-59PHONE941781-84PHONE COMPANY #9417COMPANY #60-62PHONE99885-87PHONE COMPANY #998COMPANY #


4. BTN Validation Response Record to a Credit Card Authorization Response Record


At the conclusion of the Phone Number Validation Process, the results must be sent back to the CM System so the results can be returned to the purchaser and updated in the CM System. The BTN Validation response must be converted to a format that the CM can interpret. The BTN Validation Response Record is translated to the Credit Card Authorization Response Record for this phase of the purchase.

Billing Telephone Number Validation Response Record99m9999991234562022269329180201N2Y5552269329YYCredit Card Authorization Response Record99m999999123456..........2022269329201N25552269329YYBilling Telephone Number Validation RecordCredit Card Authorization RecordPositonFieldExamplePositonFieldExample 1-15Tracking ID99m999999123456 1-15Tracking ID99m99999912345616-25BTN202226932916-35CREDIT #202226932926-28BTN VAL18036-41RESPONSE CODE201N2RESPONSECODE28-32CC RESPONSE201N242-51NEW PHONE #5552269329CODE35-35AREA CODEY52-52BUSINESS LINEYCHANGE36-45NEW PHONE #555226932953-53ACCT <90 DAYSY46-46BUSINESS LINEY47-47ACCT <90 DAYSY


Referring in particular to FIG. 14 of the drawings, at the end of a bill cycle during which a plurality of transactions or billing events or transactions have been recorded by the CMS 58, the CMS 58 communicates a billing transaction file in a credit card bill event format to the facility 28 (see step 140 in FIG. 14). Each event in the transaction file includes an indicator to indicate that the event is a phone billing transaction for inclusion in the telephone account 34. The module 30 of the facility 28 then receives the billing request file as shown at step 142, whereafter the request file is parsed, as shown at step 144, and the processor module 110 checks to see whether or not all the required information is present in the file (see step 146). If not, a code is appended to the record as show at step 148. If all the information is present in the file, the process then proceeds to step 150 where the credit card authorization to BTN validation steps 118-130, as described above, are executed. Once the validation procedure has been completed, the BTN billing response is formatted into a industry standard credit card billing response with a response code appended to the end of each record and, the records are then returned to the CMS 58 (see step 152).


At the same time, transactions or billing events which have been validated as billable and thus capable of being included in the relevant telephone account 34, are translated into an electronic message interface (EMI) format appropriate for the Telco with which the telephone account 34 is associated (see step 154). The EMI formatted file is then transferred to the Telco for billing as shown in step 156 whereafter the Telco call places each billing event on telephone account 34 associated with the subscriber line 96. Typically, the Telco returns any records that can not be billed to the telephone account 34 or that have already been billed and credited, or written off because of non payment to the facility 28 as shown at step 160. The records received by the facility 28 are in the EMI format and the facility 28 translates the record to a credit card return record including a reason code appended to the record, as shown at step 162, whereafter record is returned to the CMS 58 at the vendor 22.


An example of the billing event record conversion in which a credit card billing request is translated into a BTN billing request is set out below.


1. Credit Card Billing Request to a BTN Billing Request


Once the purchase event has been slotted for billing, it enters the billing stream for that bill cycle. In certain embodiments, daily bill cycle records are sent to the appropriate processors. As described above, the transaction validation and processing module 30 may receive the record in the same format required by a conventional credit card processing facility.


In certain embodiments, the first step in the bill cycle is to re-validate the billable status of the BTN. This is done by following the same steps in the BTN Validation process set out above. The first step is to convert the record to a BTN Validation event record.

Credit Card Billing Request RecordS749499M4N0000107252E100BP2623775174 0000 0004500ABPAT*MOORE H2624444444A2888 NW 87th REGENCY CIRCLE D2623775174A3CEADARBURG, WI 53012-0505Billing Telephone Number Validation Request Record749499M4N0000107252E10020222693290004500888WI531020505BCredit Card Authorization RecordBilling Telephone Number Validation RecordPositonFieldExamplePositonFieldExample1-1Bill EventS 1-15Tracking ID749499M4N0000107252E1002-7Merchant ID74949916-25BTN26237751748YEARS INM (13th26-33AMOUNT0004500BUSINESSyear) 9-10MONTH,4N (April34-43ADDRESS1888.......DAY14th)11-20ACCT #000010725244-45STATEWI21-24E10046-50ZIP5310225-25RECORDB51-54ZIP + 40505TYPE26-26BILL TYPEP55-55RECORD TYPEB27-46BTN262377517447-54AMOUNT0000045001-2ACCT INFOAB 3-32NAMEPAT MOORE33-43HOME #H262444444444-45ADDRESSA2INDICATOR46-65STREET888 NW 87th REGENCYCIRCLE66-76DAYTIME #D262377517477-78ADDRESS3A3 79-108CITY,CEADARBURG, WISTATE, ZIP53012 0505


2. Phone Bill Billing Record to Credit Card Billing Response Record


At the conclusion of the revalidation during the billing process, a different response record may be written to a file. That record is typically in a format according to the Credit Card Billing Response format.

Billing Telephone Number Billing Validation Response Record749499M4N0000107252E1002623775174180201N2N0000000000NN0004500BCredit Card Billing Response RecordS749499M4N0000107252E100BP2623775174201N2N0000000000NNBTN Billing Validation Response RecordCredit Card Billing Response RecordPositonFieldExamplePositonFieldExample 1-15Tracking ID749499M4N0000107252E1001-1BILLINGSEVENT16-25BTN2623775174 2-24Tracking ID749499M4N0000107252E10026-28BTN VAL18025-34BTN2623775174RESPONSECODE29-33CC RESPONE201N235-39RESPONSE CODE201N2CODE34-34AREA CODEN40-40AREA CODENCHANGECHANGE35-44NEW PHONE #000000000041-50NEW #000000000045-45BUSINESS LINEN51-51BIZ LINEN46-46ACCT <90N52-52ACCT <90 DAYSNDAYS47-53AMOUNT000450054-54RECORD TYPEB


3. BTN Billing Validation Record to a Phone Company Deposit Record


At the same time the Billing Response is returned, all accounts that were validated as positive may be formatted into a record that is acceptable at the Telephone Company for processing.

Billing Telephone Number Billing Validation Response Record749499M4N0000107252E1002623775174180201N2N0000000000NN0004500BPhone Company Deposit Record4250010114000000000074420000000000073640045000000000000000000000000000000000000000910200000000000000090300000002623775174000....000BTN Billing Validation Response RecordPhone Company Deposit RecordPositonFieldExamplePositonFieldExample 1-15Tracking749499M4N0000107252E1001-6RECORD425001IDTYPE16-25BTN2623775174 7-11DATE10140026-28BTN VAL18012-19Zero fill00000000RESPONSECODE29-33CC201N220-23PROCESSOR #7442RESPONSECODE34-34AREA CODEN24-34Zero fill000000000000CHANGE35-44NEW PHONE #000000000035-38SUBCIC #736445-45BUSINESSN39-44AMT004500LINE46-46ACCT <90N45-81Zero fill000...00DAYS47-53AMOUNT000450082-85OCN910254-54RECORDB 86-100Zero fill000000000000000TYPE101-103CIC #903104-112Zero fill00..000113-122BTN2623775174123-175Zero fill000...000


4. Negative Billing Event Records to Credit Card Negative Event Records


These BTN Billing Records are deposited at a Telephone Company for processing on to the bill page. If a charge is unable to be placed on the bill page, the event must be converted in to the Credit Card Negative Billing Event format for processing. In addition, any other negative information, such as a credit of a charge or the write-off of bad debt, must be converted to the appropriate Credit Card formats for processing by the CM. Thus, if inclusion into the telephone account 34 fails for some reason, the transaction then gets charged to the financial instrument or credit card and an industry standard credit card record is created by the module 30.


The CMS 58 typically knows how to handle the negative event by the file name that contains the records and the response code within the returned records. The file name and response codes are in the industry standard credit card processing convention.

Phone Company Return Record42500101140000000000744200000000000736400450000000000000000000000000000MO000000000910214100000000000090300000002623775174000....000Credit Card Negative Event RecordS749499M4N0000107252E1002623775174201091501Phone Company Deposit RecordCredit Card Chargeback RecordPositonFieldExamplePositonFieldExample1-6RECORD4250011-1BILLINGSTYPEEVENT 7-11DATE101400 2-24Tracking ID749499M4N0000107252E10012-19Zero fill0000000025-34BTN262377517420-23PROCESSOR #744235-37RESPONSE201CODE24-34Zero fill00000000000038-43RETURN DATE09150135-38SUBCIC #736439-44AMT00450045-69Zero fill000...0070-71REASONMOCODE72-81Zero fill000.00082-85OCN910286-89NEW OCN1410 90-100Zero fill000...000101-103CIC #903104-112Zero fill00..000113-122BTN2623775174123-175Zero fill000...000


As mentioned above, the transaction validation and processing module 30 carries out a validation process on the telephone number associated with subscriber line 96 (see FIG. 15) and periodically processes transactions directly into subscriber telephone accounts 34.


Referring in particular to FIG. 15 of the drawings, reference numeral 200 generally indicates a more detailed schematic block diagram of an embodiment of the module 30. In the module 200, the line number extraction module 108 and the OBF exchange interface 112 are integrated into the processor module 110 which is in the form of a server.


The module 200 includes an application program interface (API) 214 which is connected to the vendor 22 or service provider (see also FIG. 5) of goods and/or services which require validation of a subscriber account. The vendor 22, which could for example be an Internet Service Provider, may request the validation of the subscriber line 96 prior to concluding an electronic transaction with a subscriber via the subscriber line 96. It is, however, to be appreciated that the API 214 may be connected to a variety of different hosts or clients which require validation of a subscriber line 96 via which the vendor 22 may carry out transactions for goods and/or services.


The vendor 22 typically communicates a request to the module 200 and forwards the subscriber line number, determined by the ANI service, to the module 200 via its API 214. The module 200 then processes the information received from the vendor 22 and provides a validation status, e.g. a code indicating a valid billable number or a code indicating that the line number is not a valid billable number (unbillable or non-billable). In particular, a plurality of codes associated with various statuses of the subscriber line 96 are communicated to the vendor 22 as described in more detail below.


The module 200 includes hardware and software to implement the invention. In particular, the module 200 includes a comparator module 218, a threshold database 220, an OFFNET database 222, an ONNET database 224, a competitive local exchange carrier (CLEC) database 226, a 42 BLOCK database 228, a block and cancel database 230, an unbilled and/or unpaid bills database 232, line identification database (LIDB) short term cache 234, a validity check module 236, a regional account office (RAO) database 238, an operating company number (OCN) database 240, an ONNET database 242, an address verification database 244, customer account record exchange (CARE) results database 246, an ANI watch database 248, and an NPA (Numbering Plan Area) exchange database 250. It is to be appreciated that, in less sophisticated embodiments of the invention, all of the above databases need not be included. However, for enhanced accuracy, all of the above databases are preferably included. Further databases may also be included further to increase the reliability of the validation process.


In addition to any one or more of the above databases, the module 200 is in communication via a conventional communication channel with an offsite or, in some embodiments, on-site line identification database (LIDB) host 252. The LIDB host 252 may include a line number portability (LNP) database. Typically, the LNP database may front end access to a plurality of industry standard LIDBs (e.g. 13 different LIDBs). The LNP database may however be a separate database. As described in more detail below, the module 200 communicates the subscriber line number to the LIDB host 252 which, in turn, communicates reference subscriber data in the form of industry standard LIDB codes back to the module 200 for processing. The module 200 then processes the LIDB codes to provide the vendor 22 with validation data relating to the subscriber line 96. Unlike conventional LIDB applications which use a LIDB to make decisions regarding destination subscriber lines or call completion decisions, e.g. decisions for calling cards, collect and third party toll services or the like, the module 200 is used to identify telephone numbers of originating subscriber lines.


Broadly, the module 200 includes a communication module formed by the application program interface (API) 214 which communicates with the communication module 64 (see FIG. 5) of the vendor 22, a processor module 110 which includes the various databases 220 to 232 as well as the comparator module 218 and the validity check module 236, and an interrogation module 256 for interrogating the LIDB host 252. It is to be appreciated that the modules may be defined by one or more servers with associated databases. Further, in the example illustrated, the LIDB host 252 is shown as a single database but may comprise many different LIDB databases maintained by various LECs and, accordingly, may be located at various different geographic locations.


Referring in particular to FIGS. 16 to 19 of the drawings, various sections of a flow chart describing the method of operation of the module 200 are shown. As described above, the vendor 22 initiates a request to the module 200 to validate a transaction to be included in the account 34 associated with the subscriber line 96. As shown at step 260, the module 200 first checks to see if the BTN number is present in the request from the vendor 22 and, if no number is present, a return code 121 is generated and communicated to the vendor as shown at step 262. The code 121 indicates to the vendor 22 that the module 200 is unable to process the request. If, however, the number is present in the request from the vendor 22, the module 200 then checks if the line number captured (hereinafter also referred to as the ANI) by the ANI module 60, and the BTN entered on the form 66 (see FIG. 8) match, as shown at step 264 (see also the comparator module 218 in FIG. 15). If, however, the ANI and the BTN do not match, then the processor module 110 generates a code 120 (see step 66) to indicate that the caller and the owner of the line number are not the same person (e.g. the user enters his or her BTN in the form 66 and uses an electronic terminal connected to a different subscriber line and is thus calling from a different ANI) and the relevant modified code is then returned to the vendor 22.


If the ANI and the BTN do match, the processor module 110 interrogates the threshold database 220 (see step 268) to ascertain whether or not the line number has reached its threshold (e.g., a predefined client threshold parameter such as an account threshold). If the line number has reached its threshold, the processor module 110 then generates a code 60, as shown at step 270, which is then communicated to the vendor 22 to indicate that the line number may not be granted service. In other words, the subscriber account cannot be billed for the goods and/or services requested by the user from the vendor 22.


If the threshold has not been reached, the module 200 then interrogates its OFFNET database 22 (see step 271) to check if the industry standard NPA/NXX and operating company number (OCN) of the subscriber line 96 is present in the OFFNET database 22. The OFFNET database 22 includes NPA/NXX and OCN combinations of operating companies with which the proprietor or user of the module 200 does not have billing and collections agreements to bill into the Telco's bill page associated with the subscriber line 96. Accordingly, the facility 20 is unable to include a charge in the account associated with the subscriber line 96 on behalf of the vendor 22 for the transaction.


If the line number is in the OFFNET database 222, then the processor module 110 generates codes 130 to 133 (see step 272) and communicates these codes to the vendor 22. The codes 130 to 133 indicate that the NPA/NXX and OCN for the particular line number 96 are not billable and, accordingly, charges for goods and/or services requested by the user cannot be included in the monthly telephone account 34 by the module 200. As shown in Table 2 below, the codes 130 to 133 provide an indication to the vendor 22 why the subscriber line 96 is not billable or deliverable. If the subscriber line number is not included in the OFFNET database 222, a check is conducted to see whether or not the subscriber line number is included in the ONNET database 224. This check is however optional in the embodiment depicted in the drawings, but may be mandatory if the module 200 does not include the OFFNET database 222.


Thereafter, as shown in step 278, the processor module 110 checks to see if the line number is found in a known CLEC table in the CLEC database 226. CLEC numbers are those line numbers that are known to have ported to a CLEC and, accordingly, the proprietor of the module 200 is thus unable to route these line numbers to the correct billing entities. If the line number is found in the CLEC database 226, then the processor module 110 generates a code 140 (see step 276) which is communicated to the vendor 22. The code 140 indicates that the BTN provided by the user is not billable for the CLEC and the module 200 can thus not charge the transaction to the subscriber account associated with the subscriber line 96.


If the line number is not found in the CLEC database 226, then the module 200 checks to see if the subscriber of the subscriber line 96 has requested a 4250 billing block as shown at step 278. In particular, the processor module 110 interrogates the 42 BLOCK database 228 and, if the number is located in the database 228, which indicates that monthly recurring charges (4250) charges are prevented from being billed to that line number, the processor module 110 generates a code 150 (see step 280) which is communicated to the vendor 22 to indicate that billing to the particular subscriber line 96 has been blocked.


If, however, the subscriber line 96 has not been blocked, the module 200 then checks at step 282 if the line number is located in the block and cancel database 230 and, if so, the processor module 110 generates codes 160 and 161 which are then communicated to the vendor as shown at step 284. The block and cancel database 230 includes requests from owners of subscriber lines, agencies, businesses, or the like that a service be canceled or blocked from further billing. Thereafter, the module 200 interrogates the unbilled and/or unpaid bills database 232, as shown at step 286, to check if there is a history of any unpaid bills and/or unbillable bills associated with the subscriber line 96. Unbillable bills relate to those subscriber line numbers where previous attempts have been made to bill charges to the subscriber account associated with the line number, and which have been returned as unbillable. If the processor module 110 locates the line number in the unbillable and/or unpaid bills database 232 then, as shown at step 288, a code 170 is generated and communicated to the vendor 22 to indicate that the line number was previously found to be unbillable and is still considered to be unbillable.


The processing described above conducts a preliminary investigation into the subscriber line number or ANI/BTN to provide an initial indication of whether or not the ANI/BTN corresponds with a billable subscriber line. Once the initial investigation has been conducted, the module 200 then uses the ANI to obtain reference subscriber line data in the form of LIDB codes from one or more industry standard databases in the form of the LIDB host or database 252. Examples of the LIDB codes used in the module 200 are shown in Table 3 below.


As shown at step 290, if the ANI is not found in the LIDB database 252, the module 200 cannot provide any validation data to the vendor 22 on this subscriber line and an appropriate code is then communicated to the vendor 22 as shown at block 292.


Once the LIDB database or host 252 has been interrogated, it returns industry standard LIDB codes and line number portability (LNP) data to the module 200 as shown in step 294 (see FIG. 18). The LIDB codes are then mapped or translated by the processor module 110 into modified validation codes (see Table 3) which provide relevant validation information to the vendor 22. As can be seen from Table 3, the same modified validation code can be generated from a plurality of different LIDB codes. Once the LIDB information codes have been returned to the processor module 110, the LIDB codes, including OCN and RAO response codes, are fed into the validity check module 236 (see FIG. 15) as shown at step 96.


As mentioned above, the LIDB host 252 may also provide LNP data to the module 200. The LNP data is used to identify subscriber line numbers that have ported to a CLEC. If a subscriber line has been ported to a CLEC, the billing ONNET status of the CLEC is verified in the CLEC database 226. The LNP identifies the facilities based CLECs which are CLECs that have been assigned all the line numbers for an NPA/NXX in a specific geographic territory. This type of CLEC would be in control of the cable, dial tone and billing envelope for that number. Typically, the LNP cannot be used to identify CLEC sellers which have resold the subscriber line under their brand, but still lease the cable and tone from an incumbent local exchange carrier (ILEC). Accordingly the facility 28 may be unable to process transaction data onto a bill page or telephone account 34 of the CLEC reseller bill page. In order to identify reseller CLECs, the module 200 compares RAO and OCN information, returned from the LIDB host 252, to data in the ONNET database 224. The OCN is the local Telco that owns the subscriber line number and the RAO is the office of the Telco that is responsible from a billing standpoint for the subscriber line number.


If the validity check module 236 determines that the response codes are invalid, the module 200 generates modified codes 180 to 999 (see step 298 and Table 2) which are communicated to the requestor or vendor 22 to indicate that the mapping of the LIDB codes to the modified codes concluded that the line is an unbillable subscriber line.


If the validity check module 236 confirms the validity of the LIDB codes and, in the event of the line number being a billable line number, the processor module 110 then checks the RAO database 238 to ascertain whether or not the RAO is billable, as shown at step 300. If the RAO is not billable, then the processor module 110 generates and communicates a return code 143 (see step 302) to indicate to the vendor 22 that the line number belongs to a CLEC which is not billable by the module 200.


In a similar fashion, at step 304 the processor module 110 checks to see if the OCN returned from the LIDB host 252 corresponds with a known CLEC or if the OCN corresponds with an OFFNET OCN and is therefore also unbillable. If the line number corresponds to an OCN that is not billable, a return code 142 is generated by the processor module 110 and communicated to the vendor 22 (see step 306).


If the subscriber line number has passed the RAO and OCN checks and, accordingly, it appears that the number is billable, the processor module 110 then checks to see if a new NPA/NXX and OCN combination for this line number is guidable to the correct local Telco for billing (see step 308). If the line number is not guidable, then the module 200 generates a code 141 at step 310 which is communicated to the vendor 22 to indicate that, even though the line number is billable, the facility 28 is unable to guide the billing information to the new Telco for billing. Accordingly, the telephone number is in fact non-billable insofar as the facility 28 is concerned and a decline status is therefore communicated to the vendor 22.


The abovementioned steps are carried out to ascertain whether or not the subscriber line 96 can be billed for the goods and/or services requested. However, to enhance the accuracy or reliability of the module 200, further checks or verification are conducted as described below.


In the event that the subscriber line number has passed or complied with the abovementioned checks, and has thus not yet been rejected, the module 200 performs address verification procedures at step 312. The module 200 then interrogates an address verification database 244 to compare the address or location data (e.g. a ZIP code) supplied by the user via the form 66 (see FIG. 8) with reference address data as shown at step 312. If, however, the address supplied by the user does not match with the address in the verification database 244 or, the addresses are not within a predefined range or area, the processor module 110, as shown at step 314, generates codes 10 to 39 which are then communicated to the vendor 22 to indicate the level of likelihood that the caller (ANI) and the account owner are the same person.


During the address verification step 312, the module 200 interrogates a customer account record exchange (CARE) database (which can be an on-site database which is regularly updated), to provide enhanced reliability. In particular, the CARE database or information site is typically one or more industry standard offsite databases which allow consumers to select or change their long distance service provider. Local Telcos forward specific customer information to the LEC associated with the subscriber. The information communicated typically includes a new phone number, billing address, installation date, the person or organization responsible for the account, or the like.


As shown at step 316, the module 200 interrogates the CARE database or information site and CARE data is then loaded into CLEC and new line databases to perform certain fraud and billing checks. The CARE information investigation occurs after a successful validation event. Once the module 200 has validated the subscriber line 96, the subscriber line number data is sent to a CARE database provider hosting the CARE database 246 to obtain the BNA and age of the account. The information is typically returned within 48 hours and then processed. Care records that are returned without BNA and CLEC ACCOUNT codes are inserted into the CLEC database 226 for future reference. Accordingly, if the BTN is presented again at a later date, it will fail the CLEC check step (see step 274 in FIG. 17).


The ANI watch database 248, which includes historical and adjusted information, is used by the module 200 to determine if the account has previously been adjusted (see step 316). Typically, this step includes ascertaining previous requests by the subscriber for credit, obtaining data on any written off amounts for charges that were billed to a bill page, or the like.


If adjustments have previously been made to the account associated with the subscriber line 96, the processor module 110 generates codes 1 to 5 (see step 318) to indicate to the vendor 22 that the adjustments have been made. If no adjustments have been made, the processor module 110 checks to see whether or not the line number has a business line indicator as shown at step 320. If the business line indicator is active, the module 200 generates a code 70 (see step 322) which is communicated to the vendor 22 to advise that the line is a business line. Thereafter, as shown in step 324, the processor module 110 checks to see if the subscriber line number has been in service for less than about 90 days and, if so, a return code 80 (see step 326) is generated to advise the vendor 22 who may then selectively decide whether or not to conclude the transaction. A database of new numbers may be updated with the new number.


Thereafter, the module 200 interrogates the ANI watch database 248 (see step 328) to ascertain whether or not the area code of the line number has been changed or is scheduled to change. This interrogation is typically for billing purposes only and is not used to decide upon the validity of the request. In this step, the vendor 22 requesting the validation typically updates the billing file with the new area code number, and the processor module 110 generates a code 110 (see step 330) to advise the vendor 22 of the scheduled change to the area code.


Once the line number has passed all the aforementioned checks, the module 200 then concludes that the subscriber line 96 obtained using ANI techniques is in fact a billable line and, accordingly, the transaction may be charged directly to the account of the subscriber. Accordingly, the module 200 then generates a code 000 (see step 334) which is communicated to the vendor 22. The code 000 defines an approved status following both a billable line number inquiry as well as several fraud checks which are carried out by the fraud control module 332. If the line number has passed the abovementioned checks and the return code 000 is generated, the process terminates at block step 336. Thus, step 336 defines the end of the process during which the various checks have been conducted on the subscriber line 96 to assess whether or not it is a billable subscriber line that charges may be billed to. Step 338 defines the last step to which the process jumps when, at any point during the abovementioned process, the line number is found not to be billable (e.g., a creditworthy decision was requested by the vendor 22) and the inquiry is accordingly terminated and the relevant code is communicated to the vendor 22.


The abovementioned steps are typically executed in real time. However, information sources that do not allow checks on the line number in real time may be are carried out subsequently on the line number. Typically, once the real time evaluation is carried out and the return code 000 is communicated to the vendor, and the vendor 22 decide to proceed with the transaction, transaction data is then periodically returned to the module 200 by the vendor 22 for a pre-billing validation check or actual billing. During actual billing the module 200 accesses an account folder of the subscriber line at the Telco 26 and inserts the charges due to the vendor 22 into the telephone account 34. As shown at step 340, line numbers are sent to the CARE database 246 to determine if the BNA is available at the local Telco 26. If the folder or telephone account 34 is not available, the local Telco 26 typically sends the BNA and codes as to why the number is unavailable to the facility 28. If the BNA is found in the CARE database 246, the processor module 110 then checks to see whether or not the account was created within the last 90 days as shown at step 342. If the account was not created within the last 90 days, then the business indicator is checked as shown at step 344 and the process ends as previously shown at step 346. If, however, the number was found in the CARE database 246, the account was created within the last 90 days, or has an active business indicator then the module 200 generates the appropriate codes which are communicated to vendor 22 and the process terminates as shown at step 348.


The above process has been described in terms of modified codes set out in Table 2 but, it is to be appreciated, that the mapping or translation of the LIDB codes may produce any other defined set of corresponding codes so long as the codes are mapped onto, or generated in response to, any one or more of the industry standard LIDB codes.


A summary of the codes generated by the module 200 during execution of the validation process is provided in Table 1 below.

TABLE 1Modified codes generated during the BTN Validation Process.Code Generatedand ref to flowchartsDescription of codeReturn Code 121Indicates inability to proceed with validation; returned torequestorSee step 264Checks if ANI captured and BTN provided match (not requiredin all scenarios)Return Code 120Indicates caller and # (line number) owner are not the sameperson; returned to requestorSee step 268A defined Threshold limits the number of attempts on that #within a certain timeframeReturn Code 60Indicates # may not be granted service; returned to requestor.See step 271Checks the NPA/NXX and OCN to those in the OFFNET.OFFNET = NPA/NXX and OCN combinations whereproprietor of the module 200 does not have a Billing andCollections agreement to bill into the Telco's' bill page.Return Code 130-133Indicates that NPA/NXX & OCN for that Number are notbillable; returned to requestorSee step 274Checks the line number to see if found in known CLEC table.These are numbers that are known to have ported to a CLEC.Proprietor is unable to route these # to the correct billingentities.Return code 140Indicates # not billable for CLEC; returned to requestor.See step 278Checks line # to see if owner has requested a 4250 Billingblock. This block prevents monthly recurring (4250) chargesfrom being billed to that line #.Return Code 150Indicates that requested a block of billing; returned torequestor.See step 282Checks line number for inclusion in the Block and Canceldatabase. This database includes requests from line # owners,agencies, businesses etc that have requested that service becancelled and or blocked from further billing.Return Code 160-161Indicates number found in Block and Cancel and is not billable;returned to requestor.See step 286Checks line # for unbillable history. Unbillables are #s wheretried to bill charges previously and have been returned asunbillable.Return Code 960Indicates # has unbilled before and is still consideredunbillable; returned to requestor.See step 290If # not found in Unbillable, then routed to LIDB for info.ITEMDescriptionSee step 294Identifies info returned from LIDB re. that line #; Response Code = statusabout that # as a call termination point. OCN = OperatingCompany # = the local Telco that owns that #. RAO = RegionalAccounting Office = the office of the Telco that is responsible froma $ flow standpoint for that #.See step 296Checks the validity of the LIDB code returned for the number as aBillable #. This is where the mapping of the LIDB codes to theproprietor validation codes happens.Return CodeIndicates the mappings of the LIDB codes to the proprietor Val reply180-999codes. Each of these indicate a non-billable #; returned to requestor.See step 300Checks if RAO returned is an RAO that is not billable.Return CodeIndicates that the # belongs to a CLEC and is unbillable; returned to143requestor.See step 304Checks if OCN returned from LIDB is a known CLEC or OFFNETOCN and therefore unbillable.Return codeIndicates that the new OCN is not billable; returned to requestor.142See step 308Checks to see if new NPA/NXX & OCN combination for # isguidable to the correct local Telco for billing.Return codeIndicates that even though the # is billable, eBillit is unable to guide141to the new Telco for billing; unguidable = unbillable; # returned torequestor.The steps to indicate if # is billable have been completed.The next steps provide additional information about the # for the requestor e.g. todecide if and how much credit to extend for services. They also provide additionalbilling information.See step 312Provides address verification (if required). Matches # to address todetermine likelihood of person dialing to the person that owns theacct at local Telco.Return CodeIndicates the level likelihood that the caller (ANI) and acct owner are10-39the same. Returned to requestor.See step 316Checks to see if # has had adjustment activity previously. Thisincludes request for credit, written off for charges that billed to a billpage. Requestor makes credit decision based on #s history ofcredits, adjustments, write offs.Return Code 1-5Indicates the type and source of adjustment to charges to that #.Returned to requestor.See step 320Checks to see if the # has a business line indicator. Requestordecides if would like to extend service or not.Return Code 70Indicates that the # is identified as a business.See step 324Checks to see if the # has been in service less than 90 days.Requestor makes a decision about how much service to offer #without much payment history.Return Code 80Indicates that the # has been in service less than 90 days.See step 328Checks if the Area Code of the # has been scheduled to change. Thisis for billing information purposes only. Requestor updates billingfiled with new number.Return CodeIndicates Area Code has been scheduled to change. New number is110appended to end of record.See step 334If the number passes all the previous checks, then 000 code isreturned to requestor. The Validation is complete for this request.See step 338End of validation for numbers that did no pass or were found in otherchecks.END OF REAL TIME VALIDATION EVENTInformation sources that do not allow checks on the # in Real-time (r-t), happen on# that was returned as 000 after the r-t validation event has completed. The #s areloaded into the appropriate databases. This information will be provided once the# is returned for billing.Steps 340, 342, 344Indicates path for those #s returned with a 000code.See step 340#s are sent to CARE source to determine ifBNA (billing Name and Address) available atlocal Telco. Telco sends BNA and codes as towhy unavailable.CLEC#s that are returned with codes that indicate the# has moved to a CLEC from the local Telcoare loaded into the CLEC table.See step 342#s are sent to the CARE source to determine ifthe account has been crested within the last 90days. The response codes indicate thiscondition.New within 90#s that are returned with codes that indicate thiscondition are loaded into the NEW table.See step 344#s are sent to a Business source. This sourceidentifies which numbers belong to businesses.Biz tableNumbers that are indicated as being line #s thatbelong to businesses are loaded in this table.


Table 2 below provides the various actions which are executed in response to a modified validity code. The table provides a description and explanation of each code. Return codes 001 to 969 relate to failure codes which are generated by the module 200 prior to investigation of the LIDB host 252. Return codes 180 to 451 are generated during the LIDB code checks. In the event of the subscriber line 96 failing the checks carried out on it, the module 200 provides optional use of a credit card and, accordingly, Table 2 sets out codes which the module 200 generates in response to executing a standard credit card enquiry for a particular transaction. If the module 200, which is typically defined by a server and associated databases, is down, codes 994 to 999 are generated and communicated to the vendor.

TABLE 2Validation & BNA Reply CodesCodeActionDESCRIPTIONEXPLANATIONBILLABLE CODES000ApprovedBillable; was not found during fraudPassed all billing and fraud control checkscontrol checksFRAUD CONTROL CODES (performed after billable check)ANI WATCH (adjustments to bill)001VerifyBillable; found in ANI WATCH -Passed all billable checks; but ANI had beenCLIENT source alladjusted previously at vendor's, Client's ortelco's request for your Client #002VerifyBillable; ANI WATCH - CLIENTPassed all billable checks; but ANI had beensource Clientadjusted previously at Client's request for yourClient #003VerifyBillable; ANI WATCH - CLIENTPassed all billable checks; but ANI had beensource Telco or Vendoradjusted previously at vendor's or telco'srequest for your Client #004VerifyBillable; found in ANI WATCH -Passed all billable checks; ANI had beenGLOBALadjusted previously at vendor's, Client's ortelco's request for all Client ids005VerifyBillable; found in ANI WATCH -Passed all billable checks; ANI had beenPRODUCTadjusted previously at vendor's, Client's ortelco's request for same product typeZIP VERIFICATION010VerifyBillable; Unable to match ZIP invalidPassed all billable checks; unable to find thisZip code for this NPA/NXX -011VerifyBillable; ZIP does not matchPassed all billable checks; Zip code does notmatch this NPA/NXX012VerifyBillable; ZIP matches to samePassed all billable checks; Zip code matches toMetropolitan areasame Metropolitan area as NPA NXX.ADDRESS VERIFICATIONNote: The result of an AVS check does not mean that the transaction is declined. This information is advice only. Thesystem compares the AVS data with billing information for the buyer and passes the results of the comparison to themerchant.020VerifyBillable; BNA match not foundPassed all billable checks; no BNA matchfound for ANI021VerifyBillable; Unable to verify BNAPassed all billable checks; unable to verifyinvalidBNA to ANI info sent022VerifyBillable; with zip-Match, plus4-Passed all billable checks; BNA Zip code +4Match, locale-Match& locale (street address) matches info sent forANI, Name does not match023VerifyBillable; with zip-Match, plus4-Passed all billable checks; BNA Zip code +4Match, NoMatch-locale.matches info sent for ANI but locale (streetaddress) does not match024VerifyBillable; zip-Match, NoMatch-plus4,Passed all billable checks; BNA Zip code &locale-Match.locale (street address) matches info sent forANI but +4 does not match025VerifyBillable; zip-Match, NoMatch-plus4,Passed all billable checks; BNA Zip codeNoMatch-locale.matches info sent for ANI but locale (streetaddress) & +4 does not match026VerifyBillable; NoMatch-zip, plus4-Match,Passed all billable checks; BNA +4 and localelocale-Match.(street address) matches info sent for ANI butZip does not match027VerifyBillable; NoMatch-zip, plus4-Match,Passed all billable checks; BNA +4 matchesNoMatch-locale.info sent for ANI but locale (street address)and Zip does not match028VerifyBillable; NoMatch-zip, NoMatch-Passed all billable checks; BNA locale (streetplus4, locale-Match,address) matches info sent for ANI but ZIPand +4 does not match029VerifyBillable; NoMatch-zip, NoMatch-Passed all billable checks; BNA does notplus4, NoMatch-locale.match zip, +4 or locale (street address) sentfor ANI030GoodAddress & Zip Match031VerifyAddress Match, Zip No Match032VerifyAddress Match, Zip ServiceUnavailable033VerifyAddress No Match, Zip Match034VerifyAddress No Match, Zip No Match035VerifyAddress No Match, Zip ServiceUnavailable036VerifyAddress Service Unavailable, ZipMatch037VerifyAddress Service Unavailable, Zip NoMatch038VerifyAddress Service Unavailable, ZipService UnavailableAREA CODE CHANGE INDICATOR110UpdateIndicates there has been an area codeCode is sent in addition to the validationchange for this NPA/NXXresponse codes. New phone number isappended to record. Provided to update theaccount with the correct BTN.MISC120VerifyBTN and ANI do not matchFor use where BTN and ANI are passed and donot match.121VerifyBTN or ANI are missing from recordFor use where BTN and ANI is missing fromrecordUNBILLABLE CODESOFFNET130UnbillableNPA/NXX found in OFFNET -Area code/exchange (NPA/Nxx) combinationGLOBALresides in OFFNET DB. OFFNET is aterritory where the LEC (Local ExchangeCarrier) is unable to provide 3rd partypresentation in to it's envelope.131UnbillableNPA/NXX found in OFFNET -Area code/exchange (NPA/Nxx) combinationCLIENT SPECIFICresides in OFFNET DB specific for this Clientid.132UnbillableNPA/NXX found in OFFNET -Area code/exchange (NPA/Nxx) combinationPRODUCTresides in OFFNET DB specific for thisproduct type.133UnbillableNPA/NXX NOT VALIDArea code/exchange is not a valid area codeexchangeCLEC (CLECs are unable to provide 3rd party bill presentation in their envelopes.)140UnbillableLine number (NPA/Nxx-xxxx) inBTN has been ported to a CLEC (competitiveCLEC Territorylocal exchange carrier).141UnbillableNPA/Nxx not ON NETBTN has been ported to a CLEC (competitivelocal exchange carrier) and is not billable.142UnbillableLine number OCN in CLEC OCNOperating Company number for this BTN wastablefound on CLEC OCN table. The number is notbillable.143UnbillableLine number RAO in CLEC RAORegional Accounting Office number for thistableBTN was found on CLEC RAO table. ThisBTN is not billable.42 BLOCK (4250s Only)150UnbillableLine Number has a block for 4250Consumer has requested a block for all MRCsrecords(monthly recurring charges) from being billedto this phone number.BLOCK & CANCEL160UnbillableGLOBAL - Line number has beenConsumer requested block to stop all chargesblocked to stop all charges.from being billed to this number.161UnbillableCLIENT - Line number has a blockConsumer requested a block to stop chargesto stop all charges from this Clientfrom being billed or to cancel service for thisid.phone number from this Client id.UNBILLS960UnbillableLine number is Unbillable.Line number has been returned from the LocalTelephone companies within th last 6 monthsas unable to be billed.LIDB FAILURE180UnbillableLine number failed LIDB check -Line Number has been returned from LIDB asGENERALUnbillable.181UnbillableVacant NPA NXXNo working line #s in NPA NXX182UnbillableNo Incoming CallsLine # cannot accept incoming calls183UnbillableDenied ANIAuto decline of all attempts from this ANI184UnbillableCalling Card blockAuto decline of Calling Card number185UnbillableCollect Call BlockAuto decline of Collect calls to this number186UnbillableThird Party Call BlockAuto decline all Third Party billed calls to thisnumber187UnbillableCredit Card BlockAuto decline of charges billed to Credit Card188UnbillableGroup Number BlockAuto decline of attempts from this group.189UnbillableAudiotext BockNumber does not allow audiotext calls.190UnbillableExcessive Calling Card PIN hitsThreshold for calling card attempts has beenexceeded.191UnbillableLine Number BlockAuto decline of all charges to this number200UnbillableExcessive Use - BTNBTN has exceeded threshold201UnbillableExcessive Use DNDN has exceeded threshold202UnbillableExcessive Use - ANIANI has exceeded threshold203UnbillableExcessive USE - Calling Card PinCalling Card Pin has exceeded threshold220UnbillableFeature Group ALocal telephone switch is Feature Group A221UnbillablePBX lineLine # is a PBX line222UnbillableWATS lineLine # is a WATS line223UnbillableHotel/Motel Auto Quote w/ taxHotel/Motel Auto Quote w/ tax224UnbillableHotel/Motel Auto quote w/o taxHotel/Motel Auto quote w/o tax225UnbillableDormitory lineLine # belongs to a dorm226UnbillableHospital lineLine number belongs to a hospital227UnbillableCentrex lineLine number belongs to CENTREX228UnbillableAlternate Service ProviderLine # belongs to an alternate service provider229UnbillablePOTS line (collect or third partyLine # is plain old telephone service lines forcalls)business or residential230UnbillablePager #Line number belongs to pager231UnbillablePCS/Mobile/Cellular #Line number belongs to a wireless provider240UnbillableLine was disconnected w/o referralLine # was disconnected w/o a referral number241UnbillableLine Number changingLine is not connected yet.242Unbillablenot used243UnbillableDISCO w/o referralLine number has been removed from servicew/o referral244UnbillableTemp DISCOLine number has been removed from servicetemporarily245UnbillableDISCO with referralLine number has been disconnected w/ referralor Operator takes calls246UnbillableTemp DISCO w/ referralLine number has been removed from servicetemporarily w/ referral250UnbillablePOTS line rating on rate planPOTS line is on a rate plan for business orresidential message rate 1 or 2 or flat rate300UnbillablePublic - Incompatible interfacePublic phone with incompatible interface301UnbillableLEC Public Standard PreP OTLEC Public phone standard interface; prepayovertime302UnbillableLEC Public AlternateLEC Public phone alternate interface; functionscontrolled by set303UnbillableLEC Public Standard PP OTLEC Public phone standard interface; postpayovertime304UnbillableIC PublicIC Public Phone - Alternate Interface305UnbillableIC Public StandardIC Public Phone - Standard Interface306UnbillableLEC Public Special - PP OTLEC Public Phone- Special billing post paidOT307UnbillableLEC Public Special - PreP OTLEC Public Phone - Special Billing; Pre payOT308UnbillableLEC Semi PublicLEC Semi Public Phone309UnbillableLEC Semi Public Phone (no collectLEC Semi Public Phone does not allow collector 3rd Party calls)or 3rd party calls to this number310UnbillableLEC Prepaid CardLEC Prepaid Card Telecommunications station311UnbillableIPP (fka COCOT) Standard interfacePayphone Standard312UnbillableIPP (fka COCOT) Alternate interfacePayphone - Alternate313UnbillableCoinless (non IPP fka COCOT)Coinless Pay phone314UnbillableCoinless (IPP fka COCOT)Coinless payphone315UnbillablePrison (non IPP fka COCOT)Prison payphone316UnbillablePrison (IPP fka COCOT)Prison Payphone450UnbillableBNS: Voice Quote - without taxCharge quotes without tax451UnbillableBNS: Voice Quote - with taxCharge quotes with taxCREDIT CARD RESPONSE CODES000ApprovedCredit card approved501Decline/ErrorUser authentication Failed502Decline/ErrorInvalid tenderYour merchant bank account does not supportthe following credit card type that wassubmitted503Decline/ErrorInvalid transaction typeTransaction type is not appropriate for thistransaction. For example, you cannot credit anauthorization-only transaction.504Decline/ErrorInvalid amount505Decline/ErrorInvalid merchant informationProcessor does not recognize your merchantaccount information. Contact your bankaccount acquirer to resolve this problem.512Decline/ErrorDeclinedPlease check the credit card number andtransaction information to make sure they wereentered correctly. If this does not resolve theproblem, have the customer call the credit cardissuer to resolve.513Decline/ErrorReferralTransaction was declined but could beapproved with a verbal authorization from thebank that issued the card. Submit a manualVoice Authorization transaction and enter theverbal auth code519Decline/ErrorOriginal transaction ID not foundThe transaction ID you entered for thistransaction is not valid.520Decline/ErrorCannot find the customer referencenumber522Decline/ErrorInvalid ABA number523Decline/ErrorInvalid account numberPlease check credit card number and re-submit.530Decline/ErrorAccount Lookup informationAccount provided found in system, however,Mismatchunique key provided does not match uniquekey in system.531Decline/ErrorAccount does not existAccount provided not found in system1102Decline/ErrorInvalid expiration datePlease check and re-submit525Decline/ErrorTransaction type not mapped to thishost526Decline/ErrorInvalid vendor account527Decline/ErrorInsufficient partner permissions528Decline/ErrorInsufficient user permissions550Decline/ErrorInsufficient funds available551Decline/ErrorInvalid transaction returned fromhost552Decline/ErrorProcessor not available553Decline/ErrorCredit errorPlease make sure you have not already creditedthis transaction, or that this transaction ID isfor a creditable transaction. (For example, youcannot credit an authorization.)5110Decline/ErrorVoid errorPlease make sure the transaction ID entered hasnot already been voided. If not, then look at theTransaction Detail screen for this transaction tosee if it has settled. (The Batch field will be setto a number greater than zero if the transactionhas been settled). If the transaction has alreadysettled, your only recourse is a reversal (credita payment or submit a payment for a credit).555Decline/ErrorCapture errorOnly authorization transactions can be captured556Decline/ErrorFailed AVS checkAddress and Zip code do not match557Decline/ErrorCannot exceed sales capFor ACH transactions only558Decline/ErrorCVV2 Mismatch800UnbillableLNP Only Look-Up, number was foundLNP Only Look-Up, number was found in the LNPGTT database as ported.801UnbillableLNP Only Look-Up, number was notLNP Only Look-Up, number was not found in thefoundLNP GTT database, not ported.802UnbillableLNP Only Look-Up, the NPANXX is notLNP Only Look-Up, the NPANXX is not a portablea portable range.range.SYSTEM DOWN994ResubmitMessage Format ErrorMessage received in invalid or unrecognizedformat.995ResubmitTime outSession timed out.996ResubmitConnection FailureUnable to connect.997ResubmitSubsystem FailureSubsystem, such as LIDB, Credit Card, etc, notavailable.998ResubmitNetwork FailureNetwork Not Available999ResubmitSystem DownSystem Unavailable


As mentioned above, the module 200 translates the LIDB codes into modified verification codes as shown in Table 2. These modified validity codes are then mapped or translated. Table 3 below provides a list of the modified validity codes which are generated following the mapping carried out by the processor module 110 to translate LIDB codes to the modified verification codes set out in Table 1.

TABLE 3LIDB/LNP SOURCE TRANSLATIONS for ISP:Resp.Resp.LIDBrtfcType InCode InACTIONADMIN?DescriptiontypeEBI Code OutAPP000ApprovedCalling card has an Unrestricted PIN.G1000APP001ApprovedCalling card has a Restricted PIN. The switch must verifyg1000that the DNI matches the first 10 digits of the calling cardbefore placing the call.APP004ApprovedCollect call - No verification is required.G1000APP005ApprovedThird-party call - No verification is required.G1000APP006ApprovedThere is a system error.S999APP008ApprovedCommunications Link Tests “Good.”S999APP010ApprovedCommercial credit card is approved and the zip codeG1000matches, if the zip code was sent.APP011ApprovedYBill-to number has an Admin. Override to automaticallyG1000approve the transaction. (Admin. Reply)APP012ApprovedOriginating number (ANI) has an Admin. Override toG1000automatically approve the transaction. (Admin. Reply)APP013ApprovedDialed number (DNI) has an Admn Override to automaticallyG1000approve the transaction. (Admin. Reply)APP014ApprovedGroup number has an Admin. Override to automaticallyG1000approve the transaction. (Admin. Reply)APP015ApprovedCommercial credit card is approved but the zip code check isCC500unavailable.APP016ApprovedCommercial credit card is approved but the zip code check isCC501unavailable. Retry later.APP096ApprovedCommercial credit card is approved but the zip code check isCC502not supported.APP018ApprovedCommercial credit card is approved and the address matchesCC503but the zip code does not match.APP019ApprovedCommercial credit card is approved and the address and theCC504zip code match.APP020SuccessLNP Only Look-Up, number was found in the LNP GTTLNP800database as ported.APP021SuccessLNP Only Look-Up, number was not found in the LNP GTTLNP801database, not ported.CON050VerifyCollect call number has no block. Verify acceptance of theo1000charge.CON051VerifyThird-party call number has no block. Verify acceptance ofO1000the charge.CON053DeniedUnable to authorize, Automatic Code Gapping is in effect atS999the LIDB. Every third query is dropped by the LIDB.CON0110DeniedYExcessive Use - The bill-to number exceeded the high limitG3000threshold in the Admin. fraud control system. (Admin.Reply)CON055DeniedYExcessive Bad PIN Attempts - The threshold for bad PINO2000attempts for the calling card was exceeded in the Admin.fraud control system. (Admin. Reply) This is the same asreply code 309.CON060ConditionalYLow Limit Warning - The bill-to number exceeded the lowG3000limit threshold in the Admin. Fraud control system. (Admin.Reply)CON061ConditionalYLow Limit Warning - The dialed number exceeded the lowG3000limit threshold in the Admin. fraud control system. (Admin.Reply)CON062DeniedYExcessive Use Dialed - The dialed number exceeded the highG3000limit threshold in the Admin. fraud control system. (Admin.Reply)CON063ConditionalYNo Host Still Billable - There is no LIDB check available, butG2180the Customer has a billing agreement with this LEC.(Admin. Reply)CON064ApprovedYCommercial credit card is approved but the zip code and theCC505address do not match.CON065ConditionalYLow Limit Warning - The ANI exceeded the low limitG3000threshold in the Admin. fraud control system. (Admin.Reply)CON066DeniedYExcessive Use ANI - The ANI exceeded the high threshold inG3000the Admin. fraud control system. (Admin. Reply)CON070ApprovedCalling card has no service denial in the Card Service DenialG1000Indicator field. Calling card calls may be billed to this cardnumber.CON071ApprovedCalling card has no service denial in the Pin Service DenialG1000Indicator field. Calling card calls may be billed to this cardnumber.CON080VerifyCollect calls - Accept intralata, Reject interlata collect calls.O1000Recommend verify acceptance of the charge.CON081VerifyThird-party calls - Accept intralata, reject interlata third-partyO1000calls. Recommend verify acceptance of the charge.CON082VerifyCollect calls - Accept intralata, verify interlata collect calls.O1000Recommend verify acceptance of the charge.CON083VerifyThird-party calls - Verify intralata, reject interlata third-partyO1000calls. Recommend Verify acceptance of the charge.CON084VerifyCollect call - Verify acceptance of the charge by an Operator.O1000CON085Verify.Third-party call - Verify acceptance of the charge by anO1000Operator.CON086VerifyCollect call - Accept intralata charge, verify interlata chargeO1000with Operator.CON087VerifyThird-party calls - Verify intralata charge with operator,O1000reject interlata charge with Operator.CON088VerifyCollect Calls: POTS Line (Business/Residential)G5000CON089VerifyThird-Party Calls: POTS Line (Business/Residential)G5000CON090VerifyBNS: Centrex Line, Collect calls - Some LECs allow billingG4000to this type of line, others do not. Verify Acceptance.CON091VerifyBNS: POTS Line - Residential - Message rate 1G9000CON092VerifyBNS: POTS Line - Residential - Message rate 2G9000CON093VerifyBNS: POTS Line - Business - flat rateG9000CON094VerifyBNS: POTs Line - Business - message rate 1G9000CON095VerifyBNS: POTS Line - Business - message rate 2G9000CON096VerifyBNS: POTS Line - Residential - flat rateG9000DENY100DeniedMessage Format Error MessageS994DENY100DeniedMessage Format Error-Date formatS994DENY100DeniedMessage Format Error-Header Message ErrorS994DENY100DeniedMessage Format Error-Merchant ID ErrorS994DENY100DeniedMessage Format Error-No End of Header IndicatorS994DENY100DeniedMessage Format Error-Header Data Indicator, did not containS994data in each field of the Message That was represented by themessage text map fieldDENY100DeniedMessage Format Error-PIN not numericS994DENY100DeniedMessage Format Error-Terminating Error (commercial creditS994card onlyDENY100DeniedMessage Format Error-Terminating Number not numericS994DENY100DeniedMessage Format Error-Originating Number not NumericS994DENY100DeniedMessage Format Error-Charge Number not NumericS994DENY100DeniedMessage Format Error-No End Header IndicatorS994DENY101DeniedMessage Format Error Invalid Customer/Terminal IDS994NumberDENY102DeniedMessage Format Error Invalid Message TypeS994DENY103DeniedMessage Format Error Invalid Transaction TypeS994DENY104DeniedMessage Format Error Invalid Sequence NumberS994DENY105DeniedMessage Format Error Invalid Data IndicatorS994DENY105DeniedMessage Format Error-Header Data IndicatorS994DENY107DeniedBad PIN format. PINs must be equal to or higher than 2000.S994DENY200DeniedCalling card blocked, missing customer record - There is noS994record of that calling card number in the database.DENY201DeniedBNS, missing customer record - There is no record of thatS994line number in the database.DENY202DeniedMissing BNG - There is no record of that NPANXX in theS994database.DENY203DeniedNon billable NXX - DPC table failure. The NPANXX doesG2180not have routing or allow billing, e.g. cellular. (LIDB orAdmin. Reply)DENY204DeniedCalling card blocked, screened data - A screening mechanismO2000is in place at the LIDB that does not allow charges to thiscalling card.DENY205DeniedProtocol converter problem - There is a problem with the SS7S999protocol converter.DENY206DeniedBNS & No Calling Card Calls - No Host, Nonparticipatingo2180Group. This NPANXX exists but there is no LIDB host.(LIDB or Admin. Reply)DENY207DeniedLIDB Access Denied because no queries should be sent toS999this LIDB destination. (Admin. Reply)DENY208DeniedCalling card blocked, Screened Data on PIN (Pin ServiceO2000Denial Indicator) - A screening mechanism is in place at theLIDB that does not allow charges to this PIN.DENY209DeniedExternal SS7 Problem - There is a format problem in the SS7S999networkDENY210DeniedCalling card blocked, screened data - A screening mechanismO2000is in place at the LIDB that does not allow charges to thiscalling card.DENY211DeniedCalling card is blocked because it has a bad PIN or the PINO2000does not match database information.DENY211DeniedUnexpected Data Value, Calling card blocked, Bad PIN -O2000This means a bad PIN was used or there is no PIN on file.DENY212DeniedCalling card blocked, PIN Excessive Use at LIDB Owner. -G3000The PIN exceeded the high threshold in the LIDB fraudcontrol systemDENY213DeniedVacant BNG - There are no working lines in the NPANXX.G2181DENY214DeniedNo Collect calls - Collect calls are not allowed to this lineO2000number.DENY215DeniedNo Third-party calls - Third-party calls are not allowed to thisO2000line numberDENY216DeniedBNS: LEC Public - Standard Interface (functions controlledG10303by the network) - Postpay OvertimeDENY296DeniedBNS: Coinless (non IPP fka COCOT)G10313DENY218DeniedBNS: semi-public phone - No Collect or Third-party calls areG10309allowed to this line number.DENY219DeniedSpare - This LIDB response is not in use at this time.AV180DENY220DeniedTime-out, No response from Host - A response was notS180received from the host database within 4 seconds for a Telcoquery or 12 seconds for a Bank card query. (LIDB or Admin.Reply)DENY221DeniedBNS Data unavailable, Error Message, No Host - No collectS180or third-party calls should be allowed to this line number.DENY222DeniedCalling card Data unavailable, Error Message, No Host - NoS180calling card calls should be allowed to this line number.DENY223DeniedBNS & Calling card, screened response LIDB - A screeningO2000mechanism is in place at the LIDB that does not allowcharges to this account number.DENY224DeniedLIDB Misroute - The query was routed to the wrong LIDB.S999DENY225DeniedReject, Reroute - The LIDB could not read the format of theS994query.DENY226DeniedUnexpected Component - The LIDB cannot interpret theS994format of the query.DENY227DeniedUDTS, SS7 Network problem - There is an SS7 networkS999problem.DENY228DeniedBNS: Personal Communication Service (PCS)G8231DENY229DeniedBNS: MobileG8231DENY230DeniedNot Billable - The Customer does not have a billingG2180arrangement with the LEC for this NPANXX (OCN On-NetScreening).DENY231DeniedBNS: LEC Prepaid Telecommunications Card StationG10310DENY232DeniedFeature Group A (FGA)G4000DENY233DeniedBNS: LEC Public - Alternate Interface (functions controlledG10302by set)DENY234DeniedBNS: LEG Public - Special Billing - Postpay OvertimeG10306(functions controlled by the network)DENY235DeniedBNS: LEC Public - Special Billing - Prepay OvertimeG10307(functions controlled by the network)DENY236DeniedBNS: Public - Incompatible Network Interface (interfaceG10300other than standard or alternate)DENY237DeniedBNS: IC Public - Alternate InterfaceG10304DENY238DeniedBNS: IPP (fka COCOT) - Standard Interface311DENY239DeniedBNS: PagerG8230DENY241DeniedGeneral, Reject - The LIDB could not read the format of theS994query.DENY242DeniedInvoke, Reject - The LIDB could not read the format of theS994query.DENY243DeniedReturn Result, Reject - The LIDB could not read the formatS994of the query.DENY244DeniedReturn Error, Reject - The LIDB could not read the format ofS994the query.DENY245DeniedTransaction Portion, Reject - The LIDB could not read theS994format of the query.DENY246DeniedBNS: Vacant Number - There is no line number assigned.G2180DENY247DeniedBNS: Disconnected without referral - The line number wasG6240disconnected with no referral to a new line number.DENY248DeniedBNS: Changed to non-published number - The line numbero5000was changed to a non-published number.DENY250DeniedNo Collect Calls, Screened Data - A screening mechanism isO2000in place at the LIDB that does not allow charges to this linenumber.DENY251DeniedNo Third-party calls, Screened Data - A screeningO2000mechanism is in place at the LIDB that does not allowcharges to this line number.DENY252DeniedBNS: Screened Data - A screening mechanism is in place atG7191the LIDB that does not allow charges to this line number.DENY253DeniedBNS: Screened Data - A screening mechanism is in place atG7191the LIDB that does not allow charges to this line number.DENY2110DeniedBNS & No Calling Card, Unavailable network resource - O2411This line or card number is not in the database.DENY255DeniedBNS: Screened Data - A screening mechanism is in place atG7191the LIDB that does not allow charges to this line number.DENY256DeniedBNS: Being changed - The line number is being changed, itG6241may not yet be connected.DENY257DeniedBNS: May not yet be connected - The line number may beG6243new, it may not yet be connected.DENY258DeniedBNS: Temporarily disconnected - The line number isG6244temporarily disconnected.DENY259DeniedBNS: Disconnected, calls being taken by operator - The lineG6245number is temporarily disconnected, the operator is takingcalls.DENY260DeniedBNS: Temporarily removed from service - The line numberG6244is temporally removed from service.DENY261DeniedBNS: Not in service for incoming calls - This line numberG2182cannot accept incoming calls.DENY262DeniedBNS: Temporarily disconnected at customer request withoutG6245referral - The line number is temporarily disconnected at therequest of the customer without referral.DENY263DeniedBNS: Temporarily disconnected at customer request withG6246referral - The line number is temporarily disconnected at therequest of the customer with referral.DENY264DeniedBNS: Changed with referral to new number - The lineo5000number was changed. A referral to another line number is inplace.DENY265DeniedCalling card blocked, PIN Nonpayment - The calling card isO2000blocked because of nonpayment.DENY266DeniedCalling card blocked, Service Restriction on PIN - There is aO2000service restriction on this PIN.DENY267DeniedCalling card blocked, no PINs assigned. There is no PINO2000assigned to this calling card/line number.DENY268DeniedCalling card blocked, service denial - There is a serviceO2000restriction on this calling card.DENY269DeniedCalling Card - The calling card is a CIID (proprietary card)O2000for which there is no host.DENY270DeniedBNS: Unexpected Data Value - No Collect or Third-PartyS994Calls are allowed.DENY272DeniedLIDB/CCC Response Time-out - A response was notS180received from the host database within 4 seconds for a Telcoquery and 12 seconds for a Bank query.DENY273DeniedNo Collect Calls at Customer Request - The end userO2000customer requested the block for collect calls to this linenumber.DENY274DeniedBNS & No Calling Card Calls: Screened data.O2000DENY275DeniedBNS: Hotel/Motel Auto Quote - with taxG4000DENY276DeniedBNS: Dormitory LineG4225DENY277DeniedBNS: Hotel/Motel Auto Quote - without taxG4000DENY278DeniedBNS: PBX LineG4221DENY279DeniedBNS: Prison (IPP fka COCOT)G10316DENY280DeniedBNS: WATS LineG4222DENY281DeniedNo Third-party calls at Customer Request - The end userO2000customer requested the block for third-party calls to this linenumber.DENY282DeniedBNS: LEC Public - Standard interface - Prepay OvertimeG10301DENY283DeniedBNS: Coinless (IPP fka COCOT)G10314DENY284DeniedBNS: IC Public - Standard InterfaceG10305DENY285DeniedBNS: Voice Quote - without taxo6450DENY286DeniedBNS: Voice Quote - with taxo6451DENY287DeniedBNS: IPP (fka COCOT) - Alternate InterfaceG10312DENY288DeniedBNS: HospitalG4226DENY289DeniedBNS: Prison (non-IPP fka COCOT)G10315DENY290DeniedBNS: LEC Semi-PublicG10308DENY291DeniedBNS: Subsystem CongestionS180DENY292DeniedBNS: Subsystem FailureS180DENY293DeniedBNS: No translation for address of such natureS180DENY294DeniedBNS: Unequipped UserS999DENY295DeniedBNS: Network FailureS180DENY296DeniedBNS: Network congestionS999DENY297DeniedBNS: Cellular (cellular is distinct from mobile)G8231DENY298DeniedBNS and Calling Card - Although the NPANXX belongs toG4228SWBT the end-user account number is no longer is a SWBTcustomer. The line number now belongs to another localservice provider.DENY299FailureLNP Only Look-Up, the NPANXX is not a portable range.LNP000DENY301DeniedYDenied Originating Number (ANI) - The ANI has an Admin.G2183block to automatically decline all attempts from this linenumber. (Admin. Reply)DENY302DeniedYTerminating Number (DNI) has an Admin. block toG2182automatically decline all attempts to this line number.(Admin. Reply)DENY303DeniedYCalling card has an Admin. block to automatically decline allG2000attempts to this line number. (Admin. Reply)DENY304DeniedYCollect Number has an Admin. block to automatically declineG2000all attempts to this line number. (Admin. Reply)DENY305DeniedYThird Party Number has an Admin. block to automaticallyG2000decline all attempts to this line number. (Admin. Reply)DENY306DeniedYCommercial credit card has an Admin. block to automaticallyG2000decline all attempts to this line number. (Admin. Reply)DENY307DeniedYGroup Number has an Admin. block to automatically declineG2000all attempts from this group. (Admin. Reply)DENY308DeniedYGlobal Negative Database Block - There is an Admin. blockG2000in the Global Negative Database to this line number for theAudiotext Industry. (Admin. Reply)DENY309DeniedYExcessive calling card PIN hits - The threshold for bad PING2000attempts for a calling card was exceeded in the Admin. fraudcontrol system (Admin. Reply). This is the same as replycode 055.DENY400DeniedCommercial credit card, Invalid Commercial credit card - 506This is not a valid commercial credit card account number. Itfailed the MOD 10 check. Also an invalid amount, invaliddate or a format error may cause this response. (Host orAdmin. Reply)DENY401DeniedCommercial credit card, Call issuer - The authorization507attempt triggered a flag in the fraud control system of theissuing bank, Banknet or VISAnet.DENY402DeniedCommercial credit card, Confiscate card - No billing is508allowed to this account number. If possible confiscate thiscard.DENY403DeniedCommercial credit card, Authorization Declined - No billing509is allowed to this account number.DENY404DeniedCommercial credit card, Unable to Validate Account Number - 510There is problem in authorizing this account number.DENY405DeniedCommercial credit card, Card expired - No billing is allowed511to this account number because the card has expiredDENY406DeniedCommercial credit card - Invalid Merchant ID512DENY408DeniedCommercial credit card, Invalid card and Address (zip code) - 513Both the account number and the address or zip code areinvalid. Do not allow billing to this account number.DENY409DeniedCommercial credit card, System Problem - There is a514technical problem with the authorization system of theissuing bank, Banknet or VISAnet.DENY420DeniedCommercial credit card, Over withdrawal limit - This account515has exceeded the withdrawal threshold in the authorizationsystem of the issuing bankDENY421DeniedCommercial credit card, Over credit limit - This account has516exceeded the credit threshold in the authorization system ofthe issuing bankDENY422DeniedCommercial credit card, Lost card, Confiscate - This596account number was reported lost. No billing is allowed tothis account number. If possible confiscate this card.DENY423DeniedCommercial credit card, Stolen card, Confiscate card - This518card was reported stolen. No billing is allowed to thisaccount number. If possible confiscate this card.DENY424DeniedCommercial credit card, Invalid Pin - This means a bad PIN519was used.DENY425DeniedCommercial credit card, Allowable Number of PIN Tries520Exceeded - The threshold for bad PIN attempts for a callingcard was exceeded in the authorization system of the issuingbank, Banknet or VISAnet.DENY426DeniedDuplicate transaction. The Authorization host considers this521a duplicate transaction.


In the embodiment of the invention depicted in the drawings, regardless of the type of service provider or the type of validation request, all clients or vendors 22 typically need a profile so that the process or method carried out by the module 200 knows how to treat the request. The client or vendor profile is set up in a database which includes the indicators that are set for the type and tests for each request which will be subsequently received from the vendor.

Client or Vendor Profile TableFieldsData TypeKeyNameChar(10)ClientChar(4)PrimaryProductChar(3)TranstypeChar(3)BTN_vs_ANINull or notGlobal_OffnetNull or notClient_OffnetNull or notProduct_OffnetNull or notCalling_Card_OffnetNull or notPlan_OffnetNull or notONNETNull or notCLECNull or notBlock42Null or notUnbillNull or notCancelNull or notSmart_LIDBNull or notArea_Code_SplitNull or notZipNull or notBNANull or notBNA_AVAILNull or notThresholdNull or notClient_Bad_ANINull or notGlobal_Bad_ANINull or notProduct_Bad_ANINull or notNON-PAYNull or notGoodwillNull or notReturn_To_SenderNull or notCredit_CheckNull or not
Note:

Some tests are required for certain validation types.


In certain embodiments, the client or vendor profile is used to determine which validation request type to convert from or to, which validation checks should be performed on the ANI/BTN for the particular purchase event, which checks are to be performed for the pre-billing validation event at the time of billing, and the billing record conversion specifics for that client or vendor. Thus, the facility 28 may customize is validation procedures to suit a specific client or vendor.


For the both the validation events, the client profile check is typically performed in facility 28 prior to carrying out the validity checks. For example, the customer profile check may be included in step 98 (see FIG. 13) and step 142 (see FIG. 14). The customer profile includes client specific information which may determine the nature and extent of the validation process. Accordingly, the profile may be checked as soon as the record is received from a registration module or the customer management system 58. In use, a profile table is queried to identify the validation checks to be performed by the module 30 and the checks may differ between an initial purchase event or transaction and an associated subsequent billing event at the end of a bill cycle. These checks may, dependent on the client profile, include checking if the ANI is the same as the BTN, if the subscriber line is listed in OFFNET database 222, in the UNBILLS database 232, in the Blocking databases 228,230, in the CLEC database 226, in the LIDB database 252, in the address verification database 244, or in databases including data on previous credits, new lines, business lines area codes, area code changes, or the like.


Additionally, the client profile is typically checked to see which billing record should be written for inclusion on the phone bill for that particular purchase. This may occur as the first part of step 218 in FIG. 15 and step 260 in FIG. 17.


The client profile can also be used to determine the type of billing record to convert from and the type to convert to for inclusion the telephone account 34 for the purchase or transaction. For example, the types of billing records may include a 425001 record for a monthly recurring charge; 010101, 010105, 010102, 010116 type records for detailed, usage-based events; and 415001, 410101, 410105, 410102, 410116 records for the credit records.


An example of software tables for implementing the steps in the method set out in the flow diagrams shown in FIGS. 17 to 19 are shown below.


The first table shows the steps in the BTN test descriptions process. Typically, a set of core tests is run for each client. Additionally, clients may have some configuration options to identify the tests that best fit their program.

PROCESSTESTsPURPOSEBILLABLE BTN TESTsVAL/Pre-billClient profileClient profile for each id for BTN validation process test flags.VAL onlyANI = BTNDetermines if originating number = BTN input by caller.VAL/Pre-billInvalid # OFFNETIds Invalid NPAs & NXXsVAL/Pre-billGlobal OFFNETIds (NPA)NXX & OCN combinations where there is not a B&C agreementVAL/Pre-billProduct OFFNETIds (NPA)NXX & OCN combinations where the traffic type is not approved to bill(Jul. 24, 2001: MRC only for NECA and Illuminet Only)VAL/Pre-billClient OFFNETIds (NPA)NXX & OCN combinations where there the Client id (7###) is notapproved to billVAL/Pre-billSpecial Calling CardIds (NPA)NXX & OCN combinations of special calling card #s for non-calling cardOFFNETtraffic that are unable to be billedVAL/Pre-billPlan OFFNETIds (NPA)NXX & OCN combinations where a Client Plan is not approved to billVAL/Pre-billONNETIds (NPA)NXX & OCN combinations where there are B&C agreementsVAL/Pre-billCLECIds (NPA)NXX-xxxx's are not billable due to CLEC for all Clients.VAL/Pre-bill4250 BLOCKIds (NPA)NXX-xxxx's that have a 4250 billing block(for MRC only)VAL/Pre-billUNBILLIds (NPA)NXX-xxxx's that have unbilled previously for all ClientsVAL/Pre-billBlock & Cancel -Ids (NPA)NXX-xxxx's that requested a Block and/or Cancel; usually institutionalGLOBALVAL/Pre-billBlock & Cancel - ClientIds (NPA)NXX-xxxx's that requested a Block and/or Cancel for a particular Client idSpecificVAL/1st + nVal Code CacheIds (NPA)NXX-xxxx & Return Code combinations for previous requestPre-billVAL/1st Pre-LIDB Validity TestTo determine the billable status of the return code from the LIDB dipbillVAL/1st Pre-LIDB CLEC RAOIds RAOs that belong to CLECsbillVAL/1st Pre-LIDB CLEC OCNIds known CLEC OCNsbillVAL/1st Pre-LIDB State SpecificTo determine if the returned LIDB code is a state specific code and then a conversionbillConversionto the billable OCN for the ONNET checkVAL/1st Pre-LIDB ONNETIds billable (NPA)NXX & returned OCN combinationsbillALLVAL Trans LogLog of each validation request and response by Client IDBTN CREDIT SCORINGVAL/Pre-billAREA CODE ChangeProvides the new area code for the line number while in permissive dialing period.indicatorValZIP MATCHZIP matches zip codes for (NPA) NXX (not in production as of 6/01)VAL/Pre-billANI WATCH -CLIENT(NPA)NXX-xxxx's where there a refund/chargeback has been issued previously(SOURCE: all)for this Client IDVAL/Pre-billANI WATCH -CLIENT(NPA)NXX-xxxx's where there a refund has been issued previously for this Client(SOURCE: client)IDVAL/Pre-billANI WATCH -CLIENT(NPA)NXX-xxxx's where there a chargeback/bad debt has been issued previously(SOURCE: ebi/telco)for this Client IDVAL/Pre-billANI WATCH -(NPA)NXX-xxxx's where there a refund/chargeback/bad debt has been issuedGLOBALpreviously from CLIENT, ebi or telco(SOURCE: all)VAL/Pre-billANI WATCH -(NPA)NXX-xxxx's where there a refund/chargeback/bad debt has been issuedPRODUCTpreviously for the same product(SOURCE: all)VALAddress VerificationNot AvailableTEST BEFORE FIRST BTN BILLINGVAL/Pre-billLEC CARE FEEDDetermines if the ILEC owns the Acct. for billingVAL/Pre-billBiz vs ResDetermines the commercial or consumer status for credit scoreExample TESTsVAL/Pre-billThreshold by ClientDetermines whether the BTN has met a Client specific thresholdVAL/Pre-billLEC PROV feedTo determine if LEC owns AcctVAL/Pre-billCredit CheckCredit header files check from Credit sourceVAL/Pre-billNew within 90 daysDetermines if BTN is less than 90 days old; affects credit score


ON/OFFNET Family Tables (Billing Coverage)


The OFFNET table family contains OCN & NPA_NXX combinations where billing is not approved. If found, the BTN does not continue on the validation path.

FieldsData TypeKeyInvalid # OFFNET TableNPA_NXXNumeric(6)PrimaryOFFNET Global TableNPA_NXXNumeric (6)PrimaryOFFNET Product TableOCNInt(4)NPA_NXXNumeric(6)PrimaryNSP_ProductVarchar(10)PrimaryOFFNET Client TableOCNInt(4)PrimaryClient IDChar(4)SecondarySpecial Calling Card OFFNET TableOCNInt(4)NPA_NXX_xxxxNumeric(10)PrimaryPlan OFFNET TableClient idChar(4)PrimaryOCNInt(4)PrimaryNPA_NXXNumeric(6)PrimaryNSP_PlanChar(3)Primary


The ONNET table determines if an NPA_NXX & OCN combination can be found among the billable combinations. In this case a match, allows the BTN to move further on the validation path. A no match will return a failure.

ONNET TableFieldsData TypeKeyOCNNumeric(4)NPA_NXXNumeric(6)Primary


The CLEC table consists of CLECs that the proprietor, or user of the module 200, does not have billing contracts with. This table is specific to the line number. Sources dictate the fields that will be present for the record. A match here is considered a fail and does not continue.

CLEC TableFieldsData TypeKeyBTNNumeric(10)PrimaryJulianChar(3)YearChar(2)DateDateTimeOCNInt(4)


The 4250 Block table consists of specific line numbers that cannot be billed for 4250-01 record types. A match in this table stops the validation movement.

4250 Block TableFieldsData TypeKeyBTNNumeric(10)PrimaryJulianChar(3)YearChar(2)DateDateTime


BILL CONTROL Family Tables


The Unbills or unbillable table holds all the BTNs that have been sent to a subscribers bill page but could not be placed on the bill page for various reasons. A match here halts the validation sequence for the subject BTN.

Unbill TableFieldsData TypeKeyBTNNumeric(10)PrimaryClient idInt(4)SecondaryProductVarChar(3)TertiaryDateDateTimeReason CodeAlphaN(2)


Block and cancel tables identify BTNs that have requested a permanent or a Client specific block for billing. A match sends a failed response.

FieldsData TypeKeyBlock & Cancel - Global TableBTNNumeric(10)PrimaryDateDateTimeBlock & Cancel - Client Specific TableBTNNumeric(10)PrimaryDateDateTimeClient idNumeric(4)Secondary


Validation Cache is a table that holds responses in order not to process duplicates (e.g., Submit pressed 10 times). A match here will return the code stored from a previous request.

Validation Cache TableFieldsData TypeKeyBTNNumeric(10)PrimaryResponseChar(3)DateDateTime


LIDB Family Tables


LIDB is a third party that supplies information to the phone line number level. The module 30 typically tests and stores as many relevant fields as can be requested in a transaction.

LIDB Codes TableFieldsData TypeKeyLIDBChar(3)PrimaryDescriptionChar(100)RFCChar(3)ISPChar(3)OSPChar(3)CCCChar(3)LDDChar(3)CRCChar(3)


The LIDB Validity Table translates the LIDB code into a billable or non-billable response according to predefined business rules. A fail here will halt the validation for the request.

LIDB Validity Translation TableFieldsData TypeKeyBTNNumeric(10)PrimaryDateDateTimeLIDB_CodeChar(3)OCNChar(4)TransTypeChar(3)UpdatedbitRAOChar(3)


The State specific table is a conversion from a true OCN to a known State Specific OCN that is billable. A match here will trigger the conversion, the BTN continues in the validation process.

LIDB State Specific OCN TableFieldsData TypeKeyST_OCNNumeric (4)PrimaryBillable_OCNNumeric (4)


The transaction log is the history of each transaction request and response that is processed through the validation system.

VAL Transaction Log TableFieldsData TypeKeyCLIENT IDInt(3)ANINumeric(10)LidbCodeChar(3)DateDateTimePrimary


The TPM indicates that an NPA is in the permissive dialing period. A match here appends the record with the updated number for a record update.

FieldsData TypeKeyTPM Change TableNPA_NXXNumeric (6)PrimaryDATEDateTimeTPM Delete TableNPA_NXXNumeric (6)NoneDATEDateTimeNone
* See Exhibit A


Validation Table Maintenance














TABLE LOAD










TABLE
SCHEDULE
SOURCE
HOW





Client profile
Adds & changes
CSA
Manual


ANI = BTN
NA
NA
NA


Invalid # OFFNET
Adds & changes
Rejects/Unbills*
Manual


Global OFFNET
2 × weekly
CYCLE OFFNET
Full Replace



Thurs for Mon cycle
P:/WC30/FILES/ONOFF



Tues for Thurs cycle
CIC: 903


Product OFFNET
Fridays
Client Directory
Full Replace




Cust7000 Directory


Client OFFNET
Fridays
Client Directory
Full Replace




CYCLE files




Load for each client id.


Special Calling Card
Fridays
CYCLE OFFNET
Full Replace


OFFNET

P:/WC30/FILES/ONOFF




CIC: 903


Plan OFFNET
Adds & changes
NA
Manual


ONNET
2 × weekly
CYCLE ONNET
Full Replace



Thurs for Mon cycle
P:/WC30/FILES/ONOFF



Tues for Thurs cycle
CIC: 903


CLEC1
Mondays
CLEC MASTER*
Incremental adds


CLEC2
as process LIDB responses
Fails for LIDB OCN/RAO tests
Insert with source


CLEC3
as process BNA responses
TCSI 2618s, 2619s codes that fail for
Insert with source




BNA


4250 BLOCK
Mondays
Block42 Master
Incremental adds


UNBILL
Mondays
Unbill Master from UB1s
Incremental adds


Block & Cancel -
Mondays
INQ file
Incremental adds


GLOBAL


Block & Cancel - Client
Mondays
INQ files for Clients
Incremental adds


Specific


Val CACHE
as process LIDB requests
LIDB requests
Insert new


LIDB Validity Test
NA
NA
NA


LIDB CLEC RAO
as process LIDB requests
Code 998 only (new Telcordia source)
TBD


LIDB CLEC OCN
As process LIDB requests
P:OCN.dat
Full replace


LIDB State Specific
Adds & changes
NA
manual


VAL Trans Log
Adds
NA
All adds


AREA CODE Change
Adds
TPM
All adds


indicator







*See Exhibit B for Billing rejects and Unbills codes that are loaded into tables.




















TABLE PURGE










TABLE
SCHEDULE
TRIGGER
HOW





Client profile
changes
NA
manual


ANI = BTN
NA


Invalid # OFFNET
changes
NA
manual


Global OFFNET
See load
See load
Full replace


Product OFFNET
See load
See load
Full replace


Client OFFNET
See load
See load
Full replace


Special Calling Card
See load
See load
Full replace


OFFNET


Plan OFFNET
See load
See load
Full replace


ONNET
See load
See load
Full replace


CLEC
90 days
Insert date
Delete from table


4250 BLOCK
180 days

Delete from table


UNBILL
OCN Moratorium
Insert date and elapsed time
Delete from table


Block & Cancel -
No purge

Delete from table


GLOBAL


Block & Cancel - Client
Every 6 months
From insert date
Delete from table


Specific


VAL CACHE
>2<30 days; >180
From insert date
Delete from table



days


LIDB Validity Test
As changes
NA
Manual


LIDB CLEC RAO
See load
NA
Full replace


LIDB CLEC OCN
See load
NA
Full replace


VAL Trans Log
No purge


AREA CODE Change
Monthly
Completion of Permissive
TPM deletions


indicator

Dialing period







*See Exhibit C OCN Moratorium schedule.








Exhibit A


Example Tables


Zip to NPA_NXX source allows for best 3 zips for an NPA_NXX combination. Tests show a 70% match rate. This rate has been improved by matching to position 1-3 of the Zip. The low match rate combined with the fact that a BTN is not a portable instrument, this test is not recommended for BTN validation.

Zip Match TableFieldsData TypeKeyNPA_NXXNumeric(6)PrimaryZIP1Numeric(5)NoneZIP3Numeric(5)NoneZIP3Numeric(5)None


The following tests are optionally carried out in other embodiments of the invention.

ANI WATCH TableFieldsData TypeKeyBTNNumeric(10)PrimaryNSP_ProductChar(5)NoneClient idNumeric (3)NoneDATETIMENumeric (4)NoneSOURCENumeric (6)None


The ANI Watch has BTNs that have been given an adjustment for charges by the Client, proprietor or user of the module 200 or the Telco. This is to help the client determine the credit score for the BTN.

FieldsData TypeKeyBilling Name and Address TableNameVarchar(30)NoneAddress1Varchar(30)NoneAddress2Varchar(30)NoneAddress3Varchar(30)NoneCityVarchar(20)NoneStateCHAR(2)NoneZip+4Numeric (10)NoneBTNNumeric (10)NoneDATEDateTimeNoneSourceVarchar(20)NoneBTN Thresholding TableBTNNumeric (10)NoneDATEDateTimeNoneClient IDNumeric(3)NoneeBi RESPONSE CODEChar(3)NoneNSP_ProductChar(10)NoneTotalInt(4)None


Exhibit B


Loaded Reject and Unbill Codes

RejectLOADCodesReject Code Descriptionin DB?DB?PURGE?15ORIGINATING NXX INVALID (NXX = 555 OR 976)YInvalid OFFNETN44BILLING NXX INVALID (NXX = 555 OR 976)YINVALIDN48REFUSE TO PAY/END USER REJECTYB&CNORMAL74LEC REQUESTED BLOCKYB&CNORMAL93REGULATORY BLOCKYB&CNORMAL94INTRASTATE LEC BLOCKYB&CNORMAL95ANI BLOCKYB&CNORMAL98NON-LOCAL INTRASTATE BLOCKYB&CNORMALLOAD inUnbill CodesUnbill Code DescriptionDB?DB?PURGE?M0SHARED NPA-NXX (CLEC)YCLEC90 DAYS12ORIG NPA/NXX NOT ON TPMYInvalid OFFNETNEVER15ORIG NXX INVALID (NXX = 555 OR 976)YInvalid OFFNETNEVER16ORIG NPA INVALIDYInvalid OFFNETNEVER30TERM NPA = 800YInvalid OFFNETNEVER44BILLING NXX INVALID (NXX = 555 OR 976)YInvalid OFFNETNEVERASINVALID NPA CODEYInvalid OFFNETNEVER18ORIG NUM INVALIDYUNBILLOCN34TERMINATING NUMBER INVALIDYUNBILLOCN36SPECIAL BILLING NBR - AT&T ONLYYUNBILLOCN37SPECIAL BILLING NBR - CINCINNATI BELL ONLYYUNBILLOCN38SPECIAL BILLING NUMBER INVALIDYUNBILLOCN41BILLING NPA/NXX IN SPECIAL BILL NBR NVALIDYUNBILLOCN59SUSPECTED FRAUDYUNBILLOCNA1SUSPECTED FRAUD NUMBERYUNBILLOCNA7INVALID BILL TO COIN ACCOUNTYUNBILLOCNA8NO ACCOUNTYUNBILLOCNB0NO ACCOUNT AFTER INVESTIGATIONYUNBILLOCND6INVALID BILLING NUMBERYUNBILLOCNE6CALLS OVER $999.99YUNBILLOCNF1BILLED TO CELLULAR/MOBILE NUMBERYUNBILLOCNG1ACCOUNT IN WRITE-OFF STATUSYUNBILLOCNH8REBILL - NO LONGER BILLABLE BY PBYUNBILLOCNK2TOLL BILLING RESTRICTIONYUNBILLOCNU0DENY ALL KNOWLEDGE (DAK)YUNBILLOCNU6END-USER ACCOUNT IN FINAL STATUSYUNBILLOCNK4LEC INITIATED BILL BLOCKYUNBILLOCNL6DENIAL STATUS RESTRICTION (891/CIID)YUNBILLOCNL7DISCONNECTED ACCOUNT DUE TO NONPAYMENTYUNBILLOCNV7RESTRICTED ACCOUNTYUNBILLOCNA9EC DOES NOT HAVE BILLING ARRANGEMENT WITH ICYUNBILLOCN


Exhibit C

OCN PURGE SCHDEULEDaysNAMESOCNS90Ameritech, Pac Bell, Nevada9321, 9323, 9325, 9327,Bell, SNET, SWBT, Bell9329, 9740, 9742, 9147, 9102,Atlantic, Nynex, Bell South9104, 9206, 9208, 9210, 9211,9212, 9213, 9214, 9496120Sprint United0341, 0470, 832, 9993180CBT, GTE, NECA, Illuminet,All othersAlltel, Citizens, Qwest, default


Unlike conventional use of the LIDB database that uses the LIDB data to obtain information on a destination/termination or recipient location or subscriber unit, the module 200, in accordance with the invention, uses the industry standard LIDB database to obtain relevant information on the initiating subscriber line 96. The subscriber line reference data obtained from the LIDB database is then processed to generate modified validity codes, which provide a vendor with data to facilitate deciding whether or not a transaction should be processed. The LIDB/LNP database is queried as if a collect call event is occurring and a call is thus mimicked. The processing of the transaction typically involves communicating the relevant transaction data to a folder of the subscriber's account with a relevant Telco. The method of, and module 200 for, validating the billing account associated with the subscriber line allows, for example, a subscriber line to be used to validate and conclude a transaction instead of using a conventional payment techniques such as a credit card, debit card, bank account details or the like.


A current industry-wide problem is the lack of ability of a service provider to identify when a line subscriber has switched his service to a CLEC since the service provider may not have an existing billing arrangement with such a CLEC and may also not have a source for the BNA to allow for a direct billing solution. LNP databases were originally established for the purpose of directing call routing activities among facilities-based carriers and most telephone numbers ported to a CLEC do not involve a facility change (the CLEC may be simply reselling the incumbent LEC's facilities). This means that, for billing decision purposes, LNP queries usually provide an incorrect response.


The LNP queries are enhanced by analyzing and interpreting other field elements included within the query response. Specifically, certain values or, in some cases, the absence of certain values, in the Operating Company Number (“OCN”) and/or the Regional Accounting Office (“RAO”) fields, allows further accuracy in the validation response. While the definitions of the OCN and RAO field elements can be obtained from industry sources, their interpreted use in the validation process is unique to the present invention. Use of these additional data elements can improve the reliability of the validation event.


LNP results may be supplemented with CARE queries in LEC regions where LNP results are inadequate and CARE costs are not otherwise prohibitive based on the retail price of the underlying service. CARE provides a reliable result on CLEC-ported numbers since its basic purpose is to provide subscriber account information (such as billing name and address). Once a number is ported to a CLEC, the incumbent LEC no longer has subscriber responsibility and will, therefore, return an “unavailable” response, even if the LEC's dial-tone facility is still being utilized. This negative response is then used to generate a “deny” status on the subscriber based on the current lack of CLEC billing support.


The validation process is also supplemented through the use of internal databases built from information gathered throughout the billing and collection process.


It is important to appreciate that all of the steps in the method executed by the module 200 need not be executed in real time. Typically, after the approval code 000 has been generated by the module 200 at step 334 the module 200 terminates its pre-validation check routine as shown at step 336. At this point the module 200 may merely provide pre-validation data or verification data to indicate to the vendor 22 if the subscriber line 96 is billable. Thus the module 200 may, in a first interaction with the vendor 22 provide pre-validation data, and in a second interaction process billing information. During the processing of billing information the validation process may once again be executed. In certain embodiments, the first interaction may be in the form of a registration process during which the validation procedure is carried out to register a subscriber line 96. The vendor 22 may then conduct numerous transactions with subscriber and subsequent validation checks on the subscriber line may then only be carried out on a periodic basis as described above.


After the validation code has been sent to the vendor 22, and the pre-validation procedure has been complete, the module 200 then carries out the fraud checks on a non-real time basis (usually during the next 48 to 72 hours) as shown in steps 340 to 344. The information obtained during the fraud control checks, if necessary, is used to update the various databases. In particular, after a BTN has been successfully validated but before a billing event takes place, the CARE investigation steps 340 to 344 are executed. The module 200 is typically arranged to interrogate offsite CARE databases and the results of the enquiry are stored in the CARE database 246. Checks on the data received from the CARE databases are then performed whereafter one or more of the other databases may be updated with the results. For example, the CARE database 246 may be updated, new within 90 days information, business indicator information, or the like. CARE codes 2618 and 2619 typically indicate that the BNA is not available and that the LEC no longer owns the account.


The updating of the databases following the CARE investigation allows enhanced future checks by the module 200 in a subsequent pre-validation procedure or subsequent registration event validation event. The updated information may be provided to the vendor 22. However, if the BTN information returned from the CARE database 246 does not meet predefined criteria, the other databases of the module 200 are not updated.


When a purchase validation event or billing event is declined, fails, unbillable or is negative event for any reason, the purchaser is preferably apprised. The manner in which the failure is treated depends upon the point in time and the reason the transaction validation or billing event fails.


In certain embodiments, a business rule table drives the treatment method and course based on when the failed event occurred during the validation process and the reason for the failure. With a purchase validation event, the option may be provided to interact with the purchaser at the time of requesting the purchase. For example, the option to change failed information for a revalidation or to change to another payment option may be provided. An example of customer failure may be as follows:

If a purchasevalidation eventfails:Then the customer treatment may be:ANI = BTNScreen pop requesting new number and or to call from the matching number.Missing or incorrectScreen pop requesting correct cust code.cust codeTHRESHOLDScreen pop explaining this and a request for another payment method.OFFNETScreen pop explaining this and a request for another payment method.CLECScreen pop explaining this and a link to change carrier to ILEC. Or request another paymentoption.42 BlockScreen pop explaining this and a link to ILEC to unblock 4250. Or request another paymentoption.BLOCK andScreen pop explaining this and a request for another payment method. Also includeCANCELexplanation as to how to unblock.UNBILLsScreen pop explaining this and a request for another payment method.LIDB Code FailScreen pop explaining this and a request for another payment method.LIDB RAO/OCN failScreen pop explaining this and a link to change carrier to ILEC. Or request another paymentoption.ADDRESSScreen pop requesting correct information.VERIFICATIONPrevious AdjustmentScreen pop explaining this and a link to inquiry chat or inquiry call information.Unpaid BalanceSee above.


At the time of a pre-billing validation event or a failed billing event, the interaction with the purchaser will be after the fact and is typically in a screen pop at the next sign-on and in email form. In certain embodiments, there is a preset length of time to correct the failed information for a revalidation or change to a new payment method.

Then the customer treatment may be:If a pre-billvalidation eventfails:OFFNETScreen pop at next id sign-on explaining this and requesting change of payment method.Email containing the same information and link to update payment information.CLECScreen pop at next id sign-on explaining this and instructions how to solve or updatepayment method information. Email containing the same information and a link to changecarrier to ILEC and link to update payment method.42 BlockScreen pop at next id sign-on explaining this and instructions how to solve or updatepayment method information. Email containing the same information and link to unblock atILEC or link to update payment information.BLOCK andScreen pop at next id sign-on explaining this and instructions how to solve or updateCANCELpayment method information request for another payment method. Email requesting thesame information and a link to change carrier to ILEC and link to update payment methodUNBILLsScreen pop at next id sign-on explaining this and requesting change of payment method.Email containing the same information and link to update payment information.LIDB Code FailScreen pop at next id sign-on explaining this and requesting change of payment method.Email containing the same information and link to update payment information.LIDB RAO/OCN failScreen pop at next id sign-on explaining this and instructions how to solve or updatepayment method information. Email containing the same information and a link to changecarrier to ILEC and link to update payment methodPrevious AdjustmentScreen pop at next sign-on explaining this and a link to inquiry chat or inquiry callinformation.Unpaid BalanceSee above.If a billing eventfails:UnbillsScreen pop at next id sign-on explaining this, requesting payment of unbilled charge andsuggestions of ways to solve including a link to switch back to the ILEC and a way to updatenew phone number. It will also include a request for a change of payment method.Email containing the same information, link to change back to ILEC, to update with a newphone number, update to update payment information also contains link to inquiry chat orinquiry call.ChargebackScreen pop at next sign-on explaining this and a link to inquiry chat or inquiry callinformation.Bad Debt Write-offScreen pop at next sign-on explaining this and a link to inquiry chat or inquiry callinformation.


Once the treatment period passes, the account access is typically denied and more traditional ways of saving, winning back, and reactivation or collections activities would take place.


In the embodiment described above, information on the subscriber line 96 is forwarded by the service provider or vendor 22 to the module 200 for validation. However, in other embodiments of the invention, the consumer or user may call the module 200 directly, as shown by line 350 in FIG. 1, and the ANI may then be obtained by the module 200 directly from the terminal 24 and not indirectly from the vendor 22. Further subscriber line data, e.g. BTN, address of the user and so on, may then also be obtained directly from the user. For example, the user may have appropriate software installed on his/her PC which allows the user to dial into the module 200 in an automated fashion should he/she wish to charge any requested goods or services to his/her subscriber account. The module 200 would then validate the subscriber line 96 using the method describer above. The module 200 then typically communicates a validation code (e.g. corresponding to approval or non-approval) to the vendor 22 as shown by line 352. The vendor 22 would then conclude the transaction with the user if the subscriber line has been validated.


In the first iteration of the validation process in which a validation request is received from the vendor 22, the ANI of the subscriber line 96 is captured to identify the subscriber line to which the terminal 24 is connected so that the validation process can be executed and the transaction or purchase can be approved and the billing process can be effected. It is to be appreciated however that the validation process and further prosecution of the transaction may take place based on the BTN which the user enters but that the capturing of the ANI may reduce the likelihood of fraud. Thus, if the ANI is captured, it may be done during an initial enquiry, purchase event, or at any other time during the process.


In other embodiments of the invention, in addition to or instead of capturing the ANI, the system 20 may request a user to enter the unique number associated with every phone billing account that Telcos currently issue. These additional digits are typically found at the end of the account number on a conventional telephone bill. These digits, sometimes called customer codes, identify the account associated with that particular assignment of the phone number. These codes provide a way to avoid capturing the ANI because typically only the account holder has access to this number thereby reducing the chance of fraud. Thus, the display screen 86 of FIG. 11 optionally includes the field 364 in which a user can enter the customer codes. An appropriate database would then be interrogated to validate the subscriber line. In one embodiment of the invention, the interrogation is included in the LIDB step, and includes details on the account to the customer code level.


The customer codes may thus eliminate the need to capture the ANI by the module 60 (see FIG. 5) and, customer code data may be compared by the comparator module 218 (see FIG. 15) and as shown in step 264 in FIG. 17. As described above, the display screen 86 then includes the field 264 to accommodate this facility. Likewise, if the phone number is not confirmed, then the input screen would be provided with the customer code field.


When the customer code is used to validate the subscriber line 96, a step to interrogate the information is included in which additional information is sent to the LIDB database 252 (see FIG. 15) in step 124 of FIG. 13, and step 290 in FIG. 17. Additionally, steps relating to the return of LIDB data are updated to include the results of the interrogation of this piece of information.


The facility 28 may function as a type of clearing house. In particular, the facility 28 may be responsible or accountable for payment of the goods or services for each transaction to the service provider or vendor 22 and, in turn, receive payment from the Telco. As mentioned above, the module 200 updates the telephone bill or account 34 of the subscriber in an automated fashion (see line) and the bill 356 that the user receives (see FIG. 1) includes the charges for the goods and/or services provided by the vendor 22. The user pays the Telco 26 (see line 358), the Telco 26 pays the facility 28 (see line 360), and the facility 28 pays the vendor 22 (see line 362). It is important to appreciate that these payments need not take place at the same time. Typically, the payments between the Telco 26 and the facility 28, and the facility 28 and vendor 22, take place periodically in a batch fashion. The PC 24, and modules 30, 32 are exemplary forms of computer systems or machines within which a set of instructions, for causing the machine to perform any one of the methodologies discussed above, may be executed. In alternative embodiments, the machine may comprise a network router, a network switch, a network bridge, Personal Digital Assistant (PDA), a cellular telephone, a web appliance or any machine capable of executing a sequence of instructions that specify actions to be taken by that machine.


Each machines includes a processor, a main memory and a static memory, which communicate with each other via a bus. The machines may further include a video display unit (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)). The machine also includes an alpha-numeric input device (e.g. a keyboard), a cursor control device (e.g. a mouse), a disk drive unit, a signal generation device (e.g. a speaker) and a network interface device.


The disk drive unit includes a machine-readable medium on which is stored a set of instructions (i.e., software) embodying any one, or all, of the methodologies described above. The software is also shown to reside, completely or at least partially, within the main memory and/or within the processor. The software may further be transmitted or received via the network interface device. For the purposes of this specification, the term “machine-readable medium” shall be taken to include any medium which is capable of storing or encoding a sequence of instructions for execution by the machine and that cause the machine to perform any one of the methodologies of the present invention. The term “machine-readable medium” shall accordingly be taken to included, but not be limited to, solid-state memories, optical and magnetic disks, and carrier wave signals.

Claims
  • 1. A method of processing a transaction record, the method including: receiving a credit card authorization request associated with a transaction, the credit card authorization request being received from a computer system and selectively including a telephone number associated with a subscriber line; obtaining the telephone number from the credit card authorization request; performing a validation process based at least in part on the telephone number and generating a transaction validation indicator; generating a credit card authorization response including the transaction validation indicator; and communicating the credit card authorization response to the computer system.
  • 2. The method of claim 1, in which the telephone number replaces a credit card number.
  • 3. The method of claim 1, in which the computer system includes a Customer Management System.
  • 4. The method of claim 1, in which performing the validation process includes: creating a line identification database (LIDB) request record; communicating the LIDB request record to a line identification database (LIDB); receiving LIDB data from the line identification database (LIDB); and generating the transaction validation indicator at least partially based on the LIDB data.
  • 5. The method of claim 1, which includes: at a vendor computer system, identifying the telephone number of the subscriber line using automatic number identification (ANI) techniques; providing a credit card authorization request for communication via a network to a transaction processing facility; inserting the telephone number into the credit card authorization request; and communicating the credit card authorization request to the transaction processing facility.
  • 6. The method of claim 1, which includes routing the credit card authorization request to a financial card gateway when the credit card authorization request does not include a telephone number.
  • 7. The method of claim 1, wherein the transaction is billed to an account associated with the subscriber line.
  • 8. The method of claim 7, wherein if a billing failure occurs in which the account associated with the subscriber line is not billable, the method includes: creating a credit card billing failure record; and communicating the credit card billing failure record via a network to the computer system.
  • 9. The method of claim 1, wherein the credit card authorization request includes a tracking ID field, a name field, at least one address field, a city field, a state field, a ZIP code field, a billing telephone number field, an amount field, and a credit card number field that includes the telephone number.
  • 10. The method of claim 1, which includes: receiving a plurality of credit card transaction records from a Customer Management System, each credit card transaction record being associated with an approved credit card authorization request; identifying which one or more credit card transaction records of the plurality of credit card transaction records includes a telephone number replacing a credit card number; communicating each identified credit card transaction record to at least one telephone account transaction processing computer to process payment in an account associated with the subscriber line; and communicating a credit card record to the Customer Management System to indicate that the transaction has been processed.
  • 11. A machine-readable medium embodying instructions that, when executed by a machine, cause the machine to perform the method of claim 1.
  • 12. A system to process a transaction record, the system including: an interface to receive a credit card authorization request associated with a transaction, the credit card authorization request being received from a computer system and selectively including a telephone number associated with a subscriber line; an extraction module to obtain the telephone number from the credit card authorization request; and a processing module to: perform a validation process based at least in part on the telephone number and generate a transaction validation indicator; and generate a credit card authorization response including the transaction validation indicator, wherein the credit card authorization response is communicated to the computer system.
  • 13. The system of claim 12, in which the telephone number replaces a credit card number.
  • 14. The system of claim 12, in which the computer system includes a Customer Management System.
  • 15. The system of claim 12, in which the processing module: creates a line identification database (LIDB) request record for communication to a line identification database (LIDB); and in response to LIDB data received from the line identification database (LIDB), generates the transaction validation indicator at least partially based on the LIDB data.
  • 16. The system of claim 12, which includes a vendor computer system, wherein the vendor computer system: identifies the telephone number of the subscriber line using automatic number identification (ANI) techniques; provides a credit card authorization request for communication via a network to a transaction processing facility; inserts the telephone number into the credit card authorization request; and communicates the credit card authorization request to the transaction processing facility.
  • 17. The system of claim 12, which routes the credit card authorization request to a financial card gateway when the credit card authorization request does not include a telephone number.
  • 18. The system of claim 12, wherein if a billing failure occurs in which the account associated with the subscriber line is unbillable, the processing module creates a credit card billing failure record for communication to the computer system.
  • 19. The system of claim 12, which is configured to: receive a plurality of credit card transaction records from a Customer Management System, each credit card transaction record being associated with an approved credit card authorization request; identify which one or more credit card transaction records of the plurality of credit card transaction records includes a telephone number replacing a credit card number; communicate each identified credit card transaction record to at least one telephone account transaction processing computer to process payment in an account associated with the subscriber line; and communicate a credit card record to the Customer Management System to indicate that the transaction has been processed.
  • 20. A system to process a transaction record, the system including: means for receiving a credit card authorization request in response to a transaction, the credit card authorization request being received from a computer system and selectively including a telephone number associated with a subscriber line; means for obtaining the telephone number from the credit card authorization request; means for performing a validation process based at least in part on the telephone number and generating a transaction validation indicator; means for generating a credit card authorization response including the transaction validation indicator; and means for communicating the credit card authorization response to the computer system.