Binding content licenses to portable storage devices
Systems, methods, and/or techniques (“tools”) for binding content licenses to portable storage devices are described. In connection with binding the content licenses to the portable storage devices (“stores”), a host may perform authentication protocols that include generating a nonce, sending the nonce to a store, and receiving a session key from the store, with the session key being generated using the nonce. The store may perform authentication protocols that include receiving the nonce from the host, generating a random session key based on the nonce, and sending the session key to the host.
Latest Microsoft Patents:
- SELECTIVE MEMORY RETRIEVAL FOR THE GENERATION OF PROMPTS FOR A GENERATIVE MODEL
- ENCODING AND RETRIEVAL OF SYNTHETIC MEMORIES FOR A GENERATIVE MODEL FROM A USER INTERACTION HISTORY INCLUDING MULTIPLE INTERACTION MODALITIES
- USING A SECURE ENCLAVE TO SATISFY RETENTION AND EXPUNGEMENT REQUIREMENTS WITH RESPECT TO PRIVATE DATA
- DEVICE FOR REPLACING INTRUSIVE OBJECT IN IMAGES
- EXTRACTING MEMORIES FROM A USER INTERACTION HISTORY
Various types of content are becoming increasingly available on removable storage units. These storage units may readily be inserted into different devices to enable the devices to access the content contained in the storage.
In some instances, this content may be subject to licenses, which are administered by digital rights management (DRM) systems. In such instances, the content may be bound or licensed to a given instance of storage, but the content may be accessed from a variety of different devices. In these environments, managing compliance with licensing policies or restrictions may present challenges for the DRM systems.
SUMMARYSystems, methods, and/or techniques (“tools”) for binding content licenses to portable storage devices are described. In connection with binding the content licenses to the portable storage devices (“stores”), devices for interacting with or performing actions on content (“hosts”) may perform authentication protocols that include generating a nonce, sending the nonce to a store, and receiving a session key from the store, with the session key being generated using the nonce. The store may perform authentication protocols that include receiving the nonce from the host, generating a random session key based on the nonce, and sending the session key to the host.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter. The term “tools,” for instance, may refer to system(s), method(s), computer-readable instructions, and/or technique(s) as permitted by the context above and throughout the document.
Tools related to binding content licenses to portable storage devices are described in connection with the following drawing figures. The same numbers are used throughout the disclosure and figures to reference like components and features. The first digit in a reference number indicates the drawing figure in which that reference number is introduced.
Overview
The following document describes tools capable of performing and/or supporting many techniques and processes. The following discussion describes exemplary ways in which the tools provide for binding content licenses to portable storage devices. This discussion also describes other techniques and/or processes that the tools may perform.
In general, the operating environments 100 may enable any number of users 102 to obtain any number of instances of content 104 from any number of content sources 106. Additionally, the operating environments may include any number of stores 108.
The content 104 may include audio components, such as songs, music, recorded readings of books or magazines, or the like. The content 104 may also include audio and/or video components, such as movies, video clips, or the like. In some instances, but not necessarily all, video components may combine with corresponding audio components to provide multimedia content. The content 104 may also include still images, games, ringtones, silent video, text, or any other form of digitized information, either alone or in combination with audio and/or video components.
The content source 106 may represent services that are accessible over a wide area communication network, such as the Internet, to enable users 102 to download the content 104. Without limiting possible implementations with the following examples, the content source 106 may enable the users to download the content free of charge (e.g., in exchange for receiving ads), or may enable the users to download the content for a fee. In addition, the users may subscribe to receive the content.
Turning to the storage devices or stores 108, examples of such these devices may include, but are not limited to portable memory devices, such as flash memories 110, Secure Digital (SD) cards 112, Subscriber Identity Modules (SIM) cards 114, hard drives, dongles that communicate via Universal Serial Bus (USB) busses, or the like.
The operating environments 100 may also include one or more license servers or services, denoted generally at 116. In general, the license servers enable the users 102 to obtain any licenses appropriate for playing or otherwise interacting with or performing actions on the content 104. The licenses may permit interacting with or performing actions on the content under certain conditions, or may specify policies or limitations applicable to interacting with or performing actions on the content. Examples of such policies or limitations may include, but are not limited to, counts, time restrictions, or the like.
In some cases, the license servers 116 may provide not only licenses for content, but also the content itself. Thus,
Once the user 102, or any entity acting on behalf of the user, obtains licenses appropriate for playing the content, the operating environments may bind the licenses to the stores 108. The term “binding” as used herein with licenses refers to cryptographically associating a particular content license related to a particular device (e.g., the stores 108), such that the device is permitted to interact with or performing actions on the content under the terms of that license. As shown in
The operating environments 100 may include one or more host devices 120 (“hosts”) for playing, viewing, or otherwise interacting with or performing actions on the content 104.
Turning to the hosts 120 in more detail, the hosts may include devices such as mobile wireless devices 124, which may represent mobile telephones, smart phones, wireless personal digital assistants (PDAs), or the like. The hosts 120 may also include portable media players 126. Any of the devices 124 or 126 may be suitable for playing audio, video, or other content 122.
As described above, the license(s) for particular content is cryptographically bound to the respective storage devices 108, as represented by the arrows 118. Binding the licenses to stores is contrasted from binding the licenses to particular hosts 102. Because the licenses for the content are cryptographically bound to the stores 108, the licenses “travel” with the stores 108. These licenses enable any host that communicates with the store, to which the license is cryptographically bound, to play the content, provided that the host has a valid host certificate and provides a conformant implementation of host functionality.
As an example of this licensing scenario,
Having described the operating environments 100 as shown in
Turning first to the license server 116, it may be a computer-based system that includes one or more processors, denoted at 202. These processors may also be categorized or characterized as having a given type or architecture, but may or may not have the same type or architecture.
The license server 116 may also include one or more instances of machine-readable or computer-readable storage media, denoted generally at 204. The computer-readable media 204 may contain instructions that, when executed by the processor 202, perform any of the tools or related functions that are described herein as being performed by the license server. The processor may access and/or execute the instructions embedded or encoded onto the computer-readable media, and/or may access data stored in the computer-readable media.
Turning in more detail to the computer-readable media 204, it may include one or more instances of a digital rights management (DRM) module 206. The DRM module 206 may include, for example, one or more software modules, which when loaded into the processor and executed, cause the license server to administer licenses applicable to digital content (e.g., content 104 in
In different implementations, the license server may enable direct or indirect license acquisition (respectively, DLA and ILA) scenarios. The term direct licensing scenario refers to when a device obtains a license directly from a license server. The term indirect licensing scenario refers to when a device obtains a license indirectly from a license server by communicating through one or more intermediate devices, such as a personal computer or other proxy.
Additionally, the DRM module may interpret and enforce any rights and restrictions on licenses granted to users (e.g., 102 in
Turning now to the storage device or store 108, it may include a processor 208, which may or may not be the same type or architecture as the processor 202. The store 108 may also include a computer-readable medium 210 that is in communication with the processor 208. The computer-readable media 210 may contain instructions that, when executed by the processor 208, perform any of the tools or related functions that are described herein as being performed by the store 108. The processor 208 may access and execute the instructions embedded or encoded onto the computer-readable media 210, and may access data stored in the computer-readable media 210.
The computer-readable media 210 may include storage areas for any content loaded onto the store (e.g., content 104 in
The computer-readable media 210 may also include storage areas for licenses associated with content loaded into the store.
The computer-readable media 210 may include a DRM component 214, which may include one or more software modules that cooperate and/or communicate with the DRM module 206, which is provided by the license server 116. The DRM component 214 and/or the DRM module 206 may administer any licenses applicable to the content stored in the content storage 212. More specifically, the DRM component may store any information appropriate for tracking compliance with licenses applicable to the content. For example, the DRM component may track how many times the content has been accessed, when the content was accessed, or the like.
Referring briefly back to the content/license storage areas 212, in some implementations, those portions of the content/license storage areas that store the licenses may be secure and/or hidden, to hinder (and possibly prevent) unauthorized access to any information related to administering the licenses.
The computer-readable media 210 may include a cryptographic module, denoted in
Turning now to the host 120, it may include a processor 218, which may or may not be the same type and architecture as the processors 202 and 208. The processor 218 may communicate or cooperate with a media interface 220, which may include, for example, a slot and connector into which the storage device 108 may be inserted by a user.
The host 120 may also include a computer readable medium 222, which, in turn, may contain a DRM component 224. In some instances, the DRM component 224 may communicate or cooperate with the DRM module 206 on the license server 116, or with DRM components 214 on one or more of the stores 108. In other instances, the DRM component 224 may communicate or cooperate with both the DRM module 206 and the DRM component 214.
The computer readable medium 222 may include a crypto module 225, which may perform cryptographic operations on behalf of the host. The crypto module 225 may, for example, cooperate indirectly with the crypto module 216 on the store. Aside from the differences in operating context, the above description of the crypto module 216 may apply equally to the crypto module 225. For example, the crypto module 225 may be implemented as a separate hardware module with which the processor 218 may communicate.
The host 120 may receive indications that the store 108 has been inserted in the media interface 220. These indications may include electrical signals, software and/or hardware interrupts, software reporting events, or the like. In response to such indications, the DRM component 224 may search the store 108 for any content that is subject to license, may identify any licenses applicable to the content, and may bind the licenses to the store. Additionally, the DRM component may enable the host 120 to enforce of any policies applicable to the playing of the content, e.g., playcounts, time restrictions, or the like.
In some cases, the host 120 may access the store 108 directly, for example, when a user inserts the store into a slot provided by the host. In other instances, the host may access the store indirectly through another device. For example, the host 120 as shown in
The computer readable medium 222 may include a media player application 226. In different possible implementations, the media player application include one or more software modules for playing the content (e.g., content 122) to the user 128, or otherwise enabling the user 128 to access the content. For example, the media player application may include a movie or video viewing application, an audio playing application, or the like, depending on the nature and type of the content included in a particular implementation.
While not shown in
The computer readable medium 222 may include a content storage area 228 into which the DRM component 224 loads content for access by the media player application 226. For example, the content storage area 228 may include a buffer or other suitable data structure for storing the content for the media player application.
The computer readable medium 222 may also include a license storage area 230 into which the DRM component loads license information. For example, assuming that the DRM component loads a given instance of content from the store into the content storage area 228, and assuming that the content is subject to licensing polices, the DRM component may load any information relating to enforcing or administering these policies into the license storage area 230.
As detailed further below, the DRM component 224 may enforce any licensing polices applicable to any content loaded into the content storage area 228. When a user (e.g., user 128 in
To perform the foregoing functions, the DRM component 224 may, in some instances, communicate with the DRM component 214 on the store. In other instances, the DRM component 224 may communicate with the DRM module 206 on the license server 116. In some cases, the DRM component 224 may communicate with both the DRM module 206 and the DRM component 214.
Having described the additional aspects of the license server 116, the store 108, and the host 120 in
In some instances, the host certificate 304 may include at least a host private key 308 and a host public key 310. In other instances, the host certificate may include at least the host public key 310, with the host private key being delivered separately. The host may have access to the host private key corresponding to the host public key. Additionally, the certificate authority 302 may also maintain a certificate revocation list 312 that lists current status of any certificates previously issued by the certificate authority 302 or any certificate authority in a tree of certificate authorities. More specifically, the certificate revocation list 312 may indicate whether one or more given certificates have been revoked or have otherwise become invalid.
Any licenses applicable to content contained on the store 108 may be cryptographically bound to or associated with the private key or a collection of private keys 320 issued to the store 108. In this manner, the certificate infrastructure 300 shown in
Having described the infrastructure 300 for issuing certificates and public and private keys to the host 120 and to the store 108 in
For convenience of description, but not to limit possible implementations, some items described previously are carried forward into FIG. 4 and denoted by similar reference signs. Additionally, for ease of description, but not limitation,
Block 402 represents sending a query for a store certificate.
Block 406 represents receiving the query 404 for the store certificate. In the example shown in
Block 408 represents sending a store certificate. In the example shown in
Assuming that the host certificate is valid, the store may send a copy of its certificate in response to the query. For convenience, but not limitation,
At the host, block 410 represents receiving a store certificate. In the implementation shown in
Block 412 represents checking the store certificate against a CRL, to determine the validity of the store certificate. For example, the store certificate may have been revoked, or otherwise invalidated. In the implementation shown in
If the store certificate is valid, the host 120 may participate in the rest of the protocol 400 that is shown in
Block 416 represents sending a host certificate (e.g., 304) to a store (e.g., 108). The tools described herein may perform block 416 in response to a user (e.g., 128) inserting the store into the host. An example of a host certificate is denoted in
Block 418 represents receiving the host certificate. In the example implementation shown in
Block 420 represents checking the received host certificate against a certificate revocation list (CRL) to determine whether the host certificate remains valid, or has been revoked. In the example implementation shown in
If the host certificate remains valid, and has not been revoked, the store may continue with the rest of the protocol 400 shown in
While
Block 502 represents encrypting a nonce, using the store public key (e.g., 322). The host may obtain the store public key using the protocols 400 shown in
Block 504 represents sending the encrypted nonce.
At the store, block 508 represents receiving the encrypted nonce 506. In the example shown in
Block 510 represents decrypting the nonce. Assuming that the nonce was encrypted using the store's public key, block 510 may include decrypting the nonce using the store's private key (e.g., 320).
Block 512 represents generating a random session key. In some implementations, block 432 represents generating the random session key based on the encrypted nonce received in block 508. In the example shown in
Block 514 represents encrypting the random session key. Block 514 may include encrypting the session key using a public key associated with the host.
Block 516 represents sending the encrypted session key.
Block 520 represents receiving the encrypted session key 518. In the example shown in
Block 522 represents decrypting the session key 518. Assuming that the store encrypted the session key using the host's public key, block 522 may include decrypting the session key using the host's private key (e.g., 308).
Block 524 represents verifying the session key. In implementations where the store generates the session key based on the nonce, block 524 may include verifying that the session key is based on the nonce that was sent to the store in block 504. In implementations where the store authenticates to the host by returning the nonce, rather than generating the session key based on the nonce, block 524 may include verifying that the store returned the correct nonce.
Assuming that the host and the store successfully complete the protocols 400 and 500, the host and the store may then secure their communications with each other. For example, the host and the store may encrypt any further communications between themselves using the session key. Additionally, once the host and the store complete the protocols 400 and 500, the host and the store have authenticated to one another, and have exchanged public keys with one another. More specifically, in the examples shown in
Having described the protocol 500 in
Recalling from
Turning to the records 602 in more detail, these records may contain key identifier fields 604. These key identifier fields 604 may provide a search or index field that facilitates searching the data structures 600 to locate a license for a given instance of licensed content, as detailed further below. For convenience only,
The key identifier fields 604 may be associated with at least one content key field 606. For convenience only,
To promote security and protection, the content keys may be encrypted with the public key of the store (e.g., 322), such that they may only be decrypted with the private key of the store. In another example, the content keys may be encrypted with an intermediate symmetric key. In this manner, even if the content keys are somehow misappropriated by a malicious party, the content keys would be of no value to the malicious party, unless the store's private key were also compromised. Generally, best practices related to key management dictate that implementations of public-private key infrastructures take great care to protect the private key from compromise through hardware and/or software mechanisms. For example, these best practices may suggest secure hardware implementations.
The content identifier fields 604 may also be associated with at least one policy field 608. For convenience only,
These policy fields 608 may store policy information that enables playback devices, such as the hosts 120, to validate the license that is purportedly bound cryptographically to the store. Additionally, the policy fields may enable the host to determine whether particular operations (e.g., playbacks, copies, transfers, or the like) are permitted under the terms of the license bound cryptographically to the store.
The policy fields 608 may include information indicating any restrictions or conditions applicable to playing back, copying, transferring, accessing, or performing any other operations on the licensed content. The license for the content as granted by, for example, the license server 116, may specify the policies as stored in the fields 608. Examples of restrictions may include limitations on how many times the content may be played back, how much of the content may be played back, whether the content may be copies to other stores, or the like.
Having described the data structures 600 in
Block 702 represents presenting a selection of available content to a user. For example, the host 120 may present this selection in menu form to the user, after the user inserts the store 108 into the host. When the user inserts the store into the host, the host may examine the content/license storage area (e.g., 212) of the host to locate any available content on the host. The host may then extract identifiers associated with different instances of the available content to populate the selection of available content as presented to the user. This selection of available content may include a plurality of graphic elements, respectively representing the different instances of content available on the store.
The user may request that the host perform some operation on the selected content. For example, the user may request that the host playback the selected content, copy the selected content, or perform any other similar operation made available to the user.
Block 704 represents receiving an indication that the user has selected an instance of content. For example, the user may operate an input device to place one of the graphic elements in focus, and may then activate some control to select the graphic element that is focus. Block 704 may include receiving electrical signals, software events, or other suitable notifications that the user has made a selection.
Block 706 represents sending a request for the content selected by the user. Block 706 may include the host 120 sending the request, denoted generally at 708, to the store 108.
At the store, block 710 represents receiving the request for the content selected by the user. Block 710 may include the store receiving the request 708 from the host.
Block 712 represents identifying one or more content keys associated with the content selected by the user. It is noted that multiple content keys may be processed in the process flows shown in
Block 714 represents encrypting the content key using a session key.
Block 716 represents sending the encrypted content key, which is denoted generally at 718. For example, the store may send the encrypted content key 718 to the host.
At the host, block 720 represents evaluating the operation requested by the user against any content policy applicable to the content selected by the user.
In the example implementation shown in
Assuming that the evaluation performed in block 720 is positive, block 722 represents receiving the encrypted content key 618. In the example shown in
Using the content key, the host may access the content used to comply with the request received in block 704. In this manner, the host may validate that the policy has not been maliciously altered, by verifying the license signature.
Some implementations may use the intermediate session key that was described above. In these implementations, block 714 may include encrypting the content key (e.g., 606 in
Decision block 802 represents evaluating whether the content selected by the user is subject to a policy in a license. If not, the process flow 800 may take No branch 804 to block 806, which represents approving the request from the user.
Returning to block 802, if the selected content is subject to a license, then the process flow 800 may take Yes branch 808 to decision block 810. Decision block 810 represents evaluating whether the request from the user is permitted by any policy (e.g., 608) applicable to the selected content.
From block 810, if the request is permitted by any applicable policy, then the process flow 800 may take Yes branch 812 to block 806. Block 806 represents approving the request.
Block 814 represents performing the operation requested by the user. For example, block 806 may include communicating an approval 816 of the request from the user, and the process flow 800 may perform block 814 in response to the approval 816. Block 814 may include receiving the decrypted content key 506 from block 722 in
In some possible implementations, block 814 may include playing or otherwise presenting the selected content to the user. In other possible implementations, block 814 may include copying or transferring the selected content as requested by the user. These examples are given only for ease of description, but not to limit possible implementations.
Returning to decision block 810, if the request is not permitted by any applicable policy, then the process flow 800 may take No branch 818 to block 820. Block 820 represents denying the request submitted by the user, as not permitted by license policy applicable to the selected content. Block 820 may include sending a denial 822 of the request.
Block 824 represents presenting an error message or other suitable notification to the user who submitted the request denied in block 820. In some instances, block 824 may include indicating to the user that the request was denied because it was not permitted by the policy applicable to the selected content. Additionally, block 824 may include providing the user with one or more options for obtaining a license that would permit the requested operation.
Having described the above process flow 800 for evaluating the operation requested by the user against any applicable content policies, a few observations are noted. The implementations described in
In other situations, however, the store may have more processing capacity than the host. In these instances, the store may assume the role of evaluating the request against the content policy, thereby relieving a less-powerful host from this processing.
Turning to the protocols 900 in more detail, the blocks 702, 704, and 706 are carried forward from
Assuming the result of the evaluation block 720 is positive, the store may then perform block 712, which represents decrypting the content key for the selected content. Block 712 may include decrypting by the store private key 320. Additionally,
In the implementation shown in
Block 1002 represents evaluating whether content referenced in the request is subject to a license. If the content is subject to a license, the license would typically specify one or more policies (e.g., 608) that indicate how or whether the content may be accessed or disseminated. If the content is subject to a license, the process flows 1000 may take Yes Branch 1004 to evaluation block 906, which represents determining whether the request is permitted by any policies applicable to the content.
From evaluation block 1006, if the request is permitted by applicable policies, then the process flows 1000 may take Yes branch 1008 to block 712, which is carried forward from
Returning to the store, block 1010 represents approving the request. As shown in
Returning to evaluation block 1002, if the content is not subject to a license, then the process flows 1000 may take No branch 1014 directly to block 1010. As described above, block 1010 represents approving the request.
Returning to evaluation block 1006, if the request is not permitted by applicable policy, then the process flows 1000 may take No branch 1016 to block 1018, which represents denying the request. As shown in
At the host, block 1022 represents performing the requested operation relating to the content. Block 1022 may include performing the requested operation in response to receiving the approval 1012. To perform the requested operation, the host may utilize the content key decrypted in block 722.
Also at the host, block 1024 represents presenting an error message or other suitable communication to a user. For example, block 1024 may include indicating to the user that a requested operation is not permitted by licenses and/or policies applicable to the content. Block 1024 may also include indicating to the user how or where he or she may obtain one or more licenses to perform the requested operation.
Having described the process flows 1000 for evaluating the request against applicable content policies, the discussion now proceeds to a description of operating environments that include a token granting service, now presented with
In some instances, the user may download content 122 from a download server associated with, for example, the content/media source 106. As shown in
In other instances, however, the content to be played may not have been downloaded from a download server that is trusted by the license server. For example, the content may be pre-loaded onto a store (e.g., 108) by a manufacturer of the card, or by a retailer selling the store, and these operations may be controlled separately from the license server. In these instances, the operating environments 1100 shown in
Turning to the token granting service in more detail, it may generate a token 1004 to be stored onto the card, and may associate this token with some instance of licensed content. This token may indicate that any host into which the store is inserted is allowed to access the licensed content, consistent with any applicable license policies.
The token granting service may communicate this token, as associated with related content, to a manufacturer of the store 108, or to a retailer of the store. In turn, the retailer or manufacturer of the store may load the content and related token onto the store.
A user 102 may insert the store 108 into a host (e.g., 120), as represented generally by a line 1106. The host may include one or more processors and computer readable storage media, which are denoted by the reference numbers 218 and 222, respectively. These references are carried forward from
The computer readable storage media 222 may include a token validation module 1108, which may process the store 108 when it is inserted into the host 120. More specifically, the token validation module 1108 may interact with the token granting service 1102 to determine whether the host may play any content (e.g., 122) that is on the store.
The interaction between the token validation module 1108 and the token granting service 1102 may include at least some of the processing shown in
For ease of illustration and description,
In the example provided in
The token granting service may return a validation response 1118 to the token validation module on the host, with this validation response 1118 indicating whether the token was found to be valid or invalid. If the token granting service was able to validate the token, then the host may play the content associated with that token. If the token granting service was not able to validate the token, then the host may take some secondary action, such as presenting the token to another validation service, presenting an error message to a human user, or the like.
Returning to the evaluation block 1110, if the store that was inserted into the host does not contain any tokens related to licensed content on the store, then the token validation module may take No branch 1120 to block 1122. Block 1122 represents requesting a token from the token granting service 1102, with the line 1124 representing the request for the token.
At the token granting service, block 1126 represents generating a token in response to the request 1124, and associating the new token with content contained on the store (e.g., 122). Block 1126 may include prompting a human user to obtain any payments associated with obtaining a license to access the content.
Having described the operating environments relating to the token granting service in
The stores 108 may contain one or more licenses (e.g., 118), with
In any of the scenarios illustrated in
Using this temporary certificate or license 1202, the host may access and play the content corresponding to the temporary license or certificate. The temporary certificate or license may be temporally limited, as represented at 1204. The temporally limited license 1204 may enable the host to access the content for a pre-defined period of time, with the certificate or license expiring after this period of time.
In other examples, the temporary certificate or license 1202 may permit access to only certain portions of the content, as represented at 1206. This type of temporary license may be viewed as a type of preview license, in which the host may play only certain portions of the content, until a user or the host obtains a full license. This scenario may occur when, for example, a store is pre-loaded with content by a retailer or manufacturer. In these pre-loaded content scenarios, the store may contain only a preview license, but may nevertheless offer full licenses through the host.
In still other examples, the temporary certificate or license 1202 may permit a predefined number of accesses to the content, as represented at 1208. For example, the temporary license may permit only one playing of the content, with the temporary license expiring afterwards. However, this temporary license may permit any number of playbacks as appropriate in different implementations.
CONCLUSIONAlthough the systems and methods have been described in language specific to structural features and/or methodological acts, it is to be understood that the system and method defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as exemplary forms of implementing the claimed system and method.
In addition, regarding certain data and process flow diagrams described and illustrated herein, it is noted that the processes and sub-processes depicted therein may be performed in orders other than those illustrated without departing from the spirit and scope of the description herein. Also, while these data and process flows are described in connection with certain components herein, it is noted that these data and process flows could be performed with other components without departing from the spirit and scope of the description herein.
Claims
1. A machine-readable storage medium encoded with machine-readable instructions that, when executed by a machine, cause the machine to perform an authentication protocol comprising:
- generating a nonce;
- sending the nonce to a store associated with a host, the store being a portable storage device;
- receiving a session key from the store to authenticate the store to the host, the session key being generated using the nonce and encrypted using a public key associated with the host; and
- associating a license with the store and content contained in the store such that when the store is removed from the host and inserted into a second host, the license is transferred with the store such that the license remains associated with the store and the host does not retain residual rights to render the content, wherein the second host processes the store to determine whether the second host is authorized to render the content based at least in part on whether the store includes one or more tokens.
2. The machine-readable storage medium of claim 1, the authentication protocol further comprising encrypting the nonce before sending the nonce to the store.
3. The machine-readable storage medium of claim 2, wherein the nonce is encrypted using a public key associated with the store.
4. The machine-readable storage medium of claim 1, the authentication protocol further comprising receiving a store certificate from the store, wherein the store certificate includes a store public key.
5. The machine-readable storage medium of claim 4, the authentication protocol further comprising checking validity of the store certificate against at least one certificate revocation list.
6. The machine-readable storage medium of claim 4, the authentication protocol further comprising encrypting the nonce using the store public key.
7. The machine-readable storage medium of claim 6, the authentication protocol further comprising sending a host certificate to the store.
8. The machine-readable storage medium of claim 1, wherein the associating a license with content contained in the store includes binding the license to the session key from the store after completing the authentication protocol, the license enabling a host to access content contained on the store.
9. A mobile media player device that includes the machine-readable storage medium of claim 1.
10. A machine-readable storage medium encoded with machine-readable instructions that, when executed, cause a machine to perform operations comprising:
- receiving an encrypted nonce from a host associated with a store, the store being a portable storage device that is detachably coupled to the host;
- generating a session key based at least in part on the encrypted nonce;
- sending the session key to the host to authenticate the portable storage device;
- binding to the store one or more licenses associated with content contained in the store such that the one or more licenses are transferable with the store and are maintained in the store subsequent to a transfer of the content, the host determining that the host is authorized to render the content by: determining whether the store contains one or more tokens; parsing the one or more tokens to determine whether the one or more tokens are valid based at least in part on a determination that the store contains the one or more tokens; and requesting a token from a token granting service based at least in part on a determination that the store does not contain the one or more tokens.
11. The machine-readable storage medium of claim 10, wherein the operations further comprise receiving a host certificate, the host certificate including at least a public key associated with the host.
12. The machine-readable storage medium of claim 11, wherein the operations further comprise checking the host certificate against at least one certificate revocation list.
13. The machine-readable storage medium of claim 10, wherein the operations further comprise receiving a query for a store certificate.
14. The machine-readable storage medium of claim 10, wherein the operations further comprise sending a store certificate, the store certificate including at least a public key associated with the store.
15. The machine-readable storage medium of claim 10, wherein the nonce is encrypted with a public key associated with the store.
16. The machine-readable storage medium of claim 10, wherein the operations further comprise encrypting the session key using a public key associated with the host.
17. The machine-readable storage medium of claim 10, wherein the operations further comprise granting the license to the host after completing the authentication protocol, the license enabling the host to access content contained on the store.
18. The machine-readable storage medium of claim 10, wherein the machine-readable storage medium is included in a portable memory device.
19. The machine-readable storage medium of claim 18, wherein the portable memory device includes a flash memory, a Secure Digital (SD) card, or a Subscriber Identity Module (SIM) card.
20. A mobile media player device into which the portable memory device of claim 18 is inserted.
5715403 | February 3, 1998 | Stefik |
6681017 | January 20, 2004 | Matias et al. |
6999947 | February 14, 2006 | Utsumi et al. |
7010808 | March 7, 2006 | Leung et al. |
7076067 | July 11, 2006 | Raike et al. |
7103574 | September 5, 2006 | Peinado et al. |
7142674 | November 28, 2006 | Brickell |
7461249 | December 2, 2008 | Pearson et al. |
7689250 | March 30, 2010 | Kravitz et al. |
7711959 | May 4, 2010 | Schmidt et al. |
7779479 | August 17, 2010 | Lee et al. |
7801819 | September 21, 2010 | Swenson et al. |
7809957 | October 5, 2010 | Grawrock |
7917946 | March 29, 2011 | Lindholm et al. |
7975312 | July 5, 2011 | Broderson et al. |
8079071 | December 13, 2011 | Jogand-Coulomb et al. |
8261319 | September 4, 2012 | Libin et al. |
8296240 | October 23, 2012 | Read |
20030007646 | January 9, 2003 | Hurst et al. |
20030194092 | October 16, 2003 | Parks et al. |
20030212892 | November 13, 2003 | Oishi |
20030233550 | December 18, 2003 | Brickell |
20040064694 | April 1, 2004 | Lee et al. |
20050004875 | January 6, 2005 | Kontio et al. |
20050182727 | August 18, 2005 | Robert et al. |
20050182931 | August 18, 2005 | Robert et al. |
20050210252 | September 22, 2005 | Freeman et al. |
20050216763 | September 29, 2005 | Lee et al. |
20050234826 | October 20, 2005 | Ohmori et al. |
20050257074 | November 17, 2005 | Alkove et al. |
20050277403 | December 15, 2005 | Schmidt et al. |
20050289343 | December 29, 2005 | Tahan |
20060026433 | February 2, 2006 | Montenegro |
20060031175 | February 9, 2006 | Sellars et al. |
20060047976 | March 2, 2006 | Moroney et al. |
20060136735 | June 22, 2006 | Plotkin et al. |
20060154648 | July 13, 2006 | Oh et al. |
20070028118 | February 1, 2007 | Brown et al. |
20070081666 | April 12, 2007 | Shima |
20070100701 | May 3, 2007 | Boccon-Gibod et al. |
20070100893 | May 3, 2007 | Sanders |
20070178938 | August 2, 2007 | Kravitz et al. |
20070220616 | September 20, 2007 | Oh |
20070226489 | September 27, 2007 | Hug et al. |
20080027868 | January 31, 2008 | Ljung et al. |
20080040618 | February 14, 2008 | Andersson et al. |
20080046758 | February 21, 2008 | Cha et al. |
20080059797 | March 6, 2008 | Tokuno et al. |
20080072061 | March 20, 2008 | Cannon et al. |
20080109656 | May 8, 2008 | Kotzin |
20080114958 | May 15, 2008 | Jogand-Coulomb et al. |
20080235140 | September 25, 2008 | Read |
20090064341 | March 5, 2009 | Hartung et al. |
20090151006 | June 11, 2009 | Saeki et al. |
WO2006129934 | December 2006 | JP |
2007104465 | April 2007 | JP |
2007128278 | May 2007 | JP |
200765985 | November 2007 | JP |
200719688 | August 2008 | JP |
WO2006126801 | November 2006 | WO |
- Alapam Arnab, Specifications for a Componetised DRM framework, Sep. 4, 2005, Univ. Cape Town, pp. 41-43, 50-53.
- Atallah, et al., “Enhanced Smart-card based License Management”, retrieved at <<http://ieeexplore.ieee.org/iel5/8596/27235/01210240.pdf?isNumber=>>, Proceedings of the IEEE International Conference on E-Commerce (CEC'03), IEEE, 2003, 9 pages.
- Aura, et al., “Software License Management With Smart Cards”, retrieved at <<http://www.usenix.org/events/smartcard99/full—papers/aura/aura—html/#sec:smart—cards>>, Proceedings of USENIX Workshop on Smartcard Technology, May 10-11, 1999, Chicago, pp. 1-10.
- Mana, et al., “EC-GATE: An Infrastructure for DRM”, retrieved at <<http://www.lcc.uma.es/˜yague/SemanticsBasedAccessControl/CNIS—DRM'03.pdf>>, Proceedings of the IASTED International Conference Communication, Network, and Information Security, Dec. 10-12, 2003, USA, University of Malaga, Spain, pp. 6.
- Zhang, et al., “FLMP: A Flexible License Management Protocol for Digital Rights Management”, retrieved on Oct. 5, 2006, at <<http://scholar.google.com/scholar?num=20&hl=en&lr=lang—en&q=cache:Id1Q-c3IfoUJ:viola.usc.edu/paper/SPIE—VCIP2005/DATA/5960—122.PDF+DRM+license+store+bind>>, Tsinghua University, China, pp. 1-12.
- The Chinese Office Action mailed Dec. 14, 2011 for Chinese patent application No. 200880016965.2, a counterpart foreign application of US patent application No. 318484.01, 8 pages.
- The Chinese Office Action mailed May 24, 2012 for Chinese patent application No. 200880016965.2, a counterpart foreign application of U.S. Appl. No. 11/753,403, 6 pages.
- Chinese Office Action mailed Nov. 26, 2012 for Chinese patent application No. 200880016965.2, a counterpart foreign application of U.S. Appl. No. 11/753,403, 5 pages.
- Japanese Office Action mailed Feb. 13, 2013, for Japanese patent application No. 2010-509542, a counterpart foreign application of U.S. Appl. No. 11/753,403, 11 pages.
- Tsukada, “Public Key Infrastructure for the Enterprise System”, Nikkei BP, published on Dec. 25, 2001, pp. 1-10, 20-28, and 43-45.
Type: Grant
Filed: May 24, 2007
Date of Patent: Sep 17, 2013
Patent Publication Number: 20080294894
Assignee: Microsoft Corporation (Redmond, WA)
Inventors: Kedarnath A. Dubhashi (Redmond, WA), James M. Alkove (Woodinville, WA), Patrik Schnell (Issaquah, WA), Alexandre V. Grigorovitch (Redmond, WA), Vikram Mangalore (Redmond, WA)
Primary Examiner: Nathan Flynn
Assistant Examiner: Viral Lakhia
Application Number: 11/753,403
International Classification: H04L 9/32 (20060101);