The present invention relates to mobile wireless communication devices, systems, networks and methods of operation. In particular the present invention is directed to mobile wireless communication devices capable of Virtual Mobile Management by remote control.
Wireless handheld devices typically communicate with each other over commonly defined standards based wireless protocols. These devices are typically untethered, unlike wired communication devices such as telephones. Wireless operators provide the wireless networking infrastructure and provide service to the end customer. The customer subscribes for such a service from the operators who in turn guarantee a certain degree of quality of service to their customers.
Wireless handhelds are increasingly becoming more powerful and multi-functional with advancements in hardware and operating systems components, thus providing application developers a common set of programming interfaces or APIs to create rich interactive applications. These applications are either pre-installed prior to commercial shipment or downloaded over-the-air by the customer. Due to the varied complexity of these “smart” device and the applications that execute within them, customer seeks operator's support to troubleshoot their devices.
The customer care organization may require troubleshooting software to provide effective customer support. It may be advantageous to provide an apparatus that provides remote control and diagnostic capabilities to the customer care for effective troubleshooting.
The Virtual Mobile Management apparatus and method of the instant invention employs a control center system operable to enable remote control of wireless handheld devices based upon the establishment of dedicated communication channels with the wireless device. Communication protocols are employed to facilitate display capture, key and touch input simulation, and collect device parameters to analyze and compare with pre-defined parameters and generate a standards deviation report viewable by an authorized user. A device client is resident on the mobile device non-volatile memory and is operable by the end user to invoke the application to request remote control feature. Features and Functionalities of apparatus and method include:
Other objectives and advantages of this invention will become apparent from the following description taken in conjunction with the accompanying drawings wherein are set forth, by way of illustration and example, certain embodiments of this invention. The drawings constitute a part of this specification and include exemplary embodiments of the present invention and illustrate various objects and features thereof.
Referring to
The primary responsibility of the Communication End Point Gateway is to manage the device connections within the system. The server provides communication endpoints between Control Center (Technician Console, Admin and Control Function) and the device; which allows for multiple requests to be serviced within one session from multiple consoles. The server also provides a consistent manner of device connection and Tool service in a system with heterogeneous devices running different operating systems. The server further provides load balancing across multiple Connection Handlers on each Communication End Point Gateway Server in order to minimize single point of failure.
The Connection End Point Gateway server is comprised of a Connection Monitor,
Functions are assigned to the following areas: Admin and Control Function has a primary responsibility is to administer and manage all types of communication between the Control Center and the client devices. The Administrative Service is designed to be central administration entity of the entire VMM-RC system. Through this service, system administrators perform administration ,management and instrumentation all the servers within the system, create and maintain multiple tenants, assign tenant administrator roles, etc . . . The Management Service provides the operational end point to the system with the primary functions of Management Service being: Load distribution among the CEG, Management of device registration, Administration of devices. Administration of users, zones, policies, roles, etc., and Session Queuing.
Management Entity is responsible in providing the Management service with an in-memory data store for key operational data such as ACL, user/group/zone structures, etc. The Service Coordinator is responsible in coordinating the communication between various elements within the System. It provides the database interface to the Registration and Authentication Function in the Control Center. All services register themselves with this service. This service is responsible for service discovery.
A Registration and Authentication Function provides a single point of entry for all devices for enrollment and authentication services during VMM-RC session. It comprises of the following components: Registration Service—during Auto-Enrollment, devices are required to register themselves with this service, prior to enrolling themselves; Enrollment Service—this service is responsible to enroll registered devices with the system. Enrollment process is defined in detail in the later sections of the document; Software Update—this service manages the various client packages in the system. Devices connect to this service to request for client update. If an update is available, the service will provide the appropriate client download link; Device Management—this service provides the enrolled devices an interface to update its parameters in the system such as MDN when the device detects a change; Anchor Admin—this service provides the administration component.
The Technician Console provides a graphical user interface to manage and control the Mobile Devices. The following provides list of functions that can be performed using the console: Begin pre-enrollment requests; manage all RD Mobile devices; service the infrastructure of the Control center; perform administrative tasks, VMM-RC.
A Data Repository stores all the information about the VMM-RC Mobile devices, server configuration, tasks and status settings. These databases are pivotal to configure and update managed devices and server components. It is also responsible to maintain the user login information as well as device authentication information. The system comprises 3 database elements; an Admin DB maintains all the system configurations, tenant configuration and management information, system administration and server instrumentation data. This database is accessed by the AetherPal System Admin Service; an Ops DB maintains data that is required for the operations of the system such as device enrollment, Access Control List (ACL), groups, users, zones, etc. This database is accessed by the AetherPal Management Service and the Service Coordinator; and a Reports DB contains historical data of device enrollment, session, audit, report views, and so forth.
Referring to
Access Control Entity layer provides a set of functions to the Tool Services to communicate with the Control Center. It provides in the encapsulation of messages before forwarding it to the Communication Core. This layer is responsible to invoke an instance of the Communication Core layer and provides a state machine that defines the state of the VMM application. An Access Control Interface provides a set of standard Application Programmer Interface or API to the Tool Services. These APIs provide a consistent communication platform to facilitate both synchronous as well as asynchronous communication. The ACI State Machine identifies the overall state of the VMM application. State transitions within the ACE State Machine triggers events that are handled by the VMM layer. The states are Open and Closed. Traffic flows through the ACI layer only in the Open State. The Message Routing Entity is responsible for routing all signal messages, destined to Tool Services to the respective event handlers. The Message Processing Function is a signal message pre-processor. This entity receives signal messages from the Session Layer destined towards Tool Services. It de-frames these messages prior to forwarding it to the Message Routing Entity to apply routing rules. Messages that are destined to the server from Tool Services are encapsulated here.
The Communication Core Layer is responsible to setup and maintain a dedicated communication channel with the Control Center. This layer provides the necessary framework to transport messages between the upper layers and the Control Center. It provides message encapsulation, framing, fragmentation and packet re-construction of Tool Service messages.
Referring to
The state machine entity maintains a state within a pre-defined set of shared states between the application and the CEG. State changes within the state machine trigger the execution of state transition procedures within the application.
This signal message processor entity is responsible to encapsulate and process signal messages that are transmitted between the CEG and the application. This entity is also responsible in influencing the state transition within the state machine by altering its state. Signal messages destined to VMM modules are forwarded to the Signal Message Routing Function.
This signal message routing function entity is responsible to forward signal messages to the appropriate destination. Signal messages destined to VMM modules are directly forwarded to VVM Tool Service Coordinator. Signal messages destined to the CEG are forwarded to the link layer.
The Packet Framing Entity is responsible to encapsulate messages into Link Layer frames. These frames are then forwarded to the Transport Channel, to be forwarded to the network layer. When a network packet is received by the Packet Framing Entity, it inspects the packet and verifies the integrity of the packet. Malformed packets are silently discarded.
The Transport Channel binds to the appropriate transport layer of the underlying operating system, which is dependent upon the VMM Tool Service. It is responsible to forward messages to the network layer and receives messages from the network layer. It provides notification to the upper layer on the state of the network layer through asynchronous events.
Referring to
The VMM-RC Application provides Core Tool services, to manage the remote control session, collect the desired device diagnostics, provide self-care support for remote session activation and manage security protocol. The key features that are required by VMM-RC application to manage devices remotely include: Display Capture, this method involves the capturing of device screen; Key event Injection, this method involves the injection of key events into the device screen; Touch event injection, this method involves the simulation of touch events on the device screen; Device Information, getting the device information like network, power status, MNC, MCC, IMEI, IMSI, ESN, battery level of the smart phone etc., this is of value to the remote technician.
A VMM-RC Enabler performs the key functions: Intercepts all the SMS; keeps the VMM-RC Application to its current version; if the VMM-RC Application is removed accidentally the VMM-RC Enabler shall connect to the server and download the application and installs the same.
The User Initiated VMM-RC session is established with a server through the following phases: Device Enrollment; User Initiated Session; End to End Session Establishment; and Graceful Termination of the VMM-RC Session.
Device Enrollment: Before a Mobile device can connect to the Server, it must establish itself as a known and authenticated object in the system. In general, this is accomplished by Mutual Authentication, Enrollment Request, and Enrollment Response.
If for any reason the enrollment failed the VMM-RC Mobile application shall retry the enrollment process at a later time. For any SIM/MDN change the device will reboot as part of the standard procedure. Hence during boot-up the VMM-RC Mobile application shall detect the below changes: Device is previously Enrolled, SIM/MDN Change, Check for client upgrade. Before proceeding ahead with the re-enrollment process the VMM-RC Mobile application shall check if the data connectivity is available on the mobile device. Else it will retry at a later time.
Before the enrollment process begins the VMM-RC Mobile Application checks with the server to see if there is any client upgrade required on the mobile device.
Referring to
Step 1: When a Connection request is made for a VMM-RC connection, the technicians' Console authenticates with its peer.
Step 2: Technician's console sends a PEER_CONNECT request to the Communication End Point Gateway.
Step 3: The server authorizes the Connection Request and sends the PEER_CONNECT request to the relevant device.
Step 4: When the client receives the PEER_CONNECT request message it has to send an ACK or NAK based on its current state.
Step 5: Once the Server receives an ACK it will make the VMM-RC request with the Client.
Step 6: Based on the response (ACK or NAK) the Communication End Point Gateway will establish a peer-to-peer connection or disconnect the session.
During the VMM-RC session the technician will be able to query device information like process list, list of applications installed/running on the device, device manufacturer details etc . . . , from the mobile device in session.
Referring to
This application is a continuation-in-part of U.S. patent application Ser. No. 12/426,555, filed Apr. 20, 2009, entitled VIRTUAL MOBILE AND AD/ALERT MANAGEMENT FOR MOBILE DEVICES, which claims priority of U.S. Provisional Patent Application No. 61/046,593, filed Apr. 21, 2008, entitled VIRTUAL MOBILE AND AD/ALERT MANAGEMENT FOR MOBILE DEVICES, the entirety of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5995829 | Broderick | Nov 1999 | A |
5999521 | Thompson | Dec 1999 | A |
6047071 | Shah | Apr 2000 | A |
6144849 | Nodoushani et al. | Nov 2000 | A |
6148197 | Bridges et al. | Nov 2000 | A |
6201964 | Tung et al. | Mar 2001 | B1 |
6378088 | Mongan | Apr 2002 | B1 |
6516188 | New et al. | Feb 2003 | B1 |
6564055 | Hronek | May 2003 | B1 |
6615038 | Moles et al. | Sep 2003 | B1 |
6625451 | La Medica, Jr. et al. | Sep 2003 | B1 |
6684359 | Noy | Jan 2004 | B2 |
6907546 | Haswell et al. | Jun 2005 | B1 |
6925405 | Adir et al. | Aug 2005 | B2 |
6959433 | Morales, Jr. et al. | Oct 2005 | B1 |
6970719 | McConnell et al. | Nov 2005 | B1 |
7032212 | Amir et al. | Apr 2006 | B2 |
7194264 | Li et al. | Mar 2007 | B2 |
7286802 | Beyme et al. | Oct 2007 | B2 |
7730189 | Harikumar | Jun 2010 | B2 |
20030156549 | Binder et al. | Aug 2003 | A1 |
20040268148 | Karjala et al. | Dec 2004 | A1 |
20050192052 | Tenhunen | Sep 2005 | A1 |
20050227688 | Li et al. | Oct 2005 | A1 |
20060053289 | Singh | Mar 2006 | A1 |
20060053290 | Randle et al. | Mar 2006 | A1 |
20070294368 | Bomgaars et al. | Dec 2007 | A1 |
20080160956 | Jackson et al. | Jul 2008 | A1 |
20090077184 | Brewer et al. | Mar 2009 | A1 |
20090264102 | Parmar et al. | Oct 2009 | A1 |
20120003960 | Parmar et al. | Jan 2012 | A1 |
20120254762 | Parmar et al. | Oct 2012 | A1 |
Number | Date | Country |
---|---|---|
2009018268 | Feb 2009 | WO |
Number | Date | Country | |
---|---|---|---|
20120254762 A1 | Oct 2012 | US |
Number | Date | Country | |
---|---|---|---|
61046593 | Apr 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12426555 | Apr 2009 | US |
Child | 13492507 | US |