The present disclosure relates generally to communications systems and more specifically, but not exclusively, to telephony systems for managing call routing.
Conventional telephony systems can provide business solutions ranging from small key telephone systems to large-scale private branch exchanges. Business telephone systems include multiple central office (CO) lines that are directly controllable from multiple telephone stations and provide solutions related to call handling.
For example, a private branch exchange (PBX) is a telephone exchange or switching system that serves a private organization that has many telephone extensions, but fewer telephone lines (often referred to as “trunks”) that connect the organization to a global telecommunications network. Specifically, the PBX performs concentration of central office lines, or trunks, and provides intercommunication between a several telephone stations in the organization. The central office lines provide connections to a public switched telephone network (PSTN) and permits the shared use of these lines between all stations in the organization. Each PBX-connected station, such as a telephone set, a fax machine, or a computer modem, is often referred to as an extension and has a designated extension telephone number that may or may not be mapped automatically to the numbering plan of the central office and the telephone number block allocated to the PBX.
The PBX performs various functions including establishing connections (circuits) between the telephone sets of two users (e.g., mapping a dialed number to a physical phone, ensuring the phone isn't already busy), maintaining such connections as long as the users require them, disconnecting those connections, and providing information for accounting purposes.
Initially, PBX systems offered the primary advantage of cost savings for internal phone calls: handling the circuit switching locally reduced charges for telephone service via central-office lines. However, the expense of full-fledged PBX systems has put them out of reach of small businesses and individuals.
A PBX requires extensive setup, since it controls all routing of calls. Individual extensions have to be defined in the system. For example, an auto-attendant is often required to direct callers to extensions and queues.
As an additional drawback of conventional communication systems, the contact information of the users typically are exposed. For example, the privacy of users of a social media platform can be compromised if a phone number is exposed during an attempted call or communication through the social media platform. Unfortunately, with conventional communication systems, contact information is rarely kept private.
In view of the foregoing, a need exists for an improved communication system and method for secure call routing and queuing in an effort to overcome the aforementioned obstacles and deficiencies of conventional telephony systems.
It should be noted that the figures are not drawn to scale and that elements of similar structures or functions are generally represented by like reference numerals for illustrative purposes throughout the figures. It also should be noted that the figures are only intended to facilitate the description of the preferred embodiments. The figures do not illustrate every aspect of the described embodiments and do not limit the scope of the present disclosure.
Since currently-available telephony management systems are deficient because they fail to route and manage calls without a telephone exchange or switching system—such as a PBX, a communication routing and queueing system that provides a communication management system without the need for agents to be directly connected to a device can prove desirable and provide a basis for a wide range of communications applications, such as communication queueing as a service. This result can be achieved, according to one embodiment disclosed herein, by a communication management system 100 as illustrated in
Turning to
In some embodiments, the calls from the callers 120 are anonymous, with caller identification masked, thereby removing the need for companies to invest in the high cost of a PBX.
In an alternative embodiment and with reference to
Turning to
The communication management system 100 is suitable for use with a wide range of agents 130. In one embodiment, the communication management system 100 can be used with multiple agents 130, such as one or more telephone operators and administrators (shown in
In some embodiments, the agents 130 can log into and out of communication queues through a web server 170 (shown in
The ability for administrators (e.g., administrators 180 and/or agents 130) of the communication management system 100 to monitor their individual queues advantageously provides a self-contained queueing solution. In some embodiments, the agents 130 interact with the web server 170 through a network and software-based architecture. For example, a representational state transfer (REST) system can be used such that a REST application programming interface (API) provides the agents 130 a gateway into the web server 170. An alerting system discussed below can provide alerts including short message service (SMS), electronic mail (e-mail), and telephone calls, which can alert, for example, of not enough agents to service the calls in a queue, and other pre-defined categories. Recording of conversations can also be offered on a queue basis.
Returning to
In some embodiments, the controller 140 communicates with the telephony interface 110 via event sockets. When an event is raised in the telephony interface 110 that has been previously subscribed to by the controller 140, the event will be communicated by the telephony interface 110 to the controller 140 to determine next actions to perform in the call management.
The database 150 is a container of the MVC environment. In some embodiments, the database 150 is implemented using relational databases, including, for example, PostgreSQL. The database 150 maintains the queue of agents 130 and other predefined settings for each application. Furthermore, the database 150 maintains database triggers—such as when there are not enough agents 130 to service calls—where alerts are generated to the agents 130 of the various companies. The controller 140 can manage all communication with the database 150.
In some embodiments, the database 150 maintains tables that include a list of companies, the association of the company and an incoming phone number, the queues of the agents 130, a list of the agents 130 for each queue, and a list of settings for the company, such as hours of operation and whether to record the calls. The queueing table implements any memory management queues and includes, for example first-in/first-out (FIFO) queue with a priority setting. For example, a priority setting includes a flag in the database 150 that indicates whether a selected agent 130 should be chosen to service a call if they are available in the queue. Selected agents 130 have priority as specified by the company will get priority routing to a call 120, then others will get consideration based on length of time they have been waiting in the queue. For example, this can include an index on the queue for the priority flag and inserted time. A queue table can also include incoming callers that want a call back from a selected agent 130, but do not want to wait on the phone. The tables in the database 150 will also provide the view of the status of the system to administrators 180 of the system, such as the number of agents 130 involved in calls in the queue and the number of current available agents available in the queue.
The communication management system 100 can also provide administrative views of the queue functions. In some embodiments, with reference to
The communication management system 100 can route inbound calls 120 in any suitable manner discussed above, including via an exemplary process 4000 for communication management, shown in
At 4010, the inbound calls 120 (shown in
For example, at 4020, the controller 140 queries the database 150, based on the unique telephone number, to identify the respective company that is assigned the unique telephone number. An outbound phone call is made to the next available agent in the queue for the selected company, at 4030.
With reference now to
The telephony interface 110 subsequently answers the call and the controller 140 queries the database 150 for the next available agent, at 5022. In some embodiments, this can include a table lookup for the selected company associated with the unique telephone number as discussed above. Once identified, the selected company can set preferences, create custom greetings, maintain their own queue of agents 130, and so on. Advantageously, this provides a personalized solution for each individual subscriber company for the communication management system 100.
The selected call 120 is routed to the selected agent from 5022, at 5023. In some embodiments, the selected call 120 is routed with additional data received from the call through the telephony interface 110. For example, the caller is played a custom greeting associated with the unique telephone number and may have been asked to enter series of digits for a predetermined menu item. The selected agent 130 is played a recording that identifies a queue identifier, at 5024. For example, the queue identifier can include a company name, the unique telephone number for the company, and/or a queue name (e.g., sales or support). In some embodiments, a selected agent 130 can be associated with one or more queues for one or more companies in the database 150. Accordingly, the queue identifier can include a recording identifying the particular queue that the selected call 120 is coming from and allows the agent 130 to accept the call. The agent 130 is prompted to accept or reject the call, at 5025.
If the agent 130 accepts the call, decision block 5026, the controller 140 directs the telephony interface 110 to connect the inbound and outbound call legs to connect the caller with the agent 130, at 4030. At this point the telephony interface 110 can perform call recording for the duration of the call (not shown). For the duration of the call the agent 130 is taken out of the pool for the available agents for the queue. If the agent refuses the call, at decision block 5026, the selected agent 130 is placed at the end of the queue, at 5027, and is available for another call from the queue.
In some embodiments, an alerting mechanism is initiated from a trigger in the database 150 (or via the controller 140). This trigger inserts records in an alert table (not shown) in the database 150. The Erlang service polls this table in minute intervals and processes the alerts by instructing the telephony interface to send out the alerts to the administrators 180 of the system via SMS, email or phone call. The alert table also acts as a history table, documenting the alerts that were sent.
Turning to
In yet an alternative embodiment, a person can schedule a queue call via an external interface (e.g., via web, SMS message, email, and so on) by sending a REST call to the cloud, including in the call their phone number. The same steps are made to connect the agent and caller in this scenario, however the REST interface directly inserts the caller record in the database.
The described embodiments are susceptible to various modifications and alternative forms, and specific examples thereof have been shown by way of example in the drawings and are herein described in detail. It should be understood, however, that the described embodiments are not to be limited to the particular forms or methods disclosed, but to the contrary, the present disclosure is to cover all modifications, equivalents, and alternatives.
This application is a continuation of and claims priority to U.S. application Ser. No. 17/576,369, which was filed Jan. 14, 2022, and claims priority to U.S. application Ser. No. 15/143,286, which was filed Apr. 29, 2016, and claims priority to U.S. Provisional Patent Application No. 62/154,597, which was filed Apr. 29, 2015, and to U.S. Provisional Patent Application No. 62/234,421, which was filed Sep. 29, 2015. The disclosure of the patent applications are herein incorporated by reference in their entirety and for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
6173052 | Brady | Jan 2001 | B1 |
6327363 | Henderson et al. | Dec 2001 | B1 |
6373937 | Yegoshin | Apr 2002 | B1 |
6654815 | Goss et al. | Nov 2003 | B1 |
7899177 | Bruening et al. | Mar 2011 | B1 |
7929685 | Boyet et al. | Apr 2011 | B1 |
8582475 | Marghescu et al. | Nov 2013 | B1 |
8625760 | Peden | Jan 2014 | B1 |
8693655 | Chau et al. | Apr 2014 | B1 |
9338289 | Goyal et al. | May 2016 | B1 |
9560210 | Noble, Jr. | Jan 2017 | B1 |
20030147519 | Jain et al. | Aug 2003 | A1 |
20030198326 | Wei | Oct 2003 | A1 |
20030231647 | Petrovykh | Dec 2003 | A1 |
20040081309 | Bickford et al. | Apr 2004 | A1 |
20060126816 | Shaffer et al. | Jun 2006 | A1 |
20070064895 | Wong | Mar 2007 | A1 |
20070258576 | Klein et al. | Nov 2007 | A1 |
20080025488 | Dean et al. | Jan 2008 | A1 |
20080126216 | Flensted-Jensen et al. | May 2008 | A1 |
20080187117 | Maugars | Aug 2008 | A1 |
20080275788 | Altberg et al. | Nov 2008 | A1 |
20090003539 | Baird | Jan 2009 | A1 |
20090122972 | Kaufman et al. | May 2009 | A1 |
20090296694 | Kalyanpur et al. | Dec 2009 | A1 |
20100232594 | Lawson et al. | Sep 2010 | A1 |
20110142218 | Kosaraju et al. | Jun 2011 | A1 |
20110307547 | Backer et al. | Dec 2011 | A1 |
20120100830 | Barber | Apr 2012 | A1 |
20120114112 | Rauschenberger | May 2012 | A1 |
20120314847 | Jaiswal et al. | Dec 2012 | A1 |
20120321070 | Smith et al. | Dec 2012 | A1 |
20130022194 | Flockhart | Jan 2013 | A1 |
20130070918 | Siminoff | Mar 2013 | A1 |
20130129075 | Whitaker | May 2013 | A1 |
20130183949 | Sulmar | Jul 2013 | A1 |
20130218983 | Richard | Aug 2013 | A1 |
20130223616 | Segall et al. | Aug 2013 | A1 |
20130336472 | Fahlgren et al. | Dec 2013 | A1 |
20140307863 | Snyder et al. | Oct 2014 | A1 |
20150016600 | Desai et al. | Jan 2015 | A1 |
20150281435 | Charlson | Oct 2015 | A1 |
20160180381 | Kaiser et al. | Jun 2016 | A1 |
20170118329 | Hou | Apr 2017 | A1 |
Number | Date | Country | |
---|---|---|---|
20230396708 A1 | Dec 2023 | US |
Number | Date | Country | |
---|---|---|---|
62234421 | Sep 2015 | US | |
62154597 | Apr 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17576369 | Jan 2022 | US |
Child | 18451761 | US | |
Parent | 15143286 | Apr 2016 | US |
Child | 17576369 | US |