The present invention relates generally to communications over a telecommunications network, and in particular embodiments, to techniques and mechanisms for a system and method for data synchronization.
Database synchronization technologies may be used by mobile applications (e.g., applications on a client device) to allow a user to create and/or modify data locally on the client device even when the client device is not connected to a network. Thus, an enriched user experience can be provided, which allows the manipulation of data without being affected by the network connectivity status of a device. Mobile database synchronization mechanisms are used to synchronize user data with a backend database when a network connection between the client device and the backend database is available. Mobile database synchronization mechanisms may also be used to provide the client data on multiple interfaces (e.g., multiple client devices), to back-up (e.g., create redundant copies) the client data, and the like. The user-friendliness of mobile database synchronization mechanisms is leading to its increasing adoption.
As with many asynchronous synchronization mechanisms (e.g., not in real time synchronization), mobile database synchronization mechanisms may rely on long polling based logic or active notification based logic. However, these methods may not be efficient in terms of network resource utilization. For example, long polling methods involve a mobile application periodically polling a server to detect changes in the client data and trigger synchronization. Thus, long polling methods may be inefficient for managing data that changes infrequently. As another example, active notification based synchronization methods involve the mobile application maintaining a connection with the server to receive notifications of a change in client data. Furthermore, notifications may be delivered even when the mobile application is not in active use.
Technical advantages are generally achieved, by embodiments of this disclosure which describe systems and methods for providing data synchronization in a PTT environment.
In accordance with an embodiment, a method includes receiving, by a client on a client device, a data change notification. The data change notification indicates a change in data relating to the client at a client data store. The method further includes determining, by the client, a type of the data relating to the client changed at the client data store and determining, by the client, a data synchronization mechanism in accordance with the type of the data relating to the client changed at the client data store. Determining the data synchronization mechanism includes determining when to attempt, by the client, a data synchronization to synchronize data on the client device with the data relating to the client changed at the client data store.
In accordance with an embodiment, a method includes receiving, by a notification server in a telecommunications services platform, a data change notification. The data change notification indicates a change to data relating to a client at a client data store by one or more services provided by the telecommunications services platform. The method further includes maintaining, by the notification server, a data change notification queue for the client, determining, by the notification server, a state of the data change notification queue, and determining, by the notification server, whether to transmit the data change notification to the client in accordance with the state of the data change notification queue.
In accordance with an embodiment, a telecommunications services platform includes a client data store storing data relating to a push-to-talk (PTT) client on a client device, one or more processors, and a computer readable storage medium storing programming for execution by the one or more processors. The programming includes instructions to provide one or more PTT services to the PTT client and provide a notification server. The notification server is configured to receive a data change notification indicating a change to the data relating to the PTT client by the one or more PTT services, transmit the data change notification to the PTT client when the notification server determines no data change notifications have been transmitted to the PTT client since a most recent time the PTT client successfully synchronized data with the client data store, and not transmit the data change notification to the PTT client when the notification server determines a previous data change notification has been transmitted to the PTT client since the most recent time the PTT client successfully synchronized data with the client data store.
For a more complete understanding of various example embodiments, and the advantages thereof, reference is now made to the following descriptions taken in conjunction with the accompanying drawings, in which:
Corresponding numerals and symbols in the different figures generally refer to corresponding parts unless otherwise indicated. The figures are drawn to clearly illustrate the relevant aspects of the embodiments and are not necessarily drawn to scale.
The making and using of embodiments of this disclosure are discussed in detail below. It should be appreciated, however, that the concepts disclosed herein can be embodied in a wide variety of specific contexts, and that the specific embodiments discussed herein are merely illustrative and do not serve to limit the scope of the claims. Further, it should be understood that various changes, substitutions and alterations can be made herein without departing from the spirit and scope of this disclosure as defined by the appended claims.
Various embodiments are described within a specific context, namely, data synchronization in a push-to-talk (PTT) system. Various embodiments may, however, be applied to other systems and networks, where data synchronization between a backend client data store and client devices is desired.
Various embodiments as described below provide real-time and non-real-time data synchronization for data across one or more client devices and a backend client data store. Various embodiments allow for the flexibility of receiving data in real-time as well as providing network resource savings when using an asynchronous data synchronization mechanism.
Client devices 102 may communicate with telecommunications services platform 106 over network 104, which may be accessed by client devices 102 through a cellular network deployed by a carrier, a WiFi network, a radio access network (RAN), other wireless networks, a wired internet protocol (IP) network, combinations thereof, or the like. Network 104 may include one or more components configured to provide wireless or wired network access, such as an enhanced base station (eNB), a macro-cell, a femtocell, a Wi-Fi access point (AP), combinations thereof, or the like. Furthermore, network 104 may operate in accordance with one or more wireless communication protocols, e.g., open mobile alliance (OMA), long term evolution (LTE), LTE advanced (LTE-A), High Speed Packet Access (HSPA), Wi-Fi 802.11a/b/g/n/ac, etc. In some embodiments, network 104 may comprise various other devices, such as relays, low power nodes, etc. Network 104 may further include backhaul network components, such as various gateways, routers, controllers, schedulers, and the like.
In an embodiment where telecommunications services platform 106 is a PTT-over-Cellular (PoC) platform, subscribers to a PTT solution (e.g., users operating client devices 102) may be provisioned onto system 100 via interfaces to carriers (e.g., cellular carriers). PTT customers (e.g., enterprises) can administer these subscribers to form closed groups for PTT communications. The PTT solution may interface with the carrier, for example, by including connectivity to the carrier's core network, billing interfaces, provisioning interfaces, lawful intercept interfaces, customer care interfaces, and the like. The PTT platform may provide a plurality of PTT functions to client devices 102 through the PTT clients on client devices 102 as described in greater detail below.
In some embodiments, telecommunications services platform 106 uses container technology for virtualization of a telecommunications system architecture, such as, the virtualization of provided PTT services. Example container technologies may include Docker, Rocket, LXD, and the like although the architecture is not limited to a specific container technology. Virtualization using container technology may allow telecommunications services platform 106 to adopt a micro-services model in which service clusters are considered the building blocks of the system architecture. For example, each function provided by telecommunications services platform 106 may be virtualized in a unique service cluster, and each service cluster may perform a different function in telecommunications services platform 106. Service clusters are hosted on virtual machines of an embodiment cloud network. An embodiment cloud network may include a plurality of geographically diverse deployment sites (e.g., data centers) where various virtual machines are physically deployed. Decomposition of the system into a set of services allows each service (e.g., each function provided by the telecommunications services platform) to be independently deployed and managed. Thus, system resilience may be improved as failures are localized to individual services. Furthermore, rapid and agile deployment of services may also be achieved.
In some embodiments, telecommunications services platform 106 incorporates distributed databases, clustering technologies, data analytics tools, and messaging middleware to provide a robust, scalable platform. Telecommunications services platform 106 may use fully virtualized components with a layered approach to service orchestration, which allows telecommunications services platform 106 to be integrated into various cloud environments, such as a carrier's private cloud infrastructure, a dedicated PTT cloud infrastructure, combinations thereof, and the like. A more detailed description of an embodiment telecommunications services platform may be found in commonly-assigned U.S. patent application Ser. No. 14/994,757 filed on Jan. 13, 2016, entitled “System and Method for Elastic Scaling using a Container-Based Platform,” which is hereby incorporated by reference. Other telecommunication services platforms, including other PTT platforms, may be used in other embodiments.
Various embodiments allow different types of data synchronization mechanisms for different types of data. For example, some types of data may be synchronized using real-time data synchronization while other types of data may be synchronized using non-real-time data synchronization (also referred to as asynchronous data synchronization). Generally, as referred to herein, “real-time synchronization” refers to a synchronization mechanism where a client on a client device attempts to synchronize data when a data change notification is received regardless of whether the client is operating passively in the background of the client device or actively in the foreground of the client device. Furthermore, “non-real-time synchronization” refers to when a client on a client device waits to become active in the foreground of a client device before attempting to synchronize data when a data change notification is received. Although referred to as a non-real-time synchronization mechanism throughout, in practice, an embodiment non-real-time synchronization mechanism may include specific instances of real-time synchronization. For example, when a client receives a data change notification while the client is active in the foreground of the client device, the client may synchronize data in real-time even for types of data using a non-real-time synchronization mechanism. Thus, the use of terms “real-time” and “non-real-time” is not meant to implicitly limit the actual timing of synchronization. Rather, these terms are used to describe different types of data synchronization mechanisms, which include different types of client behavior upon receipt of a data change notification.
In an embodiment, the type of synchronization is determined by a user experience desired for a particular service, and the type of synchronization type for a particular service may be configured differently for different types of users. For example, presence and location updates notifications may be delivered in non-real time mode for users at a construction site or a school campus whereas the same information may be delivered in real time for users in the logistics industry. The types of data synchronization mechanisms for types of data may be configured by a user, a group administrator, a network administrator, a service operator, a standard, combinations thereof, or the like. Different types of data may also result in different types of notification mechanisms for indicating a change in data. For example, a non-real-time synchronization mechanism may or may not require real-time data change notifications depending on the type of data as explained in greater detail below.
Furthermore, PTT platform 106 may include different notification channels, such as, real-time notification channel 206 and non-real-time notification channel 208. Real-time notification channel 206 may be provided through a notification service 210, for example, as described in U.S. patent application Ser. No. 15/013,718 filed on Feb. 2, 2016, entitled “Session Management and Notification Mechanisms for Push-to-Talk (PTT),” which is hereby incorporated by reference. Other real-time notification mechanisms may be used in other embodiments. Non-real-time notification channel 208 may be provided through a data synchronization server 212, which may provide notification-triggered synchronization mechanisms as described in greater detail with respect to
In some embodiments, different types of data changes by different types of services may result in different types of data synchronization mechanisms as detailed in Table 1. Different types of data changes may further result in different types of notifications and/or different contents in the corresponding notification. Table 1 below provides some example types of data and corresponding types of notifications and data synchronization mechanisms in a PTT platform. In other embodiments, the types of data changes may result in other types of notifications/data synchronization mechanisms, and other types of data changes with corresponding types of notifications/data synchronization mechanisms may also exist in other embodiments. The types of notifications corresponding to different types of notifications/data synchronization mechanisms may be configured by a user, a group administrator, a network administrator, a service operator, a standard, combinations thereof, or the like.
As indicated by Table 1.0, some notifications (e.g., data change notifications) may include at least a portion of the contents of the changed data (e.g., text message contents, meta content, PTT IPA, PTT call status data, and the like) along with a pending change indication for certain types of data. In such embodiments, the contents are received in the notification and further synchronized as described above for archival purposes.
As an example regarding text messages, the data change notification may include a pending change indication as well as contents of the text messages. The notification alerts a user of the existence and contents of a new text message. However, the client may also store the text message as part of text message history (e.g., an archive to allow a user to access threaded message history, to search past text messages, and the like). A master of copy of archive may be maintained by a server (e.g., a client data store). In instances where text message data is synchronized using a non-real-time synchronization mechanism, the client will synchronize archival text message history with the server when the client comes to the foreground when the data change notification for text messages is received.
As another example regarding MMS messages, the data change notification may include a pending change indication as well as meta contents (e.g., sender information, recipient(s) information, subject lines, thumbnails of a MMS attachment, and the like) of the MMS message. The notification alerts a user of the existence and meta contents of the MMS message. However, the client may also store the meta contents of the MMS message history (e.g., an archive to allow a user to access threaded message history, to search past MMS messages, and the like). A master of copy of archive may be maintained by a server (e.g., a client data store). In instances where MMS meta content is synchronized using a non-real-time synchronization mechanism, the client will synchronize archival text message history with the server when the client comes to the foreground when the data change notification for MMS messages is received. The attachment of the MMS message may be synchronized based on client configuration. For example, when the client is configured to automatically download MMS message attachments, data synchronization is done immediately (e.g., in real-time upon receipt of the notification). Otherwise, the data synchronization for the attachment is invoked when the user requests download of the attachment. The above two examples of synchronizing archival data may further be applied for other types of data, such as, IPAs, call history data (e.g., call received data, call sent data, call duration data, and the like), combinations thereof, and the like.
If the message was not successfully delivered, a determination is made regarding the type of notification being delivered in step 262. Depending on the type of notification, different notification mechanisms may be used when a message is not successfully delivered. For example, in
Various embodiments provide mechanisms for real-time and non-real-time data synchronization with improved network resource management. For example, network resources may be wasted on data synchronization of certain types of data when a client is running as a background process. As another example, network resources may be wasted if the client performs a data synchronization check (e.g., check for data changes) every time the client is brought to foreground. Resources used to poll a server for data changes may be especially wasteful for types of data that do not change frequently. For example, configuration change notifications, group list updates, contact list updates, presence statuses for some types of users, and the like may be examples types of data that do not change frequently. Other types of data may also change infrequently.
In an embodiment, a notification server (e.g., as part of data synchronization server 212 and/or notification service 210) notifies the client when there is a change to data. Subsequently, the notification server may not send any further notifications to the client regarding non-real-time synchronization type data until the client successfully synchronizes data with a backend client data store even when there are additional changes to data relating to the client. In such embodiments, the notification server may or may not transmit subsequent notifications for real-time synchronization type data between an initial notification and when a client successfully synchronizes data with a backend client data store. Thus, network resources may be saved by transmitting a single notification, which indicates to the client that there are data changes at the client data store and triggers the client to synchronize its data with the network. Additional network resources to transmit additional notifications (e.g., for additional changes in data) between a data change notification and data synchronization may be saved. After the client synchronizes data, the notification server may transmit another notification to the client when a subsequent data change occurs. Various notifications from the notification server (including data change notifications) may further be throttled to reduce network resource congestion (e.g., RAN resource congestion) as explained in greater detail below.
Furthermore, for non-real-time synchronization types of data, a client may only perform data synchronization when the user brings the client to the foreground (e.g., when the user opens the client for use). Data synchronization may not be triggered each time the client is brought to the foreground. Rather, the client determines if a data change notification was received since a most recent successful data synchronization to trigger a subsequent data synchronization. In some embodiments, the client may not actively poll the server for changes and relies on data change notifications to determine when a change in data has occurred. The client may further synchronize data with the platform when the client regains network connectivity with the platform after the client was offline. In this way, missed data change notifications (e.g., while the client was offline) does not result in a delay or loss in synchronizing data. Thus, network resources for polling the server for data change (particularly for data that changes infrequently) can be saved.
In an embodiment, client 204 uses various services 202, and data used for the operation of these services is stored in client data store 306. In an embodiment PTT platform, services 202 may include PTT call servers (e.g., for providing PTT calls), presence servers (e.g., for tracking availability and status of contacts and/or groups), messaging servers (e.g., for text messages, multimedia messages, and/or the like), XDM servers (e.g., for contact data and/or group management data), location services, and the like. Services 202 may transmit client data changes to client data store 306.
When a service 202 creates or modifies data in client data store 306, the service 202 transmits a data change notification to notification server 308. In an embodiment, notification server 308 may be part of notification service 210 or a separate entity (e.g., part of data synchronization server 212). Notification server 308 delivers data change notifications sent by services 202 to client 204. Data change notifications for non-real-time data synchronization types of data may or may not be delivered to a client depending on whether a previous data change notification was delivered and whether a client has completed data synchronization after the previous data change notification and the type of data changed. For example, if a data change notification has already been transmitted to client 204 since the most recent time client 204 successfully performed data synchronization, notification server 308 does not deliver the subsequent data change notification to client 204. As another example, if a data change notification has not been transmitted to client 204 since the most recent time client 204 successfully performed data synchronization, notification server 308 does deliver the data change notification to client 204. Furthermore, a user (or other operator) may designate certain types of data for real-time notifications, and a data change notification may be transmitted for these types of data each time a change occurs regardless of whether a previous notification was sent since a most recent successful synchronization.
In some embodiments, notification server 308 may further interact with location server 310 and analytics system 312 to determine network resource (e.g., RAN resource) congestion status at the location of client 204 (e.g., the location of the client device on which client 204 resides). Notification server 308 may determine whether to throttle messages (e.g., notifications) when delivering the data change notifications to client 204 in accordance with interactions with location server 310 and analytics system 312.
Location server 310 tracks the RAN location for active clients (e.g., client 204) in the telecommunications services platform. For example, location server 310 may track which cells (e.g., base stations, macro-cells, femtocells, Wi-Fi APs, combinations thereof, and the like) serve clients (e.g., client 204) in the telecommunications services platform. Location information is collected through location updates sent by clients (e.g., client 204). In some embodiments, the client transmits location updates piggy-backed on other messages between the client and the various components of the telecommunications services platform. For example, location updates may be piggy-backed on service requests sent by various clients when accessing services 202.
Various services 202 report user activity to analytics system 312. This user activity data is used by analytics system 312 to create a system wide network resource utilization map (e.g., a RAN utilization map). The network resource utilization map may continuously track and monitor what network resources are being used by different cells in a network.
Notification server 308 may use the network resource utilization map and the location information to determine whether to throttle delivery of data change notifications to clients in congested areas. For example, notification server 308 may ensure that the number of notifications delivered by any cell in the network is below a maximum threshold within a certain time period. For example, notification server 308 allows delivery of data change notifications to clients served by a first cell within a first time period until a maximum number of notifications threshold is reached. The maximum number of notifications threshold and/or time periods may be configurable and set by the telecommunications system operator, a standard, a combination thereof, or the like. Once the maximum number of notifications threshold is reached, notification server 308 may hold additional notifications for delivery by the first cell until the next time period. Thus, network resources are not overwhelmed by notification delivery.
Various embodiments include real-time and non-real-time data synchronization mechanisms, which advantageously provide data synchronization with improved efficiency in network resource utilization. In an embodiment platform, a client (e.g., a client 204 on client device 102) waits to receive a data change notification from a telecommunications services platform to determine when data change(s) has occurred instead of periodically polling a client data store to detect data changes. The client is not required to keep an active connection with the telecommunications services platform to receive pushed data changes in real-time. Instead, as described above with respect to
Furthermore, whenever the client is brought to the foreground, the client may not automatically trigger data synchronization. For example, the client may initiate data synchronization if at least one data change notification was received while the client was in the background. As another example, the client may initiate data synchronization if the client temporarily lost network connectivity for at least a configurable interval of time to catch missed data change notifications during the lost network connectivity.
The client may enter inactive state 402 on startup of the client device and when client loses network connectivity/becomes temporarily unavailable. In inactive state 402, the client attempts to synchronize client data on the client device with data on the client data store (step 408A) as a result of a login attempt (e.g., attempt to re-connect with the client data store) and/or when the client is brought to the foreground (e.g., when the client switches from a background process to an active process). When the client successfully synchronizes data between the client device and the client data store, the client transitions to no-data-pending state 404. If the attempt to synchronize data (step 408A) is unsuccessful, the client determines whether to retry data synchronization (step 408B). For example, the client may retry the attempt to synchronize data until a maximum number of retries (designated MaxRetry) is exhausted. The maximum number of retries may be a configurable number set by the telecommunications services platform, the user, a standard, a combination thereof, or the like. When the maximum number of retries for data synchronization has been exhausted, the client may enter data-pending state 406.
Furthermore, when the client receives a data change notification (e.g., from a notification server) while in inactive state 402, the client determines whether it is running active in the foreground of the client device or passively in the background of the client device (step 408D). For example, the client determines whether it is actively running on the client device or running as a background process of the client device. When the client application is active in the foreground of the client device, client attempts data synchronization (step 408A). Success or failure of the data synchronization procedure may result in transitioning into no-data-pending state 404, data synchronization procedure retries, and/or transitioning into data pending state 406 as discussed above. When the client application is passive in the background of the client device, the client transitions to data-pending state 406 upon receiving the data change notification in inactive state 402.
The client enters no-data-pending state 404 when the client successfully completes data synchronization. When the client receives a data change notification from the server when in no-data-pending state, the client determines whether it is active in the foreground of the client device or passive in the background (step 408C). For example, the client determines whether it is actively running on the client device or running as a background process of the client device. When the client application is active in the foreground of the client device, client attempts data synchronization with the server (step 408A). When the client application is passive in the background of the client device, the client transitions to data-pending state 406 upon receiving the data change notification in no-data-pending state 404.
Success or failure of the data synchronization procedure may result in staying in no-data-pending state 404, data synchronization procedure retries, and/or transitioning into data pending state 406 as discussed above. For example, upon successfully synchronizing data in no-data-pending state 404, the client remains in no-data-pending state 404. If data synchronization fails in no-data-pending state 404, client retries data synchronization until a maximum number of retry attempts is exhausted. When the maximum number of retry attempts is exhausted, the client enters data-pending state 406. If the client loses network connectivity (e.g., becomes temporarily unavailable to the server) when the client is in no-data-pending state 404, then client transitions to inactive state 402.
The client enters data-pending state 406 when the client has received a data change notification from the server while the client application is passive in the background. The client may further enter data-pending state 406 when attempts at data synchronization have failed more than the maximum number of retry attempts.
In data-pending state 406, the client ignores all subsequent data change notifications received from the notification server. Furthermore, in data-pending state 406, when the client loses network connectivity (e.g., becomes temporarily unavailable to the telecommunications services platform), the client may remain in data-pending state 406.
When the client becomes active (e.g., brought to the foreground by a user or the client device's operating system), the client attempts data synchronization (step 408A) with a data synchronization server. Success or failure of the data synchronization procedure may result in transitioning into no-data-pending state 404, data synchronization procedure retries, and/or remaining into data-pending state 406 as discussed above. For example, upon successfully synchronizing data in data-pending state 406, the client transitions to no-data-pending state 404. If the data synchronization attempt fails in data-pending state 406, the client retries data synchronization until a maximum number of retry attempts is exhausted. When the maximum number of retry attempts is exhausted, the client remains in data-pending state 406.
In an embodiment, the notification server maintains a data change notification queue for each mobile client served by the notification server, such as, each client relying on the notification server to deliver notifications.
Data change notification queue is in closed state 502 when the client is offline. In closed state 502, the notification server ignores data changes notifications by the client data store and/or the various services provided by the platform. For example, the notification server may discard all data change notifications relating to the client received while the data change notification queue is in closed state 502. When the client comes online and is connected to the server, the notification server attempts to transmit an initial data change notification to the client. This notification may be sent regardless of whether any data changes occurred while the client was offline. If the initial data change notification is delivered successfully to the client, the notification server transitions the data change notification queue to data-pending state 508. The initial data change notification triggers the client to attempt data synchronization. If the initial data change notification is not delivered successfully, the notification server transitions the data change notification queue to init state 504.
When a data change notification queue is in init state 504, the notification server may retry sending the initial data change notification to the client one or more times. The data change notification queue stays in init state 504 until the initial data change notification is delivered to the client successfully or the client successfully completes a data synchronization attempt. Upon successful delivery of the initial data change notification, the state of the data change notification queue is transitioned to no-data-pending state 506. Similarly, when the client successfully completes data synchronization while the data change notification queue is in init state 504, the state of the data change notification queue is transitioned to no-data-pending state 506. If the client goes offline when the data change notification queue is in init state 504, the state of the data change notification queue is transitioned to closed state 502. Transitioning to closed state 502 may further include clearing the data change notification queue.
The data change notification queue enters data-pending state 508 after at least one data change notification has been delivered to the client. This can occur when the initial data change notification is delivered to the client; at the time of client login; or when a data change notification is received by the notification server while the data change notification queue is in no-data-pending state 506.
In data-pending state 508, the notification server enqueues subsequent data change events until the client successfully completes data synchronization with a client data store. In an embodiment, the subsequent data change events are determined by the notification server from subsequent data change notifications transmitted to the notification server by the client data store and/or various services in the platform. The notification server may further determine when a client successfully completes data synchronization from a notification transmitted by, for example, a data synchronization server (e.g., data synchronization server 212). In some embodiments, the notification server may optionally transmit data change notifications while in data-pending state 508 for certain types of data (e.g., data where real-time notifications are desired). When the client retrieves pending data by successfully completing data synchronization, the data change notification queue is transitioned to no-data-pending state 506 and the enqueued data change events may be cleared.
If the client goes offline when the data change notification queue is in data-pending state 508, the data change notification queue is cleared and the state of the data change notification queue is transitioned to closed state 502.
The data change notification queue enters no-data-pending state 506 when the client successfully synchronizes data with the client data store. In no-data-pending state 506, the notification server waits for a data change event to occur (e.g., as reported by a service) and sends a data change notification to the mobile client when the data change event occurs. After sending the data change notification to the client, data change notification queue state is transitioned to data-pending state 508. If the client goes offline when the data change notification queue is in no-data-pending state 506, the state of the data change notification queue is transitioned to closed state 502. Transitioning to closed state 502 may further include clearing the data change notification queue.
In various embodiments, the notification server may also throttle data change notifications based on client location and network resource utilization at the client location. For example, a client reports its location information to a location server as part of its login and login session refresh procedures. The location information may also be piggy-backed in service requests sent by the client. This location information is processed by an analytics system in real-time and a network resource utilization map is generated and maintained by the analytics system. For example, the network resource utilization map may be maintained and updated continuously in real-time to track network resource utilization and/or capacity at various locations in the network. When sending data change notifications to various clients, the notification server may use of the network resource utilization map to throttle the notifications and not exceed a maximum configured threshold for the network utilization level at any given network location (e.g., any cell).
In some embodiments, the processing system 600 is included in a network device that is accessing, or part otherwise of, a telecommunications network. In one example, the processing system 600 is in a network-side device in a wireless or wireline telecommunications network, such as a base station, a relay station, a scheduler, a controller, a gateway, a router, an applications server, or any other device in the telecommunications network. In other embodiments, the processing system 600 is in a user-side device accessing a wireless or wireline telecommunications network, such as a mobile station, a user equipment (UE), a personal computer (PC), a tablet, a wearable communications device (e.g., a smartwatch, etc.), or any other device adapted to access a telecommunications network.
In some embodiments, one or more of the interfaces 610, 612, 614 connects the processing system 600 to a transceiver adapted to transmit and receive signaling over the telecommunications network.
The transceiver 700 may transmit and receive signaling over any type of communications medium. In some embodiments, the transceiver 700 transmits and receives signaling over a wireless medium. For example, the transceiver 700 may be a wireless transceiver adapted to communicate in accordance with a wireless telecommunications protocol, such as a cellular protocol (e.g., long-term evolution (LTE), etc.), a wireless local area network (WLAN) protocol (e.g., Wi-Fi, etc.), or any other type of wireless protocol (e.g., Bluetooth, near field communication (NFC), etc.). In such embodiments, the network-side interface 702 comprises one or more antenna/radiating elements. For example, the network-side interface 702 may include a single antenna, multiple separate antennas, or a multi-antenna array configured for multi-layer communication, e.g., single input multiple output (SIMO), multiple input single output (MISO), multiple input multiple output (MIMO), etc. In other embodiments, the transceiver 700 transmits and receives signaling over a wireline medium, e.g., twisted-pair cable, coaxial cable, optical fiber, etc. Specific processing systems and/or transceivers may utilize all of the components shown, or only a subset of the components, and levels of integration may vary from device to device.
In accordance with an embodiment, a method includes receiving, by a client on a client device, a data change notification. The data change notification indicates a change in data relating to the client at a client data store. The method further includes determining, by the client, a type of the data relating to the client changed at the client data store and determining, by the client, a data synchronization mechanism in accordance with the type of the data relating to the client changed at the client data store. Determining the data synchronization mechanism includes determining when to attempt, by the client, a data synchronization to synchronize data on the client device with the data relating to the client changed at the client data store.
In an embodiment, the data synchronization mechanism is a non-real-time data synchronization mechanism. The non-real-time data synchronization mechanism includes determining, by the client, whether the client is running in a foreground of the client device or running in a background of the client device and attempting, by the client, to synchronize the data on the client device with the data relating to the client changed at the client data store when the client device is running in the foreground of the client device. The non-real-time data synchronization mechanism further includes waiting, by the client, until the client is running in the foreground to attempt to synchronize the data on the client device with the data relating to the client changed at the client data store when the client device is running in the background of the client device.
In an embodiment, the type of the data relating to the client changed at the client data store is presence data, contact data, group management data, a push-to-X text message notification, a push-to-X multimedia message service notification, a push-to-talk (PTT) over cellular (PoC) instant personal alert, location tracking data, changes to PTT call in progress notification, a PTT call completed notification, or a combination thereof.
In an embodiment, the data synchronization mechanism is a real-time data synchronization mechanism. The real-time data synchronization mechanism includes attempting, by the client, to synchronize the data on the client device with the data relating to the client changed at the client data store after the data change notification is received regardless of whether the client is running in a foreground of the client device or running in a background of the client device.
In an embodiment, different types of data synchronization mechanisms are selected for different types of data by a user operating the client device, a group administrator, a network administrator, a service operator, a standard, or a combination thereof.
An embodiment method further includes determining, by the client device, whether the data change notification was received after a most recent successful data synchronization on the client device when the client transitions from running in a background of the client device to running in a foreground of the client device and attempting, by the client, to synchronize the data on the client device with the data relating to the client changed at the client data store when the data change notification was received after the most recent successful data synchronization on the client device. The method may further include not attempting, by the client, to synchronize the data on the client device with the data relating to the client changed at the client data store when the data change notification was not received after the most recent successful data synchronization on the client device and the client did not lose network connectivity after the most recent successful data synchronization on the client device.
An embodiment method further includes losing, by the client, network connectivity for at least an interval of time; and attempting, by the client, to synchronize data on the client device with data at the client data store when the client regains network connectivity after losing network connectivity for at least the interval of time.
In an embodiment, the client does not poll the client data store for changes in data relating to the client, and the client is not required to maintain an active connection with the client data store for receiving changes in data relating to the client.
In an embodiment, the data change notification includes at least a portion of the data relating to the client changed at the client data store. The client maintains a first archive of data for the type of the data relating to the client changed at the client data store. The client data store maintains a second archive of data for the type of the data relating to the client changed at the client data store. The data synchronization mechanism is used, by the client, to synchronize the first archive of data with the second archive of data.
In an embodiment, a method includes receiving, by a notification server in a telecommunications services platform, a data change notification. The data change notification indicates a change to data relating to a client at a client data store by one or more services provided by the telecommunications services platform. The method further includes maintaining, by the notification server, a data change notification queue for the client, determining, by the notification server, a state of the data change notification queue, and determining, by the notification server, whether to transmit the data change notification to the client in accordance with the state of the data change notification queue.
In an embodiment, the method further includes further, transmitting, by the notification server, the data change notification to the client when the data change notification queue is in a no-data-pending state. The data change notification queue transitions into the no-data-pending state when the client successfully synchronizes data with the client data store. The method may further include after transmitting the data change notification, transitioning the data change notification queue to a data-pending state.
In an embodiment, the method further includes receiving, by the notification server, one or more additional data change notifications while the data change notification queue is in a data-pending state. The one or more additional data change notifications indicates one or more additional changes to data relating to the client at the client data store by the one or more services. The method further includes enquequing, by the notification server, the one or more additional data change notifications until the client successfully synchronizes data with the client data store. The method further includes not transmitting, by the notification server, the one or more additional data change notifications while the data change notification queue is in the data-pending state.
In an embodiment, the method further includes ignoring, by the notification server, the data change notification when the data change notification queue is in a closed state. The data change notification queue is in the closed state when the client loses network connectivity. The method further includes transmitting, by the notification server, an initial data change notification to the client when the client regains network connectivity.
In an embodiment, the method further includes throttling, by the notification server, the data change notification in accordance with a location of the client and a network resource utilization map.
In an embodiment, determining, by the notification server, whether to transmit the data change notification to the client in accordance with the state of the data change notification queue includes transmitting the data change notification to the client when the notification server determines no data change notifications have been transmitted to the client since a most recent time the client successfully synchronized data with the client data store and not transmitting the data change notification to the client when the notification server determines a previous data change notification has been transmitted to the client since the most recent time the client successfully synchronized data with the client data store.
In accordance with an embodiment, a telecommunications services platform includes a client data store storing data relating to a push-to-talk (PTT) client on a client device, one or more processors, and a computer readable storage medium storing programming for execution by the one or more processors. The programming includes instructions to provide one or more PTT services to the PTT client and provide a notification server. The notification server is configured to receive a data change notification indicating a change to the data relating to the PTT client by the one or more PTT services, transmit the data change notification to the PTT client when the notification server determines no data change notifications have been transmitted to the PTT client since a most recent time the PTT client successfully synchronized data with the client data store, and not transmit the data change notification to the PTT client when the notification server determines a previous data change notification has been transmitted to the PTT client since the most recent time the PTT client successfully synchronized data with the client data store.
In an embodiment, the telecommunications services platform further includes a location server tracking a geographic location of the PTT client. The notification server is further configured to throttle the data change notification in accordance with the geographic location of the PTT client.
In an embodiment, the programming includes further instructions to provide an analytics system. The analytics system is configured to receive user activity reports from the one or more PTT services and maintain a network resources utilization map in accordance with the user activity reports. The notification server is further configured to throttle the data change notification in accordance with the network resources utilization map
In an embodiment, the telecommunications services platform further includes a mobile datasync gateway configured to provide access to the client data store by the PTT client.
While this invention has been described with reference to illustrative embodiments, this description is not intended to be construed in a limiting sense. Various modifications and combinations of the illustrative embodiments, as well as other embodiments of the invention, will be apparent to persons skilled in the art upon reference to the description. It is therefore intended that the appended claims encompass any such modifications or embodiments.
This application claims the benefit of U.S. Provisional Application No. 62/158,384, filed on May 7, 2015, which application is hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
3912874 | Botterell et al. | Oct 1975 | A |
4796293 | Blinken et al. | Jan 1989 | A |
5353328 | Jokimies | Oct 1994 | A |
5442809 | Diaz et al. | Aug 1995 | A |
5546449 | Hogan et al. | Aug 1996 | A |
5711011 | Urs et al. | Jan 1998 | A |
5752196 | Ahvenainen et al. | May 1998 | A |
5987318 | Alperovich et al. | Nov 1999 | A |
5987331 | Grube et al. | Nov 1999 | A |
6011976 | Michaels et al. | Jan 2000 | A |
6021326 | Nguyen | Feb 2000 | A |
6138011 | Sanders, III et al. | Oct 2000 | A |
6141556 | Dougherty et al. | Oct 2000 | A |
6192119 | Wilson | Feb 2001 | B1 |
6304558 | Mysore | Oct 2001 | B1 |
6397054 | Hoirup et al. | May 2002 | B1 |
6405030 | Suprunov | Jun 2002 | B1 |
6411815 | Balasuriya | Jun 2002 | B1 |
6473501 | Paulsrud | Oct 2002 | B1 |
6477366 | Valentine et al. | Nov 2002 | B1 |
6477387 | Jackson et al. | Nov 2002 | B1 |
6549773 | Linden et al. | Apr 2003 | B1 |
6577874 | Dailey | Jun 2003 | B1 |
6606305 | Boyle et al. | Aug 2003 | B1 |
6628937 | Salin | Sep 2003 | B1 |
6661878 | Mirashrafi et al. | Dec 2003 | B1 |
6725053 | Rosen et al. | Apr 2004 | B2 |
6751468 | Heubel et al. | Jun 2004 | B1 |
6801762 | Huilgol | Oct 2004 | B1 |
6856676 | Pirot et al. | Feb 2005 | B1 |
6865398 | Mangal et al. | Mar 2005 | B2 |
6892074 | Tarkiainen et al. | May 2005 | B2 |
6895254 | Dorenbosch | May 2005 | B2 |
6898436 | Crockett et al. | May 2005 | B2 |
6993355 | Pershan | Jan 2006 | B1 |
6996414 | Vishwanathan et al. | Feb 2006 | B2 |
7026926 | Walker, III | Apr 2006 | B1 |
7043266 | Chaturvedi et al. | Jun 2006 | B2 |
7082316 | Elden et al. | Jul 2006 | B2 |
7085364 | Ahmed et al. | Aug 2006 | B1 |
7099291 | Harris et al. | Aug 2006 | B2 |
7123905 | Allaway et al. | Oct 2006 | B1 |
7170863 | Denman et al. | Jan 2007 | B1 |
7231225 | Rao et al. | Jun 2007 | B2 |
7236580 | Sarkar et al. | Jun 2007 | B1 |
7330540 | Darby et al. | Feb 2008 | B2 |
7366535 | Glass et al. | Apr 2008 | B2 |
7403775 | Patel et al. | Jul 2008 | B2 |
7460861 | Zabawskj | Dec 2008 | B2 |
7529557 | Farrill | May 2009 | B2 |
7689238 | Biswas et al. | Mar 2010 | B2 |
7738861 | Fournier | Jun 2010 | B2 |
7738892 | Ayyasamy et al. | Jun 2010 | B2 |
7738896 | Patel et al. | Jun 2010 | B2 |
7751348 | Shaffer et al. | Jul 2010 | B2 |
7764950 | Patel et al. | Jul 2010 | B2 |
7787896 | Kundu et al. | Aug 2010 | B2 |
7797010 | Manroa et al. | Sep 2010 | B1 |
7813722 | Patel et al. | Oct 2010 | B2 |
7853279 | Patel et al. | Dec 2010 | B2 |
8036692 | Ayyasamy et al. | Oct 2011 | B2 |
8244252 | Descombes | Aug 2012 | B2 |
8340651 | Gailloux | Dec 2012 | B1 |
8369829 | Nagubhai et al. | Feb 2013 | B2 |
8478261 | Vempati et al. | Jul 2013 | B2 |
8498660 | Lawler et al. | Jul 2013 | B2 |
8670760 | Lawler et al. | Mar 2014 | B2 |
8676189 | Lawler et al. | Mar 2014 | B2 |
9692878 | Rosenthal | Jun 2017 | B1 |
20010005372 | Cave et al. | Jun 2001 | A1 |
20020009990 | Kleier et al. | Jan 2002 | A1 |
20020024943 | Karaul et al. | Feb 2002 | A1 |
20020077136 | Maggenti et al. | Jun 2002 | A1 |
20020086659 | Lauper | Jul 2002 | A1 |
20020086676 | Hendrey et al. | Jul 2002 | A1 |
20020102989 | Calvert et al. | Aug 2002 | A1 |
20020187750 | Majumdar | Dec 2002 | A1 |
20020196781 | Salovuori | Dec 2002 | A1 |
20030009463 | Gallant | Jan 2003 | A1 |
20030016632 | Refai et al. | Jan 2003 | A1 |
20030017836 | Vishwanathan et al. | Jan 2003 | A1 |
20030078064 | Chan | Apr 2003 | A1 |
20030119540 | Mathis | Jun 2003 | A1 |
20030148779 | Aravamudan et al. | Aug 2003 | A1 |
20030149774 | McConnell et al. | Aug 2003 | A1 |
20030153343 | Crockett et al. | Aug 2003 | A1 |
20030190888 | Mangal et al. | Oct 2003 | A1 |
20040032843 | Schaefer et al. | Feb 2004 | A1 |
20040057449 | Black | Mar 2004 | A1 |
20040067751 | Vandermeijden et al. | Apr 2004 | A1 |
20040095954 | Varney et al. | May 2004 | A1 |
20040121760 | Wetman et al. | Jun 2004 | A1 |
20040127233 | Harris et al. | Jul 2004 | A1 |
20040152441 | Wong | Aug 2004 | A1 |
20040176100 | Florkey et al. | Sep 2004 | A1 |
20040179531 | Bi et al. | Sep 2004 | A1 |
20040196826 | Bao et al. | Oct 2004 | A1 |
20040203793 | Dorenbosch | Oct 2004 | A1 |
20040219941 | Haaramo et al. | Nov 2004 | A1 |
20040224710 | Koskelainen et al. | Nov 2004 | A1 |
20040228292 | Edwards | Nov 2004 | A1 |
20040259580 | Florkey et al. | Dec 2004 | A1 |
20050047362 | Harris et al. | Mar 2005 | A1 |
20050101308 | Lee | May 2005 | A1 |
20050111430 | Spear et al. | May 2005 | A1 |
20050119012 | Merheb et al. | Jun 2005 | A1 |
20050143135 | Brems et al. | Jun 2005 | A1 |
20050164737 | Brown | Jul 2005 | A1 |
20050189337 | Baune | Sep 2005 | A1 |
20050192041 | Oxley et al. | Sep 2005 | A1 |
20050202807 | Ayyasamy et al. | Sep 2005 | A1 |
20050216524 | Gomes | Sep 2005 | A1 |
20050221819 | Patel et al. | Oct 2005 | A1 |
20050232241 | Wu et al. | Oct 2005 | A1 |
20050239485 | Kundu et al. | Oct 2005 | A1 |
20050254464 | Patel et al. | Nov 2005 | A1 |
20050261016 | Patel et al. | Nov 2005 | A1 |
20060003740 | Munje | Jan 2006 | A1 |
20060003751 | Vo | Jan 2006 | A1 |
20060019654 | Farrill | Jan 2006 | A1 |
20060029189 | Patel et al. | Feb 2006 | A1 |
20060030347 | Biswas | Feb 2006 | A1 |
20060056361 | Jiang et al. | Mar 2006 | A1 |
20060067499 | Oliveira et al. | Mar 2006 | A1 |
20060078064 | Schmidt et al. | Apr 2006 | A1 |
20060094455 | Hannu et al. | May 2006 | A1 |
20060116150 | Bhutiani | Jun 2006 | A1 |
20060128411 | Turcanu | Jun 2006 | A1 |
20060178138 | Ostroff et al. | Aug 2006 | A1 |
20060189337 | Farrill et al. | Aug 2006 | A1 |
20060198334 | Civanlar et al. | Sep 2006 | A1 |
20060229090 | Ladue | Oct 2006 | A1 |
20060234687 | Patel et al. | Oct 2006 | A1 |
20060291452 | Velagaleti et al. | Dec 2006 | A1 |
20070002011 | Kurlander | Jan 2007 | A1 |
20070037562 | Smith-Kerker et al. | Feb 2007 | A1 |
20070037597 | Biswas et al. | Feb 2007 | A1 |
20070037598 | Ayyasamy et al. | Feb 2007 | A1 |
20070049314 | Balachandran et al. | Mar 2007 | A1 |
20070070976 | Mussman et al. | Mar 2007 | A1 |
20070099609 | Cai | May 2007 | A1 |
20070133757 | Girouard et al. | Jun 2007 | A1 |
20070154005 | Daigle | Jul 2007 | A1 |
20070189487 | Sharland et al. | Aug 2007 | A1 |
20070190492 | Schmitt | Aug 2007 | A1 |
20070190984 | Ayyasamy et al. | Aug 2007 | A1 |
20070197234 | Gill et al. | Aug 2007 | A1 |
20070204039 | Inamdar | Aug 2007 | A1 |
20070217591 | Yasuma | Sep 2007 | A1 |
20070218885 | Pfleging et al. | Sep 2007 | A1 |
20070253347 | Patel et al. | Nov 2007 | A1 |
20080064364 | Patel et al. | Mar 2008 | A1 |
20080126230 | Bellora et al. | May 2008 | A1 |
20080147671 | Simon et al. | Jun 2008 | A1 |
20080299953 | Rao | Dec 2008 | A1 |
20090037523 | Kolke | Feb 2009 | A1 |
20090047915 | Albertsson | Feb 2009 | A1 |
20090083441 | Clark | Mar 2009 | A1 |
20090092116 | Jiang et al. | Apr 2009 | A1 |
20090119678 | Shih et al. | May 2009 | A1 |
20090149167 | Patel et al. | Jun 2009 | A1 |
20090209235 | Lawler et al. | Aug 2009 | A1 |
20090235185 | Gill | Sep 2009 | A1 |
20090325540 | Yach et al. | Dec 2009 | A1 |
20100035593 | Fanco et al. | Feb 2010 | A1 |
20100142414 | Patel et al. | Jun 2010 | A1 |
20100190492 | Jiang | Jul 2010 | A1 |
20100234018 | Lawler et al. | Sep 2010 | A1 |
20110151917 | Mao et al. | Jun 2011 | A1 |
20110183659 | Ayyasamy et al. | Jul 2011 | A1 |
20110250923 | Miller et al. | Oct 2011 | A1 |
20130064336 | Schadt | Mar 2013 | A1 |
20130155875 | Ayyasamy et al. | Jun 2013 | A1 |
20130196706 | Patel et al. | Aug 2013 | A1 |
20130337859 | Patel et al. | Dec 2013 | A1 |
20140148210 | Kundu et al. | May 2014 | A1 |
20140222757 | Huang et al. | Aug 2014 | A1 |
20140289225 | Chan | Sep 2014 | A1 |
20150358406 | Scheer | Dec 2015 | A1 |
20160162370 | Mehta | Jun 2016 | A1 |
Number | Date | Country |
---|---|---|
2338150 | Mar 1998 | GB |
200392776 | Oct 2004 | JP |
00069189 | Nov 2000 | WO |
0079825 | Dec 2000 | WO |
0167674 | Sep 2001 | WO |
02101981 | Dec 2002 | WO |
03101007 | Dec 2003 | WO |
2005009006 | Jan 2005 | WO |
2005112494 | Nov 2005 | WO |
2005115032 | Dec 2005 | WO |
2005117474 | Dec 2005 | WO |
2006105287 | Oct 2006 | WO |
2010048217 | Apr 2010 | WO |
2010117815 | Oct 2010 | WO |
2015013449 | Jan 2015 | WO |
Entry |
---|
ETSI: “ETSI TS 100 812-2 v2.3.1 Terrestrial Trunked Radio (TETRA) Subscriber Identity Module to Mobile Equipment (SIM-ME) interface; Part 2: Universal Integrated Circuit Card (UfCC) Characteristics of the TSIM application”, ETSI Technical Specification, Oct. 2003, all pages. |
Nokia: “What is TETRA? Why Nokia TETRA?”, The Nokia Tetra Primer, 2002, pp. 1-29. |
Skype: “Skype”, Web Archive—Skype, May 22, 2004, pp. 1-2, May 22, 2004, pp. 1-2. |
Trachwell: “TrackWell Software and Tetra Iceland deliver value added services to Tetra users”, TRACKWELL.COM, Oct. 2002, pp. 1-1. |
Number | Date | Country | |
---|---|---|---|
20160330279 A1 | Nov 2016 | US |
Number | Date | Country | |
---|---|---|---|
62158384 | May 2015 | US |