1. Field of Invention
The present invention relates to Internet Protocol telephony, and more particularly to a method for handling the signaling related to the storing and forwarding of voice and video messages in an Internet Protocol based network.
2. Description of the Related Art
Internet Protocol (IP) telephony is the real time delivery of voice, and other multimedia data, between two or more parties across a network using Internet protocols. Internet telephony began in the mid-1990's with PC-to-PC Internet telephony, which required both parties to have a personal computer with specialized hardware and software, allowing voice signals to be transmitted over the Internet. More recently, IP telephony systems have been suggested which utilize the existing public switched telephone network (PSTN) infrastructure integrated with IP networks, such as the Internet.
Internet technology is session based, rather than connection based. An Internet protocol, such as Session Initiation Protocols (SIP) is typically used to establish the session and negotiate the capabilities for the session. Once the session is established, the actual media is transported across the IP network using a different protocol, such as Real-time Transport Protocol (RTP). IP telephony use has advanced rapidly since its introduction.
IP telephony has advantages over the PSTN, providing a cost savings for both users and carriers while allowing the transport of a variety of media types, such as voice and video, as opposed to just voice as in the case of the PSTN. While IP telephony may someday replace the PSTN, it suffers some disadvantages in that it currently lacks many of the features already developed for the PSTN. One such feature is call message deposit and retrieval.
The SIP protocol is currently a leading protocol for establishing IP telephony sessions. However, currently no definitions have been established in the SIP protocol to handle the call forwarding logic and signaling requirements necessary for proper interfacing with messaging systems for message deposit and retrieval. The conditional forwarding of calls for deposit in a messaging system is generally done when a called party is either busy or fails to answer a call. A called party may also wish to have a caller unconditionally deposit a message in a messaging system. In either case, the messaging system interface must provide signaling capabilities to store the message, whether conditionally or unconditionally, and also for a called party to later retrieve the deposited message. The signaling capabilities must also include information about the calling party depositing the message. The identity of the called party must also be verified when he or she retrieves the deposited message.
Therefore, a need exists for a method of handling the signaling required for IP telephony voice and video message deposit and retrieval in an IP based network using the SIP protocol, thereby allowing integration of the IP network with an Integrated Messaging System (IMS).
It is therefore an object of the present invention to provide a method of handling the SIP signaling requirements associated with routing calls to an IMS to allow a calling party to conditionally deposit a message in a called party's message mailbox, in an Internet Protocol based network.
It is another object of the present invention to provide a method of handling the SIP signaling requirements associated with routing calls to an IMS to allow a calling party to unconditionally deposit a message in a called party's message mailbox, in an Internet Protocol based network.
It is yet another object of the present invention to provide a method of handling the SIP signaling requirements associated with routing calls to the IMS to allow a calling party to retrieve the deposited message in the called party's messaging mailbox, in an Internet Protocol based network.
It is still another object of the present invention to provide a method of handling the SIP signaling requirements associated with notifying the called party that a new message has been deposited in the called party's message mailbox, in an Internet Protocol based network.
To achieve the above objects, a method in accordance with the present invention is provided for signaling an IMS on an IP based network to deposit a message, the method including the steps of sending a SIP INVITE request to the IMS indicating a message deposit action; receiving a corresponding SIP message from the IMS agreeing to participate in the message deposit action; and sending an SIP acknowledge message to the IMS confirming receipt of the corresponding SIP message; and depositing the message in a destination mailbox.
Also provided is a method of signaling an IMS on an IP based network to retrieve a deposited message, the method including the steps of sending a SIP INVITE request to the IMS indicating a message retrieval action; receiving a corresponding SIP message from the IMS agreeing to participate in the message retrieval action; sending an SIP acknowledge message to the IMS confirming receipt of the corresponding SIP message; and retrieving the deposited message from a mailbox corresponding to known account information.
The above and other objects, features, and advantages of the present invention will become more apparent in light of the following detailed description of an exemplary embodiment thereof taken in conjunction with the attached drawings in which:
Turning now to the drawings, in which like reference numerals identify similar or identical elements throughout the several views,
Traditional telephones 13 are connected to the Internet 17 through traditional telephone switching equipment, such as PBX's and IP telephony gateways 21. IP telephony gateways 21 each include a signaling gateway (not shown) and a media gateway (not shown). The signaling gateway provides bi-directional transportation between PSTN telephony signaling and IP telephony signaling messages, such as SIP. IP phones 15 may be connected directly to the Internet through a local area network or by a modem connection through an Internet service provider.
Generally, call signaling and media are transported across the Internet 17 between an originating IP telephony gateway 21a and a destination IP telephony gateway 21b. Typically, routing information is supported by a proxy server, such as a network server (NS) 23. The NS 23 also provides call control and call forwarding control. That is, the NS 23 includes an intermediary application program that acts as both a server and a client for the purposes of making requests on behalf of other clients or, referred to generally as calling parties hereinafter. In the SIP protocol an INVITE request is sent from the originating IP telephony gateway 21a to the address of the called party at the NS 23. IP call setup signaling messages are transported back and forth between the IP telephony gateways 21 and the NS 23 until the call is setup using the SIP protocol, as is commonly known in the art.
The system also includes a location manager 31, which provides gateway selection and mobility management services to the NS 23. The location manager 31 functions as an SIP redirect server. A redirect server is a server that accepts an SIP request, maps the address into zero or more new addresses and returns these addresses to the sender, for instance the NS 23. Unlike an SIP proxy server such as the NS 23, a redirect server does not initiate its own SIP requests or accept calls. Thus, if the NS 23 cannot send a session initiation request to the IP telephony gateway 21, the NS 23 sends a session initiation request to the called party at the location manager 31. The location manager 31 either consults its own database or accesses the legacy service control entity 29 to obtain a new address for the called party. The location manager 31 then returns the new address to the NS 23.
In cases where the called party can not be reached, i.e. the phone is busy or not answered, the call is forwarded to an Integrated Messaging System (IMS) 25. In order to properly forward, deposit and retrieve the messages in the IMS 25, the NS 23 must communicate with the IMS 25 using the SIP protocol. Currently there are no definitions established for using the SIP protocol to handle conditional call forwarding logic and the signaling requirements necessary for proper interfacing with messaging systems. The present invention establishes the SIP signaling requirements for interfacing with an IMS 25.
The NS 23 sends one or more SIP requests to the IMS 25 and receives one or more responses from the IMS 25. A request (and its retransmissions) together with the responses triggered by that request make up a SIP transaction. All responses to a request contain the same values in the Call-ID, CSeq, To, and From, as shown in the examples below. This allows responses to be matched with requests. The functions served by these parameters are commonly known in the art.
A successful SIP invitation consists of two requests, INVITE followed by an ACK request. The ACK request following an INVITE is not part of the transaction since it may traverse a different set of hosts. The INVITE request asks the called party to join a particular conference or establish a two-party conversation. After the called party has agreed to participate in the call by responding with, for instance, a 200 OK message, the caller confirms that it has received that response by sending an ACK request. If the caller no longer wants to participate in the call, it sends a BYE request instead of an ACK. The INVITE request typically contains a session description that provides the called party with enough information to join the session. The session description enumerates the media types and formats that the caller is willing to use and where it wishes the media data to be sent. If the called party wishes to accept the call, it responds to the invitation by returning a similar description listing the media it wishes to use.
The SIP INVITE request of the current invention includes an additional header added by the NS 23. The added header will use the SIP Require header protocol extension mechanism. The Require header is used to tell the IMS 25 about the options that must be supported. The proposed format for this header includes a suitable tag, such as:
The NS 23 adds the Require header and associated parameters to the SIP INVITE request forwarded to the IMS 25 by the NS 23. The NS 23 must first establish whether a called party, being an IMS account user, has selected to have all calls unconditionally forwarded to his message mailbox in the IMS 25. This information is acquired from the called party by the NS 23 via a call made by the called party to the NS 23 when the called party activates the unconditional call forwarding feature on the called party's telephone, or other communicating device. The NS 23 determines whether a called party is busy as a result of receiving a busy response, such as “486 Busy Here”, in response to the INVITE request from the NS 23 to the called party during initial call setup. The NS 23 determines whether a called party is not answering as a result of receiving a request time-out in response to the INVITE request from the NS 23 to the called party during initial call setup.
The call flow for general IP call setup between a calling party and a called party using the SIP protocol is well known in the art and not detailed herein to avoid unnecessarily obscuring the invention. The present invention therefore focuses on the method of communications required between the NS 23 and IMS 25, and more particularly the addition of the Require header and its associated parameters.
Referring to
In steps 206, 211, or 216, a typical SIP INVITE request call flow sent from the NS 23 to the IMS 25 including the additional SIP Require header is shown below:
In the above example the dtype parameter selected contains the value cfb, indicating a conditional busy call forwarding deposit operation, as in step 210. This parameter would differ for the SIP INVITE request of steps 205 and 245 and would instead be cfu and cfna, respectively.
In any case, the IMS 25 responds to the SIP INVITE request by sending a 200 OK message to the NS 23 in step 225, indicating that the request was successful and the IMS 25 has agreed to participate in the call with the NS 23. A typical response is shown below:
The NS 23 then confirms that it has received a final response to the SIP INVITE request in step 230 by sending an ACK message to the IMS 25, typically as shown below:
The message, being of video or voice content, is then deposited into the called party's mailbox address, the called party being an IMS account user, by the IMS 25 in step 235. Communication is then terminated via normal SIP BYE processing in step 240.
A method of retrieving a deposited message in accordance with the present invention is illustrated in
In step 305, if the IMS account user's account information has been authenticated by the NS 23, the call flow between the NS 23 and IMS 25 will, for example, be as follows, beginning with step 310 in which the NS 23 sends the SIP INVITE request.
The IMS 25 responds to the SIP INVITE request by sending a 200 OK message to the NS 23 in step 315, indicating that the request was successful and the IMS 25 has agreed to participate in the call with the NS 23. A typical response is shown below:
The NS 23 then confirms that it has received a final response to the SIP INVITE request in step 320 by sending an ACK message to the IMS 25, typically as shown below:
In the above scenario, no prompting is required since the IMS account user's information is authenticated and, in step 325, the IMS 25 uses the account information indicated in the INVITE request Uniform Resource Locator (URL). Thereafter, the calling user is granted access to the mailbox in step 410 and the message is retrieved in step 415, which is followed by normal SIP BYE processing at step 420 to end the call.
On the other hand, if the IMS account user cannot be authenticated in step 305, and the user is accessing the IMS 25 from a device that has a default IMS account associated with it in step 340, the procedure instead continues to step 345, providing an SIP INVITE request from the NS 23 to the IMS 25 as follows, for example:
The IMS 25 responds to the SIP INVITE request by sending a 200 OK message to the NS 23 in step 350, indicating that the request was successful and the IMS 25 has agreed to participate in the call with the NS 23. A typical response is shown below:
o=UserB 2890844527 2890844527 IN IP4 client.there.com
The NS 23 then confirms that it has received a final response to the SIP INVITE request in step 355 by sending an ACK message to the IMS 25, typically as shown below:
The SIP INVITE request above contains the account information, with no password authentication. At this point, the IMS 25 prompts the calling IMS account user for a password to verify the account contained in the INVITE request URL in step 360. If the account is verified, the procedure continues to steps 410–420 as described above. If, however, the password entered is incorrect, or the user indicates he or she is calling from a device with a default account assigned to it corresponding to another user's account, then the IMS 25 prompts the user for a user name and password in step 395 and continues to step 400 as described below.
However, if in step 340, the IMS account user is accessing the IMS 25 from a gateway or other device that does not have a default IMS account assigned to it, the NS 23 sends an account unknown SIP INVITE request to the IMS 25 in step 380 as shown below:
The IMS 25 responds to the SIP INVITE request by sending a 200 OK message to the NS 23 in step 385, indicating that the request was successful and the IMS 25 has agreed to participate in the call with the NS 23. A typical response is shown below:
The NS 23 then confirms that it has received a final response to the SIP INVITE request in step 390 by sending an ACK message to the IMS 25, typically as shown below:
In this case, the SIP INVITE request contains no account or authentication information, but only the identifier UNKNOWN in the INVITE request URL. Accordingly, in step 395, a calling party is prompted for a user name and password. If the account is verified in step 400, the procedure continues to steps 410–420 as described above. However, if the user name and password is entered incorrectly, the user is allowed a predetermined number of re-entry attempts in step 405 before the operation is aborted, ending the call in step 406.
While the present invention has been described in detail with reference to the preferred embodiments, they represent mere exemplary applications. Thus, it is to be clearly understood that many variations can be made by anyone of ordinary skill in the art while staying within the scope and spirit of the present invention as defined by the appended claims.
This application is a continuation of the U.S. patent application having Ser. No. 09/436,795, now U.S. Pat. No. 6,434,143 filed Nov. 8, 1999.
Number | Name | Date | Kind |
---|---|---|---|
5303286 | Wiedeman | Apr 1994 | A |
5434907 | Hurst et al. | Jul 1995 | A |
5481542 | Logston et al. | Jan 1996 | A |
5664009 | Hurst et al. | Sep 1997 | A |
5680116 | Hashimoto et al. | Oct 1997 | A |
5699359 | Suga | Dec 1997 | A |
5732219 | Blumer et al. | Mar 1998 | A |
5742763 | Jones | Apr 1998 | A |
5745556 | Ronen | Apr 1998 | A |
5768361 | Cowgill | Jun 1998 | A |
5794039 | Guck | Aug 1998 | A |
5802510 | Jones | Sep 1998 | A |
5826039 | Jones | Oct 1998 | A |
5832221 | Jones | Nov 1998 | A |
5859898 | Checco | Jan 1999 | A |
5864610 | Ronen | Jan 1999 | A |
5867494 | Krishnaswamy et al. | Feb 1999 | A |
5867495 | Elliott et al. | Feb 1999 | A |
5889774 | Mirashrafi et al. | Mar 1999 | A |
5907547 | Foladate et al. | May 1999 | A |
5913176 | Barabash | Jun 1999 | A |
5923659 | Curry et al. | Jul 1999 | A |
5930348 | Regnier et al. | Jul 1999 | A |
5951638 | Hoss et al. | Sep 1999 | A |
5953504 | Sokal et al. | Sep 1999 | A |
5960416 | Block | Sep 1999 | A |
6064653 | Farris et al. | May 2000 | A |
6067442 | Wiedeman et al. | May 2000 | A |
6069890 | White et al. | May 2000 | A |
6073160 | Grantham et al. | Jun 2000 | A |
6078583 | Takahara et al. | Jun 2000 | A |
6081518 | Bowman-Amuah | Jun 2000 | A |
6094578 | Purcell et al. | Jul 2000 | A |
6118864 | Chang et al. | Sep 2000 | A |
6134235 | Goldman et al. | Oct 2000 | A |
6144667 | Doshi et al. | Nov 2000 | A |
6147975 | Bowman-Amuah | Nov 2000 | A |
6151390 | Volftsun et al. | Nov 2000 | A |
6151629 | Trewitt | Nov 2000 | A |
6157648 | Voit et al. | Dec 2000 | A |
6161008 | Lee et al. | Dec 2000 | A |
6163536 | Dunn et al. | Dec 2000 | A |
6167042 | Garland et al. | Dec 2000 | A |
6178181 | Gritho | Jan 2001 | B1 |
6188760 | Oran et al. | Feb 2001 | B1 |
6195697 | Bowman-Amuah | Feb 2001 | B1 |
6226289 | Williams et al. | May 2001 | B1 |
6240449 | Nadeau | May 2001 | B1 |
6253249 | Belzile | Jun 2001 | B1 |
6278707 | MacMillan et al. | Aug 2001 | B1 |
6292479 | Bartholomew et al. | Sep 2001 | B1 |
6295291 | Larkin | Sep 2001 | B1 |
6333931 | LaPier et al. | Dec 2001 | B1 |
6335927 | Elliott et al. | Jan 2002 | B1 |
6335968 | Malik | Jan 2002 | B1 |
6339594 | Civanlar et al. | Jan 2002 | B1 |
6366576 | Haga | Apr 2002 | B1 |
6381316 | Joyce et al. | Apr 2002 | B1 |
6404746 | Cave et al. | Jun 2002 | B1 |
6404870 | Kia et al. | Jun 2002 | B1 |
6411705 | Oran et al. | Jun 2002 | B1 |
6426955 | Dalton et al. | Jul 2002 | B1 |
6434143 | Donovan | Aug 2002 | B1 |
6453034 | Donovan et al. | Sep 2002 | B1 |
6463053 | Chen | Oct 2002 | B1 |
6487283 | Thomas et al. | Nov 2002 | B1 |
6507647 | Mandalia | Jan 2003 | B1 |
6515997 | Feltner et al. | Feb 2003 | B1 |
6519242 | Emery et al. | Feb 2003 | B1 |
6529499 | Doshi et al. | Mar 2003 | B1 |
6567399 | Schuster et al. | May 2003 | B1 |
6570869 | Shankar et al. | May 2003 | B1 |
6584093 | Salama et al. | Jun 2003 | B1 |
6584110 | Mizuta et al. | Jun 2003 | B1 |
6600735 | Iwama et al. | Jul 2003 | B1 |
6631186 | Adams et al. | Oct 2003 | B1 |
6633571 | Sakamoto | Oct 2003 | B1 |
6650901 | Schuster et al. | Nov 2003 | B1 |
6658022 | West et al. | Dec 2003 | B1 |
6681252 | Schuster et al. | Jan 2004 | B1 |
6744759 | Sidhu et al. | Jun 2004 | B1 |
6937563 | Preston et al. | Aug 2005 | B1 |
6954654 | Ejzak | Oct 2005 | B1 |
Number | Date | Country |
---|---|---|
1207226 | Feb 1999 | CN |
0794650 | Sep 1997 | EP |
0123456 | Jan 2000 | EP |
9716007 | May 1997 | WO |
9716916 | May 1997 | WO |
9722210 | Jun 1997 | WO |
9723078 | Jun 1997 | WO |
9821874 | May 1998 | WO |
WO 9722209 | Feb 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20020071429 A1 | Jun 2002 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09436795 | Nov 1999 | US |
Child | 10068381 | US |