The integrity of data is important in many contexts. The lifecycle of a unit of information (e.g., a file) can involve various events, many of which have the potential to change the data, even if only slightly. Information may, for example, be stored, read, rewritten to one or more new locations, transmitted over a network and/or otherwise processed in a manner that has the potential to introduce errors into the data. In addition, despite best efforts, systems are sometimes compromised. Unauthorized access to a system may provide the opportunity to affect data, whether intentionally or inadvertently. Further, in many contexts, it is often desirable to store data in one or more systems outside of one's control. Various companies may, for instance, provide various data storage services of varying degrees of complexity. A company may, for instance provide a database service that others may utilize for various reasons, such as avoiding capital expenditures and/or the complexity of operating suitable systems on their own. At least in part due to the complexities of the systems involved in storing and otherwise processing data, maintaining data integrity can be a rather difficult task, especially when the systems are operated outside of one's control.
Various embodiments in accordance with the present disclosure will be described with reference to the drawings, in which:
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 relate to techniques for verifying persistently stored data. In an embodiment, the verification of data includes a presenter, presentee, and a trusted entity, each being implemented as a separate computer system or component thereof, such as a programming module or hardware module as discussed in more detail below. The presenter obtains data and generates a signature based at least in part on the data and secret information (a shared secret) shared between the presenter and the trusted entity. The presenter causes the data and signature and possibly additional metadata (collectively “signed data”) to be stored persistently in a data storage system, which may be a local storage device, a data storage system accessible over a network or otherwise. At a later time, the presenter or another entity may obtain the signed data and present the signed data to the presentee.
The presentee may operate in accordance with programming logic that is dependent on the validity of the data presented to it. However, the presentee may be unable to verify the data itself due to, for instance, a lack of access to the shared secret at the time of verification. To verify the data, the presentee may present the signed data to the trusted entity (verification system) which may have access to the shared secret at the time of verification (but not necessarily at the time of signature generation, in all embodiments). The trusted entity may use the shared secret to verify whether the data is valid, e.g., by using the shared secret and data to generate a reference signature which is compared to a signature from the provided signed data. The trusted entity may perform other operations, such as determining whether policy allows verification of the data and other operations.
Upon performing any applicable operations, the trusted entity may provide a response to the verification request. The response to the verification request may include information about whether the verification request was processed, any results of processing (e.g., whether the signature is deemed by the trusted entity as authentic), any reasons for denial of the request (e.g., identification of one or more policy violations) and/or other relevant information. The presentee or another system may use the response to the verification request to perform one or more operations in accordance with the response. For example, performance of some operations may require a response from the trusted entity that the data is valid. The operations following receipt of the response to the verification request may, therefore, vary in accordance with the information provided in the response to the verification request.
Numerous variations of the above are considered as being within the scope of the present disclosure. For example, in some embodiments, the presenter and presentee are implemented on different computing devices while in other embodiments, the presenter and presentee are implemented on the same computing device and may be the same entity (e.g., on the same virtual and/or physical computer system). The presentee and the trusted entity may also be implemented on the same computing device (e.g., server computer system). In addition, the presenter, presentee and trusted entity may be implemented on the same computing device. In some embodiments, the trusted entity is implemented by a service provider (such as a computing resource service provider). Presenters and/or presentees may be customers of the service provider and, in some instances, the trusted entity may be configured to receive different requests to verify the same signature from different customers of the service provider. Depending on various contextual factors (e.g., identities of requestors), the trusted entity may provide different attestations as to the validity of the electronic signature. Further, the service provider may include a system configured to provide an application programming interface for receiving application programming interface requests to configure parameters for responding to requests to verify electronic signatures, where the parameters may be determinative of what type of response and/or how much information is included in a response to a particular requestor.
In some embodiments, the secret shared between the trusted entity and the entity that generates or causes to have generated an electronic signature is derived from another, master secret. The master secret may be usable for a set of uses (e.g., for access to various computing resources, to cause certain operations to occur and the like). The shared secret may be derived from the master secret in a way that limits the uses to a proper subset of the set of uses for which the master key is usable. The master secret may be held secretly by one entity so as to prevent access to the master secret from other entities, which may include the trusted entity. In some embodiments, the shared secret is derived by inputting the master secret and information corresponding to one or more limitations (perhaps iteratively) into a one way function. The output of the one way function may be used as the shared secret or the shared secret may be based at least in part of the one way function. In this manner, the trusted secret is usable for only a limited set of uses that is smaller than the set of uses for which the master key is usable. In this manner, the holder of the master key can delegate a limited amount of authority to a trusted entity. Such techniques may be used for various purposes, such as limiting when and/or by whom data is verifiable.
Some embodiments include those in which shared secrets are held as secrets for an amount of time and then published. For example, a trusted entity may obtain (e.g., receive or generate) a cryptographic key. The trusted entity may securely store the obtained key for an amount of time, perhaps using the obtained key to verify data if so requested during the amount of time. At some point, which may be a predetermined amount of time or based at least in part on a triggering event (e.g., a request from an entity that also holds the key), the trusted entity or another entity (e.g., another entity with access to the key) may make the key publicly available, such as by publishing the key to a publicly-available website. In this manner, the key is usable by the trusted entity for an amount of time to verify data. Once the key has been published, the key becomes effectively useless for verification since anyone with access to the key (i.e., any entity with access to the source by which the key was published) can have forged an electronic signature using a published copy of the key. As a specific example, such techniques are usable with an electronic mail or other messaging system. Electronic messages (e.g., emails) can be signed using a secret with which a trusted entity has access. The authenticity of the messages (which may include header information with various metadata, including an address and/or other identity of a sender) may be verified for a period of time. Once the secret has been published, the authenticity of the message is not verifiable using the secret since anyone with access to the public secret can forge the signature of the message using the publicly-available secret.
As will be discussed in more detail below, numerous embodiments are considered as being within the scope of the present disclosure. For example, in some embodiments, the presenter 102, presentee 108 and trusted entity 110 are different logical entities. The presenter 102 and the presentee 108 may, for example, be implemented as separate computer systems and data may be transferred between the presenter 102 and the presentee 108 by way of a suitable computer network or combination of networks, such as the Internet and intranet and/or other networks described below. Similarly, the trusted entity 110 may be implemented as a computer system separate from the presenter 102 and the presentee 108. Data transfer between the trusted entity 110 and the presentee 108 and data transfer between the trusted entity 110 and the presenter 102 may occur over one or more networks, such as noted. In other embodiments however, various entities in
When the presenter 202 provides the data 204 and the signature 206 of the data 204 to the presentee 208, the presenter 202 may obtain the data 204 and the signature 206 from a data store 214 in which the data 204 and in which the signature 206 have been persistently stored. The data store 214 may be a data storage device such as a hard drive accessible to the presenter 202. As one example, the data store 214 may be a data storage device locally attached to a computer system in which the presenter 202 is implemented. As another example, the data store 214 may be accessible to the presenter 202 over a network, such as network attached storage or a data storage system provided as a service by a computing resource service provider. In some embodiments, the data store is a component of a database (e.g., relational database, NoSQL database, and/or any system configured to store data in a structured manner) and obtaining data from the data store may include querying the database. Generally the data store 214 may be any data storage system accessible by the presenter 202. The data 204 and signature for the data 206 may have been provided to the data store 214 by the presenter 202 or another system which had generated or otherwise had accessible the signature 206 of the data 204.
To enable the trusted entity 210 to verify the signature 206 of the data 204, the presenter 202 and the trusted entity 210 may share a shared secret 216. The shared secret 216 may be, for example, a cryptographic key used in one or more symmetric authentication schemes. A symmetric authentication scheme may be a scheme in which an entity that verifies the authenticity of a message by way of an electronic signature of the message does so using the same information that was used to generate the electronic signature. Such information may be held secretly between the authenticating entity and the verifying entity and, perhaps, one or more other trusted entities. Further, a symmetric authentication scheme may utilize one or more symmetric cryptographic primitives. Example shared secrets include keys usable with one or more symmetric cryptographic primitives (cryptographic algorithms), such as keys usable to generate message authentication codes (MACs), such as hash-based message authentication codes (HMACs) or cipher block chaining MACs (CBC-MACs). Generally, the use of one-way functions, including hash functions and key derivation functions (such as Bcrypt and password-based key derivation function two (PBKDF2)) that take the shared secret and data as inputs are considered as being within the scope of the present disclosure. In this manner, the presenter 202 is able to generate the signature 206 based at least in part on the data 204 while providing the trusted entity 210 the ability to use the shared secret 216 to verify the signature 206 of the data 204.
It should be noted that as with all embodiments described herein, numerous variations are considered as being within the scope of the present disclosure. For example, in some embodiments, the presenter signs the data 204 using the shared secret 216 to generate the electronic signature 206. In other embodiments, however, the presenter 202 may provide the data 204 to the trusted entity 210 for generation of the electronic signature 206. In such embodiments, the trusted entity 210 may use a secret that the presenter does or does not have access to. The shared secret may be used by the trusted entity 210 to verify the identity of the presenter (e.g., by verifying a signature of a request to sign the data) and, therefore, that it is able to generate the signature. Embodiments within those of the present disclosure, however, include those where there is not necessarily a shared secret but, for instance, the presenter 202 proves identity to the trusted entity 210 using an asymmetric signature scheme or other trust mechanism, such as an IP address.
As illustrated in
In various embodiments, server hardware may be used to implement a trusted entity and presentee and possibly a presenter. Part of such implementation may utilize abstracting the server hardware using a variety of virtualization techniques operate a plurality of guest computer systems running virtual operating system instances simultaneously.
Of the dependent domains, the most privileged is the controlling domain 406, which may run processes that implement administration operations for controlling and configuring the hypervisor. The controlling domain also may run processes that implement administration operations for controlling and configuring the lesser domains, including the client domains 408 that may, in some embodiments, host guest operating systems and applications that operate as presenters and/or presentees, such as described above. The controlling domain may have direct access to the hardware resources of the server hardware and the controlling domain may provide that access to client domains. In some embodiments, a client domain may have no direct access to the hardware resources or direct access to some hardware resources of the server hardware including, but not limited to, Graphics Processing Units (GPUs) and Network Interface Cards (NICs). Generally, client domains may be provided less direct hardware access than controlling domains.
As illustrated in
Generally, while electronic signatures of the data are used throughout the present disclosure for the purpose of illustration, the scope of the present disclosure extends to various signatures based at least in part on the data. As one illustrative example, the data or a portion thereof may be input into a one way function (e.g., a hash function) to generate a hash of the data. The signature that is persisted and perhaps eventually presented to a trusted entity may be a signature of the hash of the data, thereby allowing the data to be verified by a trusted entity with just the hash of the data and the signature of the hash without providing the trusted entity access to the data itself. In this example, data may be presented to a presentee that may calculate the hash of the data (without a shared secret or with a secret shared between the presenter and the presentee, if different entities) and present the hash and the signature to the trusted entity for verification. As another example, the data may be encrypted and a signature for the data may be generated using the encrypted data (and a shared secret). The encrypted data and the signature may be provided to the trusted entity for verification. In this manner, the encrypted data may be provided to the trusted entity without providing the data in clear text form. If needed, various embodiments may employ additional operations, such as providing a key used to encrypt the data to a presentee to enable the presentee to verify that the plaintext (cleartext) data matches the encrypted data. In general, various schemes in which different entities are provided access to plaintext data are considered as being within the scope of the present disclosure and the data upon which a signature is generated may not be the plaintext data, but may a hash of the plaintext data, encrypted data, and/or data based at least in part on the plaintext data. In other words, the term “data” and related terms are to be interpreted broadly to encompass embodiments where various transformations on original data are performed before a signature is generated.
Returning to
As illustrated by the hourglass icon in
In an embodiment, once the data and signature have been obtained 508 from storage, the data and signature for the data may be provided 510 for verification. Providing 510 the data and signature for verification may be performed in any suitable manner such as by transmitting the data and signature for verification over a network to a trusted entity able to a presentee and/or to a trusted entity. As another example, the data and signature are provided to another component such as a process or cryptographic module (e.g., a cryptographic hardware module) of the same computer system that performs the process 500.
It should also be noted that operations illustrated in
In an embodiment the process 600 includes transmitting 604 a verification request with the data and signature to a trusted entity. The verification request may be an appropriately configured application programming interface (API) call to the trusted entity which may provide an API for making such calls and other calls. As another example, when the presentee and the trusted entity are implemented by the same computing device, the verification request may be a call to a hardware device or virtual hardware device on which the trusted entity is located/implemented. The verification request may also include metadata associated with the request. The metadata may include information about a context in which the request is submitted. The information about the context may include, for instance, an Internet Protocol (IP) address from which the verification request originates, an identity of the requestor (e.g., an entity on behalf of whom the request is made), authentication information (e.g., an electronic signature) to provide authority to make the request and the like. Generally, the verification request may include additional information, different/independent from the data and the signature of the data that is used by the verification system to determine how to construct a response. A verification response may then be received 606 from the trusted entity. The verification response may include information indicating whether the data is authentic. In some embodiments, the verification response may have more than two possible responses. For example, as discussed below, verification may be dependent on policy or other factors. Accordingly, a verification response may include information whether verification was successful or unsuccessful, whether verification was performed, any reasons for not performing verification and/or other information that may be useful to a recipient of the verification response.
Upon receipt, the verification response may be analyzed to determine 608 whether the response includes information indicating that signature is verified. If it is determined 608 that the response indicates that signature is verified then the process 600 may include taking 610 one or more actions corresponding to the signature being verified. The one or more actions corresponding to the signature being verified may vary in accordance with the various embodiments. As an example, where one or more actions may include fulfilling a request whose fulfillment is contingent on the signature being verified. Generally, any actions whose performance requires the signature to have been verified may be performed. If it is determined 608 that the signature has not been verified then the process 600 may include taking 612 one or more actions corresponding to the unverified signature. The one or more actions corresponding to the unverified signature may vary in accordance with various embodiments. For example, if one or more actions had been requested and those actions are contingent on the signature having been verified, those actions may not be performed. In other words, taking one or more actions may simply be inaction. In some embodiments if the data and signature were provided as part of a request to perform one or more operations, the one or more actions corresponding to the unverified signature may include denying the request. Generally, any suitable actions corresponding to the unverified signature may be performed.
As with all processes described herein, numerous variations are considered as being within the scope of the present disclosure. For example,
Further, it should be noted that various embodiments of the present disclosure include embodiments where a response may include an attestation to validity of the signature (e.g., an attestation that the signature is valid or the signature is invalid) as a result of the policy evaluation, regardless of whether the signature is valid or not. In this manner, for example, two (or more) different requestors may submit requests to verify the same electronic signature, where the data and signature of the data in the requests are identical. The different requestors may receive different responses with different attestations to validity of the electronic signature as a result of policy applying differently to the different requestors. In addition, a response may include other information about the electronic signature in addition to or instead of an attestation to validity of the electronic signature. The other information may, for instance, identify an entity that generated the electronic signature, identify when the electronic signature was generated, identify one or more policies that may restrict what the data and/or electronic signature may be used for and the like. The type(s) and amount of information provided may also be determined based at least in part on applicable policy.
Other variations of the process 700 considered as being within the scope of the present disclosure include embodiments where other additional operations than those illustrated in
Various embodiments of the present disclosure also allow for use of scoped secrets (e.g., scoped keys).
The derived keys may each correspond to other smaller scopes within the key scope of use 802. Such smaller scopes are illustrated as subsets 804 of the key scope of use 802. Some of the derived key scopes of use 804 may overlap (i.e., have a non-empty intersection) and other sets may be distinct. In addition, some derived scopes may be entirely contained in other key scopes. In some embodiments, keys with key scopes contained in other key scopes can be used to derive additional keys with even smaller key scopes. To derive a key having a smaller scope of use, various techniques may be employed. In some embodiments for example, an HMAC may be computed based at least in part on a key having a corresponding scope of use and information corresponding to a semantic limitation of the scope of use. The information may, for instance, be a string corresponding to the limitation. The HMAC may then be used as a key or used to generate a key that has a smaller scope of use in accordance with the limitation. The information also may be formatted in accordance with a canonical system utilized by various participants.
As an illustrative example of how a key may be derived, a derived key may be based at least in part on an HMAC generated based at least in part on a first key and the string “limitation” where “limitation” may correspond to some limitation, such as a temporal or geographical limitation or the identity of a verifier. Two entities with the first key can both generate the derived key which may be used to verify signatures. Similarly, an entity with access to the first key that receives data and a signature generated based at least in part on the derived key can use the first key to derive the derived key and verify the signature. The entity may be able to determine (e.g., calculate or obtain) the information corresponding to the limitation to derive the derived key. For example, the entity may receive the information with the data and signature. The entity may also perform one or more policy checks with regard to the limitation, such as by determining whether verifying the signature would be in accordance with the limitation.
After some time, as illustrated by the hourglass icon in
Variations of the process 900 considered as being within the scope of the present disclosure include variations in how the trusted entity obtains the scoped key. As noted above, key derivation may proceed in accordance with a canonical system utilized by various participants. In some embodiments for example, the system performing the process 900 may derive the scoped key and use the derived scope key to sign data which has been persisted for a time. A trusted entity may not actually receive to scoped key from the system performing the process 900 but may be programmed or otherwise configured to derive the scoped key itself. As an illustrative example, a limitation may be a temporal limitation. For instance, a trusted entity may derive a scoped key using a master key and an encoding of the current date or a date on which the data is purported to have been signed. Both the system performing the process 900 and the trusted entity may derive a scoped key from the same shared secret by for instance inputting a time stamp with the shared secret into a one-way function such as HMAC. Other variations are also considered as being within the scope of the present disclosure.
Various embodiments of the present disclosure also allow various enhancements over conventional technique. For example, in some embodiments a trusted entity may be provided or otherwise may obtain the scoped keys. The trusted entity may after some time publish the scoped keys in order to render any signatures generated using the scoped keys unusable for verification of data integrity. As an example, various embodiments of the present disclosure are usable for code signing. A report of a scan of a network may be signed. The report may attest to the network being secure at a particular time. A key used to sign the report may be available to a trusted entity which may, after some time, publish the key such as described above. In this manner, the report is only verifiable using the key until the key is published. As another example, email messages may be signed using a key accessible to a verifier which, after an amount of time (e.g., a week) publishes the key. In this manner, email is verifiable by the key until the key is published.
As noted above, the techniques described herein provide different technical advantages in a variety of contexts. For instance, applications of the various techniques described are useful for verifying the data in electronic mail systems, databases, system scan reports and/or generally any contexts where the integrity of data is of import. Other contexts in which the techniques described herein and variations thereof are useful include digital rights management (DRM). A media player (e.g., computing device or application operating thereon) may, for instance, be configured (e.g., programmed) to require verification of a signature of a media file by a trusted entity before it will play the media file.
Other enhancements are also considered as being within the scope of the present disclosure. For example, as noted above, keys may be scoped to various limitations. A key may, for instance, be scoped to a particular verifier (e.g., by deriving the key based at least in part on a master secret and an identifier for a verifier). Data may be persistently stored with multiple signatures, each one generated using a different key scoped to a different verifier. Metadata may also be stored with or otherwise in association with the data. The metadata may include information such as which signature corresponds to which verifier having access to an appropriate key for verifying the signature. In this manner, providing the data and a signature to a trusted entity may include using the metadata to select a signature that the trusted entity (verifier) is able to verify. Alternatively, multiple signatures may be provided to a trusted entity. The trusted entity may attempt to verify the multiple signatures until one is found that is verified. Other variations are also considered as being within the scope of the present disclosure.
The illustrative environment includes at least one application server 1108 and a data store 1110. 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. Servers, as used herein, may be implemented in various ways, such as hardware devices or virtual computer systems. In some contexts, servers may refer to a programming module being executed on a computer system. 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 some (even a majority) of the data access and business logic for an application. The application server may provide 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 HyperText Markup Language (“HTML”), Extensible Markup Language (“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 1102 and the application server 1108, 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. Further, operations described herein as being performed by a single device may, unless otherwise clear from context, be performed collectively by multiple devices, which may form a distributed system.
The data store 1110 can include several separate data tables, databases or other data storage mechanisms and media for storing data relating to a particular aspect of the present disclosure. For example, the data store illustrated may include mechanisms for storing production data 1112 and user information 1116, 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 1114, 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 page image information and access rights information, which can be stored in any of the above listed mechanisms as appropriate or in additional mechanisms in the data store 1110. The data store 1110 is operable, through logic associated therewith, to receive instructions from the application server 1108 and obtain, update or otherwise process data in response thereto. In one example, a user, through a device operated by the 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 1102. Information for a particular item of interest can be viewed in a dedicated page or window of the browser. It should be noted, however, that embodiments of the present disclosure are not necessarily limited to the context of web pages, but may be more generally applicable to processing requests in general, where the requests are not necessarily requests for content.
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
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, laptop or tablet 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.
Various embodiments of the present disclosure 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 Transmission Control Protocol/Internet Protocol (“TCP/IP”), protocols operating in various layers of the Open System Interconnection (“OSI”) model, File Transfer Protocol (“FTP”), Universal Plug and Play (“UpnP”), Network File System (“NFS”), Common Internet File System (“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 Hypertext Transfer Protocol (“HTTP”) servers, FTP servers, Common Gateway Interface (“CGI”) servers, data servers, Java servers and business application servers. The server(s) also may be capable of executing programs or scripts in response to 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” or “processor”), 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, Electrically Erasable Programmable Read-Only Memory (“EEPROM”), flash memory or other memory technology, Compact Disc Read-Only Memory (“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 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,” when unmodified and referring to physical connections, 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. The use of the term “set” (e.g., “a set of items”) or “subset” unless otherwise noted or contradicted by context, is to be construed as a nonempty collection comprising one or more members. Further, unless otherwise noted or contradicted by context, the term “subset” of a corresponding set does not necessarily denote a proper subset of the corresponding set, but the subset and the corresponding set may be equal.
Conjunctive language, such as phrases of the form “at least one of A, B, and C,” or “at least one of A, B and C,” unless specifically stated otherwise or otherwise clearly contradicted by context, is otherwise understood with the context as used in general to present that an item, term, etc., may be either A or B or C, or any nonempty subset of the set of A and B and C. For instance, in the illustrative example of a set having three members used in the above conjunctive phrase, “at least one of A, B, and C” and “at least one of A, B and C” refers to any of the following sets: {A}, {B}, {C}, {A, B}, {A, C}, {B, C}, {A, B, C}. Thus, such conjunctive language is not generally intended to imply that certain embodiments require at least one of A, at least one of B and at least one of C to each be present.
Operations of processes described herein can be performed in any suitable order unless otherwise indicated herein or otherwise clearly contradicted by context. Processes described herein (or variations and/or combinations thereof) may be performed under the control of one or more computer systems configured with executable instructions and may be implemented as code (e.g., executable instructions, one or more computer programs or one or more applications) executing collectively on one or more processors, by hardware or combinations thereof. The code may be stored on a computer-readable storage medium, for example, in the form of a computer program comprising a plurality of instructions executable by one or more processors. The computer-readable storage medium may be non-transitory.
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 embodiments of the present disclosure to be practiced otherwise than as specifically described herein. Accordingly, the scope of the present disclosure 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 scope of the present disclosure 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/027,843, filed Sep. 16, 2013, entitled “TRUSTED DATA VERIFICATION,” the disclosure of which is hereby incorporated herein by reference 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 |
6084969 | Wright et al. | Jul 2000 | A |
6097817 | Bilgic et al. | Aug 2000 | A |
6185316 | Buffam | Feb 2001 | B1 |
6363154 | Peyravian | Mar 2002 | B1 |
6453416 | Epstein | Sep 2002 | B1 |
6704489 | Kurauchi | Mar 2004 | 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, Jr. 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 |
7533269 | Kumagai et al. | May 2009 | B2 |
7571324 | Canard et al. | Aug 2009 | B2 |
7580521 | Spies | Aug 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 et al. | Mar 2011 | B2 |
7921450 | Vainstein | Apr 2011 | B1 |
8006280 | Hildebrand | Aug 2011 | B1 |
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 |
8121993 | Blount et al. | Feb 2012 | B2 |
8151116 | van der Horst et al. | Apr 2012 | B2 |
8275356 | Hickie | Sep 2012 | B2 |
8321680 | Gantman | Nov 2012 | B2 |
8325922 | Sun et al. | Dec 2012 | B1 |
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 et al. | May 2014 | B1 |
8745205 | Anderson et al. | Jun 2014 | B2 |
8776190 | Cavage et al. | Jul 2014 | B1 |
8776204 | Faynberg et al. | Jul 2014 | B2 |
8817988 | Stockton | Aug 2014 | B1 |
8868923 | Hamlet et al. | Oct 2014 | B1 |
8892865 | Roth et al. | Nov 2014 | B1 |
9112910 | Pavlovski et al. | Aug 2015 | B2 |
9866375 | Reilly | Jan 2018 | B2 |
10044503 | Roth | Aug 2018 | 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 |
20020141591 | Hawkes | Oct 2002 | A1 |
20020143711 | Nassiri | Oct 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 |
20030093678 | Bowe et al. | May 2003 | A1 |
20030135740 | Talmor et al. | Jul 2003 | A1 |
20030145197 | Lee et al. | Jul 2003 | A1 |
20030147536 | Andivahis | Aug 2003 | A1 |
20030149781 | Yared et al. | Aug 2003 | A1 |
20030188117 | Yoshino et al. | Oct 2003 | A1 |
20040003246 | Hopkins | Jan 2004 | A1 |
20040054779 | Takeshima | Mar 2004 | 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 |
20050132201 | Pitman 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 |
20050273862 | Benaloh et al. | Dec 2005 | A1 |
20050278547 | Hyndman et al. | Dec 2005 | A1 |
20060070116 | Park | Mar 2006 | A1 |
20060075462 | Golan et al. | Apr 2006 | A1 |
20060085345 | Khandelwal | Apr 2006 | A1 |
20060094406 | Cortegiano | May 2006 | A1 |
20060094410 | Cortegiano | May 2006 | A1 |
20060100928 | Walczak et al. | May 2006 | A1 |
20060130100 | Pentland | Jun 2006 | A1 |
20060149677 | Shahine et al. | Jul 2006 | A1 |
20060156012 | Beeson | Jul 2006 | A1 |
20060174125 | Brookner | Aug 2006 | A1 |
20060190331 | Tollinger et al. | Aug 2006 | A1 |
20060204003 | Takata | Sep 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 |
20060235705 | Deolalikar | 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 |
20070043949 | Bugbee | Feb 2007 | A1 |
20070061571 | Hammes et al. | Mar 2007 | A1 |
20070061885 | Hammes et al. | Mar 2007 | A1 |
20070136361 | Lee et al. | Jun 2007 | A1 |
20070153732 | Yao | Jul 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 |
20070250904 | Waller | Oct 2007 | A1 |
20070277231 | Medvinsky et al. | Nov 2007 | A1 |
20080010665 | Hinton et al. | Jan 2008 | A1 |
20080037785 | Gantman | Feb 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 |
20080101610 | Birk | May 2008 | A1 |
20080126256 | Unger | May 2008 | A1 |
20080148054 | Cahill et al. | Jun 2008 | A1 |
20080163337 | Tuliani et al. | Jul 2008 | A1 |
20080168530 | Kuehr-McLaren et al. | Jul 2008 | A1 |
20080182592 | Cha et al. | Jul 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 |
20090106780 | Nord | Apr 2009 | A1 |
20090172793 | Newstadt et al. | Jul 2009 | A1 |
20090210712 | Fort | Aug 2009 | A1 |
20090214042 | Nakahara | Aug 2009 | A1 |
20090217385 | Teow et al. | Aug 2009 | A1 |
20090254572 | Redlich et al. | Oct 2009 | A1 |
20090282256 | Rakic | Nov 2009 | A1 |
20090310788 | Garrido | Dec 2009 | A1 |
20090320093 | Glazier et al. | Dec 2009 | A1 |
20100017603 | Jones | Jan 2010 | A1 |
20100037304 | Canning et al. | Feb 2010 | A1 |
20100058060 | Schneider | Mar 2010 | A1 |
20100058072 | Teow et al. | Mar 2010 | A1 |
20100071056 | Cheng et al. | Mar 2010 | A1 |
20100083001 | Shah et al. | Apr 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 | Jul 2010 | A1 |
20100205649 | Becker et al. | Aug 2010 | A1 |
20100228980 | Falk | Sep 2010 | A1 |
20100239095 | Carter et al. | Sep 2010 | A1 |
20100251347 | Roskind | Sep 2010 | A1 |
20100269156 | Hohlfeld et al. | Oct 2010 | A1 |
20100281267 | Sakumoto | Nov 2010 | A1 |
20100290476 | Brindle et al. | Nov 2010 | A1 |
20100293099 | Pauker | 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 | 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 |
20120166818 | Orsini et al. | Jun 2012 | A1 |
20120204032 | Wilkins | Aug 2012 | A1 |
20120226902 | Kim | Sep 2012 | A1 |
20120233216 | Lim | Sep 2012 | A1 |
20120243687 | Li et al. | Sep 2012 | A1 |
20120245978 | Jain et al. | Sep 2012 | A1 |
20120260096 | Balinsky | Oct 2012 | A1 |
20120265690 | Bishop et al. | Oct 2012 | A1 |
20120317414 | Glover | Dec 2012 | A1 |
20120323717 | Kirsch | Dec 2012 | A1 |
20130031255 | Maloy et al. | Jan 2013 | A1 |
20130086662 | Roth et al. | Apr 2013 | A1 |
20130086663 | Roth et al. | Apr 2013 | A1 |
20130111217 | Kopasz et al. | May 2013 | A1 |
20130132232 | Pestoni et al. | May 2013 | A1 |
20130145149 | Tanaka | Jun 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 |
20130254541 | Yamanaka et al. | Sep 2013 | A1 |
20130282461 | Ovick et al. | Oct 2013 | A1 |
20130318630 | Lam | Nov 2013 | A1 |
20140013409 | Halageri | Jan 2014 | A1 |
20140019766 | Takahashi et al. | Jan 2014 | A1 |
20140082715 | Grajek et al. | Mar 2014 | A1 |
20140122866 | Haeger et al. | May 2014 | A1 |
20140181513 | Marek | Jun 2014 | A1 |
20140181925 | Smith et al. | Jun 2014 | A1 |
20140208408 | Bilgen et al. | Jul 2014 | A1 |
20140281477 | Nayshtut et al. | Sep 2014 | A1 |
20140281487 | Klausen et al. | Sep 2014 | A1 |
20140281544 | Paczkowski | Sep 2014 | A1 |
20150082039 | Stalzer et al. | Mar 2015 | A1 |
20150089614 | Mathew et al. | Mar 2015 | A1 |
20150143131 | Kuno | May 2015 | A1 |
20150208245 | Robinton et al. | Jul 2015 | A1 |
Number | Date | Country |
---|---|---|
2006077822 | Jul 2006 | WO |
2008024705 | Feb 2008 | WO |
2014063361 | 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. |
Armstrong, “VMMs versus Hypervisors,” Bert Armstrong's Virtualization Blog [online], Jul. 2006, retrieved Sep. 3, 2015, from http://blogs.msdn.eom/b/virtual_pc_guy/archive/2006/07/10/661958.aspx, 3 pages. |
Berners-Lee et al., “Uniform Resource Identifier (URI): Generic Syntax,” Network Working Group Request for Comments: 3986, The Internet Society 2005, retrieved Nov. 30, 2011, from http://www.ietf.org/rfc/rfc3986.txt, 62 pages. |
Ghorbel-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, International Patent Application No. PCT/US2014/057043, filed Sep. 23, 2014. |
International Search Report and Written Opinion, dated Dec. 30, 2014, 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. |
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 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 [online],” May 2012, retrieved an 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 dated Dec. 27, 2012,” International Patent Application No. PCT/US2012/058083, filed Sep. 28, 2012. |
Roth et al., “Multiple Authority Key Derivation,” U.S. Appl. No. 13/431,760, filed Mar. 27, 2012. |
Roth et al., “Source Identification for Unauthorized Copies of Content,” U.S. Appl. No. 13/431,898, filed Mar. 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 Jun. 27, 2012, from https://tools.ietf.org/html/rfc1994, 13 pages. |
Trusted Computing Group, “TPM Main Part 3 Commands,” Specification Version 1.2, Level 2 Revision 116, Mar. 1, 2011, 339 pages. |
Trusted Computing Group, “TPM Main, Part 1 Design Principles,” Specification Version 1.2, Revision 116, Mar. 1, 2011, 184 pages. |
Trusted Computing Group, “TPM Main, Part 2 TPM Structures,” Specification Version 1.2, Revision 116, Mar. 1, 2011, 201 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,” Oct. 5, 2007, retrieved Aug. 22, 2013, from http://en.wikipedia.org/wiki/Physical_unclonable_function, 8 pages. |
Number | Date | Country | |
---|---|---|---|
20190149339 A1 | May 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14027843 | Sep 2013 | US |
Child | 16246331 | US |