The present invention relates generally to communication networks, and more particularly to techniques for use in communication networks for secure dynamic delegation of authority to enable applications that involve access to protected resources by entities other than the resource owner.
This section introduces aspects that may help facilitate a better understanding of the inventions. Accordingly, the statements of this section are to be read in this light and are not to be understood as admissions about what is prior art or what is not prior art.
Various facilities available via communication networks, such as the World Wide Web, permit users to create their own applications or web pages. One example is known as a “mashup,” which is a web page or application that uses or combines data or functionality from two or many more sources to create a new service or application.
A problem arises, however, when the user is required to give his/her credentials (username and password) for one source to another source, thus exposing information between sources and giving one source full access to the other source. This may not be desirable to the user.
A protocol known as OAuth attempts to provide a solution to this problem. In general, the OAuth protocol (see http://oauth.net/) enables users to provide third-party access to their web resources without sharing their passwords. However, there are several limitations and weaknesses to this protocol. First, since the protocol is tied to the Hypertext Transfer Protocol (HTTP), it is not applicable to non-web applications. Second, since the protocol relies on the use of HTTP redirection, it is vulnerable to phishing attacks. The protocol also requires multiple round trips for obtaining delegated authorization, and it is not optimal for application performance. Lastly, since the protocol uses more than one type of delegation proof and a proofing scheme that involves repeated cryptographic signing, it is more complex than necessary.
As such, there is a need for an improved approach to authority delegation that overcomes these and other drawbacks.
Embodiments of the invention provide general, effective, and secure methods for dynamic delegation of authority to enable applications (e.g., mashups and third-party applications) on communication networks (e.g., World Wide Web or in Next Generation networks) that involve access to protected resources by entities other than the resource owner.
In a first aspect, a method comprises the following steps. In a communication network wherein a first computing device represents a resource owner and a second computing device represents a resource requestor, the resource owner detects an occurrence of an event, wherein the event occurrence represents a request to access one or more resources of the resource owner stored in a resource residence. The resource owner sends an authorization token to the resource requestor in response to the event occurrence, the authorization token serving as a proof of authorization delegated by the resource owner to be presented by the resource requestor to the resource residence so as to permit the resource requestor to access the one or more requested resources stored in the resource residence.
In one or more embodiments, the event occurrence may be receipt of a resource request by the resource owner from the resource requestor (e.g., pull method). Alternatively, the event occurrence may be an occurrence of a triggering event associated with an application program (e.g., push method). The resource residence may reside in a third computing device or it may reside in the first computing device. The authorization token may have one or more of a verifiable structure, a limited lifetime, and specify a method for authenticating the resource requestor or a level of assurance for authenticating the resource requestor. The verifiable structure may comprise a digital signature of the resource owner. The authorization token may specify one or more actions that are permitted to be performed in accordance with the one or more requested resources. The resource requestor may obtain the authorization token from the resource owner in one round trip. The mechanism for obtaining a token may be bound to an existing application protocol. The presentation of the authorization token to gain access to the one or more requested resources may also be bound to an existing application protocol.
Further, the proof of authorization delegated by the resource owner may be transferred from the resource requestor to at least another resource requestor such that the other resource requestor can present another authorization token to the resource residence so as to permit the other resource requestor to access the one or more requested resources stored in the resource residence. The other authorization token obtained by the other resource requestor may specify an action permission scope that is a subset of an action permission scope specified in the authorization token obtained directly from the resource owner by the resource requestor. In one embodiment, the other authorization token obtained by the other resource requestor does not change the method for authenticating the resource requestor or a level of assurance for authenticating the resource requestor. Further, the other authorization token may be a modified form of the authorization token originally received and the previous resource requestor performs the modification prior to sending the modified form of the authorization token to the other resource requestor.
Still further, the resource owner may authenticate the resource requestor before sending the authorization token to the resource requestor.
In a second aspect, a method comprises the following steps. In a communication network wherein a first computing device represents a resource owner and a second computing device represents a resource requestor, and wherein the resource owner detects an occurrence of an event and the event occurrence represents a request to access one or more resources of the resource owner stored in a resource residence, the resource requestor receives an authorization token sent by the resource owner in response to the event occurrence, the authorization token serving as a proof of authorization delegated by the resource owner to be presented by the resource requestor to the resource residence so as to permit the resource requestor to access the one or more requested resources stored in the resource residence.
In one or more embodiments, the resource residence may authenticate the resource requestor prior to the resource requestor presenting the authorization token to the resource residence. The resource residence verifies the authorization token presented by the resource requestor prior to acting on the one or more requested resources. Further, the resource residence may authenticate the resource requestor after the resource requestor presents the authorization token to the resource residence. The resource requestor may also transfer the proof of authorization delegated by the resource owner to at least another resource requestor. Such transfer may comprise the resource requestor sending another authorization token to the other resource requestor such that the other resource requestor can present the other authorization token to the resource residence so as to permit the other resource requestor to access the one or more requested resources stored in the resource residence.
In a third aspect, a method comprises the following steps. In a communication network wherein a first computing device represents a resource owner and a second computing device represents a resource requestor, and wherein the resource owner detects an occurrence of an event and the event occurrence represents a request to access one or more resources of the resource owner stored in a resource residence, and wherein the resource requestor receives an authorization token sent by the resource owner in response to the event occurrence, the resource residence receives the authorization token, the authorization token serving as a proof of authorization delegated by the resource owner to the resource requestor to permit the resource requestor to access the one or more requested resources stored in the resource residence.
Advantageously, the dynamic authority delegation techniques of the invention are applicable to web and non-web applications. Said inventive techniques do not rely on the use of HTTP redirection, and do not require multiple round trips for obtaining delegated authorization. Further, said inventive techniques are less complex than existing authority delegation schemes.
These and other objects, features and advantages of the present invention will become apparent from the following detailed description of illustrative embodiments thereof, which is to be read in connection with the accompanying drawings.
The present invention will be illustrated below in conjunction with exemplary communication networks and exemplary applications. It should be understood, however, that the invention is not limited to use with any particular type of communication network or application. The disclosed techniques are suitable for use with a wide variety of communication networks including web based and non-web based networks, and in numerous applications. In fact, the disclosed techniques may be implemented in any suitable communication network with any suitable applications wherein it would be desirable to provide dynamic delegation of authority to enable an application on a communication network that involves access to protected resources by entities other than the resource owners.
As used herein, “authority delegation” generally refers to one party, who has access to some item, giving permission to another party to access the item. By way of example, in the embodiments below, the resource owner gives the resource requestor permission to access some resource using an authorization token. The operation is considered “dynamic” in the sense that delegation is effected in real time as needed rather than through provisioning.
As used herein, a “token” generally refers to a data object or structure representing access control criteria and operations that is verifiable or can be authenticated.
As used herein, a “resource” generally refers to any item, data, information, or the like, that could be accessible over a communication network.
As used herein, an “application” generally refers to computer software designed to help a user or entity perform one or more specific tasks.
As will be explained herein, illustrative embodiments of the invention provide techniques whereby a resource requestor can dynamically obtain, directly from a resource owner, permission to access its resources in a resource residence. A “residence,” as used herein, generally refers to a storage location accessible via a communication network. A resource requestor can access the protected resources in the resource residence by presenting a proof of authorization delegated by the resource owner. The proof (namely an authorization token) has a verifiable structure and a limited lifetime, and specifies, among other things, the method or the level of assurance for authenticating the resource requestor. The resource requestor can obtain an authorization token dynamically from the resource owner in one round trip through a mechanism that is request-response based and can be bound to an existing application protocol. For example, a resource token request/response can be carried over HTTP or the Session Initial Protocol (SIP) as part of the message header or body or both. The mechanism for presenting the resource token to gain access to the protected resources is request-response based and can be bound to an existing application protocol. For example, the token can be carried over HTPP or SIP as part of the message header or body.
The resource owner 102 can be embodied as a user agent (in the case of an end user) or an authorization server (in the case of a service provider or an organization). Similarly, the resource requestor 104 can be embodied as a user agent (in the case of an end user) or an application server (in the case of a service provider or an organization). In a use case where “Alice” (operating computing device A) asks a photo-printing service provider to print her pictures for her Moscow trip stored on a server, the resource owner 102 (Alice) would be represented by a user agent (e.g., a web browser program executing on computing device A), and the resource requestor 104 (the photo-printing service provider) would be represented by an application server. In another use case where “Bob” (operating computing device B) is a subscriber of an online movie service, the resource owner 102 (the online movie service provider) would be represented by an authorization server, and the resource requestor 104 (Bob) would be represented by a user agent (e.g., a web browser program executing on computing device B).
To gain access to certain protected resources in the resource residence 106, the resource requestor 104 needs to obtain directly from the resource owner 102 an authorization token that has a basic structure 200 as illustratively shown in
If the first response from the resource owner is not an authentication request but rather includes the authorization token, and thus step 308 (i.e., check for receipt of a failure token response described below) yields a negative, the requestor saves the authorization token (for subsequent transmission to the resource residence) in step 310.
If, however, the first response from the resource owner is an authentication request, then in step 312, the resource requestor generates and sends an authentication response to the resource owner. In step 314, the resource requestor then checks a second response it receives from the resource owner and determines whether the second response includes the authorization token (thus assuming authentication was successful). If so, then step 308 (failure token response) yields a negative, and the requestor saves the authorization token (for subsequent transmission to the resource residence) in step 310. However, if authentication failed, then the second response received from the resource owner is a failure token response, i.e., meaning that the resource owner will not issue an authorization token to the requestor. It is to be understood that the technique used for authenticating the requestor can comprise any conventional authentication technique.
Armed with the authorization token, the resource requestor 104 can then request access to the protected resources in the resource residence 106. Upon receiving the resource request (see
1—Verify that the digital signature associated with the request is valid based on the digital signature method specified in the token;
2—Verify that the token has not expired in terms of time and the maximum number of use;
3—Verify that the requested resources and actions to be performed are part of the list of resources and associated rights specified in the token;
4—Verify that the name of the resource requestor matches the requestor name in the token; and
5—Authenticate the resource requestor using the method or a method of the strength level specified in the token.
In step 502, the resource requestor generates and sends a resource request to the request residence. In step 504, the resource requestor checks a first response it receives from the resource residence and determines, in step 506, whether the first response includes an authentication request (whereby the resource residence is requesting that the requestor be authenticated before the residence permits access to the resource by the requestor) or whether the first response is asking for the authorization token.
If the first response from the resource residence is not an authentication request but rather is asking for the authorization token (514 described below), and thus step 508 (i.e., check for receipt of a failure response described below) yields a negative, the requestor sends the authorization token (516 described below).
If, however, the first response from the resource residence is an authentication request, then in step 510, the resource requestor generates and sends an authentication response to the resource residence. In step 512, the resource requestor then checks a second response it receives from the resource residence and determines whether the second response is a failure response (508) or a request for the authorization token (514) thus assuming authentication was successful. If the latter, the requestor sends the authorization token (that it received from the resource owner in accordance with the protocol described above in the context of
In step 518, the resource requestor then checks a third response it receives from the resource residence and determines whether the third response is another authentication request, i.e., a subsequent authentication request by the residence to ensure that the requestor be authenticated with a method prescribed in the token. That is, for added security, the resource residence may need to re-authenticate the requestor each time a token is received. If so, steps 524, 526 and 528 are performed, which are similar to steps 510, 512 and 508 that are described above. In step 530, the requestor processes the response, which typically contains the requested resource(s).
However, going back to step 602, if the requestor has not been authenticated and an authorization token has not yet been provided by the requestor (step 608), an authentication process is performed in steps 610 (generate and send request to requestor), 612 (check authentication response), and 614 (confirm authentication success). If not successful, then a failure response is sent to requestor in step 616. However, if authentication was successful, then step 604 is performed (check whether requestor is owner) and if affirmative, then step 606 (apply resource actions and send response) is performed. However, after successful authentication (in step 614) and verification that the requestor is not the resource owner (in step 604), the residence asks the requestor for the authorization token in step 618, and checks whether it was provided by the requestor in step 620. If not, a failure response is sent in step 616.
Once the token has been received, the resource residence verifies the token in step 622. For example, a verification is performed to determine whether a token signature is valid, the requestor's names in the request and the token match, the token has not expired, the requested resources and actions are within scope (i.e., what is permitted for the requestor and/or resource being requested). It is to be understood that fewer or more verifications can be made to the token and its contents, depending on the structure of the token. If one or more aspects of the token can not be verified, a failure response is sent to the requestor, in step 624, and thus the resource is not made available to the requestor. However, if all aspects of the received token are verified, another authentication process may be requested by the residence according to the authentication requirement (in terms of the method or assurance level) specified in the token. This is done via steps 626, 628, 630 and 632, which are similar to steps 610, 612, and 614. Assuming the second authentication is successful, the resource actions are applied and a response sent (i.e., access to resource permitted) in step 634. If not, then a failure response is sent in step 624.
Returning again to
The combined fields of the list of resources and rights 218, the expiration time 220, and maximum number of use 222 set the overall delegation scope. The degree of transferability 224 indicates the degree that a token issued by the resource owner can be forwarded down to a series of token requestors starting from the original requestor. It can assume a value of a non-negative integer. A token of zero-th degree of transferability can not be forwarded. A token of N-th degree of transferability can be transferred by an original token requestor to a second token requestor to a third requestor and so on to the N-th requestor at most.
After obtaining a transferable token, the requestor can issue a new token based on the old one to a new requestor. As shown in
When verifying a forwarded token, the resource residence needs to check, in addition, that:
1—The degree of transferability is greater than the number of new requestors present;
2—All signatures are valid; and
3—The scopes are not broadened as the token is forwarded along the way.
A use case of transferable tokens is as follows: Alice publishes certain content on a content server and makes the associated content manager her proxy for handling access to her content by others. Note that to support tokens that are transferable or of limited number of use, the resource residence needs to keep state.
Lastly,
As shown, a computing device for resource owner 810 (e.g., 102 in
As would be readily apparent to one of ordinary skill in the art, the computing devices may be implemented as programmed computers operating under control of computer program code. The computer program code would be stored in a computer (or processor or machine) readable storage medium (e.g., a memory) and the code would be executed by a processor of the computer. Given this disclosure of the invention, one skilled in the art could readily produce appropriate computer program code in order to implement the protocols described herein.
Nonetheless,
It should be understood that the term “processor” as used herein is intended to include one or more processing devices, including a central processing unit (CPU) or other processing circuitry, including but not limited to one or more signal processors, one or more integrated circuits, and the like. Also, the term “memory” as used herein is intended to include memory associated with a processor or CPU, such as RAM, ROM, a fixed memory device (e.g., hard drive), or a removable memory device (e.g., diskette or CDROM). In addition, the term “I/O devices” as used herein is intended to include one or more input devices (e.g., keyboard, mouse) for inputting data to the processing unit, as well as one or more output devices (e.g., CRT display) for providing results associated with the processing unit.
Accordingly, software instructions or code for performing the methodologies of the invention, described herein, may be stored in one or more of the associated memory devices, e.g., ROM, fixed or removable memory, and, when ready to be utilized, loaded into RAM and executed by the CPU. That is, each computing device (810, 820, and 830) shown in
Although illustrative embodiments of the present invention have been described herein with reference to the accompanying drawings, it is to be understood that the invention is not limited to those precise embodiments, and that various other changes and modifications may be made by one skilled in the art without departing from the scope or spirit of the invention.