The present invention relates to improvements to presence service, for example in a SIP environment. In particular, the present invention relates to a presentity, a presence server, and a presence system network entity.
Generally, presence is a service and/or technology by means of which a user can publish its availability, and can publish its communications contacts to other interested users.
Availability means for example (basically) that the user has switched on its terminal and is thus basically reachable, or that the user is available within a specific area. In the past, this has been referred to as “on-line” or “off-line”. However, presently the meaning of presence is to be understood in a broader sense and means the willingness and ability of a user to communicate with other users on the network. The availability is thus represented by a configurable presence status definable and/or changeable by presence events.
Communications contacts means for example the user terminal's telephone number such as an MSISDN, an email address, a URI (Uniform Resource Identifier), or any other identification information suitable and/or required for contacting the user via a means of communication he is using and/or via which he is (willing to be) available.
A user of presence, i.e. at least one of the user's terminals subscribed to presence service, is called presentity (a combination of the words “presence” and “entity”).
Such a presentity has an address to which other, interested users—referred to as watchers—subscribe. Such a subscription is accomplished using a presence protocol.
Signaling in connection with publication of presentity's status information and subscription of watchers is referred to as “publish” and “subscribe” messages.
A subscription to presence service results in notifications being sent to a respective watcher, e.g. when the presentity's presence status changes. These messages are commonly referred to as “notify”.
Based on the notifications and/or the contents thereof, respectively, the watcher is enabled to communicate with the presentity, e.g. by being aware of the availability and the communication channel/means to be used and/or to be selected.
Thus, as agreed in current IETF (Internet Engineering Task Force) publications dealing with presence service, a presence service is a system that accepts, stores, and distributes presence information to interested parties, called watchers. A presence protocol is a protocol for providing a presence service over the Internet or any other IP or even just packet-based network.
The terminology as adopted throughout the present specification is intended to be harmonized to agreed IETF terminology; however, the meaning of the expressions used is not intended to be limited by the adopted terminology. Other expressions are intended to be covered also, as long as the same functional (inter)relation is accomplished.
One example of a presence protocol to which reference is made hereinafter for explanatory purposes is thus SIP (Session Initiation Protocol).
Nevertheless, a communications contact of a user needs to be rather static so as to be reachable for communication partners and in order to dispense with notifying all communication partners of a changed communications contact.
In certain communication systems, approaches to maintain a static communications contact have recently been made.
For example, number portability in the mobile phone market has reduced “customer lock-in” (to a specific network operator) by allowing the customer to change the service provider without changing the respective telephone number such as MSISDN.
Furthermore, in the Internet, there exist certain providers who provide forwarding services for home pages and/or email. Thereby, they allow a user to maintain a static email address and/or home page address, while still changing their Internet Service Provider ISP.
With new network technologies evolving, also new service providers will show up.
One of those new network technologies and/or topologies is known as SIP (Session Initiation Protocol). SIP represents a signaling protocol for Internet conferencing, telephony, presence, events notification and instant messaging.
The protocol initiates call setup, routing, authentication and other feature messages to endpoints within an IP domain.
With SIP, and especially the presence service in SIP, the user's SIP service provider needs to be able to handle a user “parking” the presence of an outside SIP address in its system. The same problem most likely exists in the enterprise or business domain, where an employee also has a private SIP identity, and would like to co-locate that presence with the work-identity's presence. Insofar, it could be compared to a “roaming” SIP user.
Hence it is an object of the present invention to provide for a system and corresponding devices constituting the same, enabling the parking of the presence of e.g. a SIP address to another SIP service provider.
According to a first aspect of the present invention, this object is for example achieved by
According to favorable refinements,
According to a second aspect of the present invention, this object is for example achieved by
According to favorable refinements,
According to a third aspect of the present invention, this object is for example achieved by
According to favorable refinements,
Also, according to an aspect of the present invention, this object is achieved by
According to favorable refinements, the method comprises
Hence, according to the present invention, the following exemplary advantages are achieved:
The present invention will be described with reference to the accompanying drawings, in which
Accordingly, as has been outlined above, the present invention, stated in brief an in other words, comprises:
A) Setting Up a Presence Park-Account:
A special account (parking account) that is to be used to park the external identity's presence in the (local) presence system is configured in the (local) service provider. This is manually configured by the user, or automatically by the presentity.
An example of such an account could be the following (assuming that user.name is the identification of the presentity ID_of_presentity in the external service provider's domain EXT_SP, e.g. located in Finland FI)
The external service provider, i.e. its presence system network entity or entities, is configured and/or set to perform a proxying operation, i.e. to proxy or redirect, all e.g. SIP based requests to the target domain (i.e. the local domain). With reference to the above example, there is provided an address binding of SIP:user.name@ext_sp.fi
The internal service provider, i.e. its presence system network entity or entities, is a configured such that both presence publications (“Publish”) and presence subscriptions (“Subscribe”) are accepted for SIP:user.name%40ext_sp.fi@int_sp.fi. Those messages will reach the internal service provider's network entities at least upon being redirected from the external service provider's presence system network entities.
The overall implementation resides in an implementation of the above configurations at the respective network nodes concerned.
This will be set out in greater detail herein below.
Subsequently, the present invention will be described with reference to an example concerning a presence system and corresponding entities enabling the parking of the presence of a SIP address to another SIP service provider. Also, corresponding method steps for enabling proper operation of the system and entities involved will be described.
As shown in
The presentity is shown in bold outline in the lower right part of
The local domain is represented by a presence system network entity of the local domain. This does not exclude that more than one presence system network entities and/or other network entities constitute the external domain, but is chosen for the purpose of a simplified explanation only.
In addition, the local domain is represented by a presence server, associated to which is a database. At the database, so-called parking accounts are maintained for presentities not registered in the local domain, but for example registered in the external domain.
The external presentity is thus addressable in the local domain via its parking account. This parking account is established by defining the presentity's parking account at the presence server of the local domain service provider by embedding the presentity's identification in the domain under which it is registered (ID_of_Presentity@EXT_SP.cc) into a user part of an identification for the local domain (ID_of_Presentity%40EXT_SP.cc@LOC_SP.cc).
In the upper part of
Subsequently, messages shown in
Messages and/or signaling of the presentity are denoted with “P”, followed by a number indicating the sequence of messages.
Firstly, the presentity publishes its presence status (e.g. upon the occurrence of a status (change) event to the presence system network entity of its home network domain, i.e. the external domain; message P1.
This presence system network entity is thus in a domain under which the presentity is registered, and comprises a communication device for communication with other network entities. The communication device is configured to receive a notification informing of the presentity account, set up for the presentity registered under the domain, at a presence server of a local domain. In the illustrated scenario, such a notification has recently already been received by a notifying message (not shown in
Further, the communication device is configured to redirect all requests directed to the presentity's identification in the domain under which it is registered, to the presentity's presentity account at the presence server of the local domain service provider. Thus, as shown in
Thereafter, the presentity's publish message is redirected to the presence system network entity of the local domain, message P3.
Such a redirection is due to the communication device being configured to redirect messages based on an address binding of the presentity's identification in the domain under which it is registered to the presentity's presentity account at the presence server of the local domain service provider.
Alternatively, it is also possible that message P2 is not transmitted (but instead a redirection decision is taken internally in the network entity of the external domain and is processed), but that then message P3 is forwarded and/or relayed, i.e. redirected from the presence system network entity of the external domain “directly”, i.e. at least without involving the presentity again, to the presence system network entity of the local domain.
The presence system network entity of the local domain transmits the publish message, P4, further to the presence server and the associated database, so that the presence account of the presentity is accordingly updated.
In response to a successful update of the presence status of the presentity at the parking account, an ok message is returned, P5, via the presence system network entity and further to the presentity, P6.
Substantially the same basic message flow is valid for subscribe messages from a watcher to the presentity's presence information.
Messages and/or signaling of the watcher are denoted with “W”, followed by a number indicating the sequence of messages.
Firstly, the watcher subscribes to the presence status of the presentity to the presence system network entity of the presentity's home network domain, i.e. the external domain; message W1, because the presentity is firstly known to the watcher only by its identification in the domain, under which the presentity is registered.
As stated above, this presence system network entity is thus in a domain under which the presentity is registered, and comprises a communication device for communication with other network entities. The communication device is configured to receive a notification informing of the presentity account, set up for the presentity registered under the domain, at a presence server of a local domain. In the illustrated scenario, such a notification has recently already been received by a notifying message (not shown in
Further, the communication device is configured to redirect all requests directed to the presentity's identification in the domain under which it is registered, to the presentity's presentity account at the presence server of the local domain service provider. Thus, as shown in
Thereafter, the watcher's subscribe message is redirected to the presence system network entity of the local domain, message W3.
Such a redirection is due to the communication device being configured to redirect messages based on an address binding of the presentity's identification in the domain under which it is registered to the presentity's presentity account at the presence server of the local domain service provider.
Alternatively, it is also possible that message W2 is not transmitted (but instead a redirection decision is taken internally in the network entity of the external domain and is processed), but that then message W3 is forwarded and/or relayed, i.e. redirected from the presence system network entity of the external domain “directly”, i.e. at least without involving the watcher again, to the presence system network entity of the local domain.
The presence system network entity of the local domain transmits the publish message, W4, further to the presence server and the associated database, so that the watcher may subscribe to the presence account of the presentity and learn any updates contained therein.
In response to a subscription to the presence status of the presentity at the parking account, an ok message is returned, W5, via the presence system network entity and further to the watcher, W6.
The external service provider's presence system network entity is thus enabled to perform an unconditional forwarding using redirect/proxying. The watcher subscribes to the presentity's external identity's presence and follows redirection responses and points the request to the correct, i.e. the local domain. The presentity publishes its presence documents associated with its external identity and redirection/proxying works also (at the presence system network entity) for publication messages. The presence server maintains a parking account, i.e. a parking type identity. In this regard, it is to be noted that the request-URI and the presentity (entity attribute in presence document) are not the same.
It is to be noted that the publish messages of the presentity P are not in a specific timing relation to the subscribe messages of the watcher, but that subscribe and publish messages are rather independent from each other.
Hereinbefore, the system and interrelation of entities constituting the system has been described. Subsequently, details of the entities will be described with reference to a respective block circuit representation thereof.
As shown, the presentity comprises a presentity account setup device, which is adapted to cooperate with a presence server of a local domain's LOC_SP service provider.
The presentity account setup device in turn comprises a presentity account definition means, which is responsive to an instruction input. The definition means as configured to define a presentity account at the presence server of the local domain service provider. This is accomplished, for example, by embedding the presentity's identification in the domain under which it is registered, i.e. ID_of_Presentity@EXT_SP.cc, into a user part of an identification for the local domain such as e.g. ID_of_Presentity%40EXT_SP.cc@LOC_SP.cc.
In addition, the presentity further comprises a notification device, which is responsive to the presentity account definition means having defined the presentity account at the presence server of the local domain service provider. For example, the signal supplied to the presence server also triggers the notification device. The notification device is configured to notify at least one presence system network entity of the domain under which the presentity is registered, i.e. of the external domain, of the presentity account set up at the presence server of the local domain.
Still further, the presentity account setup device comprises a presence server domain detection means, which is configured to detect the domain of the presence server. For example, in a discovery operation, the presence server domain detection means learns the domain of the presence server. A judgment means judges whether the domain LOC_SP of the presence server is equal to a domain EXT_SP under which the presentity is registered. The domain under which the presentity is registered is e.g. fetched from an internal memory storing the domain under which the presentity's ID is registered. The judgment means is adapted to output the instruction input to said presentity account definition means, if said judgment means judge that the presence server domain is not equal to the domain under which the presentity is registered.
The instruction input can be directly input to the definition means in one embodiment.
Alternatively, in another embodiment, the instruction input can directly be manually input by a user of the presentity to the definition means via a man machine interface MMI.
Nevertheless, as shown in
In any case, the instruction input comprises at least the presentity's identification in the domain under which it is registered and an identification for the local domain.
The presence server of a local domain LOC_SP service provider comprises a database configured to comprise a presentity account associated to a presentity registered under a domain EXT_SP that is different from the local domain LOC_SP. In the example shown, this account is identified by SIP:ID_of_presentity%40ext_SP.cc@int_SP.cc.
The presence server comprises further a communication device configured to accomplish communication with other network entities. The communication device is particularly configured to process presence publication requests and presence subscriptions requests associated to the presentity account maintained at the server which account is associated to a presentity registered under a domain EXT_SP that is different from the local domain LOC_SP. Thos publish/subscribe requests are received due to the forwarding/redirecting of these requests, as described herein above. Upon processing those requests, the communication device is also adapted to respond to these requests with an OK message (in case of success) or with any other suitable message reflecting the processing result and conforming to the presence protocol chosen in the system, such as SIP.
The presence system network entity, in a domain under which a presentity is registered, comprises a communication device for communication with other network entities. The communication device is configured to receive a notification informing of the presentity account, set up for the presentity registered under the domain, at a presence server of a local domain. Such a notification triggers the communication device with regard to a further configuration.
Namely, additionally, having received such a notification, said communication device is configured to redirect all requests directed to the presentity's identification in the domain under which it is registered, to the presentity's presentity account at the presence server of the local domain service provider. The redirection processing is e.g. based on an address binding of presentity's identification in the domain under which it is registered to the presentity's presentity account at the presence server of the local domain service provider.
As described herein before, the present invention provides a presentity, comprising: a presentity account setup device adapted to cooperate with a presence server of a local domain's (LOC_SP) service provider, the presentity account setup device comprising: presentity account definition means, responsive to an instruction input, defining a presentity account at the presence server of the local domain service provider by embedding the presentity's identification in the domain under which it is registered (ID_of_Presentity@EXT_SP.cc) into a user part of an identification for the local domain (ID_of_Presentity%40EXT_SP.cc@LOC_SP.cc). The invention also concerns a correspondingly adapted presence system network entity as well as a correspondingly adapted presence server. The invention enables thus a parking of presence information of a presentity outside its “home” presence system. Hence, roaming presentities and/or co-location of presentity identities is enabled.
Although the present invention has been described herein above with reference to certain embodiments and variations thereof, it is to be understood that the present invention is not limited thereto. Rather, various modifications are further conceivable within the scope of the appended claims.
Number | Date | Country | |
---|---|---|---|
60583348 | Jun 2004 | US |