The present invention relates to a communications manager for managing communications between a telecommunications network core and a terminal registered with the network core, and to a method of managing communications between the telecommunications network core and a terminal registered with the network.
According to a first aspect of the present invention, there is provided a communications manager for managing communications between a telecommunications network core and a terminal registered with the network, the communications manager including means for collecting data from a plurality of sources; means for prioritising and scheduling delivery of the data to the terminal; and means for selecting a communication method to provide the data to the terminal in accordance with the priority of the data.
In the embodiment the collection of data from the various sources may be performed by a data manager. The prioritising and scheduling of delivery of data to the terminal, and the selecting of a communication method to provide the data to the terminal in accordance with the priority of the data may be performed by a connection manager.
The data may be generated by an event occurring in relation to an application with which the user of the terminal has made an association. In the embodiment a service manager includes “listeners” that detect such events and notify the data manager thereof.
The data may be prioritised according to its origin and/or type. For example, data originating from particular applications may be given a higher priority than data from other applications. Further, data of a particular type, such as contact data, may be given a higher priority than other data.
The selecting means may select one of a plurality of bearers to deliver the data to the terminal. The bearers may include, for example, SMS or an activated packet data connection. By “SMS” it is meant any suitable datagram or store-and-forward message delivery system (that may operate in a similar manner to SMS as defined in the GSM and UMTS Standards). The activated packet data connection may be established using a PDP context.
The prioritising and scheduling means may be operable to adjust the prioritising and scheduling of delivery of the data in dependence upon network communication conditions, such as the level of available network capacity. For example, if the network is very busy, the prioritising and scheduling may be adjusted for some data delivery to alleviate the congestion.
The prioritising and scheduling means may adjust the prioritising and scheduling of the delivery of data in dependence upon the type of subscription between the user of the terminal and the network, for example in dependence upon the tariff that the user has agreed with the network or on whether the user is roaming in the network and is registered with another network as their “home” network.
In the embodiment the network includes means for storing details of contacts used by the user of the terminal, which details of contacts are also stored on the user's terminal. The collected data may include updates to the contacts from third parties. The prioritising and scheduling means and the selecting means are operable in the embodiment to synchronise details of the contacts on the terminal with the details of the contacts on the network. Data relating to such synchronisation of contacts may be given a relatively high priority so that the synchronisation is maintained.
In the embodiment the terminal is a mobile terminal in radio communication with the network core via a suitable radio access network. The network may be a GSM, UMTS or SAE/LTE (4G) network.
The present invention also provides a communications manager for managing communications between a telecommunications network core and a terminal registered with the network core, the communications manager including means for collecting data from a plurality of sources; means for prioritising and scheduling delivery of the data from the terminal to the telecommunications network core; and means for selecting a communication method to provide the data to the telecommunications network core in accordance with the priority of the data.
A similar (symmetrical) but not identical communications manager may be provided in both the network core and terminal.
The present invention further provides a method for managing communications between a telecommunications network core and a terminal as defined in the claims.
For a better understanding of the present invention an embodiment will now be described by way of example, with reference to the accompanying drawings, in which:
Key elements of a mobile telecommunications network, and its operation, will now briefly be described with reference to
Each base station (BS) corresponds to a respective cell of its cellular or mobile telecommunications network and receives calls from and transmits calls to a mobile terminal in that cell by wireless radio communication in one or both of the circuit switched or packet switched domains. Such a subscriber's mobile terminal is shown at 1. The mobile terminal may be a handheld mobile telephone, a personal digital assistance (PDA) or a laptop computer equipped with a datacard.
In a GSM mobile telecommunications network, each base station comprises a base transceiver station (BTS) and a base station controller (BSC). A BSC may control more than one BTS. The BTSs and BSCs comprise the radio access network.
In a UMTS mobile telecommunications network, each base station comprises a node B and a radio network controller (RNC). An RNC may control more than one node B. The node B's and RNC's comprise the radio access network.
In the proposed LTE mobile telecommunications network, each base station comprises an eNode B. The base stations are arranged in groups, and each group of base stations is controlled by a Mobility Management Entity (MME) and a User Plane Entity (UPE).
Conventionally, the base stations are arranged in groups and each group of base stations is controlled by one mobile switching centre (MSC), such as MSC 2 for base stations 3, 4 and 5. As shown in
The MSCs 2 and 6 support communications in the circuit switched domain—typically voice calls. Corresponding SGSNs 16 and 18 are provided to support communications in the packet switched domain—such as GPRS data transmissions. The SGSNs 16 and 18 function in an analogous way to the MSCs 2 and 6. The SGSNs 16, 18 are equipped with an equivalent to the VLRs 11, 14 used in the packet switched domain.
Each subscriber to the network is provided with at least one smart card or subscriber identity module (SIM) card (strictly speaking a UICC) which, when associated with the user's mobile terminal, identifies the subscriber to the network. The terminal typically has an identifier of its own (the “International Mobile Equipment Identity”, IMEI), which can be obtained in certain networks, however this terminal ID is not essential in identifying the subscriber to the network. The SIM card is pre-programmed with a unique identification number, the “International Mobile Subscriber Identity” (IMSI) which can be accessed on the card but which is not generally known to (or used directly by) the subscriber. Printed on the outside of each SIM, there is often a further unique identification number, the ICCID/SIM Serial number (SSN), which is unrelated to the IMSI number. The subscriber is issued with a further, publicly known, number, that is, the subscriber's telephone number, by means of which calls to the subscriber are initiated by callers. This number is the Mobile Subscriber ISDN Number (MSISDN).
The network includes a home location register (HLR) 10 which, for each subscriber to the network, stores the IMSI and the corresponding MSISDN together with other subscriber data, such as the current or last known MSC or SGSN of the subscriber's mobile terminal.
When mobile terminal 1 is activated, it registers itself in the network by transmitting the IMSI (read from its associated SIM card) to the base station 3 associated with the particular cell in which the terminal 1 is located. In a traditional network, the base station 3 then transmits this IMSI to the MSC 2 with which the base station 3 is registered. In a network using the functionality described in 3GPP TS 23.236, the base station follows prescribed rules to select which MSC to use, and then transmits this IMSI to the selected MSC.
MSC 2 now accesses the appropriate storage location in the HLR 10 present in the core network 140 and extracts the corresponding subscriber MSISDN and other subscriber data from the appropriate storage location, and stores it temporarily in a storage location in a visitor location register (VLR) 14. In this way, therefore the particular subscriber is effectively registered with a particular MSC (MSC 2), and the subscriber's information is temporarily stored in the VLR (VLR 14) associated with that MSC.
Each of the MSCs of the network (MSC 2 and MSC 6) has a respective VLR (14 and 11) associated with it and operates in the same way as already described when a subscriber activates a mobile terminal in one of the cells corresponding to one of the base stations controlled by that MSC.
When the subscriber using mobile terminal 1 wishes to make a call, they enter the telephone number of the called party in the usual manner. This information is received by the base station 3 and passed on to MSC 2. MSC 2 routes the call towards the called party. By means of the information held in the VLR 14, MSC 2 can associate the call with a particular subscriber and thus record information for charging purposes.
The functionality just described may also apply to the proposed LTE mobile telecommunications network, with its eNode Bs performing the functionality of the base stations and the MME/UPE performing the functionality of the MSCs/VLRs. It is also to be appreciated that the functionality just described is one example of a network in which the embodiments of the invention may be implemented.
The procedure for transmission of “short messages” is different. The term “short messages” or “SMS messages” as used in relation to the embodiments means short messages as defined in the GSM or UMTS Standard Specifications, or a datagram delivered by a similar store-and-forward method. Such messages are commonly in the form of text messages of limited maximum length, but they can have other forms, such as in the form of binary data, or may contain configuration data for changing the functional parameters of a mobile.
Short messages may be sent to or from mobile terminals such as the mobile 1 and the others registered with the network. However, in addition, short messages may be sent to or from “short message entities” (SMEs) such as shown at 20. These SMEs may be in the form of terminals of various sorts such as fixed terminals for sending short messages of various types to mobiles and for receiving short messages from mobiles. For example, the SMEs may be in the form of terminals associated with banking computers or computers of other types generating information (control information, for example) for transmission to mobiles and for receiving short messages in response from mobiles, but may be of many other types, such as application servers of various types.
SMS is a service for transmitting simple short messages that contain text or other data between devices, that may or may not be in the same mobile network. The SMS facility is currently offered by almost all mobile devices (particularly those that use the GSM/UMTS system).
SMS communication is handled differently from calls due to SMS being non-interactive and not time critical. All SMS messages are handled by Short Message Service Centres (SMS-SC or SMSC). The network includes an SMSC 22 which routes the SMS messages of its subscribers to the network of the target device (the device to which the SMS should be sent). The SMSC 22 receives the SMS message along with the Mobile Subscriber ISDN Number (MSISDN) of the target device. In order to route the SMS message to the target device, the SMSC 22 must identify the target subscriber and to where the SMS should be routed. This data is obtained by the SMSC 22 signalling to an associated Short Message Service Gateway Mobile Switching Centre (SMS-GMSC) 24 which, in turn, signals to the target device's Home Location Register (HLR) 10 to determine to where the SMS message should be routed and the identity of the target subscriber. This process is known as a Routing Information Retrieval.
When receiving a Routing Information Retrieval, the HLR 10 responds with a Network Node Number to which the SMS message should be transmitted, which could be the address of the current serving MSC, SGSN or both, as well as the International Mobile Subscriber Identity (IMSI—see 3GPP TS 23.003).
As an optional enhancement, the home network of the target device may have deployed an SMS Router, not shown, (see 3GPP TS 23.840) which handles all incoming SMS messages for devices registered in a network. In this case, the Network node number passed to the SMS-GMSC 24 by the HLR is the address of the SMS Router. The SMS Router then takes on delivery of the SMS message to the current serving MSC or SGSN. Unlike the MSC or SGSN which changes as a mobile device moves around, the SMS Router is predominantly always the same. However, general O&M (operations and maintenance) and network upgrading mean the address can change, but this is infrequent, particularly compared to the change of current serving MSC/SGSN for a target device.
The SMS-GMSC 24 then forwards the SMS message, along with the received IMSI, on to the returned address from the HLR 10 (be that an MSC, SGSN or SMS Router), and in the successful case, the SMS message is delivered to the target device. The MSC and SGSN use the IMSI parameter to identify the target device.
Content (data) may be delivered to mobile 1 in the following way. A delivery server communicates with a content database and a scheduler and includes a Now SMS/MMS Gateway, which can be downloaded from www.nowsms.com. The Now SMS/MMS Gateway includes an SMS Gateway, a MMS Gateway, a WAP Push application and a Multimedia Messaging Service Centre (MMSC). The Now SMS/MMS Gateway has an internal MMS compiler, and requires for operation a GSM modem to be connected to the delivery server. The delivery server also communicates with the mobile device 1 via the GSM/3G network and BS 3.
If all required content is available, the scheduler program generates a URL at which the content can be found. The scheduler program then generates an HTTP GET request (a “delivery request”) for the Now SMS server. This triggers the Now SMS server to generate and send an MMS message. In the known manner, an SMS message is sent to the mobile device 1 to activate a PDP context and initiates the downloading of the content to the mobile device 1.
A communications management service in accordance with the embodiment can be characterised by:
It is these features that are designed to combine and deliver a compelling and differentiated user experience.
Owing to the diverse characteristics of various information sources, the service platforms that derive them and the performance demands required by the end user, careful consideration needs to be given to the management of data and its delivery, especially to mobile devices.
According to the embodiment of the invention, a Communications Management (CM) component is provided to address this need. The purpose of CM is to provide:
The principle drivers for CM are derived from the Address Book, Personalised Internet and Social Network use cases (events) delivered to mobile—since they are the most “chatty”. The CM therefore comprises an engine upon which all other applications, such as Storage, can build on. Given the unknown behaviour of the system that drives these events (e.g. the number of social network service (SNS) events) it is also important that the CM engine and the algorithms that drive it are sufficiently parameterised to allow services to be tuned to optimise the user experience and resource usage (battery life and network).
The Communications Manager is provided in the network and the mobile device, and on each of these comprises three sub-components, as shown in
A first sub-component is a device service manager 40 and a corresponding network service manager 70. A second sub-component is a device data manager 30 and a corresponding network data manager 50. The third sub-component is a device connection manager 60 and the corresponding network connection manager 80.
The Communications model comprises three types of message:
The Communications Manager is a message proxy that sits between mobile and network applications. The communications model is defined by a Service API within the device and network respectively. The Device side APIs are used to construct the mobile end-user applications and the Network side APIs are designed to serve both PC clients (e.g. browsers) and network applications serving mobile users.
Device service APIs can be classified as either Event message or Request message generating. The management of Event, Request and Control messages is the responsibility of the Communications Manager. Wherever possible the Communications Manager preferably uses a compressed SMS datagram to transmit events to the network.
Events are routed by the Communications Manager to subscribed applications and users on the device and on the network.
Requests to the Service API are prioritised, queued, compressed and transmitted to the network using connection-oriented, acknowledged, packet data connections (Mobile or WIFI). Requests APIs are qualified by response data.
Control Messages are generated and used by the Communications Manager to provide a robust service to help the system recover from system exceptions and perform maintenance e.g. coverage outage recovery, system time sync and subscriber checks.
Request, Events and Control messages are created when a service API is called. The API groups may include:
The Registration process with the Communications Manager is outlined here for completeness and to provide context and origins for system parameters that are used by the Communications Manager.
This Registration Wizard is enabled through the Registration API and identity API.
At the end of the registration process, the Communications Manager and other applications will have access to several system critical parameters, specifically;
The Communications Manager software implementation is preferably layered, with each layer clearly delineated by an API.
Given the distribution scenarios for communications manager applications and the customer demographic network customers with a special tariff, network customers without a special tariff and non-home network/roaming customers), the default settings for automatic connections need to be configurable.
The Communications Manager settings may include options for “request user confirmation for network connections” and allow connections to be made automatically.
Customers provisioned on the special tariff, set “automatic retrieval” as the default on installation.
For all customers who are not signed up to the special tariff, the default shall be set to “request user authorisation”.
Users who are not on the special tariff and who wish to allow automatic connections will be able to change this default setting.
Noise Control allows the user to set which network originated events they want to receive, specifically.
These groups of events define filter parameters for the Noise Control API. The user settings for Noise Control are stored on the device and network and synchronised whenever a change is made.
The user can set permissions for different types of data on the device, specifically; contacts, MyProfile, MyBlog, MySharedFolder, MyCalendar. Permissions settings are stored on the device and network and synchronised whenever a change is made.
When the user powers on the device, the Communications Manager needs to run several system checks to verify system critical parameters.
When the device is powered on for the first time it needs to establish if the user is registered for service. The Registration Flag is checked. If false, the registration process is initiated and the Registration Wizard launched.
When the device battery has been removed, time settings may be reset. It is important that the device time is kept in sync with the network time when generating event time stamps. The Communications Manager refreshes the device time via a network request. A time check is carried out each time the device connects to the network. The device time does not affect device time zone settings and is maintained separately.
If a user inserts a new SIM card into their device e.g. a new SIM of the same network operator or another operator SIM, the tariff structure used to support unlimited events may not apply. The subscriber's network can be identified from the MNC.
Device Communications Management Architecture
The Device Communications Management Architecture is shown in
Device Service Manager
The Device Service Manager 40 supports a set service APIs that create either Application Requests, Events or Control messages.
In order to create an event in response to a service API call the Device Service Manager 40 comprises “listener applications” that run in the background and listen for events on behalf of other applications. In turn, the listener applications subscribe to Network Application events published by network applications, via the Data Manager 50, and also Phone Application Events e.g. received SMS.
The Service Manager 40 supports Listeners for the following;
The Listeners, on receiving an event, notify subscribed applications, e.g. Homescreen, and write device-originated events to the Data Manager 30. The Data Manager 30 may also subscribe to the Service Manager listeners.
The following applications by default are permitted to use the Service APIs, subscribe and publish system events.
The Service Manager 40 combines several data objects to define the Address Book data objects.
An Address Book data object comprises both Profile and Contact data (for registered users). Contact data only (for unregistered users) and LastXevents associated with a contact in the events cache.
Device Data Manager
The Device Data Manager 30,
The Event Cache 32 is not infinite and only contains the most recent event updates. To compensate for this finite storage capability the cache is supported by a Network Event Store 52 (Managed by the Network Data Manager 50). The Device Data Manager 30 therefore needs to manage the periodic back-up of data to the Network Event Store 52 and retrieval of events not stored in the device cache (e.g. old events).
When the Event Cache 32 is full, the oldest events are discarded (from the bottom of the stack) and new Events are added (to the top of the stack).
When an application receives a request for an event that is not stored in the Event Cache 32 (e.g. an old event), the device returns the URL of the Network Event Store 52.
At EventCacheBackupTime intervals the Data Manager 30 backs up all device originated events to the Network Event Store 52.
When a user, with an established Network Event Store 52, migrates to a new handset the device Event Cache 32 comprises no events.
If a device is lost, the network may send a DeviceWipe message and erase all end user data; Event Cache 32 Profile Store 34 Contacts Stored Messages and User Content.
The data manager 30 stores:
Device Connection Manager
The Device Connection Manager (DCoM) 60 provides reliable, optimised communication for the Data Manager 30 and end user applications. It is configurable and is also responsible for registration/authentication/update and storing control parameters received from the network.
The DCoM 60 also supports unfavourable communications states and informs the network when delivery should be suspended. This capability is important in maintaining Address Book synchronisation and allows any network originated changes to be stored and delivered at a later time. The specific conditions supported are:
All events are queued according to priority. All Address Book related events have the highest priority and shall be actioned immediately.
Given the data size of some events (e.g. Address Book contact field update), packet data connections are considered inefficient and may have a negative effect on the end user experience.
Where appropriate, the DCoM 60 shall use SMS to transfer data to and from the network. If the event payload size exceeds that maximum SMS payload a packet data connection shall be initiated (for example, by sending an SMS message to the mobile device 1 to activate a PDP context and to initiate the downloading of the data to the mobile device 1 in the manner described above). If there is no available PDP context and a packet connection is required the Connection Manager shall give priority to all Address Book events and close connections not in use by other applications to fulfil any device or network initiated update. All other updates shall wait until a free PDP context becomes available.
During Lower Power states the network may be required to suspend event delivery. When the device power level is critical, the DCoM 60 sends a SUSPEND message to the network. Conversely, when the device power recovers or is put on charge, the DCoM 60 sends a RESUME message to the network.
When the device is Powered Off the network will be required to suspend event delivery. Prior to the device being powered off the, the DCoM 60 shall send a SUSPEND message to the network. Conversely, when the device powers on, the DCoM 60 shall send a RESUME message to the network.
Because the device may be roaming, owing to the automatic retrieval and transmission of network and device originated events, the Connection Manager needs to support control triggers to allow the network to suspend delivery, or request user authorisation before a connection is made. The Connection Manager maintains a list of all networks within the special Tariff plan—[Operator List]. The device notifies the network when the registered device PLMN is not on the [Operator List]. The device exposes a tariff flag to device applications to inform users of the current registration state (and in turn tariff change). On receiving the PLMN message, the network may suspend event delivery.
When the device is out of coverage (see
Advantageously, the Connection Manager removes duplicate events before passing to the Data Manager 30.
Preferably, on each data connection, the network checks the current software version and initiates a software update if a new version is available.
Network Communications Manager Architecture
The Network Communications Manager architecture is shown in
Network Communications Manager is a high capacity, scalable, resilient, concurrent message handling system capable of serving millions of mobile clients. The Network Communications Manager must be able to handle concurrent messaging with registered mobile devices.
Network Service Manager
A key difference between the network side architecture and the device-side architecture is that the network-side applications are modular and functions are not shared across the device software platform e.g. the contact store in the Address Book resides entirely within the application.
The Network Service Manager 70 subscribes to events from the Network Data manager 50 on behalf of authorised network based applications.
On receiving an event from the Network Data Manager 50, the Service Manager 70 filters the event and writes data using the relevant application service APIs.
Network Data Manager
The Network Data Manager 50 receives events from the Network Connection Manager 80 and Network Service Manager 70 and routes them to subscribed applications and users respectively. Events received from the Network Service Manager 70 are filtered according to the user Noise Control settings. The Data Manager 50 writes all network originated events to the network event store 52. The Data Manager 50 backs-up mobile originated Comms Events at EventCacheBackupTime intervals.
Network Connection Manager
The Network Connection Manager (NCoM) 80 provides reliable, optimised communication for the Data Manager 50 and end user applications. It maintains the configuration of device-side software and is responsible for registration/authentication/update.
The NCoM 80 receives published events from the Data Manager 50 and schedules their delivery.
All events received from the Data Manager 50 are stored in the relevant (High and Low) priority queues to await delivery.
All Network Service Manager 70 originated events shall be stored in the Network Event Store 52.
For a given user, the NCoM 80 selects either SMS or Packet delivery based on the amount of data stored in the queue. The algorithm is identical to that used by the Device.
All events (Address Book updates, SNS updates etc.) have a validity time. If, for any reason, the event validity time (e.g. 3 days) expires, the Device Address Book (profile and content stores) are refreshed when the device resumes service. The Network Connection manager 80 shall initiate the refresh on receiving a RESUME command from a registered device.
Non-Address Book events are discarded when the message validity time expires. The NCoM 80 removes duplicate events before passing to the Data Manager 50.
SMS updates use delivery reports to confirm receipt from the destination SMSC 22. If the deliver report is not received within DeliveryReportTimeout, the update shall be re-sent.
The NCoM 80 authenticates packet data connections using HTTP authentication methods. Device-originating SMS datagram authentication is implicit and uses the originating MSISDN. Network originated SMS datagrams shall be authenticated using the PushWhiteList.
Connection Manager Parameter Summary:
An example will now be described where the network stores an address book for the user of the mobile terminal. The address book is enhanced with rich contact information. For example, the address book may gather information about a particular contact from social community websites such as facebook and MySpace. The contact information in the user's address book may be shared with other users, so that when an entry is updated, the updated data is automatically propagated to the other user. The address book data needs to be synchronised with the mobile device of each relevant user.
Conventionally, such an arrangement would cause difficulties because changes made to the address book will occur sporadically. Conventionally, to update the address book on the relevant user terminals, a message is sent from the network to the terminal to prompt the user to open an active packet data connection. It is an unsatisfactory user experience to be repeatedly prompted at random times to open an active packet data connection in order to synchronise an address book.
In accordance with the embodiment of the invention, the network service manager 70 receives updates to the address book from various sources, such as from other users and from social community websites such as facebook and MySpace. The network data manager 50 writes the data into the network event store 52. The network data manager 50 then publishes the data to the network connection manager 80. The NCoM 80 prioritises the data by type. Updates to the address book will generally be given a relatively high priority. The data is then queued according to its priority and is transmitted by a suitable method (SMS or packet delivery) in dependence upon its priority and the amount of data in the queue.
Higher priority data can be sent by SMS almost in real time as it is received by the network service manager 70. Lower priority data can be sent periodically by establishing a packet data connection (for example once every 24 hours).
Advantageously, the network communication manager 80 is aware of the functionality provided by a user's handset and can modify how the data are transmitted to the mobile terminal and the format of the data in dependence upon the handset functionality.
The embodiment is also applicable to the delivery of instant messages (IM) to the terminal.
Device Service API Package Definitions
To assist the reader in understanding the embodiment described above, there follows a listing of the definitions for the API packages used by the device—in particular those commonly used in support of devices service APIs for Registration, Identity, Contact, Policy, Blog, Calendar, User Subscribed Events and Storage.
Private device side APIs can only be used by certified applications. All Connection Manager Service APIs on the device are Private APIs.
Some Connection Manager service APIs will map directly to public APIs on the phone software platform APIs. This implies that other applications on the device may modify the Address Book contact data.
Contact (vCard), Profile (vCard extensions) and Event data combine within the Address Book application to create a differentiated user experience.
At the device service API Layer no authentication parameters are passed. The Connection Manager will use the relevant (SMS datagram or packet session) authentication data objects when sending data to the network.
Registration API
NewUserID (Private)
Creates a new user ID.
SetPassword (Private)
Sets the users password.
MobileValidateMSISDN (Private)
Originated by the network to Registration Wizard application to verify MSISDN at registration. Note, the MobileValidateMSISDN contains an Application ID (not required for web validation).
AcknowledgeMSISDN (Private)
The Registration Wizard confirms receipt of the MSISDN through a validation message.
Identity
The supported Social Networking and Personalised Internet feeds are defined in the Identity Data Object.
SetIdentities (Private)
Sets an Identity data object field.
Adddentity (Private)
Adds a new internet community for a user.
DeleteIdentity (Private)
Deletes a network identity.
Contacts
CreateUserProfile (Private)
Defines a new user profile after registration.
AddProfileDetail (Private)*
Adds new profile detail.
SetProfileDetail (Private)
Sets existing profile detail.
AddContact (Private)
Adds new contact.
AddContactDetail (Private)
Adds new contact detail.
AddContactDetailBytes (Private)
This method adds one detail in binary format (e.g. photo) to an already existing contact.
AddContactDetails (Private)
Adds more than one contact detail.
DeleteContactDetails (Private)
Deletes more than one contact detail.
DeleteContacts (Private)
Deletes one or more contacts and their profiles.
GetContactDetails (Private)
Gets contact detail.
InviteUserAsFriend (Private)
Invites a contact to be a Friend (Note, if the invitation is sent to an unregistered contact, the contact will need to register first before accenting the invitation)
RejectInvitation (Private)
Rejects a friend invitation.
GetContacts (Private)
Returns a user contacts.
GetFriendsOfFriends
Gets the contacts list of a friend, subject to permission.
GetUserProfiles
As for GetContacts. Returns all Friend profiles.
LinkContacts
Where internet contacts are imported following SNS identity (e.g. Facebook entry), the user may be provided with hints that two contacts are in fact the same. This API is not applicable to the device UE and is confined to the PC interface.
SetContactDetail (Public)
Sets and existing contact detail.
SetContactDetails (Public)
As above but for more than one detail.
SetContactDetailBytes (Public)
Sets binary contact detail e.g. photo
GetContactsByLocation (Private)
This function is used to retrieve a list of contacts from the contacts list which are located in a given radius around the current location of the Connection Manager system user which is performing the request.
AddGroup (Public)
Adds a new contact Group
DeleteGroup*(Public)
Deletes a contact group.
AddUserToGroup*(Public)
Adds a contact to a group.
PokeUser
Sends a Poke event to a Friend.
DeleteUserFromGroup*(Public)
Deletes a contact from a group.
Policies
GetTermsAndConditions (Private)
Gets services terms and conditions
SetAccessPermissions (Private)
Sets access permissions for defined filter objects.
Filters:
GetAccessPermissions (Private)
Retrieves user access permissions list for data objects stored in the Connection Manager system. As a minimum, a user must provide access to their Contact Name.
SetNoiseControlSettings (Private)
Defines event notification settings for different event filters.
Event Filters:
GetNoiseControlSettings (Private)
Retrieves the current NoiseControlSettings.
Check4BlackListed (Private)
Returns list of black listed contacts.
SetBlackList (Private)
Sets contact black list.
Blogs
GetEntries (Private)
Add Entry (Private)
DeleteEntry (Private)
CommentEntry (Private)
Calendar
AddCalendarEvent (Private)
DeleteCalendarEvent (Private)
SetCalendarEventDetail (Private)
AcceptCalendarEventlnvitation (Private)
RejectCalendarEventlnvitation (Public)
GetCalendarEvent (Public)
User Subscribed Events
SubscribeToEvent* (Private)
Allows the user to subscribe to events on the internet and within Connection Manager.
DeleteSubscription* (Private)
Deletes a user subscription.
ShareEvent (Private)
Not required. Shared Events e.g. Music Player ‘Now listening to . . . .’ can be supported through Blog.AddEntry.
Storage
AddFolder (Private)
RemoveFolder (Private)
GetFolders (Private)
SetFiles (Private)
DeleteFiles (Private)
SetFolderPermissions* (Private)
Data Model Definitions
All Connection Manager data objects are stored in the network. Where data objects are replicated or cached on the device any change must be synchronised with the network. The data objects take the forms set out below:
Contact Data Object (Synchronisable)
Profile Data Object (Synchronisable)
Identity Data Object (Synchronisable)
The Identity Data Objects comprise a registered identity list stored on the network and cached on the device.
Contact BlackList Data Object (Synchronisable)
The Contact Black List is stored on the network and cached on the device.
User Subscription List Data Object (Synchronisable)
The User Subscription List is stored on the network and cached on the device.
Calendar Event Object (Synchronisable)
Calendar Event Objects (entries) are stored on the network and device. As defined by [vCal]
Event Data Object (Synchronisable)
Event Data Objects are stored on the network and cached on the device.
Comms Event Data Object (Synchronisable)
Blog Data Object
TBD
Permissions Settings Data Object (Synchronisable)
Noise Filter Settings Data Object (Synchronisable)
Filter Definitions
As mentioned previously, the embodiment allows the user to set which network originated events they want to receive. The filters take the forms set out below:
Permissions Filters
Noise Control Filters
Number | Date | Country | Kind |
---|---|---|---|
0809875.8 | May 2008 | GB | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/GB2009/050597 | 6/1/2009 | WO | 00 | 3/24/2011 |