This invention relates generally to the authentication field, and more specifically to a new and useful system and method for an integrity focused authentication service in the authentication field.
Authentication services can be used by service providers to facilitate authenticating and authorizing users within the service provider. The service provider can delegate at least a portion of authentication to the authentication service. The authentication service then will return some response indicating if the authentication/authorization process of the authentication service was successful. The service provider, trusting that response, can take an appropriate action. However, if the authentication service is compromised or not a trustful entity, the response may be falsified, potentially confirming or denying auth requests. Thus, there is a need in the authentication field to create a new and useful system and method for an integrity focused authentication service. This invention provides such a new and useful system and method.
The following description of the preferred embodiments of the invention is not intended to limit the invention to these preferred embodiments, but rather to enable any person skilled in the art to make and use this invention.
The system and method function to provide a convenient mechanism for authentication/authorization to a service provider while preserving security considerations such as integrity, confidentiality, and optionally availability. The system and method of a preferred embodiment are implemented in combination with at least one service provider and at least one client device. The system and method can function to maintain and operate the mechanics and business logic of providing an authentication service. The system and method are preferably used to provide a two-factor authentication service, which can rely on a user device, a physical token, one-time password coordination, biometric based secondary authentication, and/or any suitable form of authentication. The system and method can similarly be applied to any suitable form of multi-factor authentication. The service provider delegates or offloads the task of developing, managing, and executing a substantial portion of multi-factor authentication to that of the system.
The system and method facilitate synchronization between a service provider and client devices to reduce or eliminate the possibilities of the state of an authentication service compromising the security state of the service provider. With regard to integrity, the client device service provider synchronization can enable a service provider capability to verify the response of a client device without relying on trust of the authentication service—the authentication service (if corrupted or malicious) would be prevented from issuing wrong or faked responses to an auth requests. With regard to confidentiality, requests and sensitive data can be secured as the data is passed through the authentication service—the authentication service can continue to provide additional layers of security agnostic to underlying data. With regard to availability, the system and method may optionally be implemented on-premise or otherwise outside a dedicated remote service—the uptime of a multitenant authentication service would not determine the uptime of authentication operations of the service provider. The system and method accordingly can preferably facilitate easier authentication and security added features while not forcing service providers to place continued trust in the authentication service. The service provider can use the authentication service in substantially a trust-on-first-use mode of operation with a facilitated one-time binding/synchronization between a user device and the service provider.
As shown in
The authentication service may alternatively be implemented as a dedicated on-premise system, which can function to decouple a service provider from dependence on availability of a remote authentication service. The on-premise authentication service can be substantially similar to the remote multitenant authentication server including device messaging engine and an account system to manage mapping of an authentication device to a user identifier.
The authentication service can additionally include additional layers of security that automatically supply security signals around the authentication request and responses passed through the authentication service. The additional layers of security are preferably not used to positively indicate success of authentication but can be used in preventing authentication if any malicious activity is detected. One exemplary layer of security includes service provider anomaly detection and authentication device anomaly detection. The anomaly detection layer can identify unexpected patterns in where, how, and what is communicated through the authentication service. For example, if the device and location information of a device authentication application suddenly deviants from normal behavior, the authentication service can prevent authentication for a particular request. Another security layer variation can include a device compliance layer that can function to enforce policy according to the conditions of the authentication device. The policy compliance can be based on a vulnerability assessment used in determining the health and security level of the device. For example, the vulnerability can be used to detect if the authentication device has a known security vulnerability or exploit.
The system can additionally include a device authentication application (e.g., the device authentication application 150 of
As an additional or alternative variation, a device authentication application SDK can be included such that routines and services provided by a dedicated device authentication application can be added to third party application instances. In yet another variation, the device authentication application could be an operating system based service that is included within the device and does not require explicit download of an application by a user.
The involved service providers can be any suitable computing system, platform, device, or computing infrastructure. A service provider will preferably have an internal or primary mode of authentication such as a username and password system. The service provider can use a set of APIs and SDKs provided by the system to integrate a second layer of authentication. The service provider will additionally preferably manage a synchronized token for the set of users with the second layer of authentication enabled. The synchronized token is preferably a public key of an asymmetric key pair (wherein a device authentication application instance of the user stores the corresponding private key). The synchronized token can be used in encrypting sensitive data in an authentication request and in decrypting and verifying the authentication response. After decrypting an authentication response, the service provider can determine the success or failure of the secondary layer of authentication without depending on trusting the authentication service.
As shown in
The method is preferably executed by one of the system variations described above, but may alternatively be implemented by any suitable entity. The method is preferably performed within an authentication flow involving operation blocks performed at an authentication device and at a service provider. As shown in
Block S110, which includes synchronizing keys between a service provider and at least one authentication device, functions to establish mechanism of trust between an authentication device of a user and a service provider. Each user of a service provider preferably has an associated synchronized token pairs (at least of the users that use the authentication layer provided by the authentication service). The synchronized tokens are preferably an asymmetrical key pair. The private key is preferably stored at the authentication device, and the public key is preferably stored in an account database of the service provider, where the account database maintains an association between the user and the public key. A service provider will preferably initially configure a managing account within the authentication service, with which the service provider can make API requests to the authentication service. Once, communication channels are configured between the authentication device, the authentication service, and the service provider, the authentication service can generate a set of tokens and deliver the tokens or keys to the authentication device and the service provider. In an alternative implementation, the service provider may generate and distribute the tokens. In yet another variation, a first asymmetric key pair is generated on the authentication device and the public key is passed through the authentication service to the service provider. Additionally, a second asymmetric key pair can be generated on the service provider and the public key is passed through the authentication service to the authentication device so that messages can be encrypted and verified in either direction.
Users can be enrolled into the authentication service in a number of different ways. Enrolling preferably establishes the communication between the authentication service and the authentication device. In a first variation, a user self-enrolls in the authentication service. Self-enrollment can include registering through an account portal of the authentication service. Registering preferably includes creating a user account linked to one or more user identifiers. For example, an email address or username may be used as a user identifier within the authentication service and the service provider. Registering additionally includes providing communication addressing such as a phone number. Enrollment may alternatively be partially or fully facilitated by the service provider by using APIs to coordinate enrollment of an authentication device.
Block S120, which includes receiving the authentication request, functions to obtain a request to authenticate a particular user on behalf of a service provider. The service provider is preferably indicated in an account identifier in the API request. The service provider can submit an authentication request after a primary layer of authentication is completed within the service provider. The service provider may alternatively submit the authentication request as a primary form of authentication. The service provider can alternatively submit the authentication request when performing an action requiring heighted authentication or authorization validation. The authentication request preferably specifies a user identifier. The authentication request can additionally include metadata concerning the authentication request such as time, location, and context relating to the authentication request. As described below, some or part of the data may be encrypted by the service provider with a token synchronized with the authentication device.
Block S130, which includes mapping the authentication request to an authentication device based on the user identifier, functions to select a proper authentication device and/or authentication application instance as the destination for the authentication request. The user identifier can be a username, a password, a code, or any suitable identifier linked to one or more authentication devices. In one variation, the mapping is one to one. In another variation, a user identifier can map to more than one authentication devices and/or authentication application instances. For example, one authentication device can be used as a primary auth endpoint and a second authentication device can be a fallback auth endpoint. In another example, one authentication device can be used as an authentication endpoint and a second authentication device can be an authorization endpoint. Once an authentication device is selected through the mapping, the authentication response is preferably delivered in block S140. Delivering the authentication request can be performed over any suitable protocol or in any suitable medium. Preferably, a push notification is sent to an application instance, which then can optionally decrypt any encrypted data and execute an auth challenge. The authentication request can alternatively be sent in an SMS message, MMS message, email, in-app messaging protocol, or any suitable communication channel.
At the authentication device, the authentication request is received from the authentication service. The contents of the authentication response are preferably used in completing an authentication challenge. An authentication challenge can include presenting information from the request (e.g., when and where the auth request originated), and then obtaining a confirmation result, cancellation result, fraud result, or any suitable form of user classification of the request. User input can alternatively include a pincode, a challenge question response, or any suitable response using knowledge as an identifying factor. An alternative authentication challenge can include collecting a signature from the device such as a biometric signature, a device stored token, a device profile signature, a hardware token, and/or any suitable input to complete an auth challenge.
As one possible variation, the method can enable confidentiality of the data passed within the authentication device. The data of authentication request can be encrypted at the service provider. The public key associated with the user identifier is preferably used to encrypt the metadata or optionally a portion of the metadata as shown in
Block S330, which includes the authentication device encrypting the authentication challenge result in an authentication response and transmitting the authentication response S330, functions to cryptographically sign the results of the authentication challenge to ensure the integrity of the response contents when received at the service provider. The authentication device preferably uses the private key of the authentication device. The authentication response can be transmitted or otherwise communicated to the authentication service through the same communication channel through which the authentication request was received. Alternatively, an alternative mode of communication can be used.
Block S150, which includes receiving the authentication response and transmitting the authentication response to the service provider, functions to reroute or redirect the authentication response to the corresponding service provider. The authentication response preferably includes at least one property that includes the encrypted authentication challenge response. The authentication service is preferably prevented from modifying the challenge response portion of the authentication response to indicate a confirmation. The service provider is able to verify the results as signaled by the authentication challenge without trusting the authentication service.
As mentioned above, the method can include augmenting the authentication response with an additional layer of security as shown in
Blocks S230 and S240, which include decrypting the authentication result with the synchronized token and acting on the result of the authentication response, function to interpret the authentication response at the service provider. The service will preferably use the public key stored in association with the user to verify the authentication response and to determine the results of the authentication challenge. The service provider will preferably allow the action if the authentication challenge property confirms the authentication request and if there are no other flags in the authentication response. In other cases, the authentication challenge property can indicate the request was cancelled (e.g., the user changed his mind) or the request was marked as fraud. If canceled, the service provider can return an error or request cancellation prompt to the user making the request through the service provider. If marked as fraud, the service provider can take any suitable action such as suspending other actions on the account or alerting the user of the fraudulent attempt.
Methods
As shown in
In the example embodiment of
In some implementations, the authentication service 110 is a multi-factor authentication service. In some implementations, the authentication service 110 is a multi-tenant authentication service that is external to the service provider 120. In some implementations, the service provider 120 communicates with the authentication service 110 via a REST API. In some implementations, each authentication device (e.g., the authentication device 140 of
Methods: Managing Key Synchronization Information
Process S510, which includes managing service provider key synchronization information for at least one authentication device that is enrolled at the authentication service for a user identifier of a service provider, functions to control the authentication service 110 to manage service provider key synchronization information for at least one authentication device that is enrolled at the authentication service for a user identifier of a service provider. For each authentication device, the key synchronization information indicates that a private key associated with the user identifier and stored by the authentication device is synchronized with a public key stored at the service provider in association with the user identifier.
In some implementations, the authentication service 110 manages the service provider key synchronization information for each authentication device (e.g., the authentication device 140 of
Methods: Generation of Key Synchronization Information
As shown in
In some implementations, enrollment is initiated (process S610) by the authentication device (e.g., 140). In some implementations, enrollment is initiated (process S610) by the service provider (e.g., 120). In some implementations, enrollment is initiated (process S610) by the primary device (e.g., 130).
In some implementations, the authentication service 110 synchronizes the keys (process S620) (e.g., as shown in
In some implementations, the authentication service 110 generates the key synchronization information (process S630) and stores the generated key synchronization information (process S640).
Methods: Enrollment
In some implementations, enrollment is initiated (process S610 of
A method for enrollment of an authentication device in accordance with an example embodiment is shown in
At process S710, the primary device 130 provides an enrollment request to the service provider 120. The enrollment request provided by the primary device 130 specifies a user identifier of a user account of the service provider. Responsive to the enrollment request at process S710, the service provider 120 provides an enrollment request to the authentication service 110 (process S720). The enrollment request provided by the service provider 120 specifies the user identifier provided by the primary device 130 at the process S710. The enrollment request provided by the service provider 120 also specifies authentication service account information for the service provider 120. In some implementations, the authentication service account information specifies an account identifier of the service provider's authentication account at the authentication service 110.
At the process S730, responsive to the enrollment request at the process S720, the authentication service 110 provides an activation code to the service provider 120. The activation code is associated with the enrollment request, and is used by the authentication device 140 to enroll the authentication device in association with the enrollment request.
At the process S740, the service provider 120 provides the activation code to the primary device 130. In some embodiments, the primary device displays the activation code, and the authentication device 140 obtains the activation code by capturing an image of the activation code by using an image capture device of the authentication device. For example, the primary device can display the activation code as a QR code that is captured by a camera of the authentication device. In some embodiments, the primary device displays the activation code, and the authentication device 140 obtains the activation code by user input received via a user input device of the authentication device. For example, a user of the primary device can view the activation code displayed by the primary device 130 and input the activation code to the authentication device 140 by using a user input device of the authentication device 140.
In some implementations, the service provider 120 provides the activation code to the authentication device 140. For example, the service provider can provide the activation code to the authentication device 140 via a message (e.g., an SMS message, an MMS message, and the like).
At the process S750, the authentication device has received the activation code, and provides an activation request to the authentication service 110. In some implementations, the activation request specifies the activation code and address information of the authentication device 140.
At the process S760, responsive to the activation request of the process S750, the authentication service 110 generates an enrollment record (e.g., an enrollment record of the enrollment records 1134 of
In some implementations, the enrollment request provided by the primary device 130 at the process S710 specifies the address information of the authentication device 140, and the service provider 120 specifies the address information in the enrollment request provided to the authentication service 110 at the process S720.
Methods: Key Synchronization
In some implementations, the private key is synchronized (process S620) during enrollment (process S610 of
In some implementations, the authentication service synchronizes the private key stored by the authentication device with the public key stored at the service provider.
A method for synchronization by the authentication service in accordance with an example embodiment is shown in
As shown in
At process S810, the authentication service 110 generates a key pair that includes the public key and the private key.
At process S820, the authentication service 110 provides the private key to the authentication device 140, and provides the public key to the service provider 120. In some implementations, the authentication service 110 provides the private key in a response to the activation request received from the authentication service 110 at the process S750 of
At process S830, the service provider stores the public key received from the authentication service in association with the user identifier of the enrollment request provided to the authentication service 110 at the process S720 of
At process S830, the authentication device 140 stores the private key received from the authentication service 110. In some implementations, the authentication device stores the private key received from the authentication service in association with the user identifier of the enrollment request provided to the authentication service 110 at the process S720 of
In some implementations, after providing the public key of the generated key pair to the service provider 120 and providing the private key of the generated key pair to the authentication device 140 (process S820), the authentication service 110 generates the key synchronization information (e.g., the process S630 of
In some implementations, the service provider (e.g., 120) synchronizes the private key stored by the authentication device with the public key stored at the service provider.
A method for synchronization by the service provider in accordance with example embodiments is shown in
As shown in
At process S910, the authentication service 110 provides a synchronization request to the service provider 120.
In some implementations, the authentication service 110 provides the synchronization request to the service provider identified by the enrollment record generated at the process S760 of
In some implementations, at the process S910, the authentication service provides the synchronization request to the service provider 120 along with the user identifier corresponding to the enrollment record of the process S760. In some implementations, at the process S910, the authentication service provides the synchronization request to the service provider 120 along with the user identifier corresponding to the activation code of the process S750 of
In some implementations, at the process S910, the authentication service provides the synchronization request to the service provider 120 along with the address information corresponding to the enrollment record of the process S760. In some implementations, at the process S910, the authentication service provides the synchronization request to the service provider 120 along with the address information corresponding to the activation request of the process S750 of
At the process S920, the service provider 120 generates a key pair that includes the public key and the private key, responsive to the synchronization request of the process S910.
At process S930, the service provider 120 stores the public key generated at the process S920 in association with the user identifier of the enrollment request provided to the authentication service 110 at the process S720 of
At the process S940, the service provider 120 provides the private key to the authentication device 140. In some implementations, the service provider 120 provides the private key to the authentication device 140 along with the user identifier used at the process S930.
At process S950, the authentication device 140 stores the private key received from the service provider 120. In some implementations, the authentication device stores the private key received from the service provider 120 in association with the user identifier of the enrollment request provided to the authentication service 110 at the process S720 of
As shown in
As shown in
In some implementations, the authentication device synchronizes the private key stored by the authentication device with the public key stored at the service provider.
A method for synchronization by the authentication device in accordance with example embodiments is shown in
As shown in
At process S1010, the authentication service 110 provides a synchronization request to the authentication device 140.
In some implementations, the authentication service 110 provides the synchronization request to the authentication device 140 as a response to the activation request of the process S750 of
In some implementations, at the process S1010, the authentication service provides the synchronization request to the authentication device 140 along with the user identifier corresponding to the enrollment record of the process S760. In some implementations, at the process S1010, the authentication service provides the synchronization request to the authentication device 140 along with the user identifier corresponding to the activation code of the process S750 of
In some implementations, at the process S1010, the authentication service provides the synchronization request to the authentication device 140 along with address information of the service provider corresponding to the enrollment record of the process S760. In some implementations, at the process S1010, the authentication service provides the synchronization request to the authentication device 140 along with address information of the service provider corresponding to the enrollment request of the process S720 of
At the process S1020, the authentication device 140 generates a key pair that includes the public key and the private key, responsive to the synchronization request of the process S1010.
At process S1030, the authentication device 140 stores the private key generated at the process S1020. In some implementations, the authentication device 140 stores the private key in association with the user identifier of the enrollment request provided to the authentication service 110 at the process S720 of
At the process S1040, the authentication device 140 provides the public key to the service provider 120. In some implementations, the authentication device 140 provides the public key to the service provider 120 along with the user identifier used at the process S1030. In some implementations, the authentication device 140 provides the public key to the service provider 120 along with a user identifier specified in the synchronization request received from the authentication service 110 at the process S1010.
At process S1050, the service provider 120 stores the public key received from authentication device 140. In some implementations, the service provider 120 stores the public key received from the authentication device 140 in association with the user identifier of the enrollment request provided to the authentication service 110 at the process S720 of
As shown in
As shown in
Methods: Providing an Authentication Request to a Synchronized Device
Reverting to
The authentication service 110 determines at least one authentication device (e.g., 140) for the user identifier that stores a private key that is synchronized with the service provider 120 by using the key synchronization information (e.g., the key synchronization generated at the process S630 of
In some embodiments, determining at least one authentication device and providing the authentication request to at least one determined authentication device includes: mapping the authentication request to at least one authentication device identified by the key synchronization information as storing the synchronized private key, and providing the authentication request to the mapped at least one authentication device. In some embodiments, the authentication request is provided by the service provider, and the authentication request is for a request received at the service provider from a primary device associated with the user identifier. In some embodiments, the authentication request specifies the user identifier.
In some implementations, the request received at the service provider from the primary device is at least one of a login request, a financial transaction request, a purchase transaction request, an account management request, and a service provider management request.
In some embodiments, the authentication request includes encrypted data that is encrypted by the service provider 120 by using the public key of the key pair synchronized with the authentication device 140 associated with the user identifier specified in the authentication request (e.g., the public key synchronized at the process S620 of
In some implementations, a plurality of authentication devices (e.g., 140) are enrolled for the user identifier at the authentication service 110, and the authentication service 110 determines one or more authentication devices (e.g., 140) for the user identifier that stores a private key that is synchronized with the service provider 120 by using the key synchronization information (e.g., the key synchronization information generated at the process S630 of
In some implementations, the plurality of authentication devices include at least a primary authentication device and at least one fallback authentication device, and in a case where the authentication service cannot establish communication with the primary authentication device, the authentication service 110 provides the authentication request to the fallback authentication device.
In some implementations, the authentication service 110 provides the authentication request to one or more of a plurality of authentication devices enrolled for the user identifier based on at least one of a user identifier profile at the authentication service 110 and a service provider profile 120 at the authentication service. In some implementations, the authentication service 110 provides the authentication request to one or more of a plurality of authentication devices enrolled for the user identifier based on priority values for each authentication device as indicated by at least one of a user identifier profile at the authentication service 110 and a service provider profile 120 at the authentication service.
Methods: Authentication Response
In some embodiments, the process S530 of
In some embodiments, providing an authentication response signed by the at least one determined authentication device to the service provider includes: receiving a signed authentication response from the authentication device (e.g., 140), the signed authentication response being signed with the private key by the authentication device; and providing the signed authentication response to the service provider.
The service provider 120 verifies the signed authentication response by using the synchronized public key (e.g., the public key synchronized at the process S620 of
In some embodiments, the authentication response received by the authentication service from the authentication device includes encrypted data that is encrypted by the authentication device (e.g., 140) by using a public key received during enrollment of the authentication device at the authentication service 110 for the user identifier of the service provider. In some implementations, the public key used to encrypt data at the authentication device is a public key of the service provider 120; the authentication service 110 provides the public key and information identifying the corresponding service provider 120 to the authentication device during enrollment of the authentication device for a user identifier of the service provider 120; the authentication device stores the public key of the service provider 120 in association with information identifying the service provider 120; the authentication request identifies the service provider 120 based on information of the authentication request; and the authentication device encrypts the authentication response by using the public key corresponding to the service provider 120 identified by the authentication request.
In some implementations, the service provider 120 decrypts the encrypted authentication response by using a private key that corresponds to the public key used by the authentication device to encrypt the authentication response. In some implementations, the public key is a public key of the service provider 120 that is stored by the service provider 120.
In some embodiments, providing an authentication response signed by the at least one determined authentication device to the service provider includes: at the authentication service 110, performing a security analysis of the signed authentication response, and providing security information resulting from the security analysis to the service provider. In some implementations, the service provider uses the security information to verify the signed authentication response. In some implementations, the security information indicates at least one of: abnormal behavior patterns detected during the security analysis; fraudulent behavior patterns detected during the security analysis; and at least one security vulnerability assessment of the at least one determined authentication device.
In some implementations, the signed authentication response indicates at least one of a confirmation result, a cancellation result and a fraud result.
In some implementations, the authentication service 110 provides the signed authentication response to the service provider 120 in a response to the authentication request received from the service provider (e.g., at the process S520).
In some implementations, the authentication service 110 provides the signed authentication response to the service provider in a response to an authentication status request received from the service provider 120.
System Architecture: Authentication Service
The bus 1101 interfaces with the processors 1101A-1101N, the main memory (e.g., a random access memory (RAM)) 1122, a read only memory (ROM) 1104, a processor-readable storage medium 1105, a display device 1107, a user input device 1108, and a network device 1111.
The processors 1110A-1101N may take many forms, such as ARM processors, X86 processors, and the like.
In some implementations, the system of the authentication service 110 includes at least one of a central processing unit (processor) and a multi-processor unit (MPU).
The processors 1101A-1101N and the main memory 1122 form a processing unit 1199. In some embodiments, the processing unit includes one or more processors communicatively coupled to one or more of a RAM, ROM, and machine-readable storage medium; the one or more processors of the processing unit receive instructions stored by the one or more of a RAM, ROM, and machine-readable storage medium via a bus; and the one or more processors execute the received instructions. In some embodiments, the processing unit is an ASIC (Application-Specific Integrated Circuit). In some embodiments, the processing unit is a SoC (System-on-Chip). In some embodiments, the processing unit includes one or more of a key synchronization module 1131, an authentication module 1132, and an enrollment module 1133.
The network adapter device 1111 provides one or more wired or wireless interfaces for exchanging data and commands between the system of the authentication service 110 and other devices, such as the authentication device 140 and devices and servers of service providers, e.g., the service provider 120. Such wired and wireless interfaces include, for example, a universal serial bus (USB) interface, Bluetooth interface, Wi-Fi interface, Ethernet interface, near field communication (NFC) interface, and the like.
Machine-executable instructions in software programs (such as an operating system, application programs, and device drivers) are loaded into the memory 1122 (of the processing unit 1199) from the processor-readable storage medium 1105, the ROM 1104 or any other storage location. During execution of these software programs, the respective machine-executable instructions are accessed by at least one of processors 1101A-1101N (of the processing unit 1199) via the bus 1101, and then executed by at least one of processors 1101A-1101N. Data used by the software programs are also stored in the memory 1122, and such data is accessed by at least one of processors 1101A-1101N during execution of the machine-executable instructions of the software programs. The processor-readable storage medium 1105 is one of (or a combination of two or more of) a hard drive, a flash drive, a DVD, a CD, an optical disk, a floppy disk, a flash storage, a solid state drive, a ROM, an EEPROM, an electronic circuit, a semiconductor memory device, and the like. The processor-readable storage medium 1105 includes an operating system 1112, software programs 1113, device drivers 1114, the key synchronization module 1131, the authentication module 1132, the enrollment module 1133, enrollment records 1134, and key synchronization information 1135.
In some implementations, the key synchronization module 1131 includes machine-executable instructions that when executed by the processing unit 1199 perform the processes S810, S820 and S630 of
System Architecture: Authentication Device
The bus 1201 interfaces with the processors 1201A-1201N, the main memory (e.g., a random access memory (RAM)) 1222, a read only memory (ROM) 1204, a processor-readable storage medium 1205, a display device 1207, a user input device 1208, and a network device 1211.
The processors 1201A-1201N may take many forms, such as ARM processors, X86 processors, and the like.
In some implementations, the authentication device 140 includes at least one of a central processing unit (processor) and a multi-processor unit (MPU).
The processors 1201A-1201N and the main memory 1222 form a processing unit 1299. In some embodiments, the processing unit includes one or more processors communicatively coupled to one or more of a RAM, ROM, and machine-readable storage medium; the one or more processors of the processing unit receive instructions stored by the one or more of a RAM, ROM, and machine-readable storage medium via a bus; and the one or more processors execute the received instructions. In some embodiments, the processing unit is an ASIC (Application-Specific Integrated Circuit). In some embodiments, the processing unit is a SoC (System-on-Chip). In some embodiments, the processing unit includes the device authentication application 150.
The network adapter device 1211 provides one or more wired or wireless interfaces for exchanging data and commands between the authentication device 140 and other devices, such as a server of the authentication service 110 and devices and servers of service providers, e.g., the service provider 120. Such wired and wireless interfaces include, for example, a universal serial bus (USB) interface, Bluetooth interface, Wi-Fi interface, Ethernet interface, near field communication (NFC) interface, and the like.
Machine-executable instructions in software programs (such as an operating system, application programs, and device drivers) are loaded into the memory 1222 (of the processing unit 1299) from the processor-readable storage medium 1205, the ROM 1204 or any other storage location. During execution of these software programs, the respective machine-executable instructions are accessed by at least one of processors 1201A-1201N (of the processing unit 1299) via the bus 1201, and then executed by at least one of processors 1201A-1201N. Data used by the software programs are also stored in the memory 1222, and such data is accessed by at least one of processors 1201A-1201N during execution of the machine-executable instructions of the software programs. The processor-readable storage medium 1205 is one of (or a combination of two or more of) a hard drive, a flash drive, a DVD, a CD, an optical disk, a floppy disk, a flash storage, a solid state drive, a ROM, an EEPROM, an electronic circuit, a semiconductor memory device, and the like. The processor-readable storage medium 1205 includes an operating system 1212, software programs 1213, device drivers 1214, the authentication application 150, and synchronized private keys 1231.
In some implementations, the authentication application 150 includes machine-executable instructions that when executed by the processing unit 1299 perform the process S610 of
In some implementations, the authentication application 150 includes machine-executable instructions that when executed by the processing unit 1299 cause the authentication device 140 to provide the signed authentication response of the process S530 of
System Architecture of a Service Provider
The bus 1301 interfaces with the processors 1301A-1301N, the main memory (e.g., a random access memory (RAM)) 1322, a read only memory (ROM) 1304, a processor-readable storage medium 1305, a display device 1307, a user input device 1308, and a network device 1311.
The processors 1301A-1301N may take many forms, such as ARM processors, X86 processors, and the like.
In some implementations, the service provider 120 includes at least one of a central processing unit (processor) and a multi-processor unit (MPU).
The processors 1301A-1301N and the main memory 1322 form a processing unit 1399. In some embodiments, the processing unit includes one or more processors communicatively coupled to one or more of a RAM, ROM, and machine-readable storage medium; the one or more processors of the processing unit receive instructions stored by the one or more of a RAM, ROM, and machine-readable storage medium via a bus; and the one or more processors execute the received instructions. In some embodiments, the processing unit is an ASIC (Application-Specific Integrated Circuit). In some embodiments, the processing unit is a SoC (System-on-Chip). In some embodiments, the processing unit includes one or more of an authentication module 1333 and an enrollment module 1332.
The network adapter device 1311 provides one or more wired or wireless interfaces for exchanging data and commands between the server of the service provider 120 and other devices, such as a server of the authentication service 110 and the authentication device 140. Such wired and wireless interfaces include, for example, a universal serial bus (USB) interface, Bluetooth interface, Wi-Fi interface, Ethernet interface, near field communication (NFC) interface, and the like.
Machine-executable instructions in software programs (such as an operating system, application programs, and device drivers) are loaded into the memory 1322 (of the processing unit 1399) from the processor-readable storage medium 1305, the ROM 1304 or any other storage location. During execution of these software programs, the respective machine-executable instructions are accessed by at least one of processors 1301A-1301N (of the processing unit 1399) via the bus 1301, and then executed by at least one of processors 1301A-1301N. Data used by the software programs are also stored in the memory 1322, and such data is accessed by at least one of processors 1301A-1301N during execution of the machine-executable instructions of the software programs. The processor-readable storage medium 1305 is one of (or a combination of two or more of) a hard drive, a flash drive, a DVD, a CD, an optical disk, a floppy disk, a flash storage, a solid state drive, a ROM, an EEPROM, an electronic circuit, a semiconductor memory device, and the like. The processor-readable storage medium 1305 includes an operating system 1312, software programs 1313, device drivers 1314, the authentication module 1333, the enrollment module 1332 and synchronized public keys 1331.
In some implementations, the enrollment module 1332 includes machine-executable instructions that when executed by the processing unit 1399 perform the process S610 of
In some implementations, the authentication module 1333 includes machine-executable instructions that when executed by the processing unit 1399 control the service provider 120 to provide the authentication request of the process S520 of
In some implementations, the synchronized public keys 1331 includes the public key generated at the processes S810 of
Machines
Systems and methods of the preferred embodiment and variations thereof can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions. The instructions are preferably executed by computer-executable components preferably integrated with the authentication service. The computer-readable medium can be stored on any suitable computer-readable media such as RAMs, ROMs, flash memory, EEPROMs, optical devices (CD or DVD), hard drives, floppy drives, or any suitable device. The computer-executable component is preferably a general or application specific processor, but any suitable dedicated hardware or hardware/firmware combination device can alternatively or additionally execute the instructions.
As a person skilled in the art will recognize from the previous detailed description and from the figures and claims, modifications and changes can be made to the preferred embodiments of the invention without departing from the scope of this invention defined in the following claims.
This application claims the benefit of U.S. patent application Ser. No. 14/688,893, filed 16 Apr. 2015, which claims the benefit of U.S. Provisional Application Ser. No. 61/980,762, filed on 17 Apr. 2014, which is incorporated in its entirety by this reference.
Number | Name | Date | Kind |
---|---|---|---|
5838792 | Ganesan | Nov 1998 | A |
5870723 | Pare, Jr. et al. | Feb 1999 | A |
6119096 | Mann et al. | Sep 2000 | A |
6209091 | Sudia et al. | Mar 2001 | B1 |
6311272 | Gressel | Oct 2001 | B1 |
6694025 | Epstein et al. | Feb 2004 | B1 |
6758394 | Maskatiya et al. | Jul 2004 | B2 |
6823359 | Heidingsfeld et al. | Nov 2004 | B1 |
6934858 | Woodhill | Aug 2005 | B2 |
6956950 | Kausik | Oct 2005 | B2 |
6996716 | Hsu | Feb 2006 | B1 |
7000247 | Banzhof | Feb 2006 | B2 |
7093133 | Hopkins et al. | Aug 2006 | B2 |
7096354 | Wheeler et al. | Aug 2006 | B2 |
7107246 | Wang | Sep 2006 | B2 |
7146009 | Andivahis et al. | Dec 2006 | B2 |
7172115 | Lauden | Feb 2007 | B2 |
7331518 | Rable | Feb 2008 | B2 |
7334255 | Lin et al. | Feb 2008 | B2 |
7340600 | Corella | Mar 2008 | B1 |
7349929 | Pfitzner | Mar 2008 | B2 |
571282 | Takehiko et al. | Jun 2008 | A1 |
7386720 | Sandhu et al. | Jun 2008 | B2 |
7447784 | Eun | Nov 2008 | B2 |
7463637 | Bou-Diab et al. | Dec 2008 | B2 |
7496662 | Roesch et al. | Feb 2009 | B1 |
7526792 | Ross | Apr 2009 | B2 |
7562382 | Hinton et al. | Jul 2009 | B2 |
7562385 | Thione et al. | Jul 2009 | B2 |
7571471 | Sandhu et al. | Aug 2009 | B2 |
7574733 | Woodhill | Aug 2009 | B2 |
7599493 | Sandhu et al. | Oct 2009 | B2 |
7630493 | Sandhu et al. | Dec 2009 | B2 |
7711122 | Allen et al. | May 2010 | B2 |
7716240 | Lim | May 2010 | B2 |
7764970 | Neil et al. | Jul 2010 | B2 |
7793110 | Durfee et al. | Sep 2010 | B2 |
7836501 | Sobel et al. | Nov 2010 | B2 |
7953979 | Borneman et al. | May 2011 | B2 |
7958362 | Hwang | Jun 2011 | B2 |
7961645 | Gudipudi et al. | Jun 2011 | B2 |
7982595 | Hanna et al. | Jul 2011 | B2 |
7983987 | Kranzley et al. | Jul 2011 | B2 |
8010779 | Sermersheim et al. | Aug 2011 | B2 |
8028325 | Cahill | Sep 2011 | B2 |
8028329 | Whitcomb | Sep 2011 | B2 |
8099368 | Coulter et al. | Jan 2012 | B2 |
8136148 | Chayanam et al. | Mar 2012 | B1 |
8141146 | Ozeki | Mar 2012 | B2 |
8151333 | Zhu et al. | Apr 2012 | B2 |
8161527 | Curren | Apr 2012 | B2 |
8185744 | Brown et al. | May 2012 | B2 |
8200980 | Robinson et al. | Jun 2012 | B1 |
8225392 | Dubrovsky et al. | Jul 2012 | B2 |
8245044 | Kang | Aug 2012 | B2 |
8259947 | Rose et al. | Sep 2012 | B2 |
8275672 | Nguyen | Sep 2012 | B1 |
8296562 | Williams et al. | Oct 2012 | B2 |
8332627 | Matthews et al. | Dec 2012 | B1 |
8335933 | Humphrey et al. | Dec 2012 | B2 |
8340287 | Sandhu et al. | Dec 2012 | B2 |
8340635 | Herz et al. | Dec 2012 | B2 |
8380192 | Kim et al. | Feb 2013 | B2 |
8381297 | Touboul | Feb 2013 | B2 |
8397301 | Hering et al. | Mar 2013 | B2 |
8402526 | Ahn | Mar 2013 | B2 |
8418168 | Tyhurst et al. | Apr 2013 | B2 |
8458798 | Williams et al. | Jun 2013 | B2 |
8468609 | Leggette | Jun 2013 | B2 |
8484708 | Chern | Jul 2013 | B2 |
8495720 | Counterman | Jul 2013 | B2 |
8499149 | Chen | Jul 2013 | B2 |
8499339 | Chao et al. | Jul 2013 | B2 |
8510820 | Oberheide et al. | Aug 2013 | B2 |
8522010 | Ozzie et al. | Aug 2013 | B2 |
8528039 | Chakarapani | Sep 2013 | B2 |
8538028 | Yeap et al. | Sep 2013 | B2 |
8539544 | Garimella et al. | Sep 2013 | B2 |
8539567 | Logue et al. | Sep 2013 | B1 |
8548426 | Smith | Oct 2013 | B2 |
8549601 | Ganesan | Oct 2013 | B2 |
8571220 | Ollikainen et al. | Oct 2013 | B2 |
8578162 | Jentzsch et al. | Nov 2013 | B2 |
8595809 | Chayanam et al. | Nov 2013 | B2 |
8595822 | Schrecker et al. | Nov 2013 | B2 |
8601554 | Gordon et al. | Dec 2013 | B2 |
8612305 | Dominguez et al. | Dec 2013 | B2 |
8627438 | Bhimanaik | Jan 2014 | B1 |
8646060 | Ayed | Feb 2014 | B1 |
8646086 | Chakra et al. | Feb 2014 | B2 |
8667288 | Yavuz | Mar 2014 | B2 |
8689287 | Bohmer et al. | Apr 2014 | B2 |
8700729 | Dua | Apr 2014 | B2 |
8713329 | Schneider | Apr 2014 | B2 |
8713639 | Cheeniyil et al. | Apr 2014 | B2 |
8719930 | Lapsley et al. | May 2014 | B2 |
8732475 | Fahrny et al. | May 2014 | B2 |
8732839 | Hohl | May 2014 | B2 |
8737623 | Hart | May 2014 | B2 |
8745703 | Lambert et al. | Jun 2014 | B2 |
8751801 | Harris et al. | Jun 2014 | B2 |
8756567 | Jentsch et al. | Jun 2014 | B2 |
8756651 | Baer et al. | Jun 2014 | B2 |
8756698 | Sidagni | Jun 2014 | B2 |
8763077 | Oberheide et al. | Jun 2014 | B2 |
8806609 | Gladstone et al. | Aug 2014 | B2 |
8850516 | Hrebicek et al. | Sep 2014 | B1 |
8862097 | Brand et al. | Oct 2014 | B2 |
8891772 | D Souza et al. | Nov 2014 | B2 |
8893230 | Oberheide et al. | Nov 2014 | B2 |
8898762 | Kang | Nov 2014 | B2 |
8949596 | Yin et al. | Feb 2015 | B2 |
8949927 | Arnott et al. | Feb 2015 | B2 |
8966587 | Nair et al. | Feb 2015 | B2 |
8984276 | Benson et al. | Mar 2015 | B2 |
9037127 | Raleigh | May 2015 | B2 |
9049011 | Agrawal | Jun 2015 | B1 |
9049594 | Chen et al. | Jun 2015 | B2 |
9071611 | Yadav et al. | Jun 2015 | B2 |
9076343 | Chaar et al. | Jul 2015 | B2 |
9110754 | Poonamalli et al. | Aug 2015 | B2 |
9118656 | Ting et al. | Aug 2015 | B2 |
9122888 | Devi | Sep 2015 | B2 |
9124582 | Kalinichenko et al. | Sep 2015 | B2 |
9135458 | Hankins, Jr. et al. | Sep 2015 | B1 |
9154387 | Maki et al. | Oct 2015 | B2 |
9189491 | Fushman et al. | Nov 2015 | B2 |
9201644 | Klein et al. | Dec 2015 | B2 |
9203841 | Neuman et al. | Dec 2015 | B2 |
9223961 | Sokolov | Dec 2015 | B1 |
9225840 | Malatack et al. | Dec 2015 | B2 |
9253185 | Alaranta et al. | Feb 2016 | B2 |
9258296 | Juthani | Feb 2016 | B2 |
9270663 | Kravitz et al. | Feb 2016 | B2 |
9282085 | Oberheide et al. | Mar 2016 | B2 |
9338156 | Oberheide et al. | May 2016 | B2 |
9338163 | Wendling et al. | May 2016 | B2 |
9386003 | Kumar | Jul 2016 | B2 |
9391980 | Krahn et al. | Jul 2016 | B1 |
9418213 | Roth | Aug 2016 | B1 |
9430938 | Proud | Aug 2016 | B2 |
9443084 | Nice et al. | Sep 2016 | B2 |
9479509 | Zeuthen | Oct 2016 | B2 |
9659160 | Ligatti et al. | May 2017 | B2 |
9668137 | Sigurdson et al. | May 2017 | B2 |
9706410 | Sreenivas et al. | Jul 2017 | B2 |
20020013898 | Sudia et al. | Jan 2002 | A1 |
20020091745 | Ramamurthy | Jul 2002 | A1 |
20020136410 | Hanna | Sep 2002 | A1 |
20030061506 | Cooper | Mar 2003 | A1 |
20030115452 | Sandhu et al. | Jun 2003 | A1 |
20030149781 | Yared | Aug 2003 | A1 |
20040139318 | Fiala | Jul 2004 | A1 |
20050097350 | Patrick | May 2005 | A1 |
20050097352 | Patrick | May 2005 | A1 |
20060021018 | Hinton | Jan 2006 | A1 |
20060031938 | Choi | Feb 2006 | A1 |
20060059569 | Dasgupta et al. | Mar 2006 | A1 |
20060075475 | Boulos | Apr 2006 | A1 |
20060129817 | Borneman | Jun 2006 | A1 |
20070027961 | Holzer | Feb 2007 | A1 |
20070101145 | Sachdeva | May 2007 | A1 |
20070143860 | Hardt | Jun 2007 | A1 |
20070204016 | Kunz | Aug 2007 | A1 |
20070250914 | Fazal et al. | Oct 2007 | A1 |
20070254631 | Spooner | Nov 2007 | A1 |
20070284429 | Beeman | Dec 2007 | A1 |
20070297607 | Ogura et al. | Dec 2007 | A1 |
20080010665 | Hinton | Jan 2008 | A1 |
20080028225 | Eckert | Jan 2008 | A1 |
20080059804 | Shah | Mar 2008 | A1 |
20080120411 | Eberle | May 2008 | A1 |
20080134311 | Medvinsky | Jun 2008 | A1 |
20080201186 | Poon | Aug 2008 | A1 |
20080229104 | Ju et al. | Sep 2008 | A1 |
20090055906 | Von Wendorff | Feb 2009 | A1 |
20090083225 | Jacobs | Mar 2009 | A1 |
20090198997 | Yeap | Aug 2009 | A1 |
20090254978 | Rouskov | Oct 2009 | A1 |
20090271863 | Govindavajhala et al. | Oct 2009 | A1 |
20090328178 | McDaniel | Dec 2009 | A1 |
20100023781 | Nakamoto | Jan 2010 | A1 |
20100036931 | Certain | Feb 2010 | A1 |
20100042954 | Rosenblatt et al. | Feb 2010 | A1 |
20100100924 | Hinton | Apr 2010 | A1 |
20100107225 | Spencer | Apr 2010 | A1 |
20100131755 | Zhu | May 2010 | A1 |
20100180001 | Hardt | Jul 2010 | A1 |
20100186082 | Ladki | Jul 2010 | A1 |
20100274859 | Bucuk | Oct 2010 | A1 |
20100319068 | Abbadessa | Dec 2010 | A1 |
20110026716 | Tang et al. | Feb 2011 | A1 |
20110138469 | Ye et al. | Jun 2011 | A1 |
20110179472 | Ganesan | Jul 2011 | A1 |
20110197267 | Gravel et al. | Aug 2011 | A1 |
20110219449 | St Neitzel et al. | Sep 2011 | A1 |
20110225637 | Counterman | Sep 2011 | A1 |
20110231265 | Brown | Sep 2011 | A1 |
20110302410 | Clarke et al. | Dec 2011 | A1 |
20120096274 | Campagna et al. | Apr 2012 | A1 |
20120117229 | Van Biljon | May 2012 | A1 |
20120117626 | Yates | May 2012 | A1 |
20120131354 | French | May 2012 | A1 |
20120151567 | Chayanam | Jun 2012 | A1 |
20120227098 | Obasanjo et al. | Sep 2012 | A1 |
20120254957 | Fork | Oct 2012 | A1 |
20120278454 | Stewart | Nov 2012 | A1 |
20130060708 | Oskolkov et al. | Mar 2013 | A1 |
20130067538 | Dharmarajan | Mar 2013 | A1 |
20130086210 | Yiu | Apr 2013 | A1 |
20130086658 | Kottahachchi | Apr 2013 | A1 |
20130110676 | Kobres | May 2013 | A1 |
20130125226 | Shah et al. | May 2013 | A1 |
20130239168 | Sreenivas et al. | Sep 2013 | A1 |
20130246281 | Yamada | Sep 2013 | A1 |
20130263211 | Neuman | Oct 2013 | A1 |
20130276142 | Peddada | Oct 2013 | A1 |
20130311776 | Besehanic | Nov 2013 | A1 |
20140020051 | Lu | Jan 2014 | A1 |
20140181517 | Alaranta | Jun 2014 | A1 |
20140181520 | Wendling | Jun 2014 | A1 |
20140201841 | Deshpande et al. | Jul 2014 | A1 |
20140208405 | Hashai | Jul 2014 | A1 |
20140244993 | Chew | Aug 2014 | A1 |
20140245278 | Zellen | Aug 2014 | A1 |
20140351954 | Brownell et al. | Nov 2014 | A1 |
20150312233 | Graham, III | Oct 2015 | A1 |
20160056962 | Mehtälä | Feb 2016 | A1 |
20160164866 | Oberheide et al. | Jun 2016 | A1 |
20160286391 | Khan | Sep 2016 | A1 |
20160366589 | Jean | Dec 2016 | A1 |
Number | Date | Country |
---|---|---|
2639997 | Sep 2013 | EP |
Entry |
---|
Aloul S Zahidi; et al. “Two factor authentication using mobile phones,” 2009 IEEE/ACS International Conference on Computer Systems and Applications, Rabat, 2009, pp. 641-644. |
Bonneau Joseph; et al. “Passwords and the evolution of imperfect authentication.” Communications of the ACM 58.7 (2015): 78-87. |
Kher Vishal; et al. “Securing distributed storage: challenges, techniques and systems.” Proceedings of the 2005 ACM workshop on Storage security and survivability. ACM, 2005, pp. 9-25. |
Edge, Kenneth, et al. “The use of attack and protection trees to analyze security for an online banking system.” System Sciences, 2007. HICSS 2007. 40th Annual Hawaii International Conference on. IEEE, 2007. |
Goldfeder et al., Securing Bitcoin wallets via a new DSA/ECDSA threshold signature scheme, http://www.cs.princeton.edu/˜stevenag/threshold_sigs.pdf. |
Neuenhofen, Kay, and Mathew Thompson. “A secure marketplace for mobile java agents.” Proceeding of the second international Conference on Autonomous agents. ACM, 1998. (pp. 212-218). |
Simske et al., “APEX: Automated Policy Enforcement eXchange”, Sep. 21-24, 2010, ACM, pp. 139-142. |
Symantec, Administration guide for symantec Endpoint protection and symantec network access control, 2009, version 11.00.05.00.00. |
Symantec, Administration Guide for Symantec TM Endpoint Protection and Symantec Network Access Control, Aug. 1, 2007. |
Number | Date | Country | |
---|---|---|---|
20170339164 A1 | Nov 2017 | US |
Number | Date | Country | |
---|---|---|---|
61980762 | Apr 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14688893 | Apr 2015 | US |
Child | 15661277 | US |