The present invention relates generally to a method and arrangement for providing communication group information to a client. In particular, the invention is intended to make retrieval of information regarding active communication groups easier and more efficient.
Until recently, mobile communication terminals have been used mainly for making voice calls and communicating limited text messages, such as SMS (Short Message Service). These are fairly straightforward telecommunication services which use well-established technologies for chiefly circuit-switched single connections.
However, a multitude of new telephony services are now rapidly being developed, which are enabled by the introduction of new communication technologies providing greater network capacity and higher transmission rates. For example, GPRS (General Packet Radio Service) and WCDMA (Wideband Code Division Multiple Access) technologies are currently emerging to support wireless telephony services requiring a wide range of data rates and different protocols. The trend today is also a move towards packet-switched transport, providing greater capacity and flexibility. Further, new sophisticated terminals are also emerging on the market, having colour displays with high resolution and various codecs (coders/decoders) for communicating visual information.
Some services may involve real-time transmission of video information as well as audio information, and may further include the transmission of data representing images, text, documents, audio files and video files in a multitude of different formats and combinations. Such services are generally referred to as “multimedia” services, which term will be used in this description to represent any telephony services that involve the transfer of information in addition to an ordinary voice call.
A prevailing goal or ambition in the field of telecommunication is to converge all services on to a single transport mechanism—the Internet Protocol (IP), regardless of the type of services, access networks and technologies. Recently, a service network architecture called “IP Multimedia Subsystem” (IMS) has been developed by the 3rd Generation Partnership Project (3GPP) as an open standard, to give operators of access networks the ability to offer multimedia services in the packet domain.
An IMS network comprising various different network elements to handle the services, can be integrated with any type of access network and is independent of the access technology used, provided that the access network can meet the service requirements in terms of bandwidth, QoS (Quality of Service), etc. Hence, IMS is a platform for enabling services based on IP transport, not restricted to any limited specific set of services. A communication protocol called the “Session Initiation Protocol” (SIP) has been defined by IETF (Internet Engineering Task Force) as a generic session management protocol to support a wide range of IP-based services. SIP is purely a signalling protocol for creating, modifying and terminating communication sessions with one or more participants.
Some services that can be employed e.g. by means of the IMS solution involve communication within a group of plural participants, sometimes referred to as a “buddy list”. A client can create a group by selecting the members to be included in the group, and by invoking a service for some type of communication between the members within that group. When the service is invoked and the group is created, certain communication rules are also defined to determine how the communication should be conducted. The service requires that one or more applications are activated in the service network.
For example, a voice chat group can be created and the communication form may be determined to be a so-called “push-to-talk” mechanism, such as the IMS concept POC (Push-to-talk Over Cellular). A member in the group can then press a certain key or combination of keys on his/her mobile terminal to activate one-way voice paths to each of the other members in the group whenever he/she wants to say something, sometimes referred to as half duplex. In another example, a game group may be created to play an electronic game in real-time involving the group members. In further examples, text messages, documents or images may be exchanged within the group, or a conference call using voice paths in full duplex may be conducted.
Among other things, network 100 includes a server 102 or the like for maintaining application configuration data for active services and clients, in particular communication groups. In this description, this server is called a “group management server” 102, referring to its function in this context. In the IMS case, server 102 may include an “XCAP” (XML Configuration Access Protocol) server handling the configuration data stored in an XML (extensible Mark-up Language) format, and/or an “XDMS” (XML Data Management Server). Network 100 further includes a plurality of application servers 104, of which only one is shown, for operating various applications as required to provide specific services to clients. In this case, application server 104 is adapted to handle group services for client A.
Client A wants to create a discussion group using voice chatting, with selected members including a second client “B” belonging to another mobile network 106, as well as any number of further clients C,D . . . belonging to other home networks, as indicated by dashed lines in the figure. It should be noted that the clients A,B,C,D . . . need not necessarily use their respective home networks as access networks, but may just as well be roaming in other networks. Further, some of the clients A,B,C,D . . . may belong to the same home network, etc.
In order to establish a chat group comprising the clients A,B,C,D . . . with the network 100, client A initially sends a group establishment request 108 to the group management server 102 in network 100. This message 108 generally comprises the identity and network address for each member and an indication of the invoked service. In response thereto, a group identity is defined for that group, which may be configured by a subscriber management server or the like, not shown, in the home network 100, such as an HSS (Home Subscriber Server). The group identity is typically a network address to be used by group members for contacting the network resource handling the group. For example, if the group is a conference group, the group identity would be the network address of a conference bridge used. Further, the invoked service requires that certain applications are activated in the associated application server 104. Hence, the defined group identity will also point to a specific application server 104 to handle the invoked service for client A.
In the context of IMS, the group establishment request 108 is an XCAP message having a specific address field which is used for storing the group at the correct position in an XML database. Further, the group identity is a PSI (Public Service Identifier), typically an SIP URI (Unified Resource Identifier).
The group identity, in this case PSI, is thus stored in the group management server 102 together with a list of group member identities and relevant application configuration data (in XML format) according to the invoked service, as schematically represented by a member list L1. The above-mentioned protocol XCAP allows the client A to read, write and modify the application configuration data at any time when the group exists. In particular, client A can add new members to the group, or remove members from the group, or terminate the group altogether.
Then, after the group has been established, any member can communicate information, e.g. voice, to all the other members in the group by activating the group service. In IMS services, the used terminal will then first issue a message called SIP INVITE (PSI), or “INVITE PSI”, to the IMS network whenever he/she wants to transmit information to the others, in order to establish a communication path to each member.
Currently, it is a problem that there is no automatic mechanism for notifying the selected members in the group on the fact that they have become members in the created group. Hence, it is up to the group creator, i.e. client A, to inform the other clients on their membership, e.g. by calling or sending an e-mail, SMS, or the like to each member. This may be a tiresome task if many members are included in the group. There is also a potential risk that this information is lost or improperly intercepted by others.
Another problem is that since other clients may likewise create their groups with selected members, and each corresponding group list will be stored in the home IMS network of its creator, a specific client may be present in several group lists, each being stored locally in different nodes and networks depending on the group creators. As a result, it becomes increasingly difficult for mobile users to keep track on active communication groups when participating in plural groups, Therefore, a user may sometimes not be aware of being a member in a certain group.
Moreover, there is neither any automatic mechanism for letting members know that a group has been terminated, and again the group creator must inform them on this fact. Basically, a created group will exist until its creator terminates the group.
For example, a client may want to reject membership in unwanted groups, or may simply want to investigate which groups he/she is a member of. Currently, the only method available for retrieving group membership is to conduct a search in each network, which is cumbersome, unreliable and generates much network traffic if plural networks are searched. A simple and reliable solution is therefore needed for making information on group membership available to clients such that a client can easily find out which active communication groups he/she is a member of.
The object of the present invention is to reduce or eliminate the problems outlined above. In particular, it is an object to enable the retrieval or reception of membership information in active communication groups such that a client can find out which groups he/she is currently a member of.
This object and others are obtained by a method and arrangement for making communication group information available to group members. A group creation request is received from a first client in a first home network of the first client, for a new group that includes at least a second client and a list is stored of members in the group including the second client. A group event notification is sent from the first home network to at least a second home network of the second client, to announce that the second client is a member in the new group.
If the group contains a plurality of members belonging to different home networks, the group event notification is sent from the first home network to the home networks of the members in the group, to inform said networks that their respective clients have become members in the new group.
A TTL (Time To Live) period is preferably set for the member list during which it is considered to be valid, and the list is then refreshed just before expiry of the TTL, if the group is continued, by sending a refresh message with a new TTL to the home networks of the members in the list.
If a group identity is assigned to the group which is stored together with said group member list, the group event notification will include the group identity.
The receiving, storing and sending steps are preferably performed by a group management server in the first home network. Further, a group management server in the second home network preferably maintain a group list for the second client, comprising group identities of a plurality of communication groups of which the second client is a member. A new group is added to the group list if the second client becomes a member in said new group. On the other hand, an existing group is deleted from the group list if the second client is removed as a member from said existing group or if the group is terminated altogether.
The group management server in the second home network may send a group membership notification containing said group list to the second client, in response to receiving a membership information request from the second client. The group management server in the second home network may also automatically send a group membership notification to the second client, whenever said group list is changed.
According to one embodiment, a group modification request may be received from the first client for adding a new member to the group. The new member is then stored in said group member list, and a group event notification is sent from the first home network to the home network of the new member, to inform said home network of the new member that he/she has become a member in the group.
According to another embodiment, a group modification request may be received from the first client for removing a member from the group the removed member is then deleted from said group member list, and a membership invalidity message is sent from the first home network to the home network of the removed member, to inform said home network of the removed member that he/she has been removed from the group. The membership invalidity message may be a refresh message with the TTL set to zero, thereby indicating that the removed member's membership has become invalid.
According to yet another embodiment, the group management server in the second home network may receive a group reject message from a withdrawing client for rejecting membership in the group. In that case, the rejected group is deleted from the group list for the withdrawing client, and a membership rejection message is sent to the first home network to announce that the withdrawing client has withdrawn from the group.
The present invention further encompasses an arrangement for making communication group information available to group members, comprising a group management server which is adapted to receive a group creation request from a first client for a new group including at least a second client, and to store a list of members in the group including the second client. The group management server is further adapted to send a group event notification to a home network of the second client, to announce that the second client has become a member in the new group.
If the group contains a plurality of members belonging to different home networks, the group management server is further adapted to send the group event notification to the home networks of the members in the group, to announce that their respective clients have become members in the new group.
The group management server is preferably further adapted to set a TTL (Time To Live) period for the member list during which it is considered to be valid, and to refresh the list just before expiry of the TTL, if the group is continued, by sending a refresh message with a new TTL to the home networks of the members in the list.
If a group identity is assigned to the group which is stored together with said group member list, the group event notification will include the group identity.
The group management server may be further adapted to maintain a group list for a third client, comprising group identities of a plurality of communication groups of which the third client is a member. The group management server may also be adapted to add a new group to the group list when the third client becomes a member in said new group, and to delete an existing group from the group list if the third client is removed as a member from said existing group or if the group is terminated altogether.
The group management server may be further adapted to send a group membership notification containing said group list to the third client, in response to receiving a membership information request from the third client. The group management server may also be adapted to automatically send a group membership notification containing said group list to the third client, whenever said list is changed.
According to further embodiments, the group management server may be further adapted to receive a group modification request from the first client for adding a new member to the group, store the new member in said group member list, and to send a group event notification to the home network of the new member, to announce that he/she has become a member in the group.
The group management server may be further adapted to receive a group modification request from the first client for removing a member from the group, delete the removed member from said group member list, and to send a membership invalidity message to the home network of the removed member, to announce that he/she has been removed from the group. The membership invalidity message is preferably a refresh message with the TTL set to zero, thereby indicating that the removed member's membership has become invalid.
The group management server may be further adapted to receive a group reject message from a withdrawing client for rejecting membership in the group, delete the rejected group from a group list for the withdrawing client, and send a membership rejection message to a home network of the withdrawing client, to announce that said withdrawing client has withdrawn from the group.
The present invention further encompasses a communication system for making communication group information available to group members, comprising a first group management server in a home network of a first client, and a second group management server in a home network of a second client. The first group management server is adapted to receive a group creation request from the first client for a new group including at least the second client, and to store a list of members in the group including the second client. The first group management server is further adapted to send a group event notification to the second group management server to announce that the second client has become a member in the new group. The second group management server is adapted to maintain a group list for the second client, comprising group identities of a plurality of communication groups of which the second client is a member, and to add the new group to the group list in response to receiving said group event notification.
Further features and benefits of the present invention will be apparent from the detailed description below.
The present invention will now be described in more detail by means of preferred embodiments and with reference to the accompanying drawings, in which:
It should be noted that the present invention is concerned with the management of membership in communication groups independent of what type(s) of communication service is used. Thus, no description of how the group services per se are invoked or used is necessary to understand the present invention, and the following detailed description will therefore focus on group membership rather than the services themselves.
A preferred embodiment of the present invention will now be described, initially with reference to
As in the known procedure described above, client A intends to establish a communication group using some kind of group service, e.g. as mentioned above. The group will contain members selected by the client A, including client B. As in the previous example, the clients A and B could be currently connected to networks other than their home networks, but they can of course still communicate with their home networks as described below. The detailed mechanisms for this communication are not necessary to describe to understand the present solution.
First, client A sends a group creation request in a step 2.1 to the group management server 202A in network 200A, comprising information on the identity and network address for each selected member in the group, and an indication of the invoked service. The group creation request may also contain a name for the group in free text as optionally defined by client A, hereafter generally referred to as “group name”, such as a nickname, a description, a type of group or the like, e.g. “A's football team”. The group creation request further contains a proposed group identity in the form of a network address, such as “sip:myteam@league.com”. The server 202A then assigns an identity to the group, e.g. the proposed one. If the proposed group identity is occupied or invalid in some way, the network will reject the proposed group identity and optionally propose another one. The assigned group identity (and group name, if received) is then stored together with the received identity/address data for all members and configuration data related to the invoked service in a member list L1, as illustrated by a next step 2.2. So far, the procedure is basically the same as in the known prior art described in connection with
According to the present solution, the server 202A further sends a “group event notification” in a step 2.3 to the group management server 202B in the network 200B of client B, in order to announce that a group has been created in which client B is included as a member. This notification contains the event type (e.g. “added group member”), an identity of the group, e.g. PSI, and also preferably the group name received as above. If an IMS network is used, the group event notification is preferably sent in step 2.3 as an SIP publish message, called “SIP PUBLISH”. In a preferred embodiment, this message is directed to the network address of client B, and the network 200B (e.g. a SIP network) is configured to route the message to the server 202B instead of client B when the combination of event type and client B's address (URI) is received. Thereby, server 202A does not need to retrieve the address (URI) of server 202B.
In fact, the server 202A also sends the group notification to corresponding group management servers in the home domains of the other selected members in the group, not shown, as schematically illustrated with dashed arrows in a step 2.4. In addition, the assigned group identity, e.g. PSI, may also be sent (not shown) to client A which he/she will use as a reference in order to make any modifications to the group, such as adding or removing members.
On the other side, group management server 202B in network 200B stores the received group identity (and group name, if received) in a step 2.5. In the same way, server 202B may potentially also receive further similar group notifications from other corresponding group management servers in other networks, not shown, whenever a group is established where client B is included as a member, as schematically illustrated in a step 2.6 with dashed arrows. When such group notifications are received, server 202B stores the accompanying group identities (e.g. PSI's) in a group list L2 for this particular client B. The group list L2 for client B is thus accumulated over time and may potentially contain a plurality of group identities (and corresponding group names) as received from group management servers in various networks.
Thereby, the information on active group memberships for a specific client, in this case B, is collected at a single location in server 202B that can easily be accessed by the client. Accordingly, a step 2.7 finally illustrates that client B fetches this information from the group list L2 by making a suitable membership information request to server 202B (e.g. “GET PSI's”). In practice, the lists L1 and L2 may be stored and maintained in any suitable way, such as in storage means within the respective server, or in separate database nodes. The present invention is thus not limited in this respect.
Furthermore, a limited time period, e.g. “TTL (Time To Live)”, may be set for the member list L1 of a created group during which the list is considered to be valid. The group management server handling the list may be configured to “refresh” the list just before expiry of a TTL, or regularly (e.g. once a week), if the group is continued, by sending a refresh message with a new TTL to all members in the list, or rather to their respective home networks, even if no changes have been made.
Generally, a client can at any time obtain a valid group list from a local group management server in the home network. It is further possible for a client, e.g. client B, to reject membership in any unwanted group that may occur on his/her group list, e.g. by sending a suitable reject message to the local home server, e.g. server 202B (to be described in more detail below). The reject message will then be communicated to the group management server where the rejected group is maintained, e.g. server 202A, wherein the withdrawing client will be deleted from the member list of the group, e.g. list L1. Optionally, the withdrawing client B may retrieve addressing information on server 202A from the local server 202B, which can be used to communicate a reject message directly to server 202A.
In
In a similar manner, client A may also modify an already existing member list L1, as created according to the above, for example by adding a new member X to the group, which is illustrated in the block diagram shown in
Client A first sends a group modification request to the group management server 202A in a step 3.1 containing the group identity (e.g. PSI) and an instruction to add client X to the group, including his/her identity and network address. In response thereto, server 202A adds client X to the member list L1 of the group, in a step 3.2. Server 202A further sends a group event notification (e.g. SIP PUBLISH) in a step 3.3 to the group management server 202X, containing the event type (e.g. “added group member”), the group identity (e.g. PSI) and optionally an associated group name, to announce that client X is now a member in the group. The message sent in step 3.3 may basically be the same as the one sent in step 2.3 in the previous example.
In the present example, it is assumed that the group management server 202X maintains a group list L2 on behalf of client X, containing one or more groups in which client X is currently a member. In response to receiving the group event notification in step 3.3, server 202X adds an entry 300 in the list with the new group owned by client A, in a step 3.4. Thereby, client X can at any time fetch the list from server 202X, as illustrated in a step 3.5, and find out that he/she has become a member in the group of client A.
In a similar manner, client A may also modify the member list L1 for the group by removing a member therein from the group, which is illustrated in the block diagram shown in
Client A first sends a group modification request to the group management server 202A in a step 4.1 containing the group identity (e.g. PSI) and an instruction to remove client B from the group. In response thereto, server 202A deletes client B from the member list L1, in a step 4.2. Server 202A may also send a membership invalidity message in a step 4.3 to server 202B, to announce that client B is no longer a member in the group. The server 202A can effectively remove the group from the group list L2 in server 202B by sending a refresh message for member B with the TTL set to zero as the membership invalidity message, thereby indicating that B's membership has become invalid. The refreshed event state will then expire immediately and server 202B consequently deletes the group from list L2. As similar to the previous examples, the changed TTL may be addressed to client B but will be routed to server 202B based on the combination of event type/client B.
In response to receiving the membership invalidity message in step 4.3, e.g. with TTL=0, server 202B deletes an entry 400 for client A's group from the list, in a step 4.4. When retrieving or receiving the list at a later point in a step 4.5, client B will find out that he/she is no longer a member in the group created by client A.
Alternatively, server 202A may simply refrain from sending any further refresh messages to client B, which sooner or later results in expiry of the group entry in the list L2, depending the current TTL value. Thereby, step 4.3 can be omitted, but the group entry will linger in the list for a while until expiry.
If a group is terminated altogether, a similar procedure may be executed as described in the previous example of
Alternatively, it would be sufficient to refrain from sending any further refresh message to any client, sooner or later resulting in expiry of the group in each local server. Thus, the networks will delete the entry for client A's group from the group lists of all members, such that all clients in the former group can find out that they are no longer members in the group when retrieving the list.
As mentioned above, a client may use the group information to reject membership in any unwanted group occurring on his/her group list. Thus, if a client desires not to take part in the communication in a specific group, all traffic occurring within the group directed to this client can be blocked by the service network of that client. However, the mechanisms for blocking group communication to a specific client lie outside the scope of the present invention and will therefore not be described here further. Alternatively, the client may actively withdraw his/her membership, as described below.
A more detailed example of an alternative procedure when client B rejects membership in the group created by client A, will now be described with reference to
In the previously described procedures illustrated in
With reference to the flow chart shown in
In a first step 600, a group creation request is received from a client, such as in step 2.1 in
In its most basic form, the procedure could end there, after step 604, if no changes are made to the group. However, at some time in a next step 606, a group modification request is received from the client having created the group, such as any of the requests received in steps 3.1 and 4.1 in
Alternatively, if a member is to be removed from the group, this member is deleted from the member list in a step 614, e.g. as in step 4.2 in
The above-described procedure of
In a first step 700, a group event notification for a specific client is generally received from a server in another network, as the one sent in step 604 above. It is then determined in a step 702 what type of event the notification refers to. If the client has become a member in a group, a new entry for this group is added to an associated group list of the client, in a step 704, e.g. according to step 2.5 in
It should be noted that a group management server according to the present solution is preferably configured to act as any of the servers 202A, 202B and 202X described above. Thus, an inventive group management server is preferably capable of maintaining member lists and send group event notifications to other concerned group management servers (as the above-described server 202A), as well as maintaining group lists, receiving such group event notifications and inform clients accordingly (as the above-described servers 202B,X).
Finally, an inventive group management server will now generally be described with reference to
A group creation and modification request receiving unit 802 is configured to receive group creation and modification requests from clients, e.g. as in the above-described steps 2.1, 3.1, 4.1 and 5.1. A member list management unit 804 is configured to maintain member lists of groups for clients, e.g. as in the above-described steps 2.2, 3.2, 4.2 and 5.4. A group event notification unit 806 is configured to send group event notifications to other group management servers, e.g. as in the above-described steps 2.3, 2.4, 3.3, 4.3 and 5.3.
A group event receiving unit 808 is configured to receive group event notifications from other group management servers, e.g. as in the above-described steps 2.3, 2.6, 3.3, 4.3 and 5.3. A group list management unit 810 is configured to maintain group lists for clients, e.g. as in the above-described steps 2.5, 3.4, 4.4 and 5.2. Finally, a membership notification unit 812 is configured to receive membership requests and notify clients on the current status of his/her group list, e.g. as in the above-described steps 2.7, 3.5, 4.5 and 5.5.
The present invention provides a simple yet effective solution for making membership information in communication groups easily available to clients, such that a client can find out which active communication groups he/she is a member of, without elaborate searching. Further, this information is available without significant delay as only one server is contacted. A client creating a group is also spared the labour of informing the members on their membership in the group, since this information is made available by means of the present solution, in particular if the members are automatically notified as soon as they become members. Privacy is also enhanced since it is not necessary to provide this information by calling, sending e-mails, etc, which might be improperly intercepted. It is also possible for clients to store their own information in connection with their group lists, e.g. any identities (PSI's) of open groups they might join in the future.
While the invention has been described with reference to specific exemplary embodiments, the description is only intended to illustrate the inventive concept and should not be taken as limiting the scope of the invention, which is defined by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
0403133-2 | Dec 2004 | SE | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/SE05/01984 | 12/20/2005 | WO | 6/20/2007 |