The present invention relates in general to distributed telephony and, more particularly, to systems and methods for providing voicemail features in a distributed Voice-over-Internet Protocol (VoIP) system.
VoIP systems route voice conversations and other telecommunications over the Internet or other packet switched networks. A distributed VoIP system includes a distributed set of switches and servers that provide applications enabled by the integration of computer systems with telephony services. Computer-integrated features rely not only on a server's application platform, but also on the availability of the network that connects the switches and servers.
In a conventional distributed VoIP system data is stored on hard disk drives. The data may include voicemail messages and other data such as mailbox information, recorded names and greetings of users, system prompts, automated attendant menus and prompts, work group greetings and prompts, music on hold files, video files, and recorded conference call files. As examples, voicemail systems often store the spoken name of each user. The recorded name of a user may be played when a message from that user is listened to. Most voicemail systems also include system prompts, which are pre-recorded prompts that are arranged to guide users and/or callers in accessing and using the features of the voicemail system. Some voicemail systems include hundreds of system prompts, each of which may be stored in as many of fifteen or more different languages.
The performance and reliability of a distributed VoIP system can be increased by keeping a portion of the data consistent across all servers. For example, each server in a conventional distributed VoIP system stores the recorded name of each user in the system as well as the system prompts for the entire system. Each server has access to the data and can backup other servers, thus eliminating single points of failure. Performance is increased by locating servers relatively close geographically to users thus reducing network delays.
Because VoIP systems are highly scalable and can provide communication features to large numbers of users, the resources necessary to provide the required performance and reliability are significant. For example, a large company with thousands of employees scattered across many sites would traditionally have one or more switches and servers at each site, and each server would store at least a portion of the data for the entire VoIP system. Even systems with a relatively small number of users usually have hundreds of system prompts in many different languages stored on each server. The upfront costs and ongoing maintenance costs of providing these resources can be prohibitive.
Thus, there is a general need in the art for improved systems and methods for providing voicemail features in a distributed VoIP system.
In accordance with an embodiment of the invention, a distributed VoIP system includes a first switch coupled to a network and configured to provide voicemail features to a first group of one or more users. The system also includes a voicemail server coupled to the network. The voicemail server is configured to provide voicemail features to a second group of one or more users. The first switch is configured to store voicemail data associated with only the first group, and the voicemail server is configured to store voicemail data associated with both the first and second groups.
In one embodiment, the voicemail data includes recorded names.
In another embodiment, the first switch is an integrated switch/voicemail server.
In another embodiment, the system includes a terminal that is coupled to the voicemail server and is configured to display usage of the voicemail features in the distributed VoIP system.
In yet another embodiment, the first switch is configured to store system prompts only in languages associated with the one or more users in the first group, and the second switch is configured to store system prompts in languages available in the distributed VoIP system.
In accordance with another embodiment of the invention, voicemail data is provided to a first user in a distributed VoIP system as follows. A request is received at an integrated switch/voicemail server to provide voicemail data to a first user. If the voicemail is not in memory of the integrated switch/voicemail server, the voicemail data is requested from a voicemail server.
In one embodiment, the switch/voicemail server is associated with a first group of one or more users, and the switch/voicemail server stores the voicemail data associated with only the first group.
In another embodiment, the voicemail server is associated with a second group of one or more users, and the voicemail server stores voicemail data associated with both the first and second groups.
A further understanding of the nature and advantages of the present invention may be realized by reference to the remaining portions of the specification and the drawings.
In accordance with embodiments of the present invention, a switch/voicemail server provides voicemail features to users in a distributed VoIP system. The switch/voicemail server also manages or directs the communications of the devices associated with the users. In one embodiment, the switch/voicemail server may be an integrated device with a smaller footprint and less storage than a voicemail server. In some embodiments, the switch/voicemail server does not store the voicemail data for the entire VoIP system, but instead may request voicemail data from a voicemail server. In other embodiments, the switch/voicemail server may transfer requests for voicemail data to a voicemail server. Thus, embodiments of the present invention may reduce system resources and costs compared to conventional distributed VoIP systems. As such, the integrated switch/voicemail server may be advantageously used to provide telephony services to smaller offices or remote sites that are part of a distributed VoIP system. These and other features and advantages of the invention, as well as other embodiments of the invention, are described in more detail below.
The system shown in
As shown in
Switch 104 may also manage or direct the communications of the components that are linked to switch 104, as well as manage the state and connections of these components. In some embodiments, switch 104 may perform the same functions for the components that are linked to switch/voicemail server 122 in the event of a failure of switch/voicemail server 122.
Endpoints 110, 112, 114 and endpoints 126, 128 are communication devices that allow a user to communicate by making or receiving phone calls, voice messages, and/or other types of communications. For example, an endpoint may enable a user to carry on a phone call and may include a user interface to convey data to and receive data from the user. The endpoints may include one or more IP phones, soft phones, analog phones, button boxes, or other communication devices. Although
As shown in
In some embodiments, voicemail server 106 may also be configured as a secondary provider of voicemail features to endpoints 126, 128. As such, voicemail server 106 may store in memory at least a portion of the voicemail data for endpoints 126, 128. Alternatively, at least a portion of the voicemail data for endpoints 126, 128 may be stored in data storage 108. For example, the recorded names of the users associated with endpoints 110, 112, 114 and endpoints 126, 128 may be stored in memory of voicemail server 106 and/or in data storage 108. Additionally, the system prompts, automated attendant menus, work group greetings and prompts, music on hold files, video files, and recorded conference call files for the entire system may be stored in memory of voicemail server 106 and/or in data storage 108. As used herein, automated attendant menus include both automated attendant menus and automated attendant prompts.
Voicemail server 106 typically includes familiar software and hardware components. For example, voicemail server 106 may include an operating system, processor, local memory for storage, I/O devices, and a system bus interconnecting the components. RAM and disk drives are examples of local memory for storage of data and computer programs. Other types of local memory include magnetic storage media, optical storage media, flash memory, networked storage devices, and the like. In some embodiments, voicemail server 106 may include more than one server (e.g. server cluster).
In some embodiments, voicemail server 106 may be linked directly to data storage 108 as shown in
The components of the VoIP system at first site 100 may be linked indirectly to one or more other groups of components via network 118. For example, as shown in
The group of components at second site 101 may include switch/voicemail server 122 and endpoints 126, 128. Switch/voicemail server 122 may be configured to perform some of the same functions as switch 104. For example, switch/voicemail server 122 may be linked to PSTN 130 and act as a gateway for calls between PSTN 130 and endpoints 126, 128. Switch/voicemail server 122 may also manage or direct communications of the components of the VoIP system that are linked to switch/voicemail server 122, as well as manage the state and connections of these components. In some embodiments, switch/voicemail server 122 may perform the same functions for the components of the VoIP system that are linked to switch 104 in the event of a failure of switch 104.
Switch/voicemail server 122 may also be configured to implement some of the same features as voicemail server 106. For example, switch/voicemail server 122 may be configured to provide voicemail features to endpoints 126, 128, or those communication devices linked to switch/voicemail server 122. As explained more fully below, switch/voicemail server 122 may store in local memory the voicemail messages and voicemail data associated with endpoints 126, 128. Alternatively, the voicemail messages and/or the voicemail data may be stored in data storage. The voicemail data may include recorded names of the users associated with endpoints 126, 128, system prompts in languages associated with the users of endpoints 126, 128, system prompts in languages that are selected by a system administrator, automated attendant menus configured for switch/voicemail server 122, and other data.
Switch/voicemail server 122 typically includes familiar software and hardware components. For example, switch/voicemail server 122 may include an operating system, processor, local memory for storage, I/O devices, and a system bus interconnecting the components. RAM and disk drives are examples of local memory for storage of data and computer programs. Other types of local memory include magnetic storage media, optical storage media, flash memory, networked storage devices, and the like. In some embodiments, switch/voicemail server 122 may be linked to data storage (as shown in
Switch/voicemail server 222 may be configured to perform some of the same functions as switch/voicemail server 122 of
In some embodiments the switch/voicemail server may be configured to automatically update the system prompts it stores. For example, if the switch/voicemail server provides voicemail features to a user who is associated with a particular language, and the system prompts in that particular language are not stored by the switch/voicemail server, the switch/voicemail server may retrieve the system prompts in that language from a voicemail server. Similarly, if there are no users associated with a particular language and there are system prompts associated with that language stored on the switch/voicemail server, the switch/voicemail server may remove the system prompts in that language from memory.
As shown in
Similar to the embodiment of
In step 402 a request is received to provide voicemail data to a user. As an example, a request to play a recorded name may be generated when a user accesses a voicemail message, or when one user sends a message to another user. As other examples, a request to play a recorded name or greeting may be generated when a call goes to voicemail, or when a user requests a time stamp on a voice message. There are many other scenarios where a request for voicemail data may be generated, and the scope of the invention is not limited to the examples provided herein. The voicemail data may also include system prompts, automated attendant menus, work group greetings and prompts, music on hold files, video files, recorded conference call files, and other data. In one embodiment, the request may be received by a switch/voicemail server. Step 404 involves determining if the voicemail data is in memory. In some embodiments, the memory may be local memory. In other embodiments, the memory may be external data storage. In step 406, if the voicemail data is not in memory, the voicemail data is requested from a voicemail server. In some embodiments, each switch/voicemail server may be associated with a particular voicemail server for requesting voicemail data. In step 408 the voicemail data is received from the voicemail server. In step 410 the voicemail data is provided to the user.
In some embodiments, if the voicemail data is not received from the voicemail server within a period of time, an extension may be provided instead of the voicemail data. An extension is the phone number or extension of the communication device associated with the request. For example, when a user accesses a voicemail message, the integrated switch/voicemail server may play the recorded name of the person who left the message. However, if the switch/voicemail server does not have the recorded name in memory, and the recorded name is not provided by the voicemail server within a period of time, the extension of the person who left the message may be provided to the user. The period of time may be preset for the VoIP system, or it may be a period of time, for example two seconds, selected for the switch/voicemail server by a system administrator.
In step 502 a request to access voicemail data is received. As an example, a request to access an automated attendant menu may be generated by a user who is accessing some of the features of the voicemail system. The request may be generated by a call to the voicemail system. The voicemail data may also include recorded names, system prompts, work group greetings and prompts, music on hold files, video files, recorded conference call files, and other data. In one embodiment, the request may be received by a switch/voicemail server. Step 504 involves determining if the voicemail data is configured for the switch/voicemail server. For example, a switch/voicemail server may store only the automated attendant menus that are configured for the switch/voicemail server. In step 506, if the voicemail data is not configured for the switch/voicemail server, the request is transferred to a voicemail server. In some embodiments each switch/voicemail server may be associated with a particular voicemail server for transferring requests for voicemail data. In one embodiment, the switch/voicemail server stores only the voicemail data that is configured for the switch/voicemail server, and the voicemail server stores the voicemail data configured for the VoIP system.
In some embodiments, the switch/voicemail server may provide system prompts in all of the languages provided by the voicemail servers using a method similar to that illustrated in
In embodiments where the switch/voicemail server has less storage than a voicemail server, it may be useful to monitor the usage of the voicemail system. Accordingly, some embodiments of the invention provide systems and methods to monitor usage and administer storage limits of the voicemail features in the distributed VoIP system. For example, as shown in TABLE 1 below, data from each voicemail server and switch/voicemail server in a distributed VoIP system can be assembled and displayed. In one embodiment, an application collects the data from each server. The data may then be displayed on a terminal that is linked to one of the voicemail servers in the VoIP system. In the example shown in TABLE 1, the number of mailboxes, the number of messages, the total space used, and the free space are shown for each server in the system. This system includes a voicemail server and a switch/voicemail server. This example also shows when the last successful backup of the voice messages and voicemail data occurred for each server. “Null” is listed for the voicemail server because the voicemail server is backed up to data storage on a regular schedule. The date and time of the last successful backup to data storage is listed for the switch/voicemail server. Other embodiments may include more or fewer categories of data.
In addition to the system level data, detailed data on each server can be assembled and displayed in some embodiments. For example, TABLE 2 below shows detailed data for a particular voicemail server or switch/voicemail server. This example shows the number of mailboxes and the number of voicemail messages. Also shown is the space used for voicemail messages, recorded names, automated attendant menus, and logs and other data. This example also includes the space used and the remaining free space. Other embodiments may include more or fewer categories of data.
As another example, TABLE 3 below shows detailed data for a particular server on a per-user basis. Here, the data includes each user's name, mailbox number, user group, and free space (far right column). Also included is the total number of messages in each user's mailbox, the number of unheard messages, and the allowed number of messages. Also included is the time in days since the user received the oldest message or saved a message and the allowed time limit. Also included is the time in days since the oldest message was listened to and the allowed time limit. In some embodiments, a system administrator may control usage of the system by altering the limits shown in TABLE 3. For example, if the free space on the server is low, the time allowed for saved or unheard messages can be reduced. In other embodiments, the data can be continuously monitored by each server and flags can be automatically generated and sent to an administrator according to known techniques. Many other uses of the data and methods for administering the usage limits would be apparent to one of ordinary skill in the art.
The systems and methods for providing voicemail features in a distributed VoIP system according to embodiments of the present invention enjoy, among other advantages, distributed VoIP features such as reduced network delay (an integrated switch/voicemail server can be located geographically close to users at smaller remote sites), reduced system resources (an integrated switch/voicemail server can include fewer resources than separate switch, server, and storage components), reduced upfront and maintenance costs (reduced resources can have lower upfront and maintenance costs), system-wide knowledge (a switch/voicemail server can request voicemail data from voicemail servers), a smaller footprint (footprint of integrated switch/voicemail server can be reduced compared to separate switch, server, and storage components), and the ability to easily monitor system usage and administer storage limits.
It is to be understood that the systems shown in
In
While the present invention has been described in terms of specific embodiments, it should be apparent to those skilled in the art that the scope of the present invention is not limited to the embodiments described herein. For example, the features of one or more embodiments of the invention may be combined with one or more features of other embodiments without departing from the scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. The scope of the present invention should be determined not with reference to the above description, but should be determined with reference to the appended claims along with their full scope of equivalents.