|Publication number||US7899033 B2|
|Application number||US 11/509,317|
|Publication date||Mar 1, 2011|
|Filing date||Aug 24, 2006|
|Priority date||Aug 24, 2006|
|Also published as||US8493970, US20080063176, US20110116614|
|Publication number||11509317, 509317, US 7899033 B2, US 7899033B2, US-B2-7899033, US7899033 B2, US7899033B2|
|Inventors||Christopher J. Strieter, Stephen W. Gevers|
|Original Assignee||At&T Intellectual Property I, L.P.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (29), Classifications (14), Legal Events (3)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The present disclosure is generally related to telecommunication services.
Internet Protocol Multimedia Subsystem (IMS) is an emerging standard by 3GPP within the telecommunication industry. IMS can be used by telecommunication service providers to provide Internet Protocol (IP)-based services to their customers.
Disclosed herein are embodiments of methods and systems that control a condition on which an Internet Protocol Multimedia Subsystem (IMS) service is invoked for an incoming call. The conditional invocation of the IMS service is based on an evaluation of a plurality of values prior to receiving the incoming call. In an embodiment, prior to receiving the incoming call, the plurality of values are pushed to an event notification system using a subscribe/notify process, and the event notification system determines a value, such as a Boolean value, based on the plurality of values. The plurality of values can be based on any number of factors, and the Boolean value can be based on any arbitrarily-complex Boolean expression or function of the values. The factors may comprise persisted data.
Outside of any call flow, the event notification system uses a subscribe/notify process to notify an entity of the Boolean value and any updates thereto. The entity, such as a telephone network element, subscribes to the event notification system and controls the conditional invocation of the IMS service based on the Boolean value. When one or more of the factors change, one or more new values are pushed to the event notification system using the subscribe/notify process. The event notification system, in turn, recalculates the Boolean value based on the one or more new values. If a different Boolean value results from the recalculation, the event notification system pushes the new Boolean value to the telephone network element. When an incoming call is received, the telephone network element uses a most-recently-pushed Boolean value to determine whether or not to invoke the IMS service for the incoming call. The IMS service resides on a call path associated with the incoming call, e.g. a call path between a caller and a callee, and influences a call flow based on the most-recently-pushed Boolean value. In an embodiment, the subscribe/notify process is based on a subscribe/notify model as defined in RFC 3265.
By limiting a number of service invocations and by determining a value that indicates whether or not to invoke the IMS-based service before receiving an incoming call, embodiments can produce increased efficiency in call flow logic. Embodiments further reduce a latency of calls and increase a call capacity. Embodiments can be used by telecommunication companies to design and implement various IMS-based services.
Embodiments are described with reference to
As indicated by block 12, the method comprises registering a telecommunication device 14 of a party 16. The telecommunication device 14 may comprise a telephone, for example. The telecommunication device 14 is registered using a telecommunication network element 20 that provides a telephone service thereto. The telecommunication device 14 may be registered in response to being powered on.
As indicated by block 22, the method comprises subscribing the telephone network element 20 to an event notification system 24 to receive information associated with the party 16, and to subsequently receive updates to the information associated with the party 16. The telephone network element 20 subscribes for the information associated with the party 16 by sending a subscribe message 26 to the event notification system 24. In an embodiment, the event notification system 24 acts as an expression handler and provides an availability service that provides availability information associated with the party 16.
As indicated by block 30, the method comprises subscribing the event notification system 24 to a plurality of services to receive information associated with the party 16, and to subsequently receive updates to the information associated with the party. The event notification system 24 subscribes for the information associated with the party 16 by sending a respective subscribe message to each of the plurality of services. For purposes of illustration and example, the event notification system 24 is shown in
Optionally, as indicated by block 48, the method may comprise determining which services may generate events associated with the party 16, and determining which events generated via those services that the event notification service is to subscribe. The event notification system 24 may access a database 50 of subscriber data to determine which events/services are to be subscribed for the party 16. In an embodiment, the database 50 either comprises or is similar to a home subscription server (HSS) database. Alternative data stores of subscriber data are also contemplated for the database 50.
As indicated by block 52, the method comprises pushing a plurality of values associated with the party 16 from the plurality of services to the event notification system 24. The plurality of values may be pushed in a plurality of notify messages. For purposes of illustration and example, the service 32 pushes a value 54 in a notify message 56, the service 34 pushes a value 60 in a notify message 62, and the service 36 pushes a value 64 in a notify message 66. The event notification system 24 receives the values 54, 60 and 64 and stores these as pushed values 54′, 60′ and 64′.
In an embodiment, the services 32, 34 and 36 initially send the notify messages 56, 62 and 66 in response to the subscribe messages 42, 44 and 46, respectively, regardless of whether or not any state changes associated with the party 16 have occurred. Thereafter, as subsequently described with reference to block 80, subsequent notify messages are sent by the services 32, 34 and 36 only as state changes occur.
In an embodiment, the values 54 and 60 provide busy/not-busy indications for the party 16. For example, the value 54 may indicate if the party 16 is busy or not-busy based on a do-not-disturb feature for his/her telecommunication device 14. The value 60 may indicate if the party 16 is busy or not-busy based on any events scheduled in his/her calendar for a current time and date. The value 64 may provide an override used to override an otherwise busy or not-busy indication.
As indicated by block 66, the method comprises determining, by the event notification system 24, a value 70 associated with the party 16 based on the plurality of pushed values associated with the party 16. The value 70 is determined as a function 72 of the pushed values, e.g. a function of the pushed values 54′, 60′ and 64′. The function 72 may comprise a Boolean function of the pushed values, and the value 70 may comprise a Boolean value. In an embodiment, the value 70 indicates whether the party 16 is available or unavailable to receive incoming calls based on one or more busy/not-busy indicators and an override indicator.
As indicated by block 74, the method comprises pushing the value 70 from the event notification system 24 to the telephone network element 20. The value 70 may be pushed in a notify message 76. The telephone network element 20 receives the value 70 and stores this as a pushed value 70′.
If a state change occurs in any of the values 54, 60 or 64, the respective service 32, 34 or 36 that provides the value automatically pushes a new value associated with the party 16 to the event notification system 24. For example, responsive to a state change in the value 64, the service 34 automatically pushes a new value to the event notification system 24 in a subsequent notify message. This potential act of pushing at least one new value associated with the party 16 from at least one of the services to the event notification system 24 in at least one notify message is indicated by block 80. The event notification system 24 determines if the at least one new value pushed thereto, when applied to the function 72, causes a change in the value 70. This potential act of determining, by the event notification system 24, a change in the value 70 associated with the party 16 based on the at least one new value associated with the party 16 is indicated by block 82. As indicated by block 84, if the value 70 has changed, the changed value 70 is automatically pushed from the event notification system 24 to the telephone network element 20 in a notify message. The telephone network element receives the changed value 70 and stores same as the pushed value 70′.
As indicated by block 90, the method comprises receiving, by the telephone network element 20, an incoming call 92 for the party 16.
As indicated by block 94, the method comprises processing the incoming call 92, by the telephone network element 20, using a call flow based on the pushed value 70′. Again, the pushed value 70′ is associated with the party 16 and was pushed to the telephone network element 20 by the event notification system 24 prior to receiving the incoming call 92. The act of processing the incoming call 92 may comprise determining whether or not to invoke the IMS service 10 based on the pushed value 70′. If invoked, the IMS service 10 resides on a call path and influences a call flow associated with the incoming call 92. Based on the pushed value 70′, a decision element 96 determines whether or not to invoke the IMS service 10 for the incoming call 92.
In an embodiment, the decision element 96 invokes the IMS service 10 if the pushed value 70′ indicates that the party 16 is unavailable, and does not invoke the IMS service 10 if the pushed value 70′ indicates that the party 16 is available. This embodiment is of interest, for example, when the IMS service 10 comprises a white list service that enables a caller that is on a white list of the party 16 to have his/her call sent to the telecommunication device 14 of the party 16 even if the party 16 is deemed unavailable based on the pushed value 70′. If the party 16 is deemed unavailable based on the pushed value 70′ and if the caller is not on the white list of the party 16, the call is inhibited from being sent to the telecommunication device 14 of the party 16.
The method can flow back to block 90, wherein a subsequent incoming call is received for the party 16, or to block 80, wherein at least one new value from at least one of the services is pushed to the event notification system 24.
If the black list service 102 has not blocked the incoming call 92, a decision element 96 conditionally invokes the white list service 100 when the party 16 is reported as being “busy” based on the pushed value 70′. The pushed value 70′ indicates that the party 16 is busy if a most-recently pushed value from the do-not-disturb service 32 indicates that the party 16 is busy or if a most-recently pushed value from the calendar service 34 indicates that the party 16 is busy, and if a most-recently pushed value from the service 36 is not an override value. Therefore, prior to receiving the incoming call 92, a decision has effectively been made within the telephone network element 20 on whether or not to invoke the white list service 100. The telephone network element 20 may comprise a Service Capability Interactive Manager (SCIM), a Serving Call Session Control Function (S-CSCF), an HSS, or any combination thereof for example.
If invoked, the white list service 100 blocks the incoming call 92 if the caller is not on the white list of the party 16 and the party 16 is currently busy, and forwards the incoming call 92 to the party 16 if the caller is on the white list of the party 16. Optionally, the incoming call is processed by an element 106 which determines if caller identification is active. If the caller identification is active, a caller identification service 110 is accessed. The party 16 or another user can use a computer 112 to communicate with the caller identification service 110 via an interface 114. An example of the interface 114 is one by Leapstone Systems, Inc.
The party 16 or another user can use the computer 112 to communicate with the service 36 to change his/her override setting as represented by the value 64. The service 36 may enable the party 16 or other user to toggle either from do-not-override to override, or from override to do-not-override. Once the value 64 has been changed, the service 36 pushes the value 64 to the event notification system 24. The event notification system 24, in turn, receives and stores the value 64 as the pushed value 64′. The event notification system 24 may comprise a toggle cache 116 to cache the pushed value 64′. The event notification system 24 determines if an expression to answer the question “do we invoke the white list service?”, as represented by the function 72, has produced a new result based on the new data pushed thereto. If so, the event notification system 24 pushes the new result to the telephone network element 20, which is stored as the pushed value 70′. Thus, the telephone network element 20 automatically receives updated data (which may change periodically or otherwise from time-to-time) without having to request it.
If an S-CSCF is incapable of receiving notification messages, the event notification system can send the notifications messages to an HSS. The HSS, in turn, may be accessed by the S-CSCF to determine whether or not a service is conditionally invoked.
Embodiments of the method and system for conditionally invoking an IMS service may be used in various services either in addition to or as an alternative to the white list service. For example, a service may be constructed that limits an amount of time (e.g. a number of minutes) that a party (e.g. a teenager) can use (e.g. talk on) the phone over a specific time period. Once the amount of time associated with the party has reached a threshold, the service may limit the party to a predetermined set of numbers to which he/she can place outgoing calls. The predetermined set of numbers may comprise an emergency number (e.g. 911), a home phone number, and one or more parents' cell phone numbers. The event notification system 24 may determine a Boolean value based on the amount of time used by the party in the specific time period, and push the Boolean value to a controlling entity that conditionally invokes the service based on the Boolean value. Another service may use the same information, but limit the party to calling at particular times of the day.
In general, any of the herein-disclosed pushed values associated with a party may be associated with a particular telephone number of the party, and/or associated with a particular name of the party, and/or associated with a particular person wherein the party comprises the particular person.
In a networked deployment, the computer system may operate in the capacity of a server or as a client user computer in a server-client user network environment, or as a peer computer system in a peer-to-peer (or distributed) network environment. The computer system 400 can also be implemented as or incorporated into various devices, such as a personal computer (PC), a tablet PC, a set-top box (STB), a personal digital assistant (PDA), a mobile device, a palmtop computer, a laptop computer, a desktop computer, a communications device, a wireless telephone, a land-line telephone, a control system, a camera, a scanner, a facsimile machine, a printer, a pager, a personal trusted device, a web appliance, a network router, switch or bridge, or any other machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. In a particular embodiment, the computer system 400 can be implemented using electronic devices that provide voice, video or data communication. Further, while a single computer system 400 is illustrated, the term “system” shall also be taken to include any collection of systems or sub-systems that individually or jointly execute a set, or multiple sets, of instructions to perform one or more computer functions.
As illustrated in
In a particular embodiment, as depicted in
In an alternative embodiment, dedicated hardware implementations, such as application specific integrated circuits, programmable logic arrays and other hardware devices, can be constructed to implement one or more of the methods described herein. Applications that may include the apparatus and systems of various embodiments can broadly include a variety of electronic and computer systems. One or more embodiments described herein may implement functions using two or more specific interconnected hardware modules or devices with related control and data signals that can be communicated between and through the modules, or as portions of an application-specific integrated circuit. Accordingly, the present system encompasses software, firmware, and hardware implementations.
In accordance with various embodiments of the present disclosure, the methods described herein may be implemented by software programs executable by a computer system. Further, in an exemplary, non-limited embodiment, implementations can include distributed processing, component/object distributed processing, and parallel processing. Alternatively, virtual computer system processing can be constructed to implement one or more of the methods or functionality as described herein.
The present disclosure contemplates a computer-readable medium that includes instructions 424 or receives and executes instructions 424 responsive to a propagated signal, so that a device connected to a network 426 can communicate voice, video or data over the network 426. Further, the instructions 424 may be transmitted or received over the network 426 via the network interface device 420.
While the computer-readable medium is shown to be a single medium, the term “computer-readable medium” includes a single medium or multiple media, such as a centralized or distributed database, and/or associated caches and servers that store one or more sets of instructions. The term “computer-readable medium” shall also include any medium that is capable of storing, encoding or carrying a set of instructions for execution by a processor or that cause a computer system to perform any one or more of the methods or operations disclosed herein.
In a particular non-limiting, exemplary embodiment, the computer-readable medium can include a solid-state memory such as a memory card or other package that houses one or more non-volatile read-only memories. Further, the computer-readable medium can be a random access memory or other volatile re-writable memory. Additionally, the computer-readable medium can include a magneto-optical or optical medium, such as a disk or tapes or other storage device to capture carrier wave signals such as a signal communicated over a transmission medium. A digital file attachment to an e-mail or other self-contained information archive or set of archives may be considered a distribution medium that is equivalent to a tangible storage medium. Accordingly, the disclosure is considered to include any one or more of a computer-readable medium or a distribution medium and other equivalents and successor media, in which data or instructions may be stored.
Although the present specification describes components and functions that may be implemented in particular embodiments with reference to particular standards and protocols, the invention is not limited to such standards and protocols. For example, standards for Internet and other packet switched network transmission (e.g., TCP/IP, UDP/IP, HTML, HTTP) represent examples of the state of the art. Such standards are periodically superseded by faster or more efficient equivalents having essentially the same functions. Accordingly, replacement standards and protocols having the same or similar functions as those disclosed herein are considered equivalents thereof.
The illustrations of the embodiments described herein are intended to provide a general understanding of the structure of the various embodiments. The illustrations are not intended to serve as a complete description of all of the elements and features of apparatus and systems that utilize the structures or methods described herein. Many other embodiments may be apparent to those of skill in the art upon reviewing the disclosure. Other embodiments may be utilized and derived from the disclosure, such that structural and logical substitutions and changes may be made without departing from the scope of the disclosure. Additionally, the illustrations are merely representational and may not be drawn to scale. Certain proportions within the illustrations may be exaggerated, while other proportions may be minimized. Accordingly, the disclosure and the figures are to be regarded as illustrative rather than restrictive.
One or more embodiments of the disclosure may be referred to herein, individually and/or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any particular invention or inventive concept. Moreover, although specific embodiments have been illustrated and described herein, it should be appreciated that any subsequent arrangement designed to achieve the same or similar purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all subsequent adaptations or variations of various embodiments. Combinations of the above embodiments, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the description.
The Abstract of the Disclosure is provided to comply with 37 C.F.R. §1.72(b) and is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, various features may be grouped together or described in a single embodiment for the purpose of streamlining the disclosure. This disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter may be directed to less than all of the features of any of the disclosed embodiments. Thus, the following claims are incorporated into the Detailed Description, with each claim standing on its own as defining separately claimed subject matter.
The above disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments which fall within the true spirit and scope of the present invention. Thus, to the maximum extent allowed by law, the scope of the present invention is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5734977||Nov 10, 1994||Mar 31, 1998||Telefonaktiebolaget Lm Ericsson||Fraud detection in radio communications network|
|US5920820||Jan 25, 1996||Jul 6, 1999||Telefonaktiebolaget Lm Ericsson (Publ)||Combined home location register and service control point for a cellular telecommunications network|
|US6097945||Jan 29, 1999||Aug 1, 2000||Telefonaktiebolaget Lm Ericsson||Handling of time zones in a telecommunication system|
|US6134316||Oct 18, 1996||Oct 17, 2000||Telefonaktiebolaget Lm Ericsson||Telecommunications network with relocateability of subscriber number|
|US6603973 *||Aug 15, 1997||Aug 5, 2003||At&T Corp.||Call redirection system|
|US6693897||Nov 10, 2000||Feb 17, 2004||Sbc Technology Resources, Inc.||Method and system of screening and control of telephone calls while using a packet-switched data network|
|US6822954||Aug 2, 2001||Nov 23, 2004||Openwave Systems (Roi) Limited||Telecommunications gateway|
|US6999577||Oct 1, 2003||Feb 14, 2006||America Online, Inc.||Multi-user call waiting|
|US7664237 *||Sep 26, 2005||Feb 16, 2010||At&T Corp.||Method and apparatus for providing emergency ring tones for urgent calls|
|US20030061365||Oct 22, 2001||Mar 27, 2003||Microsoft Corporation||Service-to-service communication for network services|
|US20030095540 *||Nov 20, 2001||May 22, 2003||Nokia Corporation||Web services push gateway|
|US20030131073||Oct 22, 2001||Jul 10, 2003||Lucovsky Mark H.||Schema-based services for identity-based data access|
|US20040006623 *||Jul 5, 2002||Jan 8, 2004||Telefonaktiebolaget L M Ericsson (Publ)||Service providing mechanism|
|US20040194116||Mar 25, 2004||Sep 30, 2004||Mckee Timothy P.||System and method for public consumption of communication events between arbitrary processes|
|US20040218585||Dec 15, 2003||Nov 4, 2004||Sbc Technology Resources, Inc.||Method and system of screening and control of telephone calls while using a packet-switched data network|
|US20040236836||Jun 10, 2004||Nov 25, 2004||Barry Appelman||Recipient control of source audio identifiers for digital communications|
|US20040254998||Jun 30, 2004||Dec 16, 2004||Microsoft Corporation||When-free messaging|
|US20050018833||Oct 1, 2003||Jan 27, 2005||Wang Myles Thomas||Multi-user call waiting|
|US20050021540||Apr 30, 2004||Jan 27, 2005||Microsoft Corporation||System and method for a rules based engine|
|US20050059384||Sep 8, 2004||Mar 17, 2005||Nokia Corporation||Method and device for handling missed calls in a mobile communications environment|
|US20050074107||Jul 21, 2004||Apr 7, 2005||Renner W. Karl||Conference calls via an intelligent call waiting interface|
|US20050100145||Sep 14, 2004||May 12, 2005||Spencer Bradford L.||Multi-user intelligent call screening|
|US20050123118 *||Sep 29, 2004||Jun 9, 2005||Terry George A.||Dynamic call response system|
|US20050170861||Jun 4, 2003||Aug 4, 2005||Aki Niemi||Method and system to subscription of events using sip protocol|
|US20060077956||Oct 8, 2004||Apr 13, 2006||Saksena Vikram R||Common telephony services to multiple devices associated with multiple networks|
|US20060077957||Oct 8, 2004||Apr 13, 2006||Umamaheswar Reddy||Call handoff between subscriber's multiple devices associated with multiple networks|
|US20060095524||Oct 7, 2005||May 4, 2006||Kay Erik A||System, method, and computer program product for filtering messages|
|US20060104306||Nov 15, 2004||May 18, 2006||Maria Adamczyk||Application services infrastructure for next generation networks|
|US20060288099 *||May 8, 2006||Dec 21, 2006||Iotum Corporation, A Delaware Corporation||Method of and System for Presence Management in Telecommunications|
|U.S. Classification||370/352, 709/224, 455/461, 379/211.02, 455/458, 709/227, 379/211.01, 455/445, 370/401, 370/466|
|Cooperative Classification||H04M3/436, H04M3/42374|
|Nov 8, 2006||AS||Assignment|
Owner name: SBC KNOWLEDGE VENTURES, LP, NEVADA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:STRIETER, CHRISTOPHER J.;GEVERS, STEPHEN W.;REEL/FRAME:018501/0550
Effective date: 20061102
|Mar 25, 2013||AS||Assignment|
Owner name: AT&T INTELLECTUAL PROPERTY I, L.P., GEORGIA
Free format text: CHANGE OF NAME;ASSIGNOR:SBC KNOWLEDGE VENTURES, L.P.;REEL/FRAME:030075/0380
Effective date: 20071002
|Aug 25, 2014||FPAY||Fee payment|
Year of fee payment: 4