1. Field of the Invention
This invention relates generally to the field of network data services. More particularly, the invention relates to an apparatus and method for monitoring and maintaining a wireless device.
2. Description of the Related Art
A variety of wireless data processing devices have been introduced over the past several years. These include wireless personal digital assistants (“PDAs”) such as the Palm® VIIx handheld, cellular phones equipped with data processing capabilities (e.g., those which include wireless application protocol (“WAP”) support), and, more recently, wireless messaging devices such as the Blackberry™ wireless pager developed by Research In Motion (“RIM”).™
Mobile platforms included on the wireless data processing devices run mission-critical applications. As such, it is important to gather information about applications running on the device, protect the data on the device, and protect the applications on the device. Furthermore, there may be requirements that certain prerequisite applications be present or absent on the mobile platform to enforce an organization's policies, to secure the mobile platform, or to permit' auditing procedures.
Presently, some applications operate to scan a device and remove certain files according to criteria contained in the application. For example, a virus scanner operates in such a way. However, virus scanners only scan for known objects on the device, and not for the absence of certain objects. Furthermore, virus scanners only check for the existence of viruses, and not for generic things such as battery strength or device peripheral functionality.
Also, because the virus scanner application resides on the device on which it operates, it cannot check itself to ensure that it is running properly. Furthermore, virus scanners only accept rules from the vendor of the application, and do not have the functionality to allow organizations other than the vendor to generate and enforce rules to fit the organization's corporate policy.
Currently, existing products or technology in the market do not gather device information and enforce the existence or non-existence of applications on the device. Accordingly, what is needed is a system and method for monitoring and maintaining a wireless device. What is also needed is a network infrastructure to support remote monitoring and maintenance of a wireless device.
A system is disclosed in which a data processing device is monitored and maintained over a network. One embodiment of the system comprises a wireless device including: a service to maintain data objects, provide messaging capability, and provide data access capability on behalf of a user of the wireless device; and a rules engine communicatively coupled to the service to execute a set of rules transmitted to the wireless device from a server, the set of rules to instruct the rules engine to gather information related to the wireless device and to take action on the wireless device based on the gathered information.
In another embodiment, a system is disclosed comprising a server communicatively coupled to a network, and an administrator coupled to the server configured to provide a set of rules to a wireless device, the set of rules to instruct the wireless device to gather information related to the wireless device and take action based on the gathered information.
A better understanding of the present invention can be obtained from the following detailed description in conjunction with the following drawings, in which:
In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without some of these specific details. In other instances, well-known structures and devices are shown in block diagram form to avoid obscuring the underlying principles of the present invention.
An Exemplary Network Architecture
In one embodiment of the invention, an interface 101 forwards data objects maintained by the service 102 (e.g., e-mail messages, instant messages, calendar data, . . . etc.) to a plurality of wireless data processing devices (represented in
Alternatively, or in addition, the service 102 may provide the e-mail to the user's local computer (e.g., client 110) upon request (i.e., so that the user will receive the e-mail on his/her wireless device 130 when out of the office and on his/her personal computer 110 when in the office). Conversely, e-mail messages sent from the user's wireless data processing device 130 are transmitted to the service 102 via the interface 101.
In one embodiment, the interface 101 is a software module adapted to work with the particular service 120. It should be noted, however, that the interface 101 may be implemented in hardware or any combination of hardware and software while still complying with the underlying principles of the invention.
In one embodiment, the external data network 170 is comprised of a plurality of servers/clients (not shown) and other networking hardware (e.g., routers, hubs, . . . etc.) for transmitting data between the interface 101 and the wireless devices 130. In one embodiment, the interface 101 encapsulates data in one or more packets containing an address identifying the wireless devices 130 (e.g., such as a 24-bit Mobitex Access Number (“MAN #”)). The external data network 170 transmits the packets to a wireless service provider network 171 which, in turn, transmits the packets (or the data contained therein) over a wireless communication link to the wireless device 130. In one embodiment, the wireless service provider network is a 2-way paging network. However, various other network types may be employed (e.g., CDMA 2000, PCS, . . . etc.) while still complying with the underlying principles of the invention.
It should be noted that the network service provider network 171 and the external data network 170 (and associated interface 101) may be owned/operated by the same organization or, alternatively, the owner/operator of the external data network 170 may lease wireless services from the wireless service provider network. The underlying principles of the invention are not limited to any particular service arrangement.
In one embodiment of the invention, the service 102 (e.g., the e-mail database) is fully synchronized with the wireless data processing device 130. Thus, any actions performed on the wireless device 130 are automatically updated on the service 102 and any transactions occurring at the service 102 are automatically reflected on the device 130. Synchronization updates of this type may include but are not limited to device configuration modifications, calendar updates, e-mail message updates, instant messages, to-do list updates and/or any other type of personal information management transactions or corporate data management transactions (hereinafter “message transactions”).
As one example, when a user views an e-mail message using the device 130, an indication that the user viewed the message is transmitted to the service 102 (via the interface 101). Accordingly, if the user subsequently connects to e-mail via a client 110, the e-mail will appear as having already been viewed. Other actions such as message deletions, filing activities (e.g., moving a message to a particular folder), message responses, meeting confirmations/additions . . . etc., will automatically be reflected in the service 102, thereby providing complete synchronization between the service 102, the device 130 and/or the client 110 (if one is being used).
Current systems do not offer organizational control over monitoring their wireless devices for various criteria, and maintaining the wireless devices based on the monitoring. As such, these systems cannot gather device information and enforce organizational policies on the wireless devices. One reason for this is that prior systems do not monitor the entire wireless device unit remotely, and any monitoring is not done based on organizational policies. As such, in order for an organization to monitor and maintain its wireless devices, embodiments of the invention employ one or more of the following techniques.
An Exemplary Wireless Device Monitor
Wireless device 210 further includes a mobile platform application 212 and a rules engine 214. In one embodiment, the application 212 provides wireless messaging and data access for the wireless device 210 in connection with a main server, such as server 230. Server 230 may be maintained by an organization that owns and operates the wireless device 210. In one embodiment, application 212 operates as a service to maintain data objects on behalf of a user of the wireless device 210. Application 212 may also provide real-time synchronization of the wireless device 210 with server 230. In one embodiment, application 212 is a software module adapted to work with server 230.
In one embodiment, application 212 receives a rule definition file sent to the wireless device 210 through a wireless or wired medium. This rule definition file may be created by an organization owning the wireless device, and sent to the wireless device 210 by way of server 230, which may be operated by the organization. The rule definition file embodies a set of rules to be applied to the wireless device. In one embodiment, application 212 transfers the rule definition file to rules engine 214 for analysis and execution.
The rules engine 214 of the wireless device 210 stores and executes the rule definition file. In one embodiment, the rules engine 214 operates to verify authenticity of any rule definition files it receives. This verification may be accomplished by determining the origination of the rule definition file and cross-referencing the origination with a list of allowable entities.
Based on the rule definition file, the rules engine 214 monitors the wireless device 210 by gathering information relating to the wireless device 210, and checking information associated with one or more applications on the wireless device 210. Wireless device information that the rules engine 214 may gather includes, but is not limited to, applications installed on the device, applications not installed on the device, and functionally operative features within applications installed on the device. Furthermore, the information gathered may include device characteristics such as OS version, ROM version, application licensing restrictions and their expiry, code signature and certification validation of applications, application usage patterns, device hardware characteristics, device operating characteristics, peripherals on the device, and SMS functionality.
In one embodiment, the rules engine 214 may also take action based on the results from monitoring of the wireless device 210 by way of the rule definition file. Such actions may include, but are not limited to, warning the device user, locking the device, phoning a set of numbers, initiating software downloads and upgrades, alerting the corporate network monitors, shutting down applications, shutting down the device, and erasing critical data on the device. Furthermore, the rules engine may take action and enforce device system characteristics based on corporate policies promulgated by an organization owning the wireless device 210.
In one embodiment, rules engine 214 is a software module adapted to work with application 212. It should be noted, however, that the rules engine 214 may be implemented in hardware or any combination of hardware and software while still complying with the underlying principles of the invention.
In one embodiment, server 230 may be configured to provide a variety of different messaging and groupware services to network users (e.g., e-mail, instant messaging, calendaring, . . . etc.) such as wireless device 210. In one embodiment, these services are provided by Microsoft Exchange™. In one embodiment, server 230 is the same as server 103 of
Server 230 further includes an administrator 240 and an organization policy editor 245 as part of the administrator 240. The administrator 240 is responsible for assembling and transmitting the rule definition file to the wireless device 210. In one embodiment, the rule definition file is any set of rules to be applied to the wireless device 210. The rule definition file may be an Extensible Markup Language (XML) file, native script, executable module, or a pointer (URL) to another resource of the rule definition file. In one embodiment, any changes or updates made to the rule file may be incrementally synchronized with the wireless device.
In one embodiment, the corporate policy editor 245 is responsible for transforming corporate policies for the wireless device 210 into the set of rules for the rule definition file. Some examples of corporate policies include, but are not limited to, allowing or not allowing certain applications to exist on the wireless device, maintaining particular settings within applications, ensuring certain versions of applications are up-to-date, and preventing certain peripherals from being associated with the wireless device. One skilled in the art will appreciate that a variety of corporate policies may be implemented to monitor and maintain the wireless device 210.
In one embodiment, administrator 240 is a software module adapted to work with server 230. It should be noted, however, that the administrator 240 may be implemented in hardware or any combination of hardware and software while still complying with the underlying principles of the invention.
Then, at processing block 330, the rules engine executes the rule definition file. Upon execution of the file, the rules engine 214 may gather information related to the wireless device. The information gathered may include, but is not limited to, applications installed on the device, applications not installed on the device, functionally operative features within applications installed on the device, and battery status. Furthermore, the information gathered may include device characteristics such as OS version, ROM version, application licensing restrictions and their expiry, code signature and certification validation of applications, application usage patterns, device hardware characteristics, device operating characteristics, peripherals on the device, and SMS functionality.
Finally, at processing block 340 the rules engine 214 performs an action based on the execution of the rule definition file. Such an action may include, but is not limited to, warning the device user, locking the device, phoning a set of numbers, initiating software downloads and upgrades, alerting the corporate network monitors, shutting down applications, shutting down the device, and erasing critical data on the device.
If a periodic monitoring session is required, then at processing block 420 the rules engine 214 informs the mobile platform application 212 of the wireless device 210 to check for an update with server 230. At processing block 430, the application 212 connects to the server 230 to determine if an updated rule definition file exists. In some embodiments, the application 212 or server 230 may compare the rule definition file already on the wireless device 210 with the most recent rule definition file on the server 230.
If a more recent rule definition file exists on the server 230, then at processing block 440 the updated file is downloaded to the wireless device 210. At processing block 450, the monitoring session is initiated. In one embodiment, the monitoring session is the same process as described with respect to
At processing block 510, the server 230 updates the rule definition file stored on the server 230. Then, at processing block 520, the server incrementally synchronizes changes to the file with the wireless device 210. Such synchronization may occur over a wired or wireless medium. Finally, at processing block 530, the rules engine 214 initiates a monitoring session according to the new rule definition file received from the server 230. In some embodiments, the rules engine 214 may initiate the monitoring session when it receives an updated file, and/or it may initiate monitoring session on a periodic basis, according to some of the example time intervals mentioned previously.
Embodiments of the invention may include various steps as set forth above. The steps may be embodied in machine-executable instructions. The instructions can be used to 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, Flash memory, 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, while illustrated as an interface 101 to a service 102 executed on a server 103 (see
This application is a continuation of U.S. patent application Ser. No. 13/728,625, filed Dec. 27, 2012, which is a continuation of U.S. patent application Ser. No. 13/113,478, filed May 23, 2011, now U.S. Pat. No. 8,351,908, which is a continuation of U.S. patent application Ser. No. 11/145,391, filed Jun. 3, 2005, now U.S. Pat. No. 7,970,386, the disclosures of which are incorporated by reference herein in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
4837811 | Butler | Jun 1989 | A |
4882752 | Lindman | Nov 1989 | A |
5113041 | Blonder | May 1992 | A |
5220501 | Lawlor | Jun 1993 | A |
5237614 | Weiss | Aug 1993 | A |
5432999 | Capps | Jul 1995 | A |
5613012 | Hoffman | Mar 1997 | A |
5631947 | Wittstein | May 1997 | A |
5647002 | Brunson | Jul 1997 | A |
5675362 | Clough | Oct 1997 | A |
5687322 | Deaton | Nov 1997 | A |
5727202 | Kucala | Mar 1998 | A |
5745884 | Carnegie | Apr 1998 | A |
5771354 | Crawford | Jun 1998 | A |
5787441 | Beckhardt | Jul 1998 | A |
5790790 | Smith | Aug 1998 | A |
5857201 | Wright, Jr. | Jan 1999 | A |
5862325 | Reed | Jan 1999 | A |
5862346 | Kley | Jan 1999 | A |
5903881 | Schrader | May 1999 | A |
5928329 | Clark | Jul 1999 | A |
5958007 | Lee | Sep 1999 | A |
5987609 | Hasebe | Nov 1999 | A |
5991410 | Albert | Nov 1999 | A |
5999947 | Zollinger | Dec 1999 | A |
6125388 | Reisman | Sep 2000 | A |
6144848 | Walsh et al. | Nov 2000 | A |
6317793 | Toyosawa | Nov 2001 | B1 |
6330568 | Boothby | Dec 2001 | B1 |
6489671 | Aoki | Dec 2002 | B2 |
6496875 | Ramanujam | Dec 2002 | B2 |
6796491 | Nakajima | Sep 2004 | B2 |
6813487 | Trommelen | Nov 2004 | B1 |
6820126 | Sibecas et al. | Nov 2004 | B2 |
6842433 | West et al. | Jan 2005 | B2 |
7103806 | Horvitz | Sep 2006 | B1 |
7218941 | Kubo et al. | May 2007 | B1 |
7328451 | Aaron | Feb 2008 | B2 |
7480907 | Marolia | Jan 2009 | B1 |
7496957 | Howard | Feb 2009 | B2 |
7545767 | Zhao et al. | Jun 2009 | B2 |
7606560 | Labrou et al. | Oct 2009 | B2 |
7624393 | Egan | Nov 2009 | B2 |
7698702 | Wetherly | Apr 2010 | B2 |
7844964 | Marolia | Nov 2010 | B2 |
7987449 | Marolia | Jul 2011 | B1 |
8117293 | Anderson | Feb 2012 | B1 |
8250565 | Marolia | Aug 2012 | B2 |
8555273 | Chia et al. | Oct 2013 | B1 |
8635661 | Shahbazi | Jan 2014 | B2 |
20020069037 | Hendrickson et al. | Jun 2002 | A1 |
20020098840 | Hanson | Jul 2002 | A1 |
20020143655 | Elston et al. | Oct 2002 | A1 |
20030162555 | Loveland | Aug 2003 | A1 |
20030194998 | Bhide | Oct 2003 | A1 |
20040009751 | Michaelis et al. | Jan 2004 | A1 |
20040009761 | Money et al. | Jan 2004 | A1 |
20040034619 | Lu et al. | Feb 2004 | A1 |
20040068721 | O'Neill | Apr 2004 | A1 |
20040098715 | Aghera | May 2004 | A1 |
20040121769 | Aoki | Jun 2004 | A1 |
20040153499 | Heddaya et al. | Aug 2004 | A1 |
20040174264 | Reisman et al. | Sep 2004 | A1 |
20040268147 | Wiederin et al. | Dec 2004 | A1 |
20040268150 | Aaron | Dec 2004 | A1 |
20050003804 | Huomo | Jan 2005 | A1 |
20050055578 | Wright | Mar 2005 | A1 |
20050122930 | Zhao et al. | Jun 2005 | A1 |
20050132358 | Peev et al. | Jun 2005 | A1 |
20050149436 | Elterich | Jul 2005 | A1 |
20050164704 | Winsor | Jul 2005 | A1 |
20050206518 | Welch et al. | Sep 2005 | A1 |
20050233776 | Allen et al. | Oct 2005 | A1 |
20060015878 | Ritter | Jan 2006 | A1 |
20060053368 | Bosworth et al. | Mar 2006 | A1 |
20060101273 | Tan et al. | May 2006 | A1 |
20060117073 | Bosworth et al. | Jun 2006 | A1 |
20060147043 | Mann et al. | Jul 2006 | A1 |
20060168095 | Sharma et al. | Jul 2006 | A1 |
20060246878 | Khoury | Nov 2006 | A1 |
20060265689 | Kuznetsov et al. | Nov 2006 | A1 |
20070093243 | Kapadekar | Apr 2007 | A1 |
20070190978 | White et al. | Aug 2007 | A1 |
20080005576 | Weiss | Jan 2008 | A1 |
Number | Date | Country |
---|---|---|
2149337 | Jun 1990 | CA |
0813133 | Dec 1997 | EP |
H06-332858 | Feb 1994 | JP |
H08-137732 | May 1996 | JP |
H09-081560 | Mar 1997 | JP |
11-265279 | Sep 1999 | JP |
2000-305757 | Nov 2000 | JP |
2002-304263 | Oct 2002 | JP |
2003005905 | Oct 2003 | JP |
2005115829 | Apr 2005 | JP |
2004021114 | Mar 2004 | WO |
Entry |
---|
Altiris® Handheld Management Suite Datasheet Oct. 14, 2005. |
Altiris® Inventory Solution 6.1 for Pocket PC Product Guide. |
Altiris® Inventory Solution 6.1 for RIM Product Guide. |
Altiris® Security Solution 6.1 for Handhelds Administrator Guide. |
Altiris® Security Solution 6.1 for Handhelds User Guide. |
Release Notes Altiris Pocket Pc Agent 6.1 Service Pack 1. |
Microsoft Systems Management Server SMS 2003 Device Management Feature Pack Guide. |
Microsoft Systems Management Server 2003 with Device Management Feature Pack SC02 SMS 2003 Device Management Feature Pack. |
Operations Guide: Microsoft Systems Management Server 2003. |
Microsoft Systems Management Server 2003 with Device Management Feature Pack Concepts, Planning, and Deployment Guide. |
User's Guide: Hewlett Packard iPAQhx2000 Series Pocket PC 2004. |
Introducing Tivoli Distributed Monitoring Workbench 4.1 (Feb. 2002). |
Tivoli Distributed Monitoring (Advanced Edition) 4.1—Early Experiences (Dec. 2001). |
All About Tivoli Configuration Manager Version 4.2 (Dec. 2002). |
PDA Management with IBM Tivoli Configuration Manager (May 2003). |
Unicenter TNG Asset Management Option Administrator Guide. |
Unicenter TNG Asset Management Option Getting Started. |
Computer Associates Unicenter TNG Asset Management Option 3.1 Provices Complete Server-to-PDA Inventory. |
Combining Location and Data Management in an Environment for Total Mobility Feb. 1996. |
DARPA Open Object-Oriented DatabasePreliminary Module Specification, Change Management Module Nov. 25, 1991. |
How Not to Save Cached Internet Files with Roaming User Profiles Dec. 5, 2003. |
Roam: A Scalable Replication System for Mobile and Distributed Computing Jan. 1998. |
David H. Ratner, Selective Replication—Fine-Grain Control of Replicated Files, Jan. 1995. |
Windows History: Internet Explorer History Jun. 30, 2003. |
Apple Newton 1995. |
AT&T PocketNet Phone 1996. |
Casio Zoomer Oct. 1993. |
Concurrent Versioning Software (CVS) 1990. |
IBM DataPropagator 1994. |
IBM Simon 1994. |
Infinite InterChange Apr. 1997. |
Microsoft Internet Explorer 3.01 Oct. 1996. |
Microsoft Windows NT 4.0 Jul. 1993. |
Microsoft Windows XP Aug. 2001. |
Motorola Envoy Apr. 10, 1995. |
Motorola Marco Apr. 10, 1995. |
Nokia 9000 Communicator 1995. |
Nokia 9000i Communicator Aug. 1996. |
Pilot Organizer 1996. |
Sharp Zaurus Dec. 15, 1994. |
Sony Magic Link 1994. |
XcelleNet RemoteWare 1996. |
Casio Cassiopeia E-115 Pocket PC User's Guide 2000. |
How to Install Microsoft Mobile Information Server 2002 Server Active Sync Dec. 17, 2002. |
IBM Tivoli Configuration Manager 4.2 Aug. 2002. |
Bitfone MVP Product and related software as described in U.S. Appl. No. 60/730,286 Oct. 25, 2005. |
Computer Associates Unicenter TNGAsset Management Option 3.1 Jan. 2001. |
PDA Defense Enterprise Version 2 2002. |
zTrace zSecurity Suite Jun. 13, 2002. |
Ed Simon, Paul Madsen, Carlisle Adams, “An Introduction to XML Digital Signatures,” O'Reilly xml.com (Aug. 8, 2001), http://www.xml.com/pub/a/2001/08/08/xmldsig.html. |
International Search Report issued Jul. 7, 2008 on corresponding International application PCT/US2006/021297, filed Jun. 1, 2006. |
International Preliminary Report on Patentability issued Aug. 12, 2008 on corresponding International application PCT/US2006/021297, filed Jun. 1, 2006. |
RFC 2616, Hypertext Transfer Protocol—HTTP/1.1 at §§ 3.2.2, 9.3,9.5 (1999). |
IBM Tivoli Monitoring Workbench Feb. 2002. |
Number | Date | Country | |
---|---|---|---|
20140370860 A1 | Dec 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13728625 | Dec 2012 | US |
Child | 14472229 | US | |
Parent | 13113478 | May 2011 | US |
Child | 13728625 | US | |
Parent | 11145391 | Jun 2005 | US |
Child | 13113478 | US |