Bill distribution or payment

Method and system for a virtual safe

6941285

Abstract

A transaction server for performing a transaction over a network using a virtual smart card the server comprising, a virtual smart card database having a plurality of records each record including a virtual card identification and a value corresponding to a single virtual smart card; a security module; an emulator for emulating a smart card, the emulator for receiving smart card commands and processing the commands in conjunction with the virtual smart card database and the security module; and a virtual card reader module for receiving the smart card commands and relaying the commands to the smart card emulator whereby transactions are performed over the network using one or more the records and the virtual smart card database.


Claims

1. A method of performing a secure electronic commerce transaction over a network using a smart card, said network having a client terminal, a merchant server, a payment server, and an authentication server, said smart card being a physical smart card or a virtual smart card, said smart card being associated with a user at said client terminal, said smart card having associated smart card information, said smart card information including an account balance, said smart card information being stored at said client terminal and at said authentication server, said method comprising the steps of:

sending a transaction request message from said client terminal to said merchant server identifying a product for said transaction, said product having associated product information, said product information being displayed on a first web page supported by said merchant server, said user being able to view said web page at said client terminal using a browser;

said transaction request message being sent via a Transaction Fulfilment Mechanism (TFM) module consisting of a set of fraud management heuristics that are invoked in a progression that leads to a final fulfillment condition, said fulfillment condition dictating what type of delivery is to be made and associated criteria for completion of said transaction;

sending transaction information from said merchant server to said client terminal in response to said transaction request message, said transaction information being contained in a second web page generated by said merchant server and displayable to said user through said browser, said transaction information including a price for said product, an IP address of said payment server, a transaction identifier, and a merchant identifier, said transaction identifier for tracking said transaction by said merchant server and by said payment server, said merchant identifier for tracking said transaction by said client terminal and said payment server;

receiving a user identifier and a PIN from said user at said client terminal for authorizing said transaction;

sending said user identifier, said PIN, and said transaction information from said client terminal to said authentication server;

comparing said price of said product to said account balance for said smart card at said authentication server to determine if said transaction can proceed, said account balance being stored at said authentication server and being accessed using said user identifier and said PIN, said transaction being terminated and a first termination message being sent from said authentication server to said client terminal for display to said user if said price exceeds said account balance by a predetermined amount;

sending a draw request message from said authentication server to said payment server using said IP address of said payment server, said draw request message containing said transaction information;

sending said draw request message from said payment server to said client terminal;

sending a debit request message from said client terminal to said payment server in response to said draw request message, said debit request message including a first digital signature, said first digital signature for verifying that said debit request message originated from said client terminal, said first digital signature being generated at said client terminal using said smart card information stored at said client terminal;

sending said debit request message from said payment server to said authentication server;

comparing at said authentication server said first digital signature contained in said debit request message to a first check digital signature generated at said authentication server using said smart card information stored at said authentication server to determine if said transaction can proceed, said transaction being terminated and a second termination message being sent from said authentication server to said client terminal for display to said user if said first digital signature does not match said first check digital signature;

updating said smart card information by debiting said account balance by paid price to produce an updated account balance and storing said updated account balance at said authentication server;

sending a debit response message from said authentication server to said payment server, said debit response message including a second digital signature, said second digital signature for verifying that said debit response message originated from said authentication server and for verifying that said account balance has been debited, said second digital signature being generated at said authentication server using said smart card information stored at said authentication server;

sending said debit response message from said payment server to said client terminal;

comparing at said client terminal said second digital signature contained in said debit response message to a second check digital signature generated at said client terminal using said smart card information stored at said client terminal, said smart card information stored at said client terminal including an expected updated account balance, to determine if said transaction can proceed, said transaction being terminated and a third termination message being displayed to said user if said second digital signature does not match said second check digital signature;

updating said smart card information by debiting said account balance by paid price to produce an updated account balance and storing said updated account balance at said client terminal;

sending a verification response message from said client terminal to said payment server, said verification response message including an indication that said second digital signature matches said second check digital signature and that said transaction can proceed;

logging said indication and said transaction information at said payment server;

sending a debit result message from said payment server to said authentication server, said debit result message for confirming that said transaction has been logged and that said transaction can proceed, said debit result message including said indication and said transaction information;

logging said debit result message at said authentication server;

sending said debit result message from said authentication server to said client terminal to confirm that said transaction has been logged and that said transaction can proceed;

sending said debit result message from said client terminal to said merchant server to confirm that said transaction has been logged and that said product can be released to said user; and,

sending a purchase receipt message from said merchant server to said client terminal, said purchase receipt message indicating that said product has been released to said user, thereby completing said secure electronic commerce transaction;

wherein all of said transaction communications are routed through a secure component (Crypto Engine CEV) module which interconnects software modules and assures management of multi-identities, strong authentication, user consent, anonymity, accountability, reporting and privacy compliance.

2. The method of claim 1 wherein said network is the Internet.

3. The method of claim 1 wherein said debit result message is encrypted.

4. The method of claim 1, wherein said authentication server is operable to enable, enhance and support government, health, insurance, institutional, general business and financial services that enable processing such as credit card processing standards, e-check, legal, administrative and financial settlement between parties in online transactions in compliance with government regulations and privacy legislations.

5. The method of claim 1, further comprising the step at periodically re-configuring data on said smart card.

6. The method of claim 1, wherein the secure electronic commerce transaction method is carried out using the software modules comprising the group of:

a Public Key Infrastructure (PKI) module;

a Forwarding Mechanism/Redirection Link module;

a Secure Remote Pointer/Plug-in/Application/Applet module;

a Attribute Authority module;

a Virtual Identity module;

a Unique authentication process module;

a Secure Data Repository module;

an Authentication Authority module;

a Crypto-Engine (CEV) module;

a Payment Processing Engine module;

a Risk Management Engine module;

a Transaction Fulfillment Mechanism module;

an Insurance Module;

a Transaction Secure Repository module; and

a VirtualSAFE Deposit Box module.

7. The method of claim 6, wherein the secure session and/or the SSL protocol authenticates and secures communications with the server, and Public Key Infrastructure (PKI) combined with third party trusted Certificate Authorities authenticates the device or computer, the VirtualSAFE system and method authenticates the server, computer, and the user based on principles of secret, share secret and physical material or certificates to create uniqueness of user virtual identity.

8. The method of claim 1, further comprising a power of Attorney Consent software module.

9. The method of claim 1, further comprising an Escrow Module called Secure Proxy software module.

10. The method of claims 1 wherein said TFM and said set of fraud management heuristics are operable to perform the steps of:

generating a Customer Authentication Scoring, by considering Certificate Authentication, Secure Cookies, PIN or PIN value, and SRP Verifications criteria;

generating a Credential Identification Scoring, by considering Address, Amount, Over Limit, Declined, Plug-in Verifications, Risk Assessment, Transaction type, Payment type, Fraud, and Third party assessment proof or change criteria;

generating a Transaction Risk Scoring by considering external Third Party Fraud Assessment data, or Internal Primary Attribute, Secondary Attribute, Reduction, Tune Up, Risk Adjustment, and Fraud Data Configuration criteria;

said Fulfillment Response being dependable to third party authorization and creating a type of said Fulfillment Delivery based on a opposite score that will guarantee delivery of products/services/document; and

said three steps of generating being combined to a achieve a transaction score that is used to determine said fulfillment response and type of fulfillment delivery.

11. The method of claim 1, where information is sent to said authentication server by securely forwarding the information from said customer application in accordance with a security policy.

12. The method of claim 1 wherein each step of transmitting comprises the step of transmitting using standard secure communication session such as SSL, said unique session bundling encryption of user data by user's keys to support three basic rules; user secret, user share secret and physical material that represents sets of user's unique keys; and further comprising the step of flushing memory of tamper-proof Crypto Engine CEV process encrypted and raw data that will be securely granulated and encrypted in accordance with policy of segmentation, encryption and fragmentation of data such as keys.

13. The method of claim 1 further comprising the step of responding to a successful user authentication for a transaction, by using a user's or authorized user's unique electronic signature to sign a transactional consent, legally binding all parties in order to proceed with transactions enabled by multi-step chain, anonymous or personalized proxy/surrogate/assembly electronic signature mechanism; said transaction signed by user signature and by all other parties' signatures involved in the transaction enabling accountable anonymity in compliance with a non-reputable, transactional audit, audit legal audit and reporting mechanism.

14. The method of claim 1, wherein said payment server responds to the failure to settle a financial transaction, said user not accepting a delivered product in accordance with said policy, by said Transaction Fulfillment Mechanism initiating cancellation of said order in accordance with said policy which will trigger credit of said user transaction process such as payment server will settle and/or credit financial transaction escrowed in accordance with said agreement.

15. The method of claim 1, further comprising the step of responding to said user failing to receive delivery of a product in accordance with said agreement consented to by said user, and said Transaction Fulfillment Mechanism, by initiating cancellation of said order.

16. The method of claim 1, further comprising the step of ensuring security through a combination of public key certificates and attribute certificates which are deployed for authentication and authorization purposes for each entity in an e-commerce transaction.


Description

BACKGROUND OF THE INVENTION

With the rapid increase in the number of consumers having access to the World Wide Web, a corresponding need for conducting commerce over the Internet has emerged. However, concerns with online security have undermined the evolution of electronic commerce as security issues have affected the required level of trust between online retailers and consumers. In traditional business transactions, trust is established face-to-face and supported by documentation that reduces liability. Today, traditional business transactions are being transformed. In particular, the use of smart cards is expanding, further affecting the level of trust retailers and consumers have in electronic commerce.

A smart card, also called a chip card, integrated circuit card, memory card or processor card, is typically a credit card-sized plastic card that includes one or more integrated circuits. A smart card can interface with a point-of-sale terminal, an ATM, or with a card reader integrated with a computer, telephone, vending machine, or a variety of other devices. A smart card may be programmed with various types of functionality such as stored-value applications, credit or debit applications, loyalty applications, cardholder information, etc. Although a plastic card is currently the medium of choice for smart cards, it is possible to implement these cards using a smaller form factor. For example, a smart card could be attached to a key chain or it could be as small as a single integrated circuit chip. A smart card may also be implemented as part of a personal digital assistant, telephone, or some other form.

Typically, to increase user trust, a smart card contains a hardware encryption module for performing a variety of encryption algorithms. Encryption may also be performed in software. A typical process for issuing smart cards and for reconciling transactions performed with these cards in the consumer context may be described as follows. A terminal supplier builds the equipment used by a service provider to provide goods and/or services to consumers via smart card and service payment terminal. A card supplier contracts with an integrated circuit manufacturer and a card manufacturer for integrated circuits and plastic card bodies, respectively. The card supplier then embeds the integrated circuits in the cards and initializes them with a serial number. The card supplier then delivers these cards to a card issuer. In conjunction with a clearing and administration system, the card issuer personalizes new cards and then transfers these cards to individual cardholders (i.e. consumers). A cardholder may then charge the card with value prior to use. Alternatively, the card may be delivered with value pre-loaded. The cardholder may then use the card at a service payment terminal to purchase goods and/or services from the service provider. Upon purchase, the terminal debits the value of the purchase from the card, thus creating a service payment. The system may be implemented, for example, using Visa, MasterCard, American Express, Discovery, Players Card International, bank and financial institution debit cards, and other cards.

In this typical process, all transactions are sent in a data file from the service payment terminal, via an acquirer, to a clearing and administration system. Accumulated service payment batches from other terminals are also sent to the clearing and administration system. Based upon this collection data, the clearing and administration system receives money from the card issuer. The money received from the card issuer, of course, originates from the cardholder. The clearing and administration system then transfers a lump sum to the acquirer using a suitable settlement service (e.g. Visa, MasterCard American Express, Discovery, Players Card International, etc.) to pay the various service providers having a relationship with the acquirer. Based upon the collection data, the acquirer then transfers an appropriate amount of money to each service provider reflecting the value of the goods and services that that service provider provided to cardholders that period (e.g. day). The value of the goods and services provided is based on deductions from cardholders' smart cards.

A consumer typically uses a service payment terminal in a face-to-face context in order to purchase goods at a store or directly from the terminal itself. The service payment terminal can be an attended device or it can be integrated into a self-service device such as a vending machine or public telephone. For example, the service payment terminal may be incorporated into a soda machine in order to dispense sodas to a customer where the customer pays by inserting a smart card. Or, the service payment terminal may be a point-of-sale (POS) terminal typically found at the check-out counter or a store.

In general, service payment terminals allow consumers to use smart cards for the payment of goods and services. A service payment terminal generates a payment result from a transaction and bundles individual payment results into a collection for transfer to a clearing and administration system. The service payment terminal then transfers funds debited from consumers' smart card to the merchant whose goods and services were purchased through the terminal. Thus, a variety of goods and services may be purchased using a smart card from a merchant having a service payment terminal on premises. In addition, a consumer with a smart card may purchase goods or services from a merchant over the Internet.

Now, in order to purchase a product or service with a smart card, the card must first be loaded with value or with an identity. Typically, "stored-value" cards are loaded with value while "debit" and "credit" smart cards are loaded with the identity of the card holder. With respect to stored-value cards, value can be loaded onto the card in a variety of ways. For example, while inconvenient for the consumer, the consumer may physically travel to a bank or other institution that has an automated teller machine (ATM), or other similar device, in order to load value onto the smart card. With respect to loading value onto a smart card, the consumer may insert money into a value loading machine and have a corresponding value loaded onto the card. Or, the consumer may use a debit card to deduct value from the consumer's bank account for transfer to the card. Additionally, a credit card can be used as the source of value. In these examples, the consumer must travel to the bank to load value. A further inconvenience exists in that not all banks have value loading machines. To overcome this inconvenience, a method by which consumers may load value onto their smart cards via the Internet has been proposed and is described in U.S. patent application Ser. No. 09/070,488 (Davis, et al.), filed Apr. 30, 1998, and entitled "Internet Loading System Using Smart Card", which is incorporated herein by reference.

One disadvantage of current smart card systems is that they are dependent on the use of two hardware components new to the mass consumer market: smart cards and smart card readers. Without having large numbers of smart cards and card readers in use, there is little demand for them from consumers, which in turn makes it difficult to convince merchants to adopt these systems.

A need therefore exists for an electronic commerce system that does not require the prior deployment of physical smart cards and smart card readers. Such a system would allow merchants and issuers to establish a market presence that would in turn facilitate the acceptance of physical smart cards and card readers as they become more widely available.

With respect to the issue of trust, for electronic commerce, trust must be established in seconds between strangers who are physically separated. Effective security is based on the unequivocal authentication of authorized parties.

Methods for providing authentication include digital signatures, the public key infrastructure (PKI), and electronic payment policies such as X9.59. However, the traditional digital signature model is a complex and computationally expensive process when applied to mainstream business transactions over the Internet. The traditional digital signature model was not developed specifically for today's business transactions or a secure means to conduct electronic commerce that takes into account the infrastructure and business processes already in place within the financial sector to ensure trust in financial transactions. On the other hand, the PKI model does provide strong authentication. In addition, the financial industry's X9.59 policy, is a light-weight, high integrity, strong authentication payment protocol targeted for all methods of electronic payment including, but not limited to, set-top boxes, point-of-sale terminals with online authorization, and merchant web servers. With the appropriate smart card, X9.59 can work at point-of-sale, even improving the integrity of the current POS infrastructure, while eliminating the necessity for any identity information in payment transactions.

A need therefore exists for an electronic commerce system with effective authentication suitable for today's business transactions.

Finally, in addition to being secure, modern electronic commerce systems must protect individual privacy without impeding legitimate inquiries by law enforcement and government agencies. Typically, to improve privacy, a modem electronic commerce system must be relatively anonymous for the user.

In summary, smart cards require information be recorded on them. In the case of stored-value cards, a monetary value must be downloaded to the card. In the case of a debit or credit cards, an identity must be securely transferred to the card. Hence, a need exists for an electronic commerce system that has effective online authentication and that includes the benefits of physical smart card but that operates in a virtual environment. In addition, a need exists for an electronic commerce system that provides the benefits of card-present transactions in the context of remote networks and the Internet. Furthermore, a need exists for an electronic commerce system that can reduce costs associated with current systems with respect to card distribution, reader distribution, and connectivity. Moreover, a need exists for an electronic commerce system that provides effective authentication, security, and privacy.

A need therefore exists for an improved electronic commerce system. Consequently, it is an object of the present invention to obviate or mitigate at least some of the above-mentioned disadvantages.

SUMMARY OF THE INVENTION

The invention provides a system for conducting secure electronic commerce transactions over networks with virtual smart cards.

According to one aspect of the invention, a method for performing a secure electronic commerce transaction over a network using a smart card is provided. With respect to the method: the network has a client terminal, a merchant server, a payment server, and an authentication server; the smart card being a physical smart card or a virtual smart card; the smart card being associated with a user at the client terminal; the smart card having associated smart card information; the smart card information including an account balance; and, the smart card information being stored at the client terminal and at the authentication server. The method includes the steps of:

    • sending a transaction request message from the client terminal to the merchant server identifying a product for the transaction, the product having associated product information, the product information being displayed on a first web page supported by the merchant server, the user being able to view the web page at the client terminal using a browser;
    • sending transaction information from the merchant server to the client terminal in response to the transaction request message, the transaction information being contained in a second web page generated by the merchant server and displayable to the user through the browser, the transaction information including a price for the product, an IP address of the payment server, a transaction identifier, and a merchant identifier, the transaction identifier for tracking the transaction by the merchant server and by the payment server, the merchant identifier for tracking the transaction by the client terminal and the payment server;
    • receiving a user identifier and a PIN from the user at the client terminal for authorizing the transaction;
    • sending the user identifier, the PIN, and the transaction information from the client terminal to the authentication server;
    • comparing the price of the product to the account balance for the smart card at the authentication server to determine if the transaction can proceed, the account balance being stored at the authentication server and being accessed using the user identifier and the PIN, the transaction being terminated and a first termination message being sent from the authentication server to the client terminal for display to the user if the price exceeds the account balance by a predetermined amount;
    • sending a draw request message from the authentication server to the payment server using the IP address of the payment server, the draw request message containing the transaction information;
    • sending the draw request message from the payment server to the client terminal;
    • sending a debit request message from the client terminal to the payment server in response to the draw request message, the debit request message including a first digital signature, the first digital signature for verifying that the debit request message originated from the client terminal, the first digital signature being generated at the client terminal using the smart card information stored at the client terminal;
    • sending the debit request message from the payment server to the authentication server;
    • comparing at the authentication server the first digital signature contained in the debit request message to a first check digital signature generated at the authentication server using the smart card information stored at the authentication server to determine if the transaction can proceed, the transaction being terminated and a second termination message being sent from the authentication server to the client terminal for display to the user if the first digital signature does not match the first check digital signature;
    • updating the smart card information by debiting the account balance by the price to produce an updated account balance and storing the updated account balance at the authentication server; sending a debit response message from the authentication server to the payment server, the debit response message including a second digital signature, the second digital signature for verifying that the debit response message originated from the authentication server and for verifying that the account balance has been debited, the second digital signature being generated at the authentication server using the smart card information stored at the authentication server;
    • sending the debit response message from the payment server to the client terminal;
    • comparing at the client terminal the second digital signature contained in the debit response message to a second check digital signature generated at the client terminal using the smart card information stored at the client terminal, the smart card information stored at the client terminal including an expected updated account balance, to determine if the transaction can proceed, the transaction being terminated and a third termination message being displayed to the user if the second digital signature does not match the second check digital signature;
    • updating the smart card information by debiting the account balance by the price to produce an updated account balance and storing the updated account balance at the client terminal;
    • sending a verification response message from the client terminal to the payment server, the verification response message including an indication that the second digital signature matches the second check digital signature and that the transaction can proceed;
    • logging the indication and the transaction information at the payment server;
    • sending a debit result message from the payment server to the authentication server, the debit result message for confirming that the transaction has been logged and that the transaction can proceed, the debit result message including the indication and the transaction information;
    • logging the debit result message at the authentication server;
    • sending the debit result message from the authentication server to the client terminal to confirm that the transaction has been logged and that the transaction can proceed;
    • sending the debit result message from the client terminal to the merchant server to confirm that the transaction has been logged and that the product can be released to the user; and,
    • sending a purchase receipt message from the merchant server to the client terminal, the purchase receipt message indicating that the product has been released to the user, thereby completing the secure electronic commerce transaction.


  • According to another aspect of the invention, the network is the Internet.

    According to another aspect of the invention, the debit result message is encrypted.

    According to another aspect of the invention a transaction server is provided for performing a transaction over a network using a virtual smart card. The server includes:
    • a) a virtual smart card database having a plurality of records each record including a virtual card identification and a value corresponding to a single virtual smart card;
    • b) a security module;
    • c) an emulator for emulating a smart card, the emulator for receiving smart card commands and processing the commands in conjunction with the virtual smart card database and the security module; and
    • d) a virtual card reader module for receiving the smart card commands and relaying the commands to the smart card emulator whereby transactions are performed over the network using one or more the records and the virtual smart card database.


  • According to another aspect of the invention, a method for performing a transaction over a network using a virtual smart card and a server is provided. The method includes the steps of:
    • a) creating a plurality of records on a virtual smart card database, each record including a virtual card identifier and a value corresponding to a single virtual smart card;
    • b) receiving smart card commands via a smart card emulator and processing the commands in conjunction with the virtual smart card database and a security module; and
    • c) receiving the smart card commands via a virtual card reader module and relaying the commands to the smart card emulator whereby transactions are performed over the network using the server and one or more of the records in the virtual smart card database.


  • According to another aspect of the invention, the server's security module includes a plurality of encryption algorithms.

    BRIEF DESCRIPTION OF THE DRAWINGS

    Embodiments of the invention may best be understood by referring to the following description and accompanying drawings. In the description and drawings, like numerals refer to like structures or processes. In the drawings:

    FIG. 1 is a block diagram illustrating VirtualSAFE software modules in accordance with an embodiment of the invention;

    FIG. 2 is a flowchart illustrating the operation of the secure remote pointer component of VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 3 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in the general case in accordance with an embodiment of the invention;

    FIG. 4 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in a second case in accordance with an embodiment of the invention;

    FIG. 5 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in a third case in accordance with an embodiment of the invention;

    FIG. 6 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in a fourth case in accordance with an embodiment of the invention;

    FIG. 7 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in a fifth case in accordance with an embodiment of the invention;

    FIG. 8 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in a sixth case in accordance with an embodiment of the invention;

    FIG. 9 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in a seventh case in accordance with an embodiment of the invention;

    FIG. 10 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in an eighth case in accordance with an embodiment of the invention;

    FIG. 11 is a flowchart illustrating the steps for user enrollment in VirtualSAFE in a ninth case in accordance with an embodiment of the invention;

    FIG. 12 is a flowchart illustrating CA process steps in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 13 is a block diagram illustrating participants and their contractual relationships in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 14 is a block diagram illustrating the enrollment process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 15 is a block diagram illustrating the online transaction process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 16 is a block diagram illustrating the server authentication process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 17 is a block diagram illustrating the computer authentication process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 18 is a block diagram illustrating the user authentication process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 19 is a block diagram illustrating the back-end authentication process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 20 is a block diagram illustrating the fulfillment process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 21 is a block diagram illustrating the attribute authentication authority process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 22 is a block diagram illustrating the virtual identity (VI) process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 23 is a block diagram illustrating the virtual smart card (VSC) process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 24 is a block diagram illustrating the VirtualSAFE deposit box (VSDB) process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 25 is a block diagram illustrating the point-of-sale (POS) and virtual smart card (VSC) emulation process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 26 is a block diagram illustrating the ATM and virtual smart card (VSC) emulation process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 27 is a block diagram illustrating the wireless POS and ATM process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 28 is a block diagram illustrating the SAFEcheck process in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 29 is a block diagram illustrating physical access control in VirtualSAFE in accordance with an embodiment of the invention;

    FIG. 30 is a block diagram illustrating VirtualSAFE from a business-to-business perspective, and including an e-portal, in accordance with an embodiment of the invention; and,

    FIG. 31 is a block diagram illustrating VirtualSAFE from a business-to-consumer perspective, and including a merchant, in accordance with an embodiment of the invention.

    DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

    In the following description, numerous specific details are set forth to provide a thorough understanding of the invention. However, it is understood that the invention may be practiced without these specific details. In other instances, well-known software, circuits, structures and processes have not been described or shown in detail in order not to obscure the invention. In the description and drawings, like numerals refer to like structures or processes.

    The term "VirtualSAFE" is used herein to refer to a system, including software, for secure electronic commerce using virtual smart cards in accordance with an embodiment of the invention. VirtualSAFE may include machines for processing data, including the computer systems and network arrangements described herein.

    System. VirtualSAFE is an electronic commerce system which includes a client terminal, a merchant server, a payment server, and a VirtualSAFE authentication server. The client terminal, merchant server, payment server, and VirtualSAFE authentication server are in communication over a network, typically, the Internet. Using a web browser, a user at the client terminal browses through product and service web pages presented by a merchant through the merchant server. The user may purchase products and services from the merchant using a virtual smart card. The VirtualSAFE authentication server authenticates the user through the software modules and method described below. In general, the payment server fulfills the e-commerce transaction. VirtualSAFE has stored therein data representing sequences of instructions which when executed cause the method described herein to be performed. Of course, VirtualSAFE may contain additional software and hardware a description of which is not necessary for understanding the invention.

    Modules. Referring to FIG. 1, there is shown a block diagram illustrating VirtualSAFE software modules 100 in accordance with an embodiment of the invention. VirtualSAFE software modules 100 include the following: Public Key Infrastructure (PKI) 101; Redirection Link (RL) 102; Secure Remote Pointer (SRP) 103; Attribute Authority (AA) 104; Virtual Identity (VI) 105; Virtual Smart Card (VSC) 106; Secure Data Repository 107; VirtualSAFE (or Authentication Authority) Server 108; Crypto-Engine (CEV) 109; Payment Processing Engine 110; Risk Management Engine 111; Transaction Fulfillment Mechanism (TFM) 112; Insurance Module 113; Secure Transaction Repository 114; and VirtualSAFE Deposit Box (VSDB) 115.

    These modules are described in detail in the following beginning with the VirtualSAFE server 108 and Crypto-Engine (CEV) 109.

    VirtualSAFE Server 108. Advantageously, the VirtualSAFE server 108 (or authentication server) dispenses with the need for physical smart cards and card readers. In the following, physical smart card transactions are contrasted with virtual smart card transactions as coordinated by the VirtualSAFE server 108.

    Physical Smart Card Transactions. Typically, local cardholder functions include a consumer card interface. Display and accept/cancel options are performed at the client terminal. Payment functions, including security card control, data storage, and the use of a concentration point, are performed by a payment server. The presentation and eventual delivery of goods and services by a merchant are performed under the control of a merchant server. The Internet performs routing functions between each entity. It should be appreciated that the Internet may include its present form or it may include any other open network implemented using a combination of computer, telephone, microwave, satellite, or cable networks.

    The client terminal controls the interaction with a consumer and interfaces to the card reader that accepts a smart card having a stored-value application. The payment server communicates directly with a terminal or through a concentrator that handles a number of terminals each having a security card. The payment server also communicates with the concentration point for transmission of transaction data to a clearing and settlement system. The database stores all the appropriate information passing through the payment server for each transaction. Use of such a database allows any number of merchants (or merchant servers) to use the payment server for transactions. The payment server controls payment functions such as handling attached terminals, managing the database, and collection functions. The merchant server is typically a site that has contracted with an acquirer to accept smart card transactions as payments for goods and services purchased over the Internet.

    As discussed above, the smart card may take a variety of forms and is useful in many situations where it is desirable to store monetary value on a card that a consumer may use. Generally speaking, the smart card is any card or similar device able to store a value and decrement that value when the card is used. The card may be purchased complete with a stored value or a given value may be added to the card later. Such cards may also have their value replenished. The smart card may also perform a variety of functions in addition to simply storing value, for example, debit, credit, prepayment, and other functions. Such a card typically includes information such as a bank identifier number, a sequence number, a purchase key, a load key, an update key, an expiration date, a transaction ID, and a running balance.

    The smart card may include an encryption module in order to provide a variety of security features. For example, security features may include simple PIN numbers, biometrics, simple algorithms, or sophisticated algorithms such as the Data Encryption Standard (DES) or Rivest Shamir Adelman (RSA) encryption. Typically, a smart card is able to use these features to verify consumers and card readers, to validate security cards, and to provide a unique digital signature. A smart card may include any number of keys which are known to the card issuer and that are used during the course of a payment or load transaction to generate digital signatures for validation of the stored-value card, security card or module, or the system itself.

    The client terminal may be any suitable device for interacting with the card and for communicating over a network with a payment server and a merchant server. For example, the client terminal may be a mainframe computer, a workstation, a personal computer, a set top box, a kiosk, or any type of service payment terminal that a consumer might use to purchase goods and services. The client terminal may also be embodied in any portable device including a laptop computer, a cellular telephone (including GSM telephones), or a personal digital assistant (PDA). The card reader may be any suitable interface device that is capable of transferring information and commands between the client terminal and the card.

    Typically, the client terminal includes a "client code module" and a "card reader module". The card reader module may be implemented using any suitable software and libraries for communicating with the card reader. Its actual implementation will depend upon the type of card reader used. The client code module controls communications between the client terminal, the card reader, the payment server, and the merchant server. The client code module may be implemented using any suitable software. For example, the client code module may be implemented using a combination of "C" code and a Java applet. The applet may be supplemented with parameters from an HTML page sent from the merchant server. The client code module is also responsible for controlling displays presented to consumers and for the interaction between the card and the card reader. This module also builds the draw request message after receiving all of the start-up information from the card and the amount of the purchase from the merchant server.

    Typically, the payment server includes a payment code module and a terminal interface. As with the client terminal, the payment server may be implemented using any suitable computer, for example, a personal computer. There may be one payment server for each merchant server or a single payment server may service any number of merchant servers. There may be multiple payment servers for a single merchant. In addition, the payment server need not be remote from the merchant server but may be located at the same site and have a different Internet address. Or, the payment server and the merchant server may be implemented on the same computer. The payment server is designed to facilitate communications between the consumer's smart card and a terminal's security card.

    The payment module may be implemented using any suitable code. For example, the payment module may be implemented using a combination of "C" code, "C++" code, and Java code. The payment module may be a multi-threaded process that can service multiple concurrent client applet transactions on demand. The module is responsible for controlling all interactions with terminals including the transaction collection function. For individual transactions, the payment module controls message flow and logs interim results. When an applet connects with the payment server, it creates a transaction thread to support the transaction through its life cycle. Each thread, in turn, assigns a terminal for communications. A one-to-one correspondence between transaction threads and terminals may provide good results.

    Typically, the terminal interface is any suitable set of software and libraries for communications with a terminal either directly or through a terminal concentrator. The actual implementation of the terminal interface will depend upon the type of terminal used. For example, an IQ Delta 2010 terminal made by Schlumberger may be used. Such a terminal supports a variety of commands originating from the terminal interface. These commands emulate the normal responses from a smart card to a security card should both be located in the same service payment terminal. The actual security card commands are held in the terminal while the terminal performs the tasks necessary to simulate the presence of a smart card. The emulation of the card commands can be done by the payment server using the terminal as a card reader, or may even be performed by the client terminal.

    Typically, the security card is any suitable security card such as those that are known in the art (often referred to as a Purchase Secure Application Module or PSAM). The functionality of the security card may be replaced by a crypto-engine (as is done in VirtualSAFE), may be implemented in hardware within the payment server, or may be implemented in software. For example, the security card may be a removable credit card-sized smart card that is programmed to process and store data relating to financial transactions. The security card may contain a microchip embedded in the card that enables the card to authenticate and to validate the consumer's smart card. If the consumer smart card is acceptable to the security card, and if the smart card contains sufficient value, then the security card guarantees that the merchant providing goods and services will receive payment in the amount deducted from the smart card. The security card may also contains DES and public key purchase security keys, may authenticate the smart card during a purchase transaction, and may secure the payment and collection totals. A security card may also store digital signature algorithms for all smart cards in use. A security card may also contain a transaction identifier for the current transaction, a financial sum of all transactions remaining to be settled, a session key, and master keys for all smart cards in use. Further, the security card may contain generations of keys, blocked card indicators, dates of last update, multiple card programs, different currency rates, and additional security.

    The concentration point is typically a staging computer that communicates with a payment server to collect batches of purchase transactions. The concentration point then sends these transaction batches to a clearing and settlement system for processing. Once processed, batch acknowledgments, along with other system updates, are returned.

    Typically, the merchant server includes a merchant code module. The merchant server may be implemented on any suitable computer capable of communicating with and presenting information to consumers over the Internet. The merchant code module may be implemented using any suitable code. For example, the merchant module may be implemented using a combination of Perl, HTML, and Java code. The merchant server is typically a generic web server customized for the merchant's business. The merchant server may include databases, CGI scripts, and back-office programs that produce HTML pages for an Internet user.

    During a financial transaction, the client terminal and the merchant server exchange information via the Internet. Each transaction initiated by a consumer has a transaction identifier created at the merchant server. A merchant identifier unique to the payment server is also available from the merchant server. The client code module and the payment server also use this unique transaction identifier for tracking and logging information about the transaction. The merchant server generates a unique identification for the transaction, completes other required parameters, encrypts as appropriate, and builds an HTML page and sends it to the client terminal. The client code module interacts with the smart card and builds a "draw request message" containing related card information, the purchase amount, and other information supplied by the merchant server.

    Next, the client terminal communicates with the payment server by first forwarding the draw request to the payment server. The payment server verifies the transaction to determine if it is a valid transaction from a known merchant. The transaction is logged in the payment server's transaction database. Upon completion of a transaction, the payment server builds a result message containing the identification of the transaction and signs it. The message is then routed to the merchant server via the client terminal. The merchant server then validates the result message. After determining that the transaction was successful, the merchant server creates an HTML page for the purchased information and sends it to the client terminal. The merchant may also deliver purchased goods and services to the consumer at this point. It is also possible for the payment server and the merchant server to communicate information directly between them. As the client terminal has already established communication with the merchant server and the payment server, links are used to exchange information between the payment server and the merchant server, rather than establishing a new link.

    Virtual Smart Card Transactions. Similar to transactions with physical smart cards, the system includes the client terminal, the payment server, and the merchant server. However, the system dispenses with the need for the physical smart cards and card readers as their functionality is contained within the VirtualSAfE server 108. In VirtualSAFE, the client code module is functionally part of the VirtualSAFE server 108 instead of being part of the client terminal. And, the functionality of the card reader module for transactions with physical smart cards is included in the client code module to allow communication with a "pseudo technology process module" (see below). Also, the user interface functionality of the client code module is transferred to a client terminal module in the client terminal. In this embodiment, a "pass through" client code module serves to "pass through" communications between the merchant server and the VirtualSAFE server 108.

    Again, the VirtualSAFE server 108 effectively replaces the need for physical smart cards and card readers. To achieve this, the server 108 implements a "pseudo technology process module" and smart card emulator in software. A card database stores information representing "virtual" smart cards 106 (see below) in use within the system. The card emulator interacts with the card database and a crypto-engine (CEV) 109 (see below) to effectively replace physical smart cards and card readers. Thus, the client code module may be implemented as before unaware that it is interacting with a software emulation of a smart card rather then with a physical smart card.

    The VirtualSAFE server 108 stores the same data used with physical cards in its database and handles incoming commands from initiation or payment servers to increment or decrement a "card" balance as appropriate. Important data is stored in encrypted form and all functions that require a change to important data or the generation or checking of digital signatures is performed by the CEV 109 (see below). The VirtualSAFE server 108 is typically located at an issuer's site. One such server may support multiple issuers provided appropriate safeguards are in place to partition data.

    Furthermore, to support interoperability with existing financial networks, including different credit card vendors, financial institutions, and processing gateways, the VirtualSAFE server 108 may be located at an acquirer's site. This configuration does not change existing transaction flows and does not require additional investment to secure the financial network.

    In an alternative embodiment, the client terminal includes a card reader and a smart card. In this embodiment, the client terminal includes a client code module with "pass through" functionality. The system may operate in either of two modes. The system may operate without using a physical smart card by using the emulation contained within the VirtualSAFE server 108. Concurrently, or at a later date when smart cards and readers are more common, the system may be upgraded to make use of a physical card and reader attached to the client terminal.

    The VirtualSAFE server 108 communicates with the client terminal through a "user verification module" and with the payment server over a link. The server 108 emulates a physical smart card through the use of the pseudo technology process module, a "smart card emulator", the crypto-engine (CEV) 109, and the database 105, 106, 107, 114, 115.

    The user verification module allows the VirtualSAFE server 108 to identify which user is logged on to the system and desires access to a virtual card in the database. The module provides a login procedure that requires a secret user identifier and PIN from each user. A combination of this user identifier and PIN is then used as an index into the database to identify the record that represents the virtual smart card 106 for that user. The user verification module may also include the card identifier (digital certificate digital signature) for the user, the funding account and its expiration date, and address information for address verification during the funding portion of the initiation transaction. An address verification system may compare billing information from an authorization to that on file to assure that the real cardholder is making the transaction.

    The pseudo technology process module is a software module that performs the functionality of a physical card reader so that the emulation of a smart card is transparent to the client code module. The card reader module accepts the actual card reader commands from the client code module and, instead of using them to drive a physical card reader, places them into a format to communicate with the smart card emulator that is emulating a smart card. Thus, an existing application programming interface (API) used by the client code module to communicate with a smart card may continue to be used. In an alternative embodiment, the card reader module and the emulator may be collapsed into a single functional block although this may require modification of the commands issued by the client code module.

    The smart card emulator emulates a physical smart card by accepting and passing the incoming card commands from the card reader module and determining actions to perform. In the course of performing these actions, the emulator handles the interface to the CEV 109, fetches data from, and stores data to, the database. For example, upon receiving a command to debit a card, the emulator fetches the balance from the appropriate record in the database and transfers the encrypted balance to the CEV 109 to be decrypted and decremented. Once the new balance is encrypted by the CEV 109, the emulator receives the new balance and stores it back in the transaction secure database.

    Once an action has been performed, the emulator generates a simulated smart card response that is then relayed via the card reader module and the client code module to the payment server. The emulator generates card commands that appear as if they have been generated by a physical smart card, thus making emulation of the smart card transparent to the rest of the system. The emulator also updates the secure transaction database 114 at appropriate steps in the processing of a debit or an initiation.

    In addition to debiting or initiating a virtual card in the card database, the server 108 is able to credit a virtual card if the card was debited by mistake. In other words, once a card has been debited to make a payment, the server 108 is able to recover that value and credit the virtual card in the card database, if necessary. For example, if a transaction fails and value has been taken off the card, but no value has been credited to a particular payment server, the system is able to credit the virtual card in the card database to replace the lost value. Such an operation is different from a formal initiation command in that a user's card is credited for a value that had earlier been taken off the card.

    VirtualSAFE's databases 105, 106, 107, 114, 115 may be implemented in any suitable format and contain records for each virtual smart card in use within the system. A secure transaction repository 114 and a secure data repository 107 include the information for each virtual smart card in use and thus assists in the simulation of physical smart cards. An identifier such as a user name, PIN, or combination thereof is used as an index into the database in order to identify the appropriate virtual smart card 106 for initiating, debiting, or authentication. Advantageously, the information contained in the database is typically stored in an encrypted form for security. In one embodiment, the database are implemented in Sybase.

    Records in the database store a variety of data for each virtual smart card 106. This information includes initiation and purchase key identifiers, card and issuer certificates, initiation algorithms, initiation key versions, purchase algorithms, purchase key versions, a bank identification number (BIN), a VirtualSAFE Deposit Box (VSDB) 115 number, a transaction ID, a balance, a currency and exponent, an expiration date, and a maximum balance. Initiation and business public keys indicate which keys should be used. Although all keys may be stored within CEV 109, in one embodiment, the keys are stored within the secure data repository 107 as well, with the exception of the CEV master key that is stored in the CEV 109.

    The secure transaction repository 114 stores information regarding transactions that occur such as a debit or an initiation and may be implemented in a similar fashion as the other databases. Also referred to as a history database, the secure transaction repository 114 includes a purchase table (i.e. log full of transactions and timestamps) and an initiation table (i.e. log full of transactions, funding request/response, and timestamps).

    Crypto-Engine (CEV) 109. The CEV module 109 is used to facilitate cryptographic processing. As will be described below, the CEV 109 stores secret keys and encryption algorithms, performs cryptographic functions on secret data and generates digital signatures. Typically, the CEV 109 is a tamper-proof device that employs a level of physical security as means to protect the sensitive information contained therein. The CEV 109 may be suitable security module, for example, it may be similar to the security box typically attached to automatic teller machines. In another embodiment, the CEV 109 may be implemented on a smart card within a card reader, on a series of smart cards, on any suitably secure computer, or in software.

    In addition to other tasks, the CEV 109 performs encryption for physical smart cards. For a physical smart card, various data elements such as balance and currency are contained securely within the card. However, such data elements are not stored within the CEV 109 but are stored in the server's 108 database. Typically, important information is stored in an encrypted form in the database. The CEV 109 performs the task of receiving encrypted card data from the database via an emulator, decrypting the card data, performing required cryptographic functions on the data, and then encrypting the data and sending it back out to be stored in the financial information database 114 and secure data repository 107. For example, if the card balance is to be reduced, the encrypted balance is sent from the database to the CEV 109 where it is decrypted, reduced, and then finally encrypted again before it is returned to the database.

    The CEV 109 also performs cryptograph functions related to digital signatures used within the system. Digital signatures are used during the initiation operation and typically are generated by the smart card. Some digital signatures are used during an initiation or purchase operation and are generated by the issuer or the payment server. Some digital signatures are generated by the smart card on occurrence of an initiation or debit and are considered the final digital signature after the card has either initiated value onto, or debited value from, itself. In VirtualSAFE, the CEV 109 performs these functions which are normally handled by a smart card as no physical smart card need be present with VirtualSAFE. The CEV 109 is used to generate digital signatures and verify digital signatures for an initiation operation, and is used to verify digital signatures and generate digital signatures for a purchase operation. The CEV 109 may also perform other cryptographic functions that would normally be performed by a physical smart card.

    Initiation algorithms are identifiers that identify which cryptographic algorithm of the CEV 109 is to be used for the verification and generation of digital signatures during an initiation. The initiation key version is an identifier identifying which version of a key will be used for the generation or verification of a particular digital signature. Purchase algorithms and purchase key versions perform a similar function during a purchase.

    A six-digit BIN in combination with the ten-digit TEP forms a sixteen-digit "identification number" that uniquely identifies a particular virtual smart card 106. This identification number may also be referred to as a "card identifier". Each BIN, or card range, has a single maximum balance and currency for all of its virtual cards. The balance keeps track of the value for the particular card. Currency and exponent information provide further details concerning the balance. An expiration date provides an expiration date for the card. The maximum balance provides a maximum for the virtual card, or could also indicate a maximum balance for all virtual cards associated with a BIN.

    Public-Key Infrastructure (PKI) 101. VirtualSAFE is compliant with PKI standards for X.509 v1 and v3 certificates, RSA cryptography, PKCS #11 certificates, S/MIME certificates, PKIX v3 extensions, and Secure Electronic Transactions (SET). The PKI process 101 consists of multi-tiered and distinct Certificate Authorities (CA) defined as follows:
    • 1. An External Certification Authority (ECA) designated to issue web certificates to user client computers. Each user has an ECA key pair as follows:
      • ECA Public Key (ECApub)
      • ECA Private Key (ECApriv)
    • 2. An internal VirtualSAFE Certification Authority (VCA) designated to issue corresponding internal VirtualSAFE certificates for each external user web certificate. Each user has a VCA key pair as follows:
      • VCA Public Key (VCApub)
      • VCA Private Key (VCApriv)
    • 3. The VCA issues an encryption certificate to the VirtualSAFE Web Server (VWS) with the following key pair:
      • VSW Public Key (VSWpub)
      • VSW Private Key (VSWpriv)


  • As will be described below, VirtualSAFE has an Attribute Authority (AA) 104 designated for managing access and network permission attributes for users.

    Redirection Link (RL) 102. The redirection link 102 allows non-repudiation by using digital certificates and a secure algorithm and protocol residing on a remote merchant or business site. The redirection link 102 enables an online e-commerce process to access VirtualSAFE's secure transaction environment. The associated process consists of the following steps:
    • 1. The user completes the required conditions for executing a transaction, or request for a resource, by selecting and retrieving the appropriate access query page from a merchant server.
    • 2. The access query will be in the form "buy now" for a payment transaction or "access now" for a secure resource access or retrieval.
    • 3. The redirection link 102 will capture the relevant data from the merchant server and redirect the contents of the request to VirtualSAFE. In the case of any transaction/access any amount/session unique identifier may be transferred. In the case of a resource access request, user attributes may be transferred to Virtual SAFE.


  • The redirection link 102 allows non-repudiation by using X.509 certificates and a secure algorithm and protocol residing on a remote merchant, business, or resource site. The redirection request, once processed, initiates the Secure Remote Pointer (SRP) 103 process for encrypting, signing, and hashing transferred data. The SRP 103 is described below. The merchant and/or user can digitally sign the transaction.

    Secure Remote Pointer (SRP) 103. The SRP 103 is a composite secure algorithm and protocol residing on a remote site (i.e. VirtualSAFE, merchant, user or any other entity) that provides encrypt/decrypt and digital signing timestamp functionality for communicating with VirtualSAFE. The SRP 103 is a VirtualSAFE compatible application that runs as a web browser plug-in, applet, or standard application. The client browser, to conduct secure communications with VirtualSAFE, uses the SRP 103. The process is initiated when the user clicks on a redirection link (RL) 102 that requires an authentication and authorization check. Clicking on this RL 102, as described above, implies a commitment to access a resource, for example, a payment transaction or a secure database. In order to execute a transaction, authentication of the user is required. The process requires authentication of the user computer via an X.509 Digital Certificate or other standard PKI format. Once authenticated with a digital certificate the user, application, or browser will always communicate with VirtualSAFE via the secure web browser plug-in or the SRP 103 or application. The security approach to the SRP 103 includes multi-layer security via encryption and enveloping techniques. The SRP 103 functions include encryption of data that will be packaged and then encrypted via secure sessions in addition to an SSL communication channel with the VirtualSAFE database to complete transactions and store operational data, or for other accesses purposes.

    Referring to FIG. 2, there is shown a flowchart illustrating the operation of the secure remote pointer (SRP) 103 in accordance with an embodiment of the invention. In order to securely capture and store data from the customer, the following steps and requirements are incorporated in the SRP 103:
    • 1. The entire communication will take place over a client-server in addition to an authenticated SSL channel. Two-way authentication is established using the digital certificate distribution method described above.
      • a) The SRP 103 will encrypt data being transmitted to VirtualSAFE prior to being placed in an electronic envelope. The envelope in turn will be transmitted over the secure session in addition to an SSL channel protocol. (Encrypted data is sent in accordance with VirtualSAFE policy through the SSL.)
      • b) The VCA Public-key, VCApub, of the user that is stored in the browser, application, message, or cookie is used to encrypt data once, creating C1201.
      • c) A time stamp is concatenated to the encrypted data package C1201, the ECA private key, ECApriv, belonging to the user signs the data to create C2202.
      • d) The result is encrypted with the VirtualSAFE Web Server Public-key (VSWpub) to create C3203. This key can be obtained by the SRP 103 or in the case of dynamic application that will be transmitted with an ActiveX Control/Java Applet/Application, etc., at the time of page initiation.
    • 2. Encryption and signing of the data package is completed entirely within the secure confines of the SRP 103. The following steps are carried out to securely communicate with VirtualSAFE.
      • a) C3203 is transmitted as C4204 over SSL or other secured channel encrypted with the appropriate session keys.
      • b) The data package C4204 is decrypted 205 by the reciprocal SSL, or secure channel session keys, at the VirtualSAFE Web Server to reveal C3203.
      • c) The VirtualSAFE Web Server/Application will decrypt 206 the data package with its private key VSWpriv locally on the Web Server to reveal C2202. Optionally, this may be performed by a VirtualSAFE Application behind the Web Server.
      • d) The data is now ready to be used locally within VirtualSAFE.
      • e) The data package C2202 is passed 207 to the User's VirtualSAFE Deposit Box 115.
    • 3. The data package in its new form may now be used by VirtualSAFE for various different operations including:
      • a) Authentication. Data received for authentication is treated as an encrypted quantity that does not need to be decrypted. The encrypted data is compared with a database of encrypted PINs in the Virtual SAFE.
      • b) Transaction. The VirtualSAFE private-key VCApriv of the customer is used to decrypt the transaction data received at the time of purchase. The encrypted private information of the customer in the customer repository is decrypted and hashed or encrypted, or digitally signed and sent to the payment processor, or other transaction engine. The VirtualSAFE Private-key (VCApriv) is used to decrypt the local customer credit information for the transaction. The credit information will then be passed to the payment processor or other transaction engine. The information may be optionally signed by the customer, hashed or encrypted by an administrator. The payment configuration will determine future processing and the necessary encryption or digital signing for the data.


  • Attribute Authentication Authority (AA) 104. The AA 104 is an internal and external VirtualSAFE module that enables the assignment of authorization to users and applications to access network resources, and remote non-repudiation providing valid digital signature and verification mechanisms for new or existing financial and other information infrastructures.

    The implementation of a remote electronic commerce application requires managing access to electronic resources. The core value of an e-commerce application lies in the ability to manage identities and the associated privileges attached to these identities. In traditional approaches to PKI, a Certification Authority (CA) issues and revokes certificates used to bind a name to a public key. However, the existing certificate structure requires an existing name space where each individual is uniquely identified with a unique name and often a unique number. In e-commerce transactions, the merchant server may be assured of the customer's identity by means of digital certificate verification. However, the authorization of the customer identity to actually perform the transaction (or other access privilege) is not necessarily a given. Advantageously, VirtualSAFE provides a means for the merchant to be certain that the actions to be undertaken are legally binding and the signer indeed has the authority to execute them.

    In VirtualSAFE, digital certificates are enhanced by including attributes that provide or grant a privilege to its owner. The benefit of this approach makes the attribute certificate well suited for system access control or authorization control.

    By definition, access control entails the limiting of activities of a user on the system. Enforcement of such controls is accomplished by maintaining a reference monitor that mediates access attempts by consulting an authorization base to determine if the user attempting the access is authorized to gain access. A distinction is made here between authentication and access control; authentication confirms the identity of the user, while access control establishes identity privileges on the basis of successful authentication.

    Access control may be deployed in one of two modes, namely, an activity-based mode or a group-based mode. In the activity-based mode, user access control is managed according to activity monitoring where each access is checked against an authorization table and permissions are granted or denied on that basis. In the group-based mode, user access control is based on the group to which a user belongs. Users of the same group are authorized to perform a specific set of system tasks or actions. Instead of specifying all the individual user authorizations, actions are assigned according to the group such that an individual user may perform the tasks assigned to the user's group.

    Group-based access control is characterized by the following:
    • 1. Authorizations are defined according to classes of objects or resources where a member of a group may be authorized to access a particular resource. This enables a class of resources to be accessible to a group of users without specifying individual resource access privileges.
    • 2. Access to specific resources are defined by the activities required by a particular group. A group is defined by its authorizations and a user may be afforded access rights according to a group designation.
    • 3. Groups may be nested in a hierarchical order wherein higher-class groups may inherit lower-class group authorizations.
    • 4. Minimum access may be granted on the basis of a minimum group characteristic. Access for lower risk resources may be afforded by assigning a lower class role.
    • 5. Access privileges can be specified according to Boolean constructs wherein several group authorizations may be afforded to a user to achieve a composite access portfolio.


  • A group-based model is advantageous on several levels. For example, overall administration is shifted to the group level from the individual user level.

    A user may have several authentications including the following:
    • User authentication as described with respect to the authentication authority module 104 below. In addition, an enrolment value is exchanged between VirtualSAFE and a secure portal with a resource group. Any transaction/access session is performed by a minimum of two channels simultaneously (e.g. SSL and VPN, etc.), combining enroll value and session value digitally signed by all parties based on a digital identity group (i.e. secret, shared-secret, physical material).
    • Account/Resource digital signature authentication based a digital signature verified by a user public key attached to the account/resource.


  • The digital certificate infrastructure is well suited for this approach to access control. In the standard digital certificate, a public key is signed by a Certification Authority (CA) and distributed for authentication purposes. The same principle is applied to group-based access control. In this method, a group is described by a set of attributes that enable the members of the group to perform common functions. The attributes are bound together by a digital signature by a CA, creating an Attribute Certificate (AC), which is consequently unalterable until a new set of attributes is designated and signed. The Attribute Certificate may contain the following fields:
    • Version: Designates format of the AC currently in use.
    • Subject: Context of the AC usage in terms of the given application.
    • Issuer: Issuer of the certified AC.
    • Digital signature: Digital signature of the AC data by the Issuer.
    • Issuer Unique ID
    • Serial Number: A unique identifier of the AC.
    • Expiry: Defines the validity period of the AC.
    • Attributes: Access control definitions for the AC.


  • The attribute authentication authority (AA) 104 is advantageous for authentication and authorization of business processes. Typically, existing business processes use some means of account-based protocol to evaluate attributes. However, these methods are reliant on knowledge factor authentication where the user divulges a previously agreed secret. That is, typical business processes supporting authentication are primarily "shared-secret" based (e.g. PINs, mother's maiden name, SIN#, SSN#, etc.). The "shared-secret" has the disadvantage that the shared-secret can both originate as well as authenticate a transaction (i.e. existing business infrastructures need extra levels of security to prevent divulging the shared secret). Upgrading these existing authentication business infrastructures to PKI is straightforward and eliminates the vulnerability associated with divulging the authenticating value.

    Advantageously, VirtualSAFE includes a straightforward upgrade to existing "shared-secret" authentication processes to a "secret", "shared-secret", and "physical material" authentication process using existing business processes. By including an Attribute Certificate in a transaction, the authentication of the user is enhanced. Consider the following access control system, which is in accordance with an embodiment of the invention:
    • 1. A Trusted-Third Party Certification Authority CA(x)
    • 2. An Authentication Authority AA(y)
    • 3. Organization Resource R(1), R(2), R(3), R(4), . . . R(n)
    • 4. Groups described by attributes G(1), G(2), . . . G(n)
    • 5. Users designated as U(1), U(2), . . . U(n)


  • The Certification Authority CA(x) is capable of issuing public key certificates and of signing the root issuing certificate of the Authentication Authority AA(y). Resources are classed and labeled such that access to resource R(1) is distinct and non-connected with R(2), or any other resource R(n). Each group G(n) is assigned authorization to access a particular set of resources based on policy, for example, G(1) may access R(1), R(3), and R(4).

    In this embodiment, a method by which an authorization environment for resource access is made instantaneous, may include the following steps:
    • 1. The root certificate CA(x) is distributed to all users U(n) and resources R(n).
    • 2. The root certificate AA(y) is also made publicly available.
    • 3. Authentication Authority AA(y) is able to issue ACs to all users U(n) in G(n).


  • To exercise a resource access authorization, the following steps may now be followed:
    • 1. An access request to resource R(1) is made by a user member U(1) of group G(1), where G(1) is granted access to R(1), R(2), and R(4), and is digitally signed by the user.
    • 2. Resource R(1) verifies the digital signature of U(1) with U(1)'s public-key certificate.
    • 3. Resource R(1) checks the validity of U(1)'s certificate by verifying the digital signature with CA(x)'s root certificate.
    • 4. The AC of U(1) is verified using AA(y)'s root certificate.
    • 5. The attributes in U(1)'s certificate are then used to grant access, according to the group membership of U(1), to G(1) which includes R(1) access.


  • Given the successful verification of these queries on U(1)'s AC, then the result will be either to deny access or to grant access on the basis of identity authentication and appropriate access authorization.

    Virtual Identity (VI) 105. The VI module 105 is a composite secure algorithm and protocol for creating a digital certificate based virtual identity based on the above described secret, shared-secret, and physical material process. VI 105 includes the use of X.509 Digital Certificates in the internal VirtualSAFE Certification Authority (VCA), as described above. VI 105 also includes the following:
    • 1. The Web certificate from a third party or ECA public and private key of the user:
      • Public Key (ECApub)
      • Private Key (ECApriv)
    • 2. The VirtualSAFE CA public and private key of the user:
      • VCA Public Key (VCApub)
      • VCA Private Key (VCApriv)
    • 3. The private data of the user is encrypted with the user's public key (VCApub) and committed to the local database.
    • 4. The user's private key (VCApriv) is stored securely elsewhere in Virtual SAFE.
    • 5. VirtualSAFE then executes a retrieval of the information in the Virtual Identity 105 by employing a composite secure algorithm and protocol described below in conjunction with the Virtual Smart Card module 106. The retrieval and storage of the secure data is performed on the basis of a secret, shared-secret, and physical material process.
    • 6. The user data stored in the Virtual Identity 105 may include the following:
      • Encrypted PIN and other access data
      • AA Reference Data
      • Personal User Data
      • Financial User Data


  • Virtual Smart Card (VSC) 106. The Virtual Smart Card module 106 enables authentication and secure, isolated encrypt/decrypt and digital verification functionality. Remote or roaming VirtualSAFE digital certificate storage is an important part of this configuration. The VSC module 106 is an internal VirtualSAFE application that acts as a local secure proxy to an external virtual authentication token accessed via the Secure Remote Pointer (SRP) 103. The VSC 106 authenticates, encrypts and decrypts VirtualSAFE user data using a multi-tiered Public Key Infrastructure (PKI) 101 managed service. The VSC 106 implements a multi-tiered PKI by designating a dual set of key pairs for each user. As described above, the first set is an External Public-Private key pair, issued by the External Certification Authority (ECA), which resides on the client or web browser and interoperates with the SRP 103. The second set is a local VirtualSAFE Public-Private key pair issued by the VirtualSAFE Certification Authority (VCA) that resides securely and inaccessibly to the outside network within VirtualSAFE. The Virtual Smart Card (VSC) 106 is part of VirtualSAFE's secure backend Virtual Identity 105 management system. As described above, a system in which VirtualSAFE is deployed typically includes the following:
    • 1. Client Terminal. The client terminal typically includes a personal computer with network interface communication capability, and a World Wide Web browser application. The client terminal runs the Secure Remote Pointer 103 that makes a secure connection with the merchant server.
    • 2. Merchant Server. The merchant server (i.e. WWW server) is configured to serve web pages. The merchant server can serve pages related to an e-commerce shopping-cart application or it can serve pages relating to the access of controlled resources (e.g. documents, applications, etc.).
    • 3. VirtualSAFE server 108. The VirtualSAFE server 108 includes the VSC process 106 and the requisite VirtualSAFE Deposit Box 115 (see below) containing Virtual Identities 105.
    • 4. Payment Server. The payment server (i.e. fulfilment resource) is in communication with VirtualSAFE and may include of any valuable or sensitive services or systems, including but not limited to payment servers, secure data repositories, or other information.


  • The method by which the VSC 106 is accessed by the remote client terminal and by which it executes an online interaction is as follows:
    • 1. A communication channel is opened between the client terminal and the merchant server. The client terminal is presented with content from the merchant server. The user browses this content for items and makes an access decision. In the case of an e-commerce application, this is equivalent to browsing an electronic shopping cart application and composing a list of items for a purchase decision.
    • 2. Upon making an access decision, a signal to actuate a resource access process on behalf of the user is transmitted when the customer clicks the Redirection Link 102 on the merchant server's resource decision web page.
    • 3. The merchant server communicates the requirement to execute the resource access process to the VirtualSAFE server over a secure channel whereby authentication is initiated between the client terminal and VirtualSAFE.
    • 4. VirtualSAFE initiates Virtual Smart Card (VSC) 106 authentication by immediately downloading the Secure Remote Pointer (SRP) 103 to the client terminal.
    • 5. The SRP 103 requires PIN and PIN authentication from the user.


  • The VSC module 106 includes a multi-tiered authentication mechanism that consists of the elements described above with respect to PKI 101, that is, the ECA, VCA, and AA.

    The VSC 106 may be initiated through the following method:
    • 1. A User VCA Public-Private key-pair is generated by VirtualSAFE and stored as follows:
      • a) The VCA public key (VCApub) is combined with the Certificate Digital Signature from the External Public Key Certificate, ECA, and used as a unique identifier or footprint.
      • b) This combined unique identifier and digital certificate data is stored in an online application, browser cookie, or dynamic header of a web page, and automatically downloaded to the client terminal or web browser.
      • c) The unique identifier and digital certificate data is also stored with the user's Virtual Identity (VI) 105 in the user database. As the database's user information is entirely encrypted, the unique identifier and digital certificate data, as described, is used as a search index in order to retrieve encrypted information about a particular user.
      • d) Every query communicated to the VSC 106 from the SRP 103 contains the user's unique identifier and digital certificate data for identification purposes. Note that the data from the SRP 103 is signed and encrypted to help prevent fraud.
    • 2. All the user data stored in the VirtualSAFE database is encrypted with the individual user's VirtualSAFE private key (VCApriv). Any key that is external to VirtualSAFE cannot decrypt the local data, for example, the ECApriv key. The VCApriv key is stored securely in VirtualSAFE, apart from the VSDB 115.
    • 3. When a query is made via the Secure Remote Pointer (SRP) 103 it can arrive in either of the following two forms (as described above with respect to the SRP module 103):
      • a) Authentication. The SRP 103 query composed of a data package C1 is decrypted 208 (see FIG. 2) and verified for use by VirtualSAFE as described above.
        • I. In this case the data contained in the data package is the user footprint and the verified but still encrypted (with VCApub) Personal Identification Number (PIN) from the remote client terminal.
        • II. The user footprint is used to locate the VirtualSAFE database Virtual Identity 105 of the particular user.
        • III. Upon retrieval of the VI 105 of the particular user, the encrypted PIN from the SRP 103 is compared to the PIN in the VI 105 record.
        • IV. If the encrypted data fields match, then an authentication is affirmed, and authorizations associated with this VI 105 are requested from the AA 104.
        • V. The remaining authorizations are queried and verified as described above with respect to the Authentication Authority 104.
      • b) Transaction. The SRP 103 query composed of a data package C1 is decrypted and verified for use by the VirtualSAFE as described above.
        • I. In this case, the data contained in the data package is the user footprint and the verified but still encrypted (with VCApub) resource access query C1 from the remote client terminal.
        • II. The user footprint is used to locate the VirtualSAFE VSC 106 and Virtual Identity 105 for the particular user.
        • III. Upon retrieval of the VI 105 for the particular user, the encrypted resource access query in C1 from the SRP 103 is decrypted 209 (see FIG. 2) with VCApriv that reveals message M.
        • IV. The message M contains formatted instructions for VirtualSAFE to perform some transaction or resource access.
        • V. In order to carry out the transaction or resource access the local VI 105 data must be decrypted with VCApriv. Upon decryption of user data, the transaction must be authorized by the AA 104.
        • VI. The transaction authorization is queried and verified as described above with respect to the authentication authority module 104.
        • VII. The transaction or resource access is executed.
        • VIII. The decrypted VI 105 data is destroyed, and the existing user VI 105 record remains encrypted in the VirtualSAFE Deposit Box 115.
        • IX. Results of the transaction or resource access are returned to VirtualSAFE and the VI 105 record is updated and encrypted/hashed.
        • X. A confirmation of the transaction or resource access is communicated to the client terminal via the SRP 103 and merchant through a dedicated channel or another form of messaging.


  • The Virtual Smart Card (VSC) 106 process may be used in the context of a Point-of-Sale (POS) card-swipe terminal at a merchant's store or shop, as follows. Assume that the customer maintains an account with an existing financial institution. The following steps may be included in the use of the VSC 106:
    • 1. The merchant swipes the magnetic stripe customer debit or credit card at the POS terminal.
    • 2. The POS terminal transmits a request for authorization through the financial network. A connection is made to an intermediate smart card reader at the merchant's store or shop.
    • 3. The smart card reader includes the merchant's smart card.
    • 4. The transaction authorization request from the POS terminal prompts the smart card reader to encrypt and sign the data prior to transmission.
    • 5. VirtualSAFE requires a PIN identification to authenticate the customer.
    • 6. VirtualSAFE performs an authentication of the customer using the Virtual Smart Card process 106 (as described above).
    • 7. The customer is authenticated.
    • 8. VirtualSAFE sends an encrypted or digitally hashed and signed transaction request to the financial institution or to an Interac switch.
    • 9. An authorization message is returned to VirtualSAFE or to the merchant.
    • 10. The authorization message is decrypted by the smart card reader.
    • 11. The authorization message is returned to the POS terminal.


  • The Virtual Smart Card (VSC) 106 process may also be used in the context of check processing, as follows. Assume that the customer is already enrolled in VirtualSAFE. The following steps may be included in the use of the VSC 106:
    • 1. The customer requests a payment be made to a merchant using a VirtualSAFE check by clicking the appropriate Redirection Link (RL) 102 on the merchant's web site.
    • 2. The customer is forwarded to VirtualSAFE.
    • 3. VirtualSAFE performs a remote authentication of the user and passes the customer to their VSC 106.
    • 4. The customer approves a check payment from their personal financial credit portfolio.
    • 5. VirtualSAFE signs the data request and sends it to the financial institution.
    • 6. An optional printout of the check is generated inside the physically secure facilities of the financial institution.
    • 7. VirtualSAFE receives confirmation of check status (e.g. processed, returned, NSF, etc.).
    • 8. VirtualSAFE encrypts and stores the transaction data in the customer's Virtual Identity 105.
    • 9. An optional message or printout of the transaction is forwarded to the customer or merchant.


  • Secure Data Repository 107. The secure data repository 107 is an internal VirtualSAFE module that enables secure storage of dynamic and/or static application data, using a unique PKI based encryption scheme 101 and different crypto-engine security 109, in the same database. Existing standards and business practices allow VirtualSAFE to maintain an internal secure data repository of certificates in optimized format as long as the original certificate format can be exactly reproduced bit-for-bit. These optimizations are implementation dependent for specific operations and may contain a combination of data compression and/or field elimination.

    VirutalSAFE includes the following Database Repositories (DR):
    • 1. VSC/Customer Database. This DR is controlled by VirtualSAFE and contains customer Virtual Identities (VI) 105.
    • 2. VSC/Merchant Repository. This DR is controlled by VirtualSAFE and interfaces with a designated payment server (or other fulfillment resource).


  • The VSC/Customer and Merchant Repositories are interlinked based on the business rules and policies defined in accordance with business requirements. The VSC/Customer Repository is a composite of customers' VI 105 records. These records include all personal, financial, and credit data belonging to each customer.

    VSC/Merchant Repository is based on a fixed schema developed for payment and contains merchant data profiles. The VSC/Merchant Repository also contains payment transactions in various states of completion with a credit payment processor. These states may include the following:
    • Validated
    • Failed
    • Settled


  • These states may be managed, voided, cancelled, etc., and queries, such as retrieving transaction history, return various responses including transaction content which may include the following:
    • Payment Server Transaction ID
    • Credit Card Number
    • Expiry Date
    • Amount
    • Transaction Date
    • Transaction Status


  • External financial systems are securely interfaced with VirtualSAFE in that transaction communications are digitally encrypted and signed.

    Payment Processing Engine 110. The payment processing engine 110 enables the processing of financial transactions with remote payment providers. The payment processing engine 110 may include a server and connectivity to a payment gateway that supports wherein the servers support VirtualSAFE's compatible client-server SSL authentication. Payment processing may include the following: credit card payment, debit card payment, direct debit, check processing, wire, and EFT. Payments in VirtualSAFE may be processed in several modes including batch processing and real-time processing. Each mode achieves the same set of possible results from a payment request, whether it is authorized, settled, or declined. Real-time processing is achieved by executing a single payment request in real-time while the customer is connected. VirtualSAFE's payment processing engine 110 may support several transactions including the following:
    • Credit Card Authorization
    • Address Verification
    • Payment Submission
    • Payment Settlement
    • Transaction Void
    • Transaction Credit


  • Draw Request Messages. In the follow, a detailed description of one method for processing a draw request message in conjunction with a virtual smart card is presented. Recall that draw request messages were introduced in the description of the VirtualSAFE sever 108 above.

    Once a draw request message has been received by the payment server and passed along its terminal, the terminal parses the message back into individual responses and passes these responses sequentially to the virtual smart card. In an alternative embodiment, a dumb terminal is used and the draw request is parsed into its components and otherwise processed by the payment server, which then sends the responses to the virtual smart card itself.

    The payment code module of the payment server edits the draw request for syntactic correctness and logs the draw request message as being received. The draw request is passed to the terminal interface of the payment server. In one embodiment, the terminal interface then requests a terminal from the payment server's terminal pool. The payment server may have a pool of terminals connected to a terminal concentrator that is established at start-up. At start-up, the payment server receives a list of all valid terminal identifiers. The payment server uses these identifiers and its knowledge of transactions in progress to determine an appropriate terminal to process the transaction. Once a terminal is determined, the terminal interface builds a terminal specific message based upon the draw request and the type of terminal.

    The terminal specific draw request is sent to the chosen terminal over a local area network. A concentrator may act as a router between a transaction thread in the payment server and a corresponding terminal if many terminals are attached to the payment server. The concentrator looks at a header on the draw request to determine to which terminal the transaction should be routed. In one embodiment of the invention, the concentrator is not necessary and the payment server communicates directly with the terminal.

    The terminal parses the draw request message into its various components and processes each component in turn to emulate a card interacting with the virtual smart card in a physical terminal. Prepackaging of a variety of data into the draw request message results in fewer exchanges over the Internet between the VirtualSAFE server 108 and the payment server. By simulating an interaction, the virtual smart card behaves as if it were in a physical terminal along with an actual smart card. A variety of responses from a smart card may be emulated. In one embodiment, the terminal sends each of the two commands "Answer to Reset" and "Initialize IE-W for Purchase" down to the virtual smart card individually and waits for a return message, "Debit IE-W," before sending the next response. For a public key transaction, the certificates read by the client are also included as individual responses. In this way, even though all of the smart card information (the draw request) originating from the VirtualSAFE server 108 has been sent at once in prepackaged form over the Internet, the interaction between the smart card and virtual smart card in a physical terminal is simulated at the terminal in a remote location.

    The terminal reaches a "draw amount" state, indicating that the virtual smart card is able to generate a debit command. The virtual smart card generates its virtual smart card digital signature and the command "Debit IE-W". The digital signature and debit commands are sent to the terminal. The debit command issued by the virtual smart card may contain a wide variety of information including the virtual smart card identifier, the transaction identifier, the amount to be debited, the currency and currency exponent for the amount, the virtual smart card digital signature, the date, time, and location. The terminal in turn sends the digital signature, command, and the terminal identifier to the payment server.

    Risk Management Engine 111. The risk management engine 111 is determines transaction validity using detailed heuristic processes.

    Certificate authority digital signatures are not only expensive to manage and computationally burdensome, but they place the issuer, typically a bank, in a risky position. In a Certification Authority Digital Signature (CADS) model, the compromise of a Certification Authority's (CA) private key can be catastrophic. For example, bogus certificates may be issued and fraudulent transactions initiated, all seemingly authorized by the CA. To remedy such a problem, the CA may have to re-issue certificates to every certificate holder and put every previously issued certificate on a CRL. While a breach is undetected, the CA is in a very risky position. Consequently, Certification Authorities guard their private keys with expensive physical and procedural security measures.

    The Account Authority Digital Signatures (AADS) model, on the other hand, carries no systemic risk. Without digital certificates, there is no technical need for a bank to have a private key. Most likely, any bank involved in PKI transactions will likely have a private key, but no certificates (or hierarchy of certificates) are inherently dependent on the security of that key in the AADS model. As attractive as AADS may sound, it will never eliminate the need for digital certificates. In cases where two parties have no prior relationship, third-party certification makes sense. For example, consider a retail customer wanting to open a new account with a bank over the Internet. The concept of a third-party certificate would aid the bank tremendously in making quick work of the electronic sign-up process. This resembles the role that credit bureaus play today.

    Third-party digital certificates will exist. Account authority digital signatures do not preclude the use of CADS. They rely on the same cryptographic operations to validate digital signatures. The latter simply requires additional steps in the validation process. An account authority can easily become a certification authority by applying its digital signature to a customer's public key rather than storing the public key in the account record. If an account authority wants to support trust propagation by issuing certificates, it should, but it should do so based on a conscious business decision. By requiring certificate authority digital signatures, as most existing methodologies do, banks are thrust into the position of propagating trust via digital certificates. It is no longer a business decision but a technical requirement. Banks may not want to take on the risk of trust propagation. As account authorities they don't have to, and they can still remain central to the transaction processing business.

    VirtualSAFE's risk management engine 111 augments the payment processing functionality by providing intermediate vetting of transactions prior to execution by a remote processor. Credit Risk Management occurs in different scenarios of customer enrolment, management, and payment processing. An individual customer's credit rating is used to determine acceptability of payment transaction processing. This value is collected either at enrolment time or during a profile update. It is retrieved by calling the local database using various information fields belonging to the customer. The risk value returned is stored in the VSDB 115. At transaction processing time, the credit value rating is retrieved from the VSDB 115 and used to evaluate whether a transaction should be transmitted to the payment processor. VirtualSAFE maintains ongoing transaction logs or a system transaction journal. That is, any transaction (e.g. payment, customer profile modification, etc) executed using VirtualSAFE is stored along with the information identifying the transaction, issuer, date, resources affected, and Registered Resource Site status.

    Transaction Fulfillment Mechanism (TFM) 112. The transaction fulfillment mechanism 112 is completes e-commerce transactions by means of a secure connection with fulfillment providers. The TFM 112 includes a set of fraud management heuristics that are invoked in a progression that leads to a final fulfillment condition. The fulfillment condition will dictate what type of delivery is to be made and the associated criteria for completion. The TFM 112 and fraud management heuristic is comprised of several steps including the following:
    • 1. Customer Authentication Scoring
    • 2. Credential Identification Scoring
    • 3. Transaction Risk Scoring
    • 4. Fulfillment Response
    • 5. Fulfillment Delivery


  • The first three of these steps are combined to achieve a transaction score that is used to determine the fulfillment response and type of fulfillment delivery. Each step is mutually exclusive with the combined result determining fulfillment completion. The above steps may be described in more detail as follows:

    Customer Authentication Scoring. This step is initiated by compiling the browser logon criteria into a composite score. Elements from the browser logon that may be considered include the following:
    • Certificate Authentication
    • Secure Cookies
    • PIN or PIN value
    • SRP Verifications
    • Other


  • Credential Identification Scoring. This step creates a composite score based on the identifying elements in the order information. Each are weighted and summed based on various criteria which may include the following:
    • Address
    • Amount
    • Over Limit
    • Declined
    • Plug-in Verifications
    • Risk Assessment
    • Transaction type
    • Payment type
    • Fraud
    • Third party assessment proof or change


  • Transaction Scoring. This step involves computing a value and risk for the actual transaction being processed based on transaction attributes as follows:
    • External: Third Party Fraud Assessment that is used for clarification of internal scoring and adjusts final conclusion and instruction for fulfillment execution.
    • Internal: Primary Attribute, Secondary Attribute, Reduction, Tune Up, Risk Adjustment, and Fraud Data Configuration.


  • Fulfillment Response. This is the required response to the established criteria. The transaction will be treated as a variant of "card present", where the physical credit card is actually present, or "authorization", where the credit issuer must confirm available credit.
    • Card Present V
    • Card Present R
    • Authorization


  • Fulfillment Delivery. This is the resulting action taken on the composite score after all of the scoring attributes are evaluated and checked. The resulting delivery may include the following:
    • Request for signature
    • Drop off
    • Delivery
    • Signature
    • Photo ID


  • Insurance Module 113. Through the insurance module 113, VirutalSAFE provides liability and transaction value insurance. A transaction value insurance algorithm is an active link to the Risk Management Engine. The adjustable architecture of this module provides a full and flexible policy for cumulative, minimum, and contractual coverage related to policy and deductions.

    Secure Transaction Repository 114. The transaction secure repository 114 records and securely stores every single transaction that is made by the user.

    VirtualSAFE Deposit Box (VSDB) 115. Through VirtualSAFE's implementation of an authentication authourity server 108, multiple entities (see below) may inter-operate on an open and non-trusted network by means of AC access control. VirtualSAFE permits electronic payment, credit collection, and secure remote fulfillment processes. Through the use of the Virtual Smart Card 106, Secure Remote Pointer 103, Attribute Authority 104, and other modules, VirtualSAFE may be implemented in a variety of ways. Modularity of security objects and application objects enable VirtualSAFE to be applied to numerous electronic commerce environments. In VirtualSAFE, an electronic inter-networking payment system provides for transactions using an electronic payment VSDB 115 for keeping money, credit cards, and other forms of payment organized. Access to the instruments in the VSDB 115 is restricted by encryption and authentication to avoid unauthorized payments. A successful cryptographic authentication is required in order to obtain access to the VSDB 115. The authentication protocol obtains the information necessary for creating a network session granting authority to use an instrument, a payment holder, and a complete electronic wallet. Electronic approval results in the generation of an electronic transaction to complete the order.

    Operation. Referring to FIG. 30, there is shown a block diagram illustrating VirtualSAFE from a business-to-business perspective, and including an e-portal, in accordance with an embodiment of the invention. Referring to FIG. 31, there is shown a block diagram illustrating the VirtualSAFE system from a business-to-consumer perspective, and including a merchant, in accordance with an embodiment of the invention. VirtualSAFE ensures security through a combination of public key certificates and attribute certificates which are deployed for authentication and authorization purposes for each entity in the typical e-commerce transaction. The following entities are typically involved in an electronic commerce (e-commerce) transaction: Customer (or User); Merchant/ Business; Shipper; Payment Processor; Credit Issuer/Credit Acquirer/Credit Card Vendor; and Bank Account. In order to maintain a strong connection between security and business process, security objectives and business requirements are defined and merged in VirtualSAFE. The security objectives are based on fundamental principles of confidentiality, entity authentication, data integrity, and non-repudiation. In general, VirtualSAFE provides the following features and advantages to e-commerce entities:
    • 1. Customer (or User).
      • Customers may affect confidential purchases from merchants.
      • Only customers may access their purchase data.
    • 2. Merchant/Business
      • Merchants have access to the following information: purchase related data submitted by customers; shipping related data (e.g. personal contact information); and, relevant payment information.
    • 3. Payment Processor.
      • The Payment Processor require only payment processing credit information.
    • 4. Credit Issuer/Credit Acquirer/Credit Card Vendor.
      • The Credit Issuer requires all of the above information.
    • 5. Bank Account.
      • The Bank requires only confirmation of the payment transaction.


  • In operation, an electronic commerce system in accordance with an embodiment of the invention includes a client terminal, a merchant server, a payment server, and a VirtualSAFE server 108. A virtual smart card inside the terminal is in communication with the payment server and other modules supported by a multi-tiered authentication authority. A method for conducting an electronic commerce transaction over the Internet using this electronic commerce system may be described as follows:

    Initially, a suitable web browser initiated on the client terminal is used to access a merchant server web site. The user selects goods and/or services from the merchant site and indicates to the site that the he or she wishes to purchase these items using a virtual smart card.

    The merchant server receives this request for a virtual card transaction.

    The merchant server builds an HTML page that includes several parameters. These parameters include the total cost of the transaction as determined by the merchant server, the type of currency being used, the port and IP address of the payment server, and a unique transaction identifier used by both the payment server and the merchant server to track a transaction. Also included is a unique merchant identifier assigned to the merchant by the acquirer and known to the payment server. Other information may also be included such as the currency's exponent, a status URL address of the merchant server used for communication from the client terminal, and a merchant server generated key and other security information to ensure the identity of the merchant server and the integrity of the message. Other process related information such as software release level, encryption methodology, and keys may also be conveyed. Once this page has been built, the page is sent to the requesting client browser and triggers the initiation of a client terminal module in the client terminal.

    Some browsers may not allow an applet to invoke a dynamic link library ("DLL") due to security reasons. As such, in one embodiment of the invention, the client terminal applet, along with any DLLs needed, are pre-initiated on the client terminal. Then, the merchant server is allowed to invoke the client terminal applet and DLLs dynamically to circumvent this security precaution. In an alternative embodiment, the client applet is signed to ensure its authenticity and integrity.

    The client terminal module then displays a screen containing the amount provided by the merchant and requests that the user authorize the amount by entering their user identifier (which preferably is masked on screen) and PIN. Once entered, the client terminal module routes the purchase request (including purchase parameters from the merchant server, user identifier and PIN) to the VirtualSAFE server 108. The VirtualSAFE server 108 then validates the user identifier and PIN with the user verification module.

    The client code module of the VirtualSAFE server 108 then interacts with the pseudo technology process module to build a draw request message for later transmission to the payment server. It should be noted that at this point two types of emulation occur. The VirtualSAFE server 108 neither includes a physical smart card nor a virtual smart card. The physical card is represented as a virtual card in a record of the card database, while the virtual smart card is attached to a remote payment server. Thus, the client code module will emulate commands that a virtual smart card would issue to build the draw request, while the pseudo technology process module, the smart card emulator and the database emulate a physical smart card.

    In one embodiment of the invention, the client code module initiates a local DLL, makes an API call to that library, which in turn makes a call to another DLL that finally makes a call to the pseudo technology process. An "Initiate VSDB for Purchase" command (Initiate VSDB) is created and forwarded to the emulator via the card reader module. This command is modified in a suitable fashion to identify which record in the database will be debited (i.e. which virtual card). For example, the user identifier or PIN may be included. Next, the emulator parses the incoming command and does a database fetch to obtain the virtual card record from the database. In another embodiment of the invention, the fetch may be optimized to only retrieve certain information. The emulator then sends the record to the CEV 109 for decryption of the card data found in the record.

    Once responses to the "Initiate IE-W" (i.e. Intersector Electronic-Wallet) command from the reader are received, the client module combines these responses into a byte stream suitable for transmission over a network to a payment server. Also at this point, the currency type and expiration date of the virtual card in the database are checked, and the total cost of the ordered merchandise is checked against the card balance to ensure that the value on the card is great enough to cover the transaction. If the checks are not successful, a message to that effect is delivered to the user and the transaction terminates.

    Since the virtual smart card is remotely located, it would not be advantageous to engage in numerous commands and responses between the virtual smart card and the client code module over an open network such as the Internet. In the interests of speed and reliability, it is advantageous to have fewer messages exchanged. Accordingly, the client module emulates a variety of virtual smart card commands in order to receive responses to these commands from the pseudo technology process. To operate securely and reliably in this environment, in one embodiment of the present invention, the client module emulates a virtual smart card and gathers all the responses for transmission in one draw request message. The commands and responses take place between the client code module and the pseudo technology process as if there were an actual card reader with a physical smart card inside. In other words, the client code module need not be aware that a virtual card is being used. The draw request message may include a variety of data including a draw request token, state information, the merchant identifier, the transaction identifier, security information, a wallet provider identifier, and an intersector electronic wallet ("IE-W") identifier. Also the message may include an algorithm used by the card, an expiry date, the balance of the card, a currency code, a currency exponent, the authentication mode of the IE-W, the transaction number of the IE-W, a key version, and the purchase amount. As all of this information is prepackaged into a single draw request message, the number of messages over the Internet between the VirtualSAFE server 108 and the payment server is greatly reduced.

    In one embodiment, the draw request message is built by packaging the virtual card's response to the "Reset" and "Initiate IE-W for Purchase" commands, any public key certificates, the total cost, and the currency of the transaction received from the HTML page. For public key cards, the card and the issuer certificates are obtained from read commands and may also be included in the draw request. By packaging all of this information together into one draw request message, it is possible to cut down on the number of messages exchanged between the VirtualSAFE server 108 and the payment server and hence reliability and speed are improved.

    Next, the VirtualSAFE server 108 accesses the payment server using the IP address received from the merchant server. The VirtualSAFE server 108 sends the draw request message to the payment server. The VirtualSAFE server 108 also creates a log of the message being sent.

    The payment server sends to the client terminal the draw request and processes the draw request in conjunction with an associated virtual smart card. In one embodiment of the invention, the payment server creates a transaction thread for each connected client module to service it through the life cycle of the transaction. The payment server receives a debit command and a virtual smart card digital signature from the virtual smart card.

    The virtual smart card digital signature is a value that uniquely identifies and validates the virtual smart card to prove to the VirtualSAFE server 108 that the incoming debit command is a valid command from a real virtual smart card. This validation ensures that when the virtual card is debited the financial totals in the virtual smart card are updated. Thus, the user of the virtual card is guaranteed that a valid debit of the card has occurred. In one embodiment of the invention, the virtual smart card digital signature is an encrypted value ensuring that no other entity can forge an identity of a virtual smart card.

    The payment server sends the debit command along with the virtual smart card digital signature to the VirtualSAFE server 108 to allow the virtual card to accept the debit. At this time, the payment server also logs the debit command into its database. Upon receiving the debit command from the payment server, the client module replaces the amount in the debit command with the original amount (from the merchant server) to ensure that the amount has not been tampered with while traveling over the network. At this time, the client module may also create a log of the debit command.

    The client module forwards the debit command and virtual smart card digital signature to the emulator and it again retrieves the appropriate virtual card record from the database for processing. The card record is retained in memory while a transaction is occurring. The card record, debit command, and digital signature are sent to the CEV 109 where the virtual smart card digital signature is verified and a virtual card digital signature is generated. The card record is updated in the CEV 109 with revised parameters (including balance and transaction ID) to reflect the purchase transaction and returned to the card database. The client module receives the CEV 109 response and generates a "Debit Response" message along with the card digital signature. If the virtual card does not have enough value to satisfy the purchase amount, then a "Debit Response" message indicates as such. The card digital signature is a unique value identifying a valid virtual card in the card database. In one embodiment of the invention, the digital signature is in encrypted form to prevent tampering.

    The emulator sends the response message along with the card digital signature back to the client module. At this point, the purchase amount has been deducted from the balance on the virtual card (assuming a successful transaction). Next, the client module packages the response message along with the card digital signature and sends them back to the payment server. The client module also logs the result of this virtual card debit.

    The payment server receives the incoming message and creates a log and updates the transaction status in its database for future error recovery. The payment server then directs this received message to the virtual smart card in the terminal. Next, the virtual smart