In recent years, massively multiplayer online (“MMO”) computer applications, such as massively multiplayer role-playing games (“MMORPGs”), have become extremely popular not only with serious gamers, but also with casual gamers and other Internet users. One example of a MMO computer application enables a participant to create and develop a fictional character in a virtual world. The fictional character is usually associated with an avatar or some other visual representation that enables other participants to recognize the particular fictional character. A given participant may develop, among other things, a storyline, a reputation, and attributes of her fictional character by interacting in the virtual world via the fictional character. Other examples of MMO computer applications may not involve the creation of a virtual world representation of the participant.
The virtual world typically includes an environment with a variety of virtual locations containing a variety of virtual objects. In some cases, the virtual locations and the virtual objects mimic realistic locations and objects, while in other cases, the virtual locations and virtual objects are fanciful creations. MMO computer applications generally permit the fictional character to travel across the virtual locations and interact with the virtual objects and other fictional characters.
One significant factor in the growth of MMO computer applications has been the ability for participants to create and distribute their own content to other participants within the MMO environment. Common types of user-generated content include multimedia files, such as text, picture, audio, and video files, as well as application plug-ins that may be utilized within a MMO computer application to provide additional functionality. An example of an application plug-in may be a graphical user interface (“GUI”) embedded within a social networking website that enables participants of the website to rate movies. In MMO environments, user-generated content may also include avatars and three-dimensional virtual objects, such as cars, buildings, and the like.
There currently exists no convenient way for a content creator to license her content to other participants within the MMO environment. In many cases, the content creator is limited to providing her content for free. More sophisticated content creators may be able to create and enforce licensing terms separate and apart from the MMO computer application. However, the typical recreational content creator does not have the ability and/or resources to define and enforce licensing terms.
It is with respect to these considerations and others that the disclosure made herein is presented.
Technologies are described herein for a machine-readable and enforceable license. In particular, through the utilization of the technologies and concepts presented herein, a user may utilize a licensing interface to generate a machine-readable and enforceable license. The license may be utilized to manage the distribution of user-generated content, define a range of allowable uses for the user-generated content, and specify a license fee structure that determines the compensation a content creator is to receive for the sale of the user-generated content.
According to one aspect presented herein, a computer program generates a machine-readable and enforceable license. The computer program receives a first set of input and a second set of input. The first set of input defines a range of allowable uses for a content item generated by a user. The second set of input defines an amount of compensation for the user for a sale of the content item. A high-level representation of a license is generated based on the first set of input and the second set of input. For example, an Extensible Markup Language (“XML”) representation of the license may be generated.
It should be appreciated that although the features presented herein are described in the context of user-generated content within a MMO computer application, these features may be utilized with user-generated content configured for any suitable application including, but not limited to, other types of computer applications (e.g., a word processor) as well as online social communities. It should also be appreciated that the above-described subject matter may also be implemented as a computer-controlled apparatus, a computer process, a computing system, or as an article of manufacture such as a computer-readable medium. These and various other features will be apparent from a reading of the following Detailed Description and a review of the associated drawings.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended that this Summary be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
The following detailed description is directed to technologies for providing a machine-readable and enforceable license. Through the utilization of the technologies and concepts presented herein, a licensing interface enables a user to generate a machine-readable and enforceable license. The license may define a level of distribution of user-generated content, a range of allowable uses for the user-generated content, and a license fee structure that determines the compensation a user, such as a content creator, is to receive for the sale of the user-generated content. Examples of user-generated content include, but are not limited to, multimedia files, avatars, three-dimensional virtual objects, and computer applications. A user may utilize a licensing wizard to generate a high-level representation of a license. Alternatively, the user may generate the high-level representation of the license separate from the licensing wizard and upload the high-level representation of the license via an upload license interface. A compiler may generate a machine-readable and enforceable representation of the license by compiling the high-level representation of the license into object code. Alternatively, the high-level representation of the license may be directly utilized without compiling the high-level representation of the license into object code. The licensing wizard, the upload license interface, and the compiler may be included in a license interface, as described herein. It should be appreciated that the licensing wizard and the upload license interface described herein are merely illustrative ways to provide the license, and other ways to provide the license may be utilized as contemplated by those skilled in the art.
While the subject matter described herein is presented in the general context of program modules that execute in conjunction with the execution of an operating system and application programs on a computer system, those skilled in the art will recognize that other implementations may be performed in combination with other types of program modules. Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the subject matter described herein may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
Solely for illustrative purposes, the licensing interface is described herein in the context of a virtual world. Further, the licensing interface is described herein with reference to participant-generated content created by participants of the virtual world. It should be appreciated that the licensing interface is not so limited and may be utilized in a variety of other contexts and with any content. In particular, the licensing interface may be utilized with any content that is distributed through a content and/or service provider. Examples of content may include, but are not limited to, multimedia content, such as text, pictures, audio, video, and combinations thereof, as well as computer applications, such as application plug-ins that add new functionality to the content and/or service provider. Other examples of content include avatars and three-dimensional virtual objects. Examples of content and/or service providers may include, but are not limited to, social network websites (e.g., FACEBOOK from FACEBOOK INCORPORATED) and multimedia distribution services (e.g., ZUNE MARKETPLACE from MICROSOFT CORPORATION, ITUNES from APPLE INCORPORATED).
As used herein, the term virtual world refers to a computer-implemented environment, which may include simulated, lifelike environments as well as fanciful, non-existing environments. Exemplary virtual worlds may include any massively multiplayer online (“MMO”) computer application including, but not limited to, massively multiplayer online role-playing games (“MMORPGs”), virtual social communities, and virtual reality computer applications. In one embodiment, the MMO computer application simulates a real world environment. For example, the virtual world may be defined by a number of rules, such as the presence of gravity or the lack thereof. In other embodiments, the MMO computer application includes a fanciful environment that does not simulate a real world environment.
The virtual world is generally inhabited by avatars, which are virtual or symbolic representations of real world participants (hereinafter referred to as participants). As such, each avatar is typically associated with and controlled by a particular participant. Avatars may include two-dimensional and/or three-dimensional images. Through the virtual world, the avatars may interact with other avatars, as well as with virtual objects. Virtual objects may include virtual representations of real world objects, such as houses, cars, billboards, clothes, and soda cans, as well as fanciful creations, such as a teleportation machine or a flying car. The avatars and the virtual objects utilized in the virtual world may or may not be animated images.
In the following detailed description, references are made to the accompanying drawings that form a part hereof, and which are shown by way of illustration specific embodiments or examples. Referring now to the drawings, in which like numerals represent like elements through the several figures, aspects of a computing system and methodology for providing a machine-readable and enforceable license will be described. In particular,
The client device 104 may be any suitable processor-based device, such as a computer or a gaming device. Exemplary gaming devices include the XBOX and the XBOX 360 from MICROSOFT CORPORATION, the WII from NINTENDO COMPANY, LIMITED, and the PLAYSTATION 3 and the PSP from SONY CORPORATION. Although not so illustrated in
As shown in
The virtual world client module 120 may include any suitable component for accessing the virtual world server module 110. In one example, the virtual world client module 120 may be a computer application configured to locally provide at least a portion of the virtual world for the client device 104. In this way, the amount of data retrieved from the server computer 102 by the client device 104 to generate the virtual world may be reduced. In another example, the virtual world client module 120 may be a web browser configured to retrieve the virtual world from the virtual world server module 110. Since many public computers, such as those found in Internet cafes, commonly have a web browser installed and prohibit the installation of new computer applications, providing participants a way to access the virtual world via the web browser may provide greater accessibility and convenience.
As shown in
The license database 114 stores one or more licenses, such as a high-level and machine-independent representation of a license 124 (hereinafter referred to as “high-level license 124”). In one embodiment, the high-level license 124 is created via a licensing wizard 128 provided by the interface module 118. The licensing wizard 128 may provide a series of dialogs and predefined options that guide the content creator through a process to generate the high-level license 124. In another embodiment, the high-level license 124 is uploaded from the client device 104 via the upload license interface 130 also provided by the interface module 118.
In another embodiment, the high-level license 124 may be partially or entirely disconnected from the server 102. In this way, the high-level license 124 may be portable without any reliance on the server 102. For example, the high-level license 124 may be stored on the client device 104 or other suitable device. To protect the integrity of the high-level license 124, the high-level license 124 may include a digital certificate 136 that is signed by a private key. In one embodiment, the digital certificate 136 includes signed digests of both the high-level license 124 and the participant-generated content 126. The private key may be generated by a trusted, central authority (e.g., the administrator of the virtual world) and stored in a secure location.
When a client application, such as the virtual world client module 120, accesses the high-level license 124, the client application may utilize a corresponding public key to verify the digital certificate 136. The digital certificate may be utilized to validate that the high-level license 124 has been approved by the central authority or other source, that the high-level license 124 has not been improperly changed, and that the high-level license 124 is cryptographically associated with the content described by the high-level license 124.
By separating the high-level license 124 from the server 102, offline (i.e., non-network) transactions involving the high-level license 124 become available. For example, after a first client application obtains the participant-generated content item 126 via the server 102, the first client application also obtains the high-level license 124. Since the high-level license 124 includes the digital certificate 136, the first client application can present the participant-generated content item 126 to a second client application offline. By utilizing the public key, the second client application can render the participant-generated content item 126 to users while honoring the licensing terms of the high-level license 124.
Upon generating or uploading the high-level license 124, a compiler 132 may generate a machine-readable and enforceable representation of the license 134 (hereinafter referred to as “machine-readable license 134”) by compiling the high-level license 124 into object code. Alternatively, the high-level license 124 may be directly utilized without compiling the high-level license 124 into object code. The machine-readable license 134 may also be stored in the license database 114, as illustrated in
In one embodiment, the enforcement of the licenses, such as the high-level license 124 and the machine-readable license 134, stored in the license database 114, with respect to distributing the participant-generated content item 126, is facilitated by way of the digital rights management (“DRM”) module 106. In particular, DRM may be utilized to manage, among other distribution and usage factors, the number of computing devices that can access the participant-generated content item 126, the number of times that the participant-generated content item 126 can be accessed, the length of time for which the participant-generated content item 126 can be accessed, the number of times that the participant-generated content item 126 can be transferred, the number of times that the participant-generated content item 126 can be copied, and the number of times that a computer-readable medium (e.g., CD-ROM, DVD-ROM) containing the participant-generated content item 126 can be created. DRM may also determine the amount of money to be charged for performing these distribution and usage factors. Each of these distribution and usage factors may be defined by the content creator via the interface module 118. It should be appreciated that other suitable methods for enforcing the licenses stored in the license database 114 may also be used.
In one embodiment, the DRM module 106 is a web server. An exemplary DRM process executed by the DRM module 106 may operate as follows for the participant-generated content item 126 (e.g., a multimedia file). First, the DRM module 106 encrypts the content item 126 with a key. The encrypted content item 126 includes a uniform resource locator (“URL”) pointing to the DRM module 106. The encrypted content item 126 may be provided to the virtual world, and a participant may obtain the encrypted content item 126 at the client device 104. When the participant attempts to access the encrypted content item 126, the participant is directed to the DRM module 106 where the participant can purchase or otherwise obtain the high-level license 124 from the license database 114. If the participant agrees to the terms of the high-level license 124, the high-level license 124 may be copied to the client device 104. In this case, the high-level license 124 may include the key with which to unlock the encrypted content item 126. The participant may then access the content item 126 subject to the limitations set forth by the machine-readable and enforceable license 124 stored in the client device 104. It should be appreciated that the above described DRM process is merely illustrative. Other suitable DRM processes may be utilized as contemplated by those skilled in the art.
A participant (e.g., the content creator) or other user (e.g., a broker representing the content creator) may access the interface module 118 via an interface access module 122. In one embodiment, the interface module 118 provides a website or other remote interface. In this embodiment, the interface access module 122 may be a web browser, which enables the participant to remotely access the website provided by the interface module 118. In other embodiments, the interface access module 122 may be any suitable computer application that provides the participant access to the interface module 118.
When a participant, such as the content creator, desires to access the virtual world, the participant may initiate the virtual world client module 120 to establish a session with the virtual world server module 110 via the network 108. During the session, the virtual world server module 110 may transmit data (e.g., environment layouts, avatar movements of other participants) associated with the virtual world to the virtual world client module 120. Similarly, the virtual world client module 120 may transmit data from associated input devices to the virtual world server module 110. The virtual world client module 120 in conjunction with the interface access module 122 may further interact with the interface module 118, as briefly mentioned above, to upload the participant-generated content item 126 from the client device 104 to the content database 116 for distribution in the virtual world and to create or upload the high-level license 124 to the license database 114 to manage the distribution of the participant-generated content item 126 to other participants, manage the usage of the participant-generated content item 126 by other participants, and define the compensation the content creator is to receive from the distribution of the participant-generated content item 126.
A number of exemplary screenshots of a licensing interface provided by the interface module 118 will now be presented with reference to
Turning now to
Turning now to
The first screenshot 300 includes a usage column 302 and a definition column 304 associated with the usage column 302. Corresponding to the usage column 302 and the definition column 304 is a first row 306, a second row 308, a third row 310, and a fourth row 312. The usage column 302 includes a number of times for copy criterion at the first row 306, a number of times for use criterion at the second row 308, a type of use criterion at the third row 310, and a number of times for transfer criterion at the fourth row 312. As used herein, the number of times for copy criterion specifies the number of times in which the participant-generated content item 126 can be copied. For example, the DRM module 106 may provide only a limited number of licenses for the participant-generated content item 126. According to the first row 306 of the definition column 304, the participant 202 has defined the number of times for copy criterion as one. As such, the participant-generated content item 126 can be copied only once. As used herein, the number of times for use criterion specifies the number of times in which the participant-generated content item 126 can be used. For example, the DRM module 106 may maintain a count for the number of times the participant-generated content item 126 is used. Once the count surpasses a threshold number, the DRM module 106 may terminate access to the participant-generated content item 126. According to the second row 308 of the definition column 304, the participant 202 has defined the number of times for use criterion as unlimited. As such, the participant-generated content item 126 has no limitation on the number of uses.
As used herein, the type of use criterion specifies whether the participant-generated content item 126 is for commercial and/or non-commercial use. The limitation of the type of use may be stated in an agreement provided to other participants prior to the purchase of the participant-generated content item 126. In this case, the other participants may purchase the participant-generated content item 126 only after agreeing the terms of the agreement. According to the third row 310 of the definition column 304, the participant 202 has defined the type of use as non-commercial. As such, the participant-generated content item 126 may not be used for commercial use. As used herein, the number of times for transfer criterion specifies the number of times the participant-generated content item 126 can be transferred from one computing device to another. For example, the DRM module 106 may maintain a count on the number of times the participant-generated content item 126 is transferred. Once the count surpasses a threshold number, the DRM module 106 may disable the transfer operation. According to the fourth row 312 of the definition column 304, the participant 202 has defined the number of times for transfer criterion as two. As such, the participant-generated content item 126 may be transferred only twice. Once the participant 202 has selected and defined the applicable criteria from the plurality of available criteria, the licensing wizard 128 proceeds to the second screenshot 400.
Referring to
The screenshot 400 includes a compensation selection column 402 and a revenue selection column 404. Corresponding to the compensation selection column 402 and the revenue selection column 404 is a first row 406, a second row 408, a third row 410, and a fourth row 412. The compensation selection column 402 illustrates a number of different compensation criteria from which the participant 202 can choose. In particular, the compensation selection column 402 includes a free for lifetime criterion at the first row 406, a flat fee for lifetime criterion at the second row 408, a variable fee criterion at the third row 410, and a revenue share criterion at the fourth row 412. As used herein, the free for a lifetime criterion specifies that the participant-generated content item 126 is free for an unlimited duration. The flat fee for lifetime criterion specifies a single, unchanged rate to access the participant-generated content item 126. The variable fee criterion specifies a variable rate to access the participant-generated content item 126. For example, while the participant 202 may be compensated one amount under one circumstance, the participant 202 may be compensated by another amount under another circumstance. The variable rate may depend on any number of suitable factors specified by the interface module 118. In one example, the variable rate may be based, at least in part, on the popularity of one or more of the participant 202 generating the content item 126, the content item 126, and the other participants purchasing and/or accessing the participant-generated content item 126. The revenue share criterion specifies compensation in the form of revenue sharing when the participant-generated content item 126 is, for example, placed with advertising or utilized to sell a product or service. In the example shown in
In response to receiving the selection of the revenue share criterion, the interface module 118 provides the revenue selection column 404. The revenue selection column 404 illustrates a number of revenue sharing criteria from which the participant 202 can choose. In particular, the revenue selection column 404 includes a commission of advertisement (“ad”) revenue option at the first row 406, a percentage of ad revenue option at the second row 408, a commission of sales revenue option at the third row 410, and a percentage of sales revenue option at the fourth row 412. As used herein, the commission of ad revenue option specifies that the participant 202 receives a flat amount for each advertisement view. The percentage of ad revenue option specifies that the participant 202 receives a percentage of the revenue generated for each advertisement view. The commission of sales revenue option specifies that the participant 202 receives a flat amount for each unit of the participant-generated content item 126 sold. The percentage of sales revenue option specifies that the participant 202 receives a percentage of the revenue generated for each unit of the participant-generated content item 126 sold. In the example shown in
Turning now to
Turning now to
Upon receiving any participant input related to the range of allowable uses and the compensation, the interface module 118 generates the license 124 based on the participant input provided via the licensing wizard 128. In one embodiment, the high-level license 124 is in the form of a schema, such as Extensible Markup Language (“XML”) schema or other suitable schema language. In other embodiments, the license 124 may be in the form of a high-level programming language, such as C. After the interface module 118 generates the high-level license 124, the compiler 132 may generate the machine-readable license 134 by compiling the high-level license 124 into object code. Alternatively, the high-level license 124 may be used directly without compiling the high-level license 124 into object code. The machine-readable license 134 may be utilized by the DRM module 106 or other suitable enforcement mechanism for enforcing the licensing conditions specified in the high-level license 124. Alternatively, the high-level license 124 may be directly utilized by the DRM module 106 or other suitable enforcement mechanism. The high-level license 124 may further include a pointer 602, which associates the high-level license 124 to the machine-readable license 134.
The high-level license 124 and the machine-readable license 134 may be stored in the license database 114. Each participant-generated content item, such as the participant-generated content item 126, may be associated with one or more high-level licenses and machine-readable licenses. Through the use of the compiler 132, a participant-generated license is limited only by the restrictions of the schema or programming language of the license and/or the programming skill of the participant generating the license. In particular, the participant 202 may be able to generate simple licenses with few control statements as well as complex licenses with numerous control statements. As such, the licensing terms contained in licenses generated in the manner proposed herein may vary more greatly and may be more complex than licenses generated by conventional means.
Referring now to
Referring now to
At operation 704, the interface module 118 further receives a selection of one or more compensation options. As previously mentioned, the selected compensation options define a level of compensation provided to the participant 202 for the distribution of the participant-generated content item 126. The participant 202 may select compensation options via the licensing wizard 128. For example, upon accessing the licensing wizard 128, the participant 202 may select one or more compensation options from the compensation selection column 402. After the interface module 118 receives the selection of compensation options, the routine 700 continues to operation 706.
At operation 706, the interface module 118 generates the high-level license 124 based on the selected allowable uses and the selected compensation options. In one embodiment, the high-level license 124 is a high-level representation of the selected allowable uses and the selected compensation options. For example, high-level representation may include a schema representation, such as XML, or a programming language representation, such as C. Upon generating the high-level license 124, the routine 700 continues to operation 708.
At operation 708, the interface module 118 generates the machine-readable license 134. In particular, the compiler 132 may compile the high-level license 124 to generate object code that forms the machine-readable license 134. Alternatively, the high-level license 124 may be directly utilized without compiling the high-level license 124 into object code. The machine-readable license 134 or the high-level license 124 may be utilized by any suitable machine managing the distribution and/or usage of the participant-generated content item 126. For example, the machine-readable license 134 or the high-level license 124 may be utilized by a content provider that sells the participant-generated content item 126 to other participants in the virtual world. Upon generating the machine-readable license 134, the routine 700 continues to operation 710, where the interface module 118 inserts the pointer 602 into the high-level license 124. In one embodiment, the pointer 602 points to the machine-readable license 134, thereby associating the high-level license 124 with the machine-readable license 134.
Referring now to
By way of example, and not limitation, computer-readable media may include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules, or other data. For example, computer-readable media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROM, digital versatile disks (“DVD”), HD-DVD, BLU-RAY, or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computer 800.
According to various embodiments, the computer 800 may operate in a networked environment using logical connections to remote computers through a network such as the network 108. The computer 800 may connect to the network 108 through a network interface unit 810 connected to the bus 806. It should be appreciated that the network interface unit 810 may also be utilized to connect to other types of networks and remote computer systems. The computer 800 may also include an input/output controller 808 for receiving and processing input from a number of input devices (not shown), including a keyboard, a mouse, a microphone, and a game controller. Similarly, the input/output controller 808 may provide output to a display or other type of output device (not shown).
Based on the foregoing, it should be appreciated that technologies for a machine-readable and enforceable license are presented herein. Although the subject matter presented herein has been described in language specific to computer structural features, methodological acts, and computer readable media, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features, acts, or media described herein. Rather, the specific features, acts and mediums are disclosed as example forms of implementing the claims.
The subject matter described above is provided by way of illustration only and should not be construed as limiting. Various modifications and changes may be made to the subject matter described herein without following the example embodiments and applications illustrated and described, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.