<p> INTERNATIONAL ORGANISATION FOR STANDARDISATION</p><p>ORGANISATION INTERNATIONALE DE NORMALISATION</p><p>ISO/IEC JTC 1/SC 29/WG 11</p><p>CODING OF MOVING PICTURES AND AUDIO</p><p>ISO/IEC JTC 1/SC 29/WG 11 N10471</p><p>Lausanne, CH – February 2009</p><p>Source: Systems</p><p>Title: Text of ISO/IEC 23006-1 CD MXM APIs</p><p>Status Work in progress (Editing period)</p><p>Source Filippo Chiariglione (CEDEO.net)</p><p>Marius Preda (TELECOM SudParis)</p><p>Christian Timmerer (Klagenfurt University)</p><p>Wonsuk Lee (ETRI)</p><p>Text of ISO/IEC 23006-1 CD MXM APIs</p><p>Document type: Document subtype: Document stage: Document language: </p><p>© ISO/IEC 2009 — All rights reserved</p><p>ISO/IEC JTC 1/SC 29 N </p><p>Date: 2009-02-6</p><p>ISO/IEC CD 23006-2</p><p>ISO/IEC JTC 1/SC 29/WG 11</p><p>Secretariat: ANSI</p><p>Information technology — MPEG-M (MPEG eXtensible Middleware) — Part 2: MXM API</p><p>Élément introductif — Élément central — Partie 2: Titre de la partie</p><p>Warning</p><p>This document is not an ISO International Standard. It is distributed for review and comment. It is subject to change without notice and may not be referred to as an International Standard.</p><p>Recipients of this document are invited to submit, with their comments, notification of any relevant patent rights of which they are aware and to provide supporting documentation.</p><p>Document type: International Standard Document subtype: Document stage: (30) Committee Document language: E</p><p>STD Version 2.0 ISO/IEC CD 23006-2 Copyright notice</p><p>This ISO document is a working draft or committee draft and is copyright-protected by ISO. While the reproduction of working drafts or committee drafts in any form for use by participants in the ISO standards development process is permitted without prior permission from ISO, neither this document nor any extract from it may be reproduced, stored or transmitted in any form for any other purpose without prior written permission from ISO.</p><p>Requests for permission to reproduce this document for the purpose of selling it should be addressed as shown below or to ISO's member body in the country of the requester: [Indicate the full address, telephone number, fax number, telex number, and electronic mail address, as appropriate, of the Copyright Manger of the ISO member body responsible for the secretariat of the TC or SC within the framework of which the working document has been prepared.]</p><p>Reproduction for sales purposes may be subject to royalty payments or a licensing agreement.</p><p>Violators may be prosecuted.</p><p>© ISO/IEC 2009 — All rights reserved III ISO/IEC CD 23006-2</p><p>Contents Page</p><p>Foreword...... ix Introduction...... x 1 Scope...... 1 2 Normative references...... 1 3 Terms and definitions...... 2 4 Symbols and abbreviated terms...... 4 5 Namespace conventions...... 4 6 MXM Engine APIs...... 6 6.1 Digital Item Engine APIs...... 6 6.1.1 DI Creation...... 6 6.1.1.1 Specify metadata for a Content Item...... 6 6.1.1.2 Add an inner item to the digital item to be created...... 7 6.1.1.3 Creating a Digital Item...... 8 6.1.2 DI Editing...... 9 6.1.2.1 InsertContentInDIDElement...... 10 6.1.2.2 RemoveContentFromDIDElement...... 11 6.1.2.3 InsertAttributeInDIDElement...... 11 6.1.2.4 RemoveAttributeFromDIDElement...... 11 6.1.2.5 InsertDIDElementInDIDElement...... 12 6.1.2.6 RemoveDIDElementFromDIDElement...... 12 6.1.2.7 ReplaceDIDElement...... 12 6.1.2.8 ReplaceDIDElementAttribute...... 13 6.1.3 DI Access...... 13 6.1.3.1 GetArrayOfContentLicenses...... 13 6.1.3.2 GetArrayOfContentLicenseRefs...... 14 6.1.3.3 GetArrayOfLicenses...... 15 6.1.3.4 GetArrayOfLicenseRefs...... 15 6.1.3.5 Other methods...... 16 6.1.4 DI Presentation...... 20 6.2 MPEG-21 File Engine APIs...... 21 6.2.1 MP21 File Creation...... 21 6.2.1.1 Creating a DCF using ContentBuilder...... 21 6.2.1.2 Set the DI of an MPEG-21 file...... 22 6.2.1.3 Add a resource to an MPEG-21 file...... 22 6.2.1.4 Creating the MPEG-21 File...... 23 6.2.2 MP21 File Access...... 24 6.2.2.1 Extract a DI from an MPEG-21 file...... 24 6.2.2.2 Extract a resource from an MPEG-21 file...... 24 6.3 REL Engine APIs...... 24 6.3.1 License creation...... 24 6.3.1.1 Add a Grant to a License...... 24 6.3.1.2 Add an Issuer to a license...... 24 6.3.1.3 Create a Grant given the Principal, the Right, etc...... 24 6.3.1.4 Create a License...... 24 6.3.1.5 Create an ORC License using ContentBuilder...... 25 6.3.1.6 Create an ORC License using ORCLicenseBuilder...... 26 6.3.2 License Access...... 27 6.3.2.1 Getting the LicenseId...... 27 6.3.2.2 Operation to retrieve the license title...... 28 6.3.2.3 Operation to retrieve the inventory...... 29 6.3.2.4 Operation to retrieve the list of grants...... 29 6.3.2.5 Operation to retrieve the license issuer...... 30</p><p>IV © ISO/IEC 2009 — All rights reserved ISO/IEC CD 23006-2 6.3.2.6 Operation to retrieve other information...... 30 6.3.3 License validation...... 31 6.3.3.1 Validate if a License is Issued by a specific Issuer...... 31 6.3.4 License authorisation...... 31 6.3.4.1 Authorise an REL query against an REL License given a Context...... 31 6.4 IPMP Engine APIs...... 32 6.4.1 IPMP Information Creation...... 32 6.4.1.1 AddIPMPTool...... 33 6.4.1.2 SetMasterKey...... 34 6.4.1.3 Method to add a rigths descriptor to an IPMPInfoDescriptor...... 34 6.4.1.4 Method to add an element to an IPMPInfoDescriptor...... 35 6.4.1.5 Method to add an element to an IPMPGeneralInfoDescriptor...... 36 6.4.2 IPMP Information access...... 36 6.4.2.1 Parse an XML IPMP Message...... 36 6.4.2.2 Method to access IPMP Tool information from an IPMPInfoDescriptor...... 36 6.5 Access RightsDescriptor from an IPMPInfoDescriptor...... 37 6.5.1.1 Method to access RightsDescriptor from an IPMPInfoDescriptor...... 37 6.5.1.2 Method to access any information from any IPMP element...... 38 6.5.1.3 Create an XML IPMP Message...... 38 6.5.2 Resource Protection...... 38 6.5.2.1 ProtectResource...... 38 6.5.2.2 IdentifyProtectedResource...... 39 6.6 IPMP Tool instantiation...... 40 6.6.1.1 Method to instantiate a specific IPMP Tool having specific characteristics in a specific Control Point...... 40 6.6.1.2 Method to Initialise a specific IPMP Tool already instantiated with specific initialisation data...... 41 6.7 Media Framework Engine APIs...... 41 6.7.1 Generic Elementary Stream...... 41 6.7.1.1 Creation...... 41 6.7.1.2 Editing...... 43 6.7.1.3 Decoding...... 43 6.7.1.4 Rendering...... 43 6.7.1.5 Adaptation...... 43 6.7.2 Image APIs...... 45 6.7.2.1 Creation...... 45 6.7.2.2 Editing...... 45 6.7.2.3 Decoding...... 45 6.7.2.4 Rendering...... 45 6.7.3 Audio APIs...... 45 6.7.3.1 Creation...... 45 6.7.3.2 Editing...... 45 6.7.3.3 Decoding...... 45 6.7.3.4 Rendering...... 45 6.7.4 Video APIs...... 45 6.7.4.1 Creation...... 45 6.7.4.2 Editing...... 45 6.7.4.3 Decoding...... 45 6.7.4.4 Rendering...... 45 6.7.5 Reconfigurable Video APIs...... 45 6.7.5.1 Creation...... 45 6.7.5.2 Decoding...... 45 6.7.5.3 Engine-specific APIs...... 45 6.7.6 Muxed Content APIs...... 47 6.7.6.1 Creation...... 47 6.7.6.2 Editing...... 47 6.7.6.3 Access...... 47 6.7.6.4 Rendering...... 50 6.7.6.5 Engine-specific APIs...... 52 6.7.7 2D Layout APIs...... 60 6.7.7.1 Creation...... 60 6.7.7.2 Editing...... 60 6.7.7.3 Decoding...... 60</p><p>© ISO/IEC 2009 — All rights reserved V ISO/IEC CD 23006-2 6.7.8 2D Graphics Primitives APIs...... 61 6.7.8.1 Creation...... 61 6.7.8.2 Editing...... 61 6.7.8.3 Decoding...... 61 6.7.8.4 Rendering...... 61 6.7.8.5 CreateDIPresentation...... 61 6.7.8.6 Init...... 61 6.7.8.7 SetPresentationPanel...... 62 6.7.8.8 showNotify...... 63 6.7.9 3D Scene Graph APIs...... 63 6.7.9.1 Creation...... 63 6.7.9.2 Editing...... 63 6.7.9.3 Decoding...... 63 6.7.10 3D graphics primitives APIs...... 63 6.7.10.1 Geometry related API...... 63 6.7.10.2 Appearance related API...... 70 6.7.10.3 Texture-related API...... 73 6.7.10.4 Animation related API...... 76 6.7.10.5 Creation...... 83 6.7.10.6 Editing...... 83 6.7.10.7 Decoding...... 83 6.7.10.8 Rendering...... 83 6.8 Image Metadata Engine APIs...... 83 6.8.1 Image Metadata Creation...... 87 6.8.2 Image Metadata Editing...... 87 6.8.3 Image Metadata Access...... 87 6.8.4 Image Metadata Presentation...... 87 6.9 Audio Metadata Engine APIs...... 87 6.9.1 Audio Metadata Creation...... 87 6.9.2 Audio Metadata Editing...... 87 6.9.3 Audio Metadata Access...... 87 6.9.4 Audio Metadata Presentation...... 88 6.10 Video Metadata Engine APIs...... 88 6.10.1 Video Metadata Creation...... 88 6.10.2 Video Metadata Editing...... 89 6.10.3 Video Metadata Access...... 89 6.10.4 Video Metadata Presentation...... 89 6.11 Content Metadata Engine APIs...... 89 6.11.1 Content Metadata Creation...... 89 6.11.2 Content Metadata Editing...... 94 6.11.3 Content Metadata Access...... 94 6.11.4 Content Metadata Presentation...... 100 6.12 Digital Item Streaming Engine APIs...... 100 6.12.1 Digital Item Streaming Creation...... 100 6.12.2 Digital Item Streaming Editing...... 100 6.12.3 Digital Item Streaming Access...... 100 6.13 Digital Item Adaptation Engine APIs...... 100 6.13.1 Usage Environment Description Creation...... 100 6.13.2 Digital Item Adaptation Editing...... 101 6.13.3 Digital Item Adaptation Access...... 101 6.14 Digital Item Processing Engine APIs...... 103 6.14.1 Digital Item Processing Creation...... 103 6.14.2 Digital Item Processing Access...... 103 6.15 Event Reporting Engine APIs...... 103 6.15.1 Event Report Request Creation...... 103 6.16 Event Report Request Creation...... 103 6.16.1 Method to generate an ISO/IEC 21000-15 conformant Event Report Request...... 103 6.17 Event Report Creation...... 105 6.17.1 Method to generate an ISO/IEC 21000-15 conformant Event Report...... 105 6.18 Event Report Request Access...... 107 6.18.1 Method to obtain form a Digital Item all the Event Report Requests within it...... 107 6.18.2 Method is used to obtain Event Report Request fields from and ERR conformant to ISO/IEC 21000-15...... 107</p><p>VI © ISO/IEC 2009 — All rights reserved ISO/IEC CD 23006-2 6.18.3 Event Registration...... 108 6.18.4 Event Report Transmission...... 108 6.19 Content Protocol Engine APIs...... 108 6.19.1 Content Identification Protocol...... 108 6.19.1.1 Identify Content Item...... 109 6.19.1.2 Identify Content Element...... 111 6.19.2 Content Authentication Protocol...... 113 6.19.2.1 Authenticate Content Item...... 113 6.19.2.2 Authenticate Content Element...... 114 6.19.3 Content Access Protocol...... 115 6.19.3.1 AccessContentElement...... 115 6.19.4 Content Storage Protocol...... 116 6.19.4.1 Store a DCF...... 116 6.19.4.2 Store a DCS...... 117 6.20 License Protocol Engine APIs...... 118 6.20.1 License Access...... 118 6.20.1.1 Operation to retrieve a license given the id...... 119 6.20.2 License Storage...... 120 6.20.3 Operation to revoke a license...... 121 6.21 IPMP Tool Protocol Engine APIs...... 122 6.21.1 IPMP Tool Access...... 122 6.21.2 IPMP Tool List Access...... 122 6.22 Content Search Engine APIs...... 123 6.22.1 Content Store...... 123 6.22.2 Content Search...... 124 6.23 Security Engine APIs...... 125 6.23.1 Key Generation...... 125 6.23.1.1 Random key generation...... 125 6.23.1.2 Random key-pair generation...... 125 6.23.2 Encryption...... 126 6.23.2.1 Encrypt an array of bytes using asymmetric encryption...... 126 6.23.2.2 Encrypt an array of bytes using symmetric encryption...... 127 6.23.3 Decryption...... 128 6.23.3.1 Asymmetric decrypt an array of bytes...... 128 6.23.3.2 Symmetric decrypt an array of bytes...... 129 6.23.4 Hash calculation...... 129 6.23.4.1 Generate a hash value of an array of bytes...... 129 6.23.4.2 Generate a hash value of the contents of a file...... 130 6.23.5 Hash verification...... 131 6.23.5.1 Verify the hash value of the contents of an array of bytes...... 131 6.23.6 Digital Signature generation...... 131 6.23.6.1 Generate the digital signature for an array of bytes...... 131 6.23.7 Digital Signature verification...... 132 6.23.7.1 Verify the digital signature for an array of bytes...... 132 6.23.8 Security Information Access...... 133 6.23.8.1 Get a certificate from the secure repository as an X.509 Certificate...... 133 6.23.8.2 Get a certificate from the secure repository as an REL Principal...... 134 6.23.8.3 Get a certificate from the secure repository as a DeviceID...... 135 6.23.8.4 Export a certificate to a file...... 135 6.23.8.5 Get an array of licenses from the secure repository...... 136 6.23.8.6 Get a list of licenses from the secure repository...... 137 6.23.8.7 Get user information from the secure repository...... 138 6.23.8.8 Get domain information from the secure repository...... 138 6.23.9 Authentication...... 139 6.23.10 Trust verification...... 139 6.23.10.1 Digital Signature verification...... 139 6.23.11 Secure information storage...... 139 6.23.11.1 Store a license...... 139 6.23.11.2 Store usser information...... 140 6.23.11.3 Store a key into the secure repository...... 141 6.23.11.4 Create a Private Key for a new user and store it into the secure repository...... 141 6.23.11.5 Store a certificate from a file in the secure repository...... 143 6.23.11.6 Store a certificate from a KeyInfo in the secure repository...... 143</p><p>© ISO/IEC 2009 — All rights reserved VII ISO/IEC CD 23006-2 6.23.11.7 Store domain information in the secure repository...... 144 6.23.12 Security Information deletion...... 145 6.23.12.1 Delete a trusted certificate from the secure repository...... 145 6.23.12.2 Delete a license from the secure repository...... 146 6.23.12.3 Delete user information from the secure repository...... 147 6.23.12.4 Delete domain information from the secure repository...... 147 6.23.13 Miscellanea...... 148 6.23.13.1 Verify a REL Principal...... 148 6.23.13.2 Method to generate and embed the digital signature for an XML document...... 149 6.23.13.3 Method to verify the digital signature for an XML document...... 149 6.23.13.4 Method to authenticate a User with Password...... 150 6.23.13.5 Method to authenticate user with password and user certificate...... 151 6.23.13.6 Method to estimate the fingerprint of a tool...... 152 6.23.13.7 Method to enable or certify the operation of a tool...... 152 6.23.13.8 Method to verify locally the integrity of a tool...... 153 6.23.13.9 Method to verify remotely the integrity of a tool...... 153 6.23.13.10 Method to disable to operation of a tool...... 154 6.24 MVCO Engine APIs...... 155 6.24.1.1 Operation to load a data set from a given location...... 155 6.24.1.2 Operation to save the current data set in a given location...... 156 6.24.1.3 Operation to unload the current data set...... 156 6.24.1.4 Operation to create a user in the ontology...... 157 6.24.1.5 Operation to delete a user in the ontology...... 158 6.24.1.6 Operation for the execution of an action by a User...... 159 6.24.1.7 Operation to create a permission...... 159 6.24.1.8 Operation to launch a query...... 161 6.24.1.9 Operation to validate an action...... 162 6.24.1.10 Operation to get the list of registered users...... 163 6.24.1.11 Operation to get the list of registered IPEntities...... 163 6.24.1.12 Operation to get the rights owner of a given IPEntity...... 164 6.24.1.13 Operation to geg the IPEntity origin of a given IPEntity...... 165 6.25 Domain Engine APIs...... 166 6.25.1 Domain Management...... 166 6.25.1.1 Create Domain...... 166 6.25.1.2 Renew Domain...... 167 6.25.1.3 Delete Domain...... 168 6.25.1.4 Add Device...... 169 6.25.1.5 Add User...... 170 6.25.1.6 Renew Device...... 171 6.25.1.7 Renew User...... 171 6.25.1.8 Leave Device...... 172 6.25.1.9 Leave User...... 173 6.25.1.10 RequestLocalDomainID...... 174 6.25.2 Domain Access...... 174 6.25.2.1 RequestDomainPublicInfo...... 174 6.25.3 Domain Usage...... 175 6.25.3.1 Get Domain License...... 176 6.25.3.2 Store Domain License...... 177 6.25.3.3 Delete Domain License...... 177 6.25.3.4 Update Domain License...... 178 6.25.3.5 Start Domain Use...... 178 6.25.3.6 End Domain Use...... 179 6.25.4 UnlicensedSimultaneousUseNotice...... 180 6.26 Rendering Engine APIs...... 181 6.26.1 getNumberOfScreens...... 181 6.26.2 getScreen...... 181 6.26.3 getAspectRatio...... 182 6.26.4 getNativeResolution...... 183 6.26.5 setResolution...... 183 6.26.6 setPixelFormat...... 184 6.26.7 setPosition...... 185 6.26.8 setSize...... 185 6.26.9 initialize...... 186</p><p>VIII © ISO/IEC 2009 — All rights reserved ISO/IEC CD 23006-2 6.26.10 setEventHandler...... 186 6.26.11 setSource...... 187 6.26.12 renderGeometry...... 188 6.26.13 showAnimation...... 188 6.26.14 showBBAAnimation...... 189 7 MXM Application APIs...... 190 7.1.1 Open...... 190 7.1.2 CanAccessContentElement...... 191 7.1.3 Play...... 192 7.1.4 PresentDigitalItem...... 192 7.1.5 Adapt(namespaceURI:string, ued:string, resourceURI:string)...... 192 7.1.6 ProcessDigitalItem...... 192 Annex A (normativ) MXM Interfaces...... 193 A.1 ContentMetadataEngine...... 193 A.2 Mpeg7...... 193 A.3 Mpeg7Parser...... 193 A.4 MXMEngineResponse...... 193 A.5 MXMUseEnvDescr...... 193 Annex B (normativ) MXM Exceptions...... 194 B.1 ContentMetadataEngineException...... 194 B.2 MXMDescrException...... 194 Bibliography...... 195</p><p>© ISO/IEC 2009 — All rights reserved IX ISO/IEC CD 23006-2</p><p>Foreword</p><p>ISO (the International Organization for Standardization) and IEC (the International Electrotechnical Commission) form the specialized system for worldwide standardization. National bodies that are members of ISO or IEC participate in the development of International Standards through technical committees established by the respective organization to deal with particular fields of technical activity. ISO and IEC technical committees collaborate in fields of mutual interest. Other international organizations, governmental and non-governmental, in liaison with ISO and IEC, also take part in the work. In the field of information technology, ISO and IEC have established a joint technical committee, ISO/IEC JTC 1.</p><p>International Standards are drafted in accordance with the rules given in the ISO/IEC Directives, Part 3.</p><p>The main task of the joint technical committee is to prepare International Standards. Draft International Standards adopted by the joint technical committee are circulated to national bodies for voting. Publication as an International Standard requires approval by at least 75 % of the national bodies casting a vote.</p><p>Attention is drawn to the possibility that some of the elements of this part of ISO/IEC 23006 may be the subject of patent rights. ISO and IEC shall not be held responsible for identifying any or all such patent rights.</p><p>ISO/IEC 23006-2 was prepared by Joint Technical Committee ISO/IEC JTC 1, Information technology, Subcommittee SC 29, Coding of audio, picture, multimedia and hypermedia information.</p><p>This second/third/... edition cancels and replaces the first/second/... edition (), [clause(s) / subclause(s) / table(s) / figure(s) / annex(es)] of which [has / have] been technically revised.</p><p>ISO/IEC 23006 consists of the following parts, under the general title Information technology — MPEG-M (MPEG eXtensible Middleware):</p><p> Part 1: MXM Architecture and Technologies</p><p> Part 2: MXM API</p><p> Part 3: MXM Conformance and Reference Software</p><p>X © ISO/IEC 2009 — All rights reserved ISO/IEC CD 23006-2</p><p>Introduction</p><p>ISO/IEC 23006 is a suite of standards that has been developed for the purpose of enabling the easy design and implementation of media-handling value chains whose devices interoperate because they are all based on the same set of technologies, especially technologies standardised by MPEG, accessible from the MXM middleware.</p><p>This will enable the development of a global market of:</p><p> MXM applications that can run on MXM devices thanks to the existence of a standard MXM application API</p><p> MXM devices hosting MXM applications thanks to the existence of a standard MXM architecture</p><p> MXM components thanks to the existence of standard MXM components APIs</p><p> Innovative business models because of the ease to design and implement media-handling value chains whose devices interoperate because they are all based on the same set of technologies, especially MPEG technologies.</p><p>© ISO/IEC 2009 — All rights reserved XI COMMITTEE DRAFT ISO/IEC CD 23006-2</p><p>Information technology — MPEG-M (MPEG eXtensible Middleware) — Part 2: MXM API</p><p>1 Scope This international standard specifies a set of Application Programming Interfaces (APIs) enabling applications to access standard multimedia technologies.</p><p>NOTE The purpose of this international standard is to promote the extended use of digital media content through increased interoperability and accelerated development of components, solutions and applications.</p><p>This is achieved by specifying</p><p> The MXM architecture (ISO/IECC 23006-1);</p><p> The MXM components (by reference – ISO/IEC 23006-1);</p><p> The MXM components APIs (ISO/IEC 23006-2);</p><p> The MXM applications API (ISO/IEC 23006-2);</p><p> The inter-MXM communication protocols (ISO/IEC 29116-1).</p><p>The scope of this international standard is solely the APIs whereas the actual MXM engines are deliberately out of scope and left open for industry competition.</p><p>NOTE The APIs are made available to applications by means of MXM Engines. Each Engine (e.g. the MediaFramework Engine) provides access to a single MPEG technology (e.g. video coding) or to a group of MPEG technologies where this is convenient.</p><p>2 Normative references The following referenced documents are indispensable for the application of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.</p><p>ISO/IEC 13818 (all parts) Information technology -- Generic coding of moving pictures and associated audio</p><p>ISO/IEC 14496 (all parts) Information technology -- Coding of audio-visual objects</p><p>ISO/IEC 15938 (all parts) Information technology -- Multimedia Content Description Interface</p><p>ISO/IEC 21000 (all parts) Information technology -- Multimedia Framework</p><p>ISO/IEC 23000 (all parts) Information technology -- Multimedia Application Formats</p><p>ISO/IEC 23001 (all parts) Information technology -- MPEG Systems Technologies</p><p>ISO/IEC 23002 (all parts) Information technology -- MPEG Video Technologies</p><p>ISO/IEC 23003 (all parts) Information technology -- MPEG Audio Technologies</p><p>ISO/IEC 23004 (all parts) Information technology -- MPEG Multimedia Middleware</p><p>© ISO/IEC 2009 — All rights reserved 1 ISO/IEC CD 23006-2 ISO/IEC 23005 Information technology -- Information Exchange between Virtual Worlds</p><p>ISO/IEC 29116 Information technology:2007/Amd 2:2009 -- Supplemental Media Technologies – Multimedia eXtensible Middleware Protocols</p><p>ISO/IEC YYYYY-1, Information technology – MPEG-M (MPEG eXtensible Middleware) -- Part 1: MXM Architecture and Technologies</p><p>3 Terms and definitions For the purposes of this document, the following terms and definitions apply.</p><p>3.1 Content Creation Device a device enabling the creation of content possibly including audio-visual resources, rights information, metadata, etc.</p><p>3.2 Content Identification Device a device providing content identification and authentication services to another device</p><p>3.3 Content Provider Device a device on which content may be stored and delivering content to another device</p><p>3.4 Device a combination of hardware and software or just an instance of software that allows a user to perform actions</p><p>3.5 Domain Administrator a user creating and administering a domain by means of a Domain Management Device</p><p>3.6 Domain Management Device a device managing the lifecycle of a domain and the membership of devices and users part of it.</p><p>3.7 Inter-MXM Protocol a protocol that enable communication between MXM Devices.</p><p>3.8 IPMP Processor a module in a Media Streaming Player in charge of retrieving, instantiating, initialising and managing the IPMP Tools required to perform actions on content.</p><p>3.9 IPMP Tool a module performing (one or more) IPMP functions such as authentication, decryption, watermarking, etc.</p><p>3.10 IPMP Tool Agent a module instantiating, initialising, authenticating, and supervising any operation performed between IPMP Tools within an IPMP Tool Group</p><p>3.11 IPMP Tool Body executable code implementing either a Single IPMP Tool or an IPMP Tool Pack</p><p>3.12 IPMP Tool Group a combination of several IPMP Tools</p><p>2 © ISO/IEC 2009 — All rights reserved 3.13 IPMP Tool Pack a module that comprises an IPMP Tool Group and its IPMP Tool Agent</p><p>3.14 IPMP Tool Provider Device a device delivering IPMP Tools to another device</p><p>3.15 Licence Provider Device a device delivering licenses to another device according to a License Template previously stored</p><p>3.16 Licence Template a license granting rights to issue licenses to a device</p><p>3.17 MXM Application an application that runs on an MXM device and make calls to the MXM Application and MXM Engine APIs</p><p>3.18 MXM Application API the API of the MXM Orchestrator Engine.</p><p>3.19 MXM Device a device equipped with MXM</p><p>3.20 MXM Engine a homogeneous set of MXM Technologies</p><p>3.21 MXM Engine API the API of a single MXM Engine</p><p>3.22 MXM Orchestrator Engine a special MXM Engine capable of creating chains of MXM engines to execute a high-level application call such as Play</p><p>3.23 MXM Technology a technology that is supported by (a profile of) MXM</p><p>3.24 User any identified entity interacting in a media streaming environment using a media streaming device.</p><p>4 Symbols and abbreviated terms BBL Bitstream Binding Language</p><p>CCD Content Creation Device</p><p>CID Content Identification Device</p><p>CPD Content Provider Device</p><p>DIA Digital Item Adaptation</p><p>DID Digital Item Declaration</p><p>© ISO/IEC 2009 — All rights reserved 3 ISO/IEC CD 23006-2</p><p>DIDL Digital Item Declaration Language</p><p>DII Digital Item Identification</p><p>DIS Digital Item Streaming</p><p>DMD Domain Management Device</p><p>ER Event Report</p><p>ERR Event Report Request</p><p>IPMP Intellectual Property Management and Protection</p><p>LPD License Provider Device</p><p>LLAP Local License Access Protocol</p><p>MXMD Media Streaming Device</p><p>MSP Media Streaming Player</p><p>REL Rights Expression Language</p><p>RTP Real Time Protocol</p><p>RTSP Real Time Streaming Protocol</p><p>URI Uniform Resource Identifier</p><p>5 Namespace conventions Throughout this part of ISO/IEC YYYYY, Qualified Names are written with a namespace prefix followed by a colon followed by the local part of the Qualified Name.</p><p>For clarity, throughout this part of ISO/IEC YYYYY, consistent namespace prefixes are used. Table 1 gives these prefixes and the corresponding namespace.</p><p>Table 1 — Namespaces and prefixes</p><p>Prefix Corresponding namespace ipmpdidl urn:mpeg:mpeg21:2004:01-IPMPDIDL-NS ipmpmsg urn:mpeg:mpeg21:2006:07-IPMPMESSAGES-NS ipmpinfo urn:mpeg:mpeg21:2004:01-IPMPINFO-NS didl urn:mpeg:mpeg21:2002:02-DIDL-NS didmodel urn:mpeg:mpeg21:2002:02-DIDMODEL-NS didl-msx urn:mpeg:maf:schema:mediastreaming:DIDLextensions dii urn:mpeg:mpeg21:2002:01-DII-NS r urn:mpeg:mpeg21:2003:01-REL-R-NS sx urn:mpeg:mpeg21:2003:01-REL-SX-NS m1x urn:mpeg:mpeg21:2005:01-REL-M1X-NS</p><p>4 © ISO/IEC 2009 — All rights reserved xsd http://www.w3.org/2001/XMLSchema xsi http://www.w3.org/2001/XMLSchema-instance dsig http://www.w3.org/2000/09/xmldsig# mxmacp urn:mpeg:mpeg-m:schema:accesscontentprotocol:2009 mxmaitp urn:mpeg:mpeg-m:schema:accessipmptoolprotocol:2009 mxmalp urn:mpeg:mpeg-m:schema:accesslicenseprotocol:2009 mxmaucp urn:mpeg:mpeg-m:schema:authenticatecontentprotocol:2009 mxmbp urn:mpeg:mpeg-m:schema:baseprotocol:2009 mxmd urn:mpeg:mpeg-m:schema:domain:2009 mxmdp urn:mpeg:mpeg-m:schema:domainprotocol:2009 mxmicp urn:mpeg:mpeg-m:schema:identifycontentprotocol:2009 mxmscp urn:mpeg:mpeg-m:schema:storecontentprotocol:2009 mxmslp urn:mpeg:mpeg-m:schema:storelicenseprotocol:2009</p><p>The MXM APIs are specified using UML 1.4.2 (ISO/IEC 19501) in order to allow implementations of MXM APIs in multiple programming languages. </p><p>Methods are defined in the following way:</p><p> Each method is shown with at least its name, and optionally also with its parameters and return type.</p><p> Access modifier as follows:</p><p> "+" for public</p><p> "#" for protected</p><p> "-" for private</p><p> "~" for package</p><p> Then we can have other optional modifier (for example final) and then the name of the method followed by parentheses "( )".</p><p> After that we a colon ":" between the closed parenthesis and the returned type.</p><p> If the method has parameters, they are expressed with the reference name, a colon and the related object type.</p><p> If the method is static it will be underlined and if it is abstract all the sentence is written in Italic style.</p><p> This is an example of a login method expressed in UML:</p><p> + login(name:String, password:String):boolean</p><p>6 MXM Engine APIs</p><p>Replace the text below with a Class-Responsibility-Collaboration-like model description.</p><p>Generate the API definition and documentation with automatic tools (e.g. Doxygen) to be included as an annex with normative value</p><p>© ISO/IEC 2009 — All rights reserved 5 ISO/IEC CD 23006-2 6.1 Digital Item Engine APIs</p><p>6.1.1 DI Creation</p><p>The APIs in this section are used to create a Digital Item having the following characteristics: a top-level didl:Item, child of the didl:DIDL element contains all the information describing the content item as a whole (e.g. the content identifier, content metadata, etc.). A content item may include a number of content elements (e.g. a resource) each represented in the Digital Item by a didl:Item child of the top-level didl:Item which also contains all the information describing the content element (e.g. the content element identifier, content element metadata, content element protection information, etc.). The methods described in this section are used to create a content item having such characteristics, and are made available by an instance of ContentBuilder (see A.2).</p><p>6.1.1.1 Specify metadata for a Content Item</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setContentMetadata (contentitemMetadata : ContentItemMetadata):void</p><p>Java sample code public interface ContentBuilder { public void setContentMetadata(ContentItemMetadata contentItemMetadata); } Method description</p><p>This method is used to specify content metadata in order to be added to the Digital item when the content is created</p><p>Parameters contentItemMetadata An instance of ContentItemMetadata (see Error: Reference source not found) containing all metadata elements for the content item. This information will be inserted into the didl:Descriptor -> didl:Statement -> didl-msx:metadata -> didl-msx:StructuredData child of the top-level didl:Item</p><p>Return value void</p><p>Exceptions</p><p>6.1.1.2 Add an inner item to the digital item to be created</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ addContentElement (contentElement: ContentElementInterface):boolean</p><p>Java sample code public interface ContentBuilder { public boolean addContentElement (ContentElementInterface contentElement) throws MalformedContentElementException, UnsupportedFeatureException, SecurityManagerException, </p><p>6 © ISO/IEC 2009 — All rights reserved DCIGenerationException; } Method description</p><p>This method is used to specify that content element has to be added to a content item when the content item is created</p><p>Parameters contentElement An instance of ContentElementInterface (see Error: Reference source not found) containing all the information related to the content element (e.g. the content element identifier, metadata, protection information, resource location etc).</p><p>Return value</p><p>True if the content element was successfully added to the content item.</p><p>Exceptions</p><p>MalformedContentElementException If the content element added was malformed, its contents not complete or leading to misinterpretation.</p><p>UnsupportedFeatureException If the information contained in the content element require any processing which MXM does not support.</p><p>SecurityManagerException If an error occurred while accessing the data from the SecurityManager (in case a ProtectedContentElement (see Error: Reference source not found) was added).</p><p>DCIGenerationException If an error occurs while generating the XML elements forming the Digital Item.</p><p>6.1.1.3 Creating a Digital Item</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ createDCI (cidServiceURL : string, identifyBySendingDCI : boolean): DIDL</p><p>Java sample code public interface ContentBuilder { public DIDL createDCI(String cidServiceURL, boolean identifyBySendingDCI) throws DCIGenerationException, LicenseGenerationException, MalformedContentElementException, SecurityManagerException, BadPropertyException, UnsupportedFeatureException, ContentIdentificationException, StoreLicenseTemplateException; } Method description</p><p>This method is used to generate a Digital Item conforming to MS AF restrictions to ISO/IEC 21000-2. After ContentItemMetadata and all objects of type ContentElementInterface have been set, by calling this method MXM will perform the following steps:</p><p> Generate all licenses for all GovernedContentElements in the case any of the GovernedContentElements had requested this operation to be performed by setting specific properties (see Error: Reference source not found). Note that a license can be already included in a GovernedContentElement, or a license reference, so in this case this step will not performed. Create a Digital Item including all the information previously set</p><p>© ISO/IEC 2009 — All rights reserved 7 ISO/IEC CD 23006-2 Identify the Digital Item from the Content Identification Service specified by the cidServiceURL parameter and using one of the two Content Identification Protocols specified in Error: Reference source not found Store License Templates in case any of the GovernedContentElements had requested this operation to be performed by setting specific properties (see Error: Reference source not found) Parameters cidServiceURL The Content Identification Service where a new Content Identifier has to be requested using one of the two Content Identification Protocols specified in Error: Reference source not found identifyBySendingDCI A Boolean value indicating whether the Content Identification shall be made using Error: Reference source not found (if true) of Error: Reference source not found if false.</p><p>Return value</p><p>An object of type DIDL (see Error: Reference source not found) representing the Digital Item that was created, which can be converted in the most common formats, e.g. stored in an xml file, returned as an xml string of characters, etc..</p><p>Exceptions</p><p>MalformedContentElementException If the content element added was malformed, its contents not complete or leading to misinterpretation.</p><p>UnsupportedFeatureException If the information contained in the content element require any processing which MXM does not support (e.g. an encryption algorithm which is not supported).</p><p>SecurityManagerException If an error occurred while accessing the data from the SecurityManager (in case one or more ProtectedContentElement (see Error: Reference source not found) were added to the content item).</p><p>LicenseGenerationException This exception is thrown if a problem occurs during the generation of licenses for any of the GovernedContentElement or ProtectedContentElements requesting this operation</p><p>StoreLicenseTemplateException If an exception occurred while storing a License Template on a License service, in the case any of the GovernedContentElements had requested this operation to be performed by setting specific properties (see Error: Reference source not found).</p><p>ContentIdentificationException If an error occurred while a Content Identifier was requested to the Content Identification Service</p><p>BadPropertyException If any of the properties used to configure the ContentBuilder were corrupted or incorrectly set.</p><p>DCIGenerationException If an error occurs while generating the XML elements forming the Digital Item.</p><p>6.1.2 DI Editing</p><p>The API provided by MXM for the manipulation of Digital Items (DIs) should enable the calling applications to build and manipulate DIs at any level of granularity.</p><p>The view behind this specification is that the DID construction process begins from the finest level of granularity up.</p><p>8 © ISO/IEC 2009 — All rights reserved UML Specifications</p><p>Method syntax for interface DigitalItemManagement</p><p>+insertContentInDIDElement(didElement : string, didElementContent : Object, contentType : string) : string</p><p>+removeContentFromDIDElement(didElement : string) : string</p><p>+insertAttributeInDIDElement(didElement : string, attributeName : string, attributeValue : string) : string</p><p>+removeAttributeFromDIDElement(didElement : string, attributeName : string) : string</p><p>+insertDIDElementInDIDElement(parentDIDElemt : string, childDIDElement : string) : string</p><p>+removeDIDElementFromDIDElement(parentDIDElemt : string, childDIDElementName : string, childElementPosition : int) : string</p><p>+replaceDIDElement( parentDIDElemt : string, newChildDIDElement : string, oldChildDIDElementName : string, oldChildDIDElementPosition : int) : string</p><p>+replaceDIDElementAttribute(didElement : string, attributeName : string, attributeValue : string) : string</p><p>Class Diagram</p><p> public interface DigitalItemManagement</p><p>{</p><p>String insertContentInDIDElement(String didElement, Object didElementContent, String contentType) throws MXMDIDAccessException;</p><p>String removeContentFromDIDElement(String didElement)throws MXMDIDAccessException;</p><p>String insertAttributeInDIDElement(String didElement, String attributeName, String attributeValue) throws MXMDIDAccessException;</p><p>String removeAttributeFromDIDElement(String didElement, String attributeName) throws MXMDIDAccessException;</p><p>String insertDIDElementInDIDElement(String parentDIDElemt, String childDIDElement) throws MXMDIDAccessException;</p><p>String removeDIDElementFromDIDElement(String parentDIDElemt, String childDIDElementName, int childElementPosition) throws MXMDIDAccessException;</p><p>String replaceDIDElement(String parentDIDElemt, String newChildDIDElement, </p><p>String oldChildDIDElementName, int oldChildDIDElementPosition) throws MXMDIDAccessException;</p><p>© ISO/IEC 2009 — All rights reserved 9 ISO/IEC CD 23006-2 String replaceDIDElementAttribute(String didElement, String attributeName, String attributeValue) throws MXMDIDAccessException;</p><p>}</p><p>6.1.2.1 InsertContentInDIDElement</p><p>This method inserts the given (non-xml) text or binary content into the given DID element. The element should be a Resource, Statement or a Fragment.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The didElementContent parameter is the content to be inserted into the DID.</p><p>The contentType parameter is the type of content which is to be inserted into the DID element. The possible values for this parameter are TXTCONTENT and BINCONTENT.</p><p>The return value is an XML String containing the given DID element with the given content placed inside.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error INVALID_CONTENT_ERROR if the given content is for some reason invalid or inappropriate.</p><p>MXMDIDAccessException with error INVALID_CONTENT_TYPE_ERROR if the specified type of content is invalid.</p><p>6.1.2.2 RemoveContentFromDIDElement</p><p>This method removes the text or binary content contained within the given DID element.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The return value is an XML String containing the given DID element without the previously contained content.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error NO_CONTENT_PRESENT_ERROR if no content is present in the given DID element.</p><p>6.1.2.3 InsertAttributeInDIDElement</p><p>This method inserts the given attribute with the specified value in the given DID element. If the insertion of the specified attribute, or its value, is not in accordance with the MPEG-21 DID standard, exceptions will be thrown.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The attributeName parameter is the name of the attribute to be inserted. If the specified attribute is present, it will be overwritten.</p><p>The attributeValue element is the value of the attribute to be inserted.</p><p>The return value is an XML String containing the given DID element with the specified attribute added.</p><p>10 © ISO/IEC 2009 — All rights reserved This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error INVALID_ATTRIBUTE_INSERTION_ERROR if the attribute specified to be inserted is not appropriate or in accordance with the standard.</p><p>MXMDIDAccessException with error INVALID_ATTRIBUTE_VALUE_ERROR if the specified value for the attribute to be inserted is invalid or inappropriate.</p><p>6.1.2.4 RemoveAttributeFromDIDElement</p><p>This method removes the specified attribute from the given DID element.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The attributeName parameter is the name of the attribute to be removed.</p><p>The return value is an XML String containing the given DID element without the specified attribute.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error NO_ATTRIBUTE_PRESENT_ERROR if the attribute specified to be removed is not present.</p><p>6.1.2.5 InsertDIDElementInDIDElement</p><p>This method inserts the given child DID element within the given DID element, in the appropriate position. If the insertion of the specified DID element, is not in accordance with the MPEG-21 DID standard, an exception will be thrown.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The childDIDElement parameter is an XML string carrying the DID element to be inserted.</p><p>The return value is an XML String containing the given DID element with the given child DID element added inside.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error INVALID_ELEMENT_INSERTION_ERROR if the insertion of the specified element is against the MPEG-21 DID standard.</p><p>6.1.2.6 RemoveDIDElementFromDIDElement</p><p>This method removes the given child DID element from within the given DID element.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The childDIDElementName parameter is the name of the child DID element to be removed.</p><p>The childDIDElementPosition parameter is the position of the DID child element to be removed (in case more than one of such elements exist). The first position (top to bottom) is zero.</p><p>© ISO/IEC 2009 — All rights reserved 11 ISO/IEC CD 23006-2 The return value is an XML String containing the given DID element without the specified child DID element.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error NO_ELEMENT_FOUND_ERROR if the element specified to be removed is not present.</p><p>6.1.2.7 ReplaceDIDElement</p><p>This method replaces a specified old child DID element with a new DID element, inside the given parent DID element. The new and old DID elements must be of the same type.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The newChildDIDElement parameter is an XML string with the new DID child element to be inserted.</p><p>The oldChildDIDElementName parameter is the name of the child DID element to be replaced.</p><p>The oldChildDIDElementPosition parameter is the position of the DID child element to be replaced (in case more than one of such elements exist). The first position (to bottom) is zero.</p><p>The return value is an XML String containing the given DID element with the specified child DID element replaced by the given new DID child.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error NO_ELEMENT_FOUND_ERROR ERROR if the element specified to be removed is not present.</p><p>MXMDIDAccessException with error INVALID_ELEMENT_INSERTION_ERROR if the insertion of the new specified element is against the MPEG-21 DID standard.</p><p>6.1.2.8 ReplaceDIDElementAttribute</p><p>This method replaces the specified attribute value with the new given value. If the specified value is not in accordance with the MPEG-21 DID standard an error is thrown</p><p>The didElement parameter is a String which carries a DID element.</p><p>The attributeName parameter is the name of the attribute whose value is to be altered.</p><p>The attributeValue parameter is the new value to be attributed to the specified attribute.</p><p>The return value is an XML String containing the given DID element with the specified new value attributed to the specified attribute.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR ERROR if the given DID portion (or DID element) is for some reason invalid.</p><p>MXMDIDAccessException with error NO_ATTRIBUTE_FOUND_ERROR if the attribute specified to be replaced is not present.</p><p>MXMDIDAccessException with error INVALID_ATTRIBUTE_VALUE_ERROR id the value of the attribute to be inserted is invalid or not in accordance with the MPEG-21 DID standard.</p><p>12 © ISO/IEC 2009 — All rights reserved 6.1.3 DI Access</p><p>6.1.3.1 GetArrayOfContentLicenses</p><p>In order to extract from a Digital Item all the licenses governing the content item as a whole (i.e. present in the ipmpinfo:IPMPInfoDescriptor associated to the top-level didl:Item described in it, an instance of DCIParser (see Error: Reference source not found) has to be created and initialised by requesting the DCIParser to parse the Digital Item.</p><p>Interface DCIParser (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getArrayOfContentLicenses (): RELLicense[]</p><p>Java sample code public interface DCIParser { public RELLicense[] getArrayOfContentLicenses(); } Method description</p><p>This method is used to obtain all the licenses governing a content item as a whole. This method supposes that an object of type DCIParser has been instantiated and requested to parse the Digital Item containing the content element whose licenses are sought.</p><p>Parameters</p><p>Return value</p><p>An array containing all the Licenses (see Error: Reference source not found) found in the Digital Item for the content item. </p><p>Exceptions</p><p>6.1.3.2 GetArrayOfContentLicenseRefs</p><p>License References are URLs of services providing a license upon request if certain conditions are satisfied.</p><p>In order to extract from a Digital Item all the license references for the whole content item, an instance of DCIParser (see Error: Reference source not found) has to be created and initialised by requesting the DCIParser to parse the Digital Item.</p><p>Interface DCIParser (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getArrayOfContentLicenseRefs (): string[]</p><p>Java sample code public interface DCIParser { public String[] getArrayOfLicenseRefs(); }</p><p>© ISO/IEC 2009 — All rights reserved 13 ISO/IEC CD 23006-2 Method description</p><p>This method is used to obtain all the license references available for a content element (e.g. a resource) described in it. This method supposes that an object of type DCIParser has been instantiated and requested to parse the Digital Item containing the content element whose licenses are sought.</p><p>Parameters</p><p>Return value</p><p>An array containing all the license references found in the Digital Item for the whole content item. </p><p>Exceptions</p><p>6.1.3.3 GetArrayOfLicenses</p><p>In order to extract from a Digital Item all the licenses governing a specific content element described in it, an instance of DCIParser (see Error: Reference source not found) has to be created and initialised by requesting the DCIParser to parse the Digital Item.</p><p>Interface DCIParser (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getArrayOfLicenses (contentElementID:String): RELLicense[]</p><p>Java sample code public interface DCIParser { public RELLicense[] getArrayOfLicenses(String contentElementID); } Method description</p><p>This method is used to obtain all the licenses available for a content element (e.g. a resource) described in it. This method supposes that an object of type DCIParser has been instantiated and requested to parse the Digital Item containing the content element whose licenses are sought.</p><p>Parameters contentElementID The identifier of the content element whose licenses are sought.</p><p>Return value</p><p>An array containing all the Licenses (see Error: Reference source not found) found in the Digital Item for the content element whose identifier was specified in input. </p><p>Exceptions</p><p>6.1.3.4 GetArrayOfLicenseRefs</p><p>License References are URLs of services providing a license upon request if certain conditions are satisfied.</p><p>14 © ISO/IEC 2009 — All rights reserved In order to extract from a Digital Item all the license references for a specific content element described in it, an instance of DCIParser (see Error: Reference source not found) has to be created and initialised by requesting the DCIParser to parse the Digital Item.</p><p>Interface DCIParser (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getArrayOfLicenseRefs (contentElementID:String): string[]</p><p>Java sample code public interface DCIParser { public String[] getArrayOfLicenseRefs(String contentElementID); } Method description</p><p>This method is used to obtain all the license references available for a content element (e.g. a resource) described in it. This method supposes that an object of type DCIParser has been instantiated and requested to parse the Digital Item containing the content element whose licenses are sought.</p><p>Parameters contentElementID The identifier of the content element whose licenses are sought.</p><p>Return value</p><p>An array containing all the license references found in the Digital Item for the content element whose identifier was specified in input. </p><p>Exceptions</p><p>6.1.3.5 Other methods</p><p>[Editor's note: use one table for each method, make consistent with the rest of the document]</p><p>The specification of this API assumes that Digital Items and respective DIDs are correctly formed, that DIDs are syntactically in agreement with the MPEG-21 DID standard and that valid unique identifiers have been inserted in each Item element.</p><p>The API provided by MXM for the access to Digital Items (DIs) should enable the calling applications to access any portion of the metadata contained in a DID, to any level of granularity, within the element tree. The extracted data portion must either be a well formed XML (MPEG-21) fragment, or a contextualized textual or binary block of data.</p><p>Individual Item elements within the DID XML tree should be directly accessible through DID-wide unique Digital Item Identifiers (DIIs). All DID elements should be accessible via a request for some specific content (element) of an ancestor Item node. </p><p>Non-element data must be accessible, in a context dependent manner, via the identifier of an ancestor Item node.</p><p>The API should also be able to deliver a listing of the top Items in a DID or in an Item, and also a listing of their IDs.</p><p>UML Specifications</p><p>Method syntax for interface DigitalItemAccess</p><p>© ISO/IEC 2009 — All rights reserved 15 ISO/IEC CD 23006-2 +getTopItems(didPortion : string) : HashTable<string, string></p><p>+getItem(didPortion : string, itemID : string) : string</p><p>+getItemID(didPortion : string) : string</p><p>+getItemChildren(didPortion : string, elementPath : string) : ArrayList<string></p><p>+getElements( didPortion : string, itemID : string, elementPath : string) : ArrayList<string></p><p>+getDIDElements(didElement : string, desiredElementName : string) : ArrayList<string></p><p>+getElementContent(didElement : string) : HashTable<string, Object></p><p>Class Diagram</p><p>Java sample code implementation public interface DigitalItemAccess</p><p>{</p><p>Hashtable<String, String> getTopItems(String didPortion) throws MXMDIDAccessException; </p><p>String getItem(String didPortion, String itemID) throws MXMDIDAccessException;</p><p>String getItemID (String didPortion) throws MXMDIDAccessException;</p><p>ArrayList<String> getItemChildren(String didPortion, String elementPath) throws MXMDIDAccessException;</p><p>ArrayList<String> getElements(String didPortion, String itemID, String elementPath) throws MXMDIDAccessException;</p><p>ArrayList<String> getDIDElements(String didElement, String desiredElementName) throws MXMDIDAccessException;</p><p>Hashtable<String, Object> getElementContent(String didElement) throws MXMDIDAccessException;</p><p>}</p><p>6.1.3.5.1 GetTopItems</p><p>This method returns a Hashtable containing the IDs of the top level Items of the given DID tree, as the keys, and XML strings containing the corresponding Item elements (and their contents) as the values. </p><p>16 © ISO/IEC 2009 — All rights reserved The given tree may consist of an entire DID, or only of an Item element (and its content). In the later case, the top child Items of the given Item will be returned.</p><p>The didPortion input parameter is a String which consists of either an entire DID or a properly formatted subset of it.</p><p>The return value is a Hashtable containing the IDs of the top level Items of the given DID tree as the keys, and XML strings containing the corresponding Item elements (ant their contents) as the values.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion is for some reason invalid.</p><p>MXMDIDAccessException with error NO_ITEMS_PRESENT_ERROR if no Items exist within the given DID portion.</p><p>6.1.3.5.2 GetItem</p><p>This method retrieves from the supplied DID portion the Item element identified by the given identifier.</p><p>The didPortion parameter is a String which consists of either an entire DID or a properly formatted subset of it.</p><p>The itemID parameter is the DID wise unique identifier (a URI), of the desired Item element.</p><p>The return value is an XML String containing the requested Item element.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion is for some reason invalid.</p><p>MXMDIDAccessException with error INVALID_ITEMID_ERROR if the given Item id is invalid.</p><p>MXMDIDAccessException with error ITEM_NOT_PRESENT_ERROR if no Items with the given Item id exist within the given DID portion.</p><p>6.1.3.5.3 GetItemID</p><p>This method returns the identifier of the first Item element encountered in the given DID portion. Logically the given DID portion should consist of an Item element (and its contents).</p><p>The didPortion parameter is a String which consists of either an entire DID or a properly formatted subset of it.</p><p>The return value is a String containing the ID of the first Item element encountered in the given did portion.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion is for some reason invalid.</p><p>MXMDIDAccessException with error ITEM_NOT_PRESENT_ERROR if no Items exist within the given DID portion.</p><p>MXMDIDAccessException with error ID_NOT_PRESENT_ERROR if the id attribute is not present in the Item in scope.</p><p>© ISO/IEC 2009 — All rights reserved 17 ISO/IEC CD 23006-2 6.1.3.5.4 GetItemChildren</p><p>This method returns all of DID elements which conform to the given element path and are contained inside the first Item found inside the given did portion. Logically the did portion should consist of an Item (and its contents), or contain only one Item, even if contained within another element.</p><p>The didPortion parameter is a String which consists of either an entire DID or a properly formatted subset of it.</p><p>The elementPath parameter is a String with a comma separated list which specifies the path to the target element(s). For instance, the path “Component;Descriptor” will lead to the retrieval of all the Descriptor elements found inside Component elements (where the components are the direct children of the first Item in the given did portion)</p><p>The return value is an ArrayList containing XML strings. Each XML string is one of the matching elements.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion is for some reason invalid.</p><p>MXMDIDAccessException with error NO_ELEMENT_PRESENT_ERROR if no element exists which is located at the specified path.</p><p>6.1.3.5.5 GetElements</p><p>This method returns all of DID elements which conform to the given element path and are contained inside the Item identified by the given item ID, located inside the given did portion.</p><p>The didPortion parameter is a String which consists of either an entire DID or a properly formatted subset of it.</p><p>The itemID parameter is the DID wise unique identifier (a URI), of the target Item element.</p><p>The elementPath parameter is a String with a comma separated list which specifies the path to the target element(s). For instance, the path “Component;Descriptor” will lead to the retrieval of all the Descriptor elements found inside Component elements, which in their turn are inside the identified Item element.</p><p>The return value is an ArrayList containing XML strings. Each XML string is one of the matching elements.</p><p>This method may raise the following exceptions.</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion is for some reason invalid.</p><p>MXMDIDAccessException with error ITEM_NOT_PRESENT_ERROR if no Item with the specified id exists within the given DID portion.</p><p>6.1.3.5.6 GetDIDElements</p><p>This method returns an ArrayList with all the child elements with a name equal to the specified element name, from the given DID element XML string.</p><p>The didElement parameter is a String which carries a DID element.</p><p>The desiredElementName parameter is the name of the desired did element. It may be, for instance, “Component”, “Resource”, etc.</p><p>The return value is an XML String containing the specified target did element.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR if the given DID portion is for some reason invalid.</p><p>18 © ISO/IEC 2009 — All rights reserved MXMDIDAccessException with error NO_ELEMENT_PRESENT_ERROR if no element with the specified name exists.</p><p>MXMDIDAccessException with error INVALID_ELEMENT_NAME_ERROR of the given DID element name is invalid.</p><p>6.1.3.5.7 GetElementContent</p><p>This method returns a Hashtable with one single entry where the value is the text or binary content of the given did element, if it is inline, or the reference to the location of such content, if it is not carried in the DID. The key of Hashtable’s entry is a String specifying the type of value that is stored. </p><p>The possible values for the key are REFERENCE, TXTCONTENT and BINCONTENT.</p><p>The didElement parameter is a String which carries a DID element. That element should be a Resource, a Statement or a Fragment. </p><p>The return value a Hashtable with one single entry where the value is the text or binary content of the given did element, if it is inline, or the reference to the location of such content, if it is not carried in the DID. The key of HashTable’s entry is a String specifying the type of value that is stored.</p><p>The possible values for the key are REFERENCE, TXTCONTENT and BINCONTENT.</p><p>This method may raise the following exceptions:</p><p>MXMDIDAccessException with error INVALID_DIDPORTION_ERROR ERROR if the given DID portion is for some reason invalid.</p><p>6.1.4 DI Presentation</p><p>Interface LaserObjectProcessor{</p><p>String createDIPresentation(String laserFile, ItemMetadata metadata, String ORCLicense) raises(Exceptions);</p><p>}; createDIPresentation():</p><p>This method is used to insert content(resource) metadata and OAC license information into an “empty” scene description file, then the recreated scene description file and the OAC license will be packaged into a binary file.</p><p>Parameter: laserFile</p><p>This parameter is the path of the an “empty” scene description file. It defines the scene description about the metadata elements and OAC license element, but these elements have not real values.</p><p>Metadata</p><p>This parameter is an ItemMedata object(see A.1). It contains the metadata of a content(or resource), such as title, author, data, description, genre and content ID(or resource ID) and so on. Some values of this metadata will be inserted into the laserFile</p><p>ORCLicense</p><p>This parameter is the information of the OAC license. It is the path of the OAC license file.</p><p>Return value:</p><p>© ISO/IEC 2009 — All rights reserved 19 ISO/IEC CD 23006-2 This method returns a String type value. It indicates the path of the created binary laser file. If occurs error, return null.</p><p>Exceptions:</p><p>This method will raise the following exceptions:</p><p>IOException if occurs error while writing data into file</p><p>DocumentException if occurs error while parse the laserFile.</p><p>6.2 MPEG-21 File Engine APIs</p><p>6.2.1 MP21 File Creation</p><p>6.2.1.1 Creating a DCF using ContentBuilder</p><p>This method is employed to create an MPEG-21 File (DCF) using an instance of ContentBuilder which has already created a DCI and the information about all the resources in it.</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ createDCF (): boolean</p><p>Java sample code public interface ContentBuilder { public boolean createDCF () throws DCFGenerationException, DCIParsingException, MalformedContentElementException, BadPropertyException; } Method description</p><p>This method is used to generate MPEF-21 File (DCF) using an instance of ContentBuilder which has already created a DCI and the information about all the resources in it. The DCF is stored in the file system as a file whose filename is specified as an attribute of class ContentItemMetadata (see Error: Reference source not found), or if this parameter has not been specified, then in the application temporary folder and named as a substring of the Content ID.</p><p>Parameters void</p><p>Return value</p><p>A Boolean value set to true if the DCF was successfully created, false otherwise.</p><p>Exceptions</p><p>MalformedContentElementException If the content element added was malformed, its contents not complete or leading to misinterpretation.</p><p>DCFGenerationException If an error occurred while the DCF was created, such as impossible to write to the specified file etc.</p><p>BadPropertyException If any of the properties used to configure the ContentBuilder were corrupted or incorrectly set.</p><p>DCIParsingException If an error occurs while parsing the Digital Item in order to</p><p>20 © ISO/IEC 2009 — All rights reserved retrieve the identifiers of each didl:Item.</p><p>6.2.1.2 Set the DI of an MPEG-21 file</p><p>Interface DCFMaker</p><p>Method Syntax</p><p>+ setDCI (dciPath:String):boolean</p><p>Java sample code public interface DCFMaker { public boolean setDCI (String dciPath); } Method description</p><p>This method is used to add the digital content information(DCI) when create content file. This information is stored in a file.</p><p>Parameters dciPath the path of the dci file.</p><p>Return value boolean, If the information is added successfully, return true else false.</p><p>Exceptions</p><p>6.2.1.3 Add a resource to an MPEG-21 file</p><p>Interface DCFMaker</p><p>Method Syntax</p><p>+ addResource (resourcePath:String, itemID:String):boolean</p><p>Java sample code public interface DCFMaker { public boolean addResource (String resourcePath, String itemID); } Method description</p><p>This method is used to add a resource when create content file. Each resource is specified with an identification.</p><p>Parameters resourcePath the path of the resource file which will be added. itemID the identification of the resource when the resource is added to the content file.</p><p>© ISO/IEC 2009 — All rights reserved 21 ISO/IEC CD 23006-2 Return value boolean, If the resource is added successfully, return true else false.</p><p>Exceptions</p><p>6.2.1.4 Creating the MPEG-21 File</p><p>Interface DCFMaker</p><p>Method Syntax</p><p>+ makeFile (dcfPath:String):boolean</p><p>Java sample code public interface DCFMaker { public boolean makeFile (String dcfPath); } Method description</p><p>This method is used to create a content file using the information and resources in a specified format.</p><p>Parameters dcfPath the path of the created content file.</p><p>Return value boolean, If the content file is added successfully, return true else false.</p><p>Exceptions</p><p>22 © ISO/IEC 2009 — All rights reserved 6.2.2 MP21 File Access</p><p>6.2.2.1 Extract a DI from an MPEG-21 file</p><p>6.2.2.2 Extract a resource from an MPEG-21 file</p><p>6.3 REL Engine APIs</p><p>6.3.1 License creation</p><p>6.3.1.1 Add a Grant to a License</p><p>6.3.1.2 Add an Issuer to a license</p><p>6.3.1.3 Create a Grant given the Principal, the Right, etc.</p><p>6.3.1.4 Create a License</p><p>This method is used to generate an ISO/IEC 21000-5-conformant license.</p><p>[Editors' note: Need to make this method for creating a Grant, then we need another method, e.g. addGrant() to add more grants to a License]</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ buildCustomLicense (keyAlias:string, rightElement: RightElement, resource:GovernedContentElement, allConditions:AllConditions):RELLicense</p><p>Java sample code public interface ContentBuilder { public RELLicense buildCustomLicense(String keyAlias, RightElement rightElement, GovernedContentElement resource, AllConditions allConditions) throws LicenseGenerationException, SecurityManagerException, BadPropertyException, MalformedContentElementException, UnsupportedFeatureException; } Method description</p><p>This method is used to generate a license conformant to ISO/IEC 21000-5. The “issuer” element in the license is automatically generated by the ContentBuilder class by retrieving it from the SecurityManager (See Error: Reference source not found) object passed in the constructor of the ContentBuilder class. The same applies for the “principal”, whose certificate is retrieved from the SecurityManager too using the keyAlias input parameter. If the license is for a ProtectedContentElement, the MasterKey contained in the ProtectedContentElement will be encrypted using the principal’s public key and inserted in the License in the rel-m1x:ProtectedResource element.</p><p>Parameters keyAlias An alias for the certificate of the “principal” of the license to be issued, which will be fetched in the SecurityManager (See Error: Reference source not found) object passed in the constructor of the ContentBuilder class. If the keyAlias is null, the issued license will not specify any principal, meaning that the right is granted to everyone. rightElement An object conveying the right to be granted in the license (see Error: Reference source not found). resource An object of class GovernedContentElement (see Error: Reference source</p><p>© ISO/IEC 2009 — All rights reserved 23 ISO/IEC CD 23006-2 not found). As ProtectedContentElement (see Error: Reference source not found) extends GovernedContentElement, in case resource is an instance of ProtectedContentElement, the MasterKey contained in the ProtectedContentElement will be encrypted using the principal’s public key and inserted in the License in the rel-m1x:ProtectedResource element. allConditions An object of class AllConditions (see Error: Reference source not found) containing all the conditions to be specified in the license..</p><p>Return value</p><p>RELLicense (See Error: Reference source not found), a license conformant to ISO/IEC 21000-5 containing one rel-r:grant and the issuer.</p><p>Exceptions</p><p>LicenseGenerationException (see Error: This exception is thrown if an error occurred while Reference source not found) instantiating the classes involved in the creation of XML data.</p><p>SecurityManagerException (see Error: This exception is thrown if the digital certificate of either the Reference source not found) license issuer or the license principal could not be retrieved from the SecurityManager because it does not exist.</p><p>BadPropertyException (see Error: This exception is thrown if one or more properties required Reference source not found) by the SecurityManager (e.g. the location of the secure repository where digital certificates reside) were corrupted.</p><p>MalformedContentElementException This exception is thrown if the data contained in the resource (see Error: Reference source not found) passed as a parameter was not complete or corrupted (e.g. the Master key for a ProtectedContentElement is missing).</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties required Error: Reference source not found) by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>6.3.1.5 Create an ORC License using ContentBuilder</p><p>ORC licenses are ISO/IEC 21000-5 Amd 3 licenses equivalent to Creative Commons Error: Reference source not found licenses. This is a high-level method to create an OAC license. It supposes that an object implementing the ContentBuilder interface (see Error: Reference source not found) was initialised with the information required to retrieve the digital certificate of the issuer of the license to be issued.</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+buildORCLicense(resourceID:string, licenseName:string):RELLicense</p><p>Java sample code public interface ContentBuilder { public RELLicense buildORCLicense(String resourceID, String licenseName) throws LicenseGenerationException, SecurityManagerException, BadPropertyException, DeviceContextException; } Method description</p><p>This method is used to generate a license conformant to ISO/IEC 21000-5 Amd 3 and semantically</p><p>24 © ISO/IEC 2009 — All rights reserved equivalent to a Creative Commons Error: Reference source not found license. As the number of Creative Common licenses is a finite number, in order to create an OAC license it is only sufficient to specify the identifier of the governed resource to be inserted in the license, and the specific Creative Commons license name. The “issuer” element in the license is automatically generated by the ContentBuilder class by retrieving it from the SecurityManager (See Error: Reference source not found) object passed in the constructor of the ContentBuilder class.</p><p>Parameters resourceID The identifier of the resource to which the Grant in the license applies. licenseName The name of the specific OAC license to be created. All possible names for OAC licenses are defined in the RELLicense (see Error: Reference source not found) interface.</p><p>Return value</p><p>RELLicense (See Error: Reference source not found), a license conformant to ISO/IEC 21000-5 Amd 3 and semantically equivalent to a Creative Commons Error: Reference source not found license.</p><p>Exceptions</p><p>LicenseGenerationException (see Error: This exception is thrown if an error occurred while instantiating Reference source not found) the classes involved in the creation of XML data.</p><p>SecurityManagerException (see Error: This exception is thrown if the digital certificate of the license Reference source not found) issuer could not be retrieved from the SecurityManager because it does not exist.</p><p>BadPropertyException (see Error: This exception is thrown if one or more properties required by Reference source not found) the SecurityManager (e.g. the location of the secure repository where digital certificates reside) were corrupted.</p><p>6.3.1.6 Create an ORC License using ORCLicenseBuilder</p><p>ORC licenses are ISO/IEC 21000-5 Amd 3 licenses equivalent to Creative Commons Error: Reference source not found licenses.</p><p>Interface ORCLicenseBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+buildORCLicense(resourceID:string, licenseName:string, issuer:Issuer, creatorName:String):RELLicense</p><p>Java sample code public interface ORCLicenseBuilder { public RELLicense buildORCLicense(String resourceID, String licenseName, Issuer issuer, String creatorName) throws LicenseGenerationException; } Method description</p><p>This method is used to generate a license conformant to ISO/IEC 21000-5 Amd 3 and semantically equivalent to a Creative Commons Error: Reference source not found license. As the number of Creative Common licenses is a finite number, in order to create an OAC license it is only sufficient to specify the identifier of the governed resource to be inserted in the license, and the specific Creative Commons license name. All possible names for OAC licenses are defined in the RELLicense (See Error: Reference source not found) interface.</p><p>Parameters</p><p>© ISO/IEC 2009 — All rights reserved 25 ISO/IEC CD 23006-2 resourceID The identifier of the resource to which the Grant in the license applies. licenseName The name of the specific OAC license to be created. All possible names for OAC licenses are defined in the RELLicense (see Error: Reference source not found) interface. issuer An object extending the Issuer interface (see Error: Reference source not found), the issuer of the license to be issued. creatorName The name of the creator as it shall appear in the copyrightString of the OAC license.</p><p>Return value</p><p>RELLicense (See Error: Reference source not found), a license conformant to ISO/IEC 21000-5 Amd 3 and semantically equivalent to a Creative Commons Error: Reference source not found license.</p><p>Exceptions</p><p>LicenseGenerationException (see Error: This exception is thrown if an error occurred while instantiating Reference source not found) the classes involved in the creation of XML data.</p><p>6.3.2 License Access</p><p>6.3.2.1 Getting the LicenseId</p><p>Interface License (see Error: Reference source not found)</p><p>Method Syntax</p><p>+getLicenseId(): String</p><p>Java sample code public String getLicenseId(String xmlLicenses) throws UnsupportedFeatureException;</p><p>Method description</p><p>This method is used to extract the r:licenseId from a given license conformant to ISO/IEC 21000-5.</p><p>Parameters</p><p>A license conformant to ISO/IEC 21000-5 containing one or more rel-r:grant and the issuer</p><p>Return value</p><p>String (See Error: Reference source not found), the license id.</p><p>Exceptions</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>26 © ISO/IEC 2009 — All rights reserved 6.3.2.2 Operation to retrieve the license title</p><p>Note that the license might have more than one title, and it could have several languages etc. In its simplest version, we can consider title as a string.</p><p>Method Syntax</p><p>+getTitle(): String</p><p>Java sample code public String getTitle(String xmlLicenses) throws UnsupportedFeatureException;</p><p>Method description</p><p>This method is used to extract the title from a given license conformant to ISO/IEC 21000-5. If there are moret han one titles, behaviour is undefined.</p><p>Parameters</p><p>A license conformant to ISO/IEC 21000-5 </p><p>Return value</p><p>String (See Error: Reference source not found), the license title.</p><p>Exceptions</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>6.3.2.3 Operation to retrieve the inventory</p><p>Method Syntax</p><p>+getInventory(): String</p><p>Java sample code public String getInventory(String xmlLicenses) throws UnsupportedFeatureException;</p><p>Method description</p><p>This method is used to extract the inventory from a given license conformant to ISO/IEC 21000- 5.</p><p>Parameters</p><p>A license conformant to ISO/IEC 21000-5 </p><p>Return value</p><p>String (See Error: Reference source not found), the license inventory.</p><p>© ISO/IEC 2009 — All rights reserved 27 ISO/IEC CD 23006-2 Exceptions</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>6.3.2.4 Operation to retrieve the list of grants</p><p>Method Syntax</p><p>+getListofGrants(xmlLicense:string): List<RELGrant></p><p>Java sample code public List<RELGrant> getListofGrants(String xmlLicenses) throws MalformedContentElementException, UnsupportedFeatureException;</p><p>Method description</p><p>This method is used to extract the grants from a given license conformant to ISO/IEC 21000-5.</p><p>Parameters xmlLicense A license conformant to ISO/IEC 21000-5 containing one or more rel- r:grant and the issuer</p><p>Return value</p><p>List<RELGrant> (See Error: Reference source not found), the list of grants conformant to ISO/IEC 21000-5 contained in the license.</p><p>Exceptions</p><p>MalformedContentElementException This exception is thrown if the data contained in the (see Error: Reference source not license passed as a parameter was not complete or found) corrupted (e.g. the Master key for a ProtectedContentElement is missing).</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>6.3.2.5 Operation to retrieve the license issuer </p><p>Method Syntax</p><p>+getIssuer(xmlLicense:string): RELIssuer</p><p>Java sample code public RELIssuer getIssuer(String xmlLicenses) throws MalformedContentElementException, UnsupportedFeatureException;</p><p>Method description</p><p>28 © ISO/IEC 2009 — All rights reserved This method is used to extract the Issuer from a given license conformant to ISO/IEC 21000-5.</p><p>Parameters xmlLicense A license conformant to ISO/IEC 21000-5 containing one or more rel- r:grant and the issuer</p><p>Return value String (See Error: Reference source not found), the issuer conformant to ISO/IEC 21000-5 contained in the license.</p><p>Exceptions</p><p>MalformedContentElementException This exception is thrown if the data contained in the (see Error: Reference source not license passed as a parameter was not complete or found) corrupted (e.g. the Master key for a ProtectedContentElement is missing).</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>6.3.2.6 Operation to retrieve other information</p><p>Method Syntax</p><p>+getOtherInfo(): String</p><p>Java sample code public String getOtherInfo (String xmlLicenses) throws UnsupportedFeatureException;</p><p>Method description</p><p>This method is used to extract the r:licenseId from a given license conformant to ISO/IEC 21000-5.</p><p>Parameters</p><p>A license conformant to ISO/IEC 21000-5 containing one or more rel-r:grant and the issuer</p><p>Return value</p><p>String (See Error: Reference source not found), the otherInfo.</p><p>Exceptions</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>© ISO/IEC 2009 — All rights reserved 29 ISO/IEC CD 23006-2 6.3.3 License validation</p><p>6.3.3.1 Validate if a License is Issued by a specific Issuer</p><p>6.3.4 License authorisation</p><p>6.3.4.1 Authorise an REL query against an REL License given a Context </p><p>[Editor's note: we need to define the Context interface]</p><p>The authorise method is employed to verify whether among a set of licenses in input there is one that may grant to a specific principal a specific right over a specific resource, after verifying that the conditions in the license, if present, are met.</p><p>Interface LicenseManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ authorise (resourceID : string, licenses: List<RELLicense>, rightElement : RightElement, userAlias : String, password : string): AuthorisationResult</p><p>Java sample code public interface LicenseManager { private AuthorisationResult isActionAllowed (String resourceID, List<RELLicense> licenses, RightElement rightElement, String userAlias, String password) throws SecurityManagerException, BadPropertyException, LicenseAuthorisationException, UnsupportedFeatureException; } Method description</p><p>This method is used to verify whether a License in a list of Licenses may grant to a principal a right over a resource.</p><p>Parameters resourceID A string identifying the resource, over which a principal wants a right be granted licenses A vector of objects of type RELLicense (see Error: Reference source not found) representing an rel-r:license rightElement An object conveying the right to be granted in the license (see Error: Reference source not found). userAlias A string necessary to identify the certificate of the principal among those stored in the SecurityManager. password A string value needed to access the SecurityManager certificate repository.</p><p>Return value</p><p>An array containing all the licenses (see Error: Reference source not found) found in the list of Licenses that grant the user with userAlias and password the right in rightElement for the content item or content element with identifier resourceID. </p><p>Exceptions</p><p>LicenseAuthorisationException This exception is thrown if problems occurred while generating a query to be validated against the licenses, and parsing the</p><p>30 © ISO/IEC 2009 — All rights reserved licenses in input</p><p>SecurityManagerException This exception is thrown if the data in the secure repository is corrupted</p><p>BadPropertyException This exception is thrown if the properties used to initialise the SecurityManager were not correctly set, hence the SecurityManager was unable to determine the location of the secure repository.</p><p>UnsupportedFeatureException This exception is thrown if an error occurred while validating the principal in the license against the principal in the query.</p><p>6.4 IPMP Engine APIs</p><p>6.4.1 IPMP Information Creation</p><p>This section specifies the APIs to create a Digital Item describing a content item containing one or more protected resources, whose protection information is specified according to the MPEG-21 IPMP Components profile defined in ISO/IEC 23000-5. When a protected resource is added to a content item, and the information required to protect it has been set by means of the APIs specified in this section, an application may additionally request MXM to create the protected resource as specified in Error: Reference source not found, and obtain a new identifier for it from a Content Identification Device as specified in Error: Reference source not found.</p><p>6.4.1.1 AddIPMPTool</p><p>Interface ProtectedContentElement (see Error: Reference source not found)</p><p>Method Syntax</p><p>+addDRMTool (toolID:string, controlPointIDs:int[], key:byte[], keyFilePathname:string, initDataFilePathname:string):void</p><p>Java sample code public interface ProtectedContentElement { public void addDRMTool (String toolID, int[] controlPointIDs, byte[] key, String keyFilePathname, String initDataPathname) ; } Method description</p><p>This method is used to specify that a resource part of a content item is protected. When the Digital Item representing the content item is created, a didl:Item corresponding to this resource will be added. This will contain a didl:Component element containing a didl:Resource element, which in turn will contain an ipmpdidl:ProtectedAsset element containing the IPMP information for the resource.</p><p>A Resource may be protected by a number of IPMP Tools. Each IPMP Tool can be individually configured using the addDRMTool method. The value of the parameters of this method will be transformed into ISO/IEC 21000-4 elements and added as child of the ipmpdidl:ProtectedAsset.</p><p>Parameters toolID The identifier of the IPMP Tool controlPointIDs The list of control points in which the IPMP Tool shall operate, as defined in ISO/IEC 23001-3. key The symmetric encryption key in clear text, to be used to encrypt the resource.</p><p>© ISO/IEC 2009 — All rights reserved 31 ISO/IEC CD 23006-2 keyFilePathname The absolute pathname to an XML file containing time-dependent keys to be used to encrypt the resource. The XML file shall be formatted as a KeyData XML message as specified in ISO/IEC 23001-3. This parameter can be null, in which case the resource will not be encrypted, and no KeyData message will be added to the IPMP information related to this IPMP Tool. initDataFilePathname The absolute pathname to an XML file containing initialisation data for the IPMP Tool. The XML file shall be formatted as an InitialiseTool XML message as specified in ISO/IEC 23001-3. In case this parameter is null, no initialisation information will be added to the IPMP information related to this IPMP Tool.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>6.4.1.2 SetMasterKey</p><p>Interface ProtectedContentElement (see Error: Reference source not found)</p><p>Method Syntax</p><p>+setMasterKey (masterKey:byte[], encryptionKeyAlgorithm_JCA:string, encryptionKeyAlgorithm_W3C:string):void</p><p>Java sample code public interface ProtectedContentElement { public void setMasterKey(byte[] masterKey, String encryptionKeyAlgorithm_JCA, String encryptionKeyAlgorithm_W3C) ; } Method description</p><p>This method is used to specify a Master Key to be used to encrypt all the encryption keys to be inserted in the ipmpmsg:KeyData element, child of the ipmpinfo:InitializationData, set by means of the addDRMTool method (See Error: Reference source not found).</p><p>Parameters masterKey The Master Key to be used to encrypt all the symmetric keys set by means of the addDRMTool method (See Error: Reference source not found), to be used by the IPMP Tool to encrypt (creation phase) or decrypt (presentation phase) a resource. All these keys will be encrypted with the specified Master Key before being inserted in the ipmpmsg:KeyData message(s). encryptionKeyAlgorithm_JCA The name of the encryption algorithm to be used to encrypt all the keys with the specified Master Key as known by the platform on which the algorithm runs</p><p>32 © ISO/IEC 2009 — All rights reserved encryptionKeyAlgorithm_W3C The name of the encryption algorithm to be used to encrypt all the keys with the specified Master Key as specified in Error: Reference source not found</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>6.4.1.3 Method to add a rigths descriptor to an IPMPInfoDescriptor.</p><p>Interface ProtectedContentElement??()</p><p>Method Syntax</p><p>+addRightsDescriptor (IPMPInfoDescriptor:string, RightsDescriptor:string): string</p><p>Java sample code public interface ProtectedContentElement?? { public string addRightsDescription(String IPMPInfoDescriptor, String rightsDescriptor) ; } Method description</p><p>This method is used to add a Rights Descriptor to an existing IPMPInfoDescriptor. </p><p>Parameters</p><p>IPMPInfoDescriptor The IPMP element is the XML representation of the element where the Rights Descriptor has to be added. rightsDescriptor The Rights Descriptor is the XML representation of the Rights Descriptor to be added to the IPMP element.</p><p>Return value</p><p>A string indicating if the operation has been correctly performed. In case of error, a description of the error is returned, OK otherwise.</p><p>Exceptions</p><p>6.4.1.4 Method to add an element to an IPMPInfoDescriptor</p><p>Interface ProtectedContentElement</p><p>Method Syntax</p><p>+addElementIPMPInfo(IPMPInfoDescriptor: string, element: string):string</p><p>Java sample code public interface ProtectedContentElement?? {</p><p>© ISO/IEC 2009 — All rights reserved 33 ISO/IEC CD 23006-2 public string addElementIPMPInfo(String IPMPInfoDescriptor, String element) ; } Method description</p><p>This method is used to add an element to an existing IPMPInfoDescriptor. </p><p>Parameters</p><p>IPMPInfoDescriptor The IPMPInfoDescriptor is the XML representation of the element where the element has to be added.</p><p>Element The element is the XML representation of the element to be added to the IPMPInfoDescriptor.</p><p>Return value</p><p>A string indicating if the operation has been correctly performed. In case of error, a description of the error is returned, OK otherwise.</p><p>Exceptions isValid It raises if the element is not valid.</p><p>6.4.1.5 Method to add an element to an IPMPGeneralInfoDescriptor</p><p>Interface ProtectedContentElement??()</p><p>Method Syntax</p><p>+addElementIPMPGeneralInfo(IPMPGeneralInfoDescriptor: string, element: string):string</p><p>Java sample code public interface ProtectedContentElement?? { public string addElementIPMPGeneralInfo(String IPMPGeneralInfoDescriptor, String element) ; } Method description</p><p>This method is used to add an element to an existing IPMPGeneralInfoDescriptor. </p><p>Parameters</p><p>IPMPGeneralInfoDescriptor The IPMPGeneralInfoDescriptor is the XML representation of the element where the element has to be added.</p><p>Element The element is the XML representation of the element to be added to the IPMPGeneralInfoDescriptor.</p><p>Return value</p><p>A string indicating if the operation has been correctly performed. In case of error, a description of the error is returned, OK otherwise.</p><p>Exceptions isValid It raises if the element is not valid.</p><p>34 © ISO/IEC 2009 — All rights reserved 6.4.2 IPMP Information access</p><p>6.4.2.1 Parse an XML IPMP Message</p><p>6.4.2.2 Method to access IPMP Tool information from an IPMPInfoDescriptor</p><p>Interface ProtectedContentElement??()</p><p>Method Syntax</p><p>+getIPMPToolInfo(IPMPInfoDescriptor: string): array of string</p><p>Java sample code public interface ProtectedContentElement?? { public string [] getIPMPToolInfo(String IPMPInfoDescriptor); } Method description</p><p>This method is used to get the information from an IPMP Tool contained in an IPMPInfoDescriptor. </p><p>Parameters</p><p>IPMPInfoDescriptor The IPMPInfoDescriptor is the XML representation of the descriptor from where the IPMP tool has to be obtained.</p><p>Return value</p><p>A string array with the whole information of the IPMP tools in XML format.</p><p>Exceptions</p><p>6.5 Access RightsDescriptor from an IPMPInfoDescriptor</p><p>6.5.1.1 Method to access RightsDescriptor from an IPMPInfoDescriptor</p><p>Interface ProtectedContentElement??()</p><p>Method Syntax</p><p>+getRightsDescriptor (IPMPInfoDescriptor: string):array of string</p><p>Java sample code public interface ProtectedContentElement?? { public string [] getRightsDescriptor(String IPMPInfoDescriptor); } Method description</p><p>This method is used to get the Rights Descriptor in an IPMPInfoDescriptor. </p><p>Parameters</p><p>IPMPInfoDescriptor The IPMPInfoDescriptor is the XML representation of the descriptor from where the Rights Descriptor has to be obtained.</p><p>Return value</p><p>© ISO/IEC 2009 — All rights reserved 35 ISO/IEC CD 23006-2 A string array with the whole information of the different Rights Descriptors in XML format.</p><p>Exceptions</p><p>6.5.1.2 Method to access any information from any IPMP element</p><p>Interface ProtectedContentElement??()</p><p>Method Syntax</p><p>+parseIPMPElement (elementName: string):string</p><p>Java sample code public interface ProtectedContentElement?? { public string parseIPMPElement(String elementName); } Method description</p><p>This method is used to extract the information associated to the element identified by the elementName parameter. </p><p>Parameters elementName The name of the element to be parsed and obtained.</p><p>Return value</p><p>A string with the whole information of the element identified by elementName.</p><p>Exceptions</p><p>6.5.1.3 Create an XML IPMP Message</p><p>6.5.2 Resource Protection</p><p>6.5.2.1 ProtectResource</p><p>A resource can be protected by invoking the protectResource method specified below. After being protected, the protected resource requires a new identifier, which can be obtained by invoking the method identifyProtectedResource also specified below.</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ protectResource (resourceInfo:ProtectedContentElement):boolean</p><p>Java sample code public interface ContentBuilder { public boolean protectResource(ProtectedContentElement resourceInfo) throws MediaFrameworkException, MalformedContentElementException, UnsupportedFeatureException, IOException, DRMProcessorException; } Method description</p><p>This method is used to protect (e.g. encrypt) a resource. The method assumes that an object of type</p><p>36 © ISO/IEC 2009 — All rights reserved ProtectedContentElement was previously initialised with the information required in order to allow MXM to protect the resource accordingly</p><p>Parameters resourceInfo An instance of class ProtectedContentElement (see Error: Reference source not found) containing all the information describing the resource and how it shall be protected.</p><p>Return value true if the resource was successfully protected, false otherwise.</p><p>Exceptions</p><p>MediaFrameworkException (see Error: This exception is thrown if the MediaFramework to be used to Reference source not found) protect the resource was not found or could not be instantiated.</p><p>MalformedContentElementException This exception is thrown if the information contained in the (see Error: Reference source not found) ProtectedContentElement object given in input was not complete, not valid or leading to an ambiguous interpretation, hence MXM was unable to protect the resource.</p><p>UnsupportedFeatureException (see This exception is thrown if the information contained in the Error: Reference source not found) ProtectedContentElement object given in input was not supported by MXM (e.g. encryption algorithm not supported).</p><p>IOException (see Error: Reference This exception is thrown if problems were detected while writing source not found) the protected resource in a new file.</p><p>DRMProcessorException (see Error: This exception is thrown if one of the IPMP Tools to be used to Reference source not found) protect the resource was not found or could not be instantiated.</p><p>6.5.2.2 IdentifyProtectedResource</p><p>The identifyProtectedResource method is used to identify a resource after it has been protected (e.g. encrypted). This method works at a higher level of that that specified in Error: Reference source not found, as the ProtectedContentElement given in input, if the operation succeeds, will already contain the new identifier and its hash properly set.</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ identifyProtectedResource (protectedContentElement:ProtectedContentElement, cidURL:String):String</p><p>Java sample code public interface ContentBuilder { public String identifyProtectedResource (ProtectedContentElement protectedContentElement, String cidURL) throws ContentIdentificationException, IOException, UnsupportedFeatureException, ServiceException; } Method description</p><p>This method is used to identify a resource after this has been protected (e.g. encrypted), hence a new file has been created. The method assumes that an object of type ProtectedContentElement was previously initialised with the information required in order to allow MXM to protect the resource accordingly</p><p>Parameters</p><p>© ISO/IEC 2009 — All rights reserved 37 ISO/IEC CD 23006-2 protectedContentElement An instance of class ProtectedContentElement (see Error: Reference source not found) containing all the information describing the resource and how it shall be protected. cidURL The URL of the service to be invoked in order to request an identifier for the new resource.</p><p>Return value</p><p>The resource identifier if the resource was successfully identified, false otherwise.</p><p>Exceptions</p><p>ContentIdentificationException This exception is thrown if an error occurred while creating the (see Error: Reference source not message to request the new identifier, or if the cidURL input found) parameter is malformed.</p><p>UnsupportedFeatureException This exception is thrown if the information contained in the (see Error: Reference source not ProtectedContentElement object given in input was not supported by found) MXM (e.g. hash algorithm not supported).</p><p>IOException (see Error: Reference This exception is thrown if problems were detected while calculating source not found) the hash value of the resource file.</p><p>ServiceException (see Error: This exception is thrown if an error occurred while communicating Reference source not found) with the content identification service.</p><p>6.6 IPMP Tool instantiation</p><p>6.6.1.1 Method to instantiate a specific IPMP Tool having specific characteristics in a specific Control Point.</p><p>Interface ProtectedContentElement??()</p><p>Method Syntax</p><p>+instantiateIPMPTool (IPMPTool: string):int</p><p>Java sample code public interface ProtectedContentElement?? { public int instantiateIPMPTool(String IPMPTool); } Method description</p><p>This method is used to instantiate an IPMPTool from its XML description. </p><p>Parameters</p><p>IPMPTool The information of the IPMP Tool to be instantiated.</p><p>Return value</p><p>An integer with value 0 if the tool can be instantiated and different that 0 otherwise, to indicate</p><p>38 © ISO/IEC 2009 — All rights reserved the error.</p><p>Exceptions</p><p>6.6.1.2 Method to Initialise a specific IPMP Tool already instantiated with specific initialisation data.</p><p>Interface ProtectedContentElement??()</p><p>Method Syntax</p><p>+initialiseIPMPTool (tool: IPMPTool):int</p><p>Java sample code public interface ProtectedContentElement?? { public int initialiseIPMPTool(IPMPTool tool); } Method description</p><p>This method is used to initialise an IPMPTool. </p><p>Parameters tool A class representing the IPMPTool to be initialised</p><p>Return value</p><p>An integer with value 0 if the tool can be instantiated and different that 0 otherwise, to indicate the error.</p><p>Exceptions</p><p>6.7 Media Framework Engine APIs</p><p>6.7.1 Generic Elementary Stream</p><p>6.7.1.1 Creation</p><p>6.7.1.1.1 EncodeElementaryStream</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ encodeElementaryStream (es:ElementaryStream[]):boolean</p><p>Java sample code public interface ResourceManager { public boolean encodeElementaryStream (ElementaryStream[] es, URL location) throws ResourceBuilderException } Method description</p><p>This method is used to create (e.g. encode) a resource. The method assumes that an object of type ElementaryStream[] was previously initialised (or retrived from a demuxResource call) with the</p><p>© ISO/IEC 2009 — All rights reserved 39 ISO/IEC CD 23006-2 information required in order to allow MXM to create the resource accordingly (e.g. specify target URLs)</p><p>Parameters es A set of instances of class ElementaryStream containing all the information describing the ElementaryStream and how it shall be encoded/decoded.</p><p>Return value true if the resource was successfully created, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourseBuilder failed Reference source not found) creating the Resource</p><p>6.7.1.1.2 AddEncoderInformation</p><p>Interface ElementaryStream (see Error: Reference source not found)</p><p>Method Syntax</p><p>+addEncoderInformation (bitrate:double, algorithmName:string):void</p><p>Java sample code public interface ElementaryStream { public void addEncoderInformation(Double bitrate, String algorithmName) throws EncoderException; } Method description</p><p>This method is used to specify how an ElementaryStream has to be encoded. When an application create a Resource, an Encoder labelled algorithmName has to be instantiated in the media chain before the Muxing and Composition phase. If no EncoderInformation was specified, no Encoder has to be instantiated in the media chain</p><p>Parameters bitrate The bitrate the encoder has to use algorithmName The algorithm's name of the encoder [Editor's note: which names are allowed?]</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>EncoderException (see This exception is thrown if the algorithmName is not feasible to the Error: Reference ElementaryStream. source not found)</p><p>40 © ISO/IEC 2009 — All rights reserved 6.7.1.2 Editing</p><p>6.7.1.3 Decoding</p><p>6.7.1.4 Rendering</p><p>6.7.1.5 Adaptation</p><p>[Editor's note: use one table for each method, make consistent with the rest of the document]</p><p>Adapting resources according to terminal environment description</p><p>UML Specifications</p><p>Method Syntax for Interface MXMResAdaptDescr</p><p>+ adaptResByDescr (namespaceURI:string, ued:string):boolean</p><p>Class Diagram</p><p>Java sample code implementation public interface MXMResAdaptDescr </p><p>{</p><p> public boolean adaptResByDescr(String namespaceURI,String ued) throws MXMDescrException;</p><p>}</p><p>Method adaptResByDescr description</p><p>This method is used to adapt the resource by using the usage environment description (ued) identified by the namespace namespaceURI. The ued shall provide a description of the usage environment where the resource is consumed.</p><p>© ISO/IEC 2009 — All rights reserved 41 ISO/IEC CD 23006-2 Parameters</p><p> namespaceURI</p><p>The namespaceURI parameter is a String containing the URI of the namespace identifying the usage environment description.</p><p> ued</p><p>The ued parameter is a String containing the usage environment description.</p><p>Return value</p><p>The return value is true if the adaptation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMDescrException with NOT_SUPPORTED_ERROR.</p><p>MXMDescrException with INVALID_DESCRIPTION_ERROR.</p><p>42 © ISO/IEC 2009 — All rights reserved 6.7.2 Image APIs</p><p>6.7.2.1 Creation</p><p>6.7.2.2 Editing</p><p>6.7.2.3 Decoding</p><p>6.7.2.4 Rendering</p><p>6.7.3 Audio APIs</p><p>6.7.3.1 Creation</p><p>6.7.3.2 Editing</p><p>6.7.3.3 Decoding</p><p>6.7.3.4 Rendering</p><p>6.7.4 Video APIs</p><p>6.7.4.1 Creation</p><p>6.7.4.2 Editing</p><p>6.7.4.3 Decoding</p><p>6.7.4.4 Rendering</p><p>6.7.5 Reconfigurable Video APIs</p><p>6.7.5.1 Creation</p><p>6.7.5.2 Decoding</p><p>6.7.5.3 Engine-specific APIs</p><p>6.7.5.3.1 AddRVCDecoder</p><p>Building an RVC decoder or receiving/downloading a decoder plug-in</p><p>Interface RVCDecoderManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+addRVCDecoder (RVCType:string, serviceprovider:URL):void</p><p>Java sample code public interface RVCDecoderManager { public void addRVCDecoder(String RVCType, URL serviceprovider) throws DecoderManagerExceptions; } Method description</p><p>This method is used to configure a new RVC decoder as player plug-in or receive/download a decoder</p><p>© ISO/IEC 2009 — All rights reserved 43 ISO/IEC CD 23006-2 plug-in from web URL or service provider. It supports both “embedded” (where the new RVC decoder configuration plug-in is generated inside the MXM media receiver) and “centralized” (where the new RVC decoder configuration plug-in is received by the service provider or downloaded by a web URL) use cases.</p><p>Parameters</p><p>RVCType The identifier of a RVC configuration</p><p>Serviceprovider The URL of the service provider server</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>NewDecoderConfigurat This exception is thrown if the RVCDecoderManager process failed in ionFailedException creating/downloading the required RVC decoder plug-in (see Error: Reference source not found)</p><p>ServiceProviderConne This exception is thrown if the RVCDecoderManager process failed in ctionException (see creating/downloading the required RVC decoder plug-in for failing connection Error: Reference with the service provider server source not found)</p><p>6.7.5.3.2 AddDecoderInformation</p><p>This section specifies the APIs to describe the algorithm_name (Decoder) that has to be applied to an ElementaryStream.</p><p>Interface ElementaryStream (see Error: Reference source not found)</p><p>Method Syntax</p><p>+addDecoderInformation (algorithName:string):void</p><p>Java sample code public interface ElementaryStream { public void addDecoderInformation(String algorithmName) throws DecoderException; } Method description</p><p>This method is used to specify how a ElementaryStream has to be decoded. When an application consume a Resource, a Decoder labelled algorithmName has to be instantiated in the media chain before the Composition and Rendering phase. If no DecoderInformation are specified, the MXM framework has to be able to instantiate the decoder it holds that best fits with the ElementaryStream characteristics. Parameters algorithmName The algorithm's name of the encoder</p><p>Return value void</p><p>44 © ISO/IEC 2009 — All rights reserved Exceptions</p><p>DecoderException This exception is thrown if the algorithmName is not feasible to the (see Error: Reference ElementaryStream characteristics. source not found)</p><p>6.7.6 Muxed Content APIs</p><p>6.7.6.1 Creation</p><p>6.7.6.2 Editing</p><p>6.7.6.3 Access</p><p>[Editor's note: use tables for each method to keep consistency with the rest of the document, add exceptions and interfaces to annex]</p><p>The following interface defines the API for loading an MP4 file. </p><p>UML Specifications</p><p>Method syntax for interface MXMFileFormat</p><p>+LoadMP4(url : string, type : outputType) : boolean</p><p>+GetRARfromMETA(alloc : boolean, buff : string, size : int) : boolean</p><p>+GetXMLfromMETA(alloc : boolean, buff : string, size : int) : boolean</p><p>Class Diagram</p><p>C++ sample code implementation interface MXMFileFormat {</p><p>Boolean LoadMP4( in String url, out outputType type) raises(MXMFileFormatException);</p><p>Boolean GetRARfromMETA(in Boolean alloc, out String buff, out int size,) raises(MXMFileFormatException);</p><p>Boolean GetXMLfromMETA(in Boolean alloc, out String buff, out int size,) raises(MXMFileFormatException);</p><p>};</p><p>© ISO/IEC 2009 — All rights reserved 45 ISO/IEC CD 23006-2 Method LoadMP4 description</p><p>LoadMP4File()</p><p>This method is used to load and process (demux and decode) an MP4 file. </p><p>Parameters</p><p> url</p><p>The url parameter is a String containing the URL from where the MPEG-4 data is read.</p><p> type</p><p>The type parameter is an output parameter ot type outputType. The structure of outputType is the following:</p><p> enum outputType</p><p>{</p><p>NOTHING = -1,</p><p>OUT_VB = 0,</p><p>OUT_IFS= 1</p><p>// to be completed by other types</p><p>};</p><p> type is 0 if the geometry data from the MP4 file is proposed as a flat vertex and index buffer or 1 of it is proposed as a IndexedFaceSet structure.</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMFileFormatException with NOT_SUPPORTED_ERROR.</p><p>MXMFileFormatException with INVALID_FILE_ERROR.</p><p>Method GetRARfromMETA description</p><p>GetRARfromMETA()</p><p>This method gives access to the RAR version of the META atom of the MP4 file. One of usages is for accessing scene graph data encapsulated as described in ISO/IEC 14496-25.</p><p>Parameters</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff</p><p>46 © ISO/IEC 2009 — All rights reserved contains the META atom in RAR form</p><p> size specifies the size of buff</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMFileFormatException with NOT_SUPPORTED_ERROR.</p><p>MXMFileFormatException with INVALID_FILE_ERROR.</p><p>Method GetXMLfromMETA description</p><p>GetXMLfromMETA()</p><p>This method gives access to the XML version of the META atom of the MP4 file. One of usages is for accessing scene graph data encapsulated as described in ISO/IEC 14496-25.</p><p>Parameters</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the META atom in RAR form</p><p> size specifies the size of buff</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMFileFormatException with NOT_SUPPORTED_ERROR.</p><p>MXMFileFormatException with INVALID_FILE_ERROR.</p><p>6.7.6.4 Rendering</p><p>6.7.6.4.1 Mute</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ mute ():boolean</p><p>© ISO/IEC 2009 — All rights reserved 47 ISO/IEC CD 23006-2</p><p>Java sample code public interface ResourceManager { public boolean mute () throws ResourceBuilderException } Method description</p><p>This method is used to mute the audio renderer. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Return value true if the resource was successfully muted, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) mute the audio renderer</p><p>6.7.6.4.2 Un-Mute</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ unMute (volume: float):boolean</p><p>Java sample code public interface ResourceManager { public boolean unMute (Float volume) throws ResourceBuilderException } Method description</p><p>This method is used to unmute the audio renderer and to set accord lying the new volume level (in percent). The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Volume New volume, in percent</p><p>Return value true if the resource was successfully unmuted, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) unmute the audio renderer</p><p>6.7.6.4.3 SetVolume</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>48 © ISO/IEC 2009 — All rights reserved Method Syntax</p><p>+ setVolume (volume: float):boolean</p><p>Java sample code public interface ResourceManager { public boolean setVolume (Float volume) throws ResourceBuilderException } Method description</p><p>This method is used to set the volume (in percent) of the audio renderer. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Volume New volume, in percent</p><p>Return value true if the volume was successfully stored, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to set Reference source not found) the volume of the audio renderer</p><p>6.7.6.5 Engine-specific APIs</p><p>6.7.6.5.1 Start</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ start():boolean</p><p>Java sample code public interface ResourceManager { public boolean start() throws ResourceBuilderException } Method description</p><p>This method is used to start the media chain to process. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Return value true if the resource was successfully started, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to start Reference source not found) the media chain</p><p>© ISO/IEC 2009 — All rights reserved 49 ISO/IEC CD 23006-2 6.7.6.5.2 Stop</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ stop ():boolean</p><p>Java sample code public interface ResourceManager { public boolean stop () throws ResourceBuilderException } Method description</p><p>This method is used to stop the media chain to process. The method assumes that a media chain was previously instantiated and started</p><p>Parameters</p><p>Return value true if the resource was successfully stopped, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) stop the Resource</p><p>6.7.6.5.3 Pause</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ pause ():boolean</p><p>Java sample code public interface ResourceManager { public boolean pause () throws ResourceBuilderException } Method description</p><p>This method is used to pause the media chain to process. The method assumes that a media chain was previously instantiated and started</p><p>Parameters</p><p>Return value true if the resource was successfully paused, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) pause the Resource</p><p>50 © ISO/IEC 2009 — All rights reserved 6.7.6.5.4 Destroy</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ destroy ():boolean</p><p>Java sample code public interface ResourceManager { public boolean destroy () throws ResourceBuilderException } Method description</p><p>This method is used to destroy the media chain and deallocate any resources. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Return value true if the media chain was successfully destroyed, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) destory the media chain</p><p>6.7.6.5.5 SetMediaTime</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setMediaTime (time:double):boolean</p><p>Java sample code public interface ResourceManager { public boolean setMediaTime (Double time) throws ResourceBuilderException } Method description</p><p>This method is used to set the time, in milliseconds, of the media chain. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Time Time in milliseconds that specify the new media chain position</p><p>Return value true if the time was successfully stored, false otherwise.</p><p>Exceptions</p><p>© ISO/IEC 2009 — All rights reserved 51 ISO/IEC CD 23006-2 ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to set Reference source not found) the new position of the media chain</p><p>6.7.6.5.6 GetDuration</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getDuration ():double</p><p>Java sample code public interface ResourceManager { public Double getDuration () throws ResourceBuilderException } Method description</p><p>This method is used to query the duration, in milliseconds, of the resource is currently playing in the media chain. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Return value</p><p>The duration of the resource, in milliseconds</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) query the media duration</p><p>6.7.6.5.7 getMediaTime</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getMediaTime ():double</p><p>Java sample code public interface ResourceManager { public Double getMediaTime () throws ResourceBuilderException } Method description</p><p>This method is used to query the current media position, in milliseconds, of the resource is currently playing in the media chain. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Return value</p><p>The current media time of the resource, in milliseconds</p><p>52 © ISO/IEC 2009 — All rights reserved Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) query the media position</p><p>6.7.6.5.8 IsRunning</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ isRunning ():boolean</p><p>Java sample code public interface ResourceManager { public boolean isRunning () throws ResourceBuilderException } Method description</p><p>This method is used to query the status of the media chain. The method assumes that a media chain was previously instantiated</p><p>Parameters</p><p>Return value true if the resource is currently running, false otherwise</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) query the media chain status</p><p>6.7.6.5.9 AddMediaChainListener</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ addMediaChainListener (listener MediaChainListener):boolean</p><p>Java sample code public interface ResourceManager { public boolean addMediaChainListener (MediaChainListener listener) throws ResourceBuilderException } Method description</p><p>This method is used by an Application to be notified on the Event throwed by the media chain</p><p>Parameters listener A class that implement the MediaChainListener</p><p>© ISO/IEC 2009 — All rights reserved 53 ISO/IEC CD 23006-2 Return value true if the listener was added, false otherwise</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourceManager failed to Reference source not found) add the media chain listener</p><p>6.7.6.5.10 RemoveMediaChainListener</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ removeMediaChainListener (listener MediaChainListener):boolean</p><p>Java sample code public interface ResourceManager { public boolean removeMediaChainListener (MediaChainListener listener) throws ResourceBuilderException } Method description</p><p>This method is used by an Application to remove the listener from the list of the class has to be notified on the Event throwed by the media chain</p><p>Parameters listener A class that implement implement the MediaChainListener</p><p>Return value true if the listener was removed, false otherwise</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourseBuilder failed to Reference source not found) remove the media chain listener</p><p>6.7.6.5.11 AddMuxerInformation</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+addMuxerInformation (mimeType:string):void</p><p>Java sample code public interface ResourceManager { public void addMuxerInformation(String mimeType) throws MuxerException; } Method description</p><p>54 © ISO/IEC 2009 — All rights reserved This method is used to specify the mimetype of the Resource when a createResource is called.</p><p>Parameters mimeType The mimetype of the Resource</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>ResourceBuilderExcept This exception is thrown if the mimetype is not compatible with the ion (see Error: ResourceManager characteristic Reference source not found)</p><p>6.7.6.5.12 AddDestination</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ addDestination(es:ElementaryStream[], ipaddresses:URL[]):boolean</p><p>Java sample code public interface ResourceManager { public String addDestination (ElementaryStream[] es, URL[] ipaddresses) throws ResourceBuilderException } Method description</p><p>This method is used to forwarding (streaming) to a specified URLs the passed ElementaryStreams. </p><p>Parameters es A set of instance of class ElementaryStream containing all the information describing the ElementaryStream and how it shall be encoded/decoded. ipaddresses A set of URLs where the Elementary Stream has to be streamed</p><p>Return value true if the resource was successfully consumed, false otherwise.</p><p>Exceptions</p><p>ResourceBuilderException(see Error: This exception is thrown if the ResourseBuilder failed consuming Reference source not found) the Resource</p><p>6.7.6.5.13 ReceiveStreams</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>© ISO/IEC 2009 — All rights reserved 55 ISO/IEC CD 23006-2 +receiveStreams(ports:int[]):ElementaryStream[]</p><p>Java sample code public interface ResourceManager { public ElementaryStream[] receiveStreams (int[] ports) throws ResourceBuilderException } Method description</p><p>This method is used to receive (from streaming) from a specified set of local ports a set of ElementaryStream</p><p>Parameters ports A set of ports where the ElementaryStreams can be retrieved</p><p>Return value</p><p>A set of instance of class ElementaryStreams containing all the information describing the ElementaryStream and how it shall be encoded/decoded.</p><p>Exceptions</p><p>ResourceBuilderException(see Error: This exception is thrown if the ResourseBuilder failed Reference source not found) consuming the Resource</p><p>6.7.6.5.14 Demux</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ demux(location URL):ElementaryStream[]</p><p>Java sample code public interface ResourceManager { public ElementaryStream[] demux(URL location) throws ResourceBuilderException } Method description</p><p>This method is used to consume demux a resource, specified by an URL.</p><p>Parameters location It specifyies the source of the resource.</p><p>Return value</p><p>A set of instance of class ElementaryStream containing all the information describing the ElementaryStream and how it shall be encoded/decoded.</p><p>Exceptions</p><p>ResourceBuilderException(see Error: This exception is thrown if the ResourseBuilder failed creating Reference source not found) the Resource</p><p>56 © ISO/IEC 2009 — All rights reserved 6.7.7 2D Layout APIs</p><p>6.7.7.1 Creation</p><p>This API is used for creating the geometric transformation of the 2D object inside the scene</p><p>6.7.7.2 Editing</p><p>6.7.7.3 Decoding</p><p>This API is used for retrieving the geometric transformation of the 2D object inside the scene (position, orientation and scale)</p><p>6.7.8 2D Graphics Primitives APIs</p><p>6.7.8.1 Creation</p><p>6.7.8.2 Editing</p><p>6.7.8.3 Decoding</p><p>6.7.8.4 Rendering</p><p>6.7.8.5 CreateDIPresentation</p><p>Interface LaserObjectProcessor </p><p>Method Syntax</p><p>+ createDIPresentation (laserFile:String, metadata:MetadataInterface,ccLicense:String):String</p><p>Java sample code public interface LaserObjectProcessor { public void createDIPresentation (String laserFile, MetadataInterface metadata, String ccLicense) throws IOException, DocumentException; } Method description</p><p>This method is used to insert content(resource) metadata and cc license information into an “empty” scene description file which should be created by an authoring tool. Then this scene description file which has been inserted with metadata and the cc license will be packaged into a binary file.</p><p>Parameters laserFile The path of the an “empty” scene description file. It defines the scene description about the metadata elements and cc license element, but these elements have not real values. metadata The MetadataInterface(see Error: Reference source not found) object, some values of this metadata will be inserted into the laserFile ccLicense The path of the cc License file</p><p>Return value</p><p>© ISO/IEC 2009 — All rights reserved 57 ISO/IEC CD 23006-2 String, the path of the created binary laser file. If occurs error, return null.</p><p>Exceptions</p><p>IOException This exception is thrown if occurs error while writing data into a file.</p><p>DocumentException This exception is thrown if occurs error while parse the laserFile.</p><p>6.7.8.6 Init</p><p>Interface LaserPresentation</p><p>Method Syntax</p><p>+ init (laserFile:String):void</p><p>Java sample code public interface LaserPresentation { public void inti (String laserFile) throws IOException, DocumentException; } Method description</p><p>This method is used to parse a laser File with path laserFile. It only parses the media part of the scene file and stores them.</p><p>Parameters laserFile The path of the scene description file. </p><p>Return value void</p><p>Exceptions</p><p>IOException This exception is thrown if occurs error while writing data into file.</p><p>DocumentException This exception is thrown if occurs error while parse the laserFile.</p><p>6.7.8.7 SetPresentationPanel</p><p>Interface LaserPresentation</p><p>Method Syntax</p><p>+ setPresentationPanel (panel:Panel):void</p><p>Java sample code public interface LaserPresentation { public void setPresentationPanel (Panel panel); } Method description</p><p>This method is used to set a panel in which the scene will be presented.</p><p>58 © ISO/IEC 2009 — All rights reserved Parameters panel A panel in which the content item(resource item) will be represented. The scene will be shown in this panel.</p><p>Return value void</p><p>Exceptions</p><p>6.7.8.8 showNotify</p><p>Interface LaserPresentation</p><p>Method Syntax</p><p>+ showNotify ():void</p><p>Java sample code public interface LaserPresentation { public void showNotify (); } Method description</p><p>This method is used to parse the content scene and present the objects in a panel. It will start a thread to implement this process.</p><p>Parameters</p><p>Return value void</p><p>Exceptions</p><p>6.7.9 3D Scene Graph APIs</p><p>6.7.9.1 Creation</p><p>6.7.9.2 Editing</p><p>6.7.9.3 Decoding</p><p>6.7.10 3D graphics primitives APIs</p><p>[Editor's note: use tables for each method to keep consistency with the rest of the document, add exceptions and interfaces to annex]</p><p>© ISO/IEC 2009 — All rights reserved 59 ISO/IEC CD 23006-2 6.7.10.1 Geometry related API The following interface defines the Geometry related API when the geometry is encoded by using the BIFS node "IndexedFaceSet" or by the 3DMC elementary stream.</p><p>UML Specifications</p><p>Method syntax for interface MXMGeometry</p><p>+GetVBandIBSize() : int</p><p>+GetVBandIB (alloc : boolean, buff : string) : boolean</p><p>+GetBIFSSize(ID : string) : Integer</p><p>+GetBIFS(alloc : boolean, ID : string, buff : string) : boolean</p><p>+Get3DMCCount() : Integer</p><p>+Get3DMCSize(ID : string) : Integer</p><p>+Get3DMC(alloc : boolean, ID : string, buff : string) : boolean</p><p>C++ sample code implementation interface MXMGeometry {</p><p>// Methods</p><p> int GetVBandIBSize () raises(MXMGeometryException);</p><p>Boolean GetVBandIB (in Boolean alloc, out String buff) raises(MXMGeometryException);</p><p> integer GetBIFSSize (in String ID) raises(MXMGeometryException);</p><p>Boolean GetBIFS (in Boolean alloc, in String ID, out String buff) raises(MXMGeometryException);</p><p> integer Get3DMCCount () raises(MXMGeometryException);</p><p> integer Get3DMCSize (in String ID) raises(MXMGeometryException);</p><p>Boolean Get3DMC (in Boolean alloc, in String ID out String buff); raises(MXMGeometryException);</p><p>}</p><p>6.7.10.1.1 GetVBandIBSize</p><p>GetVBandIBSize()</p><p>This method returns the size of the decoded vertex buffer and index buffer structure when the geometry is specified in BIFS or in 3DMC.</p><p>Parameters</p><p> none</p><p>Return value</p><p>The return value is an integer specifying the size of the buffer</p><p>Exceptions</p><p>60 © ISO/IEC 2009 — All rights reserved This method may raise the following exceptions.</p><p>MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_SCENE_ERROR.</p><p>6.7.10.1.2 GetVBandIB</p><p>GetVBandIB ()</p><p>This method gives access to the decoded vertex buffer and index buffer structure when the geometry is specified in BIFS or in 3DMC.</p><p>Parameters</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the decoded mesh buffer (vertex buffer and index buffer structure) defined as following:</p><p>MeshBuffer</p><p>{</p><p>Int(4) sizeMeshData;</p><p>Int(1) vbCount;</p><p> for ( 1 .. vbCount )</p><p>VertexBufferDesc();</p><p>}</p><p>VertexBufferDesc</p><p>{</p><p>Int(4) sizeVertexBufferDesc;</p><p>VertexBuffer();</p><p>Int(1) ibCount;</p><p>For ( 1.. ibCount )</p><p>IndexBuffer();</p><p>}</p><p>VertexBuffer</p><p>{</p><p>Int(4) sizeVertexBuffer;</p><p>© ISO/IEC 2009 — All rights reserved 61 ISO/IEC CD 23006-2 Int(4) timestamp; // Frame time in miliseconds</p><p>Int(1) description;</p><p>Int(4) vertexCount;</p><p>For ( 1 .. vertexCount )</p><p>{</p><p>Float(4) x ;</p><p>Float(4) y ;</p><p>Float(4) z ;</p><p>If ( boneWeights )</p><p>{</p><p>Float(4) w0;</p><p>Float(4) w1;</p><p>Float(4) w2;</p><p>Float(4) w3;</p><p>Int(1) boneIndex0;</p><p>Int(1) boneIndex1;</p><p>Int(1) boneIndex2;</p><p>Int(1) boneIndex3;</p><p>}</p><p>},</p><p>Int(4) normalCount;</p><p>For ( 1 .. normalCount)</p><p>{</p><p>Float(4) nx ;</p><p>Float(4) ny ;</p><p>Float(4) nz ;</p><p>}</p><p>Int(4) texCoordCount;</p><p>For ( 1 .. texCoordCount)</p><p>{</p><p>Float(4) u ;</p><p>62 © ISO/IEC 2009 — All rights reserved Float(4) v ;</p><p>}</p><p>}</p><p>} </p><p>IndexBuffer</p><p>{</p><p>Int(4) sizeIndexBuffer;</p><p>Int(4) appearanceID;</p><p>Int(4) coordIndexCount;</p><p>For ( 1 .. coordIndexCount )</p><p>{</p><p>Int(4) index;</p><p>}</p><p>Int(4) texCoordIndexCount;</p><p>For ( 1 .. texCoordIndexCount)</p><p>{</p><p>Int(4) index;</p><p>}</p><p>Int(4) normalIndexCount;</p><p>For ( 1 .. normalIndexCount)</p><p>{</p><p>Int(4) index;</p><p>}</p><p>}</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>© ISO/IEC 2009 — All rights reserved 63 ISO/IEC CD 23006-2 MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_SCENE_ERROR. </p><p>The following methods should be used the geometry is encoded by using the elementary stream 3DMC.</p><p>6.7.10.1.3 Get3DMCSize</p><p>Get3DMCSize ()</p><p>This method returns the size of the BIFS buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the BIFS stream</p><p>Return value</p><p>The return value is an integer specifying the size of the BIFS buffer</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_SCENE_ERROR.</p><p>6.7.10.1.4 Get3DMC</p><p>Get3DMC()</p><p>This method gives access to the encoded BIFS buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the BIFS stream</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the encoded BIFS buffer </p><p>6.7.10.1.5 Get3DMCCount</p><p>Get3DMCCount()</p><p>This method indicates the number of 3DMC tracks in an MP4 file</p><p>Parameters</p><p> none</p><p>64 © ISO/IEC 2009 — All rights reserved Return value</p><p>The return value is an integer specifying the number of 3DMC tracks</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_GEOMETRY_ERROR.</p><p>6.7.10.1.6 Get3DMCSize</p><p>Get3DMCSize ()</p><p>This method returns the size of the 3DMC buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the 3DMC stream</p><p>Return value</p><p>The return value is an integer specifying the size of the 3DMC buffer</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_SCENE_ERROR.</p><p>6.7.10.1.7 Get3DMC</p><p>Get3DMC()</p><p>This method gives access to the encoded 3DMC buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the 3DMC stream</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the encoded 3DMC buffer </p><p>6.7.10.1.8 FreeBuffer</p><p>FreeBuffer()</p><p>© ISO/IEC 2009 — All rights reserved 65 ISO/IEC CD 23006-2 This method frees the memory allocated for the buffer transmitted in the parameter</p><p>Parameters</p><p> buff</p><p>The reference to the buffer to free</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_SCENE_ERROR.</p><p>6.7.10.2 Appearance related API</p><p>The following interface defines the Appearance related API when it is encoded by using the BIFS node "Appearance".</p><p>UML Specifications</p><p>Method syntax for interface MXMAppearance</p><p>+GetAppBufferSize() : Integer</p><p>+GetAppBuffer(alloc : boolean, buff : string) : boolean</p><p>+FreeBuffer() : boolean</p><p>C++ sample code implementation interface MXMAppearance {</p><p>// Methods</p><p> integer GetAppBufferSize () raises(MXMAppearanceException);</p><p>Boolean GetAppBuffer (in Boolean alloc, out String buff) raises(MXMAppearanceException);</p><p> boolean FreeBuffer() raises(MXMAppearanceException);</p><p>};</p><p>6.7.10.2.1 GetAppBufferSize</p><p>GetAppBufferSize ()</p><p>This method returns the size of the decoded appearance buffer structure .</p><p>Parameters</p><p> none</p><p>66 © ISO/IEC 2009 — All rights reserved Return value</p><p>The return value is an integer specifying the size of the buffer</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAppearanceException with NOT_SUPPORTED_ERROR.</p><p>MXMAppearanceException with INVALID_SCENE_ERROR.</p><p>6.7.10.2.2 GetAppBuffer</p><p>GetAppBuffer ()</p><p>This method gives access to the decoded appearance buffer structure.</p><p>Parameters</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the decoded appearance buffer structure defined as following</p><p>AppearanceBuffer</p><p>{</p><p>Int(4) sizeAppearanceData;</p><p>Int(1) appearanceCount;</p><p> for ( 1 .. appearanceCount)</p><p>Appearance();</p><p>}</p><p>Appearance</p><p>{</p><p>Int(4) textureID;</p><p>Int(1) haveMaterial;</p><p>If (haveMaterial = 1 )</p><p>{</p><p>Color diffuseColor;</p><p>Color specularColor;</p><p>© ISO/IEC 2009 — All rights reserved 67 ISO/IEC CD 23006-2 Color emissiveColor;</p><p>Float(4) transparency;</p><p>Float(4) ambientIntensity;</p><p>Float(4) shininess;</p><p>}</p><p>}</p><p>Color</p><p>{</p><p>Float(4) red;</p><p>Float(4) green;</p><p>Float(4) blue;</p><p>}</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAppearanceException with NOT_SUPPORTED_ERROR.</p><p>MXMAppearanceException with INVALID_SCENE_ERROR.</p><p>6.7.10.2.3 Freebuffer</p><p>FreeBuffer()</p><p>This method frees the memory allocated for the buffer transmitted in the parameter. </p><p>Parameters</p><p> buff the reference to the buffer to free</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAppearanceException with NOT_SUPPORTED_ERROR.</p><p>68 © ISO/IEC 2009 — All rights reserved MXMAppearanceException with INVALID_SCENE_ERROR.</p><p>6.7.10.3 Texture-related API</p><p>The following interface defines the Texture (Static Image) related API when. </p><p>UML Specifications</p><p>Method syntax for interface MXMTexture</p><p>+GetTextureCount() : Integer</p><p>+GetTextureSize(ID : string) : Integer</p><p>+GetTexture(alloc : boolean, buff : string, type : textureType) : boolean</p><p>+GetDecodedTexture(alloc : boolean, buff : string) : boolean</p><p>+FreeBuffer() : boolean</p><p>C++ sample code implementation interface MXMTexture {</p><p> integer GetTextureCount () raises(MXMTextureException);</p><p> integer GetTextureSize (in String ID) raises(MXMTextureException);</p><p>Boolean GetTexture (in Boolean alloc, out String buff, out textureType type) raises(MXMTextureException);</p><p>Boolean GetTextureResolution (in String ID, out integer W, out integer H) raises(MXMTextureException);</p><p>Boolean GetDecodedTexture (in Boolean alloc, out String buff) raises(MXMTextureException);</p><p>Boolean FreeBuffer() raises(MXMTextureException);</p><p>};</p><p>6.7.10.3.1 GetTextureCount</p><p>GetTextureCount ()</p><p>This method indicates the number of static image tracks in an MP4 file</p><p>Parameters</p><p> none</p><p>Return value</p><p>The return value is an integer specifying the number of static image tracks</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMTextureException with NOT_SUPPORTED_ERROR.</p><p>© ISO/IEC 2009 — All rights reserved 69 ISO/IEC CD 23006-2 MXMTextureException with INVALID_TEXTURE_ERROR.</p><p>6.7.10.3.2 GetTextureSize</p><p>GetTextureSize ()</p><p>This method returns the size of the encoded texture buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the texture stream</p><p>Return value</p><p>The return value is an integer specifying the size of the texture buffer</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMTextureException with NOT_SUPPORTED_ERROR.</p><p>MXMTextureException with INVALID_TEXTURE_ERROR.</p><p>6.7.10.3.3 GetTexture</p><p>GetTexture()</p><p>This method gives access to the encoded texture buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the texture stream</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the encoded texture buffer </p><p>6.7.10.3.4 GetTextureResolution</p><p>GetTextureResolution()</p><p>This method gives access to the resolution of the static image.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the texture stream</p><p>W</p><p>70 © ISO/IEC 2009 — All rights reserved The width of the image</p><p>H</p><p>The height of the image</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMTextureException with NOT_SUPPORTED_ERROR.</p><p>MXMTextureException with INVALID_TEXTURE_ERROR.</p><p>6.7.10.3.5 GetDecodedTexture</p><p>GetDecodedTexture()</p><p>This method gives access to the decoded image buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the image stream</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the decoded image buffer defined as a vector of RGBA pixels.</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMTextureException with NOT_SUPPORTED_ERROR.</p><p>MXMTextureException with INVALID_TEXTURE_ERROR.</p><p>6.7.10.3.6 FreeBuffer</p><p>FreeBuffer()</p><p>This method frees the memory allocated for the buffer transmitted in the parameter</p><p>Parameters</p><p>© ISO/IEC 2009 — All rights reserved 71 ISO/IEC CD 23006-2 buff</p><p>The reference to the buffer to free</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_SCENE_ERROR.</p><p>6.7.10.4 Animation related API</p><p>The following interface defines the Animation related API when it is encoded by using the elementary stream BBA or FAMC.</p><p>UML Specifications</p><p>Method syntax for interface MXMAnimation</p><p>+GetBBACount() : Integer</p><p>+GetBBASize(ID : string) : Integer</p><p>+GetBBA(alloc : boolean, buff : string) : boolean</p><p>+GetDecodedBBA(alloc : boolean, buff : string) : boolean</p><p>+GetFAMCCount() : Integer</p><p>+GetFAMCSize(ID : string) : Integer</p><p>+GetFAMC(alloc : boolean, buff : string) : boolean</p><p>+GetDecodedFAMC(alloc : boolean, buff : string) : boolean</p><p>+FreeBuffer() : boolean</p><p>Class Diagram</p><p>72 © ISO/IEC 2009 — All rights reserved C++ sample code implementation interface MXMAnimation {</p><p> integer GetBBACount () raises(MXMAnimationException);</p><p> integer GetBBASize (in String ID) raises(MXMAnimationException);</p><p>Boolean GetBBA (in Boolean alloc, out String buff raises(MXMAnimationException);</p><p>Boolean GetDecodedBBA (in Boolean alloc, out String buff) raises(MXMAnimationException);</p><p> integer GetFAMCCount () raises(MXMAnimationException);</p><p> integer GetFAMCSize (in String ID) raises(MXMAnimationException);</p><p>Boolean GetFAMC (in Boolean alloc, out String buff raises(MXMAnimationException);</p><p>Boolean GetDecodedFAMC (in Boolean alloc, out String buff) raises(MXMAnimationException);</p><p>Boolean FreeBuffer () raises(MXMAnimationException);</p><p>};</p><p>6.7.10.4.1 GetBBACount</p><p>GetBBACount ()</p><p>This method indicates the number of BBA tracks in an MP4 file</p><p>Parameters</p><p> none</p><p>Return value</p><p>The return value is an integer specifying the number of BBA tracks</p><p>Exceptions</p><p>© ISO/IEC 2009 — All rights reserved 73 ISO/IEC CD 23006-2 This method may raise the following exceptions.</p><p>MXMAnimationException with NOT_SUPPORTED_ERROR.</p><p>MXMAnimationException with INVALID_ANIMATION_ERROR.</p><p>6.7.10.4.2 GetBBASize</p><p>GetBBASize ()</p><p>This method returns the size of the encoded BBA buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the BBA stream</p><p>Return value</p><p>The return value is an integer specifying the size of the BBA buffer</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAnimationException with NOT_SUPPORTED_ERROR.</p><p>MXMAnimationException with INVALID_ANIMATION_ERROR.</p><p>6.7.10.4.3 GetBBA</p><p>Method GetBBA description</p><p>GetBBA()</p><p>This method gives access to the encoded BBA buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the BBA stream</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the encoded BBA buffer </p><p>74 © ISO/IEC 2009 — All rights reserved 6.7.10.4.4 GetDecodedBBA</p><p>GetDecodedBBA()</p><p>This method gives access to the decoded BBA buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the BBA stream</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the decoded BBA buffer defined as following</p><p>BBABuffer</p><p>{</p><p>Int(4) sizeAnimationBuffer ;</p><p>Int(1) hasHierarchy ;</p><p>If (hasHierarchy)</p><p>Hierarchy h;</p><p>Int(4) NoOfFrames ;</p><p>For (i=1 to NoOfFrames )</p><p>Frame f[i];</p><p>}</p><p>Hierarchy</p><p>{</p><p>Int(4) sizeHierarchy ;</p><p>Int(4) charactersCount;</p><p>For (i=1 to charactersCount )</p><p>Bone rootBone[i];</p><p>}</p><p>Bone</p><p>{</p><p>Int(4) idBone ;</p><p>Int(4) childBonesCount;</p><p>© ISO/IEC 2009 — All rights reserved 75 ISO/IEC CD 23006-2 For (i=1 to childBonesCount )</p><p>Bone Bone[i];</p><p>}</p><p>Frames</p><p>{</p><p>Int(4) size ;</p><p>Int(4) timestamp; // Frame time in miliseconds</p><p>Int(4) boneDataCount;</p><p>For (i=1 to boneDataCountt)</p><p>BoneData bd[i];</p><p>}</p><p>BoneData</p><p>{</p><p>Int(1) boneDataMask//Center,rotation,isQuaternion,Translation,ScaleOrientation,Scale</p><p>For each component in boneDataMask</p><p>Float(4) component;</p><p>}</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAnimationException with NOT_SUPPORTED_ERROR.</p><p>MXMAnimationException with INVALID_ANIMATION_ERROR.</p><p>6.7.10.4.5 GetFAMCCount</p><p>GetFAMCCount ()</p><p>This method indicates the number of FAMC tracks in an MP4 file</p><p>Parameters</p><p> none</p><p>Return value</p><p>76 © ISO/IEC 2009 — All rights reserved The return value is an integer specifying the number of FAMC tracks</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAnimationException with NOT_SUPPORTED_ERROR.</p><p>MXMAnimationException with INVALID_ANIMATION_ERROR.</p><p>6.7.10.4.6 GetFAMCCount</p><p>GetFAMCSize ()</p><p>This method returns the size of the encoded FAMC buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the FAMC stream</p><p>Return value</p><p>The return value is an integer specifying the size of the FAMC buffer</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAnimationException with NOT_SUPPORTED_ERROR.</p><p>MXMAnimationException with INVALID_ANIMATION_ERROR.</p><p>6.7.10.4.7 GetFAMC</p><p>GetFAMC()</p><p>This method gives access to the encoded FAMC buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the FAMC stream</p><p> alloc </p><p>If alloc is true, the buffer is allocated inside the function, If alloc is false, the buffer should be allocated before calling the function</p><p> buff contains the encoded FAMC buffer </p><p>© ISO/IEC 2009 — All rights reserved 77 ISO/IEC CD 23006-2 6.7.10.4.8 GetDecodedFAMC</p><p>GetDecodedFAMC()</p><p>This method gives access to the decoded FAMC buffer.</p><p>Parameters</p><p>ID</p><p> a unique identifier of the FAMC stream</p><p> buff contains the decoded FAMC buffer defined as a vector of VertexBuffer</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMAnimationException with NOT_SUPPORTED_ERROR.</p><p>MXMAnimationException with INVALID_ANIMATION_ERROR.</p><p>6.7.10.4.9 FreeBuffer</p><p>FreeBuffer()</p><p>This method frees the memory allocated for the buffer transmitted in the parameter</p><p>Parameters</p><p> buff</p><p>The reference to the buffer to free</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMGeometryException with NOT_SUPPORTED_ERROR.</p><p>MXMGeometryException with INVALID_SCENE_ERROR.</p><p>78 © ISO/IEC 2009 — All rights reserved 6.7.10.5 Creation</p><p>6.7.10.6 Editing</p><p>6.7.10.7 Decoding</p><p>6.7.10.8 Rendering</p><p>6.8 Image Metadata Engine APIs</p><p>[Editors' note: Split the following text into the sections Creation, Editing, Access, Presentation and Image Metadata Engine-specific methods. Use one table for each method to keep consistency with the rest of the document]</p><p>Creation of MPEG-7 Image Metadata (currently restricted to those used in Photo Player AF)</p><p>UML Specifications</p><p>Method syntax for class Image</p><p>~LoadImage(imageURI : string *) : int</p><p>~LoadImage(buffer : char *) : int</p><p>~EncodeJPEGImage(parameter : char *): int </p><p>Method syntax for class VisualDescriptor</p><p>~Extract(img : Image *) : boolean</p><p>~Distance(desc2 : VisualDescriptor *) : double</p><p>~EncodeXML() : string *</p><p>~DecodeXML(xml : string *) : boolean</p><p>~DecodeBinary(buffer : char *, buflen : int) : boolean</p><p>Class Diagram</p><p>© ISO/IEC 2009 — All rights reserved 79 ISO/IEC CD 23006-2</p><p>C++ sample code implementation</p><p> class Image</p><p>{</p><p>// Image class can contain the following fields string *imageURI; unsigned char *pixels; int width; int height; int bitsPerPixel; // int colorModel; // e.g. RGB</p><p>// functions:</p><p>/** Loads image from the given URI or local file, returns the status of image:</p><p> success, error code*/ int LoadImage(string *imageURI);</p><p>/** Loads images from memory – it can be used by PhotoPlayer to decode jpeg images retrieved from PP MAF file tracks */ int LoadImage(unsigned char *buffer);</p><p>80 © ISO/IEC 2009 — All rights reserved /** Encodes image to jpeg and stores it in memory (buffer),</p><p> this function may be used to add images originally stored in non-jpeg formats</p><p> to Photo Player MAF file */</p><p> int EncodeJPEGImage(unsigned char **buffer); </p><p>}</p><p> class XMLNode</p><p>/* representation of XML element e.g DOM node or string? */</p><p>/* General class for visual still image desciptor */ class VisualDescriptor</p><p>{</p><p>/** Extracts the descriptor from image*/</p><p> bool Extract(Image *img);</p><p>//or bool Extract(string*imageURI);</p><p>/** Computes the distance to the descriptor desc2 of the same type */</p><p> double Distance(VisualDescriptor *desc2);</p><p>/** Encodes XML representation of this descriptor and returns the result*/</p><p> string *EncodeXML ();</p><p>// or XMLNode * EncodeXML ();</p><p>/** Decodes and creates this descriptor from xml representation */</p><p> bool DecodeXML(string*xml);</p><p>// or bool DecodeXML(XMLNode *xml);</p><p>/** Decodes and creates this descriptor from binary representation */</p><p> bool DecodeBinary(char *buffer, int buflen);</p><p>};</p><p>© ISO/IEC 2009 — All rights reserved 81 ISO/IEC CD 23006-2 VisualDescriptor is an abstract class. The following classes are subclasses of VisualDescriptor, they implement the common interface of functions:</p><p> class DominantColorDescriptor:VisualDescriptor; class ScalableColorDescriptor:VisualDescriptor; class ColorStructureDescriptor:VisualDescriptor; class ColorLayoutDescriptor:VisualDescriptor; class HomogeneousTextureDescriptor:VisualDescriptor; class TextureBrowsingDescriptor:VisualDescriptor; class EdgeHistogramDescriptor:VisualDescriptor; class RegionShapeDescriptor:VisualDescriptor; class ContourShapeDescriptor:VisualDescriptor; class ImageSignature:VisualDescriptor;</p><p>6.8.1 Image Metadata Creation</p><p>6.8.2 Image Metadata Editing</p><p>6.8.3 Image Metadata Access</p><p>6.8.4 Image Metadata Presentation</p><p>6.9 Audio Metadata Engine APIs</p><p>6.9.1 Audio Metadata Creation</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setDuration (time:String):void</p><p>Java sample code public interface MetadataInterface { public void setDuration (String time); } Method description</p><p>This method is used to set the duration time of a video.</p><p>Parameters time the duration of the video.</p><p>Return value</p><p>82 © ISO/IEC 2009 — All rights reserved void</p><p>Exceptions</p><p>6.9.2 Audio Metadata Editing</p><p>6.9.3 Audio Metadata Access</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getDuration ():String</p><p>Java sample code public interface MetadataInterface { public String getDuration (); } Method description</p><p>This method is used to get the duration time of an audio track.</p><p>Parameters</p><p>Return value</p><p>String, if exists a duration time, return the date else return null.</p><p>Exceptions</p><p>6.9.4 Audio Metadata Presentation</p><p>6.10 Video Metadata Engine APIs</p><p>6.10.1 Video Metadata Creation</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setDuration (time:String):void</p><p>Java sample code public interface MetadataInterface {</p><p>© ISO/IEC 2009 — All rights reserved 83 ISO/IEC CD 23006-2 public void setDuration (String time); } Method description</p><p>This method is used to set the duration time of a video.</p><p>Parameters time the duration of the video.</p><p>Return value void</p><p>Exceptions</p><p>6.10.2 Video Metadata Editing</p><p>6.10.3 Video Metadata Access</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getDuration ():String</p><p>Java sample code public interface MetadataInterface { public String getDuration (); } Method description</p><p>This method is used to get the duration time of a video.</p><p>Parameters</p><p>Return value</p><p>String, if exists a duration time, return the date else return null.</p><p>Exceptions</p><p>84 © ISO/IEC 2009 — All rights reserved 6.10.4 Video Metadata Presentation</p><p>6.11 Content Metadata Engine APIs</p><p>6.11.1 Content Metadata Creation</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setID (ID:String):void</p><p>Java sample code public interface MetadataInterface { public void setID (String ID); } Method description</p><p>This method is used to set the identification of a content.</p><p>Parameters</p><p>ID the identifier of the content.</p><p>Return value void</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setTitle (title:String):void</p><p>Java sample code public interface MetadataInterface { public void setTitle (String title); } Method description</p><p>This method is used to set the title of a content.</p><p>Parameters title the title of the content.</p><p>Return value void</p><p>Exceptions</p><p>© ISO/IEC 2009 — All rights reserved 85 ISO/IEC CD 23006-2</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setAuthor (author:String):void</p><p>Java sample code public interface MetadataInterface { public void setAuthor (String author); } Method description</p><p>This method is used to set the author of a content.</p><p>Parameters author the author of the content.</p><p>Return value void</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setAbstract (abstract:String):void</p><p>Java sample code public interface MetadataInterface { public void setAbstract (String abstract); } Method description</p><p>This method is used to set the content abstract.</p><p>Parameters abstract the abstract of the content.</p><p>Return value void</p><p>Exceptions</p><p>86 © ISO/IEC 2009 — All rights reserved Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setMimeType (mimeType:String):void</p><p>Java sample code public interface MetadataInterface { public void setMimeType (String mimeType); } Method description</p><p>This method is used to set the mime type of a content.</p><p>Parameters mimeType the mime type of the content.</p><p>Return value void</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setContributor (contributor:String):void</p><p>Java sample code public interface MetadataInterface { public void setContributor (String contributor); } Method description</p><p>This method is used to set the contributor to the creation of a content item.</p><p>Parameters creator the creator of the content.</p><p>Return value void</p><p>Exceptions</p><p>© ISO/IEC 2009 — All rights reserved 87 ISO/IEC CD 23006-2 Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setGenre (genre:String):void</p><p>Java sample code public interface MetadataInterface { public void setGenre (String genre); } Method description</p><p>This method is used to set the genre of a content.</p><p>Parameters genre the genre of the content.</p><p>Return value void</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setCopyRight (copyright:String):void</p><p>Java sample code public interface MetadataInterface { public void setCopyRight (String copyright); } Method description</p><p>This method is used to set the copyright of a content.</p><p>Parameters copyright the copyright of the content.</p><p>Return value void</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>88 © ISO/IEC 2009 — All rights reserved + setCreationDate (date:String):void</p><p>Java sample code public interface MetadataInterface { public void setCreationDate (String date); } Method description</p><p>This method is used to set the creation date of a content.</p><p>Parameters date the date of the content.</p><p>Return value void</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ setThumbnail (thumbnail:String):void</p><p>Java sample code public interface MetadataInterface { public void setThumbnail (String thumbnail); } Method description</p><p>This method is used to set the thumbnail image of a content item.</p><p>Parameters thumbnail the thumbnail image of the content item.</p><p>Return value void</p><p>Exceptions</p><p>6.11.2 Content Metadata Editing</p><p>6.11.3 Content Metadata Access</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>© ISO/IEC 2009 — All rights reserved 89 ISO/IEC CD 23006-2 Method Syntax</p><p>+ getID ():String</p><p>Java sample code public interface MetadataInterface { public String getID (); } Method description</p><p>This method is used to get the ID of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a identification, return the identification else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getTitle ():String</p><p>Java sample code public interface MetadataInterface { public String getTitle (); } Method description</p><p>This method is used to get the title of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a title, return the title else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>90 © ISO/IEC 2009 — All rights reserved + getAuthor ():String</p><p>Java sample code public interface MetadataInterface { public String getAuthor (); } Method description</p><p>This method is used to get the author of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists an author, return the author else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getDescripition ():String</p><p>Java sample code public interface MetadataInterface { public String getDescripition (); } Method description</p><p>This method is used to get the abstract of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists an abstraction, return the abstract else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getMimeType ():String</p><p>© ISO/IEC 2009 — All rights reserved 91 ISO/IEC CD 23006-2 Java sample code public interface MetadataInterface { public String getMimeType (); } Method description</p><p>This method is used to get the mime type of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a mime type, return the mime type else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getContributor ():String</p><p>Java sample code public interface MetadataInterface { public String getContributor (); } Method description</p><p>This method is used to get the contributor of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a creator, return the contributor else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getGenre ():String</p><p>Java sample code public interface MetadataInterface { public String getGenre ();</p><p>92 © ISO/IEC 2009 — All rights reserved } Method description</p><p>This method is used to get the genre of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a genre, return the genre else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getCopyRight ():String</p><p>Java sample code public interface MetadataInterface { public String getCopyRight (); } Method description</p><p>This method is used to get the copyright of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a copyright, return the copyright else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getDate ():String</p><p>Java sample code public interface MetadataInterface { public String getDate (); } Method description</p><p>© ISO/IEC 2009 — All rights reserved 93 ISO/IEC CD 23006-2 This method is used to get the creation date of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a creation date, return the date else return null.</p><p>Exceptions</p><p>Interface MetadataInterface (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getThumbnail ():String</p><p>Java sample code public interface MetadataInterface { public String getThumbnail (); } Method description</p><p>This method is used to get the thumbnail information of a content item.</p><p>Parameters</p><p>Return value</p><p>String, if exists a thumbnail information, return the date else return null.</p><p>Exceptions</p><p>94 © ISO/IEC 2009 — All rights reserved 6.11.4 Content Metadata Presentation</p><p>6.12 Digital Item Streaming Engine APIs</p><p>6.12.1 Digital Item Streaming Creation</p><p>6.12.2 Digital Item Streaming Editing</p><p>6.12.3 Digital Item Streaming Access</p><p>6.13 Digital Item Adaptation Engine APIs</p><p>6.13.1 Usage Environment Description Creation</p><p>UML Specifications</p><p>Method syntax for interface MXMUseEnvDesc</p><p>~setUseEnvDescr(namespaceURI : string, ued : string) : boolean</p><p>Attribute syntax for class MXMDesrException</p><p>ACCESS_VIOLATION_ERROR : short const = 1</p><p>NOT_SUPPORTED_ERROR : short const = 2</p><p>INVALID_DESCRIPTION_ERROR const = 3</p><p>Class Diagram</p><p>Java sample code implementation for interface MXMUseEnvDescr interface MXMUseEnvDescr {</p><p>// Methods boolean setUseEnvDescr(String namespaceURI, String ued) throws MXMDescrException;</p><p>String parseUseEnvDescr(String namespaceURI) throws MXMDescrException;</p><p>}</p><p>Method setUseEnvDescr description </p><p>© ISO/IEC 2009 — All rights reserved 95 ISO/IEC CD 23006-2 This method is used to set the usage environment description (ued) identified by the namespace namespaceURI. The ued shall provide a description of the usage environment where the resource is consumed.</p><p>Parameters</p><p> namespaceURI</p><p>The namespaceURI parameter is a String containing the URI of the namespace identifying the usage environment description.</p><p> ued</p><p>The ued parameter is a String containing the usage environment description.</p><p>Return value</p><p>The return value is true if the operation was successful, otherwise false is returned.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMDescrException with NOT_SUPPORTED_ERROR.</p><p>MXMDescrException with INVALID_DESCRIPTION_ERROR.</p><p>6.13.2 Digital Item Adaptation Editing</p><p>6.13.3 Digital Item Adaptation Access</p><p>Method parseUseEnvDescr description </p><p>This method is used to parse a usage environment description identified by the namespace namespaceURI. The return value shall provide a description of the usage environment where the resource is consumed.</p><p>Parameters</p><p> namespaceURI</p><p>The namespaceURI parameter is a String containing the URI of the namespace identifying the usage environment description.</p><p>Return value</p><p>The return value is a String containing the usage environment description (ued) identified by the namespace namespaceURI. The ued shall provide a description of the usage environment where the resource is consumed.</p><p>Exceptions</p><p>This method may raise the following exceptions.</p><p>MXMDescrException with NOT_SUPPORTED_ERROR.</p><p>MXMDescrException with INVALID_DESCRIPTION_ERROR.</p><p>Java sample code implementation for class MXMDescrException public class MXMDescrException extends Exception </p><p>96 © ISO/IEC 2009 — All rights reserved { public static final short ACCESS_VIOLATION_ERROR = 1; public static final short NOT_SUPPORTED_ERROR =2; public static final short INVALID_DESCRIPTION_ERROR = 3;</p><p>}</p><p>C++ sample code implementation for class MXMDescrException exception {</p><p> unsigned short code;</p><p>};</p><p>// Exception codes const unsigned short ACCESS_VIOLATION_ERROR = 1; const unsigned short NOT_SUPPORTED_ERROR = 2; const unsigned short INVALID_DESCRIPTION_ERROR = 3;</p><p>Class MXMDescrException description </p><p>ACCESS_VIOLATION_ERROR</p><p>This exception is raised if an implementation of MXM, that supports access control, detects an illegal attempt to access the delivery context.</p><p>NOT_SUPPORTED_ERROR</p><p>This exception is raised if a call is made to a method which is not supported by MXM description API.</p><p>INVALID_DESCRIPTION_ERROR </p><p>This exception is raised if a description is not valid within the given namespace.</p><p>6.14 Digital Item Processing Engine APIs</p><p>6.14.1 Digital Item Processing Creation</p><p>6.14.2 Digital Item Processing Access</p><p>6.15 Event Reporting Engine APIs</p><p>6.15.1 Event Report Request Creation</p><p>6.16 Event Report Request Creation</p><p>6.16.1 Method to generate an ISO/IEC 21000-15 conformant Event Report Request.</p><p>Interface ContentBuilder1</p><p>© ISO/IEC 2009 — All rights reserved 97 ISO/IEC CD 23006-2</p><p>Method Syntax</p><p>+ createERR(modificationUserID: String, modificationPeerID: String, errDescription: String, ERSDII: String, ERSDescription: String, ERSPayloadPeerId:boolean, ERSPayloadUserId:boolean, ERSPayloadTime:boolean, ERSPayloadLocation:boolean, ERSPayloadDIOperation:Boolean, ERSPayloadDomainDataReportTag:String [], ERSPayloadDomainDatsemantics:String [], ERSPayloadDomainDataSyntax:String [], ERSPayloadDomainDataValue:String [], ERSPayloadDIMetadata: String [], ERSFormatSRef:String, ERSFormatSSchema:String, ERSFormatSMimeType:String, ERSDeliveryUser:String, ERSEmbeddedERRorERRReference:String, ERisERRackFullEmbedded:boolean, EVCOperations:String [], EVCDII: String []):String</p><p>Java sample code public interface ContentBuilder { public String createERR(String modificationUserID, String modificationPeerID, String errDescription, String ERSDII, String ERSDescription, boolean ERSPayloadPeerId, boolean ERSPayloadUserId, boolean ERSPayloadTime, boolean ERSPayloadLocation, boolean ERSPayloadDIOperation, String [] ERSPayloadDomainDataReportTag, String [] ERSPayloadDomainDatsemantics, String [] ERSPayloadDomainDataSyntax, String [] ERSPayloadDomainDataValue, String [] ERSPayloadDIMetadata, String ERSFormatSRef, String ERSFormatSSchema, String ERSFormatSMimeType, String ERSDeliveryUser, String ERSEmbeddedERRorERRReference,boolean ERisERRackFullEmbedded, String [] EVCOperations, String [] EVCDII) throws ERRGenerationException } Method description</p><p>This method is used to generate an Event Report Request conformant to ISO/IEC 21000-15. It generates an ERR according to the terms stated by the creator or distributor of the digital content. An ERR will contain information about the Digital Item, the resource, and the conditions under which the event will occur. Once created, it is associated to a Digital Item.</p><p>Parameters modificationUserID ERRDescriptor Modification field. The User that is modifying the ERR. modificationPeerID ERRDescriptor Modification field. The Peer that is modifying the ERR. errDescription ERRDescriptor Modification field. A description for the ERR.</p><p>ERSDII ERSpecification field.</p><p>ERSDescription ERSpecification field.</p><p>ERSPayloadPeerId ERPayloadSpecification field.</p><p>ERSPayloadUserId ERPayloadSpecification field.</p><p>ERSPayloadTime ERPayloadSpecification field.</p><p>ERSPayloadLocation ERPayloadSpecification field.</p><p>ERSPayloadDIOperation ERPayloadSpecification field.</p><p>ERSPayloadDomainDataReportTag ERPayloadSpecification DomainData field. Domain</p><p>1 The ContentBuilder, although understood from its Chillout reference, needs a description in MXM.</p><p>98 © ISO/IEC 2009 — All rights reserved metadata tag name to be reported (e.g. “LicenseIdentifier”).</p><p>ERSPayloadDomainDataSemantics ERPayloadSpecification DomainData field. Domain metadata tag semantics (e.g. “Identifier of the license used for the authorisation”).</p><p>ERSPayloadDomainDataSyntax ERPayloadSpecification DomainData field. Domain metadata tag syntax (e.g. “xsd: string”).</p><p>ERSPayloadDomainDataValue ERPayloadSpecification DomainData field. Domain metadata tag value (e.g. “LID:44t7r665:12fq35:513t554”).</p><p>ERSPayloadDIMetadata ERPayloadSpecification information for the DIMetadata field. Array containing the names of the DI metadata fields to be reported (e.g. "abstract", "title", "alternative", "creator", "creator", "identifier", "date").</p><p>ERSFormatSRef ERFormatSpecification field.</p><p>ERSFormatSSchema ERFormatSpecification field.</p><p>ERSFormatSMimeType ERFormatSpecification field.</p><p>ERSDeliveryUser ERDeliverySpecification Recipient field.</p><p>ERSDeliveryPeer ERDeliverySpecification Recipient field.</p><p>ERSDeliveryTime. ERDeliverySpecification field.</p><p>ERSDeliveryTransportService. ERDeliverySpecification field.</p><p>ERSEmbeddedERRorERRReference ERR or ERRReference to be placed in the EmbeddedERR field.</p><p>ERisERRackFullEmbedded Indicates if the previous ERSEmbeddedERRorERRReference parameter is of type ERR (true) or a ERRReference (false).</p><p>EVCOperations Array containing the ordered chain of operations that, if executed, will trigger the generation of the ER. They will be included in different DIOperationEvent elements.</p><p>EVCDII The Digital Item Identifier of the DI over which the previous operations apply, to be included in order in the previous DIOperationEvent elements.</p><p>Return value</p><p>ERRequest: an Event Report Request conformant to ISO/IEC 21000-15 containing information about the Digital Item, the resource, and the conditions under which the event will occur. </p><p>Exceptions</p><p>ERRGenerationException This exception is thrown if an error occurred while instantiating the classes</p><p>© ISO/IEC 2009 — All rights reserved 99 ISO/IEC CD 23006-2 involved in the creation of XML data.</p><p>6.17 Event Report Creation</p><p>6.17.1 Method to generate an ISO/IEC 21000-15 conformant Event Report. </p><p>Interface ContentBuilder</p><p>Method Syntax</p><p>+ createER (ERR:String, AppID: String, userID:String, peerID:String, DIOperation:String, DII:String, DIImetaName:String [], DIImetaValue:String [], DIIMetaSchema:String [], ERdescription:String, embedERR:boolean, ERRelatedDII:String, ERUserCountry:String, ERUserRegion:String, ERTime:String, DomainDataName:String[], DomainDataValue:String[], DomainDataSchema: String[], ERRReference:String):String</p><p>Java sample code public interface ContentBuilder { public String createER (String ERR, String AppID, String userID, String peerID, String DIOperation, String DII, String [] DIImetaName, String [] DIImetaValue, String [] DIIMetaSchema, String ERdescription, boolean embedERR, String ERRelatedDII, String ERUserCountry, String ERUserRegion, String ERTime, String [] DomainDataName, String[] DomainDataValue, String[] DomainDataSchema, String ERRReference) throws ERGenerationException } Method description</p><p>This method is used to generate an Event Report conformant to ISO/IEC 21000-15. It decides whether an ER needs to be created according to an ERR and some input information regarding content usage. If necessary, it generates and returns the corresponding ER. It receives as inputs a single ERR, the identification of the user, the operation that this user has performed, the time when the operation has been performed, the Digital Item identifier and the Peer identifier, amongst others. The ER generated contains information about the Digital Item, or the digital resource, and the conditions under which the event has succeeded.</p><p>Parameters</p><p>ERR Event Report Request that triggers the generation of the Event Report.</p><p>AppID Application Identifier (for the case when there is no input ERR). userID The identifier of the user that performs the action to be reported. peerID The identifier of the peer that performs the action.</p><p>DIOperation The action performed over the Digital Item or resource.</p><p>DII The Digital Item Identifier.</p><p>DIImetaName These three arrays must have the same length, and contain the key, value and schema triples that refer to any metadata in the DI DIImetaValue that needs to be reported. Those metadata elements must be those specified in the ERR, if present. DIIMetaSchema</p><p>ERdescription Textual description for the Event Report.</p><p>100 © ISO/IEC 2009 — All rights reserved embedERR Boolean indicating the originating ERR is to be included in the <ERR> field in the resulting ER (only applicable if the input ERR is not null).</p><p>ERRelatedDII Related Digital Item Identifier.</p><p>ERUserCountry Contextual information for the user.</p><p>ERUserRegion Contextual information for the user.</p><p>ERTime Time when action was performed, expressed in XMLGregorian format.</p><p>DomainDataName These three arrays must have the same length, and contain the key, value and schema triples that refer to any domain data that DomainDataValue needs to be reported. Those metadata elements must be those specified in the ERR, if present. DomainDataSchema</p><p>ERRReference If not null, it contains an URI to be included as the <ERRReference> field in the ER.</p><p>Return value</p><p>ER: an Event Report conformant to ISO/IEC 21000-15 </p><p>Exceptions</p><p>ERRGenerationException This exception is thrown if an error occurred while instantiating the classes involved in the creation of XML data.</p><p>6.18 Event Report Request Access</p><p>6.18.1 Method to obtain form a Digital Item all the Event Report Requests within it. </p><p>An instance of DCIParser (see Error: Reference source not found) has to be created and initialised by requesting the DCIParser to parse the Digital Item.</p><p>This method should perhaps go in 6.1.3, Digital Item Access (N10291).</p><p>Interface DCIParser</p><p>Method Syntax</p><p>+ getArrayOfERRs (): String[]</p><p>Java sample code public interface DCIParser { public String[] getArrayOfERRs(); } Method description</p><p>This method is used to obtain all the ERRs within A Digital Item. This method supposes that an object of type DCIParser has been instantiated and requested to parse the Digital Item containing one or more Event Report</p><p>© ISO/IEC 2009 — All rights reserved 101 ISO/IEC CD 23006-2 Requests.</p><p>Parameters</p><p>Return value</p><p>An array containing all the Event Report Requests found in the Digital Item. </p><p>Exceptions</p><p>6.18.2 Method is used to obtain Event Report Request fields from and ERR conformant to ISO/IEC 21000-15. </p><p>The extracted information will be used to determine if ERs shall be generated, and delivery options (user and/or peer to which the ER shall be sent, transport service, time of delivery, etc.).</p><p>Interface ContentBuilder</p><p>Method Syntax</p><p>+ getERRData(ERR: String):String[]</p><p>Java sample code public interface ContentBuilder { public String[] getERRDatta(String ERR) } Method description</p><p>This method is used to obtain Event Report Request fields from and ERR conformant to ISO/IEC 21000-15. The extracted information will be used to determine if ERs shall be generated, and delivery options (user and/or peer to which the ER shall be sent, transport service, time of delivery, etc.).</p><p>Parameters</p><p>ERR Event Report Request conformant to ISO/IEC 21000- 15</p><p>Return value</p><p>String[]: The different elements within the Event Report Request.</p><p>Exceptions</p><p>6.18.3 Event Registration</p><p>[Input from Eva :-)]</p><p>102 © ISO/IEC 2009 — All rights reserved 6.18.4 Event Report Transmission</p><p>[Input from Eva :-)]</p><p>6.19 Content Protocol Engine APIs</p><p>6.19.1 Content Identification Protocol</p><p>Content Identification is the process by which the hash value of a Digital Item (DCI) is persistently registered by a service (the Content Identification Device, CID) and bound to a globally unique identifier inserted in the Digital Item before the hash value was calculated. MXM provides two methods to identify a new content item: a) by sending the DCI to the CID and requesting that the hash calculation is made by the CID b) by:</p><p>1) requesting an identifier to the CID</p><p>2) inserting it in the new DCI</p><p>3) calculating the hash value or digital signature of the resulting DCI</p><p>4) sending the hash value to the CID together with the identifier obtained in 2.a requesting the new record to be registered.</p><p>6.19.1.1 Identify Content Item</p><p>6.19.1.1.1 Content Identification by sending the DCI</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ identifyContent (dci:DIDL, cidServiceURL:String):DIDL</p><p>Java sample code public interface ContentBuilder{ public DIDL identifyContent (DIDL dci, String cidServiceURL) throws ContentIdentificationException, MalformedContentElementException, DCIParsingException; } Method description</p><p>This method is used to identify a Digital Item (DCI) by sending it to the Content Identification Device. The Content Identification Device generates a new identifier, inserts it in the DCI as specified in ISO/IEC 23000- 5, generates a hash value of the DCI file and finally inserts the hash/digital signature value in the DCI as specified in ISO/IEC 23000-5. If these operations are performed successfully, the DCI containing these modifications is returned to the requesting application.</p><p>Parameters dci The Digital Item to be identified (see Error: Reference source not found for more information on the DIDL interface). cidServiceURL The URL of the service to be invoked in order to request an identifier for the new resource.</p><p>Return value</p><p>The Digital Item (see Error: Reference source not found for more information on the DIDL interface) containing the content identifier and the hash/digital signature value if the operation was performed</p><p>© ISO/IEC 2009 — All rights reserved 103 ISO/IEC CD 23006-2 successfully, null otherwise.</p><p>Exceptions</p><p>ContentIdentificationException (see Error: This exception is thrown if an error occurred while creating the Reference source not found) message to request the new identifier, or if the cidURL input parameter is malformed.</p><p>MalformedContentElementException (see This exception is thrown if the Digital Item given in input is Error: Reference source not found) corrupted, malformed or it already contains a content identifier.</p><p>DCIParsingException (see Error: This exception is thrown if the DCI returned from the Content Reference source not found) Identification service was corrupted.</p><p>6.19.1.1.2 Content Identification by sending the DCI hash</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ identifyContent (dci:DIDL, digestAlgonameJCA:String, digestAlgonameW3C, cidServiceURL:String):DIDL</p><p>Java sample code public interface ContentBuilder{ public DIDL identifyContent (DIDL tempDCI, String digestAlgonameJCA, String digestAlgonameW3C, String cidServiceURL) throws ContentIdentificationException, MalformedContentElementException, UnsupportedFeatureException; } Method description</p><p>This method is used to identify a Digital Item (DCI) by sending to the Content Identification Device its hash value. Before the hash value is calculated, a content identifier will be requested to the specified content identification service and inserted in the DCI. The Content Identification Device, upon receiving the hash value and the identifier from the client application stores the two values persistently. If these operations are performed successfully, the DCI containing these modifications is returned to the requesting application.</p><p>Parameters dci The Digital Item to be identified (see Error: Reference source not found for more information on the DIDL interface). digestAlgonameJCA The name of the hash algorithm as known by the platform on which the algorithm runs digestAlgonameW3C The name of the hash algorithm as specified in Error: Reference source not found cidServiceURL The URL of the service to be invoked in order to request an identifier for the new resource.</p><p>Return value</p><p>The Digital Item (see Error: Reference source not found for more information on the DIDL interface) containing the content identifier and the hash/digital signature value if the operation was performed successfully, null otherwise.</p><p>Exceptions</p><p>104 © ISO/IEC 2009 — All rights reserved ContentIdentificationException (see Error: This exception is thrown if an error occurred while creating the Reference source not found) message to request the new identifier, or if the cidURL input parameter is malformed.</p><p>MalformedContentElementException (see This exception is thrown if the Digital Item given in input is Error: Reference source not found) corrupted, malformed or it already contains a content identifier.</p><p>UnsupportedFeatureException (see Error: This exception is thrown if the specified digest algorithm was Reference source not found) not supported by MXM.</p><p>6.19.1.2 Identify Content Element</p><p>6.19.1.2.1 Resource identification with file in input</p><p>Interface IdentifyResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ identifyResource (resourceFile:File, digestAlgonameJCA:String, digestAlgonameW3C:String, cidServiceURL:String):String</p><p>Java sample code public interface IdentifyResourceManager{ public RequestIdentifierResponse identifyResource(File resourceFile, String digestAlgonameJCA, String digestAlgonameW3C, String cidServiceURL) throws ContentIdentificationException, AxisFault, ServiceException, IOException, UnsupportedFeatureException; } Method description</p><p>This method is used to identify a resource stored in a file. MXM generates a hash value of the resource using the specified algorithm and request an identifier to the specified service. The hash value of the resource is sent to the Content Identification service so that the issued content identifier and the resource hash will be stored persistently on the Content Identification service.</p><p>Parameters resourceFile The resource file to be identified. digestAlgonameJCA The name of the hash algorithm as known by the platform on which the algorithm runs digestAlgonameW3C The name of the hash algorithm as specified in Error: Reference source not found cidServiceURL The URL of the service to be invoked in order to request an identifier for the new resource.</p><p>Return value</p><p>The resource identifier if the resource was successfully identified, false otherwise.</p><p>Exceptions</p><p>ContentIdentificationException (see Error: This exception is thrown if an error occurred while creating the Reference source not found) message to request the new identifier, or if the cidURL input</p><p>© ISO/IEC 2009 — All rights reserved 105 ISO/IEC CD 23006-2 parameter is malformed.</p><p>UnsupportedFeatureException (see Error: This exception is thrown if the information contained in the Reference source not found) ProtectedContentElement object given in input was not supported by MXM (e.g. hash algorithm not supported).</p><p>IOException (see Error: Reference source This exception is thrown if problems were detected while not found) calculating the hash value of the resource file.</p><p>ServiceException (see Error: Reference This exception is thrown if an error occurred while source not found) communicating with the content identification service.</p><p>AxisFault (see Error: Reference source This exception is thrown if the service to be invoked is not found) unreachable.</p><p>6.19.1.2.2 Resource identification with hash in input</p><p>Interface IdentifyResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ identifyResource (resourceHash:Signature, cidServiceURL:String):String</p><p>Java sample code public interface IdentifyResourceManager{ public RequestIdentifierResponse identifyResource(Signature resourceHash, String cidServiceURL) throws ContentIdentificationException, ServiceException, AxisFault, IOException; } Method description</p><p>This method is used to identify a resource whose hash is specified in input. The hash value of the resource is sent to the Content Identification service so that the issued content identifier and the resource hash will be stored persistently on the Content Identification service.</p><p>Parameters resourceHash The hash value of the resource whose identifier is sought. See the Signature interface (Error: Reference source not found) for more information. cidServiceURL The URL of the service to be invoked in order to request an identifier for the new resource.</p><p>Return value</p><p>The resource identifier if the resource was successfully identified, false otherwise.</p><p>Exceptions</p><p>ContentIdentificationException (see Error: This exception is thrown if an error occurred while Reference source not found) creating the message to request the new identifier, or if the cidURL input parameter is malformed.</p><p>IOException (see Error: Reference source not This exception is thrown if problems were detected while found) calculating the hash value of the resource file.</p><p>106 © ISO/IEC 2009 — All rights reserved ServiceException (see Error: Reference source This exception is thrown if an error occurred while not found) communicating with the content identification service.</p><p>AxisFault (see Error: Reference source not This exception is thrown if the service to be invoked is found) unreachable.</p><p>6.19.2 Content Authentication Protocol</p><p>These methods are used to verify that the hash value of a content item and/or any of its conrtent elements are authentic, i.e. the same values registered when the content item or content element were identified.</p><p>6.19.2.1 Authenticate Content Item</p><p>Interface ContentIdentificationManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ authenticateContent (didl : DIDL, cidServiceURL : string, contentAuthenticationType : string) : ContentIdentificationResult</p><p>Java sample code public interface ContentIdentificationManager { public ContentIdentificationResult authenticateContent (DIDL didl, String cidServiceURL, string contentAuthenticationType) throws ContentAuthenticationException, MalformedContentElementException ; } Method description</p><p>This method is used to authenticate a content item (DCI). Content authentication can be performed </p><p>1. by calculating the hash value of the digital item and a. sending it to the Content Identification Device to be compared with the one stored in conjunction with the content ID b. requesting to the Content Identification Device the stored hash value in order to compare the two values 2. by sending the whole Digital Item to the Content Identification Device and letting the Content Identification Device to compare the stored value with the one calculated on the submitted DCI. Parameters didl The Digital Item to be authenticated (see Error: Reference source not found for more information on the DIDL interface). cidServiceURL The URL of the service to be invoked in order to authenticate the content item in the three modalities contentAuthenticationType a string with the name of one of the three types of content authentication available</p><p>Return value</p><p>An object or type ContentIdentificationResult (see Error: Reference source not found) containing either a true result or the reason of authentication failure.</p><p>Exceptions</p><p>ContentAuthenticationException (see This exception is thrown if an error occurred while creating the Error: Reference source not found) request message for the Content Identification Device, or if the</p><p>© ISO/IEC 2009 — All rights reserved 107 ISO/IEC CD 23006-2 cidServiceURL input parameter is malformed.</p><p>MalformedContentElementException (see This exception is thrown if the Digital Item given in input is Error: Reference source not found) corrupted or malformed.</p><p>6.19.2.2 Authenticate Content Element</p><p>Interface ContentIdentificationManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ authenticateContent (didl : DIDL, contentElementID : string, cidServiceURL : string, contentAuthenticationType : string) : ContentIdentificationResult</p><p>Java sample code public interface ContentIdentificationManager { public ContentIdentificationResult authenticateContent (DIDL didl, String contentElementID, String cidServiceURL, string contentAuthenticationType) throws ContentAuthenticationException, MalformedContentElementException ; } Method description</p><p>This method is used to authenticate a content item (DCI). Content authentication can be performed by calculating the hash value of the content element and </p><p>1. sending it to the Content Identification Device to be compared with the one stored in conjunction with the content ID 2. requesting to the Content Identification Device the stored hash value in order to compare the two values Parameters didl The Digital Item to be authenticated (see Error: Reference source not found for more information on the DIDL interface). contentElementID The identifier of the content element within the content item requiring authentication. cidServiceURL The URL of the service to be invoked in order to authenticate the content element in the two modalities contentAuthenticationType a string with the name of one of the two types of content element authentication available</p><p>Return value</p><p>An object or type ContentIdentificationResult (see Error: Reference source not found) containing either a true result or the reason of authentication failure.</p><p>Exceptions</p><p>ContentAuthenticationException (see This exception is thrown if an error occurred while creating the Error: Reference source not found) request message for the Content Identification Device, or if the cidServiceURL input parameter is malformed.</p><p>MalformedContentElementException (see This exception is thrown if the Digital Item given in input is Error: Reference source not found) corrupted or malformed.</p><p>108 © ISO/IEC 2009 — All rights reserved 6.19.3 Content Access Protocol</p><p>6.19.3.1 AccessContentElement</p><p>In order to request time-dependent information related to a Content Element (e.g. a streaming resource, streaming metadata, etc.), the following method is employed:</p><p>Interface RemoteContentElementManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ accessContentElement (contentID : string, contentElementID : string, cpdServiceURL : string, transactionID : string): void</p><p>Java sample code public interface RemoteContentElementManager { public void accessContentElement(String contentID, String contentElementID, String cpdServiceURL, String transactionID) throws AccessContentException, UnsupportedFeatureException ; } Method description</p><p>This method is used to request time-dependent information related to a content element identified by a content element ID and part of a content item identified by a content ID from a remote service (i.e. the Content provider Device). The request to the service is made according to the Request Content protocol specified in ISO/IEC 29116-1. If the protocol is successfully carried out, URLs from where the time-dependent parts of the content item can be retrieved will be returned and accessed directly by MXM which will display any audiovisual resource using the specified MediaFramework. Applications calling the method accessContentElement may listen to events of type ContentResponseEvent by implementing the callback method specified at the bottom of this table.</p><p>Parameters contentID The identifier of the content item to which the requested content element belongs to contentElementID The identifier of the requested content element cpdServiceURL The URL of the remote service to which content is requested transactionID The identifier of the message to be used in the request.</p><p>Return value</p><p>Exceptions</p><p>AccessContentException This exception is thrown if an error occurs while the Request Content protocol is being carried out</p><p>UnsupportedFeatureException This exception is thrown if MXM doesn’t know how to deal with the content received from the remote service.</p><p>Callback Interface</p><p>RequestContentResponseListener (see Error: Reference source not found)</p><p>Callback Method</p><p>+ public void handleRequestContentResponseEvent(event ContentResponseEvent) : void</p><p>© ISO/IEC 2009 — All rights reserved 109 ISO/IEC CD 23006-2</p><p>6.19.4 Content Storage Protocol</p><p>Content created by a Content Creation application may be stored on a remote location (e.g. a Content Provider Device) by invoking the methods specified below:</p><p>6.19.4.1 Store a DCF</p><p>Interface ContentUploader (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ uploadDCF (contentInfoType: ContentInfoType, dcfFile : File, transactionID : string) : void</p><p>Java sample code public interface ContentUploader { public boolean uploadDCF(ContentInfoType contentInfoType, File dcfFile, String transactionID) throws StoreContentException, UnsupportedFeatureException, BadPropertyException ; } Method description</p><p>This method is used to upload an ISO/IEC 21000-9 file to a remote location. </p><p>Parameters contentInfoType An object of type ContentInfoType (see Error: Reference source not found) containing a set of information needed to create the message to request content to be uploaded dcfFile The ISO/IEC 21000-9 file to be uploaded, which shall contain the Digital Item describing it in either the XML or BXML boxes transactionID A string identifying the specific request to upload the content, to be used in the protocol with the CPD</p><p>Return value</p><p>Exceptions</p><p>StoreContentException (Error: Reference This exception is thrown if an error occurs while the content is source not found) being stored</p><p>BadPropertyException (Error: Reference This exception is thrown if the properties used to initialise the source not found) SecurityManager were not correctly set, hence the SecurityManager was unable to determine the location of the secure repository.</p><p>UnsupportedFeatureException (Error: This exception is thrown if an error occurred while validating Reference source not found) the principal in the license against the principal in the query.</p><p>Callback Interface</p><p>StoreContentListener (see Error: Reference source not found)</p><p>110 © ISO/IEC 2009 — All rights reserved Callback Method</p><p>+ processStoreContentEvent(event : StoreContentEvent) : void</p><p>6.19.4.2 Store a DCS</p><p>Interface ContentUploader (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ storeDCS (contentBuilder: ContentBuilder, cpdServiceURL: string) : void</p><p>Java sample code public interface ContentUploader { public void storeDCS(String cpdServiceURL, ContentBuilder contentBuilder) throws StoreContentException, UnsupportedFeatureException, BadPropertyException ; } Method description</p><p>This method is used to upload a Digital Item and a number of resources referenced in it, to a remote location.</p><p>Parameters contentBuilder An object of type ContentBuilder (see Error: Reference source not found) containing the information about all the resources to be stored to a remote location, and the Digital Item previously generated after the method createDCI has been invoked (see Error: Reference source not found) cpdServiceURL The URL of the service where content shall be uploaded</p><p>Return value</p><p>Exceptions</p><p>StoreContentException (Error: Reference This exception is thrown if an error occurs while the content is source not found) being stored</p><p>BadPropertyException (Error: Reference This exception is thrown if the properties used to initialise the source not found) ContentUploader class were not correctly set, hence content storage failed.</p><p>UnsupportedFeatureException (Error: This exception is thrown if a feature not supported by MXM was Reference source not found) requested, such as storing content using a protocol which was not supported. </p><p>Callback Interface</p><p>StoreContentListener (see Error: Reference source not found)</p><p>Callback Method</p><p>+ processStoreContentEvent(event : StoreContentEvent) : void</p><p>© ISO/IEC 2009 — All rights reserved 111 ISO/IEC CD 23006-2 6.20 License Protocol Engine APIs</p><p>6.20.1 License Access</p><p>In order to extract from a remote service the method below can be invoked. A license conforming to ISO/IEC 21000-5 will be requested to the service by performing the Request License protocol specified in ISO/IEC 29116-1.</p><p>Interface LicenseManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ requestLicense (contententID:string, contentElementID:string, licenseTemplate:RELLicense, lpdServiceURL:string):void</p><p>Java sample code public interface LicenseManager { public void requestLicense(String contentID, String contentElementID, RELLicense licenseTemplate, String lpdServiceURL) throws AccessLicenseException; } Method description</p><p>This method is used to obtain a license for a content item or content element part of a content item, possibly conforming to a license template from a service. </p><p>Parameters contentID The identifier of the content item whose license is sought, or the identifier of the content item containing a content element whose license is sought contentElementID The identifier of a content element whose license is sought. This parameter shall be null in the case a license for a content item is sought licenseTemplate An object of type RELLicense (see Error: Reference source not found) specifying what shall the requested license contain in terms of principal, right, resource and possibly conditions. lpdServiceURL The URL of the remote service to be invoked in order to request a license.</p><p>Return value</p><p>Exceptions</p><p>AccessLicenseException (Error: This exception is thrown if an error occurs while the Reference source not found) msap:RequestLicense message is generated</p><p>Callback Interface</p><p>RequestLicenseResponseListener (see Error: Reference source not found)</p><p>Callback Method</p><p>+handleRequestLicenseResult(event: RequestLicenseResponseEvent) : void</p><p>112 © ISO/IEC 2009 — All rights reserved 6.20.1.1 Operation to retrieve a license given the id</p><p>Interface ContentBuilder (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ getLicense (xmlLicense:string licenseId): RELLicense</p><p>Java sample code public interface ContentBuilder { public RELLicense getLicense(String licenseId) throws SecurityManagerException, BadPropertyException, UnsupportedFeatureException; } Method description</p><p>This method is used to retreive a License given its id. </p><p>Parameters licenseId The id attribute of the license element.</p><p>Return value</p><p>RELLicense the REL license</p><p>Exceptions</p><p>SecurityManagerException (see Error: This exception is thrown if the digital certificate of Reference source not found) either the license issuer or the license principal could not be retrieved from the SecurityManager because it does not exist.</p><p>BadPropertyException (see Error: This exception is thrown if one or more properties Reference source not found) required by the SecurityManager (e.g. the location of the secure repository where digital certificates reside) were corrupted.</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM. s</p><p>6.20.2 License Storage</p><p>Interface LicenseUploader (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ storeLicense (storeLicenseRequest: StoreLicenseRequest, lpdServiceURL: string) : void</p><p>Java sample code public interface LicenseUploader { private void storeLicenseTemplates(StoreLicenseRequest : storeLicenseRequest, lpdServiceURL : string) throws MalformedContentElementException, UnsupportedFeatureException, StoreLicenseTemplateException; } Method description</p><p>© ISO/IEC 2009 — All rights reserved 113 ISO/IEC CD 23006-2 This method is used to upload a Digital Item and a number of resources referenced in it, to a remote location.</p><p>Parameters storeLicenseRequest An object of type StoreLicenseRequest (see Error: Reference source not found) to be sent to the specified service lpdServiceURL The URL of the service where the license template shall be uploaded</p><p>Return value</p><p>Exceptions</p><p>StoreLicenseTemplateException (Error: This exception is thrown if an error occurs while the license Reference source not found) template is being stored</p><p>Callback Interface</p><p>StoreLicenseEventListener (see )</p><p>Callback Method</p><p>+ processStoreContentEvent(event : StoreContentEvent) : void</p><p>6.20.3 Operation to revoke a license</p><p>Method Syntax</p><p>+revokeLicense(String licenseId): boolean</p><p>Java sample code public boolean revokeLicense(String licenseId) throws MalformedContentElementException, UnsupportedFeatureException;</p><p>Method description</p><p>This method is used to revoke a license.</p><p>Parameters licenseId Identifier of the license to be revoked.</p><p>Return value</p><p>Boolean reportin gits success.</p><p>Exceptions</p><p>MalformedContentElementException This exception is thrown if the data contained in the (see Error: Reference source not license passed as a parameter was not complete or found) corrupted (e.g. the Master key for a ProtectedContentElement is missing).</p><p>SecurityManagerException (see Error: The invoking User must have the right to revoke the Reference source not found) license. This exception is thrown if the digital certificate</p><p>114 © ISO/IEC 2009 — All rights reserved of either the license issuer or the license principal could not be retrieved from the SecurityManager because it does not exist.</p><p>UnsupportedFeatureException (see This exception is thrown if one or more properties Error: Reference source not found) required by the SecurityManager (e.g. the encryption algorithm for encrypting the Master Key with the principal’s public key) is not supported by MXM.</p><p>6.21 IPMP Tool Protocol Engine APIs</p><p>6.21.1 IPMP Tool Access</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ requestIPMPToolBody (location:URL, id:String, di:DeviceInformation):ToolBody</p><p>Java sample code public interface ResourceManager { public ToolBody requestIPMPToolBody(URL location, String id, DeviceInformation di) throws ResourceBuilderException } Method description</p><p>This method is used to retrieve from a TPD (specified by the passed location) a ToolBody that are compatible with the passed device informations</p><p>Parameters location A URL that specify where the TPD resides id The IPMPTool name that has to be retrieved di The Device Information that has to be matched from the TPD Error: Reference source not found</p><p>Return value</p><p>A TooBody, named id, that match the specified DeviceInformation Error: Reference source not found</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourseBuilder failed Reference source not found) requesting the IPMPInfo</p><p>6.21.2 IPMP Tool List Access</p><p>Interface ResourceManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ requestIPMPInfoList (location:URL, di:DeviceInformation):IPMPInfo[]</p><p>Java sample code</p><p>© ISO/IEC 2009 — All rights reserved 115 ISO/IEC CD 23006-2 public interface ResourceManager { public IPMPInfo[] requestIPMPInfoList(URL location, DeviceInformation di) throws ResourceBuilderException } Method description</p><p>This method is used to retrieve from a TPD (specified by the passed location) a list of IPMPInfo that are compatible with the passed device informations</p><p>Parameters location A URL that specify where the TPD resides</p><p> di The Device Information that has to be matched Error: Reference source not found</p><p>Return value</p><p>A set of IPMPInfo that match the passed DeviceInformation Error: Reference source not found</p><p>Exceptions</p><p>ResourceBuilderException (see Error: This exception is thrown if the ResourseBuilder failed Reference source not found) requesting the IPMPInfo</p><p>6.22 Content Search Engine APIs</p><p>Class Diagram</p><p>6.22.1 Content Store</p><p>[Editors' note: Is this necessary, or we can treat this method as a particular case of the Store Content Protocol?]</p><p>The storage part of the system is accessible by means of the store(DCFWrapper), where the DCFWrapper is a wrapper of the DCF file and Pair is bean with key-value pair attributes. </p><p>116 © ISO/IEC 2009 — All rights reserved These high level functionality's interact with the low level functions of the Distributed System layer (e.g. based on DHT, Chord, CAN like etc...) which are not part of the APIs of this engine.</p><p>UML Specifications</p><p>Method Syntax for interface DistributedStorage</p><p>+store (dcfwrapper:DCFWrapper, distributedFlag:boolean):boolean</p><p>Java sample code implementation</p><p> public interface DistributedStorage { public boolean store(DCFWrapper dcfwrapper,boolean distributedFlag); }</p><p>Method description </p><p>Once the DCF is created by the Content Creator Device, it is possible to store and index the content using the keys bound to the metadata.</p><p>Once the indexes are set, all the mappings are inserted in the Distributed SystemDHT, with the reference to the position in the system of the DCF itself (represented as an associated entity in the class diagram)</p><p>The second parameter, the distributedFlag let the user to decide if the DCF can be stored somewhere in the network (flag=true) or can force the system to store the DCF only locally, even if the related indexes will be distributed.</p><p>6.22.2 Content Search</p><p>The function of searching for content</p><p>UML Specifications</p><p>Method Syntax for interface DistributedStorage</p><p>+retrieve (pairs:List<Pair>):List<DCFWrapper></p><p>Java sample code implementation</p><p> public interface DistributedStorage {</p><p> public List<DCFWrapper> retrieve(List<Pair> pairs);</p><p>}</p><p>Method retrieve description</p><p>The retrieve process starts querying the system with specific keys that have been used for indexing the searched content. </p><p>It is possible retrieve the references to all the DCF provided by the issuer named “scott”, calling the method with the key-value pair: (“issuer”,”scott”). The user can apply for structured queries providing a list of key- value pairs mapped onto a Pair object, which is a bean with the key,value class attributes.</p><p>© ISO/IEC 2009 — All rights reserved 117 ISO/IEC CD 23006-2 The method returns a list of DCFWrappers that have the references to the real DCF content. In the DCFWrapper is written the resource from which pulling the DCF. A separate transferring channel must be set up for the physical downloading of the DCF.</p><p>6.23 Security Engine APIs</p><p>6.23.1 Key Generation</p><p>6.23.1.1 Random key generation</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ generateRandomKey(String algorithm, int keyLength): byte[]</p><p>Java sample code public byte[] generateRandomKey(String algorithm, int keyLength) throws NoSuchAlgorithmException ; Method description</p><p>This method is employed to generate a random key using the given algorithm.</p><p>Parameters algorithm algorithm used to produce a random key. keyLength the size of the random key.</p><p>Return value byte[], a random key(a pseudo-random number).</p><p>Exceptions</p><p>NoSuchAlgorithmException</p><p>6.23.1.2 Random key-pair generation</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ generateTestKeyPair(String algorithm): KeyPair</p><p>Java sample code public KeyPair generateTestKeyPair(String algorithm) throws NoSuchAlgorithmException, IOException, BadPropertyException, DeviceContextException ; Method description</p><p>This method is employed to generate a key pair (a private key and its associated public key) using the given algorithm.</p><p>Parameters algorithm algorithm to be used with this key pair.</p><p>118 © ISO/IEC 2009 — All rights reserved Return value</p><p>KeyPair, a key pair (a private key and its associated public key).</p><p>Exceptions</p><p>NoSuchAlgorithmException</p><p>IOException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.2 Encryption</p><p>6.23.2.1 Encrypt an array of bytes using asymmetric encryption</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ encrypt(byte[] data, String algorithm, String keyAlias, String password): byte[]</p><p>Java sample code public byte[] encrypt(byte[] data, String algorithm, String keyAlias, String password) throws SecurityManagerException, BadPropertyException, DeviceContextException, UnsupportedFeatureException, MalformedContentElementException ; Method description</p><p>This method is employed to encrypt the data with the given algorithm using the public key from a trusted certificate stored in the keyStore.</p><p>Parameters data data to be encrypted. algorithm algorithm used to encrypt the data. keyAlias alias for the key which is to be used with the given algorithm to encrypt the data. password password for accessing the key entry with the given key alias.</p><p>Return value byte[],result of encryption.</p><p>Exceptions</p><p>SecurityManagerException </p><p>BadPropertyException</p><p>DeviceContextException</p><p>© ISO/IEC 2009 — All rights reserved 119 ISO/IEC CD 23006-2 UnsupportedFeatureException</p><p>MalformedContentElementException</p><p>6.23.2.2 Encrypt an array of bytes using symmetric encryption</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ encrypt(byte[] data, byte[] encryptionKey, String algorithm): byte[]</p><p>Java sample code public byte[] encrypt(byte[] data, byte[] encryptionKey, String algorithm) throws SecurityManagerException, UnsupportedFeatureException, MalformedContentElementException; Method description</p><p>This method is employed to encrypt the data with the given algorithm using the key passed as a parameter.</p><p>Parameters data data to be encrypted. encryptionKey the key to be used to encrypt the data. algorithm algorithm used to encrypt the data.</p><p>Return value byte[], result of encryption.</p><p>Exceptions</p><p>SecurityManagerException </p><p>UnsupportedFeatureException</p><p>MalformedContentElementException</p><p>6.23.3 Decryption</p><p>6.23.3.1 Asymmetric decrypt an array of bytes</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ decrypt(byte[] data, String algorithm, String keyAlias, String password): byte[]</p><p>Java sample code public byte[] decrypt(byte[] data, String algorithm, String keyAlias, String password) throws NoSuchAlgorithmException, CertificateException, KeyStoreException, UnrecoverableEntryException, IOException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException,</p><p>120 © ISO/IEC 2009 — All rights reserved SecurityManagerException, DeviceContextException, BadPropertyException ; Method description</p><p>This method is employed to decrypt the input data using a private key.</p><p>Parameters data data to be decrypted. algorithm algorithm used to decrypt the data. keyAlias alias for the key which is to be used by the given algorithm to decrypt the data. password password for accessing the key entry with the given key alias.</p><p>Return value byte[], result of decryption.</p><p>Exceptions</p><p>NoSuchAlgorithmException </p><p>CertificateException</p><p>KeyStoreException</p><p>UnrecoverableEntryException</p><p>IOException</p><p>NoSuchPaddingException</p><p>InvalidKeyException</p><p>IllegalBlockSizeException</p><p>BadPaddingException</p><p>SecurityManagerException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>6.23.3.2 Symmetric decrypt an array of bytes</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ decrypt(byte[] data, byte[] decryptionKey, String algorithm): byte[]</p><p>Java sample code public byte[] decrypt(byte[] data, byte[] decryptionKey, String algorithm) throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException ;</p><p>© ISO/IEC 2009 — All rights reserved 121 ISO/IEC CD 23006-2 Method description</p><p>This method is employed to decrypt the data with the given algorithm using the key passed as a parameter.</p><p>Parameters data data to be decrypted. decryptionKey the key to be used to decrypt the data. algorithm algorithm used to decrypt the data.</p><p>Return value byte[], result of decryption.</p><p>Exceptions</p><p>NoSuchAlgorithmException </p><p>NoSuchPaddingException</p><p>InvalidKeyException</p><p>IllegalBlockSizeException</p><p>BadPaddingException</p><p>6.23.4 Hash calculation</p><p>6.23.4.1 Generate a hash value of an array of bytes</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ generateHash(byte[] data, String algorithm): byte[]</p><p>Java sample code public byte[] generateHash(byte[] data, String algorithm) throws NoSuchAlgorithmException ; Method description</p><p>This method is employed to generate hash value for the data using the given algorithm.</p><p>Parameters data data to be hashed. algorithm algorithm used to hash the data.</p><p>Return value byte[], a hash value.</p><p>Exceptions</p><p>122 © ISO/IEC 2009 — All rights reserved NoSuchAlgorithmException</p><p>6.23.4.2 Generate a hash value of the contents of a file</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ generateHash(FileInputStream fis, String algorithm): byte[]</p><p>Java sample code public byte[] generateHash(FileInputStream fis, String algorithm) throws NoSuchAlgorithmException, IOException ; Method description</p><p>This method is employed to generate hash value for a file using the given algorithm.</p><p>Parameters fis the File to be hashed. algorithm algorithm used to hash the data.</p><p>Return value byte[], a hash value.</p><p>Exceptions</p><p>NoSuchAlgorithmException</p><p>IOException</p><p>6.23.5 Hash verification</p><p>6.23.5.1 Verify the hash value of the contents of an array of bytes</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ verifyHash(byte[] data, byte[] hashValue, String algorithm): boolean</p><p>Java sample code public boolean verifyHash(byte[] data, byte[] hashValue, String algorithm) throws</p><p>NoSuchAlgorithmException ;</p><p>Method description</p><p>This method is employed to verify the hash value for the data using the given algorithm.</p><p>Parameters</p><p>© ISO/IEC 2009 — All rights reserved 123 ISO/IEC CD 23006-2 data data which has the given hash value. hashValue hash value for the given data. algorithm algorithm used to hash the data.</p><p>Return value</p><p>Boolean, result of verification</p><p>Exceptions</p><p>NoSuchAlgorithmException</p><p>6.23.6 Digital Signature generation</p><p>6.23.6.1 Generate the digital signature for an array of bytes</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ generateSignature(byte[] data, String algorithm, String keyAlias, String password): byte[]</p><p>Java sample code public byte[] generateSignature(byte[] data, String algorithm, String keyAlias, String password) throws NoSuchAlgorithmException, InvalidKeyException, SignatureException, KeyStoreException, CertificateException, IOException, UnrecoverableEntryException, BadPropertyException, DeviceContextException ; Method description</p><p>This method is employed to generate signature for the data using the given algorithm and a private key. The private key is not explicitly specified as an input parameter, the given key alias is used to obtain the needed private key.</p><p>Parameters data data to be signed. algorithm algorithm used to sign the data. keyAlias alias for the private key which is to be used with the given algorithm to sign the data. password password for accessing the key entry with the given key alias.</p><p>Return value byte[],signature for the input data.</p><p>Exceptions</p><p>NoSuchAlgorithmException </p><p>InvalidKeyException</p><p>124 © ISO/IEC 2009 — All rights reserved SignatureException</p><p>KeyStoreException</p><p>CertificateException</p><p>IOException</p><p>UnrecoverableEntryException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.7 Digital Signature verification</p><p>6.23.7.1 Verify the digital signature for an array of bytes</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ verifySignature(byte[] data, byte[] signature, String algorithm, String keyAlias,</p><p>String password): Boolean</p><p>Java sample code public boolean verifySignature(byte[] data, byte[] signature, String algorithm, String keyAlias, String password) throws NoSuchAlgorithmException, InvalidKeyException, SignatureException, KeyStoreException, CertificateException, IOException, UnrecoverableEntryException, BadPropertyException, DeviceContextException ; Method description</p><p>This method is employed to verify the signature for the data with the given algorithm and a public key. The public key is not explicitly specified as an input parameter, the given key alias is used to obtain the needed public key.</p><p>Parameters data data which has the given signature. signature ignature for the given data algorithm algorithm used to verify the signature. keyAlias alias for the private key which is to be used to obtain its corresponding public key. password password for accessing the key entry with the given key alias.</p><p>Return value boolean, result of verification.</p><p>Exceptions</p><p>© ISO/IEC 2009 — All rights reserved 125 ISO/IEC CD 23006-2 NoSuchAlgorithmException </p><p>InvalidKeyException</p><p>SignatureException</p><p>KeyStoreException</p><p>CertificateException</p><p>IOException</p><p>UnrecoverableEntryException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.8 Security Information Access</p><p>6.23.8.1 Get a certificate from the secure repository as an X.509 Certificate</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ getCertificate(String keyAlias, String password): X509Certificate</p><p>Java sample code public X509Certificate getCertificate(String keyAlias, String password) throws SecurityManagerException, BadPropertyException, DeviceContextException ; Method description</p><p>This method is employed to retrieve a trusted certificate from the keyStore giving in input a valid alias.</p><p>Parameters keyAlias The alias needed to retrieve the Certificate. password The KeyStore password.</p><p>Return value</p><p>X509Certificate, The X.509 Certificate corresponding to the alias.</p><p>Exceptions</p><p>SecurityManagerException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>126 © ISO/IEC 2009 — All rights reserved 6.23.8.2 Get a certificate from the secure repository as an REL Principal</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ getPrincipal(String keyAlias, String password): Principal</p><p>Java sample code public Principal getPrincipal(String keyAlias, String password) throws SecurityManagerException, BadPropertyException ; Method description</p><p>This method is used to obtain the CCD REL Principal to be inserted in a License. The Principal key name indicates the User's full name. The Principal key value contains the User's Public Key</p><p>Parameters keyAlias The keyAlias identifying the User. password The password necessary to retrieve the data from the KeyStore.</p><p>Return value</p><p>Principal, key value contains the User's RSA Public Key</p><p>Exceptions</p><p>SecurityManagerException</p><p>BadPropertyException</p><p>6.23.8.3 Get a certificate from the secure repository as a DeviceID</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ getDeviceID(String keyAlias, String password): DeviceID</p><p>Java sample code public DeviceID getDeviceID(String keyAlias, String password) throws SecurityManagerException, BadPropertyException, DeviceContextException ;</p><p>Method description</p><p>This method is used to obtain the DeviceID.</p><p>Parameters keyAlias The keyAlias identifying the User. password The password necessary to retrieve the data from the KeyStore.</p><p>Return value</p><p>DeviceID</p><p>© ISO/IEC 2009 — All rights reserved 127 ISO/IEC CD 23006-2</p><p>Exceptions</p><p>SecurityManagerException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.8.4 Export a certificate to a file</p><p>Interface SecurityManager</p><p>Method Syntax</p><p>+ exportCertificate(String keyAlias, String password, FileOutputStream fos): void</p><p>Java sample code public void exportCertificate(String keyAlias, String password, FileOutputStream fos) throws SecurityManagerException, IOException, BadPropertyException, DeviceContextException Method description</p><p>This method is employed to export a Device Certificate as a file in the file system.</p><p>Parameters keyAlias The alias for the certificate to be exported. password The password to get access to the KeyStore. fos The FileOutputStream referring to the File.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>SecurityManagerException</p><p>IOException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.8.5 Get an array of licenses from the secure repository</p><p>In order to extract from the SecurityManager (see Error: Reference source not found) all the licenses governing a content item or a content element part of a content item, an instance of SecurityManager has to be created and initialised. Licenses are stored in the SecurityManager using the method addLicense in Section 5.9.3</p><p>Interface SecurityManager (see Error: Reference source not found)</p><p>128 © ISO/IEC 2009 — All rights reserved Method Syntax</p><p>+ getArrayOfLicenses (secureInfoAlias:String): RELLicense[]</p><p>Java sample code public interface SecurityManager { public RELLicense[] getArrayOfLicenses(String secureInfoAlias) throws IOException, SecurityManagerException, BadPropertyException; } Method description</p><p>This method is used to extract from the SecurityManager all the licenses governing a content item or a content element part of a content item.</p><p>Parameters secureInfoAlias The identifier of the content item or content element part of a content item whose licenses are sought.</p><p>Return value</p><p>An array containing all the licenses (see Error: Reference source not found) found in the Security Manager’s repository for the content item or content element whose identifier was specified in input. </p><p>Exceptions</p><p>IOException This exception is thrown if problems occurred while reading from the secure repository.</p><p>SecurityManagerException This exception is thrown if the data in the secure repository is corrupted</p><p>BadPropertyException This exception is thrown if the properties used to initialise the SecurityManager were not correctly set, hence the SecurityManager was unable to determine the location of the secure repository.</p><p>6.23.8.6 Get a list of licenses from the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ getLicenses(String secureInfoAlias): List<RELLicense></p><p>Java sample code public List<RELLicense> getLicenses(String secureInfoAlias) throws IOException, SecurityManagerException, BadPropertyException ; Method description</p><p>This method is employed to retrieve secure License information using the given alias from the infostore indicated by its infoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information.</p><p>© ISO/IEC 2009 — All rights reserved 129 ISO/IEC CD 23006-2 Return value</p><p>List<RELLicense>,all Licenses found for a certain ResourceID or ContentID.</p><p>Exceptions</p><p>IOException </p><p>SecurityManagerException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>6.23.8.7 Get user information from the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ getSecureInfo(String secureInfoAlias): List<String></p><p>Java sample code public List<String> getSecureInfo(String secureInfoAlias) throws IOException, SecurityManagerException, DeviceContextException, BadPropertyException ; Method description</p><p>This method is employed to retrieve secure User information using the given alias from the infostore indicated by its infoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information.</p><p>Return value</p><p>List<String>, all pieces of secure information with the given Alias.</p><p>Exceptions</p><p>IOException </p><p>SecurityManagerException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>6.23.8.8 Get domain information from the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>130 © ISO/IEC 2009 — All rights reserved + getSecureDomainInfo(String secureInfoAlias): List<String></p><p>Java sample code public List<String> getSecureDomainInfo(String secureInfoAlias) throws SecurityManagerException, BadPropertyException ; Method description</p><p>This method is employed to retrieve secure Domain information using the given alias from the infostore indicated by its domainInfoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information.</p><p>Return value</p><p>List<String>, all pieces of secure information with the given Alias</p><p>Exceptions</p><p>SecurityManagerException</p><p>BadPropertyException</p><p>6.23.9 Authentication</p><p>6.23.10 Trust verification</p><p>6.23.10.1 Digital Signature verification</p><p>6.23.11 Secure information storage</p><p>6.23.11.1 Store a license</p><p>Interface SecurityManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ addLicense (secureInfoAlias:String, license:RELLicense): void</p><p>Java sample code public interface SecurityManager { public void addLicense(String secureInfoAlias, RELLicense license) throws IOException, SecurityManagerException, BadPropertyException; } Method description</p><p>This method is used to store a license in the secure repository managed by the SecurityManager. The license to be stored is associated to an alias which will be required in order to retrieve the license from the SecurityManager later on by using the method specified in Error: Reference source not found. The alias to be used is either the content ID or the content element ID, depending on whether the license governs a content item or a content element.</p><p>Parameters</p><p>© ISO/IEC 2009 — All rights reserved 131 ISO/IEC CD 23006-2 secureInfoAlias The identifier of the content item or content element part of a content item governed by the license to be stored.</p><p>License An object of type RELLicense as specified in Error: Reference source not found</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>IOException This exception is thrown if problems occurred while writing to the secure repository.</p><p>SecurityManagerException This exception is thrown if the data in the secure repository is corrupted</p><p>BadPropertyException This exception is thrown if the properties used to initialise the SecurityManager were not correctly set, hence the SecurityManager was unable to determine the location of the secure repository.</p><p>6.23.11.2 Store usser information</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ addSecureInfo(String secureInfoAlias, String secureInfo): void</p><p>Java sample code public void addSecureInfo(String secureInfoAlias, String secureInfo) throws IOException, SecurityManagerException, DeviceContextException, BadPropertyException ; Method description</p><p>This method is employed to store User information with the given alias into the License infostore indicated by its licenseInfoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information. secureInfo secure License information.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>IOException </p><p>SecurityManagerException</p><p>DeviceContextException</p><p>132 © ISO/IEC 2009 — All rights reserved BadPropertyException</p><p>6.23.11.3 Store a key into the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ addSecretKey(String keyAlias, String algorithm, int keysize, String pwdKeyStore, String pwdKeyEntry): void</p><p>Java sample code public void addSecretKey(String keyAlias, String algorithm, int keysize, String pwdKeyStore, String pwdKeyEntry) throws KeyStoreException, NoSuchAlgorithmException, CertificateException, IOException, NoSuchProviderException, BadPropertyException, DeviceContextException ; Method description</p><p>This method is employed to add a secret key(symmetric key) to the keystore, which is to be used for symmetric cipher.</p><p>Parameters keyAlias alias for the entry of the secret key. algorithm the symmetric algorithm used to generate a secret key. keysize the size of the key you want, which must be supported by the given algorithm. pwdKeyStore password for the keystore. pwdKeyEntry password for the key entry.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>KeyStoreException </p><p>NoSuchAlgorithmException</p><p>CertificateException </p><p>IOException</p><p>NoSuchProviderException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.11.4 Create a Private Key for a new user and store it into the secure repository</p><p>Interface SecurityManagerInterface</p><p>© ISO/IEC 2009 — All rights reserved 133 ISO/IEC CD 23006-2 Method Syntax</p><p>+ createUserEntry (String keyAlias, String password, PrivateKeyEntry privateKeyEntry): void</p><p>Java sample code public void createUserEntry (String keyAlias, String password, PrivateKeyEntry privateKeyEntry) throws IOException, NoSuchAlgorithmException, InvalidKeyException, CertificateException, NoSuchProviderException, SignatureException, KeyStoreException, JAXBException, DeviceContextException, BadPropertyException, SecurityManagerException ; Method description</p><p>This method is used to add a new user entry in the KeyStore. If the privateKeyEntry parameter is null, a new public/private key pair and a self certificate will be created.</p><p>Parameters keyAlias The alias used to Store the new entry in the KeyStore.</p><p>Password The password for retrieving the entry in the KeyStore associated to the alias specified. privateKeyEntry The PrivateKeyEntry to store in the KeyStore associated to the username. If this parameter is null, a test privateKeyEntry will be generated. The PrivateKeyEntry, if specified, shall contain an RSA key pair and the signature shall be of type "MD5WithRSA".</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>IOException</p><p>NoSuchAlgorithmException</p><p>InvalidKeyException</p><p>CertificateException</p><p>SignatureException</p><p>NoSuchProviderException</p><p>KeyStoreException</p><p>JAXBException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>SecurityManagerException</p><p>134 © ISO/IEC 2009 — All rights reserved 6.23.11.5 Store a certificate from a file in the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ importCertificate(String keyAlias, String password, FileInputStream fis): String</p><p>Java sample code public String importCertificate(String keyAlias, String password, FileInputStream fis) throws NoSuchAlgorithmException, CertificateException, KeyStoreException, UnrecoverableEntryException, IOException, UnsupportedFeatureException, BadPropertyException, DeviceContextException ; Method description</p><p>This method is employed to import an X509 Certificate belonging to another Device in a Device's Key Store. The alias of the new Certificate will be the Name in the X500Name structure part of the X509 Certificate.</p><p>Parameters keyAlias the KeyAlias for the new Certificate. If null, the Name in the X500Name structure part of the X509 Certificate will be used, to which the '#' is added, plus the certificate serial number. password The password necessary to retrieve the data from the KeyStore. fis The FileInputStream of the Certificate File.</p><p>Return value</p><p>String, the keyAlias employed</p><p>Exceptions</p><p>NoSuchAlgorithmException</p><p>CertificateException</p><p>KeyStoreException</p><p>UnrecoverableEntryException</p><p>IOException</p><p>UnsupportedFeatureException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.11.6 Store a certificate from a KeyInfo in the secure repository</p><p>Interface SecurityManager</p><p>Method Syntax</p><p>+ importCertificate (String keyAlias, String password, KeyInfo keyInfo): boolean</p><p>© ISO/IEC 2009 — All rights reserved 135 ISO/IEC CD 23006-2 Java sample code public boolean importCertificate (String keyAlias, String password, KeyInfo keyInfo) throws Base64DecodingException, JAXBException, CertificateException, NoSuchAlgorithmException, KeyStoreException, UnrecoverableEntryException, IOException, DeviceContextException, BadPropertyException Method description</p><p>This method is employed to import an X509 Certificate belonging to another Device in a Device's Key Store.</p><p>Parameters keyAlias the KeyAlias for the new Certificate. password The password to get access to the KeyStore. keyInfo The KeyInfo element containing the Certificate.</p><p>Return value</p><p>Boolean, TRUE if the operation is concluded successfully.</p><p>Exceptions</p><p>Base64DecodingException </p><p>JAXBException</p><p>CertificateException</p><p>NoSuchAlgorithmException</p><p>KeyStoreException</p><p>UnrecoverableEntryException</p><p>IOException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.11.7 Store domain information in the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ addSecureDomainInfo(String secureInfoAlias, String secureInfo): void</p><p>Java sample code public void addSecureDomainInfo(String secureInfoAlias, String secureInfo) throws IOException, SecurityManagerException, DeviceContextException, BadPropertyException ; Method description</p><p>This method is employed to store Domain information with the given alias into the Domain infostore indicated</p><p>136 © ISO/IEC 2009 — All rights reserved by its domainInfoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information. secureInfo secure Domain information.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>IOException </p><p>SecurityManagerException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>6.23.12 Security Information deletion</p><p>6.23.12.1 Delete a trusted certificate from the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ deleteCertificate(String keyAlias, String password): void</p><p>Java sample code public void deleteCertificate(String keyAlias, String password) throws IOException, NoSuchAlgorithmException, CertificateException, KeyStoreException, UnrecoverableEntryException, BadPropertyException, DeviceContextException ; Method description</p><p>This method is employed to delete a trusted certificate from the keyStore giving in input a valid alias.</p><p>Parameters keyAlias The alias needed to retrieve the Certificate. password The KeyStore password.</p><p>Return value void.</p><p>Exceptions</p><p>IOException </p><p>NoSuchAlgorithmException</p><p>© ISO/IEC 2009 — All rights reserved 137 ISO/IEC CD 23006-2 CertificateException</p><p>KeyStoreException</p><p>UnrecoverableEntryException</p><p>SecurityManagerException</p><p>BadPropertyException</p><p>DeviceContextException</p><p>6.23.12.2 Delete a license from the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ deleteLicenses(String secureInfoAlias, String secureInfo): void</p><p>Java sample code public void deleteLicenses(String secureInfoAlias, String secureInfo) throws IOException, SecurityManagerException, DeviceContextException, BadPropertyException ; Method description</p><p>This method is employed to delete License information with the given alias from the License infostore indicated by its licenseInfoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information. secureInfo secure License information.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>IOException </p><p>SecurityManagerException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>6.23.12.3 Delete user information from the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ deleteSecureInfo(String secureInfoAlias, String secureInfo): void</p><p>138 © ISO/IEC 2009 — All rights reserved Java sample code public void deleteSecureInfo(String secureInfoAlias, String secureInfo) throws IOException, SecurityManagerException, DeviceContextException, BadPropertyException ; Method description</p><p>This method is employed to delete User information with the given alias from the License infostore indicated by its licenseInfoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information. secureInfo secure License information.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>IOException </p><p>SecurityManagerException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>6.23.12.4 Delete domain information from the secure repository</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ deleteSecureDomainInfo(String secureInfoAlias, String secureInfo): void</p><p>Java sample code public void deleteSecureDomainInfo(String secureInfoAlias, String secureInfo) throws IOException, SecurityManagerException, DeviceContextException, BadPropertyException ; Method description</p><p>This method is employed to delete Domain information with the given alias from the Domain infostore indicated by its domainInfoStoreLocation.</p><p>Parameters secureInfoAlias alias for the entry of the secure information. secureInfo secure Domain information.</p><p>Return value</p><p>Void</p><p>Exceptions</p><p>© ISO/IEC 2009 — All rights reserved 139 ISO/IEC CD 23006-2</p><p>IOException </p><p>SecurityManagerException</p><p>DeviceContextException</p><p>BadPropertyException</p><p>6.23.13 Miscellanea</p><p>6.23.13.1 Verify a REL Principal</p><p>Interface SecurityManagerInterface</p><p>Method Syntax</p><p>+ verifyPrincipal(String keyAlias, String password, Principal principal): boolean</p><p>Java sample code public boolean verifyPrincipal(String keyAlias, String password, Principal principal) throws SecurityManagerException, BadPropertyException, UnsupportedFeatureException ; Method description</p><p>This method is used to verify the existence of a certificate expressed as an REL Principal in the secure repository.</p><p>Parameters keyAlias The keyAlias identifying the User. password The password necessary to retrieve the data from the KeyStore.</p><p>Return value</p><p>Boolean</p><p>Exceptions</p><p>SecurityManagerException</p><p>BadPropertyException</p><p>UnsupportedFeatureException</p><p>6.23.13.2 Method to generate and embed the digital signature for an XML document</p><p>Interface -</p><p>Method Syntax</p><p>+ addXMLSignature(String xmlDocument, String digestMethod, String signatureMethod, PrivateKey privateKey, Certificate certificate): String</p><p>140 © ISO/IEC 2009 — All rights reserved Java sample code public String addXMLSignature(String xmlDocument, String digestMethod, String signatureMethod, PrivateKey privateKey, Certificate certificate) throws Exception ; Method description</p><p>This method is employed to generate a digital signature and embed it into an XML document. It assumes that the digital signature will be computed over the whole XML document and embedded into it in a <DIDLInfo><dsig:Signature> element at the end of the XML document. Moreover, the input Certificate will be also embedded into the resulting signed XML document in a <dsig:KeyInfo><dsig:X509Data> <dsig:X509Certificate> element inside the <DIDLInfo><dsig:Signature> element where the signature is embedded.</p><p>Parameters xmlDocument XML document to be signed. digestMethod Digest method applied to the whole XML document to get the digest to be signed (e.g. http://www.w3.org/2000/09/xmldsig#sha1). signatureMethod Signature method applied over the digest (e.g. http://www.w3.org/2000/09/xmldsig#rsa-sha1). privateKey Private key to be used to compute the signature. certificate X509 certificate which includes the public key corresponding to the private key used to compute the signature.</p><p>Return value String, the XML document including the digital signature.</p><p>Exceptions</p><p>Exception </p><p>6.23.13.3 Method to verify the digital signature for an XML document</p><p>Interface -</p><p>Method Syntax</p><p>+ verifyXMLSignature(String xmlDocument): Boolean</p><p>Java sample code public boolean verifyXMLSignature(String xmlDocument, String keyAlias, String password) throws Exception ; Method description</p><p>This method is employed to verify the signature present in a XML document, assuming that the public key is embedded in the XML document (e.g. in the XMLDSIG KeyInfo-X509Data- X509Certificate element).</p><p>Parameters xmlDocument XML document that includes the XML signature to be checked</p><p>Return value</p><p>© ISO/IEC 2009 — All rights reserved 141 ISO/IEC CD 23006-2 boolean, result of verification.</p><p>Exceptions</p><p>Exception </p><p>6.23.13.4 Method to authenticate a User with Password</p><p>Interface -</p><p>Method Syntax</p><p>+ authenticateUser(String userName, String password): String</p><p>Java sample code public String authenticateUser(String userName, String password) throws Exception; Method description</p><p>This method is employed to retrieve a SAML token that contains the credentials of the user, and which is digitally signed by a trusted entity. The SAML token can be used to authenticate the user against any other service in the system. The token may have a validity period or may be also restricted to be used just once.</p><p>Parameters userName Name or nick of the user in the system. password Password used by the user to prove his identity.</p><p>Return value</p><p>String, an XML piece that represents the SAML token, which contains the credentials of the user.</p><p>Exceptions</p><p>Exception</p><p>6.23.13.5 Method to authenticate user with password and user certificate</p><p>Interface -</p><p>Method Syntax</p><p>+ authenticateUser(String userName, String password, X509Certificate userCertificate): String</p><p>Java sample code public String authenticateUser(String userName, String password, X509Certificate userCertificate) throws Exception; Method description</p><p>This method is employed to retrieve a SAML token that contains the credentials of the user, and</p><p>142 © ISO/IEC 2009 — All rights reserved which is digitally signed by a trusted entity. The SAML token can be used to authenticate the user against any other service in the system. The token may have a validity period or may be also restricted to be used just once.</p><p>With respect to the previous method, this method is assumed to be run over SSL, using a x509 certificate that identifies the user. This certificate can be optionally sent as an input argument. The authentication service will determine the x509 certificate that has been used, it will extract the user information and it will consult an external OCSP service to determine whether it is or not revoked. If the certificate is not revoked and the user credentials are correct, it will return the corresponding SAML token.</p><p>Parameters userName Name or nick of the user in the system. password Password used by the user to prove his identity. userCertificate The userCertificate corresponding to the user that is requesting authentication</p><p>Return value</p><p>String, an XML piece that represents the SAML token, which contains the credentials of the user.</p><p>Exceptions</p><p>Exception</p><p>Note: Other authentication alternatives may be also accepted, as the authentication in each transaction based on user/password or based on an X509 client Certificate.</p><p>6.23.13.6 Method to estimate the fingerprint of a tool</p><p>Interface -</p><p>Method Syntax</p><p>+ estimateToolFingerprint (): String</p><p>Java sample code public String estimateToolFingerprint () throws Exception; Method description</p><p>This method is employed to extract relevant features about the device (operating system) and/or the software tool that is requesting the authorisation of a user action. This information can be used to be registered during the first usage attempt of the tool in the system so that it can be later checked for integrity.</p><p>Return value</p><p>String, an XML piece that represents the relevant features about the device (operating system) and/or the software tool.</p><p>Exceptions</p><p>Exception</p><p>© ISO/IEC 2009 — All rights reserved 143 ISO/IEC CD 23006-2</p><p>6.23.13.7 Method to enable or certify the operation of a tool</p><p>Interface -</p><p>Method Syntax</p><p>+ certifyTool (String toolFingerprint, String userToken): String</p><p>Java sample code public CertificationResult certifyTool (String toolFingerprint, String userToken) throws Exception; Method description</p><p>This method is employed to check the integrity of a software tool prior to its first usage. Some features regarding the device (operating system) and/or the software tool that is requesting the authorisation of a user action will be registered so that they can be later checked for integrity.</p><p>Parameters toolFingerprint An XML piece that represents the relevant features about the device (operating system) and/or the software tool. userToken An XML piece that represents the SAML token, which contains the credentials of the user.</p><p>Return value</p><p>CertificationResult, a class that contains the following information:</p><p>- Int certificationResult: the result of the certifyTool process</p><p>- Byte[] toolPKCS12: an X509 certificate and private key that identify the certified tool. The X509 certificate includes a unique tool identifier and an enabling code that can be used for the selfVerify process.</p><p>Exceptions</p><p>Exception</p><p>6.23.13.8 Method to verify locally the integrity of a tool </p><p>Interface -</p><p>Method Syntax</p><p>+ selfVerifyTool (String toolFingerprint): String</p><p>Java sample code public String selfVerifyTool (String toolFingerprint) throws Exception; Method description</p><p>This method is employed to locally check the integrity of a software tool during its whole life operation. The features regarding the device are used to compute a security code and</p><p>144 © ISO/IEC 2009 — All rights reserved determine if it matches the enabling code received during certification. In this way, this method determines whether the tool has been manipulated.</p><p>Parameters toolFingerprint An XML piece that represents the relevant features about the device (operating system) and/or the software tool.</p><p>Return value</p><p>String, the result of the verifyTool process</p><p>Exceptions</p><p>Exception</p><p>6.23.13.9 Method to verify remotely the integrity of a tool</p><p>Interface -</p><p>Method Syntax</p><p>+ verifyTool (String toolFingerprint, String userToken): String</p><p>Java sample code public String verifyTool (String toolFingerprint, String userToken) throws Exception; Method description</p><p>This method is employed to remotely check the integrity of a software tool during its whole life operation. Some features regarding the device (operating system) and/or the software tool that is requesting the authorisation of a user action are sent to be compared to those registered in the certifyTool process.</p><p>Parameters toolFingerprint An XML piece that represents the relevant features about the device (operating system) and/or the software tool. userToken An XML piece that represents the SAML token, which contains the credentials of the user.</p><p>Return value</p><p>String, the result of the verifyTool process</p><p>Exceptions</p><p>Exception</p><p>6.23.13.10 Method to disable to operation of a tool </p><p>Interface -</p><p>Method Syntax</p><p>© ISO/IEC 2009 — All rights reserved 145 ISO/IEC CD 23006-2 + disableTool (): String</p><p>Java sample code public String disableTool () throws Exception; Method description</p><p>This method is employed to disable the operation of a software tool due to any problem detected during the verifyTool process. The tool will be deactivated in the device where it is running.</p><p>Return value</p><p>String, the result of the disableTool operation</p><p>Exceptions</p><p>Exception</p><p>6.24 MVCO Engine APIs</p><p>MPEG is standardizing an MPEG Media Value Chain Ontology (Part 19). Having digitally represented the Intellectual Property Model allows different MXM Devices to validate their IP operations against a common established model.</p><p>In practice, accessing the OWL file and reasoning over it is a non-trivial task, common to several Devices. MXM-MVCO is proposed as an API to facilitate this operation.</p><p>This API is based in methods using only basic datatypes (defining only the appropiate Exception), making its use inmediate and stratightforward.</p><p>146 © ISO/IEC 2009 — All rights reserved 6.24.1.1 Operation to load a data set from a given location.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ Load(String sURI): boolean</p><p>Java sample code public boolean Load(String sURI) throws IOException; Method description</p><p>This method is employed to load a set of assertions from a URI. This method is additive, i.e., loading a second set of data does not replace the existing one.</p><p>Data loaded includes Users, IP Entities (Digital Items), Permissions and Actions performed.</p><p>Parameters sURI Any URI making reference to an existing data repository. It can be a file, for example: file:///test.owl, but also database or a remote location (http://abc.com/test.owl).</p><p>Return value</p><p>True on success</p><p>Exceptions</p><p>IOException If the URI is not reachable.</p><p>© ISO/IEC 2009 — All rights reserved 147 ISO/IEC CD 23006-2 6.24.1.2 Operation to save the current data set in a given location.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ Store(String sURI): boolean</p><p>Java sample code public boolean Store(String sURI) throws IOException; Method description</p><p>This method is employed to store a set of assertions from a URI</p><p>Parameters sURI Any URI making reference to an existing data repository. It can be a file, for example: file:///test.owl, but also database or a remote location (http://abc.com/test.owl).</p><p>Return value</p><p>True on success</p><p>Exceptions</p><p>IOException If the URI is not reachable.</p><p>6.24.1.3 Operation to unload the current data set.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ Unload(): boolean</p><p>Java sample code public boolean Unload(); Method description</p><p>This method is employed to unload the assertions in the ontology. No individuals will remain after calling this operation.</p><p>Parameters</p><p>Return value</p><p>True on success</p><p>148 © ISO/IEC 2009 — All rights reserved 6.24.1.4 Operation to create a user in the ontology.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ CreateUser(String sUserId): boolean</p><p>Java sample code public boolean CreateUser(String sUserId) throws ExistingIdException, BadIdException; Method description</p><p>This method is employed to create a new User, identified by a user id. The new User does not assume any role a priori.</p><p>Parameters sUserId Any User identification string, provided the following: </p><p> It can only start with alphabetic characters: [a-z][A-Z]</p><p> It can be made of alphanumeric characters [a-z][A-Z][0-9], explicitly excluding blank spaces, commas or any other non- alphanumeric character</p><p>Return value</p><p>True on success</p><p>Exceptions</p><p>ExistingIdException If the identifier already exists.</p><p>BadIdException The id string is malformed</p><p>© ISO/IEC 2009 — All rights reserved 149 ISO/IEC CD 23006-2 6.24.1.5 Operation to delete a user in the ontology.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ DeleteUser(String sUserId): boolean</p><p>Java sample code public boolean DeleteUser(String sUserId) throws ExistingIdException, BadIdException; Method description</p><p>This method is employed to unregister an existing User, identified by a user id. </p><p>Parameters sUserId Any User identification string, provided the following: </p><p> It can only start with alphabetic characters: [a-z][A-Z]</p><p> It can be made of alphanumeric characters [a-z][A-Z][0-9], explicitly excluding blank spaces, commas or any other non- alphanumeric character</p><p>Return value</p><p>True on success</p><p>Exceptions</p><p>ExistingIdException If the user identifier does not exist in the ontology.</p><p>BadIdException The id string is malformed</p><p>150 © ISO/IEC 2009 — All rights reserved 6.24.1.6 Operation for the execution of an action by a User.</p><p>© ISO/IEC 2009 — All rights reserved 151 ISO/IEC CD 23006-2 Interface MVCOInterface</p><p>Method Syntax</p><p>+ ExecuteAction(String sActedBy, String sAction, String sIPEntity, String sNewIPEntity): boolean</p><p>Java sample code public boolean ExecuteUser(String sActedBy, String sAction, String sIPEntity, String sNewIPEntity) throws BadIdException, IllegalActionException, ExistingIdException; Method description</p><p>This method is employed for an User to execute an Action over an IPEntity, possible creating a new IPEntity.</p><p>Parameters sActedBy User id acting the action. sAction Action to be performed (e.g. “Render”, “CreateWork”) sIPEntity Existing IPEntity id over which the Action is executed sNewIPEntity New id to for the IPEntity to be created –if needed. This parameter may be an empty string, or a null.</p><p>Return value</p><p>True on success</p><p>Exceptions</p><p>IllegalActionException An operation cannot be performed over a given IPEntity.</p><p>ExistingIdException The given id points to a non-existing User, Action or IPEntity.</p><p>152 © ISO/IEC 2009 — All rights reserved BadIdException An id string is malformed, either in the User, the Action or the IPEntity</p><p>6.24.1.7 Operation to create a permission.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ CreatePermission(String sIssuedBy, String sAction, String sActedOver, String sActedBy): boolean</p><p>Java sample code public boolean CreatePermission(String sIssuedBy, String sAction, String sActedOver, String sActedBy) throws BadIdException, IllegalActionException, ExistingIdException; Method description</p><p>This method is employed for an User to generate the permission to execute an Action over an IPEntity, by other User.</p><p>Parameters sIssuedBy User id issuing the permission. sAction Action to be performed (e.g. “Render”, “CreateWork”) sActedOver Existing IPEntity id over which the Action is authorised to be executed sActedBy User id of the authorised User.</p><p>Return value</p><p>True on success</p><p>Exceptions</p><p>IllegalActionException An operation cannot be performed over the given IPEntity.</p><p>ExistingIdException The given id points to a non-existing User, Action or IPEntity.</p><p>BadIdException An id string is malformed, either in the User, the Action or the IPEntity</p><p>© ISO/IEC 2009 — All rights reserved 153 ISO/IEC CD 23006-2 6.24.1.8 Operation to launch a query.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ Query(String sSPARQL): Vector<String></p><p>Java sample code public Vector<String> Query(String sSPARQL) throws MalformedQueryException; Method description</p><p>This method is employed to retrieve information on the ontology. The operation always retrieves information. </p><p>Note that along 2009 “SPARQL Update” is likely to be declared W3C recommendation. If this happens, queries could change the ontology, radically altering the scope of this function.</p><p>Parameters sSPARQL String with the SPARQL query. This string has to be formed according to the W3C recommendation2.</p><p>Return value</p><p>A vector with the strings returned as a response to the query, if this was successful, or empty vector i fit was not.</p><p>Exceptions</p><p>MalformedQueryException The query execution returned an error.</p><p>2 http://www.w3.org/TR/rdf-sparql-query/</p><p>154 © ISO/IEC 2009 — All rights reserved 6.24.1.9 Operation to validate an action.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ Validate(String sAction, String sActedOver, String sActedBy): boolean</p><p>Java sample code public boolean Validate(String sAction, String sActedOver, String sActedBy) throws BadIdException, IllegalActionException, ExistingIdException; Method description</p><p>This method is employed to validate an action, giving a boolean answer (yes/no).</p><p>Parameters sAction Action to be authorised (e.g. “Render”, “CreateWork”) sActedOver Existing IPEntity id over which the Action is being validated. sActedBy User id of the User under validation.</p><p>Return value</p><p>True if the operation is validated.</p><p>Exceptions</p><p>IllegalActionException An operation cannot be performed over the given IPEntity.</p><p>ExistingIdException The given id points to a non-existing User, Action or IPEntity.</p><p>BadIdException An id string is malformed, either in the User, the Action or the IPEntity</p><p>© ISO/IEC 2009 — All rights reserved 155 ISO/IEC CD 23006-2 6.24.1.10 Operation to get the list of registered users.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ getUsers(): Vector<String></p><p>Java sample code public Vector<String> getUsers(); Method description</p><p>This method is employed to retrieve the list of existing Users</p><p>Return value</p><p>A vector with the String of the User id´s registered in the ontology.</p><p>Exceptions</p><p>6.24.1.11 Operation to get the list of registered IPEntities.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ getIPEntities(): Vector<String></p><p>Java sample code public Vector<String> getIPEntities(); Method description</p><p>This method is employed to retrieve the list of existing IPEntities</p><p>Return value</p><p>A vector with the String of the IPEntities id´s registered in the ontology.</p><p>Exceptions</p><p>156 © ISO/IEC 2009 — All rights reserved 6.24.1.12 Operation to get the rights owner of a given IPEntity.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ getRightsOwner(String sIPEntity): String</p><p>Java sample code public boolean getRightsOwner(String sAction, String sActedOver, String sActedBy) throws BadIdException, ExistingIdException; Method description</p><p>This method retrieves the rights Owner of a given IPEntity. It does not retrieve which users have been authorised in valid Parmissions.</p><p>This method is redundant and given for convenience, as the query could be performed by means of the Query method. </p><p>Parameters sIPEntity IPEntity to be queried</p><p>Return value</p><p>User id owner of the IPEntity rights.</p><p>Exceptions</p><p>ExistingIdException The given id points to a non-existing User, Action or IPEntity.</p><p>BadIdException An id string is malformed, either in the User, the Action or the IPEntity</p><p>© ISO/IEC 2009 — All rights reserved 157 ISO/IEC CD 23006-2 6.24.1.13 Operation to geg the IPEntity origin of a given IPEntity.</p><p>Interface MVCOInterface</p><p>Method Syntax</p><p>+ getOrigin(String sIPEntity): String</p><p>Java sample code public String getOrigin(String sIPEntity) throws BadIdException, ExistingIdException; Method description</p><p>This method returns the IPEntity that has given rise to the current IPEntity. If the IPEntity is a Work, a null will be returned.</p><p>This method is redundant and given for convenience, as the query could be performed by means of the Query method. </p><p>Parameters sIPEntity IPEntity to be queried</p><p>Return value</p><p>IPEntity id from which the given IPEntity id comes from.</p><p>Exceptions</p><p>ExistingIdException The given id points to a non-existing User, Action or IPEntity.</p><p>BadIdException An id string is malformed, either in the User, the Action or the IPEntity</p><p>158 © ISO/IEC 2009 — All rights reserved 6.25 Domain Engine APIs</p><p>6.25.1 Domain Management</p><p><<Interface>> DomainManagement + createDomain(dmdURI:String, credential:DomainCredentialType, domainExpiration:ValidityTimeMetered, maxNumOfDevices:Long, maxNumOfUsers:Long, maxFrequencyOfUpdateDevice:Duration, maxFrequencyOfUpdateUser:Duration):String + renewDomain(dmdURI: String, credential:DomainCredentialType, domainID:String, domainExpiration:ValidityTimeMetered, maxNumOfDevices:Long, maxNumOfUsers:Long, maxFrequencyOfUpdateDevice:Duration, maxFrequencyOfUpdateUser:Duration):void + deleteDomain(dmdURI:String, credential:DomainCredentialType, domainID:String):void + addDevice(dmdURI:String, credential:DomainCredentialType, domainID:String, expiration:ValidityTimeMetered):void + addUser(dmdURI:String, credential:DomainCredentialType, domainID:String, userID :String, expiration:ValidityTimeMetered):void + renewDevice(dmdURI:String, credential:DomainCredentialType, domainID:String, expiration: ValidityTimeMetered):void + renewUser(dmdURI:String, credential:DomainCredentialType, domainID:String, userID:String, expiration: ValidityTimeMetered):void + leaveDevice(dmdURI:String, credential:DomainCredentialType, domainID:String):void + leaveUser(dmdURI:String, credential:DomainCredentialType, domainID:String, userID :String):void</p><p>DomainManagementException Exception</p><p>6.25.1.1 Create Domain</p><p>Creation of a Domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ createDomain(dmdURI:String, credential:DomainCredentialType, domainExpiration: ValidityTimeMetered, maxNumOfDevices:Long, maxNumOfUsers:Long, maxFrequencyOfUpdateDevice:Duration, maxFrequencyOfUpdateUser:Duration):String</p><p>Java sample code public interface DomainManagement { public String createDomain(String dmdURI, DomainCredentialType credential, ValidityTimeMetered domainExpiration, Long maxNumOfDevices,Long maxNumOfUsers, Duration maxFrequencyOfUpdateDevice, Duration maxFrequencyOfUpdateUser) throws DomainManagementException } Method description</p><p>This method is used to create a Domain which is managed by the specified Domain Management Device (DMD). Using this method, Domain administrator can specify the conditions for Domain initialisation. If the Domain creation is successful, this method returns the Domain ID given by the Domain Identification Device (DoID).</p><p>Parameters dmdURI The URI of DMD which will create the Domain</p><p>© ISO/IEC 2009 — All rights reserved 159 ISO/IEC CD 23006-2 and manage the newly created Domain credential The Domain administrator’s credential. With this credential, DMD checks if the Domain administrator has enough privilege to create the Domain, and the management of the newly created Domain request this credential domainExpiration The valid period of the newly created Domain. maxNumOfDevices The maximum number of the Devices which can be added to the newly created Domain maxNumOfUsers The maximum number of the Users which can be added to the newly created Domain maxFrequencyOfUpdateDevice The shortest duration permitted between a device leaving and re-registering with this Domain maxFrequencyOfUpdateUser The shortest duration permitted between a User leaving and re-registering with this Domain</p><p>Return value</p><p>The Domain ID given by the Domain Identification Device (DoID).</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.2 Renew Domain</p><p>Renewal of a Domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ renewDomain(dmdURI: String, credential:DomainCredentialType, domainID:String, domainExpiration:ValidityTimeMetered, maxNumOfDevices:Long, maxNumOfUsers:Long, maxFrequencyOfUpdateDevice:Duration, maxFrequencyOfUpdateUser:Duration):void</p><p>Java sample code public interface DomainManagement { public void renewDomain(String dmdURI, DomainCredentialType credential, String domainID,ValidityTimeMetered domainExpiration, Long maxNumOfDevices, Long maxNumOfUsers, Duration maxFrequencyOfUpdateDevice, DurationaxFrequencyOfUpdateUser) throws DomainManagementException } Method description</p><p>This method is used to renew the specified Domain. Using this method, Domain administrator can renew the conditions of the Domain. This method requires the Domain administrator’s credential.</p><p>Parameters dmdURI The URI of DMD which is managing the Domain to be renewed</p><p>160 © ISO/IEC 2009 — All rights reserved credential The Domain administrator’s credential. With this credential, DMD checks if the Domain administrator has enough privilege to renew the Domain domainID The ID of the Domain to be renewed domainExpiration The valid period of the renewed Domain maxNumOfDevices The maximum number of the Devices in the renewed Domain maxNumOfUsers The maximum number of the Users in the renewed Domain maxFrequencyOfUpdateDevice The shortest duration permitted between a device leaving and re- registering with the renewed Domain maxFrequencyOfUpdateUser The shortest duration permitted between a User leaving and re- registering with the renewed Domain</p><p>Return value void</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.3 Delete Domain</p><p>Cancellation of a Domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ deleteDomain(dmdURI:String, credential:DomainCredentialType, domainID:String):void</p><p>Java sample code public interface DomainManagement { public void deleteDomain(String dmdURI, DomainCredentialType credentialType, String domainID) throws DomainManagementException } Method description</p><p>This method is used to delete the specified Domain. This method requires the Domain administrator’s credential. </p><p>Parameters dmdURI The URI of DMD which is managing the Domain to be deleted credential The Domain administrator’s credential, with which DMD checks if the Domain administrator has enough privilege to delete the Domain domainID The ID of the Domain to be deleted</p><p>Return value</p><p>Void</p><p>© ISO/IEC 2009 — All rights reserved 161 ISO/IEC CD 23006-2</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.4 Add Device</p><p>Add a Device to a Domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ addDevice(dmdURI:String, credential:DomainCredentialType, domainID:String, expiration:ValidityTimeMetered):RELLicense</p><p>Java sample code public interface DomainManagement {</p><p> public RELLicense addDevice(String dmdURI, DomainCredentialType credential, String domainID,ValidityTimeMetered expiration) throws DomainManagementException</p><p>}</p><p>Method description</p><p>This method is used to add a Device to the specified Domain. If this addition process is successful, the Device acquires the Domain membership license from DMD. This method requires the Domain member’s credential.</p><p>Parameters dmdURI The URI of DMD which is managing the Domain to which the Device is added credential The Domain member credential, with which DMD checks if this request has enough privilege to add the Device domainID The ID of the Domain to which the Device is added expiration the expiration date of the Domain membership</p><p>Return value</p><p>The domain membership license.</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.5 Add User</p><p>Add a User to a Domain</p><p>162 © ISO/IEC 2009 — All rights reserved Interface DomainManagement</p><p>Method Syntax</p><p>+ addUser(dmdURI:String, credential:DomainCredentialType, domainID:String, userID:String, expiration:ValidityTimeMetered):RELLicense</p><p>Java sample code public interface DomainManagement { public RELLicense addUser(String dmdURI, DomainCredentialType credential, String domainID, String userID, ValidityTimeMetered expiration) throws DomainManagementException } Method description</p><p>This method is used to add a User to the specified Domain. If this addition process is successful, the User acquires the Domain membership license from DMD. This method requires the Domain member’s credential.</p><p>Parameters dmdURI The URI of DMD which is managing the Domain to which the User is added credential The Domain member credential, with which DMD checks if the User has enough privilege to be added domainID The ID of the Domain to which the User is added userID The ID of the User to which the User is added expiration the expiration date of the Domain membership</p><p>Return value</p><p>The domain membership license.</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.6 Renew Device</p><p>Renew membership of a Device of a Domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ renewDevice(dmdURI:String, credential:DomainCredentialType, domainID:String, expiration: ValidityTimeMetered):RELLicense</p><p>Java sample code public interface DomainManagement { public void renewDevice(String dmdURI, DomainCredentialType credential, String domainID,ValidityTimeMetered expiration) throws DomainManagementException } Method description</p><p>© ISO/IEC 2009 — All rights reserved 163 ISO/IEC CD 23006-2</p><p>This method is used to renew the Device in the specified Domain. If this addition process is successful, the Device acquires the Domain membership license from DMD. This method requires the Domain member’s credential.</p><p>Parameters dmdURI The URI of DMD which is managing the Domain, the Device of which is renewed credential The Domain member credential, with which DMD checks if the Device has enough privilege to be renewed domainID The ID of the Domain, the Device of which is renewed expiration the new expiration date of the Domain membership</p><p>Return value</p><p>The domain membership license.</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.7 Renew User</p><p>Renew membership of a User of a Domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ renewUser(dmdURI:String, credential:DomainCredentialType, domainID:String, userID:String, expiration: ValidityTimeMetered):RELLicense</p><p>Java sample code public interface DomainManagement { public RELLicense renewUser(String dmdURI, DomainCredentialType credential, String domainID, String userID, ValidityTimeMetered expiration) throws DomainManagementException } Method description</p><p>This method is used to renew the User in the specified Domain. If this addition process is successful, the User acquires the Domain membership license from DMD. This method requires the Domain member’s credential.</p><p>Parameters dmdURI The URI of DMD which is managing the Domain, the User of which is renewed credential The Domain member credential, with which DMD checks if the User has enough privilege to be renewed domainID The ID of the Domain, the User of which is renewed</p><p>164 © ISO/IEC 2009 — All rights reserved userID The ID of the User to be renewed expiration the new expiration date of the Domain membership</p><p>Return value</p><p>The domain membership license.</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.8 Leave Device</p><p>Remove a Device from a Domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ leaveDevice(dmdURI:String, credential:DomainCredentialType, domainID:String):void</p><p>Java sample code public interface DomainManagement { public void leaveDevice(String dmdURI, DomainCredentialType credential, String domainID) throws DomainManagementException } Method description</p><p>This method is used to remove a Device from the specified Domain. If this addition process is successful, the Device loses the Domain membership license. This method requires the Domain member’s credential.</p><p>Parameters dmdURI The URI of DMD which is managing the Domain, the Device of which is removed credential The Domain member credential, with which DMD checks if the Device has enough privilege to be removed domainID The ID of the Domain, the Device of which is removed</p><p>Return value void</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.9 Leave User</p><p>Remove a User from a Domain</p><p>Interface DomainManagement</p><p>© ISO/IEC 2009 — All rights reserved 165 ISO/IEC CD 23006-2 Method Syntax</p><p>+ leaveUser(dmdURI:String, credential:DomainCredentialType, domainID:String, userID:String):void</p><p>Java sample code public interface DomainManagement { public void leaveUser(String dmdURI, DomainCredentialType credential, String domainID, String userID) throws DomainManagementException } Method description</p><p>This method is used to remove a User from the specified Domain. If this addition process is successful, the User loses the Domain membership license. This method requires the Domain member’s credential.</p><p>Parameters dmdURI The URI of DMD which is managing the Domain, the Device of which is removed credential The Domain member credential, with which DMD checks if the User has enough privilege to be removed domainID The ID of the Domain, the Device of which is removed userID The ID of the User to be removed</p><p>Return value void</p><p>Exceptions</p><p>DomainManagementException</p><p>6.25.1.10 RequestLocalDomainID</p><p>Request a domain identification service for the identification of a new domain</p><p>Interface DomainManagement</p><p>Method Syntax</p><p>+ requestLocalDomainID():RELLicense</p><p>Java sample code public interface DomainManagement { public void requestLocalDomainID() throws DomainManagementException } Method description</p><p>This method is used to request a domain identification service for the identification of a new domain. If this addition process is successful, the domain identification service returns an unique identification.</p><p>Return value</p><p>The Domain ID given by the Domain Identification Device (DoID).</p><p>166 © ISO/IEC 2009 — All rights reserved Exceptions</p><p>DomainManagementException</p><p>6.25.2 Domain Access</p><p>This section comprises of the APIs to query the DMD for the status of a Domain</p><p><<Interface>> DomainAccess</p><p>+ requestDomainManageInfo (dmdURI:String, domainID :String, credential:DomainCredentialType ):void</p><p>DomainAccessException Exception</p><p>6.25.2.1 RequestDomainPublicInfo</p><p>Request DMD(Domain Management Device ) for information about a specific Domain.</p><p>Tipically License Provider Device or a Content Creation Device issues this request.</p><p>Interface DomainAccess</p><p>Method Syntax</p><p>+ requestDomainPublicInfo(dmdURI:String, domainID:String):DomainPublicInfo</p><p>Java sample code public interface DomainManagement { public DomainPublicInfo requestDomainPublicInfo (String dmdURI,String domainID) throws DomainManagementException } Method description</p><p>This method is used to request Domain Management Device (DMD) for the information about a specific Domain. (e.g. how many Devices are part of the Domain, when is the Domain expiring, what is the Domain Public Key, etc.). If the request was successful, it returns DomainPublicInfo with the given domain ID. </p><p>Return value</p><p>DomainPublicInfo which includes </p><p>DomainID,DomainKey,Registration,Expiration,MaximumNumberOfUsers, MaximumFrequencyOfUpdateUser, UserID,expiration of the user,MaximumNumberOfDevices,MaximumFrequencyOfUpdateDevice,DeviceID and expiration of the device.</p><p>© ISO/IEC 2009 — All rights reserved 167 ISO/IEC CD 23006-2 Exceptions</p><p>DomainAccessException</p><p>6.25.3 Domain Usage</p><p>Collection of interface functions to access and manage the Domain usage information and the Domain rights information in the local storage</p><p><<Interface>> DomainUsage + getDomainLicense (domainID :String):RELLicense + storeDomainLicense (domainLicense :RELLicense):void + deleteDomainLicense (domainID :String) :void + updateDomainLicense (domainLicense :RELLicense) :void + startDomainUse (domainID :String, contentGroupID :List<String>, startTime :XMLGregorianCalendar) :void + endDomainUse(domainID :String, endTime:XMLGregorianCalendar):void</p><p>DomainUsageException Exception</p><p>6.25.3.1 Get Domain License</p><p>Read Domain license from local storage</p><p>Interface DomainUsage</p><p>Method Syntax</p><p>+ getDomainLicense(domainID:String):RELLicense</p><p>Java sample code public interface DomainUsage { public void getDomainLicense(String domainID) throws DomainUsageException } Method description</p><p>This method is used to read a Domain license which is locally stored in the End User Device (EUD). Using this method, EUD can use the Domain license when the EUD wants to access a content licensed to the Domain. If getDomainLicense is successfully done, this method returns the Domain license.</p><p>Parameters</p><p>168 © ISO/IEC 2009 — All rights reserved domainID The string representation of Domain indentification.</p><p>Return value</p><p>The license for the domain which has the given DomainID.</p><p>Exceptions</p><p>DomainUsageException</p><p>6.25.3.2 Store Domain License</p><p>Write domain license to local storage</p><p>Interface DomainUsage</p><p>Method Syntax</p><p>+ storeDomainLicense(strDomainID:String, DomainLicense:RELLicense):void</p><p>Java sample code public interface DomainUsage { public void storeDomainLicense(String strDomainID, RELLicense domainLicense) throws DomainUsageException } Method description</p><p>This method is used to write a Domain license to a local storage in the End User Device (EUD). This method is most likely used after addDevice method. Using this method, EUD can store the Domain license for later use in preparation of an access to content licensed to the Domain.</p><p>Parameters domainLicense Domain license.</p><p>Return value none</p><p>Exceptions</p><p>DomainUsageException</p><p>6.25.3.3 Delete Domain License</p><p>Delete Domain license from local storage</p><p>Interface DomainUsage</p><p>Method Syntax</p><p>+ deleteDomainLicense(domainID:String) :void</p><p>Java sample code</p><p>© ISO/IEC 2009 — All rights reserved 169 ISO/IEC CD 23006-2 public interface DomainUsage { public void deleteDomainLicense(String domainID) throws DomainUsageException } Method description</p><p>This method is used to delete a Domain license from a local storage in the End User Device (EUD). This method is most likely used after leaveDevice method.</p><p>Parameters domainID The string representation of Domain indentification.</p><p>Return value none</p><p>Exceptions</p><p>DomainUsageException</p><p>6.25.3.4 Update Domain License</p><p>Update domain license in the local storage</p><p>Interface DomainUsage</p><p>Method Syntax</p><p>+ updateDomainLicense(strDomainID:String, domainLicense:RELLicense) :void</p><p>Java sample code public interface DomainUsage { public void updateDomainLicense(String strDomainID, RELLicense domainLicense) throws DomainUsageException } Method description</p><p>This method is used to update a Domain license in a local storage in the End User Device (EUD). This method is most likely used after renewDevice method. Using this method, EUD can overwrite the domain license stored in the local storage which has the same domain ID with the given Domain license.</p><p>Parameters domainLicense Domain license.</p><p>Return value none</p><p>Exceptions</p><p>DomainUsageException</p><p>170 © ISO/IEC 2009 — All rights reserved 6.25.3.5 Start Domain Use</p><p>This method is used by an application, e.g. an End User Device part of a Domain to signal MXM to start recording usage data in the secure storage </p><p>Interface DomainUsage</p><p>Method Syntax</p><p>+ startDomainUse(domainID:String, contentGroupID:List<String>, startTime:XMLGregorianCalendar) :void</p><p>Java sample code public interface DomainUsage { public void startDomainUse(String domainID, List contentGroupID, XMLGregorianCalendar startTime) throws DomainUsageException } Method description</p><p>This method is used to write usage data in a local storage in the End User Device (EUD). This method must be called when the EUD starts the usage of a content with Domain license. Using this method, EUD can write a new record of usage data in the local storage.</p><p>Parameters domainID The string representation of Domain indentification of the Domain that the content belongs. contentGroupID ContentGroupID of a content licensed to the Domain that EUD used. startTime Time when EUD starts the usage of a Domain licensed content.</p><p>Return value none</p><p>Exceptions</p><p>DomainUsageException</p><p>6.25.3.6 End Domain Use</p><p>This method is used by an application, e.g. an End User Device part of a Domain to signal MXM to stop recording usage data in the secure storage </p><p>Interface DomainUsage</p><p>Method Syntax</p><p>+ endDomainUse(domainID:String, endTime:XMLGregorianCalendar):void</p><p>Java sample code public interface DomainUsage { public void endDomainUse(String domainID, XMLGregorianCalendar startTime) throws DomainUsageException } Method description</p><p>© ISO/IEC 2009 — All rights reserved 171 ISO/IEC CD 23006-2</p><p>This method is used to finalize a record of usage data in a local storage in the End User Device (EUD). This method must be called when the EUD ends the usage of a content with Domain license. Using this method, EUD can search for a usage data record with the given Domain ID and finalize it with given endTime.</p><p>Parameters domainID The string representation of Domain indentification of the Domain that a content belongs. endTime Time when EUD ends the usage of a Domain licensed content.</p><p>Return value none</p><p>Exceptions</p><p>DomainUsageException</p><p>6.25.4 UnlicensedSimultaneousUseNotice</p><p>Send a notification to DMD when an unlicensed simultaneous usage was detected at EUD.</p><p>Interface DomainUsage</p><p>Method Syntax</p><p>+ unlicensedSimultaneousUseNotice(useData:UseData):void</p><p>Java sample code public interface DomainUsage { public void unlicensedSimultaneousUseNotice (UseData useData) throws DomainUsageException } Method description</p><p>This method is used to send a notification to the Domain Manage Device(DMD). This method must be called when an unlicensed simultaneous usage was detected at the End User Device (EUD). Using this method, DMD can make decision if the domain license should sustain its validity at the next domain renewal.</p><p>Parameters useData A set of records that is created at each usage of a domain licensed content. Each record includes the identification of a device that used the content, contentGroupID of the content and the information about when the content was used. </p><p>Return value none</p><p>Exceptions</p><p>172 © ISO/IEC 2009 — All rights reserved DomainUsageException</p><p>6.26 Rendering Engine APIs</p><p>6.26.1 getNumberOfScreens</p><p>Interface Interface MXMDevice{</p><p>Void getNumberOfScreens(Int numberOfScreens);</p><p>};</p><p>Method Syntax</p><p>+ getNumberOfScreens(Int numberOfScreens):</p><p>C sample code</p><p>Method description</p><p>This method queries the number of screens available.</p><p>Parameters numberOfScreens: Number of screens.</p><p>Return value</p><p>Exceptions</p><p>6.26.2 getScreen</p><p>Interface Interface MXMDevice{</p><p>MXMScreen getScreen(Int indexOfScreen);</p><p>};</p><p>Method Syntax</p><p>+ getScreen(Int indexOfScreen):</p><p>C sample code</p><p>Method description</p><p>This method returns an interface to one of the screens.</p><p>© ISO/IEC 2009 — All rights reserved 173 ISO/IEC CD 23006-2 Parameters indexOfScreen: Index of screen.</p><p>Return value</p><p>Exceptions</p><p>6.26.3 getAspectRatio</p><p>Interface Interface MXMScreen{</p><p>Void getAspectRatio(Int aspectX, Int aspectY);</p><p>};</p><p>Method Syntax</p><p>+ getAspectRatio(Int aspectX, Int aspectY):</p><p>C sample code</p><p>Method description</p><p>This method queries the aspect ratio of the output device, e.g. a 16:9 display.</p><p>Parameters aspectX: Nominator. aspectY: Denominator.</p><p>Return value</p><p>Exceptions</p><p>6.26.4 getNativeResolution</p><p>Interface Interface MXMScreen{</p><p>Void getNativeResolution(Int resolutionX, Int resolutionY);</p><p>};</p><p>Method Syntax</p><p>174 © ISO/IEC 2009 — All rights reserved + getNativeResolution(Int resolutionX, Int resolutionY):</p><p>C sample code</p><p>Method description</p><p>This method queries the native pixel resolution of the output device, e.g. a 1920x1080 display.</p><p>Parameters resolutionX: Horizontal number of pixels in output. resolutionY: Vertical number of pixels in output.</p><p>Return value</p><p>Exceptions</p><p>6.26.5 setResolution</p><p>Interface Interface MXMView{</p><p>Void setResolution(Int resolutionX, Int resolutionY);</p><p>};</p><p>Method Syntax</p><p>+ setResolution(Int resolutionX, Int resolutionY):</p><p>C sample code</p><p>Method description</p><p>This method overrides the default resolution that will be used to initialize the new MXMView. Default is the same resolution as the parent MXMView or the resolution of the area that the view covers within its parent MXMView.</p><p>Parameters resolutionX: Horizontal number of pixels in buffer. resolutionY: Vertical number of pixels in buffer.</p><p>Return value</p><p>Exceptions</p><p>© ISO/IEC 2009 — All rights reserved 175 ISO/IEC CD 23006-2</p><p>6.26.6 setPixelFormat</p><p>Interface Interface MXMView{</p><p>Void setPixelFormat(Bool rgb, Bool alpha, Bool indexed);</p><p>};</p><p>Method Syntax</p><p>+ setPixelFormat(Bool rgb, Bool alpha, Bool indexed):</p><p>C sample code</p><p>Method description</p><p>This method overrides the default pixel format that will be used to initialize the new MXMView. No explicit format may be selected, but the best format of the platform will be chosen.</p><p>Parameters rgb: Whether RGB or YUV will be used. alpha: Whether an alpha channel will be used. indexed: Whether the pixels will use a lookup table.</p><p>Return value</p><p>Exceptions</p><p>6.26.7 setPosition</p><p>Interface Interface MXMView{</p><p>Void setPosition(Int positionX, Int positionY);</p><p>};</p><p>Method Syntax</p><p>+ setPosition(Int positionX, Int positionY):</p><p>C sample code</p><p>Method description</p><p>176 © ISO/IEC 2009 — All rights reserved This method overrides the position within the parent MXMView, default is 0,0.</p><p>Parameters positionX: Horizontal position within parent MXMView. positionY: Vertical position within parent MXMView.</p><p>Return value</p><p>Exceptions</p><p>6.26.8 setSize</p><p>Interface Interface MXMView{</p><p>Void setSize(Int sizeX, Int sizeY);</p><p>};</p><p>Method Syntax</p><p>+ setSize(Int sizeX, Int sizeY):</p><p>C sample code</p><p>Method description</p><p>This method overrides the output size used to display within the parent MXMView. Default is the same as the size of the MXMView..</p><p>Parameters sizeX: Horizontal number of pixels in buffer. sizeY: Vertical number of pixels in buffer.</p><p>Return value</p><p>Exceptions</p><p>6.26.9 initialize</p><p>Interface Interface MXMView{</p><p>© ISO/IEC 2009 — All rights reserved 177 ISO/IEC CD 23006-2</p><p>Void initialize(MXMView parentView) raise(Exceptions);</p><p>};</p><p>Method Syntax</p><p>+ initialize(MXMView parentView):</p><p>C sample code</p><p>Method description</p><p>This method is used to intialize the MXMView based on the default settings or values as overridden by above methods.</p><p>Parameters parentView: Specifies the parent MXMView or MXMScreen used to show this view. When no parentView is specified, the new view will be placed within the system's root view (default screen).</p><p>Return value</p><p>Exceptions</p><p>6.26.10 setEventHandler</p><p>Interface Interface MXMBox{</p><p>Void setEventHandler(MXMEventHandler eventHandler);</p><p>};</p><p>Method Syntax</p><p>+ setEventHandler(MXMEventHandler eventHandler):</p><p>C sample code</p><p>Method description</p><p>This method places an event handler to be called for input events belonging to this box.</p><p>Parameters eventHandler: Event handler of application.</p><p>Return value</p><p>178 © ISO/IEC 2009 — All rights reserved Exceptions</p><p>6.26.11 setSource</p><p>Interface Interface MXMVideoBox{</p><p>Void setSource(Int videoID);</p><p>};</p><p>Method Syntax</p><p>+ setSource(Int decoderID):</p><p>C sample code</p><p>Method description</p><p>This method selects the video source which to display.</p><p>Parameters videoID: ID of video source.</p><p>Return value</p><p>Exceptions</p><p>6.26.12 renderGeometry</p><p>Interface Interface MXMGraphicsBox{</p><p>Void renderGeometry(MeshBuffer geometry);</p><p>};</p><p>Method Syntax</p><p>+ renderGeometry(MeshBuffer geometry):</p><p>C sample code</p><p>© ISO/IEC 2009 — All rights reserved 179 ISO/IEC CD 23006-2 Method description</p><p>This method is used to render a geometry within the view. The given geometry will be rendered to fill the complete view. To render within a portion of a view, a sub view has to be created.</p><p>Parameters geometry: The MeshBuffer to be rendered.</p><p>Return value</p><p>Exceptions</p><p>6.26.13 showAnimation</p><p>Interface Interface MXMGraphicsBox{</p><p>Void showAnimation(MeshBuffer geometry, VertexBuffer[] animation);</p><p>};</p><p>Method Syntax</p><p>+ showAnimation(MeshBuffer geometry, VertexBuffer[] animation):</p><p>C sample code</p><p>Method description</p><p>This method is used to show an animation within the view. The given animation will be rendered to fill the complete view. To render within a portion of a view, a sub view has to be created. This method creates a new thread to run the animation and do subsequent renderings.</p><p>Parameters geometry: The MeshBuffer to be rendered. animation: A VertexBuffer vector with length equals the number of frames to be rendered and used to update the VertexBuffer component of the geometry.</p><p>Return value</p><p>Exceptions</p><p>180 © ISO/IEC 2009 — All rights reserved 6.26.14 showBBAAnimation</p><p>Interface Interface MXMGraphicsBox{</p><p>Void showBBAAnimation(MeshBuffer geometry, BBABuffer animation);</p><p>};</p><p>Method Syntax</p><p>+ showBBAAnimation(MeshBuffer geometry, BBABuffer animation):</p><p>C sample code</p><p>Method description</p><p>This method is used to show an animation of an object using BBA within the view. The given animation will be rendered to fill the complete view. To render within a portion of a view, a sub view has to be created. This method creates a new thread to run the animation and do subsequent renderings.</p><p>Parameters geometry: The MeshBuffer to be rendered. animation: A BBABuffer used to update the VertexBuffer component of the geometry.</p><p>Return value</p><p>Exceptions</p><p>7 MXM Application APIs</p><p>7.1.1 Open</p><p>This method is used to open a Digital Item or a file conforming to ISO/IEC 21000-9 in order to access to the data it contains.</p><p>Interface DRMManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ open (file : File): void</p><p>Java sample code public interface DRMManager { public DCIParser open(File file) throws ContentParsingException, BadPropertyException, MalformedContentElementException; } Method description</p><p>This method is used to open either an XML file containing a Digital Item or to extract the Digital Item from a file</p><p>© ISO/IEC 2009 — All rights reserved 181 ISO/IEC CD 23006-2 conforming to ISO/IEC 21000-9 in order to access to the data contained in the Digital Item</p><p>Parameters file Either a file containing a Digital Item conforming to ISO/IEC 21000-2 as restricted by ISO/IEC 23000-5, or an ISO/IEC 21000-9 file containing a Digital Item.</p><p>Return value</p><p>An instance of DCIParser (see Error: Reference source not found) providing an easy access to the data contained in the Digital Item.</p><p>Exceptions</p><p>ContentParsingException This exception is thrown if an error occurs while extracting the DCI from the DCF (if the file in input was an ISO/IEC 21000-9 file</p><p>BadPropertyException This exception is thrown if the properties used to configure the DRMManager class were not correctly set.</p><p>MalformedContentElementException This exception is thrown if the file in input is not a valid XML or an ISO/IEC 21000-9 files.</p><p>7.1.2 CanAccessContentElement</p><p>This method is used to determine whether a content element part of a content item that was previously opened by the DRMManager can be accessed or not.</p><p>Interface DRMManager (see Error: Reference source not found)</p><p>Method Syntax</p><p>+ canAccessContentElement (contentElementID : string, rightElement : RightElement): UseContentElementResult</p><p>Java sample code public interface DRMManager { public UseContentElementResult canAccessContentElement(String contentElementID, RightElement rightElement) throws UnsupportedFeatureException, BadPropertyException, SecurityManagerException, LicenseAuthorisationException; } Method description</p><p>This method is used to determine whether a content element part of a content item that was previously opened by the DRMManager can be accessed or not. If yes (e.g. a license is available, a decryption key is available, etc.), then the DRMManager will also configure the media framework used to access the resource (if required) by creating an appropriate media chain including one or more IPMP Tools in order to use the resource as per useType. MXM will look for a license granting the right which is needed to access the content item in the Digital Item. If no license exist, then it will search it in the SecurityManager. If a valid license is found, and the content element to acces is protected, MXM will set-up the IPMP Tools specified in the IPMP Information Descriptors of the proteted content element, authenticate them, initialise them with decryption keys and other information from the IPMP Information Descriptor so that the content element can be accessed (e.g. the media framework can proceed with rendering the content).</p><p>Parameters</p><p>182 © ISO/IEC 2009 — All rights reserved contentElementID The identifier of the content element to be accessed. This method assumes that the content item that was previously opened contains a content element with the specified contentElementID. rightElement The type of access required (e.g. play, governedCopy, etc.). See Error: Reference source not found for more information.</p><p>Return value</p><p>An object of type UseContentElementResult (see Error: Reference source not found) containing the result of whether the content element can be accessed in the way specified by useType. If yes, the returned object will contain all the information necessary to access the content element (its location, etc.), while in case the action is not allowed, the return parameter will contain the reason while the access was denied. </p><p>Exceptions</p><p>UnsupportedFeatureException This exception is thrown if an error occurs while accessing the content element and it licenses</p><p>BadPropertyException This exception is thrown if the properties used to configure the DRMManager class were not correctly set.</p><p>MalformedContentElementException This exception is thrown if the content element to access is not valid</p><p>SecurityManagerException This exception is thrown if an error occurs while retrieving licenses and/or security information from the SecurityManager</p><p>LicenseAuthorisationException This exception is thrown if an error occurred while validating a license against a query</p><p>7.1.3 Play</p><p>7.1.4 PresentDigitalItem</p><p>7.1.5 Adapt(namespaceURI:string, ued:string, resourceURI:string)</p><p>7.1.6 ProcessDigitalItem</p><p>© ISO/IEC 2009 — All rights reserved 183 ISO/IEC CD 23006-2 Annex A (normativ)</p><p>MXM Interfaces</p><p>A.1 ContentMetadataEngine</p><p>A.2 Mpeg7</p><p>A.3 Mpeg7Parser</p><p>A.4 MXMEngineResponse</p><p>A.5 MXMUseEnvDescr</p><p>184 © ISO/IEC 2009 — All rights reserved Annex B (normativ)</p><p>MXM Exceptions</p><p>B.1 ContentMetadataEngineException</p><p>B.2 MXMDescrException</p><p>© ISO/IEC 2009 — All rights reserved 185 ISO/IEC CD 23006-2 Bibliography</p><p>[1] ISO/IEC 23001-3, Information technology -- MPEG systems technologies -- Part 3: XML IPMP messages [2] “XML-Encryption Syntax and Processing” - W3C Recommendation 10 December 2002. http://www.w3.org/TR/xmlenc-core/. [3] “XML-Signature Syntax and Processing” - W3C Recommendation 12 February 2002. http://www.w3.org/TR/xmldsig-core/. [4] “XML SchemaXML Schema Part 1: Structures Second Edition W3C Recommendation 28 October 2004”, http://www.w3.org/2001/XMLSchema [5] Document Object Model (DOM) Requirements. W3C Working Draft 19-April-2001, http://www.w3.org/TR/DOM-Requirements [6] W3C Candidate Recommendation, “XML Path Language (XPath) 2.0”, 3 November 2005, http://www.w3.org/TR/xpath20/ [7] IETF, Network Working Group, Request for Comments: 2459 "Internet X.509 Public Key Infrastructure Certificate and CRL Profile", http://www.ietf.org/rfc/rfc2459.txt </p><p>186 © ISO/IEC 2009 — All rights reserved</p>
Details
-
File Typepdf
-
Upload Time-
-
Content LanguagesEnglish
-
Upload UserAnonymous/Not logged-in
-
File Pages197 Page
-
File Size-