The security of computing resources and associated data is of high importance in many contexts. As an example, organizations often utilize networks of computing devices to provide a robust set of services to their users. Networks often span multiple geographic boundaries and often connect with other networks. An organization, for example, may support its operations using both internal networks of computing resources and computing resources managed by others. Computers of the organization, for instance, may communicate with computers of other organizations to access and/or provide data while using services of another organization. In many instances, organizations configure and operate remote networks using hardware managed by other organizations, thereby reducing infrastructure costs and achieving other advantages. With such configurations of computing resources, ensuring that access to the resources and the data they hold can be challenging, especially as the size and complexity of such configurations grows.
As another example, the distribution of content, such as audio, video, electronic games, electronic books, and the like, from those who own rights in the content to those who may consume the content, can create numerous challenges. For example, content providers and others involved in content's distribution often struggle with competing goals of widespread distribution and preventing unauthorized copying. Conventional techniques for controlling access to content often do not balance such goals effectively. For instance, in order to ensure that content can be consumed with minimal burden to the consumer, conventional techniques make it difficult to identify the source of unauthorized copies of content.
In the following description, various embodiments will be described. For purposes of explanation, specific configurations and details are set forth in order to provide a thorough understanding of the embodiments. However, it will also be apparent to one skilled in the art that the embodiments may be practiced without the specific details. Furthermore, well-known features may be omitted or simplified in order not to obscure the embodiment being described.
Techniques described and suggested herein include systems and methods for key generation and applications for using generated keys, in accordance with various embodiments. The keys may be used for various purposes, such as authentication and participation in message signing schemes, encryption, and/or other purposes for which keys are useful. In an embodiment, a computing resource provider provides computing services to customers based at least in part on electronic requests received from user devices of the services. The services may be any suitable service that may be offered including, but not limited to, access to data, access to computing resources to perform operations, access to data storage services, and the like. In some instances, services and other access to computing resources may require the direct and/or indirect use of keys managed by multiple authorities, some of which may be distrustful of others and, therefore, unwilling to share their keys with others.
In some embodiments, to ensure that services are provided in a secure manner, various embodiments of the present disclosure utilize techniques to authenticate requests (also referred to as “messages”) to ensure that the requests are legitimate. In an embodiment, requests are authenticated using a Hash Message Authentication Code (HMAC) algorithm or other suitable algorithm, as discussed in more detail below.
In an embodiment, both the authenticating party (e.g., user of services or party acting on behalf of the user) and the authenticator (e.g., provider of services or party acting on behalf of the provider) share a secret credential, which may be referred to as a key. An authenticator may store shared secret credentials for multiple users. As part of a transaction, the authenticating party may sign requests using the shared secret credential, thereby forming a signature. The signature may be provided to the authenticator with the requests. The authenticator may use its own copy of the shared secret credential to generate a signature for the received requests and, by comparing if the generated signature matches the received signature (for example by being identical to the received signature), determine whether the requests were signed using the shared secret credential. If determined that the requests were signed using the shared secret credential, the requests may be considered authentic and, therefore, it may be determined that the requests should be fulfilled.
In some embodiments, the authenticator obtains information from other sources to generate the shared key. For example, the authenticator may require that an authenticating party prove access to keys held by multiple authorities. To prove such access, in an embodiment, the authenticating party may utilize a signing key that is generated, by the authenticating party or another system, based at least in part on the keys of the multiple authorities. Techniques for constructing such keys are described in more detail below. The authenticator may also obtain the keys of the multiple authorities and/or information derived from to generate its own signing key that is usable to verify signatures submitted by the authenticating party. In an embodiment, signing keys of the authenticating party and the authenticator are generated in a manner such that the order of information derived from the multiple authorities' keys is inconsequential.
Because the interactions described above are symmetric (i.e., both utilize common information when performing their roles), the shared secret credentials that an authenticator keeps can be used to both authenticate authenticating parties or to act on their behalf. As a result, a high degree of security is desirable to protect these credentials. Maintaining high degrees of security may have negative performance and availability consequences. For example, maintaining a high degree of security may include maintaining a centralized system for key storage. Such centralized systems, however, may cause a scaling bottleneck since the addition of users and/or services causes a greater burden to the centralized system. If such a centralized system fails, it may be difficult or impossible to authenticate requests. Thus, centralization provides both advantages for security and disadvantages for scaling and availability of services. In addition, a centralized system makes it difficult in instances involving authorities whose keys are required, but who may distrust one another. For example, an authority may not trust the centralized system (and/or vice versa) and, therefore, the authority and centralized system may not provide each other's keys to one another.
In an embodiment, negative impacts of such systems (and other systems) are reduced by utilizing a signing protocol that derives from shared secret credentials artifacts that may be used to prove that an authenticating party has a shared secret credential and, therefore, is likely authorized to obtain access specified in requests signed with the artifacts. In an embodiment, such artifacts are obtained by configuring authenticator computer systems to accept as a signature a value that is based at least in part on a derivation of a shared credential, instead of the shared credential itself. The derivation of the shared credential may be such that, as described more fully below, the derivation does not allow for practical determination of the shared credential. In addition, in various embodiments, variations of the signing protocol allow for secret credentials to be derived from secret credentials of multiple authorities to allow proof of access to the secret credentials of the multiple authorities.
For example, in an embodiment, authenticating parties are able to sign signatures with
HMAC(M,HMAC(X,credential)),
where M is a message, and HMAC(X, credential) is an artifact derived from a shared secret credential. As used herein, HMAC(A, B) indicates a function whose operands are A and B and which is mathematically defined according to RFC 2104. As discussed elsewhere herein, HMAC(A, B) is used throughout the present disclosure for the purpose of illustration, but other functions, including but not limited to functions that are or are based at least in part on cryptographic hash functions may be used in accordance with various embodiments of the present disclosure. The value for X may be some value that is known both by the authenticating party and the authenticator, and may be publicly available. For example, X may be a current date, encoded in a predetermined manner to ensure that HMAC(X, credential) is computed consistently by the authenticating party and the authenticator. As another example, X may be an identifier of a service with which the artifact is usable. As yet another example, X may, but does not necessarily, encode multiple semantic meanings and be provided in a manner such that both the authenticating party and the authenticator consistently compute the artifact. The semantic meaning may be a restriction on use of the key, including meaning that indicates that no further derivations form the key should be used. Combining previous examples of the present paragraph, X may be encoded as “20110825/DDS” where the string left of the slash represents a date and the string right of the slash represents the name of a service with which an artifact computed with X is usable. Generally, X may be any value or set of values encoded consistently for both the authenticating party and the authenticator. It should be noted that other suitable functions other than HMAC functions may be used, as discussed below.
Returning to the example utilizing HMACs, in an embodiment, values for X are chosen to provide additional advantages. As noted, X may (but does not necessarily) correspond to one or more semantic meanings. Semantic meanings such as time stamps, service names, regional names, and the like are used, in an embodiment, to provide a system where artifacts created in accordance with techniques of the present disclosure provide corresponding restrictions on use of keys derived from X. In this manner, even though compromise of keys generated may allow authentication by undesired parties, restrictions used to encode keys allow for the adverse effects to be minimized when keys are compromised. As an example, time restrictions used to derive keys provide an efficient way for a system to check if a submitted signature was signed with a key that was valid at the time of signature submission. As a concrete example, if a current date is used to derive a key and an authenticator system only accepts signatures submitted on the current date, the authenticator system will determine that signatures generated using keys derived with different dates are invalid. Similarly, a key derived with an identifier of a particular service would be invalid for use with another service. With respect to multiple authorities, restrictions of one authority may be combined with restrictions of other authorities. For instance, if one authority derives a secret credential from a date and another authority derives a secret credential from a geographic region, a secret credential derived from the credentials of both authorities may only be valid for the geographic region on the date. Other examples are provided below.
As noted, various techniques of the present disclosure allow for multiple parameters to be used to derive keys. Parameters for key generation may be referred to as key-derivation material. In an embodiment, keys are derived from multiple parameters through multiple use of an HMAC function. For example, a key may be computed as follows:
KS=HMAC( . . . HMAC(HMAC(HMAC(K,P1),P2),P3) . . . ,PN),
where K is a shared secret credential and the Pi are parameters. The key, KS, may be used to generate a signature, such as:
S=HMAC(KS,M),
where M is a message, which may be canonicalized. In this manner, the key is derived in a layered manner, allowing for partial derivations of the key to be passed to various components of a distributed system. For example, KP1=HMAC(K, P1) may be computed and passed on to one or more components of a distributed system. The components that receive KP1 may compute KP2=HMAC(KP1, P2), where P2 may be the same for each component or different for some or all components. The values for KP2 calculated by the various components may pass the calculations to other components of the distributed systems which may compute KP3=HMAC(KP2, P3). Each component may cache the results it calculates, and possible results computed and calculated by other components. In this manner, more security may be provided around a data store that stores shared secret keys because computations of derived keys may be performed by other components of the distributed system. In instances where keys are derived from information provided from multiple authorities, such keys may be generated by each of the authorities and provided to others for use. In this manner, the authorities are able to provide information that is usable to prove access to the keys, without providing the keys themselves.
The techniques described herein are also usable in other contexts. For example, while much of the present disclosure utilizes signature generation and verification for the purpose of illustration, the techniques are applicable in other contexts, such as data encryption and digital rights management. For example, in an embodiment, keys derived such as described above may be used to implement a system in which a hierarchy of encryption keys is generated. Keys in the hierarchy may correspond to authorities in an organizational hierarchy. The term “organization,” unless otherwise clear from context, is intended to be read in the broad sense to imply a set of principals organized in some manner. In an embodiment, keys in the key hierarchy are distributed according to the organizational hierarchy. In particular, the keys are distributed to correspond with access rights of those in the organizational hierarchy. For instance, the keys may be distributed such that a principal with a key in the hierarchy is able to decrypt data that was encrypted with a different key that was derived from the key. In this manner, if a key is lost or otherwise inaccessible, a key from higher in the hierarchy will be usable to decrypt the data.
To enable such a system, data may be maintained from which one with a key in the hierarchy may be able to derive a key that was both derived from the key and used to encrypt data. As an example, parameters for deriving the key may be stored in a data store. Data may be stored in connection with encrypted data that identifies the key that encrypted the data. The data that identifies the key may be used to locate the parameters that were used to derive the key. As an alternative, the parameters may be stored in connection with the encrypted data such that, if the key is inaccessible, a key higher in the hierarchy may be used with the parameters to derive the key. A file management system or other system may maintain such information. For instance, when a principal uses a key to encrypt data and save the encrypted data, the parameters (or information that is usable to identify the parameters) may be saved as metadata for the data.
Techniques described herein also may be used in the context of digital rights management (DRM). For instance, keys derived according to the techniques described herein may be used to derive keys for encrypting content (or generally information) or for encrypting keys for decrypting the content (or other information). In addition, techniques described herein may be used to identify sources of unauthorized copies of content. In particular, in an embodiment, techniques for deriving keys, such as those discussed above, may be used to generate a hierarchy of keys. By providing a device (such as a content-processing device) a key at a non-leaf level of the key hierarchy and parameters for deriving keys lower in the hierarchy, a device can be given a access to a large number of keys by only providing the device a single key.
In an embodiment, a hierarchy of keys is generated and subsets of the keys are provided to devices. Special care is taken in the provisioning of keys to devices. For example, in an embodiment, keys are distributed to ensure that subsets of the devices are provided different sets of keys. The subsets of devices may comprise multiple devices and/or single devices. In addition, in an embodiment, keys are provided and encrypted content is published such that authorized devices are able to use at least one of the keys to decrypt the content.
Content may be published in a particular way to enable the identification of sources of unauthorized copies of the content. In an embodiment, the content comprises a plurality of records. Each of the records may comprise encrypted content and information from which a key may be identified to decrypt the content. Some of the records may have multiple copies of the content and information from which a key for descripting each copy may be identified to decrypt the content. The keys used to encrypt (and therefore decrypt) each copy of content in a record may vary. For example, one copy of content in a record may be encrypted using one key while another copy may be encrypted using another key. In addition, the copies of content for a record may also vary among themselves, such as by varying pixels for video content or otherwise varying the content copies. The content copies may be varied so as to be imperceptible or virtually imperceptible to a person, but in a manner such that a computing device can distinguish the copies from one another.
In many instances, unauthorized parties process encrypted content and publish or otherwise make unauthorized use of the content in a manner contrary to a holder of rights in the content. For example, users often referred to as “pirates” may process content, record the output of the processing, and publish the result with the protection removed using keys extracted from a device, often for profit. When content is encoded using the techniques described herein, such unauthorized copies of the content can be obtained and analyzed to identify the source of the content. In particular, records of the output that correspond to records of the original content that have multiple varied copies of a portion of the content may be identified and used to identify which keys were used to decrypt the content. Because the keys provided to the devices vary among the devices, the keys used to decrypt the content effectively function as an identifier of one or more devices. For example, if it is determined that a key K was used to decrypt the content, it may be determined that only devices that were provided K are suspect. Similarly, if it is known that a set of ten keys were used to decrypt the content, there may be a relatively small number of devices (perhaps a single device) that was provided those exact keys. In this manner, a relatively small amount of extra information can be included with content in order to effectively identify devices that produced unauthorized copies of the content.
The illustrative environment includes at least one application server 108 and a data store 110. It should be understood that there can be several application servers, layers, or other elements, processes, or components, which may be chained or otherwise configured, which can interact to perform tasks such as obtaining data from an appropriate data store. As used herein the term “data store” refers to any device or combination of devices capable of storing, accessing, and retrieving data, which may include any combination and number of data servers, databases, data storage devices, and data storage media, in any standard, distributed, or clustered environment. The application server can include any appropriate hardware and software for integrating with the data store as needed to execute aspects of one or more applications for the client device, handling a majority of the data access and business logic for an application. The application server provides access control services in cooperation with the data store, and is able to generate content such as text, graphics, audio, and/or video to be transferred to the user, which may be served to the user by the Web server in the form of HTML, XML, or another appropriate structured language in this example. The handling of all requests and responses, as well as the delivery of content between the client device 102 and the application server 108, can be handled by the Web server. It should be understood that the Web and application servers are not required and are merely example components, as structured code discussed herein can be executed on any appropriate device or host machine as discussed elsewhere herein.
The data store 110 can include several separate data tables, databases, or other data storage mechanisms and media for storing data relating to a particular aspect. For example, the data store illustrated includes mechanisms for storing production data 112 and user information 116, which can be used to serve content for the production side. The data store also is shown to include a mechanism for storing log data 114, which can be used for reporting, analysis, or other such purposes. It should be understood that there can be many other aspects that may need to be stored in the data store, such as for page image information and to access right information, which can be stored in any of the above listed mechanisms as appropriate or in additional mechanisms in the data store 110. The data store 110 is operable, through logic associated therewith, to receive instructions from the application server 108 and obtain, update, or otherwise process data in response thereto. In one example, a user might submit a search request for a certain type of item. In this case, the data store might access the user information to verify the identity of the user, and can access the catalog detail information to obtain information about items of that type. The information then can be returned to the user, such as in a results listing on a Web page that the user is able to view via a browser on the user device 102. Information for a particular item of interest can be viewed in a dedicated page or window of the browser.
Each server typically will include an operating system that provides executable program instructions for the general administration and operation of that server, and typically will include a computer-readable storage medium (e.g., a hard disk, random access memory, read only memory, etc.) storing instructions that, when executed by a processor of the server, allow the server to perform its intended functions. Suitable implementations for the operating system and general functionality of the servers are known or commercially available, and are readily implemented by persons having ordinary skill in the art, particularly in light of the disclosure herein.
The environment in one embodiment is a distributed computing environment utilizing several computer systems and components that are interconnected via communication links, using one or more computer networks or direct connections. However, it will be appreciated by those of ordinary skill in the art that such a system could operate equally well in a system having fewer or a greater number of components than are illustrated in
A fault zone, in an embodiment, is a collection of computing resources that are separated by one or more fault boundaries such that each fault zone is tolerant to a fault of another fault zone. As an example, each fault zone 204 may be a separate data center. Thus, if one data center ceases being operational, perhaps due to a power outage or other disruptive event, other data centers may continue to operate. The fault zones may be each located in different geographic locations and some or all of the fault zones may be separated by geopolitical boundaries. For example, two or more of the fault zones may be in different countries. It should be noted that, for the purpose of illustration, the present disclosure provides numerous examples where fault zones are data centers. However, fault zones can be defined in numerous other ways. For example, separate rooms in the same data center may be considered separate fault zones in accordance with various embodiments. As another example, computing resources in the same location, but supported by different backup power generators and/or supported by different network resources, may be considered different fault zones. As yet another example, data centers may be clustered such that each cluster of data centers may be considered a fault zone. Further, there may be many reasons a fault zone may fail, including reasons relating to power grid operation, public network operation, political assertions of power, and other reasons.
In an embodiment, customers 206 communicate with the computing resource provider 202 over a network 208, such as the Internet. The customers 206 may have resources configured in one or more of the fault zones 204 and may communicate with the resources by sending electronic messages, such as messages invoking a web-service application programming interface (API) of the computing resource provider in order to configure and operate the resources. Customers may utilize resources in multiple fault zones in order to decrease the effects of potential failures that impact the customers' resources. A customer who utilizes resources of the computing resource provider 202 to operate a publicly accessible website may, for example, maintain web and other servers in separate fault zones so that, if servers in one fault zone fail, the public may still access the web site by accessing servers in another fault zone.
It should be noted that the various embodiments illustrated in
As illustrated in
As noted above, various embodiments of the present disclosure allow for various levels of authority to be given for different reasons.
Returning to the illustrative example of
As noted above, each fault zone may include one or more services 406. Accordingly, as illustrated in
As noted, the particular allocation of authority as illustrated in
Various embodiments of the present disclosure relate to message signatures.
As illustrated in
In an embodiment, the process 600 includes obtaining 601 a key K. The key can be obtained in any suitable manner. For example, the key may be generated by a computer system performing the process 600. The key may be electronically received by a computer system performing the process 600. Generally, obtaining the key may be performed in any suitable manner. The key may be any suitable key for a particular signature algorithm being utilized. For example, if a hash-based message authentication code (HMAC) scheme is being used with a secure hash algorithm (SHA)-256 cryptographic hash function, the key may be a sequence of bytes, such as a sequence of 64 or fewer bytes. Different cryptographic hash functions, such as SHA-224, SHA-384, and SHA-512 may also be used.
In an embodiment, the process also includes canonicalizing a message M to form a canonicalized message Mc. Canonicalizing a message may include arranging information in the message in a format that allows a verifier to verify whether a signature of the message is valid. Generally, many information communication protocols transform the bits that comprise a message while leaving the message semantically identical. As a result, two semantically identical messages may comprise different sets of bits and, therefore, may result in different signatures. Accordingly, canonicalization allows for a straightforward way of ensuring that a signature can be verified. It should be noted, however, that some embodiments of the present disclosure do not require message canonicalization. For example, if various protocols being utilized do not result in semantically identical messages comprising different sets of bits, canonicalization may not be necessary and may be omitted. Generally, canonicalization may be omitted in any instance where signature verification is able to proceed successfully without manipulation of a signed message.
In an embodiment, a signature is generated by computing HMAC(K, Mc), where HMAC( ) is an HMAC function, such as described above. HMAC functions have several properties that make them particularly useful for various embodiments of the present disclosure. For example, HMAC functions can be computed efficiently by a computer system, thereby leaving computing resources available for other tasks. In addition, HMAC functions are preimage resistant (non-invertable). For instance, given a signature S=HMAC(K, M) with K a key and M a message, essentially no information is gained about the key K. For example, from S it would be computationally impossible or at least impractical to determine K from S. HMAC functions are also second preimage resistant. In other words, given S=HMAC(K, M) and M, it is impossible or at least computationally impractical to determine a message M′ different from M such that S=HMAC(K,M′). In addition, HMAC functions are forgery-resistant. For instance, given an oracle for S=HMAC(K, M), querying the oracle N times (N a positive integer) allows for the production of at most N signature-message pairs. In other words, given a set of signature-message pairs, it is impossible or computationally impractical to determine the key or determine a function that will produce a correct signature for a message not in the set.
While HMAC functions are particularly useful for various embodiments, other functions can be used. For example, any function with the above properties of HMAC functions may be used. In addition, other functions that do not necessarily have all (or any) of the above properties can be used, such as in circumstances where security is not of primary concern and/or where security is a concern, but is maintained through other mechanisms. It should be noted that various illustrations of various embodiments show specific inputs into HMAC functions, but that variations are possible. For example, the inputs to an HMAC function (or other function) may be different. As described above, for instance, one input is a key. However, this input may be derived from a key or otherwise based at least in part on a key. As an illustrative example, input may comprise a key with information, such as a signature scheme identifier (perhaps a version identifier), that is added to the key as a suffix, prefix, or otherwise. As another example, input may be information that is obtained by use of a mapping of the key to the information, which may be another key. Similarly an input shown as a message may be derived from a message. As another example variation considered as being within the scope of the present disclosure, the signature may not be the output of an HMAC function, but one or more values that are derived from the output of a HMAC function (or other suitable function). In some embodiments, the key and the message may be passed into the function in the reverse order.
Returning to the description of
In an embodiment, a signature S and message M are received 704. The signature S and message M may be received electronically from a submitter, such as a computing device that performed the process 700 of
Accordingly, in an embodiment, a determination is made 710 whether S′ is equal to the received signature S. In other words, a determination is made whether the received signature is sufficient, for example, because it is a signature that was generated using the key K. Thus, in an embodiment, if it is determined 710 that S′ and S are not equal, then the signature is 712 unverified. However, if the S′ is equal to S, then the signature is 714 verified. Depending on whether the signature is verified, appropriate action may be taken. For instance, if the message was a request for access to a computing resource, the requested access may be denied (at least temporarily). Similarly, if the message was a request for access to the computing resource and the signature was verified, the requested access may be granted. It should be noted, however, that the appropriate action to be taken can vary widely in various embodiments depending on the reason(s) signatures are received and verified.
As noted above, various embodiments of the present disclosure apply to numerous environments. In many environments, it is useful to have centralized management of various aspects of security maintenance.
As illustrated in
As illustrated in
Key propagation may be made in various ways. In an embodiment, keys are distributed over secure channels to various recipients. In some embodiments, the key authority propagates the same keys to each key zone. Also, some keys may be usable in multiple key zones. The key authority 802 may propagate keys usable in multiple key zones to those multiple key zones while refraining from propagating those keys to key zones where the keys cannot be used. Thus, in the example of a computing resource provider, the key authority 802 may propagate a key for a customer only to those key zones where the customer is able to use the key, such as data centers used to maintain computing resources of the customer.
Various embodiments of the present disclosure also provide for key propagation in manners providing for numerous advantages.
As illustrated in
As shown in the illustrative example of
Derivations of keys may be performed in numerous ways.
Further, as discussed more below, the process 1000 may be used multiple times to derive a key. For example, a key generated using the process 1000 (or a variation thereof) may be used to generate another key, using the same or another restriction. Using the terminology in the figure, Ri+1 may be, for instance, a sequence of bits that encodes information indicating where the key Ki+1 could be used. Ki+1 would become the key Ki for a next iteration of the process. For example, if the process 1000 was used to generate a key based on a geographic restriction, the key generated may be used to generate a key with a date-based restriction. Such a process may be utilized multiple times to use multiple restrictions to derive a key. As discussed more fully below, by using multiple restrictions to derive a key, one or more verifiers can enforce policy while verifying signatures. As a brief illustrative example, as part of a signature verification process, a verifier may determine an expected signature using a restriction, such as an encoding of a current date. If a signature was provided that was generated on a different date, then verification of the signature would fail, in accordance with an embodiment. Generally, if use of a signature does not comply with a restriction used to derive a key, signature verification may fail in accordance with various embodiments.
As illustrated in
HMAC(HMAC(HMAC(HMAC(HMAC(K,date),region),service),protocol),Mc).
In this example, K is a key, “date” is an encoding of a date, “region” is an encoding of an identifier of a region, “service” is an encoding of an identifier of a service, “protocol” corresponds to a particular message encoding protocol, and Mc is a canonicalized message. Thus, as illustrated in
HMAC(HMAC(HMAC(HMAC(K,date),region),service),protocol)
which itself is derived by use of the HMAC function multiple times, each time with a different restriction. With a signing key derived in this manner, it can be said that the signing key is specialized along a key path, the key path referring to the information (such as a restrictions) used as an operand. For instance, the key path for the example of
In the example of
As with other embodiments described herein, variations are considered as being within the scope of the present disclosure. For instance,
Key derivation may be performed in numerous ways in accordance with various embodiments. For instance, a single computing device could compute a signing key, in accordance with some embodiments. In accordance with other embodiments, multiple computing devices may collectively compute a signing key. As a specific illustrative example, referring to
Kregion=HMAC(HMAC(K,date),region)
and another computer may compute
Signing Key=HMAC(Kregion,Service).
As another example, a separate computer system may perform a different layer in the computation of the signing key. Referring to the example in the previous paragraph, instead of a single computer computing Kregion, one computer may compute
Kdate=HMAC(K,date)
and another computer may compute
Kregion=HMAC(Kdate,region).
The signer computer system 1306 may also, in various embodiments, generate KN on its own if, for example, the restrictions R1-RN are made available to the signer and/or made publicly available. In addition, the signer computer system 1306 may perform only part of the process for deriving KN on its own in various embodiments. For instance, the signer may obtain (perhaps from an appropriate key provider computer system) Ki, for some integer i that is less than N and restrictions Ri+1 through RN. The signer may then use Ki and restrictions Ri+1 through RN to generate the signing key, KN. Other variations are also considered as being within the scope of the present disclosure.
The signer computer system 1306 may use the key KN to sign messages to be verified by the verifier 1304. For instance, as illustrated, the signer 1306 computes the signature S=HMAC(KN, MC), where MC is a canonicalized version of a message M, also sent to the verifier. Because the verifier has KN, the verifier can independently canonicalize the message M and compute HMAC(KN, MC) to determine if the result of the computation matches the received signature S.
It should be noted that variations of the process illustrated in
The techniques described above (which are further described in U.S. patent Ser. No. 13/248,962, filed on Sep. 29, 2011, and titled “Parameter Based Key Derivation”), and variations thereof, may be used to construct keys that are usable for actions that depend on multiple authorities. For example, the above techniques may be modified to provide a key that is derived from multiple keys, each belonging to a corresponding authority and where at least one of the keys is not accessible by at least one of the authorities. As a concrete example, variations of the above techniques may be used to generate a key that is valid only if it is derived from two keys, each accessible by an authority but inaccessible to the other authority. A key holder of such a key may thereby be able to prove access to both keys and, therefore, validity of the key.
In many instances, it is desirable for the performance of certain actions to be requisite on involvement of multiple authorities. For example, the accomplishment of an act may require the use of two separate services. For security purposes, the two services may, for various reasons, be mutually distrustful of one another or perhaps one of the systems does not trust the other. Therefore, key sharing among the systems may be restricted accordingly.
(spec1, . . . ,specN)
where speci may be an encoding of a key path. The key path may include information for each node in the key path, the information for each node being separated from the information for another node by a delimiter. The information may be ordered, such as according to the order of the nodes in a corresponding key hierarchy. The information for one or more or all of the speci may be public information or at least information to parties participating in performance of the process 1500. In addition, a key-seed may, but does not necessarily, encode one or more restrictions that are meaningful to one or more participating authorities and/or a recipient of a message signed using, in part, the key-seed. With this latter variation, the techniques described herein may be adapted to accomplish dual (or higher-dimensional) control where each involved authority specifically agrees to an action (rather than originally intended scope of use).
Encoding the key-seed in this manner, in an embodiment, results in the key-seed being a logical statement of the precise key use, that is, full restriction among all authorized keys that a key holder is authorizing by producing a signature. In an embodiment, the process 1500 includes obtaining 1504 a partial key for each key holder including, in some embodiments, a partial key for a message signor performing the process 1500. A partial key for a key holder in an embodiment is a key specialized along a key path for a specific key holder. For example, an authority may have a key which is secret to that authority and perhaps a higher authority, such as a key authority, that is, an authority operable to generate and/or distribute keys for use and/or derivation of other keys. By encoding restrictions into that key, such as by using techniques described above, a partial key may be generated. Continuing the present example, a partial key may have the form:
Pki=HMAC(Kspeci,Key-Seed)
where Kspeci is a key specialized along the path corresponding to speci.
Obtaining the partial key for each key holder may be performed in various ways. For example, when each key holder is separated from a device performing the process 1500 by a network, each key holder may transmit their partial keys electronically over the network in a message or other transmission that encodes the partial key. As another example, information from which the partial key may be obtained may be transmitted to a computing device performing the method 1500. For instance, in an embodiment where specializing a key down a key path involves multiple indications of an HMAC process, information resulting from multiple invocations of the HMAC process may be provided to the computer along with other information from which the computing device can further invoke the HMAC process to derive the partial key. In other words, a result of partially performing a process of deriving a partial key may be provided for further completion of the process to generate the partial key. Generally, any method of obtaining the partial key for each key holder may be used.
From the obtained partial keys, in an embodiment, a signing key is computed based at least in part on the obtained partial keys and the computed key-seed. For example, as illustrated to the right of the flowchart in
SK=HMAC(PK1+ . . . +PKn,Key-Seed).
Once the signing key is computed 1506, in an embodiment, a message is signed 1508 using the computed signing key. The message may be any message for which a signature is required or desired such as a request to access a service or for another use, such as described above. For a message denoted in
S=HMAC(SK,Message).
While not illustrated as such, the message may be canonicalized, as discussed above. Generally, explicit discussion of canonicalization and other such processes may be omitted in the present disclosure for the purpose of clear illustration; however, it should be noted that such variations are within the scope of the present disclosure. Also, as noted below, keys derived in this way may be used for other cryptographic operations including, but not limited to, encryption and decryption of data, where the data may be, for example, content and/or another key.
In an embodiment, once the message is signed 1508, the message may be provided with the signature for verification by a verification computing device such as described above. As one example, the message and signature may be provided in one or more communications that collectively encode the signature and the message. Generally, any method of providing a message verifier information that is based at least in part on the message and a signature for the message and that is usable to the verifier to verify the signature may be used.
In embodiments, a verifier computer system uses information available to it in order to determine whether the signature provided with the message is authentic.
(spec1, . . . ,specN).
It should be noted that, while shown as following the receipt of a message and signature, computation of the key-seed may be performed at other times. For example, computation of the key-seed may be pre-computed prior to receipt of a message and signature for the message. Generally, as noted elsewhere herein, the performance of various steps of the processes described herein may be performed in an order that is different from that that is illustrated explicitly in the drawings. Such variations will be apparent to those with skill in the art and are not necessarily described herein explicitly.
Returning to the process 1600, a partial key is acquired from each of the various key holders, such as described above in connection with
A signing key is computed 1608 using the acquired partial keys and the key-seed such as described above in connection with
If it is determined that the message does not comply with the restrictions of the key-seed, action appropriate to the signature not being verified may be taken 1614, as discussed in more detail below. If, however, it is determined 1612 that the message does comply with the restrictions, in an embodiment, a determination is then made 1616 whether the generated signature matches the signature that was received. For example, determination whether the generated signature matches the received signature may include determining whether the generated signature and the received signature are identical. If the generated signature does not match the received signature, then an appropriate action to the signature not being verified may be taken 1614. An appropriate action may vary depending on the context in which the signature verification process 1600 is performed. For instance, the appropriate action may be to transmit a message to the message signing and/or to another computer system where the message encodes the fact that the signature was not successfully verified. Other appropriate action may be to deny access requested by a request encoded in the message. Similarly, if it is determined 1616 that the generated message signature matches the received message signature, then action appropriate to the signature being verified may be taken 1618. Such action may include, for instance, transmission of a message that encodes the fact that the signature was verified and/or providing access requested in the message. Another such action, in an embodiment, includes storage of the message and/or signature for later use. Storage of the message and/or signature may, therefore, indicate that the message was submitted with a valid signature.
As shown in
As shown in
Constructions, such as those described above, may be used in various schemes for signing messages. For example,
In
Even though the validity of the signature provided from the client 1802 to the verifier 1804 is dependent on the keys identified respectively by K1 and K2, in this example, the verifier is able to verify messages without having access to those keys. For example, in this particular illustration, Authority 1, labeled as 1806, and Authority 2, labeled as 1808, respectively provide the values of α and β to the verifier which may use the values of α and β to verify a message signed by the client. The message signed by the client may be signed using the techniques described above and using information accessible to the client. For instance, the client may have the keys identified by K1 and K2 and may be able to compute α and β and generate a signing key accordingly using α and β. Similarly, the client may have received α from Authority 1 and β from Authority 2 and may, therefore, use α and β to generate a signing key. As yet another example, the client may have a key derived along the partial key path of the key path shown in the figure. Such a key, using the techniques described above, may be used to generate α and β and therefore the signing used to produce a signature that can be verified by the verifier 1804. Numerous variations are considered as being within the scope of the present disclosure. For example, the client may have α and K2. A client may have β and K1. As yet another example, a client may have a and a key specialized along the key path shown from K2 to Y2. It will be understood to one with ordinary skill in the art that numerous other variations are also possible and such examples are considered as being within the scope of the present disclosure.
The authority labeled Authority 2, in this example, uses this message signature and a and its own value of β to determine whether the signature is valid, such as by techniques described above. Authority 2 may also derive β as needed, such as upon receipt of information from Authority 1, but may not persistently store the value. A verification decision may be then sent from Authority 1 to Authority 2 to allow Authority 1 to take appropriate action depending on whether the signature is valid as determined by Authority 2. In this manner, Authority 1 can determine or can take actions depending on the validity of the signature when that signature depends from K2 even though the Authority 1 does not have access to K2. Other variations are also considered as being within the scope of the present disclosure. For instance, referring to
Numerous variations of the present disclosure are considered as being within the scope of the present disclosure. For example,
As noted, various techniques of the present disclosure may be used in a variety of contexts and not just for use in message, signature and verification schemes. In particular, techniques of the present disclosure are usable for the purposes of key escrow. In many instances, it is desirable to have information encrypted for the sake of data security. However, it may be desirable that certain individuals within an organization are always able to access encrypted data regardless of who in the organization encrypted the data. Accordingly, techniques of the present disclosure are usable to enable the encryption of data in a way that provides for convenient access of data by different individuals within an organization (or other entity).
As illustrated in the figure, such a hierarchy may continue until a lowest level is achieved. Techniques of a present disclosure allow for a system that enables data to be encrypted by someone in the hierarchy. In such a system, the techniques also enable such a system to have a feature whereby the data is not decryptable by those lower in the hierarchy but is always decryptable by those higher in the hierarchy. For instance, if a CTO encrypts data, a vice-president would not be able decrypt the data without access to the CTO's key or a key in the key path from the CTO to the root of the hierarchy. Similarly, the CTO may use his or her own key to encrypt data and the CEO, corresponding to a root node in this example, may always be able to decrypt that data.
To the left of the center section of
As one example, a member of an organization may utilize the process 2400 to generate a key that that person can pass on to somebody lower in the hierarchy. By a member of an organization generating a key, it should be noted that the user of particular apparatuses, such as specifically configured computer systems, are used to generate the key under the control of the member. For instance, the member of the organization may provide user input into a computer system (either local to the user or remote from the user and accessible over a network) to cause the computer system to generate the key. The process 2400 may also be performed numerous times by a computer system that generates and distributes all the keys and passes them out according to their positions in the hierarchy. As yet another example, the process 2400 may be performed by an automated process without user input. For example, the process 2400 may be performed in response to a request transmitted electronically by another computer system.
Turning to the drawing, the process 2400 in an embodiment includes obtaining a key 2402. As shown in
Returning to
The process 2400 shown in
As a specific illustrative example, data (which may be metadata for the encrypted data) may contain, encode, or otherwise encode a key path. For this example, the key path may be a/b/c/d/e/f. The values for a, b, c, d, e, and f may comprise key-derivation material. In this manner, it may be determined that an authority having access to a key specialized along the key path encrypted the data.
In an embodiment, once the authority under which the data was encrypted is identified, a key is generated 2506 according to the identified authority's position in the authority hierarchy. Generating the key may be done in any suitable manner depending on where the authority's position is and what information is available from those above the authority's position in the hierarchy. For example, if a lower level employee encrypted data, keys from a path of the hierarchy proceeding from the root of the hierarchy to the lower level employee may be used to generate the employee's key and to decrypt 2508 the data using the generated key. For instance, in the example shown in
It should be noted that numerous variations of the process 2500 are considered to be within the scope of the present disclosure. For example, depending on what information is available, it may not be certain which key to use to decrypt the data. Because the hierarchies in typical organizations will not be unmanageably large, numerous keys may be tried for decrypting data before the data is successfully encrypted. For example, it may not be known who encrypted the data. Therefore, the hierarchy can be traversed in any manner, as the different keys are tried as they go along. For example, the CEO's key may be tried before trying keys of the officers of the board whose keys may be tried before the Vice-President, etc.
Other variations are also considered as being within the scope of the present disclosure. For example, keys constructed in accordance with the techniques described in connection with
Another example in which techniques of the present disclosure are particularly useful is in the context of digital rights management (DRM). For instance, as discussed below, techniques of the present disclosure may be utilized in order to encrypt content in a manner such that, if a party decrypts the content and makes the content unavailable to others in an unauthorized manner, the decrypted content can be used to identify a device that decrypted the content or at least a set of devices that decrypted the content.
As illustrated in
In an embodiment, techniques of the present disclosure include providing content in a manner such that one or more of the records include multiple copies of corresponding content and metadata for the content. Turning to the illustrative example of a video, each of one or more of the frames of the video may have multiple copies on a medium that encodes the content, such as a digital video disk (DVD) or other medium, such as a computer-readable storage medium. Referring to
In an embodiment, each copy of content for a record includes data encrypted under a different key ID. As will be discussed below, a device processing the contents may identify a record for which the device has a key that is enabled to decrypt the content. It should also be noted that any particular device may have enough keys to decrypt content for numerous copies of a record, not just only one. In addition, the copies of content for a record may vary amongst themselves. In an embodiment, the copies that vary from other copies do so in a manner that is detectible by a computing device, but that is not humanly distinguishable or, if humanly distinguishable, then in a manner that is calculated to be insignificant, such as in a manner that is calculated to be of minimal distraction to a person consuming the content (such as by watching a video when the content is video content). The content can be varied in numerous ways, such as by varying one or more pixels in an image, varying a characteristic of audio content, and the like. Pixels may be varied, for example, by varying the pixels' color, intensity, and other characteristics. Generally, any manner of modifying the information that encodes the content may be used.
As shown in
Further, providing content processing devices 2802 keys may be done in a manner that results in a record of associations between keys that have been provided and the devices to which the keys have been provided. Associations between keys and devices may be recorded at various granularities. For instance, in an embodiment, each device is provided with a unique set of keys. A database or other device may associate, through one or more database tables, each device with a unique set of keys that were provided to the device. As another example, multiple devices are provided with the same set of keys. A record associating devices with sets of keys may, therefore, associate groups of devices with sets of keys. The groups of devices may be organized in any suitable manner. For example, each device under the same model of a manufacturer may receive the same set of keys. Each device under the same manufacturer may receive the same set of keys. In addition, keys may be distributed in manner that results in multiple devices with no apparent relationship having the same set of keys. For instance, one thousand key sets may be randomly distributed to one million devices, thereby ensuring that at least some devices share the same set of keys.
As noted, different content processing devices 2802 are be provided with different sets of keys in various embodiments. The sets of keys provided to the devices may be chosen such that, for existing content produced in accordance with the present disclosure, when the content includes multiple copies of content for a record, every device will have a key usable to decrypt at least one of the copies. Similarly, future content may be produced such that, for existing devices having had keys provisioned (excluding, perhaps, devices that have been blacklisted or that have keys that have been blacklisted), the devices will have a key usable to decrypt at least one copy of content for records of the content having multiple records. Generally, keys may be produced and content may be produced in coordination to ensure that devices can properly decrypt when such is acceptable.
For instance, looking at the first content processing devices 2802 on
As illustrated in
Identifying a copy of the next record may include identifying a copy of content of the next record that the device is able to decrypt using information available to the device. For example, the device may analyze information identifying the keys available to the device and key-deriving material to determine one or more keys that the device can use to decrypt one or more copies of the content. For instance, in one example, referring to
In an embodiment, when a copy for the next record matching a stored key ID is identified 3006, a copy of the content for the next record matching the key ID is accessed 3008. The accessed copy may then be processed 3002, such as described above. In this manner, the content processing device 2802 selects, from multiple copies of records, records that it is able to decode by virtue of having or at least being able to derive a key appropriate for decoding the content. It should be noted that
To the right of the process 3100 shown in
For example, referring to
Once the devices having the set of matched keys is identified, then remedial action with respect to the identified devices may be taken 3210. Numerous actions may be taken as remedial action. For example, the keys used to provide the unauthorized copy of content may be blacklisted in a data store that is marked as not usable for the production of future content such that future content provided is not decodable by the identified devices. Other actions may also be taken, such as by submitting an electronic message to the manufacturer so that the manufacturer updates firmware of the devices and/or other actions.
In an embodiment, a determination is made 3306 whether there are additional keys to process and if there are, then the next key is accessed 3302 and devices having access to that accessed key are identified 3304 as described above. If there are no additional keys to process, then in an embodiment, the intersection of the identified sets of devices having access to each of the keys is identified 3308. As an illustrative example, it may be determined that all devices of two different manufactures have a first key, but that only certain models of each of the manufacturers have a second key, thus only devices from any of those manufacturers that have both keys would be identified in this intersection. Finally, performance of the process 3300, as illustrated in
Bus subsystem 3404 provides a mechanism for enabling the various components and subsystems of computer system 3400 to communicate with each other as intended. Although bus subsystem 3404 is shown schematically as a single bus, alternative embodiments of the bus subsystem may utilize multiple busses.
Network interface subsystem 3416 provides an interface to other computer systems and networks. Network interface subsystem 3416 serves as an interface for receiving data from and transmitting data to other systems from computer system 3400. For example, network interface subsystem 3416 may enable a user computer to connect to the Internet and facilitate communications using the Internet. The network interface subsystem 3416 may also facilitate the receipt and/or transmission of data on other networks.
User interface input devices 3412 may include a keyboard, pointing devices such as a mouse, trackball, touchpad, or graphics tablet, a scanner, a barcode scanner, a touch screen incorporated into the display, audio input devices such as voice recognition systems, microphones, and other types of input devices. In general, use of the term “input device” is intended to include all possible types of devices and mechanisms for inputting information to computer system 3400.
User interface output devices 3414 may include a display subsystem, a printer, a fax machine, or non-visual displays such as audio output devices, etc. The display subsystem may be a cathode ray tube (CRT), a flat-panel device such as a liquid crystal display (LCD), light emitting diode (LED) display, or a projection or other display device. In general, use of the term “output device” is intended to include all possible types of devices and mechanisms for outputting information from computer system 3400. The output device(s) 3414 may be used, for example, to present user interfaces to facilitate user interaction with applications performing process descried herein and variations therein, when such interaction is appropriate.
Storage subsystem 3406 provides a computer-readable storage medium for storing the basic programming and data constructs that provide the functionality of the present invention. Applications (programs, code modules, instructions) that when executed by a processor provide the functionality of the present invention may be stored in storage subsystem 3406. These Application modules or instructions may be executed by processor(s) 3402. Storage subsystem 3406 may also provide a repository for storing data used in accordance with the present invention. Storage subsystem 3406 may comprise memory subsystem 3408 and file/disk storage subsystem 3410.
Memory subsystem 3408 may include a number of memories including a main random access memory (RAM) 3418 for storage of instructions and data during program execution and a read only memory (ROM) 3420 in which fixed instructions are stored. File storage subsystem 3410 provides a non-transitory persistent (non-volatile) storage for program and data files, and may include a hard disk drive, a floppy disk drive along with associated removable media, a Compact Disk Read Only Memory (CD-ROM) drive, an optical drive, removable media cartridges, and other like storage media.
Computer system 3400 can be of various types including a personal computer, a portable computer, tablet computer, a workstation, a network computer, a mainframe, a kiosk, a server or any other data processing system. Due to the ever-changing nature of computers and networks, the description of computer system 3400 depicted in
As noted in several places throughout the present disclosure, variations of that which is explicitly described are considered as being within the scope of the present disclosure. For example, an information processing system, such as the computer system 3400, may also be configured with additional capabilities that may be utilized according to adaptations of the various techniques described above. For example, as noted above, multiple copies of a portion of data may be provided to an information processing system, such as described above. In some instances (or even all, in some embodiments) the information processing system may have access to enough keys to decrypt a plurality of the multiple copies of the portion of data. In such instances, the information processing system may select from the multiple copies. For instance, the information processing system may be programmed to select a copy to decrypt based at least in part on information available to the information processing device. The information may be any suitable information including, but not limited to, global positioning system coordinates, a device serial number for the information processing system, information provided by an external computer system such as a content provider/publisher computer system, and/or any information that effectively distinguishes the information processing system from at least one other information processing system and/or any information based at least in part thereon. In this manner, the selections of which copies to decrypt are usable to distinguish the information processing system from other information processing systems and, therefore, may be used forensically, such as to identify the source of unauthorized copies of content. For instance, a computer system with access to output of an information processing system may be able to distinguish, based at least in part on one or more selections of copies to decrypt, between information processing devices that would have made such selections and information processing devices that would not have made such selections. Distribution of keys to the information processing devices may be made in a coordinated manner to enable such distinctions.
The techniques described explicitly herein may also be adapted, combined, and otherwise modified. As just one example, techniques involving multiple authorities may be combined with techniques involving DRM such that, for instance, sources of unauthorized content is identifiable, but also such that proof of access to multiple keys is necessary to decrypt the content. In addition, specific uses (e.g. message signing and verification and encryption/decryption of data) of keys derived using the various techniques described herein are used for the purpose of illustration, but other uses of keys are also considered as being within the scope of the present disclosure. For example, keys derived in connection with multiple authorities (or, generally, any derived key) can be used not only for message signing and verification, but for the encryption and decryption of data. Generally, keys derived in accordance with the various techniques described herein can be used for any suitable cryptographic operation including, but not limited to, encryption, decryption, signature generation, signature verification, zero knowledge proof construction, non-signature based interactive authentication, input into a bit commitment protocol, password constructions to create a family of passwords reconstructable by a base key, and other cryptographic operations and combinations thereof.
The various embodiments further can be implemented in a wide variety of operating environments, which in some cases can include one or more user computers, computing devices, or processing devices which can be used to operate any of a number of applications. User or client devices can include any of a number of general purpose personal computers, such as desktop or laptop computers running a standard operating system, as well as cellular, wireless, and handheld devices running mobile software and capable of supporting a number of networking and messaging protocols. Such a system also can include a number of workstations running any of a variety of commercially-available operating systems and other known applications for purposes such as development and database management. These devices also can include other electronic devices, such as dummy terminals, thin-clients, gaming systems, and other devices capable of communicating via a network.
Most embodiments utilize at least one network that would be familiar to those skilled in the art for supporting communications using any of a variety of commercially-available protocols, such as TCP/IP, OSI, FTP, UPnP, NFS, CIFS, and AppleTalk. The network can be, for example, a local area network, a wide-area network, a virtual private network, the Internet, an intranet, an extranet, a public switched telephone network, an infrared network, a wireless network, and any combination thereof.
In embodiments utilizing a Web server, the Web server can run any of a variety of server or mid-tier applications, including HTTP servers, FTP servers, CGI servers, data servers, Java servers, and business application servers. The server(s) also may be capable of executing programs or scripts in response requests from user devices, such as by executing one or more Web applications that may be implemented as one or more scripts or programs written in any programming language, such as Java®, C, C# or C++, or any scripting language, such as Perl, Python, or TCL, as well as combinations thereof. The server(s) may also include database servers, including without limitation those commercially available from Oracle®, Microsoft®, Sybase®, and IBM®.
The environment can include a variety of data stores and other memory and storage media as discussed above. These can reside in a variety of locations, such as on a storage medium local to (and/or resident in) one or more of the computers or remote from any or all of the computers across the network. In a particular set of embodiments, the information may reside in a storage-area network (“SAN”) familiar to those skilled in the art. Similarly, any necessary files for performing the functions attributed to the computers, servers, or other network devices may be stored locally and/or remotely, as appropriate. Where a system includes computerized devices, each such device can include hardware elements that may be electrically coupled via a bus, the elements including, for example, at least one central processing unit (CPU), at least one input device (e.g., a mouse, keyboard, controller, touch screen, or keypad), and at least one output device (e.g., a display device, printer, or speaker). Such a system may also include one or more storage devices, such as disk drives, optical storage devices, and solid-state storage devices such as random access memory (“RAM”) or read-only memory (“ROM”), as well as removable media devices, memory cards, flash cards, etc.
Such devices also can include a computer-readable storage media reader, a communications device (e.g., a modem, a network card (wireless or wired), an infrared communication device, etc.), and working memory as described above. The computer-readable storage media reader can be connected with, or configured to receive, a computer-readable storage medium, representing remote, local, fixed, and/or removable storage devices as well as storage media for temporarily and/or more permanently containing, storing, transmitting, and retrieving computer-readable information. The system and various devices also typically will include a number of software applications, modules, services, or other elements located within at least one working memory device, including an operating system and application programs, such as a client application or Web browser. It should be appreciated that alternate embodiments may have numerous variations from that described above. For example, customized hardware might also be used and/or particular elements might be implemented in hardware, software (including portable software, such as applets), or both. Further, connection to other computing devices such as network input/output devices may be employed.
Storage media and computer readable media for containing code, or portions of code, can include any appropriate media known or used in the art, including storage media and communication media, such as but not limited to volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage and/or transmission of information such as computer readable instructions, data structures, program modules, or other data, including RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disk (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the a system device. Based on the disclosure and teachings provided herein, a person of ordinary skill in the art will appreciate other ways and/or methods to implement the various embodiments.
The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereunto without departing from the broader spirit and scope of the invention as set forth in the claims.
Other variations are within the spirit of the present disclosure. Thus, while the disclosed techniques are susceptible to various modifications and alternative constructions, certain illustrated embodiments thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the invention to the specific form or forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention, as defined in the appended claims.
The use of the terms “a” and “an” and “the” and similar referents in the context of describing the disclosed embodiments (especially in the context of the following claims) are to be construed to cover both the singular and the plural, unless otherwise indicated herein or clearly contradicted by context. The terms “comprising,” “having,” “including,” and “containing” are to be construed as open-ended terms (i.e., meaning “including, but not limited to,”) unless otherwise noted. The term “connected” is to be construed as partly or wholly contained within, attached to, or joined together, even if there is something intervening. Recitation of ranges of values herein are merely intended to serve as a shorthand method of referring individually to each separate value falling within the range, unless otherwise indicated herein, and each separate value is incorporated into the specification as if it were individually recited herein. All methods described herein can be performed in any suitable order unless otherwise indicated herein or otherwise clearly contradicted by context. The use of any and all examples, or exemplary language (e.g., “such as”) provided herein, is intended merely to better illuminate embodiments of the invention and does not pose a limitation on the scope of the invention unless otherwise claimed. No language in the specification should be construed as indicating any non-claimed element as essential to the practice of the invention.
Preferred embodiments of this disclosure are described herein, including the best mode known to the inventors for carrying out the invention. Variations of those preferred embodiments may become apparent to those of ordinary skill in the art upon reading the foregoing description. The inventors expect skilled artisans to employ such variations as appropriate, and the inventors intend for the invention to be practiced otherwise than as specifically described herein. Accordingly, this invention includes all modifications and equivalents of the subject matter recited in the claims appended hereto as permitted by applicable law. Moreover, any combination of the above-described elements in all possible variations thereof is encompassed by the invention unless otherwise indicated herein or otherwise clearly contradicted by context.
All references, including publications, patent applications, and patents, cited herein are hereby incorporated by reference to the same extent as if each reference were individually and specifically indicated to be incorporated by reference and were set forth in its entirety herein.
This application is a continuation of U.S. patent application Ser. No. 14/282,386, filed on May 20, 2014, entitled “SOURCE IDENTIFICATION FOR UNAUTHORIZED COPIES OF CONTENT,” which is a divisional application of U.S. patent application Ser. No. 13/431,898, filed on Mar. 27, 2012, entitled “SOURCE IDENTIFICATION FOR UNAUTHORIZED COPIES OF CONTENT,” the content of both of which is incorporated by reference herein in its entirety. This application is related to and incorporates by reference for all purposes the full disclosure of co-pending U.S. patent application Ser. No. 13/431,760, filed Mar. 27, 2012, entitled “MULTIPLE AUTHORITY KEY DERIVATION,” and U.S. patent application Ser. No. 13/431,882, filed Mar. 27, 2012, entitled “HIERARCHICAL DATA ACCESS TECHNIQUES,” the content of both of which is incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5179591 | Hardy et al. | Jan 1993 | A |
5200999 | Matyas et al. | Apr 1993 | A |
5497421 | Kaufman et al. | Mar 1996 | A |
5850443 | Van Oorschot et al. | Dec 1998 | A |
5956404 | Schneier et al. | Sep 1999 | A |
6084969 | Wright et al. | Jul 2000 | A |
6097817 | Bilgic et al. | Aug 2000 | A |
6185316 | Buffam | Feb 2001 | B1 |
6295359 | Cordery et al. | Sep 2001 | B1 |
6381696 | Doyle | Apr 2002 | B1 |
6453416 | Epstein | Sep 2002 | B1 |
6601172 | Epstein | Jul 2003 | B1 |
6826686 | Peyravian et al. | Nov 2004 | B1 |
6851054 | Wheeler et al. | Feb 2005 | B2 |
6957393 | Fano et al. | Oct 2005 | B2 |
6959394 | Brickell et al. | Oct 2005 | B1 |
6985583 | Brainard et al. | Jan 2006 | B1 |
7010689 | Matyas et al. | Mar 2006 | B1 |
7073195 | Brickell et al. | Jul 2006 | B2 |
7139917 | Jablon | Nov 2006 | B2 |
7228417 | Roskind | Jun 2007 | B2 |
7320076 | Caronni | Jan 2008 | B2 |
7512965 | Amdur et al. | Mar 2009 | B1 |
7685430 | Masurkar | Mar 2010 | B1 |
7721322 | Sastry et al. | May 2010 | B2 |
7757271 | Amdur et al. | Jul 2010 | B2 |
7765584 | Roskind | Jul 2010 | B2 |
7836306 | Pyle et al. | Nov 2010 | B2 |
7890767 | Smith et al. | Feb 2011 | B2 |
7913084 | Medvinsky et al. | Mar 2011 | B2 |
7917764 | Futa | Mar 2011 | B2 |
8006289 | Hinton et al. | Aug 2011 | B2 |
8024562 | Gentry et al. | Sep 2011 | B2 |
8041954 | Plesman | Oct 2011 | B2 |
8059820 | Malaviarachchi et al. | Nov 2011 | B2 |
8151116 | van de Horst et al. | Apr 2012 | B2 |
8254571 | Boyen | Aug 2012 | B1 |
8275356 | Hickie | Sep 2012 | B2 |
8332922 | Dickinson et al. | Dec 2012 | B2 |
8370638 | Duane et al. | Feb 2013 | B2 |
8386800 | Kocher et al. | Feb 2013 | B2 |
8387117 | Eom et al. | Feb 2013 | B2 |
8418222 | Gbadegesin et al. | Apr 2013 | B2 |
8423759 | Moreau | Apr 2013 | B2 |
8453198 | Band et al. | May 2013 | B2 |
8464058 | Chen et al. | Jun 2013 | B1 |
8464354 | Teow et al. | Jun 2013 | B2 |
8533772 | Garg et al. | Sep 2013 | B2 |
8543916 | Anderson et al. | Sep 2013 | B2 |
8561152 | Novak et al. | Oct 2013 | B2 |
8621561 | Cross et al. | Dec 2013 | B2 |
8688813 | Maes | Apr 2014 | B2 |
8695075 | Anderson et al. | Apr 2014 | B2 |
8739308 | Roth | May 2014 | B1 |
8745205 | Anderson et al. | Jun 2014 | B2 |
8776190 | Cavage et al. | Jul 2014 | B1 |
8776204 | Faynberg et al. | Jul 2014 | B2 |
8868923 | Hamlet et al. | Oct 2014 | B1 |
8892865 | Roth | Nov 2014 | B1 |
20010008013 | Johnson et al. | Jul 2001 | A1 |
20010018739 | Anderson et al. | Aug 2001 | A1 |
20020016840 | Herzog et al. | Feb 2002 | A1 |
20020067832 | Jablon | Jun 2002 | A1 |
20020112181 | Smith | Aug 2002 | A1 |
20020161723 | Asokan et al. | Oct 2002 | A1 |
20020161998 | Cromer et al. | Oct 2002 | A1 |
20020162019 | Berry et al. | Oct 2002 | A1 |
20020194483 | Wenocur et al. | Dec 2002 | A1 |
20020198848 | Michener | Dec 2002 | A1 |
20030016826 | Asano et al. | Jan 2003 | A1 |
20030041110 | Wenocur et al. | Feb 2003 | A1 |
20030120940 | Vataja | Jun 2003 | A1 |
20030135740 | Talmor et al. | Jul 2003 | A1 |
20030145197 | Lee et al. | Jul 2003 | A1 |
20030149781 | Yared et al. | Aug 2003 | A1 |
20030188117 | Yoshino et al. | Oct 2003 | A1 |
20030200450 | England et al. | Oct 2003 | A1 |
20040088260 | Foster et al. | May 2004 | A1 |
20040103096 | Larsen | May 2004 | A1 |
20040128505 | Larsen | Jul 2004 | A1 |
20040128510 | Larsen | Jul 2004 | A1 |
20040131185 | Kakumer | Jul 2004 | A1 |
20040143733 | Ophir et al. | Jul 2004 | A1 |
20040158734 | Larsen | Aug 2004 | A1 |
20040172535 | Jakobsson et al. | Sep 2004 | A1 |
20050036611 | Seaton et al. | Feb 2005 | A1 |
20050043999 | Ji et al. | Feb 2005 | A1 |
20050060580 | Chebolu et al. | Mar 2005 | A1 |
20050080914 | Lerner et al. | Apr 2005 | A1 |
20050132192 | Jeffries et al. | Jun 2005 | A1 |
20050132215 | Wang et al. | Jun 2005 | A1 |
20050166263 | Nanopoulos et al. | Jul 2005 | A1 |
20050235148 | Scheidt et al. | Oct 2005 | A1 |
20050271207 | Frey | Dec 2005 | A1 |
20050273862 | Benaloh | Dec 2005 | A1 |
20050278547 | Hyndman et al. | Dec 2005 | A1 |
20060070116 | Park | Mar 2006 | A1 |
20060075462 | Golan et al. | Apr 2006 | A1 |
20060094406 | Cortegiano | May 2006 | A1 |
20060094410 | Cortegiano | May 2006 | A1 |
20060100928 | Waleczak, Jr. et al. | May 2006 | A1 |
20060130100 | Pentland | Jun 2006 | A1 |
20060149677 | Shahine et al. | Jul 2006 | A1 |
20060165233 | Nonaka et al. | Jul 2006 | A1 |
20060174110 | Strom | Aug 2006 | A1 |
20060174125 | Brookner | Aug 2006 | A1 |
20060190331 | Tollinger et al. | Aug 2006 | A1 |
20060206440 | Anderson et al. | Sep 2006 | A1 |
20060206925 | Dillaway et al. | Sep 2006 | A1 |
20060218625 | Pearson et al. | Sep 2006 | A1 |
20060230284 | Fiske | Oct 2006 | A1 |
20060256961 | Brainard et al. | Nov 2006 | A1 |
20060271785 | Holtmanns et al. | Nov 2006 | A1 |
20060282878 | Stanley et al. | Dec 2006 | A1 |
20070005955 | Pyle et al. | Jan 2007 | A1 |
20070033396 | Zhang et al. | Feb 2007 | A1 |
20070037552 | Lee et al. | Feb 2007 | A1 |
20070061571 | Hammes et al. | Mar 2007 | A1 |
20070061885 | Hammes et al. | Mar 2007 | A1 |
20070136361 | Lee et al. | Jun 2007 | A1 |
20070157309 | Bin et al. | Jul 2007 | A1 |
20070174614 | Duane et al. | Jul 2007 | A1 |
20070186102 | Ng | Aug 2007 | A1 |
20070234410 | Geller | Oct 2007 | A1 |
20070250706 | Oba | Oct 2007 | A1 |
20070277231 | Medvinsky et al. | Nov 2007 | A1 |
20080010665 | Hinton et al. | Jan 2008 | A1 |
20080040773 | AlBadarin et al. | Feb 2008 | A1 |
20080066150 | Lim | Mar 2008 | A1 |
20080080718 | Meijer et al. | Apr 2008 | A1 |
20080083036 | Ozzie et al. | Apr 2008 | A1 |
20080114995 | Jogand-Coulomb | May 2008 | A1 |
20080163337 | Tuliani et al. | Jul 2008 | A1 |
20080168530 | Kuehr-McLaren et al. | Jul 2008 | A1 |
20080182592 | Cha et al. | Jul 2008 | A1 |
20080219449 | Ball et al. | Sep 2008 | A1 |
20080222694 | Nakae | Sep 2008 | A1 |
20080301444 | Kim et al. | Dec 2008 | A1 |
20080301630 | Arnold et al. | Dec 2008 | A1 |
20080313719 | Kaliski, Jr. et al. | Dec 2008 | A1 |
20090013402 | Plesman | Jan 2009 | A1 |
20090019134 | Bellifemine et al. | Jan 2009 | A1 |
20090049518 | Roman et al. | Feb 2009 | A1 |
20090172793 | Newstadt et al. | Jul 2009 | A1 |
20090210712 | Fort | Aug 2009 | A1 |
20090217385 | Teow et al. | Aug 2009 | A1 |
20090254572 | Redlich et al. | Oct 2009 | A1 |
20090320093 | Glazier et al. | Dec 2009 | A1 |
20100017603 | Jones | Jan 2010 | A1 |
20100083001 | Shah et al. | Jan 2010 | A1 |
20100037304 | Canning et al. | Feb 2010 | A1 |
20100058060 | Schneider | Mar 2010 | A1 |
20100058072 | Teow et al. | Mar 2010 | A1 |
20100071056 | Cheng | Mar 2010 | A1 |
20100111296 | Brown et al. | May 2010 | A1 |
20100125894 | Yasrebi et al. | May 2010 | A1 |
20100131756 | Schneider | May 2010 | A1 |
20100142704 | Camenisch et al. | Jun 2010 | A1 |
20100180130 | Stahl et al. | Jul 2010 | A1 |
20100205649 | Becker et al. | Aug 2010 | A1 |
20100239095 | Carter et al. | Sep 2010 | A1 |
20100251347 | Roskind | Sep 2010 | A1 |
20100262988 | Bauer et al. | Oct 2010 | A1 |
20100269156 | Hohlfeld et al. | Oct 2010 | A1 |
20100281264 | Sakumoto | Nov 2010 | A1 |
20100290476 | Brindle et al. | Nov 2010 | A1 |
20100332845 | Asaka | Dec 2010 | A1 |
20110004753 | Gomi et al. | Jan 2011 | A1 |
20110010538 | Falk et al. | Jan 2011 | A1 |
20110035593 | Pyle et al. | Feb 2011 | A1 |
20110055562 | Adelman et al. | Mar 2011 | A1 |
20110055585 | Lee | Mar 2011 | A1 |
20110078107 | Almeida et al. | Mar 2011 | A1 |
20110083015 | Meier | Apr 2011 | A1 |
20110099362 | Haga et al. | Apr 2011 | A1 |
20110131415 | Schneider | Jun 2011 | A1 |
20110138192 | Kocher et al. | Jun 2011 | A1 |
20110167479 | Maes | Jul 2011 | A1 |
20110179469 | Blinn et al. | Jul 2011 | A1 |
20110231940 | Perumal et al. | Sep 2011 | A1 |
20110239283 | Chern | Sep 2011 | A1 |
20110252229 | Belenkiy et al. | Oct 2011 | A1 |
20110265172 | Sharma et al. | Oct 2011 | A1 |
20110296497 | Becker | Dec 2011 | A1 |
20110311055 | Parann-Nissany | Dec 2011 | A1 |
20110320606 | Madduri et al. | Dec 2011 | A1 |
20120017095 | Blenkhorn et al. | Jan 2012 | A1 |
20120020474 | Kudoh et al. | Jan 2012 | A1 |
20120023334 | Brickell et al. | Jan 2012 | A1 |
20120036551 | Le Saint et al. | Feb 2012 | A1 |
20120054625 | Pugh et al. | Mar 2012 | A1 |
20120060035 | Kalmady et al. | Mar 2012 | A1 |
20120106735 | Fukuda | May 2012 | A1 |
20120110636 | Van Biljon et al. | May 2012 | A1 |
20120144034 | McCarty | Jun 2012 | A1 |
20120159577 | Belinkiy et al. | Jun 2012 | A1 |
20120233216 | Lim | Sep 2012 | A1 |
20120243687 | Li et al. | Sep 2012 | A1 |
20120245978 | Jain et al. | Sep 2012 | A1 |
20120265690 | Bishop et al. | Oct 2012 | A1 |
20120317414 | Glover | Dec 2012 | A1 |
20130031255 | Maloy et al. | Jan 2013 | A1 |
20130086662 | Roth | Apr 2013 | A1 |
20130086663 | Roth et al. | Apr 2013 | A1 |
20130111217 | Kopasz et al. | May 2013 | A1 |
20130132232 | Pestoni et al. | May 2013 | A1 |
20130145447 | Maron | Jun 2013 | A1 |
20130166918 | Shahbazi et al. | Jun 2013 | A1 |
20130191884 | Leicher et al. | Jul 2013 | A1 |
20130198519 | Marien | Aug 2013 | A1 |
20130254536 | Glover | Sep 2013 | A1 |
20130282461 | Ovick et al. | Oct 2013 | A1 |
20130318630 | Lam | Nov 2013 | A1 |
20140013409 | Halageri | Jan 2014 | A1 |
20140082715 | Grajek et al. | Mar 2014 | A1 |
20140122866 | Haeger et al. | May 2014 | A1 |
20140181925 | Smith | Jun 2014 | A1 |
20140208408 | Bilgen et al. | Jul 2014 | A1 |
20140281477 | Nayshtut et al. | Sep 2014 | A1 |
20140281487 | Klausen et al. | Sep 2014 | A1 |
20150082039 | Stalzer et al. | Mar 2015 | A1 |
20150089614 | Mathew et al. | Mar 2015 | A1 |
Number | Date | Country |
---|---|---|
1254464 | May 2000 | CN |
2006508471 | Mar 2006 | JP |
2007505542 | Mar 2007 | JP |
2008228051 | Sep 2008 | JP |
WO2006077822 | Jul 2006 | WO |
WO2008024705 | Feb 2008 | WO |
WO2014063361 | May 2014 | WO |
Entry |
---|
Amazon, “Amazon Prime Video—security considerations,” Amazon.com General Help Forum, http://www.amazon.com/gp/help/customer/forums?ie=UTF8&cdForum=Fx2NFGOONPZEXIP&cdPage=1&cdSort=newest&cdThread=Tx18VZVGGU0Y32, latest reply Jun. 17, 2013, 3 pages. |
Berners-Lee et al., “Uniform Resource Identifier (URI): Generic Syntax,” Network Working Group Request for Comments: 3986, The Internet Society 2005, retrieved on Nov. 30, 2011, from http://www.ietf.org/rfc/rfc3986.txt. |
Garay et al., “Timed Release of Standard Digital Signatures,” Financial Cryptography, Mar. 11, 2002 [lecture notes in computer science], Springer Berlin Heidelberg, pp. 168-182. |
Ghorbei-Talbi et al., “Managing Delegation in Access Control Models,” International Conference on Advanced Computing and Communications, pp. 744-751, Dec. 18-21, 2007. |
International Search Report and Written Opinion dated Dec. 30, 2014, in International Patent Application No. PCT/US2014/057043, filed Sep. 23, 2014. |
International Search Report and Written Opinion dated Dec. 30, 2014, in International Patent Application No. PCT/US2014/057051, filed Sep. 23, 2014. |
International Search Report and Written Opinion dated Oct. 22, 2014, International Patent Application No. PCT/US2014/042569, filed Jun. 16, 2014. |
Kiyomoto et al., “Design of Self-Delegation for Mobile Terminals,” Information and Media Technologies 1(1):594-605 2006, reprinted from IPSJ Digital Courier 1:282-293 (2005). |
Krawczyk et al., “HMAC: Keyed-Hashing for Message Authentication,” Internet Engineering Task Force (IETF) Request for Comments: 2104, Feb. 1997, retrieved Jan. 22, 2015, from https://tols.ietf.org/html/rfc2104, pp. 1-11. |
Liscano et al., “A Context-based Delegation Access Control Model for Pervasive Computing,” 21st International Conference on Advanced Information Networking and Applications Workshops 2:44-51, May 21-23, 2007. |
Massachusetts Institute of Technology, “Kerberos V5 Installation Guide [online],” May 2012, retrieved on Jun. 27, 2012, from http://web.mit.edu/kerberos/krb5-1.10/krb5-1.10.2/doc/krb5-install.htm, 65 pages. |
Massachusetts Institute of Technology, “Kerberos V5 System Administrator's Guide [online],” May 2012, retrieved on Jun. 27, 2012, from http://web.mit.edu/kerberos/krb5-1.10/krb5-1.10.2/doc/krb5-admin.html, 57 pages. |
Massachusetts Institute of Technology, “Kerberos V5 UNIX User's Guide,” May 2012, retrieved on Jun. 28, 2012, from http://web.mit.edu/kerberos/krb5-1.10/krb5-1.10.2/doc/krb5-user.html, 38 pages. |
Patent Cooperation Treaty, “Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration,” issued to International Application No. PCT/US2012/058083 dated Dec. 27, 2012. |
Roth et al., “Hierarchical Data Access Techniques,” U.S. Appl. No. 13/431,882, filed Mar. 27, 2012. |
Simpson, “PPP Challenge Handshake Authentication Protocol (CHAP),” Network Working Group, Aug. 1996, retrieved from internet Jun. 27, 2012, http://etherpad.tools.ietf.org/html/rfc1994, 13 pages. |
TCG Published, “TPM Main Part 1 Design Principles,” Specification Version 1.2, Revision 116, Mar. 1, 2011, 184 pages. |
TCG Published, “TPM Main Part 2 TPM Structures,” Specification Version 1.2, Level 2 Revision 116, Mar. 1, 2011, 202 pages. |
TCG Published, “TPM Main Part 3 Commands,” Specification Version 1.2, Level 2 Revision 116, Mar. 1, 2011, 339 pages. |
Wang et al., “Extending the Security Assertion Markup Language to Support Delegation for Web Services and Grid Services,” IEEE International Conference on Web Services 1:67-74, Jul. 11-15, 2005. |
Wikipedia, “Physical unclonable function,” retrieved Aug. 22, 2013, from http://en.wikipedia.org/wiki/Physical—unclonable—function, 8 pages. |
Number | Date | Country | |
---|---|---|---|
20160191993 A1 | Jun 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13431898 | Mar 2012 | US |
Child | 14282386 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14282386 | May 2014 | US |
Child | 15063331 | US |