FEDERATED DOWNLOAD OF DIGITAL CONTENT TO WIRELESS DEVICES
A content descriptor is received at a download server on a network from a remote content server, which is coupled to the download server through a computer network. The content descriptor is indicative of a selection by a user transmitted from a wireless client device to the remote content server and relating to a digital product hosted by the remote content server. The content descriptor is used by the download server to obtain the digital product from the remote content server. The digital product is then downloaded from the download server to the wireless client device via a wireless network. The content descriptor may include information such as a reference for use by the download server in locating the digital product, information describing the digital product, price information relating to the digital product, and/or information specifying a licensee of the digital product.
Latest UNWIRED PLANET, LLC Patents:
- Method and arrangements in a telecommunication system
- Self configuring and optimization of cell neighbors in wireless telecommunications networks
- Self configuring and optimization of cell neighbors in wireless telecommunications networks
- Method and arrangements in a telecommunication system
- Self configuration and optimization of cell neighbors in wireless telecommunications
This application claims the benefit of Provisional U.S. Patent application No. 60/504,010, filed on Sep. 17, 2003 and entitled, “Federated Download Model”, which is incorporated herein by reference.
FIELD OF THE INVENTIONAt least one embodiment of the present invention pertains to systems and methods for providing digital content to wireless services subscribers, and more particularly, to a federated download model for providing digital content to wireless services subscribers.
BACKGROUNDPersonal mobile communication/computing devices, such as cellular telephones, personal digital assistants (PDAs) and two-way pagers, can be referred to collectively as “mobile devices” or “wireless devices”. The current state-of-the-art of mobile devices has advanced far beyond that of their predecessors. For example, early cellular telephones used analog signals to communicate over wireless telecommunications networks (or simply “wireless networks”) and were nothing more than mobile telephones. Today's most advanced cellular telephones are all digital and provide many other functions in addition to telephony capability. For example, many of the latest generation of mobile telephones (and other mobile devices) allow their users to play games, access World Wide Web pages, exchange email, exchange and download files, exchange short messaging service (SMS) messages, and send and receive video.
With new mobile devices providing a wider range of capabilities, there is increasing demand among the users of these devices (i.e., wireless services subscribers) for new and interesting types of digital content that can be used on these mobile devices, such as games and other applications, images, ring tones, screensavers, wallpapers, etc. Although newer mobile devices often come pre-provisioned with certain digital products when first acquired by the subscriber, it is desirable to allow subscribers to acquire additional digital products for use in their mobile devices, as such products become available.
Certain obstacles have thus far hindered the ability to make a wide range of digital products available to wireless subscribers. On computer networks such as the Internet, typically some computers act as servers, by providing information or services to other computers that act as the clients. Users can search for information and visit servers as they please, as long as the servers provide them with access. Each server is responsible for access control and what information it provides to whom; this is referred to as a “federated” model.
The opposite of a federated model is a so-called “walled garden” model. A network modeled after a walled garden enforces strict access control to content and information. Only the server, or servers, inside the “walls” can be accessed by users. External servers can only provide content if the content is submitted to servers inside the walls.
Service providers such as wireless Communication Service Providers (CSPs) are generally concerned with problems related to the kind of content delivered to the client devices using their networks. These problems include the following:
-
- Quality concerns—The issue is whether the content is going to be properly consumed by the client device. If the quality is poor, the customer support issues will be costly.
- Content delivery—Depending on device characteristics and content type, the delivery method to the client device may vary. Sophisticated delivery mechanisms are required to be in place with each server that intends to serve content to consumer devices.
- Rights management—The issue is whether the owner of the content can be assured that only client devices with rights to the content can use the content.
- Revenue—Providing content for download is a service that can be monetized (i.e., generate revenue/profit). The issue is how a CSP can ensure that the content that is downloaded is properly billed.
Since the walled garden model offers strict control over available content, it addresses the foregoing problems. However, the walled garden model has its own set of problems, including:
-
- Consumers are restricted to the services, content and information that are available in the walled garden. This restriction can be viewed as very undesirable, especially by a consumer group that is used to the Internet.
- Scalability can become a problem when all consumers access a constrained resource, such as the limited number of servers available in the walled garden.
- Service management becomes critical to the CSP. If the service does not provide a compelling user experience, service use and adoption will suffer. Many CSPs do not have core expertise in this field.
- Lack of choice of name-brand content may result from poor content and supplier management by the CSP.
Therefore, the basic problem becomes: How can a federated network of content servers be provided to consumers, without losing the ability to charge for content usage, manage digital rights, ensure content quality, and deliver content to client devices in a robust and secure way? Thus, it is desirable to have a solution for providing digital content to wireless devices which combines the strict control of a walled garden with the freedom provided by a federated model.
SUMMARY OF THE INVENTIONThe present invention includes a method of operating a download server on a network. A content descriptor is received at the download server from a remote content server, which is coupled to the download server through a computer network. The content descriptor is indicative of a selection by a user transmitted from a wireless client device to the remote content server and relating to a digital product hosted by the remote content server. The content descriptor is used by the download server to obtain the digital product from the remote content server. The digital product is then downloaded from the download server to the wireless client device via a wireless network.
In another aspect of the invention, a content server on a network hosts a digital product available for download to multiple wireless client devices. The content server receives a selection by a user from a wireless client device, the selection relating to the digital product. The wireless client device then contacts a remote download server, which is coupled through a computer network to the content server, after the selection is made. The content server sends a content descriptor indicative of the selection to the remote download server. The content server then sends the digital product to the remote download server, to be downloaded from the download server to an end user.
Other aspects of the invention will be apparent from the accompanying figures and from the detailed description which follows.
One or more embodiments of the present invention are illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
A method and apparatus for federated download of digital content to wireless devices are described. Note that in this description, references to “one embodiment” or “an embodiment” mean that the feature being referred to is included in at least one embodiment of the present invention. Further, separate references to “one embodiment” or “an embodiment” in this description do not necessarily refer to the same embodiment; however, such embodiments are also not mutually exclusive unless so stated, and except as will be readily apparent to those skilled in the art from the description. For example, a feature, structure, act, etc. described in one embodiment may also be included in other embodiments. Thus, the present invention can include a variety of combinations and/or integrations of the embodiments described herein.
As used in this description, the terms “digital content”, “digital product”, “content”, and “product” are used interchangeably to mean software and/or data embodying things such as games and other applications, applets or the like; images; screensavers; wallpaper; ring tones; etc., particularly (but not necessarily exclusively) those designed for use in mobile devices such as cellular telephones, PDAs and other small-footprint wireless/mobile devices. For convenience the terms “purchase” or “buy” are used to mean either actual purchase or any other conventional way in which a subscriber can acquire rights to use or posses digital content (e.g., by acquiring a license).
OverviewAs described in greater detail below, a system which manages publication, purchase and delivery of digital content is implemented in a network server system on a network. The server system includes an application server referred to herein as the “download server”. The download server may be implemented in the form of a single physical computing platform, or it may be implemented in the form of multiple physical computing platforms coupled to each other on a network, such as a local area network (LAN). Digital content providers can publish and manage their products using the download server via a computer network, such as the Internet, and can make their products available to wireless services subscribers through the download server for purchase or licensing. Subscribers can access the server system via wireless networks to purchase rights to download and use the digital content on their wireless communication devices.
A number of mobile client devices 21 (e.g., 21A, 21B, etc.) operate on each wireless network 22. A number of servers 25 (e.g., 25A, 25B, etc.) operate on the computer network 24 to provide a variety of services for the mobile devices 21 and/or to one or more non-wireless client devices 29 coupled to the computer network 24. For example, the servers 25 may include World Wide Web servers, file servers, application servers, etc.
Each gateway 23 can be operated by the operator of the wireless network (the “wireless carrier”) to which it is directly connected. Each gateway 23 provides an interface between a particular wireless network 22 and the computer network 24 (e.g., the Internet), providing routing and, if necessary, appropriate protocol translation and/or content transcoding. In some cases, the gateway 23 may be a standalone device or system. In other cases, the gateway 23 may be part of a more-capable server system that provides additional value-added services to users of client devices 21; such as a proxy service, a provisioning manager, etc. An example of such a gateway is the Mobile Access Gateway available from Openwave Systems of Redwood City, Calif.
A download server 1 in accordance with the present invention is connected to the computer network 24, either directly (as shown) or indirectly. The download server 1 may be operated by a wireless carrier.
Download ServerThe product catalog 37 facilitates discovery and purchase of digital products by subscribers. The product catalog 37 is a database and an electronic commerce storefront that controls the subscriber shopping experience. Content providers submit content into the product catalog 37. Product administrators associated with the download server 1 approve and publish content in the product catalog 37, which subscribers can then discover and purchase.
The delivery manager 31 is the download server's interface to the various subscribers and is responsible for delivering purchased digital content to subscribers. Once the download server 1 verifies that the subscriber owns the right to the content, the delivery manager 31 can perform content delivery. The delivery manager 31 is responsible for applying the appropriate delivery channel based on any of a number of factors, such as content type, device capability, and subscriber preference. The delivery manager 31 further is responsible for invoking one of multiple available protocol handlers which is appropriate for communicating with each requesting mobile device.
The digital rights manager 32 is responsible for performing digital rights management (DRM) operations, as described further below, based at least partially on information stored in the personal vault 36. Among other things, the digital rights manager 32 is responsible for tracking product usage and license renewal purchase. The personal vault 36 stores, on a subscriber-by-subscriber basis, information to facilitate DRM, such as product licenses and/or other “purchase” information of the products purchased by each subscriber. This allows a subscriber to remove downloaded content from a mobile device without losing rights to the product, or to recover products on a device in cases of device hard reset, loss, etc.
The subscriber database 34 stores various information on all subscribers served by the download server 1. The stored information may include, for example, wireless device type and identifier number, contact information, account information, etc. for each subscriber. The content cache 35 stores digital products that have been downloaded from content providers, in order to speed up subsequent downloads from the download server 1 to client devices 21.
The content analysis manager 33 manages a process of verifying content quality and compliance with various requirements when the content is initially obtained by the download server 1 from a content provider (e.g., compliance with its declared type, content structure resource utilization, etc.). Content must pass the content analysis process satisfactorily before being made available for download to subscribers.
A download server such as described above can be implemented in a walled garden model, as illustrated in
The walled garden model for the discovery, purchasing and downloading of content has various shortcomings, such as noted above. Accordingly, it is desirable to avoid the normal problems associated with a walled garden model, while also avoiding the above-noted problems normally associated with a federated model.
Federated ModelA federated model according to certain embodiments of the invention is described now with reference to
A significant challenge in building a federated solution is to come up with a simple yet powerful mediation protocol between the download server 1 and the content providers 2. The protocol must be simple to make it possible for third-party content providers 2 to integrate with a carrier-hosted download server. The protocol must be powerful so that download server 1 can add sufficient value in the content delivery value chain. Such a protocol will now be described.
The protocol, according to certain embodiments of the invention, is based on an entity referred to herein as a Universal Content Descriptor (UCD). The UCD allows the download server 1 to add value for third-party content providers in the areas of DRM, content instrumentation, content delivery, content monetization, content validation, and content caching. In certain embodiments, the UCD is an extensible markup language (XML) document which includes some or all of the following fields (not all of these fields are used in every embodiment or use case):
-
- Vendor name
- Product version
- Product name with locale specified
- Reference ID—unique identifier to a subscription plan or product bundle
- Info URI—a reference (uniform resource identifier) to a more detailed offering page by the content provider
- Content URI—a reference to the content binary file or another UCD. This can be zero or more.
- MIME-type of the content file
- Usage Model—The download usage model, with locale specified
- Purchase price and currency code
- subscriber who will own the license (not necessarily the same as the subscriber who made the purchase)
- Success URL (uniform resource locator)—redirection of the client once delivery is complete
- Failure URL—redirection of the client in the event of a failure on the download server.
Once content is discovered from a third-party content site, the client device 21 is redirected to the download server 1. The download server 1 uses the UCD URI passed as a parameter in the redirected URL to obtain a UCD from the content provider 2. Client redirection may be performed in any of several ways. In certain embodiments, for example, the content provider 2 codes the UCD directly into the product catalog. In other embodiments, a network gateway, such as gateway 23 in
Referring now to
Referring now to
The download server 1 recognizes that subscriber B is completing a purchase initiated by subscriber A. Following the same operations as 612 through 619 in
In certain embodiments, the download server 1 can support various subscription based models, which would normally be defined by the content provider. A subscription plan is a logical association of product offerings, renewable on a periodic basis, which can be based on specified product criteria, such as category, MIME-type/Content type, etc, vendor, etc. The following are examples of possible subscription plans, although the download server 1 can theoretically support any subscription plan defined by a content provider:
-
- Subscription by All
- Subscription by Vendor
- Subscription by MIME-type/Content type
- Subscription by Category
- Subscription by One product
In the above examples, which have the format, Subscription by [X], the user has access to all products in X if the user subscribes to X.
A subscription plan makes use of the UCD in the following ways different from a regular purchased content:
-
- Info URI—Subscribers may be redirected to the content provider site to a more appropriate page describing the offerings of the plan. The download server will only contain the license for the subscription but will not offer the subscriber the list of offerings.
- Reference ID—A unique identifier created by the provider to refer to a particular subscription plan. This identifier can then be used by subsequent content delivery to refer to the same subscription plan recognized by the download server.
- Content URI—If this field is present, the download server delivers the content after confirmation of the AOC. If not, the user is redirected to the Success URI after confirmation.
Refer again to
Once a content provider has sent the download server 1 a valid reference ID, that reference ID then becomes a link to a subscription plan with product offerings defined by the content provider. The download server 1 does not need to know which products can be offered by the content provider, as long as that reference ID is used to acknowledge that the content is part of a particular subscription plan. Refer again to
In certain embodiments, the download server 1 also supports bundling of digital products. Product bundling refers to associating a single price with two or more contents. A product bundle can come in the form of: a) single price, multiple contents, single usage model; or b) single price, multiple contents, multiple usage model per content.
A product bundle entails different use of the UCD than with single content delivery. For a product bundle, the first UCD retrieved by the download server 1 includes the following fields:
-
- Info URI—Subscribers may be redirected to the provider site to a more appropriate page describing the product bundles.
- Reference ID—A unique identifier created by the provider to refer to a particular product bundle. This identifier can then be used by subsequent content delivery to refer to the same product bundle recognized by the download server.
- Content URI—This field contains one or more references to content UCDs. Each UCD represents a unique piece of content with its full price and usage model.
- Price—The price of the product bundle
- Usage Model—A model describing that this is a product bundle
Each UCD described by the Content URI represents a product that is part of the product bundle. The price described becomes the full price of the individual product when it is purchased separately from the bundle. The usage model is also unique to this product.
Although subscribers will have paid one price for the product bundle, they will have access to the bundled content from their personal vaults, each possibly with its own usage model. The use case then becomes exactly the same as those in
The above-described download manager 1 can be implemented in the form of one or more conventional server-class computer systems. Similarly, a content server 25 such as described above can also be implemented in the form of one or more conventional server-class computer systems.
The processing system shown in
The processor(s) 130 may be, or may include, one or more programmable general-purpose or special-purpose microprocessors or digital signal processors (DSPs), microcontrollers, application specific integrated circuits (ASICs), programmable logic devices (PLDs), or a combination of such devices. The bus system 136 includes one or more buses or other physical connections, which may be connected to each other through various bridges, bus controllers and/or adapters such as are well-known in the art. For example, the bus system 136 may include a “system bus”, which may be connected through one or more adapters to one or more expansion buses, such as a Peripheral Component Interconnect (PCI) bus, HyperTransport or industry standard architecture (ISA) bus, small computer system interface (SCSI) bus, universal serial bus (USB), or Institute of Electrical and Electronics Engineers (IEEE) standard 1394 bus (sometimes referred to as “Firewire”). In alternative embodiments, some or all of the aforementioned components may be connected to each other directly, rather than through a bus system.
The mass storage device 133 may be, or may include, any one or more devices suitable for storing large volumes of data in a non-volatile manner, such as a magnetic disk or tape, magneto-optical (MO) storage device, or any of various types of Digital Versatile Disk (DVD) or Compact Disk (CD) based storage, or a combination of such devices.
The data communication device 134 is a device suitable for enabling the processing system to communicate data with a remote processing system over a data communication link 138, and may be, for example, a conventional telephone modem, a wireless modem, an Integrated Services Digital Network (ISDN) adapter, a Digital Subscriber Line (DSL) modem, a cable modem, a radio transceiver, a satellite transceiver, an Ethernet adapter, or the like.
The I/O devices 135 (which may be omitted in a system that operates exclusively as a server and provides no direct local user interface) may include, for example, one or more devices such as: a pointing device such as a mouse, trackball, touchpad, or the like; a keyboard; audio speakers; and/or a display device such as a cathode ray tube (CRT), a liquid crystal display (LCD), or the like. Other variations upon the illustrated set of components can be implemented in a manner consistent with the invention.
Software (including instructions and data) 137 to implement the techniques described above may be stored in one or more of ROM 131, RAM 132, and mass storage device 133. In certain embodiments, the software 137 may be initially loaded into the processing system by downloading it from a remote system through the communication device 134.
Thus, a method and apparatus for federated download of digital content to wireless devices have been described. Although the present invention has been described with reference to specific exemplary embodiments, it will be recognized that the invention is not limited to the embodiments described, but can be practiced with modification and alteration within the spirit and scope of the appended claims. Accordingly, the specification and drawings are to be regarded in an illustrative sense rather than a restrictive sense.
Claims
1. A download server on a network, comprising:
- one or more processors; and
- a memory storing executable instructions that when executed by the one or more processors cause the one or more processors to perform a method comprising: receiving a content descriptor as a consequence of a redirect, wherein the content descriptor is indicative of a selection by a user transmitted from a wireless client device and relates to a digital product hosted by a remote content server that is coupled to the download server via a computer network; determining that the digital product is not in a cache accessible by the download server; responsive to the determination, using the content descriptor to obtain the digital product from the remote content server; and delivering the digital product from the download server to the wireless client device via a wireless network.
2. The download server of claim 1, wherein the content descriptor is encoded in a product catalog hosted by the remote content server.
3. The download server of claim 1, wherein the content descriptor is received from the wireless client device and the redirect is a redirect of the wireless client device to the download server.
4. The download server of claim 1, wherein the content descriptor is received from the remote content server as a consequence of the remote content server receiving the selection.
5. The download server of claim 1, wherein the content descriptor includes a reference to the digital product, for use by the download server to obtain the digital product from the remote content server.
6. The download server of claim 1, wherein the content descriptor includes information for use by the download server to perform digital rights management (DRM) in relation to the selection.
7. The download server of claim 1, wherein executable instructions, when executed by the one or more processors, cause the one or more processors to perform a method further comprising storing the digital product in the cache.
8. A method of operating a download server comprising one or more processors on a network, the method comprising, at the download server:
- receiving a content descriptor a consequence of a redirect, wherein the content descriptor is indicative of a selection by a user transmitted from a wireless client device and relates to a digital product hosted by a remote content server that is coupled to the download server via a computer network;
- determining that the digital product is not in a cache accessible to the download server;
- responsive to the determination, using the content descriptor to obtain the digital product from the remote content server; and
- delivering the digital product from the download server to the wireless client device via a wireless network.
9. The method of claim 8, wherein the content descriptor is encoded in a product catalog hosted by the remote content server.
10. The method of claim 8, wherein the content descriptor is received from the wireless client device and the redirect is a redirect of the wireless client device to the download server.
11. The method of claim 8, wherein the content descriptor is received from the remote content server as a consequence of the remote content server receiving the selection.
12. The method of claim 8, wherein the content descriptor includes a reference to the digital product, for use by the download server to obtain the digital product from the remote content server.
13. The method of claim 8, wherein the content descriptor includes information for use by the download server to perform digital rights management (DRM) in relation to the selection.
14. The method of claim 8, further comprising storing the digital product in the cache.
15. A non-transitory computer-readable medium comprising computer executable instructions that when executed by a processor of a computer system instruct the processor to perform a method of:
- receiving a content descriptor a consequence of a redirect, wherein the content descriptor is indicative of a selection by a user transmitted from a wireless client device and relates to a digital product hosted by a remote content server that is coupled to the download server via a computer network;
- determining that the digital product is not in a cache accessible to the download server;
- responsive to the determination, using the content descriptor to obtain the digital product from the remote content server; and
- delivering the digital product from the download server to the wireless client device via a wireless network.
16. The non-transitory computer-readable medium of claim 15, wherein the content descriptor is received from the wireless client device and the redirect is a redirect of the wireless client device to the download server.
17. The non-transitory computer-readable medium of claim 15, wherein the content descriptor is received from the remote content server as a consequence of the remote content server receiving the selection.
18. The non-transitory computer-readable medium of claim 15, wherein the content descriptor includes a reference to the digital product, for use by the download server to obtain the digital product from the remote content server.
19. The non-transitory computer-readable medium of claim 15, wherein the content descriptor includes information for use by the download server to perform digital rights management (DRM) in relation to the selection.
20. The non-transitory computer-readable medium of claim 15, wherein the computer executable instructions, when executed by the processor, instruct the processor to perform a method further comprising storing the digital product in the cache.
Type: Application
Filed: Jun 17, 2014
Publication Date: Oct 2, 2014
Applicant: UNWIRED PLANET, LLC (Reno, NV)
Inventors: Rikard M. Khellberg (Santa Cruz, CA), Joseph W. Azure (Belmont, CA), Richard M. Lee (Pleasanton, CA), Sheng Liang (Cupertino, CA)
Application Number: 14/307,273