An embodiment of the system for publishing events of a telephony application to a client includes a call router that generates events from the telephony application and an event router that manages the publication of events generated by the call router and that manages the subscription to events by clients. The system can be used with a telephony application that interfaces with a telephony device and an application server.
|
1. A system comprising:
a call router constructed to:
manage a plurality of telephony applications provided by a plurality of internet application servers external to the system, wherein each telephony application controls interaction between a telephony device and a respective internet application server,
generate an event from at least one of the plurality of telephony applications during the management of the at least one telephony application, and
publish each generated event to an event router; and
the event router, the event router being constructed to:
responsive to publishing of an event by the call router, identify at least one subscriber to the published event, and send the published event from the event router to the at least one subscriber,
wherein the system is a multi-tenant telephony web event system.
9. A method comprising:
at a call router of a multi-tenant telephony web event system that includes the call router and an event router:
managing a plurality of telephony applications provided by a plurality of internet application servers external to the multi-tenant web event system, wherein each telephony application controls interaction between a telephony device and a respective internet application server,
generating an event from at least one of the plurality of telephony applications during the management of the at least one telephony application, and
publishing each generated event to the event router;
at the event router:
responsive to publishing of an event by the call router, identifying at least one subscriber to the published event, and sending the published event from the event router to the at least one subscriber.
19. A method comprising:
at an event router of a multi-tenant telephony web event system that includes the event router and a call router:
receiving a request to subscribe to an event publication from a subscriber,
verifying the subscriber is authorized to subscribe to the event publication, and
subscribing the subscriber to the event publication, the event publication being published by the event router,
wherein the event router manages subscriptions of a plurality of telephony applications provided by a plurality of internet application servers external to the multi-tenant web event system, each telephony application controlling interaction between a telephony device and a respective internet application server; and
at the call router:
managing the plurality of telephony applications,
generating an event from at least one of the plurality of telephony applications during the management of the at least one telephony application, and
publishing each generated event to the event router, wherein each generated event returned to the subscriber via the event router is returned to the subscriber through an event connection.
2. The system of
3. The system of
4. The system of
5. The system of
wherein the event router comprises an event proxy system comprising a set of event proxy servers,
wherein each event proxy server of the set of event proxy servers subscribes to the events of the event router and manages subscriptions to events by remote clients by pushing events to subscribed remote clients through an open HTTP connection, and
wherein the event proxy servers comprise event filters that selectively permit pushing of events to a client according to an event attribute.
6. The system of
wherein the event router includes a plurality of message brokers that manage the publication of events for the event router, and
wherein the event proxy servers connect to a message broker to subscribe to an event.
8. The system of
10. The method of
11. The method of
12. The method of
13. The method of
14. The method of
15. The method of
16. The method of
17. The method of
18. The method of
20. The method of
21. The method of
22. The method of
23. The method of
|
This application is a continuation of co-pending U.S. patent application Ser. No. 12/572,258, filed 1 Oct. 2009, which claims the benefit of U.S. Provisional Application No. 61/102,007 filed on 1 Oct. 2008, both of which are hereby incorporated in their entirety by this reference.
This invention relates generally to the event notification field, and more specifically to an new and useful system and method in the telephony web event field.
In recent years, there has been a growing trend of both internet-enabled phones and “websites as software”. These two markets thrive on the transfer of information, instantaneous communication, and interaction between remote devices. However, current systems do not provide a seamless integration of telephony actions with remotely hosted applications, with server-side components, or with front-end websites. For instance, it is currently extremely difficult (if not impossible) to relay events that happen during a telephony call to or from a website securely in real-time during the telephony call. In addition, separation of business logic from telephony components complicates the transfer of realtime events from the call infrastructure to other remote services. Thus, there is a need in the telephony field to create a new and useful telephony web event system and method. This invention provides such a new and useful system and method.
The following description of the preferred embodiments of the invention is not intended to limit the invention to these preferred embodiments, but rather to enable any person skilled in the art to make and use this invention.
1. Telephony Web Event System
As shown in
The call router 110 of the preferred embodiment functions to initiate the publication of events occurring during a telephony application. The telephony application is preferably a program controlling the interaction between a telephony based device 112 and an internet based web application server 114. The call router 110 preferably controls the call and program logic that enables telephony devices 112 to interface with the application server 114, as discussed in more detail below. The call router 110 preferably detects events occurring from the telephony application 114 and publishes these events to the event router 120. The call router may additionally include an event distributor 116 that determines to which event router to deliver the event. In one variation, the event router 120 includes a plurality of message brokers 128 that manage the publication of events. The message brokers 128 may be sharded or arranged according to event type or any suitable arrangement. The event distributor 116 preferably has control logic to know the correct message broker 128 to send an event. The control logic is preferably updated or synched with the scaling of hardware or software resources of the event router. As an example, an event may have varying attributes, such as account ID, a call ID, or event type. The message brokers 128 may be sharded based on any of these attributes or any combination of attributes. For example, if there are 3 event routers (shards), then the call router could convert the call ID into an integer and that number modulo 3 to determine which event router to contact. An event proxy server 122 may additionally share this control logic such that the event proxy server 122 knows which message broker(s) 128 to subscribe to. The event proxy server 122 preferably uses a similar technique to determine which event router 120 to contact based on what attributes where subscribed to. Additionally an event may be distributed (published) to multiple message brokers 128, such as in the situation where an event has attributes that are managed by multiple message brokers 128. For example, the event may be published by one message broker 128 that manages publication of events for a particular account and the event may additionally be published by a second message broker 128 that manages publication of events of a particular event type. Additionally, multiple event distributor 116 may be allocated or deallocated. The call router and the event router preferably communicate using HTTP or alternatively HTTPS, though any suitable communication system may be used. The published event preferably includes the account to which the event belongs, the type of event, and optionally a set of event data related to the event.
The call router 110 of the preferred embodiment additionally functions to initiate or receive calls from the telephony device 112 and connect to a web-application server 114. The call router no is substantially similar to the call router disclosed in application Ser. No. 12/417,630 filed on 2 Apr. 2009 and entitled “System and Method for Processing Telephony Sessions” which is hereby incorporated in its entirety by this reference. The call router 110 is preferably connected to a PSTN device over the PSTN network, such that it can receive and make calls from PSTN-connected devices 112, such as landlines, cellular phones, satellite phones, or any other suitable PSTN-connected devices, as well as non-PSTN devices, such as Voice-Over-Internet-Protocol (VOIP) phones, SIP devices, Skype, Gtalk, or other Internet addressable voice devices. The call router no may alternatively or additionally function as or include a message router for use with message-based networks such as SMS, email, faxes, instant messaging, or micro-blogging networks. The call router 110 can preferably connect to an SMS network, such that it can receive and send messages from SMS network devices 112, cellular phones, computers, smart phones, or any suitable SMS network devices. The call router no may also send or receive text messages, multimedia messages, emails, faxes and other suitable PSTN-compatible communication messages. The call router no can preferably connect to an instance messaging network, such that the call router no can receive and send messages and receive and transmit presence information from different instance messages networks such as those based on protocols like Jabber, AIM, or fax. The call router 110 can preferably connect to micro-blogging networks such as Twitter such that it can receive and send messages to and from micro-blogging networks via APIs exposed by those networks. The call router 110 may alternatively send and receive message from any suitable system with exposed APIs. The call router no preferably communicates with the application server 114 using an application layer protocol, more preferably using the HTTP, or secure HTTPS, protocol. The communication between the application server 114 and the call router no is preferably stateless and any state information (e.g., call state) or data is preferably located in a URI or the request parameters, such as HTTP headers, GET URI parameters, POST request body parameters, or HTTP cookies. Available state information is preferably transmitted by call router requests to the application server for stateless processing, and the application server preferably stores no state. Alternatively, the application server preferably stores local state information, such as databases or sessions, as is common in web development. The call router 110 preferably stores state information in call router resources 29. The call router resources are preferably accessible by the application server 114 and other devices through a call router API. The call router 110 preferably associates each incoming phone number with a starting resource address (or more specifically a URI), more preferably the URI is provided by the application server 114, still more preferably the URI is provided by the application developer before a call is received at the call router no by associating the initial URI with the incoming call address (such as DID, SIP address, etc.) or by the application upon initiation of an outgoing call. The call router 110 preferably sends call data such as the caller number (obtained via Caller ID), caller geographic data (country, city, and/or state, zip), the number dialed, the time of the call, or any other suitable information or parameter. The call data is preferably digitally signed with a secret key stored on the call router no. A cryptographic hash of the information is preferably included along with the information as a digital signature. The call router no may also encrypt sensitive information (either before or after the cryptographic hash is computed) using the secret key to allow sensitive information to be sent across the network. The call data is preferably sent as an HTTP POST request to the application server 114. Call data may also be sent in URL (GET) variables, or encapsulated in HTTP headers. An example HTTP request containing the information in the header as shown in
Any suitable action or parameter, either initiated by the telephony device 112 or by the application server 114, may constitute an event generated by the call router 110. The call router no preferably automatically detects such events through any suitable program logic. Events may relate to call related events such as starting or ending a call, starting or ending dialing a number, or any call based occurrence. The events may additionally or alternatively be related to telephony actions such as starting or stopping recording audio, starting or stopping a Text-To-Speech (TTS) conversion, starting or stopping the playing of an audio file, beginning or stopping the gathering of telephony input, redirecting the call to another phone number, or any telephony based instruction. Events may additionally be adjusted for particular applications such as conference calls. Conference call events might include a participant joining a call, a participant leaving a call, gathering telephony input, participant muted, participant unmated, or any suitable conference based event. Furthermore, events may be generated for actions that occur on the message-based protocols used by the call router 110. For example, an messaging events might include a message sent, message received, and message error for SMS, email, faxes, instant messaging, or micro-blogging messages.
The event router 120 of the preferred embodiment functions to connect published events with subscribers of the event. Preferably, the published event is pushed to subscribers through an open HTTP connection (a single continuous HTTP connection). The open HTTP connection functions to simplify software of a web application using the system. Alternatively, the connection may push data with HTTPS, intermittent HTTP/HTTPS connections, AMF Channel, TCP connection, UDP connection, chat protocols such as jabber, or any suitable messaging framework. The event router is preferably a server, which may be partitioned and scaled for greater capacity. The event router 120 may alternatively be a monolithic system or any suitable software or hardware device(s) for routing events between any number of event publishers and authorized subscribers. In one preferred embodiment, the event router includes an event proxy server 122 and/or a message broker 128. The event proxy server 122 preferably manages the subscriptions from a client (i.e., subscriber) and/or performs more computational intensive processes like filtering events and security. The message broker 128 preferably manages the publications and more preferably manages a subset of event publications from the call router. The event proxy server 122 is preferably part of a cluster of event proxy servers 122 that can be dynamically scaled to satisfy capacity requirements. The message broker 128 is preferably part of a cluster of message brokers 128 that can similarly be dynamically scaled to satisfy capacity requirements. A load balancer may additionally be included within the event router 120 to manage the capacity load of the various components (e.g., the event proxy servers 122 and the message brokers 128). A plurality of load balancers may be individually implemented for each component type, or a single load balancer may manage the event router 120.
The message broker 128 of the event router 120 functions to manage the publication of events. The message broker 116 (or core message distributor) preferably handles routing of events to be published. A message broker is preferably any message broker as is known in the art such as RabbitMQ or other Advanced Message Queuing Protocol (AMQP) based broker. Preferably, a plurality of message brokers 128 is used to manage the events. More preferably message brokers 128 are sharded (i.e., partitioned) according to dedicated event types (or group of event types). Events are preferably distributed to the appropriate message broker 128 based on the event type. The sharding of message brokers may alternatively be according to any suitable rule. The message brokers 128 (i.e., the shards) may additionally be hosted on different hardware or software platforms, and event type responsibilities may be adjusted when additional message brokers 128 are allocated or deallocated from the cluster of message brokers 128. The message broker 128 may alternatively be a single device for all published events or hosted on a single system. A message broker 128 preferably sends events to an event proxy server 122 that is subscribed to a particular event. A message broker 128 may additionally send an event for any number of subscriptions, where the subscriptions are managed by any suitable number of event proxy servers 122.
The event proxy server 122 of the event router 120 functions to manage the subscriptions of clients. The client preferably connects to the event proxy server 122 for establishing a subscription to an event and to receive notification of events being published through the event router 120. Events published by a message broker 128 are preferably distributed to a subscribed event proxy server 122, and the event proxy server 122 preferably sends the event to a client. The event proxy server 122 is preferably part of a plurality of event proxy servers 122 that can be automatically scaled. Additionally, an event proxy server preferably manages multiple subscriptions, and may subscribe to multiple message brokers 128. Additionally, a plurality (or series) of event proxy servers 122 may be connected to a single message broker 128 or any suitable device publishing the event for the event router 120. The plurality of event proxy servers 122 functions to increase the volume of subscriptions the event router 120 can manage. A plurality of event proxy servers 122 may alternatively be used with a partitioned message broker 128, multiple message brokers 128, or any suitable configuration. As another variation, an event proxy may have multiple subscriptions (e.g., for different clients) to a message broker 128. This multiple subscriptions may have redundancies. The event proxy server 122 may aggregate the subscriptions for improved system efficiency, as shown in
The event router 120 of the preferred embodiment may additionally include an event filter 124 that functions to selectively pass events to a client. The event filter 124 is preferably operated on an event proxy server 122. Event filters 124 selectively filter the number of events published to a particular subscriber based on account security, event type, contents, and/or any suitable parameter of the event. When a subscriber issues a subscription request, the request preferably contains a set of credentials and more preferably a set of event filters. The event router 120, more preferably the event proxy server 122, first verifies the account ownership via the credentials to determine if the subscriber is authorized to view events for the given account. Once a subscriber's identity is determined, the event router only passes events that are associated with authorized accounts. Preferably, this account-level security preferably limits visibility of events to only the relevant account or accounts, and the event filters are preferably applied after the account-level security. The event proxy server 122 preferably applies the event filters 124 to determine if the event router should publish an event to a given subscriber. The event filter 124 is preferably a type filter or a parameter filter. A type filter preferably filters event details by the type of event such as ‘call start’, ‘call end’, ‘call error’, ‘call warning’, ‘record start’, ‘record end’, ‘gather start’, ‘gather end’, ‘dial start’, ‘dial end’ and/or any suitable type of event. A parameter filter preferably filters events based on characteristics of the event such as by caller ID, contents of call, time of call, duration of call, area code of call, and/or any suitable characteristic of a call. A parameter filter may additionally filter based on the event (such as which digit was pressed by the caller, the warning message issued by the call router, or the length of a recording). Event filters 124 may be used in a variety of ways. As one example, filters may be configured to subscribe to a particular call. As another example, the filters may be configured to subscribe to all calls to and/or from a given phone number. As yet another example, the filters may be configured to subscribe to a particular telephony application action such as “call start” across an account (which may involve multiple simultaneous calls for various phone numbers). The event filter 124 may additionally function to provide a level of security. The event filter 124 preferably prevents inspection, observation, receiving, and/or gathering of any useful information concerning a subset of events. A publisher may implement a security event filter 124 for events the publisher does not want a subscriber to see or alternatively, any suitable entity may implement a security event filter 124.
The event router 120 of the preferred embodiment may additionally include a security policy engine 126 that functions to enforce a security policy governing which subscribers are allowed to subscribe to a particular event. The event proxy server 122 preferably operates the security policy engine 126. Preferably, the security policy engine 126 includes a signed URL. The signed URL is preferably composed of a subscription message and a verification token. The verification token functions to be validation of the authenticity of the subscription request. A private key shared between the client application developer and the event router is preferably used to generate the verification token and is preferably a code, password, or any suitable identifier. The verification token is preferably implemented as an HMAC (Hash Message Authentication Code) hash using the key, but may alternatively be implemented by any suitable cryptographic message authentication technique. The verification token preferably includes the subscription request including a subscription URL, subscription filters, subscription expiration time, and/or any other suitable subscription metadata or parameter. The verification token is preferably attached to the subscription request. In one preferred version, the verification token is appended to the end of a URL of the subscription message to form the signed URL. The signed URL allows the subscription request to be passed to unknown devices, such as a remote web browser, and allowing the browser to issue subscription requests without knowing the key or other information. Alternatively, other security systems such as OAuth URL signing or any suitable security method may be implemented.
The system of the preferred embodiment may also include a connection to the client device 130, which functions to be a channel through which published events that a client subscribes to can be delivered. The connection 130 is preferably any suitable network connection either wired or wireless. The connection 130 is preferably between an event router 120 and the client, and more preferably, the connection 130 is between an event proxy server 122 and the client. The connection to the client is preferably an HTTP connection but may be any suitable signaling protocol. The client device of the preferred embodiment functions to provide interaction with subscribed events. The client device may be a front-end interface of the web application. The client device preferably reacts to events and provides an interface for user interaction. The client device may be a website, a computer program, a web enabled consumer product, a server, or any suitable device. However, the client device may alternatively be a backend system such as a data collection system. A browser 132 is one common type of client. A connection with a browser is preferably implemented via Ajax in javascript (e.g., XMLHttpRequest) or via a flash plugin (e.g., XMLSocket or an AMF or SecureAMF channel). An Application Programming Interface (API) server 134 is a second common type of client. A client preferably initiates the creation of connection 130 to the event router 122. However, in the situation of an API server 134, the event router 120 or, more preferably, an event proxy server 122 may initiate the creation of a connection 130 to the client 130. There may additionally be a control channel and a publication channel. The control channel is a connection through which a client submits a subscription request. The client can manage subscriptions through the control channel. Management of subscription includes modifying an existing subscription (e.g., updating filters or changing expiration time), adding a subscription, deleting a subscription and/or any suitable subscription change. The subscription channel is the connection through which events are sent to the client. In one variation, a client may setup multiple subscriptions and/or modify subscriptions through multiple control channels or alternatively through one control channel at different times. One publication channel is preferably used regardless of the number of subscriptions of a client. This functions to reduce the number of open connection 130 between the client and the event proxy server 122. The connection 130 may be any suitable connection as mentioned above. In the case where the connection is a long poling type connection, a client preferably connects to the event proxy server 122, gets an event, and closes a connection. When the client is not connected, events may be missed by the client. The event proxy server 122 preferably includes a cache to store events (up to an expiration time) and delivers the cached events to the client during the next connection with the client.
The application server 114 of the preferred embodiment functions to provide a web developer with an improved development environment for interfacing and designing interactions for communications applications. The call router 110 preferably manages the interaction between the telephony device(s) 112 and the application server 114. Events are preferably generated by this interaction. The web application (application server) is preferably a website, but may alternatively be a computer program, a web enabled consumer product, or any suitable method or device capable of event subscription tasks. The application server 114 preferably combines telephony actions and a website to form a powerful user experience. In one example of an application server 114, a user may enter a phone number and leave audio comments for individual photos as the photos cycle through a slideshow. In a second example, a conference call can be managed through a web interface. In a third example, a customer service phone call may be managed and annotated using a web interface. In a fourth example, a business or sales phone call may be managed and supported by using a web interface. Any suitable application server utilizing telephony interaction may alternatively be used. The web application is preferably programmed in a manner similar to regular websites, but integration into the system allows for new user experiences relying on telephony actions.
The application server 114 functions to provide data processing logic for requests received from the call router no. The application server 114 is preferably connected to the call router 110 via a network 24, more preferably via the Internet. The application server 114 is preferably a third party server operated outside of the system, but the system may alternatively include the application server 114. A URI is preferably associated with an application server 114 or an application on an application server 114. The application server 114 preferably communicates with the call router no using an application layer protocol, more preferably using the HTTP protocol, or more secure HTTPS protocol. The application server 114 preferably receives HTTP requests from and sends HTTP responses to the call router no. The application server 114 preferably runs on a standard stack of programming languages, hosting providers, operating systems and databases to handle HTTP requests, as if the caller were a website visitor in a web browser. The application server 114 also preferably verifies the digital signatures of the call data received in the requests using the secret key to compute a cryptographic hash from the received information and the hash received. If the computed hash and the received hash do not match, or no hash is received with the request, then the application server 114 preferably determines the request is fraudulent, and the request is preferably discarded. If the computed hash and received hash match, the application server 114 preferably determines that the request is authentic and proceeds further with the processing of the request. The application server may alternatively choose to ignore the hash if security is not important. The application server preferably uses call state data communicated by the call router request to determine the next call router instructions, without requiring call state stored on the application server. The application server may alternatively use call state data sent by the call router, such as the caller ID of the caller or the unique ID of the call, to reference additional or external state data, such as rows in a database or session data stored on the application server.
The application server 114 preferably responds to HTTP requests received from the call router 110 by generating telephony instructions for the call router no. Telephony instructions when executed by the call router preferably cause an event to be detected by the call router no. The application server preferably replies to the call router in XML, however, any suitable machine-readable message format may be used, including HTML, key/value pair text, delimited text or binary encoding. The XML preferably includes the telephony instructions for the call router 110 such as connecting to another number, playing a recorded greeting, reading text, and/or requesting DTMF digit entry from the caller. The telephony instruction may alternatively be related to SMS messaging, Multimedia Messaging Service (MMS) messaging, faxes, instant messages, email, micro-blogging, or any suitable messaging task. The telephony instruction may additionally be used to send an outgoing SMS message, arrange a phone call from a specific phone number, arranging for a callback, setting up a conference call (connecting multiple numbers), sending an email, interfacing with a calendar or scheduling system, purchasing goods, or services, or any other suitable instruction. The XML instructions are preferably a set of commands to be executed in order, one at a time (i.e., sequentially). An example XML response is shown in
As an additional alternative, the system may be implemented to be full duplex where events (client events) may additionally be published from a client and the call router can subscribe to the client events as shown in
2. Telephony Web Event Method
As shown in
As an alternative, the method may additionally include receiving a subscriber generated client event, publishing the client event to the event router and identifying a call router subscribed to a client event, and sending the client event to the call router. This functions to make the eventing method full duplex for two way event publication and subscription. The duplex eventing system is substantially similar to the eventing system described, but where the client generates the events and the call router is subscribed to the events.
2A. Method of Publishing an Event
Step S110, which includes publishing an event to a router, functions to initiate the announcement of an event. Event details are preferably sent to an event router at a URL or other suitable resource or connection identifier. Event details preferably include account identification, event type, any event data associated with the event, and any other suitable parameters relating to the event. Publishing to a router preferably occurs after a new event occurs, but alternatively, a batch of events may be published periodically, a batch of events may be published when an event count is satisfied, an event may be published when an event type is satisfied, or any suitable event publishing rule may be applied. An event is preferably generated from a telephony application operating on a call router. The telephony application is preferably substantially similar in functionality to the one described above. A call router preferably publishes an event to an event router. The event is preferably published over HTTP, but any suitable protocol may be used. An event distributor may additionally select a message broker to send the event. A plurality of message brokers may be sharded according to event types and the event distributor preferably is capable of mapping the event to the appropriate message broker.
Step S120, which includes identifying subscribers to an event, functions to identify all authorized subscribers that should be notified that the event occurred. The subscribers are preferably associated with a subscription URL. Any suitable number of subscribers is preferably identified, and subscribers are preferably identified by inspecting a list of subscribers. The subscribers may alternatively be associated with a group of other subscribers, and a group (or groups) may be identified as a subscriber. Identifying subscribers is preferably performed by an event router, and more preferably an event proxy server in cooperation with a message broker, though any suitable device may be used. Preferably, an event proxy server performs the steps of managing a subscription of a client (subscriber) and subscribing to an event publication of the event router. The event proxy server preferably subscribes on behalf of a client, so that subscription processing can be delegated to the event proxy server. More preferably a message broker performs the steps of publishing the event. So that the event proxy server subscribes to a message broker. Identifying subscribers of an event may include a sub-step of verifying event filters. An account-level security may additionally be enforced by the event router to limit the visibility of events to only relevant accounts. The event is compared to filters of a subscriber to ensure the subscriber should be sent the event. The filters are preferably type filters or parameter filters as discussed above.
Step S130, which includes publishing an event to a subscriber, functions to notify a subscriber of the occurrence of an event. The event is preferably published by an event router over an open HTTP connection, but alternatively, a periodic HTTP connection, messaging framework such as Jabber, or any suitable communication protocol may be used. In the situation where a client has previously broken a connection with the event router (i.e., is not connected to the event router at the time an event occurs), the event proxy server preferably establishes a connection to the subscriber. The event proxy server preferably establishes the connection by accessing the stored address of the client and connecting through any suitable protocol. In the case the subscriber is an API server, an API command may be used to connect or notify the API server of the event.
2B. A Method of Subscribing to an Event
Step S210, which includes generating a signed URL for an event subscription, functions to generate a URL encoding any subscription URL, filter, and/or identification information. An unsigned URL is preferably generated including account identification, subscription URL, subscription filters, subscription expiration time, and/or any other suitable subscription metadata or parameter. Preferably, a key is looked up based on the account identification. The key is used to create a verification token. The verification token is preferably implemented as an HMAC-SHA1 (Hash Message Authentication Code) hash using the key or any suitable another cryptographic message authentication technique may be used. The verification token additionally includes the subscription request including a subscription URL, subscription filters, subscription expiration time, and/or any other suitable subscription metadata or parameter. The verification token is preferably appended to the unsigned URL to form a signed URL. The signed URL is preferably integrated into a subscription request. The subscription request is preferably a request to receive particular events of a telephony application.
Step S220 includes sending a subscription request to an event router. The subscription request is preferably sent to an event router by HTTP protocol, but any suitable protocol may alternatively be used. The subscription request is preferably received by an event router, and more preferably is received by an event proxy server. The event proxy server preferably manages subscriptions.
Step S230, which includes verifying an event subscription, functions to verify the identity of a subscriber. The signed URL of the event is preferably deconstructed to identify account identification, subscription URL, subscription filters, subscription expiration time, and/or any other suitable subscription metadata or parameter. The event router preferably verifies that the account identification is included in the signed URL or other authentication credentials. If no account identification is found, the subscription request is discarded and an error is returned. If the identification information is included a key for the account is looked up (i.e. found in a database). The key is preferably a shared key that is identical to the key of Step S210. The key is then used to form a verification token. The verification token is preferably a HMAC hash, or alternatively any suitable cryptographic message or identifier. The verification token is compared to the verification token from the signed URL to verify the match.
Step S240, which includes allowing an event subscription, functions to allow a client to subscribe to an event. A subscription preferably allows a client to receive events in real time (approximately a few milliseconds to a few seconds). An event subscription also only allows events that are authorized to be viewed by the account, such as events generated by calls on that account. More preferably, the events preferably pass any filters of a subscriber. As an additional alternative, subscriptions may expire after a given time. As part of Step S240, the method includes the event proxy server (or event router) configuring filters for the subscription. This step functions to setup processing operations of the subscription. Additionally, any suitable subscription setup that must be performed is additionally performed. In the variation where the subscriber previously has a subscription, the previous subscription may be modified to include the new subscription details. Events from multiple subscriptions of one subscriber are preferably sent to the subscriber through a single connection as described above. In the situation where a subscriber is not connected to the event router when an event occurs the event proxy server or any suitable device may queue or cache the events for delivery when the subscriber next establishes a connection.
As a person skilled in the art will recognize from the previous detailed description and from the figures and claims, modifications and changes can be made to the preferred embodiments of the invention without departing from the scope of this invention defined in the following claims.
Wolthuis, John, Lawson, Jeffrey, Cooke, Evan
Patent | Priority | Assignee | Title |
10057412, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Region-based connecting of calls using client-specific control and provisioned numbers |
10122682, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Region-based bridging of calls using client-specific control and revised caller identifiers |
10135974, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Client-specific control of shared telecommunications services |
10142329, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Multiple-factor authentication |
10165114, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Intelligent call handling and routing |
10187530, | Oct 01 2008 | Twilio, Inc. | Telephony web event system and method |
10298751, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customization of alerts using telecommunications services |
10298770, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Template-based configuration and management of telecommunications services |
10348902, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Template-based management of telecommunications services |
10404759, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Client-specific control of shared telecommunications services |
10425531, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customized communication lists for data communications systems using high-level programming |
10447861, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Intelligent call handling and routing based on numbering plan area code |
10455094, | Oct 01 2008 | Twilio Inc. | Telephony web event system and method |
10523813, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Region-based connecting of calls using client-specific control and provisioned numbers |
10547916, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customization of emergency notifications for telecommunications services |
10616174, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customized telecommunication monitoring and alerts using a high-level programming interface |
10645217, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Client-specific control of shared telecommunications services |
10721359, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Intelligent call handling and routing based on numbering plan area code |
10749938, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Switchboard server using a high-level programming interface |
10805356, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Client-specific control of shared telecommunications services |
10848617, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Intelligent call handling and routing |
10855839, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customized call lists for voip systems using high-level programming |
10860741, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Telecommunication privacy protection using a high-level programming interface |
10904395, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Template-based configuration and management of telecommunications services |
10951484, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customized call model generation and analytics using a high-level programming interface |
10965666, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Multiple-factor authentication |
10999429, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Region-based bridging of calls using client-specific control and revised caller identifiers |
11005998, | Oct 01 2008 | Twilio Inc. | Telephony web event system and method |
11044363, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customization of alerts using telecommunications services |
11044365, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Multi-level programming/data sets with decoupling VoIP communications interface |
11115537, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Template-based management of telecommunications services |
11128595, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customized telecommunication monitoring and alerts using a high-level programming interface |
11146596, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Client-specific control of shared telecommunications services |
11212391, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Intelligent call handling and routing based on numbering plan area code |
11252276, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Client-specific control of shared telecommunications services |
11388062, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customized call model generation and analytics using a high-level programming interface |
11403423, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Telecommunication privacy protection using a high-level programming interface |
11412084, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customization of alerts using telecommunications services |
11425260, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Template-based configuration and management of data-communications services |
11451620, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Switchboard server using a high-level programming interface |
11451662, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customized call lists for voip systems using high-level programming |
11509764, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Region-based connecting of calls using client-specific control and provisioned numbers |
11558369, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Multiple-factor authentication |
11575732, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Networked device control using a high-level programming interface |
11632471, | Oct 01 2008 | Twilio Inc. | Telephony web event system and method |
11641427, | Oct 01 2008 | Twilio Inc. | Telephony web event system and method |
11647087, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Intelligent call handling and routing |
11665285, | Oct 01 2008 | Twilio Inc. | Telephony web event system and method |
11671533, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Programming/data sets via a data-communications server |
11706333, | Jun 23 2016 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Region-based bridging of calls using client-specific control and revised caller identifiers |
11785363, | Jun 23 2017 | WILMINGTON SAVINGS FUND SOCIETY, FSB | Customization of emergency notifications for communications services |
11889027, | Oct 01 2008 | Twilio Inc. | Telephony web event system and method |
9807244, | Oct 01 2008 | Twilio, Inc. | Telephony web event system and method |
Patent | Priority | Assignee | Title |
5274700, | Nov 27 1989 | MPL APPLICATIONS, L L C | Methods of automatically rerouting an incoming telephone call placed over a network |
5526416, | Nov 16 1992 | Wilmington Trust, National Association, as Administrative Agent | Automatic call distribution system with an ISDN compatible call connection system and method |
5581608, | Aug 28 1992 | UNIFY GMBH & CO KG | Method and apparatus for masking the reporting of network telephony events to a computer |
5598457, | Sep 30 1994 | AT&T IPM Corp | Technique for providing redundant capability in a personal mobile communication system |
5867495, | Nov 18 1996 | Verizon Patent and Licensing Inc | System, method and article of manufacture for communications utilizing calling, plans in a hybrid network |
5934181, | Jan 23 1998 | SEB S.A.; SEB SA | Cooking utensil comprising a sensor for measuring the temperature of this utensil |
6026440, | Jan 27 1997 | International Business Machines Corporation | Web server account manager plug-in for monitoring resources |
6094681, | Mar 31 1998 | UNIFY, INC | Apparatus and method for automated event notification |
6138143, | Jan 28 1999 | SAP SE | Method and apparatus for asynchronous transaction processing |
6185565, | Dec 18 1997 | RPX CLEARINGHOUSE LLC | System and method for communication session disposition responsive to events in a telecommunications network and the internet |
6192123, | Apr 14 1997 | REMOTE CONCEPTS LLC | Method and apparatus for initiating telephone calls using a data network |
6206564, | Jan 23 1998 | SEB SA | Cooking utensil including a temperature sensor integrated into the bottom of the utensil |
6223287, | Jul 24 1998 | International Business Machines Corporation | Method for establishing a secured communication channel over the internet |
6232979, | Dec 19 1997 | Microsoft Technology Licensing, LLC | Method, system, and computer program product for fast computation using parallel multi-channel resampling and blending |
6269336, | Jul 24 1998 | Google Technology Holdings LLC | Voice browser for interactive services and methods thereof |
6317137, | Dec 01 1998 | Microsoft Technology Licensing, LLC | Multi-threaded texture modulation for axis-aligned volume rendering |
6373836, | Sep 15 1997 | Genesys Telecommunications Laboratories, Inc. | Apparatus and methods in routing internet protocol network telephony calls in a centrally-managed call center system |
6425012, | Dec 28 1998 | Koninklijke Philips Electronics N V | System creating chat network based on a time of each chat access request |
6426995, | Feb 16 2000 | Samsung Electronics Co., Ltd. | Radiation inspection system and method using the same |
6430175, | May 05 1998 | Alcatel Lucent | Integrating the telephone network and the internet web |
6434528, | Mar 31 1999 | LinkedIn Corporation | Computer network telephony |
6445694, | Mar 07 1997 | WEB TELEPHONY LLC | Internet controlled telephone system |
6445776, | Dec 31 1998 | RPX CLEARINGHOUSE LLC | Abstract interface for media and telephony services |
6459913, | May 03 1999 | AT&T Corp. | Unified alerting device and method for alerting a subscriber in a communication network based upon the result of logical functions |
6493558, | Oct 15 1999 | Nokia Technologies Oy | TD-SMS messaging gateway |
6496500, | Jun 28 1999 | ALEXIS INTELLECTUAL PROPERTY, LLC | System and method for controlling telephone calls through a cross platform enabled internet browser |
6501739, | May 25 2000 | CUFER ASSET LTD L L C | Participant-controlled conference calling system |
6501832, | Aug 24 1999 | Genesys Telecommunications Laboratories, Inc | Voice code registration system and method for registering voice codes for voice pages in a voice network access provider system |
6507875, | Jan 08 1997 | International Business Machines Corporation | Modular application collaboration including filtering at the source and proxy execution of compensating transactions to conserve server resources |
6577721, | May 01 1998 | Nokia Technologies Oy | Conference call |
6600736, | Mar 31 1999 | Lucent Technologies Inc | Method of providing transfer capability on web-based interactive voice response services |
6606596, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, including deployment through digital sound files |
6614783, | Apr 01 1997 | CosmoCom, Inc. | Multimedia telecommunication automatic call distribution system using internet/PSTN call routing |
6625258, | Dec 27 1999 | RPX CLEARINGHOUSE LLC | System and method for providing unified communication services support |
6625576, | Jan 29 2001 | Lucent Technologies Inc.; Lucent Technologies Inc | Method and apparatus for performing text-to-speech conversion in a client/server environment |
6636504, | Mar 18 1999 | Verizon Patent and Licensing Inc | Reverse billing of internet telephone calls |
6662231, | Jun 30 2000 | DISTRIBUTED MEDIA SOLUTIONS, LLC | Method and system for subscriber-based audio service over a communication network |
6704785, | Mar 17 1997 | Vitria Technology, Inc. | Event driven communication system |
6707889, | Aug 24 1999 | Genesys Telecommunications Laboratories, Inc | Multiple voice network access provider system and method |
6711129, | Oct 26 1999 | AVAYA Inc | Real-time admission control |
6711249, | Feb 08 2001 | Microsoft Technology Licensing, LLC | Common gateway to call control systems |
6738738, | Dec 23 2000 | Microsoft Technology Licensing, LLC | Automated transformation from American English to British English |
6757365, | Oct 16 2000 | Microsoft Technology Licensing, LLC | Instant messaging via telephone interfaces |
6765997, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, with the direct delivery of voice services to networked voice messaging systems |
6768788, | Sep 13 1999 | FOOTHILL CAPITAL CORPORATION | System and method for real-time, personalized, dynamic, interactive voice services for property-related information |
6778653, | Nov 09 1999 | RPX CLEARINGHOUSE LLC | Storing information about a telephony session |
6785266, | Mar 02 1998 | WEB TELEPHONY LLC | Internet controlled telephone system |
6788768, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for real-time, personalized, dynamic, interactive voice services for book-related information |
6792086, | Aug 24 1999 | Genesys Telecommunications Laboratories, Inc | Voice network access provider system and method |
6792093, | Dec 05 2000 | MIND FUSION, LLC | System and method for telephone call recording and recorded call retrieval |
6798867, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, with real-time database queries |
6807529, | Feb 27 2002 | Google Technology Holdings LLC | System and method for concurrent multimodal communication |
6807574, | Oct 22 1999 | Microsoft Technology Licensing, LLC | Method and apparatus for content personalization over a telephone interface |
6819667, | Aug 05 1999 | WSOU Investments, LLC | PSTN-internet notification services |
6820260, | Jun 17 1999 | AVAYA Inc | Customized applet-on-hold arrangement |
6829334, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, with telephone-based service utilization and control |
6834265, | Dec 13 2002 | Google Technology Holdings LLC | Method and apparatus for selective speech recognition |
6836537, | Sep 13 1999 | MICROSTRATEGY INCORPORATED | System and method for real-time, personalized, dynamic, interactive voice services for information related to existing travel schedule |
6842767, | Oct 22 1999 | Microsoft Technology Licensing, LLC | Method and apparatus for content personalization over a telephone interface with adaptive personalization |
6850603, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized dynamic and interactive voice services |
6870830, | Nov 30 2000 | VALTRUS INNOVATIONS LIMITED | System and method for performing messaging services using a data communications channel in a data network telephone system |
6873952, | Aug 11 2000 | Microsoft Technology Licensing, LLC | Coarticulated concatenated speech |
6874084, | May 02 2000 | International Business Machines Corporation | Method and apparatus for establishing a secure communication connection between a java application and secure server |
6885737, | May 30 2002 | Nuance Communications, Inc | Web integrated interactive voice response |
6888929, | Aug 24 1999 | Genesys Telecommunications Laboratories, Inc | Revenue generation method for use with voice network access provider system and method |
6895084, | Aug 24 1999 | Genesys Telecommunications Laboratories, Inc | System and method for generating voice pages with included audio files for use in a voice page delivery system |
6898567, | Dec 29 2001 | Google Technology Holdings LLC | Method and apparatus for multi-level distributed speech recognition |
6912581, | Feb 27 2002 | Google Technology Holdings LLC | System and method for concurrent multimodal communication session persistence |
6922411, | Sep 29 2000 | ALVARIA, INC | Networked computer telephony system driven by web-based applications |
6931405, | Apr 15 2002 | Microsoft Technology Licensing, LLC | Flexible subscription-based event notification |
6937699, | Sep 27 1999 | GOOGLE LLC | System and method for advertising using data network telephone connections |
6940953, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services including module for generating and formatting voice services |
6941268, | Jun 21 2001 | Microsoft Technology Licensing, LLC | Handling of speech recognition in a declarative markup language |
6947417, | Jun 29 2001 | Movius Interactive Corporation | Method and system for providing media services |
6947988, | Aug 11 2000 | Wilmington Trust, National Association, as Administrative Agent | Method and apparatus for allocating resources of a contact center |
6961330, | Jun 23 2000 | Mavenir LTD | Web development and deployment using SMS and USSD |
6964012, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, including deployment through personalized broadcasts |
6970915, | Nov 01 1999 | Microsoft Technology Licensing, LLC | Streaming content over a telephone interface |
6977992, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, with real-time database queries |
6985862, | Mar 22 2001 | Microsoft Technology Licensing, LLC | Histogram grammar weighting and error corrective training of grammar weights |
6999576, | Nov 17 2002 | Verizon Patent and Licensing Inc | System connection adapter and terminal |
7003464, | Jan 09 2003 | Google Technology Holdings LLC | Dialog recognition and control in a voice browser |
7006606, | Jun 05 1996 | VOICE FX INTERNATIONAL, INC | Sponsored information distribution method and apparatus |
7010586, | Apr 21 2000 | Oracle America, Inc | System and method for event subscriptions for CORBA gateway |
7020685, | Oct 08 1999 | Unwired Planet, LLC | Method and apparatus for providing internet content to SMS-based wireless devices |
7039165, | Sep 13 1999 | MICROSTRATEGY INCORPORATED | System and method for personalizing an interactive voice broadcast of a voice service based on automatic number identification |
7062709, | Dec 21 2002 | International Business Machines Corporation | Method and apparatus for caching VoiceXML documents |
7076037, | Dec 22 2004 | Metro Enterprises, Inc. | Process for dynamic call routing in real time |
7076428, | Dec 30 2002 | Google Technology Holdings LLC | Method and apparatus for selective distributed speech recognition |
7089310, | Jun 13 2000 | Microsoft Technology Licensing, LLC | Web-to-phone account linking using a linking code for account identification |
7103003, | Sep 11 2000 | RPX CLEARINGHOUSE LLC | Network planning tool |
7103171, | Jun 29 2001 | Oracle America, Inc | System and method for multi-channel communication queuing using routing and escalation rules |
7106844, | Sep 26 2001 | AT&T Intellectual Property I, L P | System and method for identifying contaminated telephone numbers and correct LRN under number pooling |
7111163, | Jul 10 2000 | ALTERWAN, INC , A CALIFORNIA CORPORATION | Wide area network using internet with quality of service |
7140004, | Jun 13 2000 | Microsoft Technology Licensing, LLC | Method and apparatus for zero-footprint phone application development |
7143039, | Aug 11 2000 | Microsoft Technology Licensing, LLC | Providing menu and other services for an information processing system using a telephone or other audio interface |
7197331, | Dec 30 2002 | Google Technology Holdings LLC | Method and apparatus for selective distributed speech recognition |
7197461, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for voice-enabled input for use in the creation and automatic deployment of personalized, dynamic, and interactive voice services |
7197462, | Apr 27 2001 | IBM Corporation | System and method for information access |
7197544, | Jan 09 2003 | Match Group, LLC | Voice and video greeting system for personal advertisement and method |
7225232, | Mar 28 2002 | AVAYA Inc | Using existing web-based information to generate responses to user queries |
7227849, | Apr 09 1998 | Nokia Technologies Oy | Implementation of multiple simultaneous calls in a mobile communication system |
7260208, | Dec 21 2001 | System, method and apparatus for least cost automatic routing of calls in telephone networks with data supplied on demand | |
7266181, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized dynamic and interactive voice services with integrated inbound and outbound voice services |
7269557, | Aug 11 2000 | Microsoft Technology Licensing, LLC | Coarticulated concatenated speech |
7272212, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services |
7272564, | Mar 22 2002 | Google Technology Holdings LLC | Method and apparatus for multimodal communication with user control of delivery modality |
7277851, | Nov 22 2000 | Microsoft Technology Licensing, LLC | Automated creation of phonemic variations |
7283515, | Feb 14 2003 | Managed Inventions, LLC | Internet telephony network and methods for using the same |
7286521, | Jul 21 2000 | Microsoft Technology Licensing, LLC | Localized voice over internet protocol communication |
7287248, | Oct 31 2002 | Microsoft Technology Licensing, LLC | Method and system for the generation of a voice extensible markup language application for a voice interface process |
7289453, | Dec 13 2001 | Sony Deutschland GmbH | Adaptive quality-of-service reservation and pre-allocation for mobile systems |
7296739, | Mar 31 2000 | Intel Corporation | Managing on-line transactions |
7298732, | Feb 19 2002 | Samsung Electronics Co., Ltd. | Method for initializing internet protocol phone in internet protocol telephony system |
7308085, | Jan 24 2001 | Microsoft Technology Licensing, LLC | Serializing an asynchronous communication |
7308408, | Jul 24 2000 | Microsoft Technology Licensing, LLC | Providing services for an information processing system using an audio interface |
7324633, | May 30 2002 | Nuance Communications, Inc | Web integrated interactive voice response |
7324942, | Jan 29 2002 | MicroStrategy, Incorporated | System and method for interactive voice services using markup language with N-best filter element |
7328263, | Jan 30 2001 | Cisco Technology, Inc. | Controlling access of concurrent users of computer resources in a distributed system using an improved semaphore counting approach |
7330463, | May 28 2003 | RPX CLEARINGHOUSE LLC | Enterprise voice over internet protocol (VoIP) virtual private network (VPN) |
7330890, | Oct 22 1999 | Microsoft Technology Licensing, LLC | System for providing personalized content over a telephone interface to a user according to the corresponding personalization profile including the record of user actions or the record of user behavior |
7340040, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for real-time, personalized, dynamic, interactive voice services for corporate-analysis related information |
7349714, | Mar 10 2000 | Samsung Electronics Co., Ltd | Power control apparatus and method in a wireless communication system using scheduled packet data service channel |
7369865, | Oct 17 2002 | System and method for sending SMS and text messages | |
7373660, | Aug 26 2003 | Cisco Technology, Inc. | Methods and apparatus to distribute policy information |
7376223, | Sep 24 2002 | AT&T Intellectual Property I, L P | Method and system for connecting a subscriber to an advertiser prior to call completion |
7376586, | Oct 22 1999 | Microsoft Technology Licensing, LLC | Method and apparatus for electronic commerce using a telephone interface |
7376733, | Feb 03 2003 | Hewlett Packard Enterprise Development LP | Method and apparatus and program for scheduling and executing events in real time over a network |
7376740, | Jun 13 2000 | Microsoft Technology Licensing, LLC | Phone application state management mechanism |
7412525, | Jan 24 2001 | Microsoft Technology Licensing, LLC | System verifying if an email request passed a policy check before initiating an interactive telephony session |
7418090, | Nov 25 2002 | Verizon Patent and Licensing Inc | Methods and systems for conference call buffering |
7428302, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for real-time, personalized, dynamic, interactive voice services for information related to existing travel schedule |
7440898, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, with system and method that enable on-the-fly content and speech generation |
7447299, | May 02 2000 | Microsoft Technology Licensing, LLC | Voice and telephone keypad based data entry for interacting with voice information services |
7454459, | Sep 04 2001 | Malikie Innovations Limited | Method and apparatus for implementing a real-time event management platform |
7457249, | Jan 04 2005 | ARLINGTON TECHNOLOGIES, LLC | Alternate routing of media connections within a single communications system across public or private network facilities |
7457397, | Aug 24 1999 | Genesys Telecommunications Laboratories, Inc | Voice page directory system in a voice page creation and delivery system |
7473872, | Nov 25 2003 | IRISOHYAMA, INC | Cooking tool |
7486780, | Sep 13 1999 | MicroStrategy, Incorporated | System and method for the creation and automatic deployment of personalized, dynamic and interactive voice services, with telephone-based service utilization and control |
7496054, | Sep 29 2000 | ALVARIA, INC | Networked computer telephony system driven by web-based applications |
7500249, | May 02 2000 | Oracle America, Inc | Cluster event service method and system |
7505951, | May 30 2006 | MOTOROLA SOLUTIONS, INC | Hierarchical state machine generation for interaction management using goal specifications |
7519359, | Sep 30 2005 | Google Technology Holdings LLC | Voice tagging of automated menu location |
7522711, | Oct 19 2001 | Microsoft Technology Licensing, LLC | Delivery of audio driving directions via a telephone interface |
7536454, | Dec 28 2001 | Google Technology Holdings LLC | Multi-modal communication using a session specific proxy server |
7552054, | Aug 11 2000 | Microsoft Technology Licensing, LLC | Providing menu and other services for an information processing system using a telephone or other audio interface |
7571226, | Oct 22 1999 | Microsoft Technology Licensing, LLC | Content personalization over an interface with adaptive voice character |
7613287, | Nov 15 2005 | Microsoft Technology Licensing, LLC | Method and apparatus for providing ringback tones |
7623648, | Dec 01 2004 | Microsoft Technology Licensing, LLC | Method and system of generating reference variations for directory assistance data |
7630900, | Dec 01 2004 | Microsoft Technology Licensing, LLC | Method and system for selecting grammars based on geographic information associated with a caller |
7631310, | Nov 14 2003 | GOOGLE LLC | Loadbalancing multiple files across computing devices |
7644000, | Dec 29 2005 | Microsoft Technology Licensing, LLC | Adding audio effects to spoken utterance |
7657433, | Sep 08 2006 | Microsoft Technology Licensing, LLC | Speech recognition accuracy with multi-confidence thresholds |
7657434, | May 30 2006 | Google Technology Holdings LLC | Frame goals for dialog system |
7668157, | Jul 25 2003 | Verizon Patent and Licensing Inc | Presence based telephony |
7672295, | Nov 12 2003 | Microsoft Technology Licensing, LLC | Method and system for design for run-time control of voice XML applications |
7675857, | May 03 2006 | GOOGLE LLC | Method and apparatus to avoid network congestion |
7676221, | Feb 20 2004 | Microsoft Technology Licensing, LLC | Call intercept methods, such as for customer self-support on a mobile device |
7715547, | Jun 14 2004 | Soleo Communications, Inc. | Voice XML network gateway |
7742499, | Aug 18 2005 | AVAYA Inc | Adaptive bandwidth network management for VOIP network |
7779065, | Sep 18 2003 | NYTELL SOFTWARE LLC | Dynamic cost network routing |
7875836, | Apr 28 2004 | IMURA INTERNATIONAL INC | Tag assembly for radio frequency identification controlled heatable objects |
7882253, | Apr 05 2001 | REAL-TIME INNOVATIONS, INC | Real-time publish-subscribe system |
7920866, | Jul 07 2005 | Alcatel-Lucent USA Inc | Method of hard handover in a wireless communication system |
7926099, | Jul 15 2005 | Apple Inc | Computer-implemented method and system for security event transport using a message bus |
7936867, | Aug 15 2006 | AVAYA Inc | Multi-service request within a contact center |
7962644, | Mar 18 2002 | ORACLE INTERNATIONAL CORPORATION, A CALIFORNIA CORPORATION | Systems and methods for handling a plurality of communications |
7979555, | Feb 27 2007 | ExtraHop Networks,Inc. | Capture and resumption of network application sessions |
8023425, | Jan 28 2009 | Headwater Research LLC | Verifiable service billing for intermediate networking devices |
8069096, | May 27 2008 | SCIQUEST INC. | Multi-constituent attribution of a vendor's product catalog |
8081958, | Dec 01 2006 | Slack Technologies, LLC; SLACK TECHNOLOGIES, INC | User initiated invite for automatic conference participation by invitee |
8103725, | Nov 17 2006 | Microsoft Technology Licensing, LLC | Communication using delegates |
8126128, | Nov 01 2006 | AT&T Intellectual Property I, L P | Life cycle management of user-selected applications on wireless communications devices |
8149716, | Aug 20 2007 | Raytheon BBN Technologies Corp | Systems and methods for adaptive routing in mobile ad-hoc networks and disruption tolerant networks |
8150918, | Jan 29 2003 | Adobe Inc | Client controllable server-side playlists |
8156213, | Jul 27 2009 | Juniper Networks, Inc. | Merging network device configuration schemas |
8185619, | Jun 28 2006 | Dynatrace LLC | Analytics system and method |
8196133, | Dec 02 2003 | Cisco Technology, Inc. | Software change modeling for network devices |
8233611, | Mar 31 2006 | United Services Automobile Association (USAA); UNITED SERVICES AUTOMOBILE ASSOCIATION USAA | Member-initiated outbound call |
8238533, | Jan 14 2008 | AT&T MOBILITY II LLC | Telecommunications least cost routing system |
8243889, | Aug 23 2007 | ALVARIA CAYMAN CX | System and method for dynamic call-progress analysis and call processing |
8266327, | Jun 21 2005 | Cisco Technology, Inc | Identity brokering in a network element |
8295272, | Jul 25 2003 | Verizon Patent and Licensing Inc | Methods and systems for presence-based telephony communications |
8306021, | Apr 02 2008 | TWILIO, INC | System and method for processing telephony sessions |
8326805, | Sep 28 2007 | EMC IP HOLDING COMPANY LLC | High-availability file archiving |
8346630, | Jun 30 2006 | INTUIT INC.; INTUIT, INC | Method and apparatus to efficiently verify inventory |
8355394, | Aug 21 2007 | ALVARIA CAYMAN CX | System and method for dynamic telephony resource allocation between premise and hosted facilities |
8417817, | Sep 15 2010 | GOOGLE LLC | Preventing server overload |
8429827, | Dec 02 2008 | Electronic cooking utensil for setting cooking time with cooking status indicator | |
8438315, | Mar 31 2008 | EMC IP HOLDING COMPANY LLC | Techniques for non-disruptive upgrade |
8462670, | Jun 16 2008 | HOIIO PTE LTD | Internet based communication system and method |
8467502, | Feb 27 2001 | Verizon Patent and Licensing Inc | Interactive assistant for managing telephone communications |
8503639, | Feb 27 2001 | Verizon Patent and Licensing Inc | Method and apparatus for adaptive message and call notification |
8503650, | Feb 27 2001 | Verizon Patent and Licensing Inc | Methods and systems for configuring and providing conference calls |
8509068, | Nov 16 2005 | Tyntec Group Limited | Method and devices for routing messages |
8532686, | Dec 24 2010 | Qualcomm Incorporated | System and method for managing spectrum resources |
8542805, | May 14 2009 | ALVARIA CAYMAN CX | System and method for encrypted media service in an interactive voice response service |
8582450, | Sep 30 2009 | MITEL NETWORKS, INC ; Shoretel, INC | Status reporting system |
8594626, | Apr 02 2008 | T-MOBILE INNOVATIONS LLC | Post-paid wireless service balance management |
8601136, | May 09 2012 | Twilio, Inc. | System and method for managing latency in a distributed telephony network |
8611338, | Apr 02 2008 | TWILIO, INC | System and method for processing media requests during a telephony sessions |
8613102, | Mar 30 2004 | Citrix Systems, Inc | Method and system for providing document retention using cryptography |
8649268, | Feb 04 2011 | TWILIO, INC | Method for processing telephony sessions of a network |
8667056, | Jun 29 2011 | Amazon Technologies, Inc | Dynamic traffic management |
8675493, | Jul 02 2002 | WSOU Investments, LLC | Routing bandwidth guaranteed paths with local restoration in label switched networks |
8755376, | Apr 02 2008 | Twilio, Inc. | System and method for processing telephony sessions |
8767925, | Feb 27 2001 | Verizon Patent and Licensing Inc | Interactive assistant for managing telephone communications |
8806024, | Sep 14 2010 | OMG HOLDINGS, INC | Bi-directional sharing of a document object model |
8837465, | Apr 02 2008 | Twilio, Inc. | System and method for processing telephony sessions |
8838707, | Jun 25 2010 | TWILIO, INC | System and method for enabling real-time eventing |
8861510, | Jun 28 2012 | MITEL NETWORKS, INC ; Shoretel, INC | Dynamic assignment of media proxy |
8948356, | Oct 15 2012 | Twilio, Inc. | System and method for routing communications |
8964726, | Oct 01 2008 | TWILIO, INC | Telephony web event system and method |
9014664, | Jun 28 2013 | Boku, Inc. | Configurable price matrix for mobile billing at a merchant server |
9015702, | Jan 13 2012 | Oracle International Corporation | Determining compatibility of an application with different versions of an operating system |
20010038624, | |||
20010043684, | |||
20010051996, | |||
20020006124, | |||
20020006125, | |||
20020006193, | |||
20020064267, | |||
20020067823, | |||
20020077833, | |||
20020126813, | |||
20020136391, | |||
20020165957, | |||
20020176378, | |||
20020198941, | |||
20030006137, | |||
20030014665, | |||
20030018830, | |||
20030023672, | |||
20030026426, | |||
20030046366, | |||
20030051037, | |||
20030058884, | |||
20030059020, | |||
20030060188, | |||
20030061317, | |||
20030061404, | |||
20030088421, | |||
20030097447, | |||
20030103620, | |||
20030123640, | |||
20030195990, | |||
20030196076, | |||
20030211842, | |||
20030231647, | |||
20040008635, | |||
20040011690, | |||
20040044953, | |||
20040052349, | |||
20040071275, | |||
20040101122, | |||
20040102182, | |||
20040165569, | |||
20040172482, | |||
20040205689, | |||
20040213400, | |||
20040218748, | |||
20040228469, | |||
20040240649, | |||
20050005200, | |||
20050010483, | |||
20050021626, | |||
20050025303, | |||
20050038772, | |||
20050043952, | |||
20050047579, | |||
20050060411, | |||
20050091572, | |||
20050125251, | |||
20050128961, | |||
20050135578, | |||
20050141500, | |||
20050147088, | |||
20050177635, | |||
20050181835, | |||
20050228680, | |||
20050238153, | |||
20050240659, | |||
20050243977, | |||
20050246176, | |||
20050289222, | |||
20060008073, | |||
20060015467, | |||
20060047666, | |||
20060067506, | |||
20060129638, | |||
20060143007, | |||
20060168334, | |||
20060203979, | |||
20060209695, | |||
20060212865, | |||
20060215824, | |||
20060217823, | |||
20060217978, | |||
20060222166, | |||
20060256816, | |||
20060262915, | |||
20060270386, | |||
20060285489, | |||
20070002744, | |||
20070036143, | |||
20070050306, | |||
20070070906, | |||
20070070980, | |||
20070071223, | |||
20070074174, | |||
20070121651, | |||
20070127691, | |||
20070127703, | |||
20070130260, | |||
20070133771, | |||
20070149166, | |||
20070153711, | |||
20070167170, | |||
20070192629, | |||
20070208862, | |||
20070232284, | |||
20070242626, | |||
20070265073, | |||
20070286180, | |||
20070291905, | |||
20070293200, | |||
20070295803, | |||
20080005275, | |||
20080025320, | |||
20080037715, | |||
20080037746, | |||
20080040484, | |||
20080052395, | |||
20080091843, | |||
20080101571, | |||
20080104348, | |||
20080134049, | |||
20080139166, | |||
20080146268, | |||
20080152101, | |||
20080154601, | |||
20080155029, | |||
20080162482, | |||
20080165708, | |||
20080177883, | |||
20080201426, | |||
20080209050, | |||
20080222656, | |||
20080229421, | |||
20080232574, | |||
20080235230, | |||
20080256224, | |||
20080275741, | |||
20080310599, | |||
20080313318, | |||
20080316931, | |||
20080317222, | |||
20080317232, | |||
20080317233, | |||
20090046838, | |||
20090052437, | |||
20090052641, | |||
20090059894, | |||
20090063502, | |||
20090074159, | |||
20090075684, | |||
20090083155, | |||
20090089165, | |||
20090089352, | |||
20090089699, | |||
20090093250, | |||
20090125608, | |||
20090129573, | |||
20090136011, | |||
20090170496, | |||
20090171659, | |||
20090171669, | |||
20090171752, | |||
20090182896, | |||
20090217293, | |||
20090220057, | |||
20090221310, | |||
20090222341, | |||
20090225748, | |||
20090225763, | |||
20090232289, | |||
20090234965, | |||
20090235349, | |||
20090252159, | |||
20090276771, | |||
20090288012, | |||
20090288165, | |||
20090300194, | |||
20090316687, | |||
20090318112, | |||
20100037204, | |||
20100070424, | |||
20100082513, | |||
20100087215, | |||
20100088187, | |||
20100088698, | |||
20100115041, | |||
20100142516, | |||
20100150139, | |||
20100167689, | |||
20100188979, | |||
20100191915, | |||
20100208881, | |||
20100217837, | |||
20100217982, | |||
20100232594, | |||
20100235539, | |||
20100251329, | |||
20100251340, | |||
20100281108, | |||
20100291910, | |||
20110029882, | |||
20110029981, | |||
20110053555, | |||
20110078278, | |||
20110081008, | |||
20110083179, | |||
20110093516, | |||
20110096673, | |||
20110110366, | |||
20110131293, | |||
20110167172, | |||
20110170505, | |||
20110176537, | |||
20110211679, | |||
20110251921, | |||
20110253693, | |||
20110255675, | |||
20110265168, | |||
20110265172, | |||
20110267985, | |||
20110274111, | |||
20110276892, | |||
20110276951, | |||
20110280390, | |||
20110283259, | |||
20110289126, | |||
20110299672, | |||
20110310902, | |||
20110320449, | |||
20110320550, | |||
20120000903, | |||
20120011274, | |||
20120017222, | |||
20120023544, | |||
20120028602, | |||
20120036574, | |||
20120039202, | |||
20120059709, | |||
20120079066, | |||
20120083266, | |||
20120089572, | |||
20120094637, | |||
20120110564, | |||
20120114112, | |||
20120149404, | |||
20120170726, | |||
20120173610, | |||
20120174095, | |||
20120179907, | |||
20120180021, | |||
20120180029, | |||
20120198004, | |||
20120201238, | |||
20120208495, | |||
20120226579, | |||
20120239757, | |||
20120254828, | |||
20120281536, | |||
20120288082, | |||
20120290706, | |||
20120304245, | |||
20120304275, | |||
20120316809, | |||
20120321070, | |||
20130029629, | |||
20130031158, | |||
20130047232, | |||
20130054684, | |||
20130058262, | |||
20130067448, | |||
20130097298, | |||
20130156024, | |||
20130179942, | |||
20130201909, | |||
20130204786, | |||
20130212603, | |||
20130244632, | |||
20140064467, | |||
20140105372, | |||
20140106704, | |||
20140123187, | |||
20140129363, | |||
20140153565, | |||
20140185490, | |||
20140254600, | |||
20140274086, | |||
20140282473, | |||
20140355600, | |||
20140379670, | |||
20150004932, | |||
20150004933, | |||
20150023251, | |||
20150066865, | |||
20150181631, | |||
DE1684587, | |||
EP282126, | |||
EP1464418, | |||
EP1522922, | |||
EP1770586, | |||
ES2134107, | |||
JP10294788, | |||
JP2004166000, | |||
JP2004220118, | |||
JP2006319914, | |||
WO2087804, | |||
WO2006037492, | |||
WO2009018489, | |||
WO2009124223, | |||
WO2010037064, | |||
WO2010040010, | |||
WO2010101935, | |||
WO2011091085, | |||
WO9732448, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jan 07 2015 | Twilio, Inc. | (assignment on the face of the patent) | / | |||
Jan 26 2015 | WOLTHUIS, JOHN | TWILIO, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035064 | /0588 | |
Jan 26 2015 | COOKE, EVAN | TWILIO, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035064 | /0588 | |
Feb 24 2015 | LAWSON, JEFFREY | TWILIO, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035064 | /0588 |
Date | Maintenance Fee Events |
Jan 08 2020 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 09 2024 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Aug 02 2019 | 4 years fee payment window open |
Feb 02 2020 | 6 months grace period start (w surcharge) |
Aug 02 2020 | patent expiry (for year 4) |
Aug 02 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 02 2023 | 8 years fee payment window open |
Feb 02 2024 | 6 months grace period start (w surcharge) |
Aug 02 2024 | patent expiry (for year 8) |
Aug 02 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 02 2027 | 12 years fee payment window open |
Feb 02 2028 | 6 months grace period start (w surcharge) |
Aug 02 2028 | patent expiry (for year 12) |
Aug 02 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |