Remote feature activation authentication file system

Information

  • Patent Grant
  • 7890997
  • Patent Number
    7,890,997
  • Date Filed
    Monday, January 20, 2003
    22 years ago
  • Date Issued
    Tuesday, February 15, 2011
    14 years ago
Abstract
A system for providing a user with authorization to perform one or more functions using or otherwise involving a computational component is provided. The system includes an authentication file system 100 operable to (a) receive a request from a user for a second set of authentication information permitting a second set of operations to be performed on a computational component, wherein the computational component is operable to be installed by the user on the computational system, wherein the computational component contains a first set of authentication information permitting a first set of operations to be performed on the computational component; and wherein the first and second sets of operations are different; (b) generate an authentication file containing the second set of authentication information; and (c) transmit the authentication file to the computational system.
Description
FIELD OF THE INVENTION

The present invention is directed specifically to authentication systems and specifically to authentication systems for telecommunication systems.


BACKGROUND OF THE INVENTION

When software is installed in a system (particularly a telecommunication system), it is often necessary to establish service logins within the system for maintenance personnel. These service logins must be very secure to prevent the existence of the login not only from presenting a security risk for the customer but also from being compromised by the customer who can then change the software and right-to-use restrictions for the software. As used herein, a “login” refers to a sequence of symbols or a combination of symbol sequences, such as a user ID or login name and a password and/or a key, that must be correctly inputted into a computational component for a user to be authorized to perform one or more functions using or otherwise involving the computational component. As will be appreciated, a “password” is a unique character or sequence of characters known to a computational component and to a user who must specify the character or character sequence to be authorized to perform one or more functions using or otherwise involving the computational component and a “key” is a sequence of symbols used with a cryptographic algorithm for encrypting or decrypting data. Examples of keys include key-encrypting keys, key-exchange keys, master keys, private keys, and public keys.


In designing a method for initializing the service logins on the system, it is desirable to meet a number of criteria. First for maximum security, each service login should have a unique access key. Second the service login access keys should be established in the system software not only when it is shipped with the system but also at the time of system installation. Default passwords, once compromised, provide little, if any, meaningful security. The software that is shipped with the system should be capable of being distributed electronically and of being copied so that a single copy can be used to install multiple systems. Third, the service logins should be capable of being initialized by a non-trusted person who does not have login privileges without compromising the login access keys. For example, many telecommunication systems are installed by technicians and business partners that are not allowed to have knowledge of the access keys. Fourth, once the logins are initialized the access key information must be known to the manufacturer or system maintenance provider. This is needed to permit service personnel to login using the access keys in the future for system maintenance. Fifth, the service logins should be able to be initialized without requiring a network or data connection from the manufacturer's or system maintenance provider's system directly to the customer's system as such direct communication is not always possible. Sixth, any system to initialize services logins should be available globally as most manufacturer's sell systems internationally. Seventh, a mechanism should be provided to ensure that the service logins are initialized on the customer's system before installation can be completed. Systems cannot be serviced without the service logins being initialized. Eighth, the access keys should be able to be updated or changed after initialization in the event that an access key is compromised. Finally, a mechanism should be provided to ensure that the login access keys for a given system can only be installed on the intended system. If the access key is installed on the wrong system, it would not be possible to access that system since its access keys would be different than those listed in the manufacturer's/maintenance provider's database.


SUMMARY OF THE INVENTION

These and other needs are addressed by the various embodiments and configurations of the present invention. The present invention is directed to an architecture and process for providing authentication information (typically in encrypted form) remotely to a computational system. As used herein, “authentication” refers to verification of the identity of a user or the user's eligibility to access an object, and “authentication information” refers to information, such as passwords, names, and keys, used by a computational component or system to perform verification of the user's identity or eligibility to access the object.


In one embodiment of the present invention, a process for providing a user with authorization to perform one or more functions, using or otherwise involving the computational component, is provided. The process includes the steps of:


(a) Providing a computational component (e.g., contact switching, routing or handling hardware and/or software) for installation by a user (e.g., a trusted or non-trusted party) on a computational system (e.g., a telecommunication switch or server). The computational component has a first set of authentication information (e.g., a login name and/or default password) permitting a first set of operations to be performed on the computational component.


(b) Receiving a request from the user for a second set of authentication information (e.g., a login name and a password and/or key) permitting a second set of operations to be performed on the computational component. The first and second sets of operations are different.


(c) Generating an authentication file containing the second set of authentication information.


(d) Transmitting the authentication file to the computational system.


In one configuration, the first set of authentication information includes a default password, and the first set of operations includes the operation of requesting delivery of the authentication file. The default password provides limited or no ability of the user to access or alter information or objects stored or otherwise contained in the computational component.


In one configuration, the computational system is associated with a unique identifier, and the authentication file includes the unique identifier. The unique identifier, for example, can be a serial number or other type of identifier of the computational component being installed or already in the computational system, such as a processor. In this manner, the authentication file is linked one-to-one with the computational system and cannot be used on a different computational system.


In yet another embodiment, a process for installing a computational component on the computational system is provided. The process includes the steps of:


(a) Providing a computational component for installation by a user on a computational system, the computational component having a first set of authentication information permitting a first set of operations to be performed on the computational component;


(b) Receiving the first set of authentication information from the user before, during, or after installation of the computational component on the computational system.


(c) Verifying the first set of authentication information.


(d) When the first set of authentication information is successfully verified, receiving a request from the user for a second set of authentication information permitting a second set of operations to be performed on the computational component.


(e) Receiving an authentication file containing the second set of authentication information.


(f) Loading the authentication file onto the computational system.


In one configuration, the loading step includes the step of validating and decrypting the authentication file. The validating step typically includes at least one of the following operations (a) determining whether or not a serial number contained in the authentication file matches a serial number associated with the computational system, (b) determining whether or not a right to use the computational component has expired, (c) determining whether or not a version contained in the authentication file matches a version of the computational component, (d) verifying data integrity of the authentication file, and (e) determining whether or not the authentication file length and format are correct.


In yet another embodiment, an authentication file for use in controlling access to a computational system is provided. The data structures in the file include:


(a) a set of login names;


(b) for each login name in the set of login names, a password and/or key; and


(c) a unique identifier associated with the computational system.


The file can also include one or more of the following: a platform type associated with the computational system, a software release associated with software operating on the computational system, and a right-to-use expiration date associated with the software.


In an exemplary configuration, the steps are performed in response to a technician logging onto a central website to request an authentication file for the computational component. The website is used for license creation and delivery for computational components and already has a database record for the computational system that was generated to obtain a right-to-use license. The technician identifies the appropriate database record for the system and requests delivery of the authentication file. Password(s), key(s), and/or other authentication information are then collected and assembled into the authentication file. The file is encrypted and delivered to the technician via e-mail and downloaded to the technician's computer. The key generation and creation of authentication files is done automatically without presenting any key information to the technician. Because the file is encrypted when delivered and the security rules governing the default password severely limit the use privileges of the user, the (access) keys within the file are not compromised when the file is delivered to the technician. The technician can therefore be a trusted or non-trusted party. As used herein, a “non-trusted party” refers to a party who is not provided with access to and/or the ability to alter a defined set of information or objects. A “trusted party”, on the other hand, is a party who is provided with access to and/or the ability to alter the defined set of information or objects. Examples of a non-trusted party are a purchaser of the computational component and maintenance personnel who are not employees of the manufacturer of the computational component. The computational component can thus be installed and login initialization performed by any person without regard to his or her trustworthiness. Because the login access keys are contained in a data file, the keys can be transferred to the system software without direct communication between the manufacturer and the system software. The data file can be transported to the system via magnetic media, optical media, e-mail, or other means not requiring a real-time connection.


The invention can provide a number of advantages compared to conventional systems. For example, each service login can have a unique access key, thereby providing maximum security. Second, the service login access keys can be established in the system software not only when the software is shipped with the system but also at the time of system installation. The default password, even if compromised, has extremely limited use privileges, thereby maintaining meaningful levels of security. The software that is shipped with the system is capable of being distributed electronically and of being copied so that a single copy can be used to install multiple systems. Third, the service logins can be initialized by a non-trusted person who does not have login privileges without compromising the login access keys. For example, telecommunication systems can be readily installed by technicians and business partners, without providing them with access keys. Fourth, once the logins are initialized the access key information can be readily available to the manufacturer or system maintenance provider. This permits service personnel to login using the access keys in the future for system maintenance. Fifth, the service logins can be initialized without requiring a network or data connection from the manufacturer's or system maintenance provider's system directly to the customer's system. Sixth, the system to initialize service logins can be available globally to accommodate international sales. Seventh, the service logins can be initialized on the customer's system before installation can be completed. Systems can thereby be immediately serviced. Eighth, the access keys can be updated or changed after initialization in the event that an access key is compromised. Ninth, due to the use of a unique identifier in the authentication file, login access keys for a given system can only be installed on the intended system.


These and other advantages will be apparent from the disclosure of the invention(s) contained herein.


The above-described embodiments and configurations are neither complete nor exhaustive. As will be appreciated, other embodiments of the invention are possible utilizing, alone or in combination, one or more of the features set forth above or described in detail below.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram of an authentication file system according to a first embodiment of the present invention;



FIG. 2 is a flowchart showing an operation of the remote feature activator according to an implementation of the first embodiment;



FIG. 3 is a flowchart showing an operation of the authentication file generator according to an implementation of the first embodiment;



FIG. 4 is a flowchart showing an operation of the password retrieval agent according to an implementation of the first embodiment;



FIG. 5 is a flowchart showing an operation of the key manager according to an implementation of the first embodiment;



FIG. 6 is a flowchart showing an operation of the key manager according to an implementation of the first embodiment;



FIG. 7 is a flowchart showing another implementation of the remote feature activator according to the first embodiment;



FIGS. 8A and 8B are flowcharts showing another implementation of the authentication file generator according to the first embodiment;



FIG. 9 is a flowchart showing another implementation of the password creator according to the first embodiment;



FIG. 10 is a flowchart showing another implementation of the encryptor according to the first embodiment;



FIG. 11 depicts the data structures in the platform login table;



FIG. 12 depicts the data structures in the authentication file; and



FIG. 13 is a flowchart of an implementation of the local access controller.





DETAILED DESCRIPTION
Overview of the Authentication File System

Referring to FIG. 1, the authentication file system 100 comprises a remote feature activation or RFA system 104 to create, encrypt and deliver authentication files, a password change system scheduler 108 that periodically requests the RFA system 104 to provide authentication files containing new passwords according to predetermined authentication information aging policies, password storage 112 for storing and retrieving passwords and related information (e.g., a unique platform identifier or PID, a unique system identifier or SID, a unique module identifier or MID, a functional location, and platform type associated with each stored password), a password retrieval agent 116 for adding, updating, modifying, and validating of entries in the password storage 112 based on predetermined rules or policies and retrieving stored passwords, a first business application programming interface or BAPI 120 to process messages between the RFA system 104 and password retrieval agent 116, key storage 124 for storing keys and associated key information (e.g., PID, SID, MID, and platform type associated with each stored access key), a key manager 128 for creating keys, for adding, updating, modifying, and validating of entries in the key storage 124 based on predetermined rules or policies, and for retrieving stored keys, and a second BAPI 132 to process messages between the RFA system 104 and key manager 128.


The RFA system 104 comprises a remote feature activator 136 to supervise the operation of the remote feature activation system 104 and completion of the transaction records to update an authentication file history log 140 (discussed below), an authentication file generator 144 to generate authentication files, a password creator (discussed below) 148 to create a random password in response to a password creation request from the authentication file generator 144, a platform login table 152 containing a listing of the logins for each platform type based on the software release, an authentication file history log 140 containing a record of all authentication file activity (e.g., the SID associated with a switch/server, MID associated with the switch server, PID associated with the switch/server, software release, request or transaction number, request or transaction type, source of the request, date and time of transaction, success/failure of the request, and any error messages), and the authentication file encryptor 156 that converts the generic/plain text authentication file into an encrypted authentication file that is ready for delivery to the target system.


The data structures in the platform login table 152 are shown in FIG. 11. As can be seen from FIG. 11, for each platform type 1100 and release 1104 (typically of the software loaded onto the switch/server), a serial swap-out indicator 1108 (that indicates whether or not a new authentication file is required when the license file serial number is changed in the remote feature activation system record), the location 1112 in password storage 112 of the corresponding record (containing password(s)), a listing 1116 of logins or login names (an identifier associated with the user), whether a password is required (yes/no) 1120, any default passwords 1124 used before installation of an authentication file, the password length 1128 (for new password creation and existing password verification), availability of key protection (yes/no) 1132, and the key setting (on/off) 1136. The platform login table 152 is used by the authentication file generator 144 to determine what logins to put in the authentication file. The table also defines which logins require keys and which logins require passwords. The logins required for a switch/server are based on the platform (or switch/server) type or model and the software release.


Referring to FIG. 12, the authentication file 1200 typically includes the platform type 1204, serial number 1208 associated with the switch/server (typically the serial number of an associated processor in the switch/server), software release 1212, right-to-use expiration date 1216 (for the loaded software), platform ID 1220, a listing 1224 of login names and associated passwords, and a listing 1228 of login names and associated keys. The file typically contains password definitions for the logins requiring passwords and key definitions for the logins requiring keys.


A telecommunication switch/server 160, such as the DEFINITY™, 58700™, 58300™, and 58100™ switches/servers sold by Avaya, Inc., is in communication with the authentication file system 100 via a network 164, such as PSTN. The switch/server 160 comprises memory 168 and a processor 172. The switch/server comprises an authentication file 176, which contains authentication information and is delivered by the system 100, and a local access controller 180 for generating authentication file delivery requests and installing received encrypted authentication files on the switch/server. A terminal 184, such as a PC, is connected to the switch/server to permit users to interface with the switch/server. The terminal preferably includes a graphical user interface for the user.


The authentication file system 100 delivers authentication files to target or requesting switches/servers, that typically run on an open operating system. These authentication files contain the non-default passwords and keys for services logins to these switches/servers. Authentication file delivery generates the encrypted authentication file for delivery to the system over a geographically distributed processing network. The authentication file generator 144 interfaces with the password retrieval agent 116 for password storage and retrieval and with the key manager 128 for key generation, storage, and retrieval. The password change system scheduler 108 interfaces with the remote feature activator 136 to request authentication files periodically with new passwords and existing keys. This is done by submitting a password change request to the authentication file system 100. The activator 136 issues an authentication file request for each switch/server identified in the password change request.


Secure and unsecure users with basic (low level) logins can request authentication file delivery remotely from the authentication file system 100. The file can be delivered by any medium, such as via a switch contact (via direct dial-in to the switch/server), email or Web download. The authentication files can include new or existing passwords or keys. When system records are created for switches/servers requiring authentication files and when upgrade modules are added to a switch/server requiring password files and reflected in existing system records for the switch/server, the remote feature activator 136 sends a record creation request to the password retrieval agent 116 and key manager 128 as discussed below with reference to FIGS. 2-6. The records in password storage 112 and key storage 124 are needed to store the passwords and keys for the switch/server. When there is an existing record for a switch/server, the remote feature activator 136 sends an authentication file request where an authentication file comprising a new or existing password or new or existing key is required. This process is discussed below with reference to FIGS. 7-10 and 13. A license file or authentication file cannot be delivered for a switch/server unless a record creation request has been successfully completed for that switch/server.


When a computational component, such as hardware or software, is installed on the switch/server administrative personnel must have the ability to log onto the system as an authentication file has not yet been delivered. Typically, the hardware or software is installed with a default password. The default password permits the user to issue a request for an authentication file to be installed on the switch/server. The default password has extremely limited use privileges, which are typically limited to the right to request installation of an authentication file and certain software/hardware installation commands. In one configuration, the user cannot logon to the software being installed using the default password or otherwise access or alter the information or objects in the software. In the event that the authentication file, after installation, is erased or otherwise unusable, the default password is retained in memory to permit the user to re-install the authentication file.


Record Creation

Referring to FIG. 2, the process to create a record will now be discussed. The remote feature activator 136 in step 200 initially receives a record creation request. The request can be sent by maintenance personnel at the time of sale or installation of the switch/server or at the time of sale or installation of upgrades to the switch/server. In step 204, the record creation request is forwarded to the authentication file generator 144. The record creation request includes the system ID or SID, module ID or MID, request number, request type (module add or application add), platform type, software release, applications (for “module add” this is a listing of the applications for a given module and for “application add” this is a listing of all the applications that were added to the module), software version for each application in the record creation request, platform ID or PID, serial number associated with the switch/server, and the like).


Referring now to FIG. 3, the record creation request in step 300 is received by the authentication file generator 144. The authentication file generator 144 in step 304 forwards the record creation request to the key manager 128 and password retrieval agent 116. The record creation request to the password retrieval agent and key manager includes the SID, MID, and PID.


Referring to FIG. 4, the password retrieval agent 116 in step 400 receives the record creation request from the generator 144 and in step 404 processes the request. The agent 116 sets up a record for the switch/server, by either creating a new record or modifying an existing record and assigning a platform PID if needed, to the switch/server. In step 408, the agent 116 returns a record creation response authentication file generator 144. The response includes the SID, MID, PID, an indicator regarding whether or not the record was successfully created, and any error messages.


Referring now to FIG. 5, the key manager 128 in step 500 receives the record creation request from the generator 144. In decision diamond 504, the manager 128 determines whether or not the platform PID included within the request is already in an existing record in key storage 124. If the PID in the request is not already in a record, the manager 128, in step 508, creates new keys for each login and a new record. Key storage 124 stores one or more versions of the confirmed keys for each switch/server and the last delivered keys if they have not yet been confirmed. This storage allows login to the switch/server when the last delivered authentication file was not successfully installed. If the PID in the request is already in a record, the record creation request fails.


In step 512, the manager 128 generates and sends a record creation response (containing the platform PID) to the authentication file generator 144. The response includes an indicator of the success or failure of the request.


Referring again to FIG. 3, the authentication file generator 144, when record creation responses from both the password retrieval agent 116 and key manager 128 are received, determines in step 308 whether the response is a pass or fail.


When the response from the key manager indicates a failure due to there being an existing record in key storage, the generator 144, in step 312, generates and sends a record update request to the key manager 128. The update request includes the SID, MID, and PID associated with the switch/server. Referring to FIG. 6, the manager 128 in step 600 receives the record update request and in step 604 updates the existing record in key storage 124 containing the platform PID. In step 608, the manager 128 generates and sends a record update response to the authentication file generator 144. The response contains the SID, MID, an indicator of the success or failure of the record update request, and any error messages. As will be appreciated, failure is deemed to exist when a record having the platform PID in the update request cannot be located in key storage 124. In step 316 of FIG. 3, the generator 144 receives the response.


After step 316 or when the record creation response from the password retrieval agent 116 includes a failure indicator or when the record creation response from the agent 116 or manager 128 includes a success indicator, the generator 144 performs step 320. In step 320, the generator 144 generates and sends an overall record creation response to the remote feature activator 136. The response includes the SID, MID, PID, request number, the success or failure of the record creation operation in password storage 112 and key storage 124, and any error messages.


Returning again to FIG. 2, the remote feature activator 136 in step 208 receives the overall record creation response, logs the response into the authentication file history log 140 and generates and sends a response to the requester. If the response includes an error message indicating that a record creation request failed or if the activator 136 gets no response from the generator 144 to a record creation request, the response to the requestor shall be an error message, and no requests for a license file or authentication file delivery shall be allowed. Such requests will only be allowed if a record creation request is successfully acted upon.


Authentication File Delivery

Referring to FIG. 7, authentication file delivery will now be discussed.


In step 700, an authentication file delivery request is received by the remote feature activator 136 from the user of the terminal 184 or a user connected directly to the authentication file system 100.


In step 704, an authentication file request is generated by the remote feature activator 136 and in step 708 sent to the authentication file generator 144. The authentication file request is either for new or existing passwords and/or new or existing keys. The authentication file request typically includes the SID associated with the switch/server, the MID associated with the switch/server, a request number, a platform type, an application description, a software version, the PID associated with the switch/server, a serial number associated with the switch/server, an expiration date of a right-to-use, a password type (new or existing), and a key type (new or existing).


Referring to FIG. 8A, the authentication file generator 144 receives in step 800 the authentication file request from the activator 136. The generator 144 determines whether there is a pending authentication file request for the specified switch/server (SID or PID) (i.e., an authentication file has been delivered to the activator 136 but the activator 136 has not yet responded with a delete information request). If there is a pending request for the switch/server, the passwords and keys delivered in the authentication file shall be the same passwords as delivered in the pending request. If there is not a pending request for the switch/server, the generator 144, in step 804, determines the type of authentication file request received from the activator 136.


When the request is for new passwords, the generator 144 proceeds to step 808 and generates and sends a password creation request to the password creator 148 (one request per login). Referring to FIG. 9, the creator 148 receives the password creation request in step 900 and creates the requested random password(s) according to predefined rules in step 904 (one password/login). The password length of the new passwords is specified in the platform login table. In step 908, the creator 148 generates and sends the newly created password(s) back to the generator 144 in a password creation response.


Returning to FIG. 8A, the generator 144 in step 812 receives the password creation response. The generator 144 does not allow the passwords for different logins to be the same. If this occurs, the generator 144 requests another new password. The generator 144 then proceeds to step 816 (discussed below).


When the request is for existing password(s), the generator 144 proceeds to step 820 and generates and sends a password retrieval request to the password retrieval agent 116. The password retrieval request includes the SID, MID, and login names for which passwords are needed. The password retrieval agent 116 retrieves the password(s) and sends a password retrieval response (including the SID, MID, a success/failure indicator and, if located, the password(s) for each login name) back to the generator 144. The password retrieval response is received by the generator 144 in step 824.


In decision diamond 828, the generator 144 determines whether there is an existing valid password(s) for a login that requires a password (e.g., there is a password, the password is of the length specified in the platform login table, the password is the default as specified in the platform login table 152). If there is no existing valid password, the generator proceeds 144 to step 808 discussed above. If there is an existing valid password, the generator proceeds to step 816.


In step 816, the generator 144 determines whether the authentication file request is for new or existing keys. When the request is for new keys, the generator proceeds to decision diamond 832 and, when the request is for existing keys, proceeds to decision diamond 836.


In decision diamond 832, the generator 144 determines whether there are any unconfirmed keys. As used herein, an “unconfirmed key” refers to a key that has been generated but has not been successfully delivered while a “confirmed key” refers to a key that has been generated and successfully delivered. This is done by sending a key confirmation status request (containing the SID and MID) to the key manager 128. In response, the key manager returns a message including the SID, MID, and an indicator if there any unconfirmed keys for the switch/server are present. When there are unconfirmed keys and an authentication file with existing keys is to be generated, the generator returns an error message to the remote feature activator 136 in step 840 indicating that existing keys were previously provided. The generator then proceeds to step 850 (discussed below). When there are no unconfirmed keys and an authentication file with existing keys is to be generated, the generator in step 844 issues a new key request to the key manager 128 for each login specified in the platform login table. The new key request includes the SID, MID, and login for which the key is needed. In step 848, the requested new keys are received by the generator 144.


In decision diamond 836, the generator 144 determines whether there are any unconfirmed keys. This is done by sending a key confirmation request to the key manager. When there are unconfirmed keys, the generator 144 in step 850 queries the key manager for the unconfirmed key. When there are no unconfirmed keys, the generator 144 in step 852 queries the key manager 128 for the confirmed keys. The key request includes the SID, MID, key type (current key or unconfirmed key), and the login for which the key is needed. The unconfirmed or unconfirmed keys, as the case may be, are received by the generator 144 in step 848 and later used in the authentication file.


Referring to FIG. 8A and 8B, the generator 144 assembles the authentication file in plain text form in step 854 and provides the plain text file to the encryptor 156 in step 856. Referring now to FIG. 10, the encryptor 156 receives the encryption request, containing the plain text file, in step 1000, encrypts the file in step 1004, and returns an encryption response containing the encrypted authentication file to the generator 144 in step 1008.


In step 858, the generator 144 receives the encryption response from the encryptor 156 and, in step 860, generates and sends an authentication file response to the remote feature activator 136. The response includes the SID, MID, request number, the success or failure of the authentication file request, encrypted authentication file information (e.g., file name and location), new or existing password(s), new or existing keys, and any error messages.


Referring again to FIG. 7, the remote feature activator 136 receives the authentication file response from the generator in step 712. In step 716, the encrypted authentication file is delivered via network 164 to the switch/server and/or via network 186 to the terminal 184 for installation on the switch/server. In step 720, the activity is logged into the authentication file history log 140 (e.g., including request type, source of the request, date and time, success/failure of the request, and any error messages). In step 724, a delivery status message is generated and sent to the generator 144 including the SID, MID, request number, and the success or failure of the delivery to the switch/server or terminal. A successful delivery is not necessarily the same event as a successful installation on the switch/server. An authentication file can be successfully delivered but never installed on the switch/server.


Referring again to FIG. 8B, the generator 144 in step 862 receives the delivery status message. In decision diamond 864, the generator 144 determines if the delivery status message indicates a delivery success or failure. If the delivery was successful, the generator 144 in step 866 generates and sends a key confirmation message to the key manager 128. The key confirmation message contains the delivered newly created keys and the PID of the switch/server. Only newly created (or otherwise unconfirmed) keys require confirmation to the key manager. The key manager confirms the keys for the switch/server and sends a key confirmation response back to the generator 144 indicating that the keys were successfully confirmed. The key confirmation response is received by the generator 144 in step 868.


In decision diamond 870, the generator 144 next determines whether new password(s) were provided to the switch/server. When new password(s) were provided to the switch/server, the generator 144 in step 874 generates and sends a password store request to the password retrieval agent 116. The password store request includes the SID, MID, PID, and the new password(s). The agent 116 updates the record corresponding to the switch/server in password store 112, and generates and sends a password store response to the generator 144. The response includes the SID, MID, an indicator of the successful completion of or failure to complete the password store request, and any error messages. The response is received by the generator 144 in step 876. When no new password(s) were provided to the switch/server (decision diamond 870), when the delivery status message indicates a failure (decision diamond 864), or after completion of step 876, the generator 144 generates and sends a delivery status response message to the remote feature activator 136. The message includes the SID, MID, request number, the success/failure of the key confirmation, the message ID of the password storage request, and any error messages. Once any new passwords have been successfully stored in password storage 112, the activator 136 sends a delete information request (which includes the SID, MID, and request number) to the generator 144, indicating that the temporary record created by the generator 144 with the encrypted authentication file can be deleted. In response to the delete information request from the activator 136, the generator 144 deletes the record associated with the authentication file delivery (e.g., the record containing the plain text authentication file) and returns a response message to the activator 136 indicating the success/failure of the record deletion. The response message includes the SID, MID, request number, and the success/failure of the record deletion.


Installation of the Delivered Authentication File


FIG. 13 depicts the operation of the local access controller 180 when a decrypted authentication file is received by the telecommunication switch/server 160. In step 1300, the load authentication file command is invoked, such as by a user of terminal 184. In step 1304, the controller 180 decrypts the new authentication file (after receipt of the file from the authentication file system 100).


In decision diamond 1308, the local access controller 180 performs a series of checks to determine if the authentication file is valid. The local access controller 180 confirms that the serial number 1208 contained in the authentication file 1200 (FIG. 12) matches the serial number of the active processor in the switch/server 160, that the right-to-use has not expired, that the version or release contained in the authentication file matches the software version or release loaded onto the switch/server 160, the authentication file has data integrity by using a checksum or other suitable approach, and that the authentication file length and format are correct.


If one or more of the preceding queries is not confirmed, the local access controller proceeds to step 1312 and displays a suitable error message to the user and terminates operation.


If each of the queries is confirmed, the new authentication file is stored in translation in step 1316. The new authentication file overwrites the authentication file already in memory.


Once the file is installed, the logins are initialized and the access keys within the file are used by the controller 180 to authenticate users attempting to login using a service login. To ensure that the file is installed and service logins are activated, the controller 180 will not provide full functionality until a valid authentication file is installed. The authentication file delivery and loading steps in the installation process cannot be skipped or forgotten because additional installation steps cannot be completed unless the authentication file is in place.


If it is necessary or desired to change the access keys after initial installation of the telecommunication switch/server, a new authentication file with new access keys can be requested from the authentication file system 100 website, delivered to the technician, and installed on the switch/server 160. A date/time stamp is used in each authentication file to ensure that, when a new authentication file is installed in place of an existing authentication file on a switch/server, the new file is in fact newer than the existing file. This prevents accidental installation of an older file, which would result in the access keys of record in the key storage 124 differing from the access keys on the switch/server.


When it is necessary to log into the authentication file system using a service login, the key manager accesses key storage to locate and retrieve the unique key for the switch/server from which the login request is received. The key is used to successfully provide the correct response to the access challenge generated by the authentication file system 100 based on the same access key in the authentication file installed on the switch/server 160.


A number of variations and modifications of the invention can be used. It would be possible to provide for some features of the invention without providing others.


For example in one alternative embodiment, the various modules referenced herein are implemented as software, hardware (e.g., a logic circuit), or a combination thereof.


In another alternative embodiment, the division of the various functions performed by the various modules in the authentication file system are different.


In another alternative embodiment, the authentication file can include fields for any number of unique identifiers for the same or differing types of hardware components. For example, for validation of the authentication file to be successful the local access controller could require that there be matches for serial numbers not only of a control processor but also of an application specific integrated circuit or another type of hardware component.


The present invention, in various embodiments, includes components, methods, processes, systems and/or apparatus substantially as depicted and described herein, including various embodiments, subcombinations, and subsets thereof. Those of skill in the art will understand how to make and use the present invention after understanding the present disclosure. The present invention, in various embodiments, includes providing devices and processes in the absence of items not depicted and/or described herein or in various embodiments hereof, including in the absence of such items as may have been used in previous devices or processes, e.g. for improving performance, achieving ease and\or reducing cost of implementation.


The foregoing discussion of the invention has been presented for purposes of illustration and description. The foregoing is not intended to limit the invention to the form or forms disclosed herein. In the foregoing Detailed Description for example, various features of the invention are grouped together in one or more embodiments for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed invention requires more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive aspects lie in less than all features of a single foregoing disclosed embodiment. Thus, the following claims are hereby incorporated into this Detailed Description, with each claim standing on its own as a separate preferred embodiment of the invention.


Moreover though the description of the invention has included description of one or more embodiments and certain variations and modifications, other variations and modifications are within the scope of the invention, e.g. as may be within the skill and knowledge of those in the art, after understanding the present disclosure. It is intended to obtain rights which include alternative embodiments to the extent permitted, including alternate, interchangeable and/or equivalent structures, functions, ranges or steps to those claimed, whether or not such alternate, interchangeable and/or equivalent structures, functions, ranges or steps are disclosed herein, and without intending to publicly dedicate any patentable subject matter.

Claims
  • 1. A method, comprising: providing a first computational component for installation by an untrusted user on a first computational system, the first computational component having a first set of authentication information permitting a first set of operations to be performed on the first computational component, wherein the first set of authentication information corresponds to a first login and comprises a first key and/or password, and wherein the first set of operations comprises requesting delivery of a second set of authentication information to enable a second set of operations to be performed on the first computational component, the first and second sets of operations being different, wherein the first set of operations provides access by the user to fewer validly licensed operational features than the second set of operations;receiving by a remote feature activation system, at the time of sale or after purchase and installation of the first computational component, a request to create and/or update a system record associated with at least one of the first computational system and component;creating or updating, by the remote feature activation system, the system record;after the system record is created or updated successfully, receiving, by an input via signal transmission over a geographically distributed processing network, a request from the untrusted user for the second set of authentication information;generating, by the remote feature activation system, the second set of authentication information, wherein the second set of authentication information comprises a unique first identifier of the first computational system, corresponds to at least a second login, and comprises a second key and/or password, whereby the unique first identifier associates the second set of authentication information with the first computational system and prevents use of the second set of authentication information with a second computational system having a different unique second identifier;encrypting, by the remote feature activation system, the second set of authentication information to form an encrypted second set of authentication information;transmitting, by the remote feature activation system over the geographically distributed processing network, the encrypted second set of authentication information to the first computational system; andprohibiting, by the first computational system, the untrusted user from accessing a plain text version of at least one of the second key and/or password in the second set of authentication information.
  • 2. The method of claim 1, wherein the first computational system is a telecommunication switch or server and the first computational component is software to be loaded onto the switch or server, wherein the second set of authentication information is delivered by Web download, wherein the first set of operations do not permit the user to cause execution of the first computational component, and, wherein the first set of operations provides, at most, only limited access to validly licensed operational features and the second set of operations provides full access to validly licensed operational features, and the method further comprising: determining, by the first computational system, whether or not the unique first identifier contained in the second set of authentication information matches the unique first identifier of the first computational system;determining, by the first computational system, whether or not a right to use the first computational component has expired;determining, by the first computational system, whether or not a version contained in the second set of authentication information matches a version of the first computational component;wherein, when the unique first identifier in the second set of authentication information matches the unique first identifier of the first computational system, when the right to use the first computational component has not expired, and when the version in the second set of authentication information matches the version of the first computational component, the second set of authentication information is considered to be valid; andwherein, when one or more of the following is true: when the unique first identifier in the second set of authentication information does not match the unique first identifier of the first computational system, when the right to use the first computational component has expired, or when the version in the second set of authentication information does not match the version of the first computational component, the second set of authentication information is considered to be invalid.
  • 3. The method of claim 1, wherein the first set of authentication information comprises a default password and the first set of operations comprise requesting delivery of the second set of authentication information and wherein the default password does not entitle the user to access the second set of authentication information.
  • 4. The method of claim 1, wherein the second set of authentication information is unique to the second login.
  • 5. The method of claim 4, wherein the second set of authentication information comprises a plurality of platform type, the first identifier, a platform identifier, a software release, a right-to-use expiration date, one or more login names, one or more passwords associated respectively with the one or more login names, and one or more keys associated, respectively, with the one or more login names.
  • 6. The method of claim 1, wherein the second set of authentication information is transmitted by electronic mail.
  • 7. The method of claim 1, wherein the second set of authentication information comprises at least one of a password and key associated with a login name and wherein each login has a unique at least one of a password and key.
  • 8. The method of claim 1, wherein the second set of operations comprise logging onto the first computational component and accessing information contained therein and wherein the user does not have use privileges to access in unencrypted form the second key and/or password in the second set of authentication information.
  • 9. The method of claim 1, wherein the encrypted second set of authentication information is in a data file and is transmitted without a real-time direct connection between the first computational system and the remote feature activation system.
  • 10. The method of claim 1, wherein the generating step comprises: determining whether the request is for a newly created password or an existing password;when the request is for a newly created password, creating the new password; andwhen the request is for an existing password, retrieving the password from password storage.
  • 11. The method of claim 10, further comprising: determining whether there are any unconfirmed keys associated with the first computational system.
  • 12. The method of claim 11, further comprising: determining whether the request is for a newly created key or an existing key;when the request is for a newly created key, creating the new key; andwhen the request is for an existing key, retrieving the key from key storage.
  • 13. The method of claim 1, further comprising: receiving a record creation request, the record creation request comprising at least two of the following: a first computational component identifier, the first computational system identifier, a request number, a request type, a platform type, a software release, a software version, a platform identifier, and a serial number;creating a new record in response to the record creation request, the new record comprising a plurality of at least one of passwords and keys for each of a plurality of logins; andverifying, by the first computational system, that the second set of authentication information is valid, said verification comprising at least one of serial number matching, right-to-use expiration, version or release matching, data integrity verification, and authentication file length and format verification; andwherein the request for the second set of authentication information comprises at least two of the first computational component identifier, the first computational system identifier, the request number, the platform type, an application description, the software version, the platform identifier, the serial number, an expiration date of a right-to-use, a password type, and a key type; and wherein the generating step comprises:in response to the request for the second set of authentication information, obtaining at least two of a password and key corresponding to the at least one of the first computational system identifier, the first computational component identifier, the request number, the platform type, the application description, the software version, the platform identifier, the serial number, the expiration date of the right-to-use, the password type, and the key type; andassembling the second set of authentication information.
  • 14. A system, comprising a non-transitory computer-readable medium that includes: a processor-executable retrieval agent operable to (i) receive, at the time of sale or after purchase and installation of a first computational component, from a remote feature activation system, and by a network, a request to create or update a system record associated with at least one of a first computational system and the first computational component and (ii) create and/or update the system record; anda processor-executable authentication file system operable, after the system record is created or updated successfully, to:(a) receive a request from an untrusted user for a second set of authentication information permitting a second set of operations to be performed on the first computational component, wherein the first computational component is operable to be installed by the untrusted user on the first computational system, wherein the first computational component contains a first set of authentication information permitting a first set of operations to be performed on the first computational component, wherein the first set of authentication information corresponds to a first login and comprises a first key and/or password, and wherein the first set of operations comprises requesting delivery of the second set of authentication information, and wherein the first and second sets of operations are different;(b) generate an encrypted authentication file containing the second set of authentication information, wherein the second set of authentication information comprises a unique first identifier of the first computational system, corresponds to at least a second login, and comprises a second key and/or password, whereby the unique first identifier prevents use of the second set of authentication information with a second computational system having a different unique second identifier; and(c) transmit, over a geographically distributed processing network, the encrypted authentication file to the first computational system, wherein the untrusted user does not have a privilege to access, through the first computational system, a plain text version of at least one of the second key and/or password in the encrypted authentication file.
  • 15. The system of claim 14, wherein the first computational system is a telecommunication switch or server and the first computational component is software to be loaded onto the switch or server, wherein the authentication file is delivered by Web download, wherein the first set of operations do not permit the user to cause execution of the first computational component, wherein the first set of operations provides, at most, only limited access to validly licensed operational features and the second set of operations provides full access to validly licensed operational features and wherein the first computational system is further operable to: determine, by the first computational system, whether or not the unique first identifier contained in the second set of authentication information matches the unique first identifier of the first computational system;determine, by the first computational system, whether or not a right to use the first computational component has expired;determine, by the first computational system, whether or not a version contained in the second set of authentication information matches a version of the first computational component;wherein, when the unique first identifier in the second set of authentication information matches the unique first identifier of the first computational system, when the right to use the first computational component has not expired, and when the version in the second set of authentication information matches the version of the first computational component, the second set of authentication information is considered to be valid; andwhen one or more of the following is true: when the unique first identifier in the second set of authentication information does not match the unique first identifier of the first computational system, when the right to use the first computational component has expired, or when the version in the second set of authentication information does not match the version of the first computational component, the second set of authentication information is considered to be invalid.
  • 16. The system of claim 14, wherein the first set of operations provides, at most, limited access to validly licensed operational features of the first computational component, wherein the second set of operations provides full access to validly licensed operational features of the first computational component, wherein the first set of authentication information comprises a default password and the first set of operations comprise requesting delivery of the authentication file and wherein the default password does not entitle the user to access the second set of authentication information.
  • 17. The system of claim 14, wherein the second set of authentication information is unique to the second login.
  • 18. The system of claim 14, wherein the authentication file is transmitted by electronic mail.
  • 19. The system of claim 14, wherein the second set of authentication information comprises at least one of a password and key associated with a login name and wherein each login has a unique at least one of a password and key.
  • 20. The system of claim 14, wherein the second set of operations comprise logging onto the first computational component and accessing information contained therein and wherein the user does not have use privileges to access in unencrypted form the second key and/or password in the encrypted authentication file after transmission to the user.
  • 21. The system of claim 14, wherein the authentication file system comprises an encryptor operable to encrypt the authentication file in a data file, without a direct connection between the first computational system and the remote feature activation system.
  • 22. The system of claim 14, wherein the authentication file system comprises: an authentication file generator operable to generate the authentication file;a password creator operable to create at least one of a random and pseudo random password;an authentication file encryptor operable to encrypt the authentication file; anda platform login table comprising a listing of login names and at least one of an associated password and key.
  • 23. The system of claim 22, further comprising: a password retrieval agent operable to store passwords in and retrieve passwords from password storage;a key manager operable to generate new keys and store keys in and retrieve keys from key storage; anda password change system scheduler operable to periodically request a new authentication file to be generated and transmitted to the first computational system.
  • 24. The system of claim 14, wherein the authentication file comprises a plurality of platform type, a software release, an expiration date, one or more login names, one or more passwords associated respectively with the one or more login names, and one or more keys associated respectively with the one or more login names.
  • 25. The system of claim 14, wherein the authentication file comprises: a set of login names;for each login name in the set of login names, at least one of a password and a key; anda unique first identifier associated with the first computational system.
  • 26. The system of claim 25, wherein each login name has a corresponding password.
  • 27. The system of claim 25, wherein each login name has a corresponding key and wherein the authentication file further comprises a plurality of a platform type, a software release, and a right-to-use expiration date.
  • 28. The system of claim 25, wherein the unique first identifier is a serial number of a processor in the first computational system.
  • 29. The system of claim 25, further comprising a platform type associated with the first computational system, a software release associated with software operating on the first computational system, and a right-to-use expiration date associated with the software.
  • 30. A method, comprising: providing a first computational component for installation by an untrusted user on a first computational system;providing the untrusted user with at least one of a first password and key corresponding to a first login;after a first set of operations is enabled and after the untrusted user has successfully logged in to the first computational component using the first login and the at least one of the first password and key, receiving, at an input, a request from the untrusted user for authentication information permitting a second set of operations by the first computational component on the first computational system to be enabled, the authentication information corresponding to at least a second login and comprising a unique first identifier of at least one of the first computational component and first computational system and at least one of a second password and key, whereby the unique first identifier prevents use of the authentication information, on a second computational system, with a second computational component, wherein at least one of the second computational component and second computational system has a unique second identifier different from the first identifier;generating, by a remote feature activation system, an encrypted authentication file containing the set of authentication information; andtransmitting, by the remote feature activation system over a distributed processing network, the encrypted authentication file to the user, wherein the user is not privileged to access, through the first computational system, a plain text version of at least one of the second password and key in the encrypted authentication file.
  • 31. The method of claim 30, wherein the first login and the at least one of a first password and key permit the first set of operations to be performed on the first computational system, wherein the first set of operations provides the untrusted user with, at most, limited access to validly licensed features of the first computational component, wherein the request is transmitted over the distributed processing network, and wherein the first computational system is a telecommunication switch or server, and the first computational component is software to be loaded onto the switch or server, wherein the authentication file is delivered by Web download, wherein the first set of operations do not permit the user to cause execution of the first computational component, and wherein the first set of operations permit the user to request delivery of the authentication file and installation of the first computational component, and wherein the authentication information and second set of operations permit full access, by the untrusted user, to the validly licensed features.
  • 32. The method of claim 30, wherein the first login and at least one of a first password and key permits the first set of operations to be performed on the first computational component, wherein the first set of operations includes requesting authentication information, wherein the request is transmitted over the distributed processing network, wherein the first computational system is a telecommunication switch or server, and the first computational component is software to be loaded onto the switch or server, wherein the authentication file is delivered by Web download, wherein the second set of operations, but not the first set of operations, permit the user to cause execution of the first computational component, and wherein the first set of operations permit the user to request delivery of the authentication file and installation of the first computational component.
  • 33. The method of claim 30, wherein the at least one of a first password and key is different from the at least one of the second password and key.
  • 34. The method of claim 33, wherein the authentication file comprises a plurality of platform type, a software release, an expiration date, one or more login names, one or more passwords associated respectively with the one or more login names, and one or more keys associated respectively with the one or more login names.
  • 35. The method of claim 30, wherein the first login and the at least one of a first password and key provide the untrusted user with, at most, only limited access to validly licensed operational features and the authentication information provides, by the second set of operations, the untrusted user with full access to validly licensed operational features and wherein the authentication file is transmitted by electronic mail.
  • 36. The method of claim 30, wherein the encrypted authentication file is transmitted in a data file, without a direct connection between the first computational system and the remote feature activation system.
  • 37. The method of claim 30, wherein the generating step comprises: determining whether the request is for a newly created password or an existing password;when the request is for a newly created password, creating the new password; andwhen the request is for an existing password, retrieving the password from password storage.
  • 38. The method of claim 37, further comprising: determining whether there are any unconfirmed keys associated with the first computational system.
  • 39. The method of claim 38, further comprising: determining whether the request is for a newly created key or an existing key;when the request is for a newly created key, creating the new key; andwhen the request is for an existing key, retrieving the key from key storage.
  • 40. The method of claim 30, further comprising: receiving a record creation request, the record creation request comprising at least two of the following: the first identifier, a request number, a request type, a platform type, a software release, a software version, a platform identifier, and a serial number;creating a new record in response to the record creation request, the new record comprising a plurality of at least one of passwords and keys for each of a plurality of logins; andverifying, by the first computational system, that the authentication information is valid, said verification comprising at least one of serial number matching, right-to-use expiration, version or release matching, data integrity verification, and authentication file length and format verification; andwherein the request for the authentication information comprises at least two of the first identifier, the request number, the platform type, an application description, the software version, the platform identifier, the serial number, an expiration date of a right-to-use, a password type, and a key type; and wherein the generating step comprises:in response to the request for the authentication information, obtaining at least one of a password and key corresponding to the at least two of the first identifier, the request number, the platform type, the application description, the software version, the platform identifier, the serial number, the expiration date of a right-to-use, the password type, and the key type;assembling the authentication information; andencrypting the authentication information for transmission over the network to the user.
  • 41. A system, comprising a non-transitory computer-readable medium that includes: a processor-executable authentication file system operable to: receive a request from an untrusted user for authentication information permitting installation of a first computational component on a first computational system, wherein the untrusted user uses at least one of a first password and key corresponding to a first login to generate the request, the authentication information corresponding to at least a second login and comprising a unique first identifier of at least one of the first computational component and first computational system and at least one of a second password and key, whereby the unique first identifier prevents use of the authentication information, on a second computational system, with a second computational component, wherein at least one of the second computational component and second computational system has a unique second identifier different from the first identifier;generate an encrypted authentication file containing the set of authentication information as cipher text; andtransmit, over a distributed processing network, the encrypted authentication file to the user, wherein the user is prohibited, by the first computational system, from accessing a plain text form of the at least one of the second password and key in the encrypted authentication file.
  • 42. The system of claim 41, wherein the first login provides the untrusted user with, at most, limited access to validly licensed features of the first computational component and the authentication information provides the user with full access to validly licensed features, wherein the first login and the at least one of a first password and key permit a first set of operations to be performed on the first computational system, wherein the first set of operations provides the untrusted user with, at most, limited access to validly licensed features of the computational component, wherein the request is transmitted to the user over the distributed processing network, and wherein the first computational system is a telecommunication switch or server, and the first computational component is software to be loaded onto the switch or server, wherein the authentication file is delivered by Web download, wherein the first set of operations do not permit the user to cause execution of the first computational component, and wherein the first set of operations permit the user to request delivery of the authentication file.
  • 43. The system of claim 41, wherein the first login and at least one of a first password and key permit a first set of operations to be performed on the first computational component, wherein the first set of operations includes requesting authentication information, wherein the request is transmitted over the distributed processing network, wherein the first computational system is a telecommunication switch or server, and the first computational component is software to be loaded onto the switch or server, wherein the authentication file is delivered by Web download, wherein the first set of operations do not permit the user to cause execution of the first computational component, and wherein the first set of operations permit the user to request delivery of the authentication file.
  • 44. The system of claim 41, wherein the at least one of a first password and key is different from the at least one of the second password and key and wherein the authentication information is unique to each login.
  • 45. The system of claim 44, wherein the authentication file comprises a plurality of platform type, a software release, an expiration date, one or more login names, one or more passwords associated respectively with the one or more login names, and one or more keys associated respectively with the one or more login names.
  • 46. The system of claim 41, wherein the first login and the at least one of a first password and key provide, at most, only limited access to validly licensed operational features and the authentication information provides full access to validly licensed operational features and wherein the authentication file is transmitted by electronic mail.
  • 47. The system of claim 41, wherein each login has a unique at least one of a password and key.
  • 48. The system of claim 41, wherein the user does not have use privileges to access in unencrypted form the at least one of the second password and key in the encrypted authentication file after transmission to the user.
  • 49. The system of claim 41, wherein the encrypted authentication file is transmitted in a data file, without a direct connection between the first computational system and the remote feature activation system.
  • 50. The system of claim 41, wherein the authentication file system is operable to: determine whether the request is for a newly created password or an existing password;when the request is for a newly created password, create the new password; andwhen the request is for an existing password, retrieve the password from password storage.
  • 51. The system of claim 50, wherein the authentication file system is operable to: determine whether there are any unconfirmed keys associated with the first computational system.
  • 52. The system of claim 51, wherein the authentication file system is operable to: determine whether the request is for a newly created key or an existing key;when the request is for a newly created key, create the new key; andwhen the request is for an existing key, retrieve the key from key storage.
CROSS REFERENCE TO RELATED APPLICATIONS

This application claims the benefits under 35 U.S.C. §119 of U.S. Provisional Patent Application Ser. No. 60/436,874, of the same title, filed Dec. 26, 2002, to Walker et al., which is incorporated herein by this reference.h

US Referenced Citations (258)
Number Name Date Kind
4288659 Atalla Sep 1981 A
4405829 Rivest et al. Sep 1983 A
4780821 Crossley Oct 1988 A
4811393 Hazard Mar 1989 A
4888800 Marshall et al. Dec 1989 A
4937863 Robert et al. Jun 1990 A
5005122 Griffin et al. Apr 1991 A
5023907 Johnson et al. Jun 1991 A
5157663 Major et al. Oct 1992 A
5179591 Hardy et al. Jan 1993 A
5204897 Wyman Apr 1993 A
5206903 Kohler et al. Apr 1993 A
5230020 Hardy et al. Jul 1993 A
5260999 Wyman Nov 1993 A
5307481 Shimazaki et al. Apr 1994 A
5329570 Glassmacher et al. Jul 1994 A
5341427 Hardy et al. Aug 1994 A
5347580 Molva et al. Sep 1994 A
5386369 Christiano Jan 1995 A
5390297 Barber et al. Feb 1995 A
5408649 Beshears et al. Apr 1995 A
5448639 Arazi Sep 1995 A
5553143 Ross et al. Sep 1996 A
5563946 Cooper et al. Oct 1996 A
5579222 Bains et al. Nov 1996 A
5629980 Stefik et al. May 1997 A
5646992 Subler et al. Jul 1997 A
5671412 Christiano Sep 1997 A
5673315 Wolf Sep 1997 A
5699431 Van Oorschot et al. Dec 1997 A
5708709 Rose Jan 1998 A
5717604 Wiggins Feb 1998 A
5724428 Rivest Mar 1998 A
5742757 Hamadani et al. Apr 1998 A
5745569 Moskowitz et al. Apr 1998 A
5745576 Abraham et al. Apr 1998 A
5745879 Wyman Apr 1998 A
5754761 Willsey May 1998 A
5758068 Brandt et al. May 1998 A
5758069 Olsen May 1998 A
5790074 Rangedahl et al. Aug 1998 A
5790664 Coley et al. Aug 1998 A
5796941 Lita Aug 1998 A
5828747 Fisher et al. Oct 1998 A
5835600 Rivest Nov 1998 A
5864620 Pettitt Jan 1999 A
5905793 Flockhart et al. May 1999 A
5905860 Olsen et al. May 1999 A
5935243 Hasebe et al. Aug 1999 A
5940504 Griswold Aug 1999 A
5956505 Manduley Sep 1999 A
5956716 Kenner et al. Sep 1999 A
5960085 de la Huerga Sep 1999 A
5978565 Ohran et al. Nov 1999 A
5982873 Flockhart et al. Nov 1999 A
5995625 Sudia et al. Nov 1999 A
6006016 Faigon et al. Dec 1999 A
6009401 Horstmann Dec 1999 A
6011973 Valentine et al. Jan 2000 A
6023763 Grumstrup et al. Feb 2000 A
6023766 Yamamura Feb 2000 A
6047242 Benson Apr 2000 A
6067621 Yu et al. May 2000 A
6108703 Leighton et al. Aug 2000 A
6128389 Chan et al. Oct 2000 A
6134660 Boneh et al. Oct 2000 A
6148415 Kobayashi et al. Nov 2000 A
6163607 Bogart et al. Dec 2000 A
6173053 Bogart et al. Jan 2001 B1
6178511 Cohen et al. Jan 2001 B1
6189146 Misra et al. Feb 2001 B1
6192122 Flockhart et al. Feb 2001 B1
6212635 Reardon Apr 2001 B1
6219652 Carter et al. Apr 2001 B1
6223291 Puhl et al. Apr 2001 B1
6246871 Ala-Laurila Jun 2001 B1
6314565 Kenner et al. Nov 2001 B1
6343280 Clark Jan 2002 B2
6360320 Ishiguro et al. Mar 2002 B1
6381747 Wonfor et al. Apr 2002 B1
6414595 Scrandis et al. Jul 2002 B1
6421726 Kenner et al. Jul 2002 B1
6442708 Dierauer et al. Aug 2002 B1
6463534 Geiger et al. Oct 2002 B1
6502079 Ball et al. Dec 2002 B1
6513117 Tarpenning et al. Jan 2003 B2
6539481 Takahashi et al. Mar 2003 B1
6557105 Tardo et al. Apr 2003 B1
6574612 Baratti et al. Jun 2003 B1
6584454 Hummel et al. Jun 2003 B1
6615347 de Silva et al. Sep 2003 B1
6640305 Kocher et al. Oct 2003 B2
6654888 Cooper et al. Nov 2003 B1
6675208 Rai et al. Jan 2004 B1
6697945 Ishiguro et al. Feb 2004 B2
6704885 Salas-Meza et al. Mar 2004 B1
6760324 Scott et al. Jul 2004 B1
6765492 Harris Jul 2004 B2
6769063 Kanda et al. Jul 2004 B1
6772133 Kambayashi et al. Aug 2004 B1
6775782 Buros et al. Aug 2004 B1
6778820 Tendler Aug 2004 B2
6785726 Freeman et al. Aug 2004 B1
6795941 Nickels Sep 2004 B2
6816842 Singh et al. Nov 2004 B1
6826606 Freeman et al. Nov 2004 B2
6842896 Redding et al. Jan 2005 B1
6850958 Wakabayashi Feb 2005 B2
6854010 Christian et al. Feb 2005 B1
6868403 Wiser et al. Mar 2005 B1
6876984 Tadayon et al. Apr 2005 B2
6883095 Sandu et al. Apr 2005 B2
6889212 Wang et al. May 2005 B1
6901386 Dedrick et al. May 2005 B1
6904523 Bialick et al. Jun 2005 B2
6920567 Doherty et al. Jul 2005 B1
6928166 Yoshizawa Aug 2005 B2
6928558 Allahwerdi et al. Aug 2005 B1
6934463 Ishiguro et al. Aug 2005 B2
6934848 King et al. Aug 2005 B1
6941283 Kambayashi et al. Sep 2005 B2
6957344 Goldshlag et al. Oct 2005 B1
6959291 Armstrong et al. Oct 2005 B1
6961858 Fransdonk Nov 2005 B2
6968384 Redding et al. Nov 2005 B1
6973444 Blinn et al. Dec 2005 B1
6976164 King et al. Dec 2005 B1
6981222 Rush et al. Dec 2005 B2
7032113 Pendlebury Apr 2006 B2
7035918 Redding et al. Apr 2006 B1
7065214 Ishiguro et al. Jun 2006 B2
7069468 Olson et al. Jun 2006 B1
7073063 Peinado Jul 2006 B2
7085382 Terao et al. Aug 2006 B2
7096469 Kubala et al. Aug 2006 B1
7100044 Watanabe et al. Aug 2006 B2
7124304 Bel et al. Oct 2006 B2
7146340 Musson Dec 2006 B1
7149806 Perkins et al. Dec 2006 B2
7152245 Dublish et al. Dec 2006 B2
7171662 Misra et al. Jan 2007 B1
7185195 Hug et al. Feb 2007 B2
7206936 Aull et al. Apr 2007 B2
7225333 Peinado et al. May 2007 B2
7228426 Sinha et al. Jun 2007 B2
7302703 Burns Nov 2007 B2
7308717 Koved et al. Dec 2007 B2
7313828 Holopainen Dec 2007 B2
7318236 DeMello et al. Jan 2008 B2
7336791 Ishiguro Feb 2008 B2
7356692 Bialick et al. Apr 2008 B2
7382881 Uusitalo et al. Jun 2008 B2
7383205 Peinado et al. Jun 2008 B1
7415729 Ukeda et al. Aug 2008 B2
7545931 Dillaway Jun 2009 B2
7552166 Chack Jun 2009 B2
7565325 Lenard et al. Jul 2009 B2
7716348 Redding et al. May 2010 B1
20010001268 Menon et al. May 2001 A1
20010013024 Takahashi Aug 2001 A1
20010034846 Beery Oct 2001 A1
20020001302 Pickett Jan 2002 A1
20020010681 Hillegass et al. Jan 2002 A1
20020013722 Kanaga Jan 2002 A1
20020017977 Wall Feb 2002 A1
20020038422 Suwamoto et al. Mar 2002 A1
20020052939 Lee May 2002 A1
20020083003 Halliday et al. Jun 2002 A1
20020087892 Imazu Jul 2002 A1
20020104006 Boate et al. Aug 2002 A1
20020107809 Biddle et al. Aug 2002 A1
20020112186 Ford et al. Aug 2002 A1
20020116340 Hellberg et al. Aug 2002 A1
20020125886 Bates et al. Sep 2002 A1
20020138441 Lopatic Sep 2002 A1
20020154777 Candelore Oct 2002 A1
20020164025 Raiz et al. Nov 2002 A1
20020169625 Yang et al. Nov 2002 A1
20020169725 Eng Nov 2002 A1
20020174356 Padole et al. Nov 2002 A1
20020176404 Girard Nov 2002 A1
20020188656 Patton et al. Dec 2002 A1
20020188704 Gold Dec 2002 A1
20020194473 Pope et al. Dec 2002 A1
20030005427 Herrero Jan 2003 A1
20030013411 Uchiyama Jan 2003 A1
20030018491 Nakahara et al. Jan 2003 A1
20030018582 Yaacovi Jan 2003 A1
20030023564 Padhye et al. Jan 2003 A1
20030055749 Carmody et al. Mar 2003 A1
20030084306 Abburi et al. May 2003 A1
20030095542 Chang et al. May 2003 A1
20030144959 Makita Jul 2003 A1
20030149670 Cronce Aug 2003 A1
20030149874 Balfanz et al. Aug 2003 A1
20030156719 Cronce Aug 2003 A1
20030159033 Ishiguro Aug 2003 A1
20030159070 Mayer et al. Aug 2003 A1
20030163428 Schneck et al. Aug 2003 A1
20030172035 Cronce et al. Sep 2003 A1
20030177393 Ishiguro Sep 2003 A1
20030191936 Kawatsura et al. Oct 2003 A1
20030208449 Diao Nov 2003 A1
20030233547 Gaston et al. Dec 2003 A1
20040003269 Waxman et al. Jan 2004 A1
20040010440 Lenard et al. Jan 2004 A1
20040010469 Lenard et al. Jan 2004 A1
20040039916 Aldis et al. Feb 2004 A1
20040047354 Slater et al. Mar 2004 A1
20040073517 Zunke et al. Apr 2004 A1
20040078339 Goringe et al. Apr 2004 A1
20040088541 Messerges et al. May 2004 A1
20040103011 Hatano et al. May 2004 A1
20040103324 Band May 2004 A1
20040127196 Dabbish et al. Jul 2004 A1
20040128395 Miyazaki Jul 2004 A1
20040128551 Walker et al. Jul 2004 A1
20040133794 Kocher et al. Jul 2004 A1
20040162998 Tuomi et al. Aug 2004 A1
20040166878 Erskine et al. Aug 2004 A1
20040172367 Chavez Sep 2004 A1
20040181695 Walker Sep 2004 A1
20040181696 Walker Sep 2004 A1
20040199760 Mazza Oct 2004 A1
20040249763 Vardi Dec 2004 A1
20040260589 Varadarajan et al. Dec 2004 A1
20040268120 Mirtal et al. Dec 2004 A1
20050005098 Michaelis et al. Jan 2005 A1
20050038753 Yen et al. Feb 2005 A1
20050076204 Thornton et al. Apr 2005 A1
20050086174 Eng Apr 2005 A1
20050091507 Lee et al. Apr 2005 A1
20050144437 Ransom et al. Jun 2005 A1
20050154877 Trench Jul 2005 A1
20050185792 Tokutani et al. Aug 2005 A1
20050198510 Robert et al. Sep 2005 A1
20050202830 Sudit Sep 2005 A1
20050229004 Callaghan Oct 2005 A1
20050246098 Bergstrom et al. Nov 2005 A1
20050289072 Sabharwal Dec 2005 A1
20060021068 Xu et al. Jan 2006 A1
20060026105 Endoh Feb 2006 A1
20060036554 Schrock et al. Feb 2006 A1
20060036894 Bauer et al. Feb 2006 A1
20060064582 Teal et al. Mar 2006 A1
20060089912 Spagna et al. Apr 2006 A1
20060178953 Aggarwal et al. Aug 2006 A1
20060190409 Hillegass et al. Aug 2006 A1
20060242083 Chavez Oct 2006 A1
20060294010 Kim et al. Dec 2006 A1
20070033419 Kocher et al. Feb 2007 A1
20070094710 Walker et al. Apr 2007 A1
20070107067 Fountian May 2007 A1
20070219917 Liu et al. Sep 2007 A1
20080052295 Walker et al. Feb 2008 A1
20080082449 Wilkinson et al. Apr 2008 A1
20080141242 Shapiro Jun 2008 A1
20080189131 Chavez Aug 2008 A1
Foreign Referenced Citations (3)
Number Date Country
1 071 253 Jan 2001 EP
1562378 Aug 2005 EP
2006085481 Mar 2006 JP
Related Publications (1)
Number Date Country
20040128551 A1 Jul 2004 US
Provisional Applications (1)
Number Date Country
60436874 Dec 2002 US