WO2014194039A1 - Method and apparatus for call handling signaling - Google Patents
Method and apparatus for call handling signaling Download PDFInfo
- Publication number
- WO2014194039A1 WO2014194039A1 PCT/US2014/039935 US2014039935W WO2014194039A1 WO 2014194039 A1 WO2014194039 A1 WO 2014194039A1 US 2014039935 W US2014039935 W US 2014039935W WO 2014194039 A1 WO2014194039 A1 WO 2014194039A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- call
- script
- call handling
- particular state
- engaged
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M3/00—Automatic or semi-automatic exchanges
- H04M3/42—Systems providing special services or facilities to subscribers
- H04M3/436—Arrangements for screening incoming calls, i.e. evaluating the characteristics of a call before deciding whether to answer it
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/10—Architectures or entities
- H04L65/1046—Call controllers; Call servers
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/1066—Session management
- H04L65/1069—Session establishment or de-establishment
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/1066—Session management
- H04L65/1096—Supplementary features, e.g. call forwarding or call holding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/535—Tracking the activity of the user
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M2201/00—Electronic components, circuits, software, systems or apparatus used in telephone systems
- H04M2201/40—Electronic components, circuits, software, systems or apparatus used in telephone systems using speech recognition
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M2201/00—Electronic components, circuits, software, systems or apparatus used in telephone systems
- H04M2201/60—Medium conversion
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M3/00—Automatic or semi-automatic exchanges
- H04M3/42—Systems providing special services or facilities to subscribers
- H04M3/50—Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
- H04M3/53—Centralised arrangements for recording incoming messages, i.e. mailbox systems
- H04M3/533—Voice mail systems
- H04M3/53308—Message originator indirectly connected to the message centre, e.g. after detection of busy or absent state of a called party
Definitions
- Embodiments of the present invention generally relate to a voice over internet protocol (VoIP) service, and more specifically, to a method and apparatus for performing call handling signaling.
- VoIP voice over internet protocol
- a called party can dictate how to respond to a call. For example, the called party can terminate the call if it is from a particular number or if the called party is already on another call. The called party can associate media with their contacts, and have the media play on their device when a particular contact calls. In other instances, the called party can program their device to divert a call to voice mail, or to perform another action if the called party has indicated they are occupied by another task. The called party has control over how a call is handled.
- the calling party has no way of controlling a call once it is placed to the called device.
- the calling party has no control over how a call is handled.
- the called party can only dial a particular telephone number, and the call is handled in accordance with the called party's direction.
- Embodiments of the present invention relate to a method and apparatus for call handling comprising receiving, from a first device, an incoming call request directed to a second device, wherein the call request contains call handling information and transmitting an outgoing call request to the second device, wherein the outgoing call request is based at least in part upon the call handling information.
- Figure 1 is an illustration depicting interactions between a calling device and a called device in accordance with one or more embodiments of the present invention
- Figure 2 is a depiction of a flow diagram of an instruction set for an exemplary script as described above in accordance with embodiments of the present invention
- Figure 3 is a detailed depiction of a first and second computer system in accordance with at least one embodiment of the present invention.
- Figure 4 depicts a flow diagram for a method for call handling in accordance with previous embodiment of the present invention as depicted in Figures 1 -3; and [0012]
- Figure 5 depicts a flow diagram for a method for incoming call handling in accordance with previous embodiment of the present invention as depicted in Figures 1 -3.
- Embodiments of the present invention generally relate to call handling signaling within a calling network, such as a Voice over Internet Protocol (VoIP) network.
- a user of a telephony device may provide a signal indicating how their calls to any called party, or a particular called party, should be handled by the device in use by the called party.
- the signaling information input by the user of the calling device may further indicate a set of actions that the called device should execute upon receiving the call.
- FIG. 1 is an illustration depicting interactions between a calling device 100 and a called device 108 in accordance with one or more embodiments of the present invention.
- the device 100 and the device 108 are hosted on the carrier network 106, though according to other embodiments, the two devices may be hosted by two different carrier networks.
- the device 100 and device 108 may optionally have respective VoIP application (VOIP APP) 101 and VoIP Application 109 stored thereon.
- the VoIP applications 101 and 109 are managed by the same service provider. Subscribers, i.e., users of device 100 and 108, are able to communicate with other devices via the carrier network 106 by using the VoIP Application 101 and the VoIP Application 109.
- a call configuration message is generally sent to the carrier network 106.
- the carrier network 106 is a VoIP network.
- the carrier network 106 may be a non-VoIP network such as a circuit switched network or the like.
- this message oftentimes takes the form of a SIP INVITE message.
- other call configuration messages are submitted to the network such as H.323 (a protocol for providing audio visual communication sessions over packet networks), JINGLE (a protocol for peer to peer session control for multimedia interactions such as VoIP) messages, or the like.
- a user interacts with the device 100 and indicates to the VOIP APP 101 that a call placed from device 100 should be handled in a particular way. That handling information is stored in a call configuration message 102 as call parameter information 104.
- the call parameter information 104 may comprise, for example, at least one of ringtone URL 150, avatar URL 151 and script URL 152.
- the call configuration message 102 is delivered to the carrier network 106, which then forwards the message 102 to the device 108.
- carrier network 106 is unaware of the additional information stored in the call configuration message 102, and the carrier network 106 processes the call configuration message 102 to perform any configuration prior to establishing the call between device 100 and device 108.
- the device 108 receives the call configuration message 102 comprised of, among other information, call parameter information 104.
- the device 108 then handles the call according to the call parameter information 104.
- the carrier network 106 can parse the call parameter information 104 from the call configuration message 102 and prompt the device 108 to perform particular functions as indicated by the call parameter information 104.
- the call parameter information 104 may contain call handling instructions indicating how the device 108 should handle the call.
- the call handling instructions may indicate that the device 108 should go to voicemail if the user of device 108 is already engaged in a call, or send a text message to the device 100 that the user of device 108 is engaged in a call.
- the call parameter information may also contain an embedded caller ID, name of the caller, content from a social media account, instructions to enable device functionality such as a camera phone, enable remote monitoring or disabling a called device remotely using embedded call instructions, application flags, and other simple data.
- any instructions related to call handling for the device 108 to execute can be inserted into the call parameter information 104. If the device 108 is capable of executing the particular instructions, then the device 108 will execute the instructions according to the call parameter information 104. In some instances, if the device 108 is not capable of executing call handling instructions, the carrier network 106 may return a system message to the device 100 indicating the status of device 108. In yet another embodiment, the call parameter information 104 may contain direct links to one or more media items, and the device 108 automatically parses those links and plays or displays media from those links upon receiving a call from device 108.
- the call handling instructions may initiate a "call-hunt", i.e., dialing up to a threshold number of telephone numbers if an initial number does not respond.
- the call configuration message 102 may be a session initiation protocol (SIP) INFO, UPDATE, NOTIFY or INVITE message, or could be embedded in other types of signaling such as H.323, JINGLE, or the like.
- SIP session initiation protocol
- the call configuration message 102 may take the form of any configuration message passed through a carrier network, and the call parameter information 104 may be embedded in any data/voice packets travelling across the carrier network 106.
- the call parameter information 104 may provide a link to a script containing call handling instructions.
- the user of device 100 may compose, or use another application to compose, a script 1 12, which comprises a set of instructions for call handling on a called device.
- the script 1 12 may, according to an exemplary embodiment, be stored on script server 1 10.
- the script 1 12 may be accessed from storage within the carrier network 106.
- the script 1 12 may be embedded into the call parameter information 104 directly based on the size of the script 1 12.
- the call parameter information 104 may be directly embedded in the SDP content of a SIP message instead of linking to an external URL.
- the script 1 12 comprises a set of instructions to be executed by the device 108.
- the device 108 further comprises a call handling parser 1 14, which can interpret the script 1 12 and execute the script 1 12.
- the script 1 12 may contain call handling information indicating that if the device 108 is already on a call, the call from the device 100 should be directed to voicemail.
- the script 1 12 may contain call handling information indicating that if the device 108 is already on a call, the user of device 100 can have his call transcribed and texted to the device 108.
- the script 1 12 may comprise instructions to play one or more media items, such as ringtones, video clips, displaying pictures, or the like.
- the script may be composed of JavaScript, or any other well known and suitable scripting language.
- the call parameter information 104 may provide a link to a web page containing a user interface.
- the called party is provided an interactive interface for enabling advanced call termination based on responses from the calling party.
- user interface design tools may be provided to the calling party to customize user interfaces for their called parties.
- the device 108 may be configured to display a user interface through means other than a web page, such as on a VOIP APP.
- the VOIP APP may be configured to parse and execute script 1 12 by displaying an appropriate user interface.
- the interfaces may be customized for particular parties, or based on the status or type of the called device. For example if the called device is a mobile phone, a user interface compatible with a mobile device resolution is provided in the call parameter information 104, and if the called device is a tablet, a more robust and complete interface is provided.
- the calling party may also provide customizable contact buttons such as email buttons, or the like, as a part of the user interface, enabling the called party to communicate with the calling party at their convenience.
- the called party may determine what times they are available to receive a call and program the called device to send a message back to the calling party automatically indicating future call back times
- the call parameter information 104 may be a vehicle for delivering advertisements to the called party or called device.
- the advertising information is provided directly in the call parameter information 104.
- the call parameter information 104 contains a link to a web site containing the advertising, a link to audio/video advertisements, or the like.
- the calling party may embed advertisements into their scripts, i.e., provide callback handling as well as advertisements.
- the advertisements may also be used in the logic contained in the script 1 12, for example, displaying the advertisement if the user is unavailable.
- the called party may determine what times they are available to receive a call and program the called device to send a message back to the calling party automatically indicating future call back times.
- Figure 2 is a depiction of a flow diagram of an instruction set 200 for an exemplary script as described above in accordance with embodiments of the present invention.
- Figure 2 illustrates user programmed logic embedded either into the call parameter information 104, or stored in a script located on a server.
- a URL linking to the script is stored in the call parameter information 104.
- the instruction set 200 begins at step 202 and proceeds to step 204.
- the instruction set 200 determines whether a called device is engaged in another call. If the called device is engaged in another call, the instruction set requests that the called device forward the calling party to voicemail allowing the calling party to leave a message at step 210.
- step 206 it is determined whether the called device has been in motion. If it is determined the called device has been in motion or is in motion, the method proceeds to step 212, where the called device is vibrated, for example, to indicate that a call is incoming. In other instances, any alert or notification can be presented to the user in order to notify the user of an incoming call.
- step 208 the instruction set determines whether the user of the device is playing a game on the device, and if so, performs speech to text on the calling party's message at step 214, and messages the called device.
- step 216 the instruction set 200 terminates the call.
- FIG. 3 is a more detailed depiction of the device 100 as a computer system 300 and the device 108 as a computer system 350 in accordance with at least one embodiment of the present invention.
- the computer system 300 includes a processor 302, various support circuits 306, and memory 304.
- the processor 302 may include one or more microprocessors known in the art.
- the support circuits 306 for the processor 302 include conventional cache, power supplies, clock circuits, data registers, I/O interface 307, and the like.
- the I/O interface 307 may be directly coupled to the memory 304 or coupled through the support circuits 306.
- the I/O interface 307 may also be configured for communication with input devices and/or output devices 368 such as network devices, various storage devices, mouse, keyboard, display, video and audio sensors, IMU and the like.
- the memory 304 stores non-transient processor-executable instructions and/or data that may be executed by and/or used by the processor 302. These processor-executable instructions may comprise firmware, software, and the like, or some combination thereof. Modules having processor-executable instructions that are stored in the memory 304 comprise a VoIP application 310, a parameter module 312, and an interpreter 314.
- the computer 300 may be programmed with one or more operating systems, which may include OS/2, Java Virtual Machine, Linux, SOLARIS, UNIX, HPUX, AIX, WINDOWS, IOS, and ANDROID among other known platforms.
- the computer 350 includes a processor 352, various support circuits 356, and memory 354.
- the processor 352 may include one or more microprocessors known in the art.
- the support circuits 356 for the processor 352 include conventional cache, power supplies, clock circuits, data registers, I/O interface 357, and the like.
- the I/O interface 357 may be directly coupled to the memory 354 or coupled through the support circuits 356.
- the I/O interface 357 may also be configured for communication with input devices and/or output devices 378 such as network devices, various storage devices, mouse, keyboard, display, video and audio sensors, IMU and the like.
- the memory 354, or computer readable medium stores non-transient processor-executable instructions and/or data that may be executed by and/or used by the processor 352. These processor-executable instructions may comprise firmware, software, and the like, or some combination thereof. Modules having processor-executable instructions that are stored in the memory 354 comprise a VoIP application 360, a parameter module 362 and an interpreter 364.
- the computer 350 may be programmed with one or more operating systems, which may include OS/2, Java Virtual Machine, Linux, SOLARIS, UNIX, HPUX, AIX, WINDOWS, IOS, and ANDROID among other known platforms.
- the memory 304 and the memory 354 may include one or more of the following random access memory, read only memory, magneto-resistive read/write memory, optical read/write memory, cache memory, magnetic read/write memory, and the like, as well as signal-bearing media as described below.
- Both computer systems 300 and 350 contain a parameter module and an interpreter.
- the parameter module 312 allows a user of the system 300 to program call back handling information and enter call back parameters, such as ringtone URL, script URL, avatar URL.
- the parameter module 312 couples with the VoIP application 310 to modify an outgoing call configuration message, i.e., call configuration message 102 of Figure 1 .
- the call configuration message will be submitted to the network 106 before placing the call between VoIP application 310 and VoIP application 360.
- the carrier network 106 receives the call configuration message from the VoIP application 310, and, according to one embodiment, forwards the message to the VoIP application 360.
- the computer system 350 then invokes the interpreter 364 to parse the call configuration message to determine whether any parameters for call handling have been added. If the computer system 350 did not have the interpreter 364 installed in memory 360, the VoIP application 360 would ignore the information embedded by the parameter module 312.
- the interpreter 364 is also capable of fetching scripts, audio, video, images and the like from a URL hosted on a script server, such as script server 1 10 shown in Figure 1 , embedded in the call configuration message.
- the interpreter 364 parses a script from the embedded URL, such as the instruction set 200 shown in Figure 2. If the computer system 350 is unable to perform some of the instructions in instruction set 200, for example, modifying the vibration pattern of the system 350, the interpreter 364 ignores those instructions.
- the interpreter 364 interprets the call parameter information and directs the VoIP application 101 to perform the behavioral functionality contained in the call parameter information, for example, call parameter information 104 shown in Figure 1 , given by the user of computer system 300.
- the user of computer system 350 opts to enable call handling from a calling party, and may opt out of call handling altogether.
- the called computer system 350 may specify that the call handling instructions can be executed if a special code is embedded in the instructions, or in the call parameter information, indicating that a trusted party is attempting to perform call handling. Further, the code may be an encrypted key generated according to algorithms well known in the art.
- call handling information can also be sent to landlines, where the calling party and the called party have specially provisioned hardware, such as computer systems 300 and 350, coupled to their landline device, to enable call handling from a called party.
- Figure 4 depicts a flow diagram for a method 400 for call handling in accordance with the embodiment of the present invention as depicted in Figures 1 -3.
- the method 400 is an exemplary implementation of the VoIP application 310 and the parameter module 312 as executed on the computer system 300 shown in Figure 3.
- the method 400 begins at step 402 and proceeds to step 404.
- the parameter module 312 receives a call request for a call from a first device to a second device.
- the call request may comprise call handling information, comprising call parameter information from a user of a first device, i.e., computer system 300.
- the device may be computer software, a mobile device, a VoIP device or the like.
- the parameter module 312 formats the call parameter information.
- the parameter module 312 formats the parameter information using extensible markup language (XML), though those of ordinary skill in the art would recognize that this format is presented as merely an example, and is not limiting.
- the call parameter module 312 may upload the data to a server, and allow the data to be accessed via a URL, which is embedded into the call parameter information.
- the call parameter module 312 inserts the formatted call parameter information into a call configuration message for an outgoing call to a second device, for example computer system 350 executing VoIP Application 360.
- the VoIP application 310 transmits an outgoing call request to the second device, i.e., places a call from the computer system 300 to the computer system 350 using the configuration message, in order to control call handling of the second computer system 350 according to the call parameter information.
- the outgoing call request is based at least in part upon the call handling information. The method terminates at step 410.
- Figure 5 depicts a flow diagram for a method 500 for call handling in accordance with the embodiment of the present invention as depicted in Figures 1 -3.
- the method 500 is an exemplary implementation of the VoIP application 360 and the interpreter 364 as executed on the computer system 350 shown in Figure 3.
- the method 500 begins at step 502 and proceeds to step 504.
- the VoIP application 360 receives a call configuration message comprising call parameter information from a user of a first device, i.e., computer system 300.
- the device may be computer software, a mobile device, a VoIP device or the like.
- call parameter information is extracted from the call configuration message by the VoIP application 360 at step 506. If, at step 508, the VoIP application 360 determines that the computer system/device 350 is not capable of, or has not enabled, call handling instructions from a called party, the method terminates at step 512.
- step 510 the VoIP application 360 forwards the call parameter information to the interpreter 364.
- the interpreter 364 parses the call parameter information, and retrieves scripts and media located by URLS embedded in the call parameter information. At step 510, the interpreter 364 then parses and executes the call handling instructions contained in the scripts when a call is received from computer system 300. The method terminates at step 512.
Landscapes
- Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Multimedia (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Telephonic Communication Services (AREA)
Abstract
A method for call handling comprising receiving, from a first device, an incoming call request directed to a second device, wherein the call request contains call handling information and transmitting an outgoing call request to the second device, wherein the outgoing call request is based at least in part upon the call handling information.
Description
METHOD AND APPARATUS FOR CALL HANDLING SIGNALING
BACKGROUND OF THE INVENTION
Field of the Invention
[0001] Embodiments of the present invention generally relate to a voice over internet protocol (VoIP) service, and more specifically, to a method and apparatus for performing call handling signaling.
Description of the Related Art
[0002] In the current art, a called party can dictate how to respond to a call. For example, the called party can terminate the call if it is from a particular number or if the called party is already on another call. The called party can associate media with their contacts, and have the media play on their device when a particular contact calls. In other instances, the called party can program their device to divert a call to voice mail, or to perform another action if the called party has indicated they are occupied by another task. The called party has control over how a call is handled.
[0003] However, currently the calling party has no way of controlling a call once it is placed to the called device. The calling party has no control over how a call is handled. The called party can only dial a particular telephone number, and the call is handled in accordance with the called party's direction.
[0004] Therefore, there is a need in the art for a method for enabling called party control over call handling using signaling in accordance with exemplary embodiments of the present invention.
SUMMARY OF THE INVENTION
[0005] Embodiments of the present invention relate to a method and apparatus for call handling comprising receiving, from a first device, an incoming call request directed to a second device, wherein the call request contains call handling
information and transmitting an outgoing call request to the second device, wherein the outgoing call request is based at least in part upon the call handling information.
[0006] Further embodiments of the present invention relate to a method and apparatus for incoming call handling comprising receiving, at a called device, a call configuration message, determining call handling information from the call configuration message; and taking an action based upon the call handling information.
BRIEF DESCRIPTION OF THE DRAWINGS
[0007] So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.
[0008] Figure 1 is an illustration depicting interactions between a calling device and a called device in accordance with one or more embodiments of the present invention;
[0009] Figure 2 is a depiction of a flow diagram of an instruction set for an exemplary script as described above in accordance with embodiments of the present invention;
[0010] Figure 3 is a detailed depiction of a first and second computer system in accordance with at least one embodiment of the present invention;
[0011] Figure 4 depicts a flow diagram for a method for call handling in accordance with previous embodiment of the present invention as depicted in Figures 1 -3; and
[0012] Figure 5 depicts a flow diagram for a method for incoming call handling in accordance with previous embodiment of the present invention as depicted in Figures 1 -3.
DETAILED DESCRIPTION
[0013] Embodiments of the present invention generally relate to call handling signaling within a calling network, such as a Voice over Internet Protocol (VoIP) network. According to an exemplary embodiment, a user of a telephony device (calling device) may provide a signal indicating how their calls to any called party, or a particular called party, should be handled by the device in use by the called party. The signaling information input by the user of the calling device may further indicate a set of actions that the called device should execute upon receiving the call.
[0014] Figure 1 is an illustration depicting interactions between a calling device 100 and a called device 108 in accordance with one or more embodiments of the present invention. The device 100 and the device 108 are hosted on the carrier network 106, though according to other embodiments, the two devices may be hosted by two different carrier networks. The device 100 and device 108 may optionally have respective VoIP application (VOIP APP) 101 and VoIP Application 109 stored thereon. The VoIP applications 101 and 109 are managed by the same service provider. Subscribers, i.e., users of device 100 and 108, are able to communicate with other devices via the carrier network 106 by using the VoIP Application 101 and the VoIP Application 109. In order to initiate a call between devices, a call configuration message is generally sent to the carrier network 106. According to an exemplary embodiment, the carrier network 106 is a VoIP network. In other embodiments, however, the carrier network 106 may be a non-VoIP network such as a circuit switched network or the like. Those of ordinary skill in the art would recognize that the present invention may be embodied on devices utilizing any type of network. In a VoIP network, this message oftentimes takes the form of a SIP INVITE message. In other types of networks, other call configuration messages are
submitted to the network such as H.323 (a protocol for providing audio visual communication sessions over packet networks), JINGLE (a protocol for peer to peer session control for multimedia interactions such as VoIP) messages, or the like.
[0015] A user interacts with the device 100 and indicates to the VOIP APP 101 that a call placed from device 100 should be handled in a particular way. That handling information is stored in a call configuration message 102 as call parameter information 104. In some embodiments, the call parameter information 104 may comprise, for example, at least one of ringtone URL 150, avatar URL 151 and script URL 152. The call configuration message 102 is delivered to the carrier network 106, which then forwards the message 102 to the device 108.
[0016] According to this embodiment of the invention, carrier network 106 is unaware of the additional information stored in the call configuration message 102, and the carrier network 106 processes the call configuration message 102 to perform any configuration prior to establishing the call between device 100 and device 108. The device 108 receives the call configuration message 102 comprised of, among other information, call parameter information 104. The device 108 then handles the call according to the call parameter information 104. According to another embodiment, the carrier network 106 can parse the call parameter information 104 from the call configuration message 102 and prompt the device 108 to perform particular functions as indicated by the call parameter information 104.
[0017] According to some embodiments, the call parameter information 104 may contain call handling instructions indicating how the device 108 should handle the call. The call handling instructions may indicate that the device 108 should go to voicemail if the user of device 108 is already engaged in a call, or send a text message to the device 100 that the user of device 108 is engaged in a call. The call parameter information may also contain an embedded caller ID, name of the caller, content from a social media account, instructions to enable device functionality such
as a camera phone, enable remote monitoring or disabling a called device remotely using embedded call instructions, application flags, and other simple data.
[0018] Those of ordinary skill in the art will appreciate that any instructions related to call handling for the device 108 to execute can be inserted into the call parameter information 104. If the device 108 is capable of executing the particular instructions, then the device 108 will execute the instructions according to the call parameter information 104. In some instances, if the device 108 is not capable of executing call handling instructions, the carrier network 106 may return a system message to the device 100 indicating the status of device 108. In yet another embodiment, the call parameter information 104 may contain direct links to one or more media items, and the device 108 automatically parses those links and plays or displays media from those links upon receiving a call from device 108.
[0019] According to other embodiments, the call handling instructions may initiate a "call-hunt", i.e., dialing up to a threshold number of telephone numbers if an initial number does not respond. The call configuration message 102 may be a session initiation protocol (SIP) INFO, UPDATE, NOTIFY or INVITE message, or could be embedded in other types of signaling such as H.323, JINGLE, or the like. Those of ordinary skill in the art would recognize that the call configuration message 102 may take the form of any configuration message passed through a carrier network, and the call parameter information 104 may be embedded in any data/voice packets travelling across the carrier network 106. In the SIP protocol, messages contain a content header, for example, "Content-Type: application/sdp", however content is not limited to session description protocol (SDP) content alone and may be any form of content. According to some embodiments of the present invention, the call parameter information 104 may provide a link to a script containing call handling instructions. The user of device 100 may compose, or use another application to compose, a script 1 12, which comprises a set of instructions for call handling on a called device. The script 1 12 may, according to an exemplary embodiment, be stored on script server 1 10. In another embodiment, the script 1 12 may be
accessed from storage within the carrier network 106. According to yet another embodiment, the script 1 12 may be embedded into the call parameter information 104 directly based on the size of the script 1 12. In some instances, the call parameter information 104 may be directly embedded in the SDP content of a SIP message instead of linking to an external URL.
[0020] The script 1 12 comprises a set of instructions to be executed by the device 108. According to an exemplary embodiment, the device 108 further comprises a call handling parser 1 14, which can interpret the script 1 12 and execute the script 1 12. The script 1 12 may contain call handling information indicating that if the device 108 is already on a call, the call from the device 100 should be directed to voicemail. The script 1 12 may contain call handling information indicating that if the device 108 is already on a call, the user of device 100 can have his call transcribed and texted to the device 108. According to other embodiments, the script 1 12 may comprise instructions to play one or more media items, such as ringtones, video clips, displaying pictures, or the like. In exemplary embodiments, the script may be composed of JavaScript, or any other well known and suitable scripting language.
[0021] According to another embodiment, the call parameter information 104 may provide a link to a web page containing a user interface. The called party is provided an interactive interface for enabling advanced call termination based on responses from the calling party. In this embodiment, user interface design tools may be provided to the calling party to customize user interfaces for their called parties. In other embodiments, the device 108 may be configured to display a user interface through means other than a web page, such as on a VOIP APP. For example, the VOIP APP may be configured to parse and execute script 1 12 by displaying an appropriate user interface.
[0022] In some instances, the interfaces may be customized for particular parties, or based on the status or type of the called device. For example if the called device is a mobile phone, a user interface compatible with a mobile device resolution is
provided in the call parameter information 104, and if the called device is a tablet, a more robust and complete interface is provided. The calling party may also provide customizable contact buttons such as email buttons, or the like, as a part of the user interface, enabling the called party to communicate with the calling party at their convenience. In some instances, the called party may determine what times they are available to receive a call and program the called device to send a message back to the calling party automatically indicating future call back times
[0023] According to other embodiments, the call parameter information 104 may be a vehicle for delivering advertisements to the called party or called device. In one instance, the advertising information is provided directly in the call parameter information 104. In other instances, the call parameter information 104 contains a link to a web site containing the advertising, a link to audio/video advertisements, or the like. According to some embodiments, the calling party may embed advertisements into their scripts, i.e., provide callback handling as well as advertisements. The advertisements may also be used in the logic contained in the script 1 12, for example, displaying the advertisement if the user is unavailable. In some instances, the called party may determine what times they are available to receive a call and program the called device to send a message back to the calling party automatically indicating future call back times.
[0024] Figure 2 is a depiction of a flow diagram of an instruction set 200 for an exemplary script as described above in accordance with embodiments of the present invention. Figure 2 illustrates user programmed logic embedded either into the call parameter information 104, or stored in a script located on a server. A URL linking to the script is stored in the call parameter information 104.
[0025] The instruction set 200 begins at step 202 and proceeds to step 204. At step 204, the instruction set 200 determines whether a called device is engaged in another call. If the called device is engaged in another call, the instruction set
requests that the called device forward the calling party to voicemail allowing the calling party to leave a message at step 210.
[0026] If the instruction set 200 determines that the called device is not engaged in another call, the instruction set 200 proceeds to step 206, where it is determined whether the called device has been in motion. If it is determined the called device has been in motion or is in motion, the method proceeds to step 212, where the called device is vibrated, for example, to indicate that a call is incoming. In other instances, any alert or notification can be presented to the user in order to notify the user of an incoming call.
[0027] If the instruction set 200 determines that the called device is not in motion, the instruction set 200 proceeds to step 208. At step 208, the instruction set determines whether the user of the device is playing a game on the device, and if so, performs speech to text on the calling party's message at step 214, and messages the called device. At step 216, the instruction set 200 terminates the call.
[0028] Figure 3 is a more detailed depiction of the device 100 as a computer system 300 and the device 108 as a computer system 350 in accordance with at least one embodiment of the present invention. The computer system 300 includes a processor 302, various support circuits 306, and memory 304. The processor 302 may include one or more microprocessors known in the art. The support circuits 306 for the processor 302 include conventional cache, power supplies, clock circuits, data registers, I/O interface 307, and the like. The I/O interface 307 may be directly coupled to the memory 304 or coupled through the support circuits 306. The I/O interface 307 may also be configured for communication with input devices and/or output devices 368 such as network devices, various storage devices, mouse, keyboard, display, video and audio sensors, IMU and the like.
[0029] The memory 304, or computer readable medium, stores non-transient processor-executable instructions and/or data that may be executed by and/or used
by the processor 302. These processor-executable instructions may comprise firmware, software, and the like, or some combination thereof. Modules having processor-executable instructions that are stored in the memory 304 comprise a VoIP application 310, a parameter module 312, and an interpreter 314. The computer 300 may be programmed with one or more operating systems, which may include OS/2, Java Virtual Machine, Linux, SOLARIS, UNIX, HPUX, AIX, WINDOWS, IOS, and ANDROID among other known platforms.
[0030] The computer 350 includes a processor 352, various support circuits 356, and memory 354. The processor 352 may include one or more microprocessors known in the art. The support circuits 356 for the processor 352 include conventional cache, power supplies, clock circuits, data registers, I/O interface 357, and the like. The I/O interface 357 may be directly coupled to the memory 354 or coupled through the support circuits 356. The I/O interface 357 may also be configured for communication with input devices and/or output devices 378 such as network devices, various storage devices, mouse, keyboard, display, video and audio sensors, IMU and the like.
[0031] The memory 354, or computer readable medium, stores non-transient processor-executable instructions and/or data that may be executed by and/or used by the processor 352. These processor-executable instructions may comprise firmware, software, and the like, or some combination thereof. Modules having processor-executable instructions that are stored in the memory 354 comprise a VoIP application 360, a parameter module 362 and an interpreter 364. The computer 350 may be programmed with one or more operating systems, which may include OS/2, Java Virtual Machine, Linux, SOLARIS, UNIX, HPUX, AIX, WINDOWS, IOS, and ANDROID among other known platforms.
[0032] The memory 304 and the memory 354 may include one or more of the following random access memory, read only memory, magneto-resistive read/write
memory, optical read/write memory, cache memory, magnetic read/write memory, and the like, as well as signal-bearing media as described below.
[0033] Both computer systems 300 and 350 (i.e., devices 100 and 108, respectively) contain a parameter module and an interpreter. The parameter module 312, for example, allows a user of the system 300 to program call back handling information and enter call back parameters, such as ringtone URL, script URL, avatar URL. Subsequently, when the user of computer system 300 uses the VoIP application 310 to place a call to the VoIP application 360, the parameter module 312 couples with the VoIP application 310 to modify an outgoing call configuration message, i.e., call configuration message 102 of Figure 1 . The call configuration message will be submitted to the network 106 before placing the call between VoIP application 310 and VoIP application 360.
[0034] The carrier network 106 receives the call configuration message from the VoIP application 310, and, according to one embodiment, forwards the message to the VoIP application 360. The computer system 350 then invokes the interpreter 364 to parse the call configuration message to determine whether any parameters for call handling have been added. If the computer system 350 did not have the interpreter 364 installed in memory 360, the VoIP application 360 would ignore the information embedded by the parameter module 312. The interpreter 364 is also capable of fetching scripts, audio, video, images and the like from a URL hosted on a script server, such as script server 1 10 shown in Figure 1 , embedded in the call configuration message. The interpreter 364 parses a script from the embedded URL, such as the instruction set 200 shown in Figure 2. If the computer system 350 is unable to perform some of the instructions in instruction set 200, for example, modifying the vibration pattern of the system 350, the interpreter 364 ignores those instructions.
[0035] Once the computer system 350 accepts a call from computer system 300, the interpreter 364 interprets the call parameter information and directs the VoIP
application 101 to perform the behavioral functionality contained in the call parameter information, for example, call parameter information 104 shown in Figure 1 , given by the user of computer system 300. According to some embodiments, the user of computer system 350 opts to enable call handling from a calling party, and may opt out of call handling altogether. In some instances, the called computer system 350 may specify that the call handling instructions can be executed if a special code is embedded in the instructions, or in the call parameter information, indicating that a trusted party is attempting to perform call handling. Further, the code may be an encrypted key generated according to algorithms well known in the art.
[0036] Those of ordinary skill will recognize that call handling information can also be sent to landlines, where the calling party and the called party have specially provisioned hardware, such as computer systems 300 and 350, coupled to their landline device, to enable call handling from a called party.
[0037] Figure 4 depicts a flow diagram for a method 400 for call handling in accordance with the embodiment of the present invention as depicted in Figures 1 -3. The method 400 is an exemplary implementation of the VoIP application 310 and the parameter module 312 as executed on the computer system 300 shown in Figure 3.
[0038] The method 400 begins at step 402 and proceeds to step 404. At step 404, the parameter module 312 receives a call request for a call from a first device to a second device. The call request may comprise call handling information, comprising call parameter information from a user of a first device, i.e., computer system 300. The device may be computer software, a mobile device, a VoIP device or the like.
[0039] Once the call parameter information has been received, the parameter module 312 formats the call parameter information. For example, the parameter
module 312 formats the parameter information using extensible markup language (XML), though those of ordinary skill in the art would recognize that this format is presented as merely an example, and is not limiting. Additionally, if the call parameter information includes audio or visual data, the call parameter module 312 may upload the data to a server, and allow the data to be accessed via a URL, which is embedded into the call parameter information.
[0040] At step 406, the call parameter module 312 inserts the formatted call parameter information into a call configuration message for an outgoing call to a second device, for example computer system 350 executing VoIP Application 360.
[0041] At step 408, the VoIP application 310 transmits an outgoing call request to the second device, i.e., places a call from the computer system 300 to the computer system 350 using the configuration message, in order to control call handling of the second computer system 350 according to the call parameter information. The outgoing call request is based at least in part upon the call handling information. The method terminates at step 410.
[0042] Figure 5 depicts a flow diagram for a method 500 for call handling in accordance with the embodiment of the present invention as depicted in Figures 1 -3. The method 500 is an exemplary implementation of the VoIP application 360 and the interpreter 364 as executed on the computer system 350 shown in Figure 3.
[0043] The method 500 begins at step 502 and proceeds to step 504. At step 504, the VoIP application 360 receives a call configuration message comprising call parameter information from a user of a first device, i.e., computer system 300. The device may be computer software, a mobile device, a VoIP device or the like.
[0044] Once the call configuration message is received, call parameter information is extracted from the call configuration message by the VoIP application 360 at step 506. If, at step 508, the VoIP application 360 determines that the
computer system/device 350 is not capable of, or has not enabled, call handling instructions from a called party, the method terminates at step 512.
[0045] If the computer system 350 is capable of receiving and executing the call instructions in the call parameter information, the method proceeds to step 510. At step 510, the VoIP application 360 forwards the call parameter information to the interpreter 364.
[0046] The interpreter 364 parses the call parameter information, and retrieves scripts and media located by URLS embedded in the call parameter information. At step 510, the interpreter 364 then parses and executes the call handling instructions contained in the scripts when a call is received from computer system 300. The method terminates at step 512.
[0047] While the foregoing is directed to embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.
Claims
1 . A method for call handling comprising:
receiving, from a first device, an incoming call request directed to a second device, wherein the call request contains call handling information; and
transmitting an outgoing call request to the second device, wherein the outgoing call request is based at least in part upon the call handling information.
2. The method of claim 1 further comprising:
embedding a user specified uniform resource locator (URL) into the outgoing call request.
3. The method of claim 2 wherein the URL links to a script comprising a set of programmatic statements for execution on the second device.
4. The method of claim 3, further comprising:
embedding a media URL into the script for playing on the second device.
5. The method of claim 4, wherein the media comprises at least one of a text file, an audio file, a video file, or an image.
6. The method of claim 3, further comprising:
embedding conditional logic into the script.
7. The method of claim 6 wherein the conditional logic comprises:
determining whether the second device is in a particular state, and if the second device is in the particular state, performing an action according to the script.
8. The method of claim 7, wherein the particular state comprises at least one of: the second device is engaged on another call, the second device is configured to be silent and the second device is engaged in an application.
9. The method of claim 8, wherein the action comprises at least one of:
sending a textual message to the second device;
sending a notification to the calling device at the termination of a currently engaged call; and
requesting the second device to forward the calling device to voicemail.
10. The method of claim 1 wherein the call handling information is embedded into a content portion of a signaling protocol message.
1 1 . The method of claim 10, wherein the call handling information may comprise a uniform resource locator to media content, the media content comprising at least one of a text file, an audio file, a video file, or an image.
12. The method of claim 10, further comprising:
embedding conditional logic into the script.
13. The method of claim 12 wherein the conditional logic comprises:
determining whether the second device is in a particular state, and if the second device is in the particular state, performing an action according to the script.
14. The method of claim 13, wherein the particular state comprises at least one of: the second device is engaged on another call, the second device is configured to be silent and the second device is engaged in an application.
15. The method of claim 14, wherein the action comprises at least one of:
sending a textual message to the second device;
sending a notification to the calling device at the termination of a currently engaged call; and
requesting the second device to forward the calling device to voicemail.
16. An apparatus for outgoing call handling comprising:
a parameter module, executed by a processor, for receiving from a first device an incoming call request directed to a second device, wherein the call request comprises call handling information; and
a voice over internet protocol (VoIP) application, executed by the processor, for transmitting an outgoing call request to the second device, wherein the outgoing call request is based at least in part upon the call handing information.
17. A method for incoming call handling comprising:
receiving, at a called device, a call configuration message;
determining call handling information from the call configuration message; and
taking an action based upon the call handling information.
18. The method of claim 17, where prior to taking the action:
a URL is determined from the call handling information linking to a script comprising call instructions.
19. The method of claim 18, further comprising:
executing the script on the called device.
20. The method of claim 19, further comprising:
wherein the script contains conditional logic to configure actions of the second device.
21 . The method of claim 20 wherein the conditional logic comprises:
determining whether the second device is in a particular state, and if the second device is in the particular state, performing an action according to the script.
22. The method of claim 21 , wherein the particular state comprises at least one of: the called device is engaged on another call, the called device is configured to be silent and the called device is engaged in an application.
23. The method of claim 22, wherein the action comprises at least one of:
sending a textual message to the first device;
sending a notification to the calling device at the termination of a currently engaged call; and
requesting the second device to forward the calling device to voicemail;
24. The method of claim 23, wherein the call handling information is embedded into a content portion of a signaling protocol message.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP14803872.2A EP3005667A4 (en) | 2013-05-31 | 2014-05-29 | Method and apparatus for call handling signaling |
CA2913415A CA2913415A1 (en) | 2013-05-31 | 2014-05-29 | Method and apparatus for call handling signaling |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/907,340 US20140355486A1 (en) | 2013-05-31 | 2013-05-31 | Method and apparatus for call handling signaling |
US13/907,340 | 2013-05-31 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2014194039A1 true WO2014194039A1 (en) | 2014-12-04 |
Family
ID=51985008
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2014/039935 WO2014194039A1 (en) | 2013-05-31 | 2014-05-29 | Method and apparatus for call handling signaling |
Country Status (4)
Country | Link |
---|---|
US (1) | US20140355486A1 (en) |
EP (1) | EP3005667A4 (en) |
CA (1) | CA2913415A1 (en) |
WO (1) | WO2014194039A1 (en) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5274700A (en) * | 1989-11-27 | 1993-12-28 | Unifi Communications Corporation | Methods of automatically rerouting an incoming telephone call placed over a network |
US5299260A (en) * | 1990-11-20 | 1994-03-29 | Unifi Communications Corporation | Telephone call handling system |
US5574782A (en) * | 1995-04-14 | 1996-11-12 | Lucent Technologies Inc. | Minimizing service disruptions in handling call request messages where new message formats are needed in a telecommunication network |
KR20040071969A (en) * | 2003-02-07 | 2004-08-16 | 에스케이 텔레콤주식회사 | Mobile Communication Terminal Capable of Swiching Ring Mode and Method thereof |
KR101113873B1 (en) * | 2005-11-10 | 2012-02-29 | 엘지전자 주식회사 | Method for displaying agent, mobile terminal thereof |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6278771B1 (en) * | 1998-03-19 | 2001-08-21 | Ameritech Corporation | Method and system for providing enhanced call waiting with verification and name change service |
US6446109B2 (en) * | 1998-06-29 | 2002-09-03 | Sun Microsystems, Inc. | Application computing environment |
US20070047523A1 (en) * | 2001-08-16 | 2007-03-01 | Roamware, Inc. | Method and system for call-setup triggered push content |
US7248677B2 (en) * | 2000-08-22 | 2007-07-24 | Symbian Software Ltd. | Method of and apparatus for communicating user related information using a wireless information device |
US20050143103A1 (en) * | 2003-12-31 | 2005-06-30 | France Telecom, S.A | System, method, device, and computer program product for a sender to send a personalized notification to a recipient of a communication |
EP1696645A1 (en) * | 2005-02-25 | 2006-08-30 | Sony Ericsson Mobile Communications AB | Caller information provision |
-
2013
- 2013-05-31 US US13/907,340 patent/US20140355486A1/en not_active Abandoned
-
2014
- 2014-05-29 WO PCT/US2014/039935 patent/WO2014194039A1/en active Application Filing
- 2014-05-29 EP EP14803872.2A patent/EP3005667A4/en not_active Withdrawn
- 2014-05-29 CA CA2913415A patent/CA2913415A1/en not_active Abandoned
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5274700A (en) * | 1989-11-27 | 1993-12-28 | Unifi Communications Corporation | Methods of automatically rerouting an incoming telephone call placed over a network |
US5299260A (en) * | 1990-11-20 | 1994-03-29 | Unifi Communications Corporation | Telephone call handling system |
US5574782A (en) * | 1995-04-14 | 1996-11-12 | Lucent Technologies Inc. | Minimizing service disruptions in handling call request messages where new message formats are needed in a telecommunication network |
KR20040071969A (en) * | 2003-02-07 | 2004-08-16 | 에스케이 텔레콤주식회사 | Mobile Communication Terminal Capable of Swiching Ring Mode and Method thereof |
KR101113873B1 (en) * | 2005-11-10 | 2012-02-29 | 엘지전자 주식회사 | Method for displaying agent, mobile terminal thereof |
Non-Patent Citations (1)
Title |
---|
See also references of EP3005667A4 * |
Also Published As
Publication number | Publication date |
---|---|
CA2913415A1 (en) | 2014-12-04 |
EP3005667A1 (en) | 2016-04-13 |
US20140355486A1 (en) | 2014-12-04 |
EP3005667A4 (en) | 2017-03-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
AU2013278076B2 (en) | Method and apparatus for diverting callers to web sessions | |
EP2656571B1 (en) | Delivery and execution of logic in user terminal in ims session | |
US20150026354A1 (en) | System and method for implementing multimedia calling line identification presentation service | |
US8315377B2 (en) | Method and device for dispatching an alert message in a network | |
KR20160144479A (en) | Displaying video call data | |
US20230353603A1 (en) | Call processing system and call processing method | |
US20110153868A1 (en) | Cloud-Based Application For Low-Provisioned High-Functionality Mobile Station | |
US20230353673A1 (en) | Call processing method, call processing apparatus, and related device | |
EP2874417A1 (en) | Method, apparatus and device for establishing call | |
US20160112473A1 (en) | Method for real-time communication between web browsers | |
JP2009528789A (en) | Network communication session management method and communication transfer notification server | |
CN103179288A (en) | Method and system for displaying call information and device and terminal for pushing call displaying information | |
CN101742007B (en) | Method and system for opening voice conference by utilizing Widget technology | |
AU2012290738B2 (en) | System and method for activating a mobile device to initiate a communication | |
US10951771B2 (en) | Method and apparatus for call handling control | |
WO2015058648A1 (en) | Message service processing method and apparatus based on ip telephone | |
US20080212943A1 (en) | Triggering events for video ringtones | |
US20140355486A1 (en) | Method and apparatus for call handling signaling | |
KR102109609B1 (en) | Terminal Equipment and Call control method for mVoIP, and Call service system based Internet Protocol | |
US20080232351A1 (en) | IP communication system and IP telephone apparatus | |
US20240251034A1 (en) | Method for processing a telephone call in a communication network, method for transmitting, method for receiving such a call, corresponding devices, system and computer programs | |
KR102066753B1 (en) | Method and device of voice absence notification in ip phone service | |
US20190273824A1 (en) | Universal Ring Free | |
CN115335805A (en) | Method, machine and computer program product for dynamically connecting network communication channels | |
WO2011086404A1 (en) | Message display in ims networks |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 14803872 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2913415 Country of ref document: CA |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2014803872 Country of ref document: EP |