MULTI-PARTY CLOUD AUTHENTICATOR

Information

  • Patent Application
  • 20220123950
  • Publication Number
    20220123950
  • Date Filed
    October 15, 2020
    4 years ago
  • Date Published
    April 21, 2022
    2 years ago
Abstract
This disclosure describes techniques for authenticating one or more devices of a user in association with cloud computing services. The techniques include generating credential portions. The credential portions may be used in a signing protocol between one of the user devices and a cloud authenticator. The signing protocol may generate a signature that may be used in authentication with a cloud computing service. Furthermore, the user may be able to use any one of the user devices to log in to an online service after enrolling only a single user device with the online service. As such, the cloud authenticator may assist multiple user devices to authenticate with the cloud computing service.
Description
TECHNICAL FIELD

The present disclosure relates generally to a multi-party cloud authenticator for authenticating one or more devices of a user in association with cloud computing services.


BACKGROUND

Cloud computing offers businesses cost-effective access to virtually unlimited computing power and storage, rather than the businesses purchasing and/or maintaining physical computing resources. As such, many businesses offer services that are performed at distributed and/or remote locations. Since many services include use of private information of a user, such as personal and/or financial information, security is critical for many services offered via cloud computing. However, the distributed nature of cloud computing can increase the complexity of security issues. Therefore, the increasing use of cloud computing by businesses warrants improved methods for customer protection.





BRIEF DESCRIPTION OF THE DRAWINGS

The detailed description is set forth below with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items. In some cases, parentheticals are utilized after a reference number to distinguish like elements. Use of the reference number without the associated parenthetical is generic to the element. The systems depicted in the accompanying figures are not to scale and components within the figures may be depicted not to scale with each other.



FIGS. 1A-2H illustrate component diagrams with an example environment in which multi-party cloud authentication concepts may be employed, in accordance with the present concepts.



FIGS. 3-4 illustrate flow diagrams of example methods for multi-party cloud authentication concepts, in accordance with the present concepts.



FIG. 5 illustrates a computing system diagram illustrating a configuration for a data center that can be utilized to implement aspects of the technologies disclosed herein.



FIG. 6 is a computer architecture diagram showing an illustrative computer hardware architecture for implementing a device that can be utilized to implement aspects of the various technologies presented herein.





DESCRIPTION OF EXAMPLE EMBODIMENTS
Overview

This disclosure describes, at least in part, a method that may be implemented by a user device communicatively coupled to an intermediary device and/or a server device. In some examples, the intermediary device may represent a cloud authenticator. The server device may represent a remote, online service. The method may include registering a first user device with a user account of a user. Registering the first user device may include generating a primary first credential portion retained by the first user device and a primary second credential portion retained by the cloud authenticator, for example. The method may include registering a second user device with the user account of the user, including generating a secondary first credential portion based at least in part on the primary first credential portion and generating a secondary second credential portion based at least in part on the primary second credential portion, for example. The method may include receiving, from the first user device, a first request to authenticate the user account to an online service. Responsive to the first request, the method may include generating a first signature by participating in a first signing protocol between the cloud authenticator and the first user device. In some examples, the first signature may be based at least in part on the primary first credential portion, the primary second credential portion, and a credential identifier (ID) for the online service. The method may include sending the first signature to a remote device associated with the online service to authenticate the user account to the online service. Further, the method may include receiving, from the second user device, a second request to authenticate the user account to the online service. Responsive to the second request, the method may include generating a second signature by participating in a second signing protocol between the cloud authenticator and the second user device. In some examples, the second signature may be based at least in part on the secondary first credential portion, the secondary second credential portion, and the credential ID for the online service.


This disclosure also describes, at least in part, a method that may be implemented by a user device communicatively coupled to intermediary device and/or a server device. In some examples, the intermediary device may represent a cloud authenticator, while the server device may represent a remote, online service. The method may include communicating with a cloud authenticator to generate a primary first credential portion and a primary second credential portion associated with a user account at the cloud authenticator. The method may include receiving the primary first credential portion. The method may also include participating in a signing protocol with the cloud authenticator to generate a signature. In some examples, the signature may be based at least in part on the primary first credential portion and the primary second credential portion. At least partly in response to generating the signature, the method may include accessing an online service by the first user device. Further, the method may include communicating with the cloud authenticator and with a second user device to generate a secondary first credential portion and a secondary second credential portion associated with the user account at the cloud authenticator.


Additionally, the techniques described herein may be performed by a system and/or device having non-transitory computer-readable media storing computer-executable instructions that, when executed by one or more processors, performs the method described above.


Example Embodiments

This disclosure describes techniques for a cloud authenticator. A cloud authenticator may provide an interface through which a user may log in to an online service. The cloud authenticator may help the online service trust a user device of the user to allow access to the online service through the use of a credential associated with the user. Also, the user may have multiple user devices from which the user would like to log in to the online service. In some implementations, the cloud authenticator may enable the user to use any one of the multiple user devices to register and/or log in to an online service after enrolling only a single user device with the online service, providing convenience for the user. Furthermore, in some implementations, the cloud authenticator may not be able to use the credential of the user without the cooperation of at least one of the user devices under control of the user, providing security for the user. Thus, the present techniques offer a relatively convenient and safe system for a user to log in to online services.


Cloud authentication systems may be replacing passwords as a preferred authentication mechanism for online services, and possibly other entities. Online services may include websites and/or another form of Relying Party (RP), which may rely on some form of authentication of a user in order to allow the user to access the online service. However, some logistical challenges remain in the way of more widescale adoption of cloud authentication systems for account log in. One of the issues with cloud authentication systems is account recovery, for which a current recommendation is to enroll multiple authenticators. Users may wish to enroll multiple authenticators, as the user may wish to use different user devices (with different attached authenticators) to access various online services. However, under the current model, users may need to enroll each of their “N” authenticators (e.g., user devices) with each of “M” online services (e.g., websites), for a total of “N*M” enrollments. Thus, the amount of enrollments may easily grow to an unacceptable user burden for common amounts of M (100+RPs) that a user engages in modern life. Additionally, in the enterprise space, an administrator may wish to create a role and then designate a number of users (or a subset of user devices of the users) as eligible authenticators for that role. In this case, the amount of associated enrollments could easily become burdensome for the administrator.


A naïve cloud authenticator may work by storing a credential of a user, then allowing each user device of the user to authenticate to the cloud authenticator. In turn, the cloud authenticator could authenticate to any given website on behalf of the user device, using the credential of the user. Such a scheme may free the user from the burden of having to repeatedly, manually log in and/or register from any of multiple user devices with user names, passwords, etc. However, unfortunately the naïve cloud authenticator scheme presents a danger to the user. Since the naïve cloud authenticator is outside the control of the user, and stores a raw credential of the user, the naïve cloud authenticator is therefore capable of logging in to a website and/or an account of the user without permission from the user. The present concepts provide a cloud authenticator that solves the potentially burdensome “N*M” (number of enrollments) problem, but also ensures that cryptographically the cloud authenticator cannot log in to an account of the user without consent and/or cooperation of the user.


In some implementations, a cloud authenticator may provide an interface via which a user device of a user may hold a first credential portion of a credential associated with the user and the cloud authenticator may hold a second credential portion of the credential associated with the user. The first credential portion and the second credential portion may be complimentary, such that together the portions may be used to authenticate to the online service. Throughout a login process for a website, the first credential portion may be retained by the user device of the user. Additionally or alternatively, the second credential portion may be retained by the cloud authenticator. Generation of the first and second credential portions may be accomplished such that none of the user device(s), the cloud authenticator, or any other device ever has possession of the complete credential. When each credential portion is retained separately by the user device and the cloud authenticator, neither the user device nor the cloud authenticator is able to log into an online service without the cooperation of the other entity. No single actor may complete the credential and/or take authentication action unilaterally, for example. Such a cloud authentication system offers improved security for a user since the cloud authenticator may not log in to a user account without permission from the user. Permission may be provided by confirming a biometric of the user, for example. Furthermore, in an instance where a user device is stolen, the user device may not be used to log in to the user account without permission from the user.


Taken one step further, the cloud authentication system may be designed such that any of multiple user devices of the user may be able to derive (or have access to) the first credential portion. Therefore, in a first instance, a user may be allowed to log in to an online service where a mobile phone (under control of the user) provides the first credential portion and the second credential portion is provided by the cloud authenticator. Additionally, the same user may be allowed to log in to the online service in a second instance, where a desktop computer (under control of the user) provides the first credential portion to be used with the second credential portion held by the cloud authenticator. Such a scheme may be referred to as a multi-party cloud authentication system, where multiple parties (e.g., the user devices and the cloud authenticator) are using “shares” (e.g., portions) of a credential associated with the user. Stated another way, a multi-party cloud authentication system may use any of several devices of a user to cooperate with a cloud authenticator to access an online service in a convenient and safe manner.


One example way to implement a first credential portion and a second credential portion in a multi-party cloud authentication system is through the use of a threshold signature. With a threshold signature (e.g., threshold signature algorithm), a private key is not held by a single entity, but instead is spread across multiple entities. Threshold signatures allow two (or more) entities to use keyshares (e.g., credential portions) to form a signature, without reconstructing a complete credential. To generate a signature, the entities (or at least some subset of the entities) among which the credential portions are distributed must cooperate to generate the signature. Therefore, a cloud authenticator using a threshold signature algorithm may form a signature to log in to a user account with the cooperation of at least one user device that is under control of the user. In some implementations, the signature may be used for an authentication procedure with an online account, such as WebAuthn. The signature formed with the threshold signature algorithm may be used to sign an assertion, registration, log on statement, etc., to log on to a website, for example. In some cases, the cooperation to form the signature may be referred to as a signing protocol. The resultant signature and/or signed assertion may be verified by any entity with a public key that coordinates with the private key. For example, the online service that the user is attempting to access may hold the coordinating public key. The online service may be able to use the public key to verify the signature created with the threshold signature algorithm.


To summarize, by sharing critical elements of an authentication procedure, the multi-party cloud authentication system allows a user to easily register and use multiple user devices, yet is resilient to loss or theft of any individual user device. The multi-party cloud authentication system may also be applied to the sharing of enterprise “roles” across multiple users. In an enterprise system, the multi-party cloud authentication system may allow an administrator to easily and safely provision and recover accounts, and other important features for enterprise workforces. As such, the multi-party cloud authentication system offers an improved interface through which users may access an online service and/or administrators may manage an enterprise workforce.


Although the examples described herein may refer to a user device and/or an intermediary device as participating in a multi-party cloud authentication system in a cloud networking environment, the techniques can generally be applied to any device or role, including an enterprise workforce scenario. Further, the techniques are generally applicable for any network of devices managed by any entity where virtual resources are provisioned. In some instances, the techniques may be performed by software-defined networking (SDN), and in other examples, various devices may be used in a system to perform the techniques described herein. The devices by which the techniques are performed herein are a matter of implementation, and the techniques described are not limited to any specific architecture or implementation.


The techniques described herein provide various improvements and efficiencies with respect to network communications. For instance, the techniques described herein may reduce the amount of computational resource use, storage, dropped data, latency, and other issues experienced in networks due to lack of network resources, overuse of network resources, issues with timing of network communications, and/or improper routing of data. By improving network communications across a network, overall performance by servers and virtual resources may be improved.


Certain implementations and embodiments of the disclosure will now be described more fully below with reference to the accompanying figures, in which various aspects are shown. However, the various aspects may be implemented in many different forms and should not be construed as limited to the implementations set forth herein. The disclosure encompasses variations of the embodiments, as described herein. Like numbers refer to like elements throughout.



FIGS. 1A and 1B collectively illustrate an example environment 100 in accordance with the present multi-party cloud authentication concepts. Example environment 100 may include a cloud computing network 102 (e.g., network), one or more user devices 104, one or more server devices 106 (e.g., remote devices), and/or one or more intermediary devices 108 (e.g., cloud computing devices). Parentheticals are utilized after a reference number to distinguish like elements. Use of the reference number without the associated parenthetical is generic to the element. For example, FIGS. 1A and 1B include two instances of a user device 104, including user device 104(1) which may represent a mobile phone, and user device 104(2) which may represent a desktop computer. In some scenarios, multiple user devices 104 may be associated with a single user, and may be viewed as being under the control of the user. The server device 106 may provide a remote, online service that the user wishes to engage via at least one of the user devices 104. Additionally or alternatively, the intermediary device 108 may represent a cloud authenticator that may provide a service of assisting user devices 104 with authenticating to server device 106. In some implementations, the user associated with user devices 104 may have a user account with the cloud authenticator represented by intermediary device 108, for instance. In this case, user device 104(1) and user device 104(2) may be trusted (e.g., known) by the cloud authenticator as being associated with the user account. Additional detail regarding the enrollment of, and building trust in, multiple user devices with a user account at a cloud authenticator will be provided below, relative to FIGS. 2A-2H.


The user devices 104, server devices 106, and/or intermediary devices 108 may be communicatively coupled among one another and/or to various other devices via network 102. Within the example environment 100, a user device 104, server device 106, intermediary device 108, and/or other devices may exchange communications (e.g., packets) via a network connection(s) to network 102, indicated by double arrows 110. For instance, network connections 110 may be transport control protocol (TCP) network connections or any network connection (e.g., information-centric networking (ICN)) that enable the devices to exchange packets with other devices via cloud computing network 102. The network connections 110 represent, for example, a data path between a user device 104 and an intermediary device 106. For example, the user device 104 may be a computer, laptop, mobile device, tablet, etc., while the server device 106 and/or the intermediary device 108 may be a network device 106 that is configured to provide data and/or network services to the user device 104. The server device 106 and/or intermediary device 108 may or may not be a producer, a point of generation and/or origination of the data. For instance, the data may originate elsewhere for the server device 106 and/or the intermediary device 108 to be able to provide to the user device 104. Alternatively or additionally, the data may pass through other network devices (e.g., router, switch) on a path from the server device 106 and/or the intermediary device 108 to the user device 104. It should be appreciated that the term “network connection” may also be referred to as a “network path.” The use of a cloud computing network in this example is not meant to be limiting. Other types of networks are contemplated in accordance with multi-party cloud authentication concepts.



FIGS. 1A and 1B show several examples of communications among user devices 104, server device 106, and intermediary device 108. The communications are indicated with dashed, numbered lines. In some implementations, the communications may be part of a multi-party cloud authentication scenario for the intermediary device 108 to assist a user device 104 to authenticate with an online service offered via server device 106. For example, in FIG. 1A at “Step 1,” user device 104(1) may communicate with intermediary device 108. User device 104(1) may be registered under a user account of the user at the cloud authenticator such that intermediary device 108 recognizes user device 104(1) as associated with the user account. The communication at Step 1 may correspond to an initial enrollment with the online service. In this case, the user may wish to enroll with the online service at server device 106 via the cloud authenticator at intermediary device 108 such that the user may use any of his/her user devices 104 to access the online service without having to enroll each of the user devices 104 with the online service. Step 1 may include generation of a first credential portion 112 and a second credential portion 114 that may be used to authenticate to the online service. Additional detail regarding the generation of credential portions will be provided below, relative to FIGS. 2A-2H.


As shown in FIG. 1A, user device 104(1) may hold (e.g., retain, have access to, etc.) first credential portion 112(1) (e.g., a client key). The intermediary device 108 may hold second credential portion 114(1) (e.g., cloud key). In this example, the first credential portion 112 and the second credential portion 114 may be viewed as complimentary, such that the first credential portion 112 and the second credential portion 114 together comprise a complete credential. As such, the first credential portion 112 and the second credential portion 114 may both be needed to generate a signature for authentication purposes.


Following generation of the first credential portion 112 and the second credential portion 114, the communication at Step 1 may include a signing protocol between user device 104(1) and intermediary device 108. The signing protocol may include several messages that are sent between user device 104(1) and intermediary device 108. For instance, an algorithm may be used that constitutes several back-and-forth messages which generate a signature. In some examples, the algorithm may be a threshold signature algorithm. The signing protocol may be performed using the first credential portion 112(1) held by user device 104(1) and the second credential portion 114(1) held by intermediary device 108. However, the user device 104(1) may retain the first credential portion 112(1) and the intermediary device 108 may retain the second credential portion 114(1) throughout the signing protocol. Stated another way, intermediary device 108 may participate in the signing protocol without ever knowing and/or having access to plain text of the first credential portion 112. As such, the first credential portion 112 is kept “secret” from the cloud authenticator. Similarly, user device 104(1) does not have access to the second credential portion 114. Through the communication in Step 1, a signature 116A may be generated. The signature 116A may be associated with an assertion, such as an assertion related to a log on and/or other authentication action regarding the online service represented by server device 106.


At “Step 2A” of FIG. 1A, intermediary device 108 may send or otherwise provide signature 116A to server device 106. Server device 106 may review signature 116A to determine whether the associated assertion may be trusted. For example, the server device 106 may hold a public key, and inspection of signature 116A by server device 106 may include comparing and/or matching the public key to a private key associated with a corresponding online account of the user at the online service. In this manner, the user account at the cloud authenticator may be authenticated to the online account at the online service. Note that the online service may or may not be aware of any user device 104. In some implementations, the cloud authenticator may be registering the user account and/or logging in to the online service on behalf of the user, such that the online service is aware of the cloud authenticator, but not necessarily a user device 104. Conversely, in some implementations, the online service may or may not be aware of any intermediate device 108 and/or the cloud authenticator. For example, the online service may only “see” one or more of the user devices 104 throughout the registration, authentication, and/or log in processes. Various communication flows are contemplated for the delivery of a signature 116 to the online service. For example, “Step 2B” is shown in FIG. 1A as an alternate version, where signature 116A may be sent to server device 106 from user device 104(1). For instance, user device 104(1) may act as a proxy for the cloud authenticator in completing an authorization process with the online service.


At “Step 3” of FIG. 1A, upon determining that signature 116A is valid and/or that access to the user account has otherwise been authenticated, server device 106 may provide the online service associated with the user account. Note that after authentication, the cloud authenticator may or may not continue to be involved as an intermediary in the interaction represented by Step 3. Server device 106 may provide the online service to the user at user device 104(1) directly, or indirectly via intermediary device 108. Furthermore, once the user has been authenticated in a user session via a user device 104 (e.g., user device 104(1)), the user may actually access the online service in the user session through a different user device 104, such as user device 104(2).


The multi-party cloud authentication scenario may continue in FIG. 1B. In general, FIG. 1B illustrates how another user device 104(2) associated with the user may be used to access the online service at server device 106. In some implementations, “Step 4” may represent user device 104(2) receiving a first credential portion 112(2) that may correspond to the online service offered via server device 106. For example, since user device 104(1) and user device 104(2) are enrolled with the user account at the cloud authenticator, user device 104(1) may trust user device 104(2) to receive a version of the first credential portion 112. Therefore, user device 104(2) may participate in a protocol that allows another version of the first credential portion 112(1) to be generated for user device 104(2), resulting in first credential portion 112(2) at user device 104(2). Similarly, second credential portion 114(2), which corresponds to first credential portion 112(2), may be generated for intermediary device 108. Therefore, as a result of Step 4, user device 104(2) may hold first credential portion 112(2) and intermediary device 108 may hold second credential portion 114(2) without the user having had to enroll user device 104(2) with the online service. In this example, intermediary device 108 does not receive and/or have access to any version of first credential portion 112. Further, a user device 104 does not receive and/or have access to any version of second credential portion 114. Additional detail regarding the generation of copies of credential portions will be provided below, relative to FIGS. 2A-2H. Note that a first and/or second credential portion may not necessarily be site-specific, and/or correspond to any particular online service. The first and/or second credential portions, when used together, and/or when combined with a piece of site-specific data, may form a site-specific credential.


At “Step 5” of FIG. 1B, user device 104(2) may communicate with intermediary device 108 to initiate a signing protocol. The signing protocol may be performed using the first credential portion 112(2) held by user device 104(2) and the second credential portion 114(2). Similar to Step 1 of FIG. 1A, the result of the communication in Step 5 of FIG. 1B may be a signature 116B, which may be associated with an assertion related to authenticating the user account at the cloud authenticator to the online service at server device 106. In some examples, different instances of first credential portion 112 and second credential portion 114 may be designed such that signature 116B and signature 116A are effectively the same. Stated another way, first credential portion 112(2) and second credential portion 114(2) may be generated such that server device 106 recognizes either signature 116A or signature 116B as an acceptable authorization to access the online service. Further, signature 116B and signature 116A may be byte-for-byte identical. Therefore, server device 106 may recognize either signature 116A or signature 116B as valid because they are the same signature.


At “Step 6” of FIG. 1B, intermediary device 108 may send or otherwise provide signature 116B to server device 106. Note that similar to Step 2B of FIG. 1A, in some examples user device 104(2) may send signature 116B to server device 106. As described above, user device 104(2) may act as a proxy for the cloud authenticator during authentication. Server device 106 may review signature 116B to determine whether authentication of the user account with the online account at the online service may proceed. In this manner, the user account at the cloud authenticator may be authenticated to the online account at the online service. At “Step 7,” upon determining that signature 116B is valid, server device 106 may provide the online service associated with the user account. Note that in the examples shown through FIGS. 1A and 1B, the multi-party cloud authentication system was able to perform authentication services for multiple user devices 104 without the online service having to subscribe to and/or download any particular software and/or application of the cloud authenticator. The online service could review signature 116A and/or signature 116B without any particular accommodation related to the user device 104 enrollment scheme with the user account at the cloud authenticator or for the credential generation process between the user devices 104 and the cloud authenticator, for instance.


In summary, in the multi-party cloud authentication scenario illustrated through FIGS. 1A and 1B, intermediary device 108 provided a multi-party cloud authentication service to a user associated with user devices 104(1) and 104(2), allowing the user to sign in to an online service offered via server device 106. The user was able to use multiple user devices 104 to access the online service in different instances, without having to enroll each user device 104 that was used with the online service. Authentication with the online service was accomplished without the online service having to make any special accommodation for the cloud authenticator. Further, control of the first credential portion 112 associated with the user was retained at the user devices 104 throughout the scenario, such that the cloud authenticator represented by intermediary device 108 did not have control and/or unilateral use of a complete credential (e.g., private key) associated with the user.


Note that the depiction of a single server device 106 (e.g., remote device) and/or a single intermediary device 108 (e.g., cloud computing device) in FIGS. 1A and/or 1B is not meant to be limiting. The online service may be provided by multiple server devices 106, and the multi-party authentication may be provided via multiple intermediary devices 108, either in the same or different sign-on instances. For instance, multi-party authentication may be provided through multiple intermediary devices 108, such that user devices 104(1) and 104(2) may be communicating with different physical intermediary devices 108 at different times.



FIGS. 2A-2H collectively illustrate an additional example multi-party cloud authentication scenario in accordance with the present concepts. FIGS. 2A-2H illustrate an example environment 200. Some aspects of the examples shown in FIGS. 2A-2H may be similar to aspects of the examples described above relative to FIGS. 1A and 1B. Therefore, for sake of brevity, not all elements of FIGS. 2A-2H will be described in detail. Parentheticals are utilized after a reference number to distinguish like elements. Use of the reference number without the associated parenthetical is generic to the element. It should be appreciated that various example Steps are described relative to FIGS. 2A-2H for the purpose of illustrating multi-party cloud authentication concepts. As such, more or fewer Steps might be performed than shown in the FIGS. 2A-2H and described herein. The Steps may also be performed in a different order than those described herein.


Example environment 200 may include a cloud computing network 202 (e.g., network), one or more user devices 204, one or more server devices 206 (e.g., remote devices), and/or one or more intermediary devices 208 (e.g., cloud computing devices). The depiction of a single server device 206 and/or a single intermediary device 208 in FIGS. 2A-2H is not meant to be limiting. The user devices 204, server devices 206, and/or intermediary devices 208 may be communicatively coupled among one another and/or to various other devices via network 202. A user device 204, server device 206, intermediary device 208, and/or other devices may exchange communications (e.g., packets) via a network connection(s) to network 202, indicated by double arrows 210.


The example multi-party cloud authentication scenario illustrated in FIGS. 2A-2H may include one or more first credential portions 212, second credential portions 214, and/or signatures 216, similar to concepts described above relative to FIGS. 1A and 1B. Additionally, the example multi-party cloud authentication scenario illustrated in FIGS. 2A-2H may include one or more public keys 218 and/or private keys 220. In some examples, each user device 204 may have a (potentially unique) keypair, including a public key 218 and a private key 220. The keypair may enable identification of the respective user device 204, for instance. The keypairs may be held in storage 222 on the user devices 204. For example, user device 204(1) is holding a keypair, including public key 218(1) and private key 220(1) in storage 222(1). Similarly, user device 204(2) is holding a keypair, including public key 218(2) and private key 220(2) in storage 222(2). Differences in the keypairs at user device 204(1) and user device 204(2) may allow identification of the respective user devices 204, differentiation of messages received from those user devices 204, and/or assertions signed using those keypairs, for instance. In some implementations, storage 222 may be a form of secure storage, such as a hardware security module (HSM).


Beginning with FIG. 2A, the example multi-party cloud authentication scenario includes communications among user devices 204, server device 206, and intermediary device 208, indicated with dashed, numbered lines. In some implementations, the communications may be part of a multi-party cloud authentication scenario for a user to enroll and/or set up multiple user devices 204 with a user account at a cloud authenticator represented by intermediary device 208. For example, the example multi-party cloud authentication scenario may begin at “Step 1” of FIG. 2A, with a user device 204(1) enrolling with the user account at the cloud authenticator and/or establishing a new user account at the cloud authenticator. In order to facilitate enrollment, user device 204(1) may send public key 218(1) to the intermediary device 208. Intermediary device 208 may associate the public key 218(1) with the user device 204(1) and/or with the user account. Intermediary device 208 may also hold the public key 218(1) in storage 224. In some cases, storage 224 may represent cloud storage for the cloud authenticator. Since the cloud authenticator now has access to public key 218(1), the cloud authenticator may be able to verify future messages received from user device 204(1) that are signed with the corresponding private key 220(1) of the keypair, for instance. As such, Step 1 of FIG. 2A may represent a “trust on first use” type arrangement.


As part of an enrollment protocol, Step 1 of FIG. 2A may also include generation of a first credential portion 212(1) and a corresponding second credential portion 214(1), similar to Step 1 of FIG. 1A. In general, generation of a first credential portion 212 and a corresponding second credential portion 214 may be performed in a distributed manner between a user device 204 and the cloud authenticator, for example. The credential generation may require agreement from both the user device 204 and the cloud authenticator to participate, such that neither is able to complete the generation process without cooperation from the other entity. In some implementations, the generation process and/or enrollment protocol may include multiple rounds of message trading between the user device 204 and the cloud authenticator. The generation process may be a function provided by a threshold signature algorithm, for instance. In some implementations, the generation process may be viewed as “trustless,” such that neither the user device 204 nor the cloud authenticator controls the generation process. In one example, code that enables participation in the credential generation process may be loaded on a user device 204, such as via an application associated with the cloud authenticator. In some examples, the first credential portion 212 and second credential portion 214 created between the cloud authenticator and the first user device 204 to enroll with the user account at the cloud authenticator may be viewed as a “primary” keyshare for purposes of this description, including a primary first credential portion 212 and a primary second credential portion 214. User device 204(1) may hold (e.g., retain) first credential portion 212(1) and intermediary device 208 may hold second credential portion 214(1) in storage 224, for example. Also, as suggested above, the first credential portion 212(1) and/or second credential portion 214(1) may be combined with a piece of site-specific data relating to the online service, forming a site-specific credential.


At “Step 2” of FIG. 2A, once a first credential portion 212 and a second credential portion 214 have been generated in association with the user account, the first credential portion 212 and second credential portion 214 may be used to authenticate to the online service at server device 206. For instance, first credential portion 212(1) and second credential portion 214(1) may be used to generate a signature 216. As shown in the example in FIG. 2A, user device 204(1) and intermediary device 208 may participate in a signing protocol using first credential portion 212(1) and a second credential portion 214(1), generating signature 216A, in this case. The signing protocol may also include a threshold signature algorithm, for instance. Throughout the signing protocol, the user device 204(1) may retain first credential portion 212(1) and intermediary device 208 may retain the second credential portion 214(1) such that the intermediary device 208 does not know and/or have access to plain text of the first credential portion 212(1). As such, the first credential portion 212(1) is kept “secret” from the cloud authenticator. Similarly, user device 204(1) does not have access to the second credential portion 214(1). Note that for some elements, a reference letter may be used to distinguish different instances of an element introduced in different FIGS. of the example multi-party cloud authentication scenario. For example, the “A” in signature 216A corresponds to an instance “A” relative to FIG. 2A. Additional detail regarding the formation of signatures will be provided below, relative to FIGS. 2D and 2E, for example.


At “Step 3” of FIG. 2A, the cloud authenticator may use the signature 216A to authenticate the user account with the online service. Note that user device 204(1) may actually send the signature 216A to server device 206, acting as a proxy for intermediary device 208, for instance. Server device 206 may review signature 216A to determine whether the associated message and/or assertion may be trusted. For example, the server device 206 may use keypairs associated with a corresponding online account of the user at the online service to analyze and/or compare with the signature 216A. Once again, the online service may or may not be aware of any individual user device 204 and/or intermediary device 208. In some implementations, the cloud authenticator may be registering the user account and/or logging in to the online service on behalf of the user, such that the online service is aware of the cloud authenticator, but not necessarily a particular user device 204. Or conversely, the user device 204 may be communicating with the server device and acting as a proxy for cloud authenticator throughout the authentication process. Upon determining that signature 216A is valid and/or that access to the user account has otherwise been authenticated, server device 206 may provide the online service associated with the user account to user device 204(1), either directly or indirectly.


The multi-party cloud authentication scenario may continue in FIG. 2B. FIG. 2B demonstrates how additional user devices 204 may be associated with the user account at the intermediary device 208. For example, after user device 204(1) has been enrolled with the user account at the cloud authenticator, an additional user device 204(2) may be enrolled via an enrollment protocol. At “Step 4” of FIG. 2B, user device 204(2) may send public key 218(2) to intermediary device 208204(2) in order to enroll with the user account at the cloud authenticator. In some implementations, the “primary” keyshare of the first-enrolled user device 204 may be used to help create a new, “secondary” keyshare with another user device 204. For instance, as shown in “Step 5” of FIG. 2B, user device 204(1), user device 204(2), and intermediary device 208 may communicate to create (secondary) first credential portion 212(2) and (secondary) second credential portion 214(2), using (primary) first credential portion 212(1) and (primary) second credential portion 214(1). User device 204(1) may consent to participate in the generation of the secondary keyshare for user device 204(2) since user device 204(2) is under the control of the user, and therefore user device 204(1) trusts user device 204(2). Stated another way, the user may bootstrap trust between user device 204(1) and user device 204(2) so that user device 204(2) is trusted to receive a new first credential portion 212 in association with the user account at the cloud authenticator. Additionally or alternatively, a cloud broker or other entity may assist with the messaging that includes generation of new and/or secondary keyshares between user devices 204 of a common user. For instance, scanning a quick response (QR) code may be part of a process of initiating the generation of a new keyshare with a user device 204.


In some implementations, trust in newly enrolled user devices 204 is established by the previously enrolled user devices 204, and may or may not be established by the cloud authenticator as well. Therefore, the cloud authenticator may not be able to enroll a device without the explicit consent of a user device 204 already-enrolled with that user account. Therefore, the cloud authenticator may not be able to hijack the user account, such as by enrolling its own device. Note that in some examples, a trusted third party may be permitted to enroll a “backup” device with a user account. For example, if a user loses control of their enrolled device(s), the trusted third party may be able to recover the user account. The backup device may have privileges restricted to disallow signing and/or to only allow enrolling new devices when additional requirements are met, for instance.


Referring again to the scenario in FIG. 2B, although user device 204(1), user device 204(2), and intermediary device 208 may communicate to create first credential portion 212(2) and second credential portion 214(2), the new keyshare for user device 204(2) may be generated in such a way that user device 204(1) may not learn first credential portion 212(2) during the new keyshare generation process. Furthermore, during the new keyshare generation process, user device 204(1) may not learn second credential portion 214(2), intermediary device 208 may not learn first credential portion 212(1), and/or intermediary device 208 may not learn first credential portion 212(2). Stated another way, each of user devices 204 and intermediary device(s) 208 retain the keyshare portions intended for their respective use, without learning the keyshare portions of the other devices/entities.



FIG. 2C provides an example representation of the distribution of various keyshares after several user devices 204 have been enrolled with the cloud authenticator. For example, intermediary device 208 may hold the public keys 218 of several user devices 204 in storage 224. In storage 224, intermediary device 208 may also hold several second credential portions 214 that correspond to first credential portions held by the respective user devices 204. For instance, as shown in FIG. 2C, intermediary device 208 holds public key 218(3) of user device 204(3) in storage 224. Also, intermediary device 208 holds second credential portion 214(3) in storage 224, where second credential portion 214(3) corresponds to first credential portion 212(3) held by user device 204(3).


The multi-party cloud authentication scenario may continue in FIG. 2D. FIG. 2D demonstrates how the user account may be registered with an online service at server device 206 via the cloud authenticator. Further, the user may wish to register with the online service via the cloud authenticator in such a manner that the user may access the online service using any of his/her user devices 204 that are already enrolled with the cloud authenticator, without having to individually, manually register each of the user devices 204 with the online service. At “Step 6” of FIG. 2D, user device 204(1) and intermediary device 208 may participate in a protocol for registering with an online service offered via server device 206. The registration protocol may include selecting, generating, and/or agreeing on a credential for the online service. Various schemes are contemplated for selecting a credential for an online service. For instance, example schemes for selecting the credential include two-party elliptic curve digital signature algorithm (2P-ECDSA), Edwards-curve digital signature algorithm (EdDSA), etc.


In some schemes, the credential may be selected without being wholly known to either user device 204(1) or intermediary device 208. The credential may be selected such that the credential may be formed using the first credential portion 212 and second credential portion 214. The registration protocol may also include selecting a credential identifier (ID) 226 for the online service. The credential ID 226 may be (potentially) unique relative to other credential IDs for the user account at the cloud authenticator. As a byproduct, the credential ID 226 may also be unique to the online service, such that different online services (e.g., websites) have different credential IDs 226. Furthermore, in some implementations, the credential may be formed using the first credential portion 212, second credential portion 214, and credential ID 226. In one example, the credential may be formed with the following mathematical expression:





Credential=(1st Cred.)*(2nd Cred.)*hash(Cred. ID)


where “1st Cred.” is first credential portion 212, “2nd Cred.” is second credential portion 214, and “hash(Cred. ID)” is a hash of credential ID 226. The hash may be a preexisting hash function in some cases. Note that although the credential may be conceptually formed using the above expression, the credential may not actually be reconstructed by either a user device 204 or the cloud authenticator. In this manner neither the user devices 204 nor the cloud authenticator may have access to the complete credential.


Referring again to FIG. 2D, after credential ID 226D has been selected for an online service at server device 206, credential ID 226D may be used together with first credential portion 212(1) and second credential portion 214(1) to generate signature 216D to authenticate to the online service. For example, user device 204(1) may participate in a signing protocol with intermediary device 208 to form signature 216D. The signing protocol may include a threshold signature algorithm. In some examples, signature 216D may be represented by the following mathematical expression:





Signature(1st Cred.)*(2nd Cred.)*hash(Cred. ID)


where “1st Cred.” is first credential portion 212(1), “2nd Cred.” is second credential portion 214(1), and “hash(Cred. ID)” is a hash of credential ID 226D. Stated another way, a message may be signed using the complete credential that is formed with the first credential portion 212(1), second credential portion 214(1), and credential ID 226D. However, throughout any signing protocol, the first credential portion 212 may be kept “secret” from the cloud authenticator, and the second credential portion 214 may be kept secret from any user device 204. In “Step 7” of FIG. 2D, the resultant signature 216D may be provided to server device 206 for authentication purposes.


In some examples, credential IDs 226 that have been selected for online services may be stored by the cloud authenticator. In this manner, any user device 204 of the user may be used to sign in to the online service via the user account with the cloud authenticator. A credential ID 226 may or may not be protected (e.g., encrypted) before the cloud authenticator is allowed to receive and/or store the credential ID 226. For instance, since the cloud authenticator does not have access to a first credential portion 218 that is needed to form a complete credential, the credential ID 226 may not need to be encrypted with respect to the cloud authenticator. However, in order for a user device 204 to trust a credential ID 226 stored by the cloud authenticator, a scheme may be used for the credential ID 226 to be signed by another user device 204, as illustrated in FIG. 2E. In FIGS. 2E-2H, credential IDs 226 that have been asserted as associated with the user account and/or otherwise signed will be marked with an asterisk (*). For example, in “Step 8” of FIG. 2E, credential ID 226D is shown as “Cred. ID* 226D.” In some examples, the credential ID 226D may be signed with the same credential used for login, formed using the first credential portion 212, second credential portion 214, and hash of credential ID 226, as described above. Signed credential ID 226D may then be stored in storage 224 of intermediary device 208. In some examples, the signing of a credential ID 226 may be part of the process of selecting the credential ID 226, such as in Step 6 of FIG. 2D. Additionally or alternatively, signed credential IDs 226 may be added to storage 224 as part of a synching process among user devices 204 and/or the cloud authenticator at intermediary device 208, for instance. Such a synching process may occur automatically, such as at a preset interval, and/or may occur by some other trigger, such as when user devices 204 logs in to or accesses the user account, when a new user device 204 is enrolled with the user account, etc. In some implementations, credential IDs 226 may be distributed among the user devices 204.


Continuing at “Step 9” of FIG. 2F, the user may wish to access the online service at server device 206 with user device 204(3), via the cloud authenticator. In some examples, as shown in FIG. 2F, user device 204(3) may participate in a signing protocol with intermediary device 208 in order to authenticate user device 204(3) to the online service. In the signing protocol, user device 204(3) may provide first credential portion 212(3), while intermediary device 208 may provide second credential portion 214(3) and signed credential ID 226D. Since credential ID 226D is signed using the credential that is formed using first credential portion 212 and second credential portion 214, user device 204(3) can use the corresponding public key to validate that a user device 204 participated in signing credential ID 226D, and therefore user device 204(3) may agree to participate in the signing protocol. (In other examples, credential ID 226 may be provided by user device 204(3) for the signing protocol.) The signing protocol may produce a signature 216. In some examples, the signature 216 may be represented by the following mathematical expression:





Signature(1st Cred.)*(2nd Cred.)*hash(Cred. ID)


where “1st Cred.” is first credential portion 212(3), “2nd Cred.” is second credential portion 214(3), and “hash(Cred. ID)” is a hash of credential ID 226D. Note that although user device 204(3) is using first credential portion 212(3) (and not first credential portion 212(1)) to produce the signature 216, the resultant signature 216 of the signing protocol in Step 9 of FIG. 2F may actually be similar to, matching, or the same as the resultant signature 216 of the signing protocol in Step 6 of FIG. 2D. For example, although first credential portion 212(3) and second credential portion 214(3) are different than first credential portion 212(1) and second credential portion 214(1), respectively, the resultant complete credential formed to complete a signature 216 with credential ID 226D may be virtually (or identically) the same complete credential, resulting in a matching signature 216D. As such, Step 9 of FIG. 2F also produces signature 216D, and in “Step 10,” signature 226D may be sent to server device 206 for authentication such that the user may access the online service via user device 204(3). Stated another way, any user device 204 (e.g., user device 204(1), user device 204(3), etc.) may be able to derive the selected, complete credential for an online service to produce a signature 216 for authentication purposes, such that the online service is unaware of any difference in the signature 216. (Note that other examples are contemplated where a signature may be created without including a hash of a credential ID 226.)



FIG. 2G provides an example representation of the distribution of various credential IDs 226 after enrollment in at least one additional online service. For example, intermediary device 208 may hold signed credential ID 226D and signed credential ID 226G in storage 224. Note that credential ID 226D and credential ID 226G may be associated with different online services (e.g., different websites), such as a website “D” and a website “G,” for instance. At the instance represented in FIG. 2G, the user would be able to use any of user devices 204 to log on to website “D” or website “G” without having had to enroll any second user device 204 with the respective website. (Note that in some cases, credential ID 226D and credential ID 226G could be associated with different user accounts for a same online service, or associated with different user accounts for different online services, etc. Stated another way, a credential ID 226 is an identifier for a corresponding credential, not necessarily for any particular online service or user account.) In some examples, after the initial enrollment of any user device 204 with the user account at the cloud authenticator and generation of a respective first credential portion 212 and second credential portions 214 for that user device 204, no further communication is needed for that user device 204 to be able to participate in a subsequent signing protocol for a future online service registered through any other user device 204. Therefore, through generation of first credential portions 212, second credential portions 214, and credential IDs 226, the multi-party cloud authentication system is able to share the authentication credentials for different user devices 204 to access an online service, without having to separately register each user device 204 with the online service. Once again, the user devices 204 are trusted to receive the first credential portions 212, and participate in signing protocols with the credential IDs 226, due to the bootstrapping of trust in the user devices 204 via the primary keyshares of the first-enrolled user device 204 and/or appropriate keyshares of any already-enrolled user device 204.


Note that in FIG. 2G, storage device 224 has acquired a collection of various items such as second credential portions 214, public keys 218, and credential IDs 226. Storage 224 may contain more or less items than shown in FIG. 2G at any given instance, as the information is updated and/or synchronized. Furthermore, items in storage 224 of the cloud authenticator and/or held at any of user devices 204 may be updated, removed, replaced, edited, moved, etc. Through updating storage 224, the overall web of trust associated with the user account may be continuously strengthened and/or improved. Additionally or alternatively, through the sharing of trust and/or credential IDs 226, the cloud authenticator may serve as backup for the user devices 204. In some implementations, first credential portions 212 may be encrypted, then sent to the cloud authenticator for storage and/or backup purposes. Thus, the sharing of trust, credential IDs 226, and/or encrypted first credential portions 212 fosters the multi-party cloud authentication system in which any of multiple user devices 204 may be used by the user to access an online service, without the user having to enroll each user device 204.



FIG. 2H illustrates a scenario where a user device 204 may be disenrolled, indicated with an “X” over user device 204(2). For example, user device 204(2) may be lost, damaged, or stolen. In another example, the user may be replacing user device 204(2) with a new user device 204, and may wish to disenroll user device 204(2). For disenrollment purposes, the cloud authenticator may simply mark the disenrolled user device 204(2) as “untrusted” (indicated with an “X” over the public key 218(2) in storage 224). Intermediary device 208 may refuse to participate in a signing protocol with an untrusted device. For instance, since intermediary device 208 no longer trusts user device 204(2) in associated with the user account, intermediary device 208 will not use second credential portion 214(2) (also indicated with an “X”) to participate in a signing ceremony with user device 204(2). Since both credential portions are necessary to complete a signing protocol, even if user device 204(2) is in the possession of a different user that tries to inappropriately access the user account or online service of the user, a corresponding first credential portion 212 on user device 204(2) would be useless to the different user. As noted above, verification that a user device 204 is in control of the intended user associated with the user account may be made with a biometric, password, etc., relative to the user device 204. Stated another way, any entity, even an attacker, may obtain a first credential portion 212 with no ill effects, such as unapproved access to a user account and/or online service.


As described through FIGS. 2A-2H, using a multi-party cloud authentication system, a first user device 204 may be used to log in to an online service, and later a second user device may be used to access that online service. For example, a user may register their mobile phone with a website, then later use their tablet to log in the website, without having to separately enroll and/or verify the tablet with the website. Through the use of keyshares, user devices under control of the user are able to verify trust in other user devices. The multi-party cloud authentication system may be robust to attack after loss or theft of a device, since portions of any given authentication credential are divided between the user device and the cloud authenticator. Neither the user device nor the cloud authenticator can unilaterally complete and use the complete authentication credential without cooperation from the other entity.


In some implementations, a multi-party cloud authentication system may be applied to an enterprise case, where a cloud authenticator account may be created not for a user, but for a “role” in the enterprise. An administrator may create a role account and then enroll all or a subset of one or more user devices in that account. The benefits of the multi-party cloud authentication system may be similarly realized in the enterprise case, including sharing an authentication credential (portion), disenrolling user devices from a role account, etc. For instance, in some examples, the administrator may be able to use the multi-party cloud authentication system to apply policy to user devices, and then may block release of a credential where a particular user device does not conform to the policy.


To summarize, the multi-party cloud authentication techniques described herein may represent a more efficient and safer method of authenticating users to an online service. The techniques may therefore improve security relative to cloud computing services, while also improving the user experience. The techniques may be relatively lightweight, featuring low computational cost and/or low bandwidth usage. Furthermore, the benefits of multi-party cloud authentication techniques may be become more pronounced as users increasingly use multiple devices to access online services, and do not wish to be hassled with cumbersome log on processes.



FIGS. 3 and 4 illustrate flow diagrams of example methods 300 and 400 that include functions that may be performed at least partly by a network device, such as intermediary devices 108 or 208, or a user device, such as user devices 104 or 204 described relative to FIGS. 1A-2H. The logical operations described herein with respect to FIGS. 3 and 4 may be implemented (1) as a sequence of computer-implemented acts or program modules running on a computing system and/or (2) as interconnected machine logic circuits or circuit modules within the computing system.


The implementation of the various devices and/or components described herein is a matter of choice dependent on the performance and other requirements of the computing system. Accordingly, the logical operations described herein are referred to variously as operations, structural devices, acts, or modules. These operations, structural devices, acts, and modules may be implemented in software, in firmware, in special purpose digital logic, and any combination thereof. It should also be appreciated that more or fewer operations might be performed than shown in the FIGS. 3 and 4 and described herein. These operations may also be performed in parallel, or in a different order than those described herein. Some or all of these operations may also be performed by components other than those specifically identified. Although the techniques described in this disclosure is with reference to specific devices, in other examples, the techniques may be implemented by less devices, more devices, different devices, or any configuration of devices and/or components.



FIG. 3 illustrates a flow diagram of an example method 300 for network devices to perform multi-party cloud authentication techniques. Method 300 may be performed by an intermediary device (e.g., intermediary device 108 or 208) communicatively coupled to first and second user devices (e.g., user devices 104 or 204), for instance. The intermediary device may represent a cloud authenticator. The intermediary device may also be communicatively coupled to a server device. The server device may represent an online service, such as a website. In some examples, method 300 may be performed by a computing device comprising one or more processors and one or more non-transitory computer-readable media storing computer-executable instructions that, when executed by the one or more processors, cause the one or more processors to perform method 300.


At 302, method 300 may include registering, by the cloud authenticator, the first user device with a user account of a user. In some examples, registering the first user device may comprise generating a primary first credential portion retained by the first user device and a primary second credential portion retained by the cloud authenticator. The primary first credential portion and the primary second credential portion may be retained by the first user device and the cloud authenticator, respectively, throughout the generation process. In this manner, neither the first user device nor the cloud authenticator may have possession of the credential portion belonging to the other entity.


At 304, method 300 may include registering, by the cloud authenticator, the second user device with the user account of the user. In some examples, registering the second user device may comprise generating a secondary first credential portion based at least in part on the primary first credential portion and generating a secondary second credential portion based at least in part on the primary second credential portion. The method may also include participating in an enrollment protocol with the first user device to generate the secondary first credential portion.


At 306, method 300 may include receiving, at the cloud authenticator and from the first user device, a first request to authenticate the user account to an online service.


Responsive to the first request, at 308, method 300 may include generating a first signature by participating in a first signing protocol with the first user device. In some examples, the first signature may be based at least in part on the primary first credential portion, the primary second credential portion, and a credential identifier (ID) for the online service. The method may also include selecting the credential ID by participating in a registration protocol with the first user device to register with the online service. During the first signing protocol, the primary first credential portion may be retained by the first user device and the primary second credential portion may be retained by the cloud authenticator. Here again, neither the first user device nor the cloud authenticator may have possession of the credential portion belonging to the other entity during and/or throughout the first signing protocol. In some examples, the first signing protocol may be a threshold signature signing protocol.


At 310, method 300 may include providing, by the cloud authenticator, the first signature to a remote device associated with the online service to authenticate the user account to the online service. Providing the first signature may include the cloud authenticator sending the first signature to the online service. Stated another way, the cloud authenticator may log on to the online service on behalf of the user, using the first signature. In other examples, providing the first signature may include the cloud authenticator facilitating the first user device sending the first signature to the online service. For instance, the cloud authenticator may participate in the signing protocol, from which the first user device may receive the first signature and log in to the online service using the first signature.


At 312, method 300 may include receiving, at the cloud authenticator and from the second user device, a second request to authenticate the user account to the online service.


Responsive to the second request, at 314, method 300 may include generating a second signature by participating in a second signing protocol between the cloud authenticator and the second user device. In some examples, the second signature may be based at least in part on the secondary first credential portion, the secondary second credential portion, and the credential ID for the online service. The first signature may match the second signature, either exactly or effectively for authentication purposes, in some cases. In some examples, the method may include receiving a signed copy of the credential ID from the first user device at the cloud authenticator. The second signature may be generated in the second signing protocol using the signed copy of the credential ID. Once again, the secondary first credential portion may be retained by the second user device and the secondary second credential portion may be retained by the cloud authenticator. In some implementations, the first user device and the second user device may (potentially) never have access to plain text of any second credential portion. Further, the cloud authenticator may (potentially) never have access to plain text of any first credential portion. Neither entity requires knowledge of the credential portion belonging to the other entity to be able to perform multi-party cloud authentication techniques. However, the cloud authenticator may receive and/or store credential IDs for various online services, public keys of the user devices, etc.



FIG. 4 illustrates a flow diagram of an example method 400 for network devices to perform loop prevention techniques. Method 300 may be performed by a first user device (e.g., user device 104 or 204) communicatively coupled to an intermediary device (e.g., intermediary device 108 or 208) and/or a second user device, for instance. The intermediary device may represent a cloud authenticator. The intermediary device and/or the user devices may also be communicatively coupled to a server device. The server device may represent an online service, such as a website. In some examples, method 400 may be performed by a computing device comprising one or more processors and one or more non-transitory computer-readable media storing computer-executable instructions that, when executed by the one or more processors, cause the one or more processors to perform method 400.


At 402, method 400 may include communicating, by the first user device, with the cloud authenticator to generate a primary first credential portion and a primary second credential portion associated with a user account at the cloud authenticator.


At 404, method 400 may include receiving, by the first user device, the primary first credential portion. In some examples, the primary first credential portion may be retained by the first user device and the primary second credential portion may be retained by the cloud authenticator.


At 406, method 400 may include participating in a signing protocol with the cloud authenticator to generate a signature. The signature may be based at least in part on the primary first credential portion and the primary second credential portion. During the signing protocol, the primary first credential portion may be retained by the first user device and the primary second credential portion may be retained by the cloud authenticator. The signature may be used for authenticating to the online service, for instance. In some examples, the signing protocol may comprise a threshold signature signing protocol. Also, the signature may comprise a threshold signature. In some examples, the method may include selecting, by the first user device and with the cloud authenticator, a credential identifier (ID) for the online service. The signature may be based at least in part on the credential ID, in addition to the primary first credential portion and the primary second credential portion.


At 408, at least partly in response to generating the signature, method 400 may include accessing the online service by the first user device. The first user device may access the online service directly, or may access the online service indirectly via the cloud authenticator, for instance.


At 410, method 400 may include communicating, by the first user device, with the cloud authenticator and with the second user device to generate a secondary first credential portion and a secondary second credential portion associated with the user account at the cloud authenticator. In some examples, the method may include signing, by the first user device, a copy of the credential ID to create a signed credential ID. The method may further include sending the signed credential ID to the cloud authenticator in association with the user account. In instances where the second user device participates in a signing protocol with the cloud authenticator, the signed credential ID may be used during the generation of the signature. The second user device may agree to participate in the signing protocol due to the use of the signed credential ID, since the signature by the first user device on the copy of the credential ID may install trust by the second user device in the credential ID.



FIG. 5 is a computing system diagram illustrating a configuration for a data center 500 that can be utilized to implement aspects of the technologies disclosed herein. The example data center 500 shown in FIG. 5 includes several computers 502A-502F (which might be referred to herein singularly as “a computer 502” or in the plural as “the computers 502”) for providing computing resources. In some examples, the resources and/or computers 502 may include, or correspond to, any type of networked device described herein, such as an intermediary device (108 or 208) and/or a user device (104 or 204). Although, computers 502 may comprise any type of networked device, such as servers, switches, routers, hubs, bridges, gateways, modems, repeaters, access points, hosts, etc.


The computers 502 can be standard tower, rack-mount, or blade server computers configured appropriately for providing computing resources. In some examples, the computers 502 may provide computing resources 504 including data processing resources such as virtual machine (VM) instances or hardware computing systems, database clusters, computing clusters, storage clusters, data storage resources, database resources, networking resources, and others. Some of the computers 502 can also be configured to execute a resource manager 506 capable of instantiating and/or managing the computing resources. In the case of VM instances, for example, the resource manager 506 can be a hypervisor or another type of program configured to enable the execution of multiple VM instances on a single computer 502. Computers 502 in the data center 500 can also be configured to provide network services and other types of services.


In the example data center 500 shown in FIG. 5, an appropriate local area network (LAN) 508 is also utilized to interconnect the computers 502A-502F. It should be appreciated that the configuration and network topology described herein has been greatly simplified and that many more computing systems, software components, networks, and networking devices can be utilized to interconnect the various computing systems disclosed herein and to provide the functionality described above. Appropriate load balancing devices or other types of network infrastructure components can also be utilized for balancing a load between data centers 500, between each of the computers 502A-502F in each data center 500, and, potentially, between computing resources in each of the computers 502. It should be appreciated that the configuration of the data center 500 described with reference to FIG. 5 is merely illustrative and that other implementations can be utilized.


In some examples, the computers 502 may each execute one or more application containers and/or virtual machines to perform techniques described herein. For instance, the containers and/or virtual machines may serve as server devices, user devices, and/or routers in the cloud computing network 102 or 202.


In some instances, the data center 500 may provide computing resources, like application containers, VM instances, and storage, on a permanent or an as-needed basis. Among other types of functionality, the computing resources provided by a cloud computing network may be utilized to implement the various services and techniques described above. The computing resources 504 provided by the cloud computing network can include various types of computing resources, such as data processing resources like application containers and VM instances, data storage resources, networking resources, data communication resources, network services, and the like.


Each type of computing resource 504 provided by the cloud computing network can be general-purpose or can be available in a number of specific configurations. For example, data processing resources can be available as physical computers or VM instances in a number of different configurations. The VM instances can be configured to execute applications, including web servers, application servers, media servers, database servers, some or all of the network services described above, and/or other types of programs. Data storage resources can include file storage devices, block storage devices, and the like. The cloud computing network can also be configured to provide other types of computing resources 504 not mentioned specifically herein.


The computing resources 504 provided by a cloud computing network may be enabled in one embodiment by one or more data centers 500 (which might be referred to herein singularly as “a data center 500” or in the plural as “the data centers 500”). The data centers 500 are facilities utilized to house and operate computer systems and associated components. The data centers 500 typically include redundant and backup power, communications, cooling, and security systems. The data centers 500 can also be located in geographically disparate locations. One illustrative embodiment for a data center 500 that can be utilized to implement the technologies disclosed herein will be described below with regards to FIG. 6.



FIG. 6 shows an example computer architecture 600 for a computer 502 capable of executing program components for implementing the functionality described above. The computer architecture 600 shown in FIG. 6 illustrates a conventional server computer, workstation, desktop computer, laptop, tablet, network appliance, e-reader, smartphone, and/or other computing device, and can be utilized to execute any of the software components presented herein. The computer 502 may, in some examples, correspond to a physical device described herein (e.g., intermediary device, user device, etc.), and may comprise networked devices such as servers, switches, routers, hubs, bridges, gateways, modems, repeaters, access points, etc. For instance, computer 502 may correspond to intermediary device 108 or 208.


As shown in FIG. 6, the computer 502 includes a baseboard 602, or “motherboard,” which is a printed circuit board to which a multitude of components or devices can be connected by way of a system bus or other electrical communication paths. In one illustrative configuration, one or more central processing units (“CPUs”) 604 operate in conjunction with a chipset 606. The CPUs 604 can be standard programmable processors that perform arithmetic and logical operations necessary for the operation of the computer 502.


The CPUs 604 perform operations by transitioning from one discrete, physical state to the next through the manipulation of switching elements that differentiate between and change these states. Switching elements generally include electronic circuits that maintain one of two binary states, such as flip-flops, and electronic circuits that provide an output state based on the logical combination of the states of one or more other switching elements, such as logic gates. These basic switching elements can be combined to create more complex logic circuits, including registers, adders-subtractors, arithmetic logic units, floating-point units, and the like.


The chipset 606 provides an interface between the CPUs 604 and the remainder of the components and devices on the baseboard 602. The chipset 606 can provide an interface to a RAM 608, used as the main memory in the computer 502. The chipset 606 can further provide an interface to a computer-readable storage medium such as a read-only memory (“ROM”) 610 or non-volatile RAM (“NVRAM”) for storing basic routines that help to startup the computer 502 and to transfer information between the various components and devices. The ROM 610 or NVRAM can also store other software components necessary for the operation of the computer 502 in accordance with the configurations described herein.


The computer 502 can operate in a networked environment using logical connections to remote computing devices and computer systems through a network, such as networks 102, 202, and/or 508. The chipset 606 can include functionality for providing network connectivity through a network interface controller (NIC) 612, such as a gigabit Ethernet adapter. The NIC 612 is capable of connecting the computer 502 to other computing devices over the network 202. For instance, in the example shown in FIG. 6, NIC 612 may help facilitate transfer of data, packets, assertions, signatures and/or communications, such as credential IDs 226 and/or public keys 218, over the network 202 with intermediary device 208. It should be appreciated that multiple NICs 612 can be present in the computer 502, connecting the computer to other types of networks and remote computer systems.


The computer 502 can be connected to a storage device 614 that provides non-volatile storage for the computer. The storage device 614 can store an operating system 616, programs 618, database 620, and/or other data. In some examples, database 620 may represent and/or include storage 222, 224, and/or 228, for instance. The storage device 614 can be connected to the computer 502 through a storage controller 622 connected to the chipset 606, for example. The storage device 614 can consist of one or more physical storage units. The storage controller 622 can interface with the physical storage units through a serial attached SCSI (“SAS”) interface, a serial advanced technology attachment (“SATA”) interface, a fiber channel (“FC”) interface, or other type of interface for physically connecting and transferring data between computers and physical storage units.


The computer 502 can store data on the storage device 614 by transforming the physical state of the physical storage units to reflect the information being stored. The specific transformation of physical state can depend on various factors, in different embodiments of this description. Examples of such factors can include, but are not limited to, the technology used to implement the physical storage units, whether the storage device 614 is characterized as primary or secondary storage, and the like.


For example, the computer 502 can store information to the storage device 614 by issuing instructions through the storage controller 622 to alter the magnetic characteristics of a particular location within a magnetic disk drive unit, the reflective or refractive characteristics of a particular location in an optical storage unit, or the electrical characteristics of a particular capacitor, transistor, or other discrete component in a solid-state storage unit. Other transformations of physical media are possible without departing from the scope and spirit of the present description, with the foregoing examples provided only to facilitate this description. The computer 502 can further read information from the storage device 614 by detecting the physical states or characteristics of one or more particular locations within the physical storage units.


In addition to the mass storage device 614 described above, the computer 502 can have access to other computer-readable storage media to store and retrieve information, such as policies, program modules, data structures, and/or other data. It should be appreciated by those skilled in the art that computer-readable storage media is any available media that provides for the non-transitory storage of data and that can be accessed by the computer 502. In some examples, the operations performed by the network (e.g., 102, 202, and/or 508), and or any components included therein, may be supported by one or more devices similar to computer 502. Stated otherwise, some or all of the operations performed by the network (e.g., 102, 202, and/or 508), and or any components included therein, may be performed by one or more computer devices 502 operating in a cloud-based arrangement.


By way of example, and not limitation, computer-readable storage media can include volatile and non-volatile, removable and non-removable media implemented in any method or technology. Computer-readable storage media includes, but is not limited to, RAM, ROM, erasable programmable ROM (“EPROM”), electrically-erasable programmable ROM (“EEPROM”), flash memory or other solid-state memory technology, compact disc ROM (“CD-ROM”), digital versatile disk (“DVD”), high definition DVD (“HD-DVD”), BLU-RAY, ternary content addressable memory (TCAM), and/or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store the desired information in a non-transitory fashion.


As mentioned briefly above, the storage device 614 can store an operating system 616 utilized to control the operation of the computer 502. According to one embodiment, the operating system comprises the LINUX operating system. According to another embodiment, the operating system comprises the WINDOWS® SERVER operating system from MICROSOFT Corporation of Redmond, Wash. According to further embodiments, the operating system can comprise the UNIX operating system or one of its variants. It should be appreciated that other operating systems can also be utilized. The storage device 614 can store other system or application programs and data utilized by the computer 502.


In one embodiment, the storage device 614 or other computer-readable storage media is encoded with computer-executable instructions which, when loaded into the computer 502, transform the computer from a general-purpose computing system into a special-purpose computer capable of implementing the embodiments described herein. These computer-executable instructions transform the computer 502 by specifying how the CPUs 604 transition between states, as described above. According to one embodiment, the computer 502 has access to computer-readable storage media storing computer-executable instructions which, when executed by the computer 502, perform the various processes described above with regards to FIGS. 1A-4. The computer 502 can also include computer-readable storage media having instructions stored thereupon for performing any of the other computer-implemented operations described herein.


The computer 502 can also include one or more input/output controllers 624 for receiving and processing input from a number of input devices, such as a keyboard, a mouse, a touchpad, a touch screen, an electronic stylus, or other type of input device. Similarly, an input/output controller 624 can provide output to a display, such as a computer monitor, a flat-panel display, a digital projector, a printer, or other type of output device. It will be appreciated that the computer 502 might not include all of the components shown in FIG. 6, can include other components that are not explicitly shown in FIG. 6, or might utilize an architecture completely different than that shown in FIG. 6.


As described herein, the computer 502 may comprise one or more devices, such as intermediary device 108 or 208, user devices 104 or 204, and/or other devices. The computer 502 may include one or more hardware processors 604 (processors) configured to execute one or more stored instructions. The processor(s) 604 may comprise one or more cores. Further, the computer 502 may include one or more network interfaces configured to provide communications between the computer 502 and other devices, such as the communications described herein as being performed by intermediary device 108 or 208, user devices 104 or 204, and/or other devices. In some examples, the communications may include data, packet, assertion, signature and/or other communications, such as credential IDs 226 and/or public keys 218, and/or other information transfer, for instance. The network interfaces may include devices configured to couple to personal area networks (PANs), wired and wireless local area networks (LANs), wired and wireless wide area networks (WANs), and so forth. For example, the network interfaces may include devices compatible with Ethernet, Wi-Fi™, and so forth.


The programs 618 may comprise any type of programs or processes to perform the techniques described in this disclosure in accordance with multi-party cloud authentication techniques. For instance, the programs 618 may cause the computer 502 to perform techniques for communicating with other devices using any type of protocol or standard usable for determining connectivity. Additionally, the programs 618 may comprise instructions that cause the computer 502 to perform the specific techniques for multi-party cloud authentication.


While the invention is described with respect to the specific examples, it is to be understood that the scope of the invention is not limited to these specific examples. Since other modifications and changes varied to fit particular operating requirements and environments will be apparent to those skilled in the art, the invention is not considered limited to the example chosen for purposes of disclosure, and covers all changes and modifications which do not constitute departures from the true spirit and scope of this invention.


Although the application describes embodiments having specific structural features and/or methodological acts, it is to be understood that the claims are not necessarily limited to the specific features or acts described. Rather, the specific features and acts are merely illustrative some embodiments that fall within the scope of the claims of the application.

Claims
  • 1. A computer-implemented method comprising: registering, by a cloud authenticator, a first user device with a user account of a user, the registering comprising generating a primary first credential portion retained by the first user device and a primary second credential portion retained by the cloud authenticator;registering, by the cloud authenticator, a second user device with the user account of the user, the registering comprising generating a secondary first credential portion based at least in part on the primary first credential portion and generating a secondary second credential portion based at least in part on the primary second credential portion;receiving, at the cloud authenticator and from the first user device, a first request to authenticate the user account to an online service;responsive to the first request, generating a first signature by participating in a first signing protocol between the cloud authenticator and the first user device, the first signature based at least in part on the primary first credential portion, the primary second credential portion, and a credential identifier (ID) for the online service;providing, by the cloud authenticator, the first signature to a remote device associated with the online service to authenticate the user account to the online service;receiving, at the cloud authenticator and from the second user device, a second request to authenticate the user account to the online service; andresponsive to the second request, generating a second signature by participating in a second signing protocol between the cloud authenticator and the second user device, the second signature based at least in part on the secondary first credential portion, the secondary second credential portion, and the credential ID for the online service.
  • 2. The computer-implemented method of claim 1, wherein the first signature matches the second signature.
  • 3. The computer-implemented method of claim 1, wherein the primary first credential portion is retained by the first user device and the secondary first credential portion is retained by the second user device.
  • 4. The computer-implemented method of claim 3, wherein the primary first credential portion is not available to the cloud authenticator during generation of the primary first credential portion and during the first signing protocol.
  • 5. The computer-implemented method of claim 1, wherein the first signing protocol is a threshold signature signing protocol.
  • 6. The computer-implemented method of claim 1, wherein the generating the secondary first credential portion further comprises: participating in an enrollment protocol with the first user device to generate the secondary first credential portion based at least in part on the primary first credential portion.
  • 7. The computer-implemented method of claim 1, further comprising: selecting the credential ID by participating in a registration protocol with the first user device to register with the online service.
  • 8. The computer-implemented method of claim 1, further comprising: receiving a signed copy of the credential ID,wherein the generating the second signature in the second signing protocol comprises using the signed copy of the credential ID.
  • 9. A cloud computing device comprising: one or more processors; andone or more non-transitory computer-readable media storing computer-executable instructions that, when executed by the one or more processors, cause the one or more processors to:register a first user device with a user account of a user, the registering comprising generating a primary first credential portion retained by the first user device and a primary second credential portion retained by the cloud computing device;register a second user device with the user account of the user, the registering comprising generating a secondary first credential portion based at least in part on the primary first credential portion and generating a secondary second credential portion based at least in part on the primary second credential portion;receive, from the first user device, a first request to authenticate the user account to an online service;responsive to the first request, generate a first signature by participating in a first signing protocol with the first user device, the first signature based at least in part on the primary first credential portion, the primary second credential portion, and a credential identifier (ID) for the online service;provide the first signature to a remote device associated with the online service to authenticate the user account to the online service;receive, from the second user device, a second request to authenticate the user account to the online service; andresponsive to the second request, generate a second signature by participating in a second signing protocol with the second user device, the second signature based at least in part on the secondary first credential portion, the secondary second credential portion, and the credential (ID) for the online service.
  • 10. The cloud computing device of claim 9, wherein the first signature matches the second signature.
  • 11. The cloud computing device of claim 9, wherein the primary first credential portion is retained by the first user device and the secondary first credential portion is retained by the second user device.
  • 12. The cloud computing device of claim 11, wherein the primary first credential portion is not available to the cloud computing device during generation of the primary first credential portion and during the first signing protocol.
  • 13. The cloud computing device of claim 9, wherein the first signing protocol is a threshold signature signing protocol.
  • 14. The cloud computing device of claim 9, wherein the computer-executable instructions further cause the one or more processors to: generate the secondary first credential portion by participating in an enrollment protocol with the first user device.
  • 15. The cloud computing device of claim 9, wherein the computer-executable instructions further cause the one or more processors to: select the credential ID by participating in a registration protocol with the first user device to register with the online service.
  • 16. The cloud computing device of claim 9, wherein the computer-executable instructions further cause the one or more processors to: receive a signed copy of the credential ID; andgenerate the second signature in the second signing protocol using the signed copy of the credential ID.
  • 17. A method comprising: communicating, by a first user device, with a cloud authenticator to generate a primary first credential portion and a primary second credential portion associated with a user account at the cloud authenticator;receiving, by the first user device, the primary first credential portion;participating in a signing protocol with the cloud authenticator to generate a signature based at least in part on the primary first credential portion and the primary second credential portion;at least partly in response to generating the signature, accessing an online service by the first user device; andcommunicating, by the first user device, with the cloud authenticator and with a second user device to generate a secondary first credential portion and a secondary second credential portion associated with the user account at the cloud authenticator.
  • 18. The method of claim 17, wherein the signing protocol comprises a threshold signature signing protocol and the signature comprises a threshold signature.
  • 19. The method of claim 17, further comprising: selecting, by the first user device and with the cloud authenticator, a credential identifier (ID) for the online service,wherein the participating in the signing protocol further comprises generating the signature based at least in part on the primary first credential portion, the primary second credential portion, and the credential ID.
  • 20. The method of claim 19, further comprising: signing, by the first user device, a copy of the credential ID to create a signed credential ID; andsending the signed credential ID to the cloud authenticator in association with the user account.