The present invention. relates to a method for delivering content and a content server which delivers content. More specifically, the present invention relates to Digital Rights Management (DRM) or Intellectual Property Management and Protection (IPMP) for a generic digital content, especially to the protection and management of a digital content independent of any data format.
As various kinds of network are widely deployed, it will be demanded that digital content can be delivered and distributed to user via such network besides using CD, DVD. The corresponding issue is raised by content owner. Is it secure to sell their content in this way?
As hard disk or other storage embedded device become more and more, another issue is that how the content protection technique can ensure the entitled rights to be exercised correctly.
As many different digital formats exist to use for packaging content in digital form for easy transmitting over various network, question arises as how the protection technology can be cross-used among different digital formats.
At the same time users have more demands on the convenience with low cost for enjoying content, even sharing with their friends if they purchase such rights, to have rich user experience.
Conflict is always there since content owner cares for any illegal copy so that content providers are trying to protect content in their own proprietary ways due to lacking of the open protection techniques in the market at that time.
This not only brings a big barrier for content owner to sell content, but also brings a heavy cost for CE (consumer electronics) manufacturers to produce different versions of the product just for matching with various protection techniques which content provider use.
MPEG-21 is trying to define a generic framework to enable transparent and augmented use of digital content across a wide range of networks and devices used by different communities. How to protect the contents when they are being used across network or devices, becomes a very important item in MPEG-21, which is the part 4 of MPEG-21, called MPEG-21 IPMP (Intellectual Property Management and Protection).
In the past, people working on MPEG-4/2 IPMP Extension were required to define a content protection scheme based on MPEG-4/2 system since the aim is to protect any content if they are packaged in MPEG-4/2 format.
In MPEG-21, a Digital Item (DI) is defined as a structured digital object for any digital content with a standard representation, identification and description, and it will be used as the fundamental unit of interchange, distribution and transaction within MPEG-21 framework.
The Digital Item is declared and expressed using XML by Digital Item Declaration (DID). Besides a digital content which is represented as media resources in MPEG-21, such as video, music, image, the DID provides the flexible structure to include various kinds of functional metadata. Such metadata is supposed to describe media resource format, to specify resource protection scheme, to give the resource an identification name, to provide User preference, etc.
Besides the core part of DID technology, some other key technologies have also been elaborately developed or are under development. Digital Item Identification (DII), Digital Item Adaptation (DIA), Intellectual Property Management and Protection (IPMP), REL(Rights Expression Language)/RDD (Rights Data Dictionary), as well as ER (Event Reporting) are all the important technologies for extensively exploiting the Digital Items' usage. All the functional metadata defined by these technologies can be placed into a DID document to aid the actual media resource consumption.
In order to prevent copyright infringement such as an illegal copy, a protecting process such as encrypting. is performed to digital content. In the DID document, a description related to IPMP (referred to as an “IPMP description”, hereinafter) is, for example, related to a protecting process tool with which the protecting process is performed or a protection canceling tool with which the protection is canceled. A terminal on the user side analyzes the IPMP description. The user downloads the necessary protection canceling tool based on the result of the analysis to cancel the protection of the content by using the protection canceling tool, and then performs processes such as a content reproducing process and a content printing process. Since the protecting process tool and the protection canceling tool are paired, even if the protecting process tool is described in the IPMP description, the corresponding protection canceling tool can be downloaded. The protecting process tool is, for example, an encryption tool, an electronic watermark (watermarking) embedding tool, a digital signature tool, or the like. Protection canceling tools corresponding to these protecting process tools are a decryption tool, a detection tool, and a checking tool, respectively. Hereinafter, an “IPMP tool” indicates the protecting process tool or a protection canceling tool.
REL is a language which regulates user's right such as “John can reproduce one piece of music for one month”, in other words, a language which regulates use conditions of content. A user terminal analyzes the REL description. The user can perform processes such as a content reproducing process and a content printing process only when the use conditions regulated by the REL description are satisfied.
A content protection and management mechanism is highly requested to address most of the requirements raised by many different application domains, especially in the scope of MPEG-21 domain, to reflect the market needs.
The Related Art are as follows:
1: Inventors: Zhongyang Huang, Ming Ji, Sheng Mei Shen, Takanori Senoh, Takuyo Kogure, and Takafumi Ueno, a patent related to “Apparatus of an MPEG-21 System”, internal patent number Pat 01.028, filed in Japan on February 2002
2: “ISO/IEC 21000-2 MPEG-21 Digital Item Declaration FDIS”, ISO/IEC JTC1 SC29/WG11/N4813, May 2002
3: “IMPEG-21 Architecture, Scenarios and IPMP Requirements”, ISO/IEC JTC1 SC29/WG11/N5874, July 2003
In the conventional DID document, the IPMP description and the REL description related to a specific content is not given together in one digital item having the specific content or the address of the specific content, that is, the IPMP description and the REL description are separately given. When the IPMP description and the REL description are separately given, however, there is a problem of low efficiency and a large time loss in analyzing the descriptions separately, because the IPMP description and the REL description are closely related to each other. For example, when the DID document shown in
Furthermore, it is an object of the present invention to solve the following problems.
The requirements on MPEG-21 IPMP are the problems to be targeted and solved here.
IPMP, especially MPEG-21 IPMP shall support the management and protection of intellectual property in descriptors and description schemes.
IPMP, especially MPEG-21 IPMP shall provide for interoperability so that content is able to be played anywhere.
IPMP, especially MPEG-21 IPMP should enable devices to dynamically discover, request, and obtain upgrades for supporting new media formats, IPMP tools and support.
IPMP, especially MPEG-21 IPMP shall provide mechanisms to reference Digital Item Descriptions as part of the language, make reference to external content descriptions.
IPMP, especially MPEG-21 IPMP shall provide mechanisms to associate Expressions with composite Digital Items.
IPMP, especially MPEG-21 IPMP shall provide mechanisms to reference Containers or other aggregations of Digital Items.
IPMP, especially MPEG-21 IPMP should flag that a particular Expression should be subject to protection. The protection itself (if any) is provided by an IPMP system controlling the Expression as a Digital Item.
IPMP, especially MPEG-21 IPMP shall provide mechanisms to reference authentication schemes.
IPMP, especially MPEG-21 IPMP shall provide mechanisms to ensure that the IPMP is independent of the format or delivery channel of Digital Items.
IPMP, especially MPEG-21 IPMP shall unambiguously articulate requirements relating to IPMP Tool and Features.
IPMP, especially MPEG-21 IPMP shall need to identify IPMP Tools and Features to build trusted IPMP implementations.
IPMP Tools and Features are components parts to build an IPMP-enabled Terminal or Peer. It should also possible for a Terminal or Peer to disclose its IPMP capability (IPMP Tools and Features). This makes it possible for a communicating Terminal or Peer to examine IPMP capability of another Terminal or Peer before deciding to engage with it.
The present invention has been made to solve the above problems and has an object to provide a method for delivering content and a content server which can make it possible for a user to efficiently obtain a protection canceling tool without wasting time to perform reproduction or the like of content.
On the content packaging side:
By introducing the concept of IPMP Control Graph to refer to all the rights and protection information which is directly associated with the content;
By defining IPMP Control Graph or REL-IPMP Control Graph as protection metadata holder to contain rights and protection information which is used to package and protect the content;
By placing rights & condition in the IPMP Control Graph or REL-IPMP Control Graph;
By placing content encryption information in the IPMP Control Graph or REL-IPMP Control Graph;
By placing watermarking information in the IPMP Control Graph or REL-IPMP Control Graph;
By placing rights protection information in the IPMP Control Graph or REL-IPMP Control Graph;
By placing and indicating key information which is used to encrypt content in the IPMP Control Graph or REL-IPMP Control Graph;
By placing key/license information in the IPMP Control Graph or REL-IPMP Control Graph, or in Rights, DID, or somewhere indicated by keyLocation;
By indicating which IPMP Tool is used for encryption, digital signing, watermarking with ToolID in the IPMP Control Graph or REL-EPMP Control Graph;
By associating rights and protection with the protected digital content or its sub content using content ID or DII and sub content ID;
By placing IPMP Control Graph or REL-IPMP Control Graph in DID container or other appropriate place in other application domains;
On the terminal side:
By parsing DID to retrieve content ID or sub content ID, and IPMP Control Graph or REL-IPMP Control Graph;
By parsing IPMP Control Graph or REL-IPMP Control Graph to retrieve Rights and Protection related descriptions;
By invoking IPMP tools which are used to protect the content or rights, or other metadata;
By retrieving key information from KeyData Holder directly of indirectly;
By retrieving a key license from a protected License Manager;
By un-protecting the protected content using the above obtained information;
By checking Rights' integrity using the tool indicated by ToolID;
By parsing the rights and conditions which are embedded with the content;
By retrieving watermarking descriptions and preparing for further action.
A first method for delivering content according to the present invention includes the steps of:
processing the content to protect copyright of the content;
deciding use conditions of the content;
describing a first digital item or a second digital item in which said first digital item is defined in a form of Digital Item Declaration, said first digital item containing the content or an address of the content and being able to contain other digital items defined therein;
packaging said first or second digital item described in the form of Digital Item Declaration; and
delivering said first or second digital item packaged in said packaging step to a user terminal;
wherein, in said describing step, a first description regarding processing the content to protect the copyright of the content and a second description regarding the use conditions are both described in said first digital item.
Preferably, said second description is described followed by said first description in said first digital item, so that said second description is analyzed ahead of said first description by the user terminal.
Preferably, said describing step includes a step of describing a flag which indicates that the copyright of the content is protected, and information of a first protect canceling tool for canceling the protection of the copyright of the content. This method is as referred to a second method for delivering content.
Preferably, in the second method for delivering content, said processing step includes at least one of a step of embedding digital watermarking in the content, a step of encrypting the content, and a step of making digital signature in the content, and said description step includes a step of describing, based on a type of processing the content to protect the copyright, at least one of a set of a flag which indicates that the digital watermarking is embedded in the content and information of a detection tool for detecting the digital watermarking, a set of a flag which indicates that the content is encrypted and information of a decryption tool for decrypting the content, and a set of a flag which indicates that the digital signature is made in the content and information of a checking tool for checking the digital signature, as said first description. This method is as referred to a third method for delivering content.
Preferably, in the third method for delivering content, said processing step includes a step of encrypting the content with a use of an encryption key, and
said describing step includes a step of describing a flag which indicates that the content is encrypted, the information of a decryption tool for decrypting the content, and information of the encryption key, as said first description. This method is as referred to a fourth method for delivering content.
Preferably, in the fourth method for delivering content, said processing step further includes a step of encrypting the encryption key, and
said describing step further includes a step of describing information of a license key for decrypting the encrypted encryption key. This method is as referred to a fifth method for delivering content.
Preferably, in each of the first to fifth methods for delivering content, further includes the steps of:
processing said second description to protect copyright of said second description;
describing a flag which indicates that the copyright of said second description is protected, and information of a second protect canceling tool for canceling the protection of the copyright of said second description.
A content server according to the present invention includes:
a content processor which processes content to protect copyright of the content;
a use condition generator which generates use conditions of the content;
a describer which describes a first digital item or a second digital item in which the first digital item is defined in a form of Digital Item Declaration, said first digital item containing the content or an address of the content and being able to contain other digital items defined therein;
a packaging unit which packages said first or second digital item described in the form of Digital Item Declaration; and
a deliverer which delivers said first or second digital item packaged by said packaging unit to a user terminal;
wherein said describer describes both of a first description regarding processing the content to protect the copyright of the content and a second description regarding the use conditions in said first digital item.
Preferably, in the first content server, said describer describes a flag which indicates that the copyright of the content is protected, and information of a first protect canceling tool for canceling the protection of the copyright of the content. This content server is referred to as a second content server.
Preferably, in each of the first and second content server, said content processor processes said second description to protect copyright of said second description; and
said describer describes a flag which indicates that the copyright of said second description is protected, and information of a second protect canceling tool for canceling the protection of the copyright of said second description.
According to a content delivering method and a content server of the present invention, in a digital item having content or an address of the content, both an IPMP description and a REL description related to the content are given. In this manner, for every content, a user terminal can analyze the REL description and the IPMP description related to the content. Therefore, a user can obtain only a protection canceling tool necessary for processing the content. When the REL description is given before the IPMP description is given in the digital item, the user terminal analyzes the REL description prior to the IPMP description. For this reason, only a protection canceling tool necessary for the REL description can be obtained. As a result, the user can efficiently obtain the protection canceling tool without wasting time to make it possible to perform reproduction or the like of the content.
The invention is very effective when content is required to be protected with rights and conditions, especially such content can be in any data form and could be transmitted via various network.
The invention is effective when such protection is required to associate with the protected content via content ID, especially such protection information is defined as a set of descriptions attached to the protected content using content ID, or DII in MPEG-21;
The invention is effective when such protection is placed in a generic IPMP Control Graph holder or REL-IPMP Control Graph holder, which is clean and convenient for content creation, content distribution, as well as content consumption, and such holder could be carried in DID in MPEG-21 static file format or carried in SDP for RTP transmission.
The invention is effective when each of the protection is indicated by ToolID so that both defined IPMP tool and external IPMP Tool can be used for flexibility, renewability and extensibility.
On the content production side as shown in
The content could be watermarked using certain watermarking tool to achieve certain functions, such as finger printing, persistent association, or copyright protection by embedding CID or other information.
The content can be encrypted by an IPMP tool with ToolIDXXX, where xxx is the number which is registered with RA (Registration Authority), to indicate which encryption algorithm is used. A default tool such as AES is defined for simple hardware to implement. The resulted Key information could be carried in IPMP Control Graph directly or by pointing to a location where the whole Key information data could be found. The encryption key can be further encrypted and finally a. license could be generated and directly carried in either IPMP Control Graph, in REL data or other Rights Expression Data, or in DID itself, or in somewhere which can be indicated by KeyLocation indicator to be carried in IPMP Control Graph/REL/DID;
However the segments of key information would also possibly be packaged together with the associated content segments when the protected content is transmitted via network for synchronization purpose.
Rights can be expressed by an independent and existing technology standard such as REL defined in MPEG-21 or other Rights Expression methods, and such rights could be protected by digital signature for its integrity.
On the content consumption side as shown in
The corresponding protection tools would be invoked and acted on the protected object, the tools can be those normative tools defined by MPEG-21 standard and hence installed in the device, or the tools can be proprietary and identified by tool IDs which can be downloaded from a remote location;
Tool is identified by a registered Tool ID, which is a flag to tell terminal or device to prepare the corresponding tool or locate the tool beforehand;
The key information is retrieved from KeyData Holder defined and carried in IPMP Control Graph directly or indirectly, and it would also possibly be obtained in segment with the corresponding content segment to be protected if the content is distributed through network.
The license information can be obtained from License Manager which could be a temper resistant entity to prevent any disclosure of how a license is retrieved by a license manager.
Rights and content is un-protected by using the above key, key data, and protection tool. Rights is further parsed by Rights Parser to obtain the rights and conditions in clear form, so that the rights and conditions processing can be conducted.
Therefore the un-protected content can be played back, rendered, modified, deleted, or adapted if there is such rights entitled for the user.
As shown in
The DID has defined a useful model (unit 1.1 in
Module 1.2 shown in
The further improvements over the Prior Art are:
Since DID is to address static relation among each elements and it can be treated as file format, rights and protection information can be directly associated to its protected content as IPMP_Control_Graph, shown in
On the other hand, key information can be carried from KeyData Holder in IPMP_Control_Graph directly or indirectly. It could also be segmented when the content is delivered via network.
Rights which might be encrypted is carried separately or together with protection information.
Another Prior Art is shown in
The Rights Expression Language (REL) Engine in module 2.1 is the component that determines REL authorizations, given an authorization request and a set of licenses and root grants. The REL Engine uses the License Manager to help resolve authorization queries.
The Digital Item Manager in module 2.2 parses Digital Item Declarations within Digital Items. The Digital Item Manager also provides access to where the Digital Items are, and creates Digital Item iNstances in module 2.3. The Digital Item Manager passes to the License Manager any Licenses that are embedded within Digital Item Declarations.
The Digital Item iNstance in module 2.3 represents a Digital Item within a Trusted Domain. The Digital Item iNstance contains local metadata about the Digital Item, such as storage location and possibly information about content encryption keys.
The License Manager in module 2.4 supports the REL Engine by managing the persistent state of Licenses and their authorization or revocation status. The License Manager is also responsible for verifying the integrity of Licenses.
The Condition Processor in module 2.5 selects, evaluates and fulfills Conditions, and initiates the execution of authorized Operations (via the DIP Processor, generating a Right Exercise) once conditions are satisfied.
The IPMP User Session Manager in module 2.6 orchestrates the invocation of Digital Item Operations (via the Condition Evaluator), first making sure that proper authorization is obtained (via the REL Engine) and that conditions are evaluated (via the Condition Evaluator).
A Right Exercise in module 2.7 is a record of having exercised a right, i.e., the invocation of a Digital Item Operation. It is maintained by the User Session Manager, and is used to associate the fulfillment of Conditions with the exercise of Rights.
The Digital Item Processing Engine in module 2.8 executes Digital Item Operations, including Digital Item Methods (DIMs), Digital Item Basic Operations (DIBOs) in module 2.9, and Digital Item eXtended Operations (DIXOs) in module 2.10. The DIMs are executed by a DIM Engine, the DIXOs by a DIXO Engine, and the DIBOs by a DIBO Library. The Digital Item Processing Engine updates the User Session State with process state information.
The big issue with
The second issue with
The third issue with
The better rights and protection is designed based on the two cases. The first case is where the existing REL is employed for expressing the corresponding rights and conditions and a protection control mechanism is defined to take care of content protection including encryption, watermarking, key management. The second case is where the existing REL is extended by adding protection function which could include encryption, watermarking, key management, etc.
Both cases are elaborated in the following sections.
(Content Packaging and Consumption with Separate Right and Protection)
The DID describer 26 describes a digital item having content to which an ID is assigned or an address of the content in a form of Digital Item Declaration. The DID describer 26 gives a description related to a use condition of content represented by the use condition data input from the use condition data generator 25 and a description related to a protecting process performed to the content in the digital item. The packaging unit 27 packages the digital items described in the form of Digital Item Declaration. The deliverer 28 delivers the packaged digital items to a user terminal. And, the deliverer 28 externally outputs the protection canceling tool output from the content protecting processor 24. The digital item can be recursively defined, i.e., the digital item can define another digital item in the digital item itself. The DID describer 26 gives a description related to a use condition of the content and a description related to a protecting process of the content in the same digital item as that having the content or the address of the content.
As in
When the content is needed to transmit via network, normally it will be segmented, encrypted and stored as Resource somewhere, and the corresponding time-variant key is stored as Key Information in KeyData Holder in IPMP Control Graph in module 5.9 directly or indirectly by pointing to a location.
For example when the protected content is transmitted over RTF, IPMP Control Graph can be carried in SDP (Section Description Protocol), while the key information can be carried in the RTP header or as special case for video and audio packet as long as there has synchronization among time-variant keys and the protected video or audio data.
Module 5.1 is to assign content ID, DII in MPEG-21 could be used here. If necessary sub content ID can be used and the protection can be associated with this sub content ID if the sub content need to be protected. The assignment of content ID is performed by the content assigner 23.
Module 5.2 is to place a flag in IPMP Control Graph to tell if the content is protected or free. Module 5.3 is to place a flag in IPMP Control Graph to indicate if there is watermarking embedded. The place of those flags is performed by the DID describer 26.
If there is watermarking embedded in the content, module 5.4 will assign watermarking (WM) ToolID for the WM tool used for this case, and ToolID is then recorded and placed in IPMP Control Graph. The module 5.5 will create WM Descriptions including watermarking Interface or API related information which is placed in IPMP Control Graph. The assignment of the WM ToolID is performed by the content protecting processor 24. The placement of the WM ToolID in IPMP Control Graph, and the creation of the WM Descriptions are performed by the DID describer 26.
Module 5.6 is to determine if the content will be encrypted, and a flag for “Yes/No” will be placed in IPMP Control Graph in module 5.15. The placement of the flag is performed by the DID describer 26.
Module 5.9 is to assign encryption ToolID for the encryption tool used for this case, and ToolID is then recorded and placed in IPMP Control Graph. The module 5.7 is to place Key information in KeyData Holder directly in IPMP Control Graph, or pointing by the Holder to other location. The assignment of the encryption Tool ID is performed by the content protecting processor 24. The placement of the encryption ToolID in IPMP Control Graph, and the placement of the Key information are performed by the DID describer 26.
The encryption key can be further encrypted in module 5.11, and 5.13, and the key as a license is eventually placed in IPMP Control Graph, REL, DID, or somewhere indicated by KeyLocation1. The encryption of the key is performed by the content protecting processor 24, and the placement of the key as a license is performed by the DID describer 26.
Module 5.8 is to create and package rights with the corresponding conditions which conforms to the existing REL standard, and this part could be modified and edited by distribution agents in the content distribution value chain. The creation of the right is performed by the use condition data generator 25.
The module 5.10 is to protect the rights metadata by digitally signing the rights. Module 5.12 is to assign ToolID for the verification of the digital signature, and module 5.14 is to place the Entity_Key in IPMP Control Graph, or in DID, or in somewhere indicated by KeyLocation2. The assignment of the digital signature of the rights and ToolID for the verification of the digital signature is performed by the content protecting processor 24. The placement of the Entity_Key is performed by the DID describer 26.
The detail of module 5.15 is shown in
It will be described in detail about
As shown in
As shown in Table 1, the “KeyInformation” in the IPMP description is key information of the encryption key used to encrypt the content. The encryption key is encrypted to prevent the encryption key from being abused when content is delivered to a user. The license key is a key to decrypt the code. A position where a license key is arranged is described in the above-mentioned IPMP description.
Table 2 shows the meaning of a REL description (6.8). In Table 2, the left column shows actual descriptions, and the right column shows simple meanings of the descriptions.
As shown in
As shown in
A protecting process may be performed to the REL description (metadata of right) . In the case, the DID describer 26 uses the data received from the use condition data generator 25 to form a REL description, and sends the REL description to the content protecting processor 24. The content protecting processor 24 performs a protecting process to the received REL description. At this time, the process performed by the content server 20 is the same as the process performed by it when the protecting process is performed to the content. More specifically, processes shown in steps S2 and S3 in
Module 9.1 is to parse DID and IPMP Control Graph information where DID parser is required only for the case IPMP Control Graph is carried in DID in MPEG-21 case.
In the case of content distribution over RTF network, IPMP Control Graph can be retrieved from SDP to obtain rights and protection description information except the key information if it is time-variant.
Module 9.2 is to detect if the content is protected or free. If it is free, it will be able to play back by module 9.18 for consumption. Otherwise there are three branches to go and check in module 9.3, 9.4, and 9.5, respectively.
Module 9.3 is to detect if the Rights is encrypted, module 9.4 is to detect if the content is encrypted, and module 9.5 is to detect if the content is watermarked.
If the rights is protected, module 9.6 is to invoke the protection tool with ToolID and module 9.7 is to check the integrity of the rights using the tool. If the integrity is successfully verified in module 9.8, the rights will be sent to module 9.9 for parsing the rights by REL Engine which conforms to the existing REL standard.
Module 9.11 is to process the rights and conditions attached to the content and store the entitled rights and conditions in a buffer. In module 9.19 those rights requested by the users are subjected to checking against the rights and conditions stored in the buffer.
If there is license carried in Rights, module 9.10 is to retrieve license from License Manager which may be temper resistant (TR) protected.
If the content is protected and encrypted, module 9.13 is to invoke the encryption tool indicated by ToolID carried in IPMP Control Graph, module 9.14 is to retrieve Key Information, and module 9.12 is to obtaining the key license from License Manager.
License Manager here could be protected by temper resistant technique if it is part of the terminal or somewhere in other places, since it will provide the actual license which the decryption engine will use to un-protect the content.
The encryption tool can be defined as default for most of the terminals to use in their implementation, while an IPMP ToolID is provided so that people can choose other than default encryption tool in their special domain. If the platform is allowed to download and use different encryption tool indicated by ToolID, it would achieve extensibility, flexibility and renewability at the same time we will achieve interoperability across different domains.
Key Information could be retrieved from different places in the case of content delivery via various networks. This will depend on where you place key information. If you place them in RTF header, you can get them there, while if you place them as other packets like video and audio data, you can get them by following the same rules applied to video and audio. The time-variant key information is required to obtain in the same time when you need to decrypt the video and audio content.
Module 9.15 is to decrypt the content with the invoked tool, KeyData, and License, then passed to module 9.17 for further processing.
If the content is detected as watermarked in module 9.5, the watermarking tool with ToolID and its description data including interface will be invoked and prepared in module 9.16 for action which is up to user's request.
Finally module 9.17 is to exercise the rights which user is requested based on the entitled rights & conditions, and act on the un-protected content which is the output of module 9.15.
In
As shown in
Decrypting, watermarking, etc. in module 10.12, could be conducted in module 10.8 if such method is defined in DIME, or in module 10.9 if it is defined as one function of DEBO, or in module 10.10 if it is an external function.
The line 10.14 is shown for the data flow from IPMP Control Graph processing module to REL Engine, and the line 10.15 is shown for the data flow from IPMP Control Graph processing module to NI iNstance.
The line 10.16 is shown for the data flow from License Manager to the un-protecting block in the module 10.12 for issuing a license.
Module 10.13 is for Event Reporting Engine which is placed in the same trusted domain compared to that in
TR means Temper Resistance module to be used to protect License Manager operation and Condition Processing Operation.
Other modules have the similar meaning as explained in
(Content Packaging and Consumption with Mixed Rights and Protection)
A content server according to an embodiment 2 of the present invention has the same configuration and the same operation as those in the content server according to the embodiment 1, and therefore, a description thereof will be omitted.
In this case, there is no clear boundary between rights and protection, and they are mixed. IPMP Control Graph can be considered as REL-IPMP Control Graph.
Based on the current MPEG-21 REL or other rights expression language, protection of content as well as indicating for how to protect the content is not defined. In this case the existing REL has to be extended to support such protection signaling.
As shown in
Other modules have the same functions as explained above.
As in
When the content is needed to transmit via network, normally it will be segmented, encrypted and stored as Resource somewhere, and the corresponding time-variant key is stored as Key Information in KeyData Holder in REL-EPMP Control Graph in module 11.9 directly or indirectly by pointing to a location.
For example when the protected content is transmitted over RTP, REL-EPMP Control Graph can be carried in SDP (Section Description Protocol), while the key information can be carried in the RTP header or as special case for video and audio packet as long as they are synchronized among time-variant keys and the protected video or audio data.
Module 11.1 is to assign content ID, DII in MPEG-21 could be used here. Module 11.2 is to place a flag in REL-IPMP Control Graph to tell if the content is protected or free. Module 11.3 is to place a flag in REL-IPMP Control Graph to indicate if there is watermarking embedded.
If there is watermarking embedded in the content, module 11.4 will assign watermarking (WM) ToolID for the WM tool used for this case, and ToolID is then recorded and placed in REL-IPMP Control Graph. The module 11.5 will create WM Descriptions including watermarking Interface or API related information which is placed in REL-IPMP Control Graph.
Module 11.6 is to determine if the content will be encrypted, and a flag for “Yes/No” will be placed in REL-IPMP Control Graph in module 11.15.
Module 11.9 is to assign encryption ToolID for the encryption tool used for this case, and ToolID is then recorded and placed in REL-IPMP Control Graph. The module 11.7 is to place Key information in KeyData Holder directly in REL-IPMP Control Graph, or pointing by the Holder to other location.
The encryption key can be further encrypted in module 11.11, and 11.13, and the key as a license is eventually placed in REL-IPMP Control Graph, REL, DID, or somewhere indicated by KeyLocation1.
Module 11.8 is to create and package rights with the corresponding conditions which conforms to the existing REL standard, and this part could be modified and edited by distribution agents in the content distribution value chain.
The module 11.10 is to protect the rights metadata by digitally signing the rights. Module 11.12 is to assign ToolID for the verification of the digital signature, and module 11.14 is to place the Entity_Key in REL-IPMP Control Graph, or in DID, or in somewhere indicated by KeyLocation2.
The detail of module 11.15 is shown in
It can be seen from the
The characteristic feature of the present invention in which both an IPMP description and a REL description related to certain content are given in a digital item having the content, and the IPMP description and the REL description are set in the same package to deliver the package to a terminal can also be applied to the following case.
Considering about the case that it is described in the REL description that certain content can be watched at a plurality of resolutions and it is described in the IPMP description about a decryption tool necessary when the content is decrypted for each resolution, when the IPMP description and the REL description related to one piece of content are given to different digital items, and therefore, the REL description and the IPMP description are independently interpreted on a reception side, all the decryption tools necessary when the content is watched for all of the resolutions are downloaded at once when the IPMP description is interpreted. In this case, even if a user desires to watch the content at one specific resolution, all the decryption tools are downloaded. For this reason, long time and large cost are disadvantageously required to transmit the unused decryption tools, and a memory for storing the unused decryption tools must be disadvantageously assured. In contrast to this, when both the IPMP description and the REL description are given in a digital item having the content, and the IPMP description and the REL description are delivered as the same package, only necessary decryption tools related to the resolution desired by a user can be downloaded. Thus, time and cost required to transmit the decryption tools can be minimized, and unnecessary tools need not be stored in a memory advantageously.
As shown in
Other modules are the same functions as explained in the above.
In
Module 14.1 is to parse DID and REL-IPMP Control Graph information where DID parser is required only for the case REL-IPMP Control Graph is carried in DID in MPEG-21 case.
In the case of content distribution over RTF network, REL-IPMP Control Graph can be retrieved from SDP to obtain rights and protection description information except the key information if it is time-variant.
Module 14.2 is to detect if the content is protected or free. If it is free, it will be able to play back by module 14.18 for consumption. Otherwise there are three branches to go and check in module 14.3, 14.4, and 14.5, respectively.
Module 14.3 is to detect if the Rights is encrypted, module 14.4 is to detect if the content is encrypted, and module 14.5 is to detect if the content is watermarked.
If the rights is protected, module 14.6 is to invoke the protection tool with ToolID and module 14.7 is to check the integrity of the rights using the tool. If the integrity is successfully verified in module 14.8, the rights will be sent to module 14.9 for parsing the rights by REL Engine which conforms to the existing REL standard.
Module 14.11 is to process the rights and conditions attached to the content and store the entitled rights and conditions in a buffer. In module 14.19 those rights requested by the users are subjected to checking against the rights and conditions stored in the buffer.
If there is license carried in Rights, module 14.10 is to retrieve license from License Manager which may be temper resistant (TR) protected.
If the content is protected and encrypted, module 14.13 is to invoke the encryption tool indicated by ToolID carried in REL-IPMP Control Graph, module 14.14 is to retrieve KeyInformation, and module 14.12 is to obtaining the key license from License Manager.
License Manager here could be protected by temper resistant technique if it is part of the terminal or somewhere in other places, since it will provide the actual license which the decryption engine will use to un-protect the content.
The encryption tool can be defined as default for most of the terminals to use in their implementation, while an IPMP ToolID is provided so that people can choose other than default encryption tool in their special domain or case. If the platform is allowed to download and use different encryption tool indicated by ToolID, it would achieve extensibility, flexibility and renewability at the same time we will achieve interoperability across different domains.
Key Information could be retrieved from different places in the case of content delivery via various networks. This will depend on where you place key information. If you place them in RTF header, you can get them there, while if you place them as other packets like video and audio data, you can get them by following the same rules applied to video and audio. The time-variant key information is required to obtain in the same time when you need to decrypt the video and audio content.
Module 14.15 is to decrypting the content with the invoked tool, KeyData, and License, then passed to module 14.17 for further processing.
If the content is detected as watermarked in module 14.5, the watermarking tool with ToolID and its description data including interface will be invoked and prepared in module 14.16 for action which is up to user's request.
Finally module 14.17 is to exercise the rights which user is requested based on the entitled rights & conditions, and act on the un-protected content which is the output of module 14.15
In
As shown in
Decrypting, watermarking, etc. in module 15.12, could be conducted in module 15.8 if such method is defined in DIME, or in module 15.9 if it is defined as one function of DIBO, or in module 15.10 if it is an external function.
The line 15.14 is shown for the data flow from REL-EPMP Control Graph processing module to REL Engine, and the line 15.15 is shown for the data flow from REL-IPMP Control Graph processing module to NI iNstance.
The line 15.16 is shown for the data flow from License Manager to the un-protecting block in the module 15.12 for issuing a license.
Module 15.13 is for Event Reporting Engine which is placed in the same trusted domain compared to that in
TR means Temper Resistance module to be used to protect License Manager operation and Condition Processing Operation.
Other modules have the similar meaning as explained in
In
The present invention has been described with respect to the specific embodiment. However, many other modifications, corrections, and other uses are apparent to persons skilled in the art. Therefore, the present invention is not limited to a specific disclosure and can be limited by only the accompanying claims of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2003-353691 | Oct 2003 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP04/14344 | 9/30/2004 | WO | 4/11/2006 |