 
                 Patent Application
 Patent Application
                     20080089504
 20080089504
                    The present invention relates to a method for providing presence information in a telecom network.
Voice and data communication services often make use of presence information in telecom and computer networks. Such services may offer e.g. a calling end-user extra context information whether a called end-user is accessible by phone, and if not, for what reason and by which alternative means (voicemail, email) the called end-user can be contacted instead. In addition, end-users may be offered via a call manager service the ability to personalize their accessibility dependent on e.g. calendar information. The concept of presence has been used in several application areas, for instance in Instant Messaging. Starting from a simple notion of online/offline status, it has been expanded to include other context information around the status such as disposition (out to lunch, away from the computer, etc.) and activity status (on the phone, idle, etc.). For such services and applications there is value in knowing the real-time status of an end-user in order to increase the accessibility of that end-user and to provide the end-user greater flexibility and control in managing their communications. As a result voice and data communication services may be offered between end-users in the most convenient manner.
In known applications such as Instant Messaging such presence information is in general determined based on the real-time status of an end-user device or connection. This may be accomplished either as part of status information registered at the centralized network control, or status update information actively sent by the end-user device or by polling the status of the end-user device or connection at regular intervals without any notice to the end-user. As part of Instant Messaging applications presence information is typically used to show the online/offline status of the end-user device or connection of the persons on a contact list and is used to determine by what medium they can be reached (e.g. via Internet or an enterprise communication network).
Potentially this presence capability can also be extended to mobile users because the databases in a mobile network have knowledge of the activity status (reachable, not reachable or busy) of their mobile end-user devices. In addition, the Open Service Access Mobility Service Capability Feature (OSA Mobility SCF, see cited documents [2], [3]) standard specifies a possible method for the retrieval of presence information in mobile networks. The OSA standards are specified in order to transfer mobile network specific control information in a generalised format to non-mobile specific applications like services offered via Internet. The OSA Mobility SCF standard deals among others with the retrieval of status information (busy/idle), location information (longitude/latitude) and altitude information of end-user devices in mobile networks.
However, telecom networks that provide Plain Old Telephony Service (POTS) and/or Integrated Services Digital Network (ISDN) services do often not comprise a capability to determine real-time the status of an end-user device (busy/idle) or the status of an end-user line (busy/idle). In such telecom networks, the end-user line (which is also called a subscriber's line) connects the end-user device (e.g. a telephone set) to an exchange that is comprised by the telecom network. According to ITU-T Q.9 (see cited documents [1]), a subscriber's line is a telephone line connecting the subscriber's equipment to the exchange, typically fixed twisted copper wires. An end-user device that is connected to a telecom network is a passive element with regard to the generation of status information. A disadvantage of this is that real-time status information regarding the end-user line and/or end-user device is not available.
In known telecom networks, if one would like to know the real-time status of an end-user line, one should set up a call to that end-user line. If the end-user is on the phone, this will be noticeable by the return of a busy indication. However a disadvantage is that, if the end-user is not on the phone, the end-user will receive alerting indications or ringing tone and may answer the call and will thus be aware of the fact that another user is attempting to recover the real-time status of this end-user line.
It may also be possible that a polling mechanism based on sending call attempts is used to determine the real-time status of the end-user line. However, this would also create an undesirable situation because receiving alerting indications or ringing tone would hinder end-users. It is a disadvantage of the prior art that such situations cannot be avoided with the existing basic call procedures in telecom networks without requiring special features regarding end-user devices, or without other complex adaptations of the telecom network.
It is an object of the invention to eliminate the drawbacks of the prior art and to provide a method for the real-time provisioning of status information regarding an end-user line comprised by a telecom network.
In accordance with this invention, a method is disclosed for:
determining if the real-time status of an end-user line is busy or idle, the end-user line connecting an end-user device and an exchange that is comprised by a telecom network that provides services to an end-user and that comprises Signalling System No. 7 (SS7) functionality, whereby a presence function is used and whereby the presence function comprises a process that makes use of the Completion of Calls to Busy Subscriber (CCBS) supplementary service that is comprised by the SS7 functionality.
In a first aspect of the invention a presence function is disclosed, which is e.g. comprised by a computer program in a computer system, and that can be interconnected via SS7 signalling links to a telecom network. This presence function is interconnected to the SS7 signalling part functionality of this network and may offer any type of interface to a service application requesting for status information. The presence function can make use of the standard Signalling System No. 7 (SS7) capabilities in a telecom network supporting the CCBS supplementary service. These SS7 network capabilities for this CCBS supplementary service are standardized by ITU-T and ETSI. The SS7 functionality in a telecom network comprises data interfaces between the exchanges in a telecom network for sending information in SS7 messages to control calls (e.g. to set up and clear calls) and associated services. The CCBS supplementary service offers end-users the possibility to receive an automatic call-back when the called end-user becomes free again after the initial call set-up failed due to a busy condition.
A purpose of the present invention is to provide a relatively simple method for real-time determining the status (idle/busy) of an end-user line in a telecom network.
A telecom network that comprises fixed lines and provides POTS and/or ISDN services including the Completion of Calls to Busy Subscriber (CCBS) supplementary service does generally not comprise a presence capability. As a consequence, real-time status information (i.e. the line or device of an end-user is busy or idle) is not commonly available in such telecom networks
An advantage of making use of a presence function according to this invention is that real-time determining the status (idle/busy) of an end-user line or an end-user device in a telecom network can be achieved in a relatively simple way. No modifications in the telecom network or special equipment at the end-user location are required.
Another aspect of the present invention is that the presence function can behave itself as an originating local exchange according to the standard CCBS procedures. The presence function may interact with the service application, although the presence function may also be used without a service application. Further, the presence function may also interact with an exchange to which the end-user line is connected whose real-time status is to be determined. During the process of determining the real-time status of an end-user line, the exchange behaves itself as a terminating local exchange according to the standard CCBS procedures. Also during the process of determining the real-time status, CCBS related information is exchanged between the presence function and the exchange. This CCBS related information is comprised by SS7 signalling messages.
The presence function can, amongst others, be used in the context of an interactive status reporting mechanism in accordance with the UserStatus API as specified in the OSA Mobility SCF standard (see cited documents [4]). The presence function may also be used in the context of a triggered status reporting mechanism in accordance with the UserStatus API as specified in the OSA Mobility SCF standard.
Another possibility is to use a presence function in the context of a multiple network domain, whereby the multiple network domain comprises a telecom network that provides POTS and/or ISDN services and also one or more other types of networks. In such a context, the service application is able to interact with the other types of networks in order to retrieve real-time status information. With the presence function according to this invention the service application is also able to interact with the telecom network to retrieve real-time status information.
The foregoing aspects and many of the attendant advantages of this invention will become better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawing, wherein:
 In 
  
  
  
  
  
  
  
  
 In 
 In 
 In 
For the purpose of teaching of the invention, preferred embodiments of the method and devices of the invention are described in the sequel. It will be apparent to the person skilled in the art that other alternative and equivalent embodiments of the invention can be conceived and reduced to practice without departing form the true spirit of the invention, the scope of the invention being limited only by the appended claims as finally granted.
A purpose of the present invention is to provide a method for determining the real-time status of an end-user line comprised by a telecom network. This real-time status may have different possible values such as idle and busy, although it also may be possible that there are more possible values for the real-time status. The value busy, for instance, may indicate that the end-user line is in use at a certain instance of time. The real-time status is not restricted to real real-time situations. For instance, there can be a delay between the moment that for the real-time status is requested (e.g. by an application) and the moment that it is determined (according to the method of the present invention). There can also be a delay between the moment that the real-time status is determined and the moment that it is presented to e.g. an application or a human being. In cases where the delay is relatively large, one could also speak of the status of the end-user line instead of the real-time status of the end-user line.
If an end-user line is used to provide POTS services, there is in general is a direct relationship between the real-time status of the end-user line and whether an end-user is on the phone or not on the phone. This is because in such a situation only one call can be handled simultaneously over the end-user line.
If and end-user line is used to provide ISDN services, there is a somewhat different situation. This is because in this situation more than one call can be handled over one end-user line (i.e. one call per ISDN B-channel). As a consequence, the real-time status of an end-user line being busy normally indicates that there is no free ISDN B-channel available in that end-user line. In general, there is a relationship between the real-time status of an end-user line and whether an end-user is on the phone or not on the phone.
In the further description of this invention no distinction is made between the provisioning of POTS services and ISDN services over an end-user line, so that the method according to this invention can be applied in both cases.
According to the present invention, the standard Signalling System No. 7 (SS7) capabilities in a telecom network supporting the CCBS supplementary service are used for determining the real-time status of an end-user line or an end-user device. The SS7 network capabilities for the CCBS supplementary service are standardized by ITU-T and ETSI. The SS7 functionality in a telecom network comprises data interfaces between the exchanges in a telecom network for sending information in SS7 messages to control calls (e.g. to set up and clear calls) and associated services. The CCBS supplementary service offers end-users the possibility to receive an automatic call-back when the called end-user becomes free again after the initial call set-up failed due to a busy condition.
In another aspect of the invention a presence function is used that is connected to a telecom network. This presence function is interconnected to the SS7 signalling part functionality of this network and may offer any type of interface to a service application requesting for real-time status information.
  
 In 
  
The presence function (5) may also comprise a database, and additionally or alternatively, a standard SS7 protocol stack. This SS7 protocol stack enables the presence function (5) to interact via the first interface (8) with a SS7 signalling function (80) that is comprised by the telecom network (1). The SS7 signalling function (80) is usually an existing function in telecom networks, and could be comprised by a dedicated physical entity in the SS7 data network. Between each exchange (7) and the signalling function (80), there will be then a SS7 interface. It may also be possible that the signalling function (80) is integrated in one or more exchanges comprised by the telecom network (1).
 Via the signalling function (80) the presence function (5) can send and receive SS7 signalling messages to and from the exchange (7). The presence function (5) may be implemented as integral part of an exchange or other system that is already interconnected to the SS7 data network in the telecom network (1). In such an alternative scenario the first interface (8) would then be invisible and possibly implemented in another way. The telecom network (1) may also comprise other entities that are not depicted in 
As stated earlier, the process comprised by the presence function (5) may also comprise elementary procedures for an originating local exchange in accordance with the CCBS standard. These procedures enable the presence function (5) to simulate the CCBS interaction via SS7 message with the exchange (7) as if a calling end-user interconnected to another exchange in the telecom network (1) would have initiated the execution of the CCBS supplementary service. Thus, instead of a calling end-user it is the presence function (5) that will be informed concerning the real-time status of an end-user line (4). In the case of such a simulation by the presence function (5), the exchange (7) that serves the end-user (3) that corresponds to the end-user line (4) of which the real-time status is to be determined will perform the standard procedures for a terminating local exchange in accordance with the CCBS standard.
  
As part of the standard SS7 signalling message routing in the telecom network (1), the CcbsRequest invoke component will be sent to the exchange (7) serving the end-user (3). The exchange (7) will behave itself as the terminating local exchange according to the standard CCBS procedures. An advantage of this is that the exchange (7) will start, upon receiving the CcbsRequest invoke component, monitoring the status of the end-user line (4) in accordance with the standard CCBS procedures.
As a result of the busy status of the end-user line (4), the exchange (7) will generate a CcbsRequest return result component (see explanatory list, b)) which is comprised in a SS7 message. With the standard SS7 signalling message routing in the telecom network (1), this SS7 message will be sent via the interface (8) to the presence function (5). At this stage of the interaction the CcbsRequest return result only informs the presence function (5) that the exchange (7) has initiated a CCBS monitoring process to determine the status of the end-user line (4). The process comprised by the presence function (5) shall then start a timer to await the possible receipt of a RemoteUserFree invoke component (see explanatory list, d)) from the exchange (7).
If within a specific time interval, indicated by the expiry of the timer as part of the process in the presence function (5), no RemoteUserFree invoke component in a SS7 message is received from the exchange (7), the presence function (5) shall send a StatusReportResult (see explanatory list, g)) to the service application (6) with an indication that the real-time status of the end-user line (4) is busy. The presence function (5) may also send a CcbsCancel invoke component (see explanatory list, e)) in a SS7 signalling message to the exchange (7) via the interface (8) at the telecom network (1). On receipt of the CcbsCancel invoke component the exchange (7) will stop the CCBS monitoring process in the exchange (7) will be stopped. An advantage of sending this CcbsCancel invoke component is that a possible recall requires no specific CCBS coding as part of a subsequent call set-up message. Subsequently, the process in the presence function (5) shall be stopped.
  
  
 The foregoing set of diagrams depicted in 
  
  
  
An advantage of the present invention is that no modifications in the telecom network (1) or special features regarding an end-user device (2) are needed. This is because use is made of the existing standard SS7 signalling capabilities for the support of the CCBS supplementary service. In accordance to this invention it only requires to interconnect the presence function (5) via SS7 links to the telecom network (1). Hereby the presence function (5) on request retrieves the real-time status of an end-user line (4) comprised by the telecom network (1) in the way described before.
  
In this respect known solutions are available to retrieve the real-time status of an end-user line (4) in a mobile network (10) and may be accomplished in another network domain (100) with similar characteristics whereas such a real-time status capability is not available in telecom networks (1).
  
 In 
 In 
 Without the use of the presence function (5) the service application (6) would not be able to offer this automatic call back service without hinder to the called end-user (for the example in 
Explanatory List
CCBS Components in SS7 Messages
The following messages are relevant for the interaction between the exchange (7) and the presence function (5).
a). CcbsRequest Invoke Component
According the CCBS standard this component is sent in a SS7 message between two exchanges in a telecom network when a calling end-user has activated the CCBS supplementary service when a call attempt failed due to the busy status of the called end-user. The exchange serving the calling end-user requests the exchange serving the called end-user to start a CCBS monitoring action for the busy end-user. With this CCBS monitoring action the exchange of the called end-user will report the exchange of the calling end-user if the status of the called end-user has become idle again. This CcbsRequest invoke component includes parameters like the telephone numbers of both end-users and some call specific information. In addition, the exchange serving the calling end-user will retain all call related information of the original call in order to make an automatic call set-up to the called end-user if the status of the called end-user has become idle and the calling end-user answers the phone.
b). CcbsRequest Return Result Component
This component is sent by the exchange serving the called end-user to the exchange serving the calling end-user to acknowledge the successful invocation of the CCBS monitoring action as a response to a received CcbsRequest invoke component.
c). CcbsRequest Return Error Component
This component is sent by the exchange serving the called end-user to the exchange serving the calling end-user to report an unsuccessful invocation of a CCBS monitoring action as a response to a received CcbsRequest invoke component.
d). RemoteUserFree Invoke Component
This component is sent by the exchange serving the called end-user to the exchange serving the calling end-user to report the idle status of the called end-user as result of an outstanding CCBS monitoring action.
e). CcbsCancel Invoke Component
This component may be sent by either the exchange serving the called end-user or the exchange serving the calling to cancel an outstanding CCBS monitoring action for the called end-user or the CCBS call information kept at the exchange serving the calling end-user, respectively.
UserStatus API Messages as Part of OSA Mobility SCF
The following UserStatus API messages are relevant for the interaction between the service application (6) and the presence function (5).
f). StatusReportRequest
This message is specified as part of the interactive status reporting mechanism by which a service application can request a network for the status of the end-user.
g). StatusReportResult
This message is sent by a network to report the status of the end-user in response to a StatusReportRequest message from the service application.
h). TriggeredStatusReportRequestStart
This message is specified as part of the triggered status reporting mechanism by which a service application can request a network for reporting the status changes of an end-user.
i). TriggeredStatusReportRequestStop
This message is specified as part of the triggered status reporting mechanism by which a service application cancels an earlier request to a network for reporting the status changes of an end-user.
j). TriggeredStatusReport
This message is sent by the network to report the status or status change of the end-user in response to a TriggeredStatusReportRequestStart message from the service application.
  
| Number | Date | Country | Kind | 
|---|---|---|---|
| 04078540.4 | Dec 2004 | EP | regional | 
| Filing Document | Filing Date | Country | Kind | 371c Date | 
|---|---|---|---|---|
| PCT/EP05/13210 | 12/8/2005 | WO | 5/31/2007 |