This application relates generally to the field of wireless data processing systems, and more particularly, to managing content synchronization between a data service and a data processing device.
Many portable data processing devices such as wireless personal digital assistants (“PDA”) and cellular telephones are capable of processing multimedia content including, for example, digital audio content, music instrument digital interface (“MIDI”) audio content (e.g., ring tones), still video images and even motion video. In addition, many Internet service providers today allow subscribers to download multimedia content and applications (e.g., games, utilities, messaging clients, etc) over the data processing device's wireless or terrestrial network connection.
One problem which exists with current systems, however, is that even through many current portable data processing devices are powerful enough to process the multimedia content and applications, the portable devices do not have sufficient non-volatile storage capacity to store a significant amount of multimedia content and/or applications. While current storage technologies such as Flash memory and hard discs have improved significantly in recent years, they are often still inadequate for storing, for example, a user's entire MP3 collection or collection of still pictures or video.
Techniques are described to track and manage applications and content between a wireless device and a service comprising: maintaining a first plurality of records on the service; each of the first plurality of records corresponding to applications and/or content (hereinafter “applications”) purchased by a user, each of the first plurality of records having an “uninstalled” field to indicate whether the applications are uninstalled or installed on the wireless device; maintaining a second plurality of records on the wireless device, including an uninstalled field to indicate whether the applications are uninstalled or installed on the wireless device; receiving input from a user on the wireless device; uninstalling the first application in response to the user input; modifying wireless device in response to the user input; transmitting an indication that the application has been uninstalled to the service; and modifying the uninstall field within the record corresponding to the first application on the service in response to the indication, the service maintaining both the record corresponding to the first application and the application on behalf of the wireless device.
A better understanding of managing content synchronization between a data service and a data processing device can be obtained from the following detailed description in conjunction with the following drawings, in which:
a-c illustrate a graphical user interface according to one embodiment of the invention.
Techniques for managing content synchronization between a data service and a data processing device may be implemented on an external data management service 120 such as that illustrated generally in
In
In one embodiment, when a wireless device 110 initially attempts to access data services via GPRS 202, the director 201 assigns the wireless device to a particular dispatcher 210. The dispatcher 210 forms the central point of communications and policy management for data transmitted between the wireless device 110 and the service 220. In one embodiment, the dispatcher 210 maintains socket connections (e.g., TCP sockets) between the wireless device 110 and the various servers maintained on the data service 220. For example, as described in greater detail below, to enable content downloading and content synchronization, the dispatcher 210 maintains socket connections between the wireless device 110 and the PDM server 216. Additional details. associated with the communication architecture between the wireless device 110, the dispatcher 210 and the various servers are described in co-pending application entitled SYSTEM AND METHOD FOR MANAGING DATA AND VOICE CONNECTIVITY FOR WIRELESS DEVICES, Ser. No. 11/058,785, filed Feb. 14, 2005 (hereinafter “Data Connectivity Management Application”), which is assigned to the assignee of the present application and which is incorporated herein by reference.
In one embodiment, each time a user logs into or out of the service 220, the dispatcher 210 notifies the DB proxy 217 to update the user's online status within the user database 220 accordingly. In addition, given the significant differences in bandwidth between the wireless network 122 and the local network 202 on which the service 220 operates, the dispatcher 210 may temporarily buffer data transmitted to and from the wireless device 110 over each individual socket connection.
If the physical/data link connection between the wireless device 110 and service provider 200 is temporarily lost (e.g., because the user passes through a tunnel), the user will not immediately be disconnected from the dispatcher. Rather, the user's “online” status will be maintained within the user database 220 for a specified period of time (e.g., 10 minutes), along with an indication of the dispatcher 210 through which the wireless device is connected.
An exemplary portion of the user database 220 is illustrated in
It should be noted that a single table is illustrated in
As mentioned above, many current portable data processing devices are not equipped with sufficient non-volatile storage capacity (e.g., Flash memory) to handle the amount of multimedia content and/or applications desired by many users. To address this problem, one embodiment provides a unique mechanism for temporarily “uninstalling” multimedia content and applications from the portable data processing device 110 and tracking both the installed and uninstalled content/applications on the data service 120.
Specifically, in one embodiment, the premium download manager (“PDM”) 316 controls the distribution and management of the multimedia content and/or applications installed on the portable data processing device. First, the PDM allows users to purchase various types of content and/or applications directly from the wireless device 110. The content may include, by way of example and not limitation, utilities, network clients, new ring tones for the wireless device, graphical images, video and/or encoded audio (e.g., MP3 or AAC files).
As illustrated in
Other data contained within the purchase record 401 may include a global identification code uniquely identifying the application/content on the service; the name of the application (in this case, “Calculator Application”); the purchase price; the purchase date; the size of the application; an external reference field pointing to the underlying content/application referenced by the purchase record; an indication as to whether the application is an upgrade to a previously-installed application; a “service last modified” date field to indicate when the record was last modified at the service; and a “device last modified” field to indicate when the record was last modified at the device. In one embodiment, these fields are used to determine whether the record has been changed for synchronization purposes. The “device last modified” field is updated whenever any other field in the record is modified, and the modified record is then sent to the service. If for some reason the service never receives the record, the discrepancy will be detected the next time the device and service synchronize with one another because checksums (which, as described below, may be calculated using last modified times) will not match.
Purchase records can be modified on the service first as the result of change made via the service administrators, e.g., through an administrative Web interface used by customer care representatives. Using this Web interface, the customer care representatives may install or remove purchases by making changes directly in the database and pushing the changed records down to the device. The “service last modified” field might be affected by this.
If the purchase is authorized, determined at 603, then at 604 the PDM 316 generates a new record related to the purchase and stores the new record in the user database, initially with the uninstall bit field 500 set to “No” (i.e., indicating that the application/content is going to be installed on the wireless device 110). At 605, a copy of the record is transmitted to the wireless device via the client-side PDM 401. At 606, the client-side PDM 401 checks the uninstalled bit field, determines that the bit field is set to “No,” and requests the application/content from the service-side PDM 316. The client-side PDM also stores the new record within the wireless device's non-volatile storage 420. At 607, the service-side PDM 316 transmits the application/content from the content database 321. In the case of an application, the application is then installed on the wireless device 110; in the case of multimedia content, the multimedia content is stored on within the device's non-volatile storage 420.
As mentioned above, after the application/content is installed, the user may choose to temporarily remove it from the wireless device (e.g., because of limited storage space).
One of the benefits of the foregoing configuration is that both the wireless device and the service effectively track all of the applications and/or multimedia content that the user is authorized to use on his/her wireless device (i.e., that the user has rightfully purchased, or which was given away free). Thus, at any subsequent point in time, the user may easily reinstall a particular application or multimedia file on the wireless device 110, as illustrated in
If enough space is available, determined at 803, then at 804, the client-side PDM 401 changes the uninstall bit field from a “Yes” to a “No” and, at 805, synchronizes the change with the corresponding record stored within the user database 320 of the data service 120. At 806, the service-side PDM 316 transmits the application/content from the content database 321. Once again, in the case of an application, the application is then installed on the wireless device 110; in the case of multimedia content, the multimedia content is stored on within the device's non-volatile storage 420.
Returning to 803, if the space on the data processing device is insufficient, the user is presented with the option (e.g., via a user interface such as that described below) to uninstall another application or content before the new content is downloaded at 807.
In addition to the reinstallation scenario described above, because the current state of the user's applications and content is maintained within the user database 320 on the service 120, if the wireless device 110 is lost or stolen, or if records or associated applications and multimedia content on the wireless device are somehow lost, the user's applications and multimedia content may be identified by the service 120 and reinstalled on the wireless device 110.
One embodiment of a method for restoring the installed applications/content on a wireless device is set forth in
At 904, the service-side PDM 316 runs the same checksum on the records stored within the user database 320. If the checksums match, then the device and the service are synchronized and the process ends. However, at 905, if the checksums do not match, then the service-side PDM 316 requests a list of records from the wireless device 110. At 906, the client-side PDM 401 sends the list of records to the service. In one embodiment, the list includes the global ID, service last modified and device last modified fields for each records and/or the checksum calculated from these fields.
At 907, the service-side PDM compares each record in the list with the records stored in the user database to identify those records to send to the wireless device. At 913, the client-side PDM 401 stores the records and scans each record to determine which ones indicate that the application/content is purchased and installed. At 914, the client-side PDM 401 checks to determine whether the applications/content are actually installed. In one embodiment, it sends a request to the operating system software executed on the wireless device to make this determination. Finally, at 915, the client-side PDM 401 requests those applications/content which should be installed on the device, but which are not.
At 902, if the client-side PDM 401 determines that no records for applications and/or content on the device (e.g., in the event all the records have been lost or the user purchased a new device), then at 910, the client-side PDM sends a message to the service-side PDM with an indication that no records exist. In one embodiment, this is accomplished by using a checksum equal to zero. At 911, the service-side PDM 316 retrieves all of the user's records from the user database and transmits them to the service-side PDM. The process then continues from 913 as described above.
One embodiment of a user interface for managing installed and uninstalled applications is illustrated in
The user may select each application using a mouse or cursor control device and generate a window such as that shown in
Although the same records 401-403 are stored on the wireless device 110 and the service 120 in the embodiments described above, the records may not necessarily be stored in the same format. For example, in one embodiment, the records 401-403 are stored on the data service 120 in a standard SQL database format, whereas the records may be stored on the wireless device in a format compatible with the file system employed on the wireless device 110 or in a proprietary binary format. However, the underlying principles of the invention are not limited to the particular format used to store the records.
The embodiments of the invention described herein may be particularly useful in cases where the wireless device 110 is only capable of communicating with the data service, and not another type of storage device such as a personal computer (i.e., where the user may back up his/her applications and/or content). However, the underlying principles of the invention are not limited to this configuration.
Embodiments of the invention may include various steps as set forth above. The steps may be embodied in machine-executable instructions which cause a general-purpose or special-purpose processor to perform certain steps. Alternatively, these steps may be performed by specific hardware components that contain hardwired logic for performing the steps, or by any combination of programmed computer components and custom hardware components.
Elements of the present invention may also be provided as a machine-readable medium for storing the machine-executable instructions. The machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, CD-ROMs, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnetic or optical cards, propagation media or other type of media/machine-readable medium suitable for storing electronic instructions. For example, the present invention may be downloaded as a computer program which may be transferred from a remote computer (e.g., a server) to a requesting computer (e.g., a client) by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
Throughout the foregoing description, for the purposes of explanation, numerous specific details were set forth in order to provide a thorough understanding of the invention. It will be apparent, however, to one skilled in the art that the invention may be practiced without some of these specific details. For example, although each of the functional modules illustrated in
| Number | Name | Date | Kind |
|---|---|---|---|
| 5126786 | Tanaka | Jun 1992 | A |
| 5159592 | Perkins | Oct 1992 | A |
| 5436960 | Campana, Jr. et al. | Jul 1995 | A |
| 5559800 | Mousseau et al. | Sep 1996 | A |
| 5594910 | Filepp et al. | Jan 1997 | A |
| 5625670 | Campana, Jr. et al. | Apr 1997 | A |
| 5631946 | Campana, Jr. et al. | May 1997 | A |
| 5715387 | Barnstijn et al. | Feb 1998 | A |
| 5727202 | Kucala | Mar 1998 | A |
| 5778176 | Geihs et al. | Jul 1998 | A |
| 5790974 | Tognazzini | Aug 1998 | A |
| 5802312 | Lazaridis et al. | Sep 1998 | A |
| 5819172 | Campana, Jr. et al. | Oct 1998 | A |
| 5915095 | Miskowiec | Jun 1999 | A |
| 5961590 | Mendez et al. | Oct 1999 | A |
| 5964830 | Durrett | Oct 1999 | A |
| 6023708 | Mendez et al. | Feb 2000 | A |
| 6035104 | Zahariev | Mar 2000 | A |
| 6035339 | Agraharam et al. | Mar 2000 | A |
| 6067451 | Campana, Jr. et al. | May 2000 | A |
| 6076109 | Kikinis | Jun 2000 | A |
| 6134593 | Alexander et al. | Oct 2000 | A |
| 6151643 | Cheng et al. | Nov 2000 | A |
| 6151677 | Walter et al. | Nov 2000 | A |
| 6157935 | Tran et al. | Dec 2000 | A |
| 6166734 | Nahi et al. | Dec 2000 | A |
| 6167441 | Himmel | Dec 2000 | A |
| 6188752 | Lesley | Feb 2001 | B1 |
| 6199099 | Gershman et al. | Mar 2001 | B1 |
| 6233318 | Picard et al. | May 2001 | B1 |
| 6289212 | Stein | Sep 2001 | B1 |
| 6317592 | Campana, Jr. et al. | Nov 2001 | B1 |
| 6324691 | Gazdik | Nov 2001 | B1 |
| 6330618 | Hawkins et al. | Dec 2001 | B1 |
| 6370687 | Shimura | Apr 2002 | B1 |
| 6396482 | Griffin et al. | May 2002 | B1 |
| 6418310 | Dent | Jul 2002 | B1 |
| 6449622 | LaRue et al. | Sep 2002 | B1 |
| 6502124 | Shimakawa et al. | Dec 2002 | B1 |
| 6622175 | Piller | Sep 2003 | B1 |
| 6728685 | Ahluwalia | Apr 2004 | B1 |
| 6785534 | Ung | Aug 2004 | B2 |
| 6832230 | Zilliacus et al. | Dec 2004 | B1 |
| 6980963 | Hanzek | Dec 2005 | B1 |
| 7076736 | Hugh | Jul 2006 | B2 |
| 7136635 | Bharatia et al. | Nov 2006 | B1 |
| 20010029607 | Veres et al. | Oct 2001 | A1 |
| 20010034712 | Colvin | Oct 2001 | A1 |
| 20010056508 | Arneson et al. | Dec 2001 | A1 |
| 20020032768 | Voskuil | Mar 2002 | A1 |
| 20020083035 | Pearl et al. | Jun 2002 | A1 |
| 20020103935 | Fishman et al. | Aug 2002 | A1 |
| 20020132609 | Lewis et al. | Sep 2002 | A1 |
| 20020194279 | Chern | Dec 2002 | A1 |
| 20030027554 | Haumont | Feb 2003 | A1 |
| 20030032417 | Minear et al. | Feb 2003 | A1 |
| 20030055902 | Amir et al. | Mar 2003 | A1 |
| 20030081591 | Cheung et al. | May 2003 | A1 |
| 20030088693 | Cheung et al. | May 2003 | A1 |
| 20030115270 | Funk et al. | Jun 2003 | A1 |
| 20030182380 | Yabe et al. | Sep 2003 | A1 |
| 20040077347 | Lauber et al. | Apr 2004 | A1 |
| 20040082323 | Smith | Apr 2004 | A1 |
| 20040090950 | Lauber et al. | May 2004 | A1 |
| 20040199663 | Horvitz et al. | Oct 2004 | A1 |
| 20050144251 | Slate | Jun 2005 | A1 |
| Number | Date | Country |
|---|---|---|
| WO 9836344 | Aug 1998 | WO |
| WO 9906929 | Feb 1999 | WO |
| WO 0030003 | May 2000 | WO |