US20060177009A1 - Integrated multi-media communication system - Google Patents
Integrated multi-media communication system Download PDFInfo
- Publication number
- US20060177009A1 US20060177009A1 US11/053,271 US5327105A US2006177009A1 US 20060177009 A1 US20060177009 A1 US 20060177009A1 US 5327105 A US5327105 A US 5327105A US 2006177009 A1 US2006177009 A1 US 2006177009A1
- Authority
- US
- United States
- Prior art keywords
- message
- server
- messaging
- information
- network
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 230000006854 communication Effects 0.000 title claims abstract description 184
- 238000004891 communication Methods 0.000 title claims abstract description 180
- 238000012546 transfer Methods 0.000 claims description 58
- 230000009471 action Effects 0.000 claims description 53
- 230000004044 response Effects 0.000 claims description 48
- 238000000034 method Methods 0.000 claims description 42
- 230000008878 coupling Effects 0.000 claims description 32
- 238000010168 coupling process Methods 0.000 claims description 32
- 238000005859 coupling reaction Methods 0.000 claims description 32
- 230000001276 controlling effect Effects 0.000 claims description 11
- 230000001413 cellular effect Effects 0.000 claims description 5
- 238000001914 filtration Methods 0.000 claims description 2
- 238000010586 diagram Methods 0.000 description 18
- 230000008569 process Effects 0.000 description 17
- 230000006870 function Effects 0.000 description 14
- 230000000875 corresponding effect Effects 0.000 description 10
- 230000015654 memory Effects 0.000 description 10
- 238000007726 management method Methods 0.000 description 8
- 238000013507 mapping Methods 0.000 description 7
- 238000012545 processing Methods 0.000 description 7
- 239000008186 active pharmaceutical agent Substances 0.000 description 5
- 229920001690 polydopamine Polymers 0.000 description 4
- 230000011664 signaling Effects 0.000 description 4
- 101100113084 Schizosaccharomyces pombe (strain 972 / ATCC 24843) mcs2 gene Proteins 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 230000010354 integration Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 239000004065 semiconductor Substances 0.000 description 3
- -1 MCS3 Proteins 0.000 description 2
- 101100545229 Saccharomyces cerevisiae (strain ATCC 204508 / S288c) ZDS2 gene Proteins 0.000 description 2
- 101100114859 Schizosaccharomyces pombe (strain 972 / ATCC 24843) crk1 gene Proteins 0.000 description 2
- 101100022564 Schizosaccharomyces pombe (strain 972 / ATCC 24843) mcs4 gene Proteins 0.000 description 2
- 101100167209 Ustilago maydis (strain 521 / FGSC 9021) CHS8 gene Proteins 0.000 description 2
- 230000006399 behavior Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 239000002184 metal Substances 0.000 description 2
- 229910044991 metal oxide Inorganic materials 0.000 description 2
- 150000004706 metal oxides Chemical class 0.000 description 2
- 108010041420 microbial alkaline proteinase inhibitor Proteins 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 150000003839 salts Chemical class 0.000 description 2
- 102100024412 GTPase IMAP family member 4 Human genes 0.000 description 1
- 101000833375 Homo sapiens GTPase IMAP family member 4 Proteins 0.000 description 1
- 101001094649 Homo sapiens Popeye domain-containing protein 3 Proteins 0.000 description 1
- 101000608234 Homo sapiens Pyrin domain-containing protein 5 Proteins 0.000 description 1
- 101000578693 Homo sapiens Target of rapamycin complex subunit LST8 Proteins 0.000 description 1
- XUIMIQQOPSSXEZ-UHFFFAOYSA-N Silicon Chemical compound [Si] XUIMIQQOPSSXEZ-UHFFFAOYSA-N 0.000 description 1
- 102100027802 Target of rapamycin complex subunit LST8 Human genes 0.000 description 1
- 230000004913 activation Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000003542 behavioural effect Effects 0.000 description 1
- 239000000969 carrier Substances 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 229920000547 conjugated polymer Polymers 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 238000011982 device technology Methods 0.000 description 1
- 230000009977 dual effect Effects 0.000 description 1
- 230000005669 field effect Effects 0.000 description 1
- 230000014509 gene expression Effects 0.000 description 1
- 230000008676 import Effects 0.000 description 1
- 238000010348 incorporation Methods 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000001537 neural effect Effects 0.000 description 1
- 229920000642 polymer Polymers 0.000 description 1
- 229910052710 silicon Inorganic materials 0.000 description 1
- 239000010703 silicon Substances 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
- 230000001755 vocal effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M3/00—Automatic or semi-automatic exchanges
- H04M3/42—Systems providing special services or facilities to subscribers
- H04M3/50—Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
- H04M3/53—Centralised arrangements for recording incoming messages, i.e. mailbox systems
- H04M3/5307—Centralised arrangements for recording incoming messages, i.e. mailbox systems for recording messages comprising any combination of audio and non-audio components
Definitions
- the disclosure herein relates generally to communication systems, and more particularly to integrated communication and messaging systems.
- An enterprise can be any collection of users of communication media having some common purpose, but a typical example is a company with one or more sites and some number of employees who are users of communication media.
- Communication media include electronic mail (“email”) messaging, Short Messaging Service (“SMS”) messaging, voice messaging, and more.
- SMS Short Messaging Service
- Users receive and send messages over a variety of wired and wireless networks via a variety of devices, such as desktop computers, wired phones, wireless devices (e.g., phones and personal digital assistants (“PDAs”)), and more.
- PDAs personal digital assistants
- Enterprises currently have the ability to centralize and manage email messaging using commercially available groupware that centrally stores information about all of the users and their messages. Enterprises also have the ability to centrally manage traditional voice messaging using a Private Branch Exchange (“PBX”).
- PBX Private Branch Exchange
- the systems for managing email messaging and the systems for managing voice mail messaging are not at all well integrated. For example, when a new user is added to the enterprise, a system administrator for the enterprise sets up the user in the email system using the groupware application and its set methods, data and protocols. In addition, a different administrator specializing in telephony must set up the user in the voice messaging system using different methods, data and protocols. Voice data and email data are typically stored in separate databases. Both initial user setup and updating user information are complicated by the fact that the email and voice systems are so distinct.
- FIG. 1 is a block diagram of a system that includes an integrated communication system (“ICS”), under an embodiment.
- ICS integrated communication system
- FIG. 2 is a flow diagram for providing integrated communication processes using the ICS, under an embodiment.
- FIG. 3 is a block diagram of example information flows in a system that includes the ICS, under an embodiment.
- FIG. 4 is another flow diagram for providing integrated communication processes using the ICS, under an embodiment.
- FIG. 5 is a block diagram of an enterprise network system that includes a communication server and Interface Module (“IM”) of an ICS, under an embodiment.
- IM Interface Module
- FIG. 6 is a block diagram of an enterprise network system that includes the ICS, under an embodiment.
- FIG. 7 is a block diagram that shows interactions between the IM and components of a messaging server (“MSERV”) environment, under an embodiment.
- MSERV messaging server
- FIG. 8 is an information flow for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment.
- FIG. 9 is an alternative information flow for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment.
- FIG. 10 is an information flow for routing and accessing voice mail messages via the ICS when the MSERV is in an offline state, under an embodiment.
- FIG. 11 is a block diagram of a system that includes the ICS with a Form-Based User Interface (“FBUI”), under an embodiment.
- FBUI Form-Based User Interface
- FIG. 12 is a sample FBUI as displayed on a client device, under an embodiment.
- FIG. 13 is a block diagram of a system that includes multiple sites and multiple components, under an alternative embodiment.
- integrated communication systems integrate different types of messaging so that a user of the ICS can access multiple types of messages (e.g., voice mail messages, electronic mail, email messages, instant messaging messages, SMS (Short Messaging System) messages, MMS (Multimedia Messaging System) messages, etc. with a single message interface.
- messages e.g., voice mail messages, electronic mail, email messages, instant messaging messages, SMS (Short Messaging System) messages, MMS (Multimedia Messaging System) messages, etc. with a single message interface.
- SMS Short Messaging System
- MMS Multimedia Messaging System
- the ICS of an embodiment relieves the dependency of a voice mail system, for example, by providing users with access to voice mail messages and capabilities of the voice mail system through the local groupware applications and email messaging system.
- the ICS generally includes a communication server, a cache system, and an interface module.
- the ICS integrates with a messaging and collaboration system and the corresponding groupware applications in a network environment for example.
- the communication server and interface module function to route a call received from a caller to a user and, in the event the user is not available, to receive and route a voice mail message left by the caller.
- the ICS uses caching processes during the receiving and routing of voice mail messages that provide users with fast access to voice mail messages, user information and contact information. Using caching process, the ICS also provides access to the voice mail messaging system during periods when the messaging and collaboration system is offline.
- the ICS also leverages the storage capability of the messaging and collaboration system to eliminate the need for a separate voice mail database.
- the message interface of the ICS includes a form-based interface for use in retrieving voice mail messages and controlling actions taken on voice mail messages received in the enterprise network system.
- This form-based interface enables a user to retrieve and take various actions on voice mail messages using data of a form provided to the user's client device by the enterprise network email system. Use of the form-based interface thus provides users with access to the integrated messaging functions offered by the ICS without a requirement to install or run a dedicated client application on the user's client device.
- FIG. 1 is a block diagram of a system 10 that includes an integrated communication system (“ICS”) 100 , under an embodiment.
- ICS 100 includes a communication server 110 , an interface module (“IM”) 120 , and a cache system 130 (also referred to as the “cache”), but is not so limited.
- Communication server 110 couples to components of any number of networks 150 and 160 using any of a variety of communication protocols, where networks 150 and 160 may be of the same or of different types.
- Networks 150 and 160 allow for information transfers between various client devices 170 and 199 , also referred to as user devices 170 and 199 .
- IM 120 of ICS 100 couples to transfer information or data with communication server 110 . Additionally, IM 120 couples to transfer information with one or more components of a messaging server 140 , where transferring information includes one or more of pulling, receiving, retrieving, polling, transmitting, and pushing operations, to name a few. As an example of an information transfer between IM 120 and messaging server 140 , IM 120 pulls user information from messaging server 140 and makes the pulled user information available to other components of ICS 100 , wherein the user information includes information relevant to at least network 150 .
- the components of messaging server 140 may include for example one or more processors 142 , also referred to as “central processing units” or “CPUs,” and one or more databases 144 coupled to CPU 142 .
- IM 120 may be hosted on or running under control of messaging server 140 , but is not limited to this configuration.
- messaging server 140 may be a component of network 150 that hosts communication server 10 , but is not so limited.
- messaging server 140 may be hosting a groupware application (e.g., Microsoft Exchange, LotusNotes, etc.) of an enterprise network 150 .
- Cache 130 couples to communication server 110 and communicates to transfer information with one or more of communication server 110 , IM 120 , and one or more components of messaging server 140 , as described below. Cache 130 may also couple to additional components (not shown) of network 150 .
- cache 130 may receive caller information (e.g., voice mail messages, caller identification, etc.) from client devices 199 via communication server 110 .
- caller information e.g., voice mail messages, caller identification, etc.
- An example of information transfers between cache 130 and messaging server 140 includes transfers in which cache 130 receives user information from messaging server 140 , where the user information may be routed from messaging server 140 via IM 120 and/or communication server 110 .
- Another example of information transfers between cache 130 and messaging server 140 includes transfers in which messaging server 140 receives information from cache 130 routed from cache 130 via communication server 110 and/or IM 120 .
- Examples of information transfers between cache 130 and IM 120 include transfers of user information pulled from messaging server 140 by IM 120 and directed to cache 130 , and transfers in which IM 120 directs a message from at least one of messaging server 140 and cache 130 to at least one device on networks 150 and 160 using the user information.
- Cache 130 holds or temporarily stores the received information under the above examples.
- Networks 150 and 160 include various network components (not shown) of one or more communication service providers or carriers, but are not so limited. Further, networks 150 and 160 and corresponding network components can be any of a number/combination of network types known in the art for providing communications among coupled devices 170 and 199 including, but not limited to, proprietary networks, local area networks (“LANs”), metropolitan area networks (“MANs”), wide area networks (“WANs”), backend networks, public switched telephone networks (“PSTN”), the Internet, and other public networks for example. Additionally, networks 150 and 160 may include hybrid networks that use a proprietary network for some portion of the communications routing, for example, while using one or more different public networks for other portions of the communications routing.
- LANs local area networks
- MANs metropolitan area networks
- WANs wide area networks
- PSTN public switched telephone networks
- networks 150 and 160 may include hybrid networks that use a proprietary network for some portion of the communications routing, for example, while using one or more different public networks for other portions of the communications routing.
- Client devices 170 and 199 include communication devices like telephones, cellular telephones, and radio telephones. Client devices 170 and 199 also include processor-based devices like, for example, portable computers (“PC”), portable computing devices, personal digital assistants (“PDA”), communication devices, cellular telephones, portable telephones, portable communication devices, and user devices or units. Client devices can include so-called multi-modal devices, where the user can interact with the device and/or the ICS through any form of input and output, such as text input, speech recognition, text output, text-to-speech, graphics, recorded files and video. In such devices, the speech recognition and text-to-speech generation may partly take place in the device and partly in the ICS.
- PC portable computers
- PDA personal digital assistants
- Client devices can include so-called multi-modal devices, where the user can interact with the device and/or the ICS through any form of input and output, such as text input, speech recognition, text output, text-to-speech, graphics, recorded files and video. In such devices, the speech
- Sound and/or video may be generated by the ICS by a continuous stream of sound and/or video data sent to the device.
- Client devices can include all such devices and equivalents, and are not limited to any particular type of communication and/or processor-based device.
- client devices 170 are client devices operating in a private network environment like an enterprise network
- client devices 199 are client devices operating in different private network environments or under any number of public networks.
- FIG. 2 is a flow diagram for providing integrated communication processes 200 using ICS 100 , under an embodiment.
- Processes 200 include receiving data streams from networks of different types, at block 202 .
- the data streams may include a variety of data including, for example, audio or voice data. Further, the data streams may be received from any number of networks or client devices operating on the networks.
- Processes 200 further include generating messages at a communication server using information of the data streams, at block 204 .
- the generated messages may be any of a number of message types. Returning to the above example in which the received data stream includes audio data, the generated message is a voice mail message, but is not so limited.
- Processes 200 also include transferring the messages, at block 206 .
- the transferring operation includes for example caching information of the messages in the ICS cache and/or forwarding the messages to a messaging server.
- processes 200 include pulling user information from a messaging server coupled to the ICS, at block 208 , as described above.
- the user information includes information relevant to users of at least the network hosting the ICS, but is not so limited.
- Processes 200 also include caching pulled user information from the messaging server, at block 210 .
- processes 200 include use of the user information of the cache to direct a message from at least one of the messaging server and the cache to one or more client devices on any of the networks, at block 212 .
- the ICS of an embodiment integrates different types of messaging so that a user of the ICS can access all of the message types (e.g., voice mail messages, electronic mail or email messages, etc.) with a single message interface (also referred to as a “user interface” or “UI”).
- a single message interface also referred to as a “user interface” or “UI”.
- the ICS of an embodiment relieves the dependency on a voice mail system with a dedicated voicemail and user database, for example, by providing users with access to voice mail messages and capabilities of the voice mail system through the local email messaging system.
- FIG. 3 is a block diagram of example information flows 300 in a system 30 that includes ICS 100 , under an embodiment.
- the system also includes a messaging server 140 and any number of client devices 170 that couple to ICS 100 .
- ICS 100 couples to a communications network 160 .
- ICS 100 , messaging server 140 , and client devices 170 may be hosted under a network 150 , but are not so limited.
- System 30 is shown with one each of ICS 100 , messaging server 140 , and client device 170 for purposes of this description, but may include any number of each of ICS 100 , messaging server 140 , and client device 170 coupled in any combination.
- System 30 may also couple to one or more other systems (not shown) or networks via any number of backend couplings (not shown)
- Components of ICS 100 include a communication server and an interface (not shown).
- the interface of ICS 100 may run under control of messaging server 140 , as described above, but is not so limited.
- Information flow 300 begins when, in response to receiving data streams from networks 160 of different types, ICS 100 generates a first message 302 and transfers first message 302 to messaging server 140 via a communication with messaging server 140 .
- First message 302 may be a voice mail message (“Voice Mail Type” or “VMT”) but is not limited to this type of message.
- VMT Voice Mail Type
- a voice mail message is left by a “caller” to the ICS.
- the VMT may be implemented using “Message Class” and/or “Message Type” fields associated with messages in Microsoft Exchange.
- Second message 312 is of a different type from that of first message 302 , and includes information of first message 302 .
- Second message 312 may for example be an email message but is not limited to this type of message.
- Second message 312 is transferred to a client device 170 via a communication with client device 170 , where the communication uses a communication protocol of network 150 .
- client device 170 determines a type of the second message and requests form data 314 that corresponds to second message 312 .
- Messaging server 140 in response to the request for form data 314 , transfers form data 314 to client device 170 via the second coupling.
- One or more components of ICS 100 generate and/or provide form data 314 for storage in messaging server 140 , and form data 314 is generated under the communication infrastructure of network 150 .
- the form data may be displayed to the user using the corresponding form.
- Client device 170 uses form data 314 to view contents of second message 312 .
- the client device also uses form data 314 to establish communications with communication server 110 (of ICS 100 ) via a third coupling.
- the communication protocol of the third coupling is different than the communication protocol of the second coupling, but is not so limited.
- An “embedded control” controls activation of the third coupling.
- the client device allows a “user” using the client device to direct actions 322 on first message 302 via the third coupling with the ICS using the form data.
- a “user” is an individual with enabled capability to use functions within the ICS.
- FIG. 4 is a flow diagram for integrated communication processes 400 using ICS 100 , under an embodiment.
- Processes 400 include transferring a first message to a messaging server from a communication server via a first coupling, at block 402 .
- Processes 400 also include generating a second message at the messaging server in response to a type of the first message and transferring the second message to a client device via a second coupling, at block 404 .
- the second message may be of a different type than the first message and includes data of the first message.
- Processes 400 further include transferring to the client device form data that corresponds to the first message, at block 406 .
- processes 400 include establishing a third coupling between the client device and the communication server using the form data, at block 408 . Moreover, processes 400 include directing actions on the first message from the client device using the form data, the actions directed via the third coupling, at block 410 .
- the ICS of an embodiment integrates messages of different types to enable a user to access a number of message types through components of the ICS.
- an application of the ICS of an embodiment is as a substitute for a voice mail system in an enterprise network, where the ICS enables a user to receive and/or take action on voice mail messages using the enterprise email system.
- FIG. 5 is a block diagram of an enterprise network system 500 that includes a communication server 110 and IM 120 of an ICS, under an embodiment.
- Communication server 110 couples to at least one messaging server 140 via IM 120 .
- IM 120 runs under messaging server 140 , but is not limited to running under this server.
- Messaging server also couples to one or more databases 144 .
- Messaging server 140 of an embodiment supports the messaging capabilities of enterprise network system 500 using a groupware application (e.g., Microsoft Exchange) (not shown) along with other applications as appropriate to the size and type of enterprise network system 500 .
- Messaging server 140 , database 144 , and groupware application may be referred to as collectively forming a “messaging environment.”
- Communication server 110 couples to any number of client devices 199 external to enterprise network 500 via one or more networks (not shown), as described above with reference to FIG. 1 . Similarly, communication server 110 couples to any number of client devices 170 local to enterprise network 500 .
- Communication server 110 includes an operating system 518 as well as numerous components or subsystems. These components include but are not limited to one or more Voice Applications 512 , an Execution Engine 514 , and any number of Mobile Application Modules 516 , as described below, or any other type of application module.
- FIG. 6 is a block diagram of an enterprise network system 600 that includes an ICS, under an embodiment.
- the ICS includes a communication server 610 as described above, also referred to as a “Messaging Communication Server” or “MCS.”
- MCS may be highly scalable.
- the MCS may be configured as a modular “appliance” that is essentially self-contained, and may be, for example, encased in a stackable, “pizza-box” style server.
- the ICS also includes IM 620 (also referred to herein as the “IM”) and a Management Console 660 .
- the IM which in one embodiment runs under control of a messaging server 640 (also referred to herein as “MSERV 640 ” or “MSERV”), couples to components of the MCS, the MSERV, and a Database 644 (also referred to herein as a “Database”) in a number of sequences as described herein and as appropriate to enterprise network system 600 .
- the IM also couples to MCS Management Console 660 .
- the MCS and the MSERV couple to the LAN for communication with other components (not shown) of enterprise network system 600 .
- the MCS of an embodiment includes an “Operating System” along with an “Execution Engine,” some number of “Voice Applications,” and some number of “Mobile Applications.”
- the Operating System includes for example a Linux kernel with a journaling file system that provides integrity of file system tables and the data structure.
- the storage on the MCS may be configured as a RAID (Redundant Array of Independent Disks) configuration to provide high reliability access to software and data.
- the Operating System supports operations of numerous other components of the MCS as described below.
- the MCS includes a “Telephony Interface” that couples calls and connects callers and users to/from the MCS.
- the Telephony Interface couples call information to/from a private branch exchange (“PBX”) (not shown) for example, where the PBX is a component of enterprise network system 600 .
- PBX private branch exchange
- the Telephony Interface couples to the PBX using a variety of telephony integrations that include one or more of analog, Simplified Message Desk Interface (“SMDI”), T 1 /E 1 , Voice over Internet Protocol (“VOIP”), and Digital Set Emulation (“DSE”) signals, but may couple using other signals/signaling protocols.
- SMSI Simplified Message Desk Interface
- VOIP Voice over Internet Protocol
- DSE Digital Set Emulation
- the MCS When receiving a call from the PBX, for example, the MCS receives data of an incoming call from the PBX, where the data includes called party information, a reason for transfer of call (e.g., called party line busy, no answer by called party, called party using call forwarding, etc.), and calling parting information (caller ID, etc.).
- a reason for transfer of call e.g., called party line busy, no answer by called party, called party using call forwarding, etc.
- calling parting information caller ID, etc.
- a “Driver” couples information received at the Telephony Interface to the “Telephony Services” component of the MCS.
- the Driver may perform low level signaling and/or data conversion as appropriate to the received signals.
- the Telephony Services include one or more components for use in processing the received signals. These components include, for example, voice processing, switching/control, and PBX signaling, but are not limited to these components.
- the MCS of an embodiment includes at least one “Voice Browser” that, when the MCS receives a call, receives voice information of the call.
- the Voice Browser controls the use of automatic speech recognition (“ASR”) for speech recognition and DTMF recognition.
- ASR automatic speech recognition
- the Voice Browser of an embodiment couples to a cache or other temporary store that holds voice recordings and/or name grammars (“Voice Recordings/Grammars”) (the name grammars are cached after being generated from names in a user list, as described below).
- the ASR may use information of the name grammars.
- the Voice Browser controls the use of text-to-speech (“TTS”) as well as the play of any number of pre-recorded prompts (e.g., WAVE format files).
- TTS text-to-speech
- the Voice Browser uses voice extensible markup language (“VXML”) but is not limited to this protocol.
- Alternative embodiments of the MCS may not include the Voice Browser.
- the MCS may directly communicate with, or use other software or processes, for communication between the voice application and the Telephony Services and/or Driver.
- the Virtual Machine, Voice Applications, and Execution Engine form a hierarchical state machine framework in which the Virtual Machine runs a number of APIs and modules. Consequently, the Voice Applications can include one component controlling the user interfaces (“UI”) to the MCS, and another component handling lower-level communications with the modules.
- UI user interfaces
- Use of a loose coupling between the modules and the Voice Browser provided by the state machine framework allows independence between the languages used in the different modules and the Voice Browser.
- the state machine framework may receive hypertext transport protocol (“HTTP”) requests from the Voice Browser, for example, and generate VXML or Speech Application Language Tags (“SALT”) (SALT extends existing mark-up languages such as hypertext markup language (“HTML”), extensible hypertext markup language (“XHTML”), and extensible markup language (“XML”), and enables multimodal and telephony-enabled access to information, applications, and web services from devices like PCs, telephones, and PDAs for example).
- HTTP hypertext transport protocol
- XHTML extensible hypertext markup language
- XML extensible markup language
- XML extensible markup language
- the Voice Applications of an embodiment include a number of components including an automatic attendant, a caller interface, a user interface, and a system main menu, but may include other types of voice applications.
- the automatic attendant is speech enabled, but may be dual tone multi-frequency (“DTMF”)-enabled.
- the automatic attendant which can be enabled or disabled, uses information of contact lists (e.g., User List) in the Cache.
- the Voice Applications also include at least one voice mail application.
- the voice mail application uses information of the Cache (e.g., User List, Global Address List, Public Folders, Personal Contact Folders) in operations that include sending a new voice mail and/or forwarding a received voice mail.
- the voice mail application also uses Cache information in support of voice mail networking in which voice mails and corresponding information are exchanged with groupware applications of enterprise network system 600 , as described below.
- the voice mail application couples to the MCS state machine framework described above via one or more application programming interfaces (“API”).
- API application programming interfaces
- the APIs handle the different data formats/types in use by enterprise network system 600 (e.g., greeting data, PIN (Personal Identification Number) code data, voice mail message data, system parameters, etc.).
- the Cache also couples to the state machine framework, where the Cache includes one or more of local cache and distributed cache. Therefore, communications among the voice mail application, the Cache, and the MSERV take place via the state machine framework and the APIs as appropriate to the state (e.g., offline, online) of the MSERV.
- the modules running under the Virtual Machine of an embodiment include Mobile Applications.
- the Mobile Applications provide access to user information via mobile devices, where the access may include transferring information of email, calendar, and/or contacts to a user's mobile client device via an electronic message (e.g., SMS, MMS, and/or pager).
- an electronic message e.g., SMS, MMS, and/or pager.
- the MCS also includes an “Administration/Configuration” manager.
- the Administration/Configuration manager provides access to and control of a unified configuration file of the MCS.
- the Administration/Configuration manager uses information of the unified configuration file to provide separate Configuration Files to one or more of the components of the MCS as appropriate.
- the unified configuration file can be copied from the MCS and stored for backup purposes. Additionally, a predefined configuration file may be uploaded to the MCS to provide the appropriate configuration for the MCS.
- a browser interface to the Administration/Configuration manager allows remote access to the MCS.
- the MCS also includes a “Self Maintenance Supervisor” or reliability server that monitors MCS components and restarts failed processes when necessary, for example.
- the MCS also includes “Security Restrictions” for use in controlling MCS/port security.
- the MCS of an embodiment interfaces with the MSERV via the IM.
- the MCS communicates with the IM via the Groupware Connector for example, but is not so limited.
- the Groupware Connector of an embodiment includes a “Web Server,” but is not so limited.
- the MSERV functions as a messaging and collaboration server.
- the IM is an interface that runs under the MSERV in one embodiment to provide communications and information transfers between components of the MCS and components of the MSERV. In other embodiments, the IM may run under control of the MCS, for example.
- the IM includes and/or couples with Management Console 660 as well as with a diagnostics component (“Diagnostics Component”) and/or a run time component (“RTC”) (not shown).
- Management Console 660 supports access to the MCS by a system administrator of enterprise network system 600 for purposes of managing user access. Consequently, Management Console 660 allows a system administrator to enable new users with integrated messaging functionality of the ICS and administer and monitor one or more MCSs.
- the Diagnostics Component of the IM supports on-the-fly diagnostics gathering, computing, and/or compiling of pre-specified diagnostics information or parameters from the MSERV. In this manner the MCS may provide diagnostics information and a user may provide dynamically updateable diagnostics information.
- the RTC translates communications between components of the MCS and components of the MSERV.
- the RTC may be used to retrieve user information from the directory service (e.g., Active Directory) of a groupware application in response to a request from the MCS, as described below.
- Communications between the RTC and components of the MCS use for example XML and Web Services.
- Communications between the RTC and the MSERV may use one or more APIs of the MSERV (e.g., MAPI, Collaboration Data Objects (“CDO”), Web Distributed Authoring and Versioning (“WebDAV”), etc.).
- MSERV e.g., MAPI, Collaboration Data Objects (“CDO”), Web Distributed Authoring and Versioning (“WebDAV”), etc.
- the MSERV of an embodiment represents a messaging and collaboration server.
- the messaging and collaboration server includes a groupware application that runs on one or more servers and enables users via local client devices to send and/or receive electronic mail and other forms of interactive communication through computer networks.
- the MCS of an embodiment interoperates with groupware applications that include, but are not limited to, Microsoft Exchange Server, but alternative embodiments may use other types of messaging and collaboration servers. Therefore, the MCS of an embodiment interoperates with client device applications (“client applications”) such as Microsoft Outlook, as well as with other email client applications (e.g., Microsoft Outlook Express).
- client applications such as Microsoft Outlook
- other email client applications e.g., Microsoft Outlook Express
- the MSERV sends and receives email messages through what is commonly referred to as a client device such as a personal computer, workstation, or a mobile device including mobile phones or PDAs.
- client device typically connects to the LAN, which may include any number and/or combination of servers or mainframe computers where the email mailboxes and public folders are stored.
- the centralized servers connect to numerous other types of networks (e.g., private or proprietary, and the Internet) to transmit and receive email messages to other email users. Consequently, the MCS uses the MSERV for storing and forwarding email messages in an embodiment.
- the MSERV also couples to a directory service (not shown), which is a database of information on each user account in the enterprise network system. Access to the directory service may use for example a Lightweight Directory Access Protocol (“LDAP”).
- LDAP Lightweight Directory Access Protocol
- the MSERV provides integrated collaborative messaging features such as scheduling, contact, and task management capabilities.
- MSERV configuration when the MSERV is Microsoft Exchange, the MSERV runs on a version of the Microsoft Windows Server operating system.
- a version of Microsoft Office Outlook runs on Windows-based local client devices and communicates with the MSERV through the messaging application programming interface (“MAPI”) protocol.
- the MSERV also accommodates other client device access by supporting one or more of Post Office Protocol 3 (“POP3”) and Internet Message Access Protocol 4 (“IMAP4”) protocols as well as support for Simple Mail Transfer Protocol (“SMTP”).
- POP3 Post Office Protocol 3
- IMAP4 Internet Message Access Protocol 4
- SMTP Simple Mail Transfer Protocol
- the MCS of an embodiment along with Microsoft Outlook Web Access (a service in Microsoft Exchange) accommodates web browser-based access clients, also referred to as thin clients.
- the MSERV collaboration features support information sharing among users.
- Collaborative scenarios include maintaining shared address lists that all users can view and edit, scheduling meetings that include people and conference rooms by viewing associated free or busy schedules, the ability to grant other people, such as administrators, access to user mailboxes on behalf of the user.
- the IM serves as an interface for the transfer of information between components of the MCS and components of the MSERV. Transferring information includes for example pulling, receiving, retrieving, polling, transmitting, and pushing operations, to name a few.
- the IM pulls information from one or more components of the MSERV and makes the pulled information available to, for example, the MCS Cache.
- the IM also pushes information from one or more components of the MCS to the MSERV.
- the components of the IM translate communications between components of the MCS (e.g., Virtual Machine, Cache, etc.) and components of the MSERV environment.
- the IM retrieves user information from components of the directory service (e.g., Active Directory) in response to a request from the MCS/Cache.
- the directory service e.g., Active Directory
- Embodiments of the IM may include one or more of the following components: an RTC, a Management Console, a desktop component, messaging actions control component, Diagnostics Component and/or a message waiting indication component.
- the desktop component allows the user to configure aspects of the user's integrated messaging account, such as voice message greetings, extended absence greeting, PIN code data, and presence information.
- the messaging actions control component receives and responds to user generated requests from the FBUI (defined herein) to take actions such as playing, replaying to and forwarding voice messages, as well as calling the sender of a voice mail message.
- the message waiting indication component receives events from the user's message inbox folder and requests corresponding action from the PBX or other aspect of the telephony system, such turning on message waiting indicators on the user's device(s).
- the message waiting indication component may send notifications by way of SMS, MMS and/or pager.
- FIG. 7 is a block diagram 700 that shows interactions between the IM and components of the MSERV environment 740 , under an embodiment.
- the components of MSERV environment 740 include the MSERV and one or more Databases as described above.
- the Database of an embodiment includes a directory service 742 .
- Directory service 742 provides a location for storage of information about network-based entities, such as applications, files, and printers to name a few. Directory service 742 also stores information about individuals, also referred to as users, and this information is referred to herein as “User Information.” As such directory service 742 provides a consistent way to name, describe, locate, access, manage, and secure information about individual resources in an enterprise network environment. Directory service 742 uses the stored information to act as the main switchboard of the enterprise network operating system and is therefore the central authority that manages the identities and brokers the relationships between distributed resources of the enterprise network, thus enabling the resources to work together. Directory service 742 of an embodiment may be Microsoft Active Directory (“AD”), but is not so limited.
- AD Microsoft Active Directory
- the user object for enterprise USER 2 is shown as USER 2 object 702 .
- the user object includes many fixed attributes such as user name, user phone number, user mailbox location, and user email address.
- the user object further includes a number of “Custom Attributes.”
- the number of Custom Attributes is small, for example fifteen, compared to the number of fixed attributes.
- the Custom Attributes are usable to store information not provided for in the predefined fixed attributes.
- a Custom Attribute stores user-specific data that is used by the Voice Applications. Examples of such user-specific data include a class of service (“COS”) for the user, a voice mail extension for the user, whether voice mail is enabled for the user, etc.
- COS class of service
- the data is stored as a data stream in the Custom Attribute with a maximum size of 2048 bytes.
- the user-specific data that is used by the Voice Applications is stored as individual data items in fixed attributes by extending AD in a known manner.
- the user mailbox location fixed attribute indicates where the user's email mailbox is stored in the enterprise. In some large enterprises, there may be many MSERVs, each including a database storing many user mailboxes. As shown, the mailbox location fixed attribute points to USER 2 mailbox 704 on an MSERV called MSERV 1 .
- User mailbox 704 stores email messages sent to the user, as well as outgoing messages and other items, for predetermined periods of time.
- the messages can be of at least two types, one of which is a “normal” message that is routinely accessible by the user. Another message type is a “hidden” message that is not routinely accessible by the user through the normal user email interfaces.
- a hidden message is used to store data used by the Voice Applications. In contrast to the data stored in the Custom Attribute, however, the data stored in the hidden message can be much larger than the 2048 byte limit of the custom attribute.
- audio files stored as attachments to the hidden message such as a “busy” greeting for the user's voice mail mailbox, a “no answer” greeting for the user's voice mail mailbox, and a recorded name for the user's voice mail mailbox.
- An example of the MCS accessing the MSERV environment 740 through IM 620 is a phone caller calling the voice mail mailbox of USER 2 when USER 2 is on the phone.
- the MCS transmits an action via IM 620 with a request to “play busy greeting.”
- the transmission includes information to access the USER 2 object 702 fixed attributes to determine the user's email mailbox location.
- the transmission includes information to access the USER 2 object 702 Custom Attribute and to transfer the contents of the Custom Attribute to the MCS via IM 620 .
- the hidden message is opened to transfer the appropriate audio file (“busy” greeting in this case) to the MCS for playing over the phone to the caller.
- operations of the Voice Applications and the Virtual Machine couple the Cache and other components of the MCS to components of the MSERV via the IM.
- the MCS and the IM support the transfer of information between the Cache and backend network components like the MSERV and the database.
- This configuration provides transparency between the Voice Applications and data stored in the database when using information of the database to support voice mail messaging functions of the MCS, as described below.
- the information transfers between the Cache and the MSERV along with use of the Custom Attributes and Hidden Messages as described above allow the ICS to overcome the need for an external database to store information stored by a typical voice mail system. This is because the information used by the MCS in providing voice mail message capabilities integrated with the email messaging capabilities of the enterprise network is pulled by the MCS from the MSERV via the IM. The pulling or retrieving may be performed periodically, continually, on demand, and/or in response to particular events (e.g., update of the information in the MSERV) but is not so limited.
- the information pulled by the MCS includes information of a “Global Address List” (“GAL”), information of one or more “Public Folders,” “Personal Contacts,” and information of a “User List.”
- GAL Global Address List
- the GAL includes information of all users in the enterprise network having access privileges that include the use of email.
- Public Folders include information of the network enterprise (e.g., contacts, calendars, etc.) that are shared with all users.
- the Personal Contacts include contact information for each user.
- the User List includes User Information for a subset of users in the GAL each of whom has access privileged that include the use of the ICS.
- the User List therefore is a subset of the GAL and is retrieved and/or cached as a separate list or stream in order to improve efficiency of communications and minimize the delays associated with having the MCS search the entire contents of the GAL for information used in executing a user-requested action on a voice mail message.
- the User List of an embodiment includes one or more of the following parameters corresponding to each user, but is not limited to these parameters: Site identification, mail box number, pronounceable name, office telephone extension, COS, automatic attendant state (e.g., enabled, disabled), voice mail state (e.g., enabled, disabled), Voice User Interface (“VUI”) state (e.g., enabled, disabled), mobile access state (e.g., enabled, disabled), bad logins, locked out, attendant destination, force change of PIN code, mobile gateway identification, full name, first name, last name, user name, home telephone number, office telephone number, cellular telephone number, identification, email address, department, active greeting state, time and date announcement, voice mail notification state (e.g., enabled, disabled), mail box status, PIN code in encrypted or raw form, no answer greeting, busy greeting, extended absence greeting, recorded name, and system greeting.
- VUI Voice User Interface
- the pulled information is pushed by the IM to the MCS and held in the Cache.
- the MCS uses the pulled information in subsequent voice mail message manipulation operations as described below. This pulling and caching of information by the MCS improves the speed and efficiency of voice mail message operations and prevents unnecessary loads on the MSERV resulting from the nearly continuous stream of read requests to the MSERV database in typical messaging systems.
- the pulling of information from the MSERV by the MCS includes pulling and caching of information including the GAL, Public Folder, and User List.
- the pulled information is cached by the MCS on a system or non-individual basis because this information applies throughout the enterprise. This information is pulled and cached periodically, for example at 24-hour intervals (e.g., each morning at 2:00 am), or may be loaded on demand, but is not so limited.
- the MCS pulls and caches information of the Personal Contacts on a per user basis because this information is different for each user.
- the Personal Contacts may be requested and cached by the MCS periodically or on demand (e.g., at the time a user logs in to the ICS, in response to modifications of the Personal Contacts, etc.).
- the MCS and the IM function to route a call placed by a caller to a user and, in the event the user is not available, to receive and route a voice mail message left by the caller.
- the MCS and the IM also function to provide a user with access to voice mail messages using the messaging server of the enterprise email system.
- the voice mail access supports both online and offline modes of the messaging server.
- the MCS receives and detects a call at the Telephony Interface.
- Data of the call e.g., called party information, calling party information, reason for call transfer, etc.
- the Voice Browser transfers a request to the Voice Applications in response to the call data.
- a Dispatcher component of the Voice Applications routes the call to one or more other Voice Application components in accordance with information of the User List.
- the Dispatcher identifies the target user for the call, and determines whether the target user's automatic attendant is enabled. If the automatic attendant is enabled then the automatic attendant receives the call request and provides the caller with one or more call routing options (e.g., caller selects call routing by selecting and/or saying extension number, selecting and/or saying name, etc.) and routes the call according to the caller's input.
- call routing options e.g., caller selects call routing by selecting and/or saying extension number, selecting and/or saying name, etc.
- one or more of the Voice Applications determine an active greeting currently designated by the user for use in responding to calls (e.g., system greeting, no answer greeting, busy greeting, extended absence greeting, etc.), and retrieve the designated active greeting from one of the Cache or MSERV as appropriate to a state of the MSERV.
- the respective application(s) play the greeting, activate a “record mode” to record the voice mail message of the caller, and provide the caller with additional options available for call and/or message routing (e.g., message marking options, message delivery options, send message, route message to additional users, etc.).
- the respective application(s) Upon completion of the recording and/or selection of a message routing option by the caller, the respective application(s) terminate the call (hangs up) and transfer the recorded voice mail message to one or more locations in the Cache and/or MSERV (e.g., a mail box) that correspond to the user, as described below with reference to FIGS. 8, 9 , and 10 .
- the voice mail message may be transferred before the application terminates the call.
- the MCS of an embodiment in conjunction with the IM supports availability of and access to the voice mail applications when the MSERV is both “online” and “offline” through the use of the Cache.
- the MCS of an embodiment includes an “Offline Detector” that monitors an availability state of the MSERV and detects unavailability (“offline condition” or “offline state”) of the MSERV. Upon detecting MSERV unavailability, the MCS transitions to a mode that supports voice mail message recording and retrieval during the MSERV offline condition.
- Caching of select information received and/or generated in the MCS enhances performance of the enterprise network voice messaging system by reducing the instances of data retrieval from the MSERV. Further, caching of select information improves the reliability of the enterprise network voice messaging system by allowing access to the voice messaging system during periods when the MSERV is offline.
- Information received at the MCS is routed and held in the Cache in accordance with policies running in the state machine framework and/or the availability state of the MSERV.
- Examples of information held in the Cache include but are not limited to the User List, Global Address List, information of Public Folders, information of Personal Contact Folders, voice mail message information (both the text description portion and the audio message portion of the voice mail message), greetings, and other user parameters/permissions, and personal information of users (e.g., PIN codes).
- the MCS generally holds information of the recorded message in the Cache.
- the MCS may also transfer the recorded voice mail message via the IM to the MSERV where it is stored in the Database.
- FIG. 8 is an information flow 800 for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment.
- This information flow 800 shows one MCS and one MSERV in an enterprise network environment, but this is shown only as an example and does not limit the network environment to the types, numbers, and/or coupling of components shown as alternative embodiments may have any number of MCSs and/or MSERVs.
- Information flow 800 begins when a caller places a call 802 to a user and availability of the user results in the caller leaving a voice mail message (referred to herein as the “VMSG”) for the user.
- the voice mail message VMSG is received at the MCS and routed 804 C to the Cache where it is assigned an identification (referred to herein as the “CACHEID”) and held.
- the voice mail message VMSG may be held in the Cache for a pre-specified period of time, but the embodiment is not so limited.
- the voice mail message VMSG and the CACHEID are also routed 804 M to the MSERV via the IM, as described above.
- the MSERV assigns an identification (referred to herein as the “VMSGID”) to the incoming voice mail message VMSG and stores 806 the voice mail message VMSG along with the VMSGID and CACHEID in one or more areas of memory (not shown) available to the MSERV.
- Memory may include any various form of storage or computer-readable memories such as, but not limited to, volatile memory (random access memory (“RAM”), non-volatile memory (read-only memory (“ROM”), EEPROM, disk, and/or other storage devices that may include one or more of magnetic and optical storage media.
- the MCS pulls information (e.g., periodically, on demand, etc.) from the MSERV via the IM and uses the pulled information in providing voice mail message capabilities integrated with email messaging capabilities of the enterprise network. Therefore, pulling operations by the IM include pulling of information identifying the stored voice mail message VMSG, where the information identifying the voice mail message VMSG includes but is not limited to the CACHEID.
- the IM may pull 808 a voice mail list (referred to herein as a “VMLIST” 809 ), which includes CACHEIDs and VMSGIDs for any stored messages from the MSERV environment. The IM pushes 810 VMLIST 809 to the MCS where it is held.
- VMLIST 809 may be generated from the user's inbox upon each request from the IM or may be stored and maintained in the MSERV or in the cache as a current representation of the contents of a user's voice mailbox, or inbox. If and when a time period for holding a VMSG in the Cache expires, the VMSG is still identifiable from VMLIST 809 , and can be found in the MSERV if requested, using the VMSGID.
- Information flow 800 continues when a user accesses 820 the enterprise network system to retrieve his/her voice mail messages.
- the user access 820 causes the VMLIST to be pulled 808 from the MSERV and pushed 810 by the IM to the Cache, and also or alternatively to the MCS
- the user selects one or many voice mail message(s) by selecting a VMSGID/CACHEID item from the VMLIST.
- MCS searches 822 the Cache for a message, using the Cache identification CACHEID of the selected message.
- the MCS will locate the CACHEID and the message contents VMSG in the Cache. Once located through use of the CACHEID, the MCS retrieves 814 R the voice mail message contents VMSG from the Cache, and plays the voice mail message for the user as appropriate to the action selected by the user.
- the mapping includes a mapping of voice mail message contents to identification information of the email environment (MSERV environment), and mapping identification information of the email environment to identification information of the voice mail environment (MCS).
- MCS voice mail environment
- the mapping includes mapping of voice mail message contents to the message identification VMSGID, and mapping of the message identification VMSGID of the email environment to the MCS identification CACHEID.
- Transferring indicates an action of a component or entity that has the affect of transferring the data or information to another component or entity.
- Transferring includes sending in response to a request, query or command, and sending on the initiative of the transferring component or entity.
- the transfer may be an internetwork transfer, an intranetwork transfer, or a transfer between a network component or entity and a non-network component or entity.
- receiving indicates a component or entity receiving transferred data or information.
- Receiving includes receiving in response to a request, query or command, and retrieving in response to a request, query or command.
- the transfer may be an inter-network transfer, an intra-network transfer, or a transfer between a network component or entity and a non-network component or entity.
- FIG. 9 is an alternative information flow 900 for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment.
- This alternative information flow 900 describes the scenario in which the message VMSG is left by the caller and stored in the cache and in the MSERV environment, and after expiration of the time for holding the message VMSG in the cache.
- Information flow 900 begins when a caller places a call 802 to a user and availability of the user results in the caller leaving a voice mail message VMSG for the user.
- the voice mail message VMSG is received at the MCS and routed 804 C to the cache as described above, and the VMSG and CACHEID is routed 804 to the MSERV via the IM, also as described above.
- the MSERV assigns identification VMSGID to the incoming voice mail message VMSG and stores 806 the voice mail message VMSG along with the VMSGID in one or more areas of memory (not shown) available to the MSERV.
- Information flow 900 continues when a user accesses 820 the enterprise network system to retrieve his/her voice mail messages.
- VMLIST 809 is pulled 808 from the MSERV and pushed 810 by the IM to the MCS.
- the user selects a voice mail message from VMLIST 809 , by selecting a CACHEID/VMSGID item.
- the MCS searches 822 the Cache for the Cache identification CACHEID of the selected message in response to the user selection. Because the message was left by the caller and stored in the MSERV environment and expired in the cache before the user calls in, the MCS will not locate the CACHEID in the Cache.
- the MCS accesses the MSERV, identifies the message VMSG, and pulls 924 R the voice mail message contents from the MSERV environment via the IM.
- the MCS plays the pulled voice mail message VMSG for the user as appropriate to the action selected by the user.
- the MCS of an embodiment provides offline behavior that allows for holding, storing, and retrieving voice mail messages when the MSERV is offline or unavailable for some reason, or during times when the connection between the MCS and the MSERV is unreliable.
- Offline behavior means absence of a coupling between the MSERV and the MCS.
- a component of the MCS e.g., Offline Detector
- detects the MSERV is offline.
- the MCS holds the recorded voice mail message in the in response to detecting the MSERV state as offline.
- the Groupware Connector pulls the voice mail message from the Cache and transfers the recorded voice mail message via the IM to the MSERV where it is stored in the Database.
- FIG. 10 is an information flow 1000 for routing and accessing voice mail messages via the ICS when the MSERV is in an offline state, under an embodiment.
- This information flow 1000 shows one MCS and one MSERV in an enterprise network environment, but this is shown only as an example and does not limit the network environment to these components as alternative embodiments may have any number of MCSs and/or MSERVs.
- the information flow 1000 begins when a caller places a call 802 to a user and availability of the user results in the caller leaving a voice mail message VMSG for the user.
- the voice mail message VMSG is received at the MCS, however a component of the MCS detects an unavailable or offline condition of the MSERV.
- the MCS assigns a CACHEID to the incoming message VMSG, and holds 1004 C the message contents VMSG along with the CACHEID in the Cache.
- Information flow 1000 continues when a user accesses 820 the enterprise network system to retrieve his/her voice mail messages while the MSERV remains in an offline condition.
- the user selects a voice mail message from a list of CACHEIDs generated from the collection of voice mail messages held for him/her by in the cache.
- the MCS searches 1022 the Cache using the Cache identification CACHEID of the selected message.
- the MCS pulls 1014 R the voice mail message contents from the Cache, and plays the voice mail message for the user as appropriate to the action selected by the user.
- the MCS continues to monitor the condition of the MSERV. At such time as the MCS detects a return of the MSERV to an online condition, the MCS pulls 1004 P the voice mail message VMSG and its CACHEID from the Cache, and transfers 1004 M the voice mail message and CACHEID via the IM to the MSERV.
- the MSERV assigns an identification VMSGID to the incoming voice mail message VMSG and stores 1006 the voice mail message VMSG along with the VMSGID and CACHEID in one or more areas of memory as described above.
- the ICS of an embodiment provides a Form-Based User Interface (“FBUI”).
- FBUI is a form-based messaging or communication interface for use by users in retrieving voice mail messages and controlling actions taken on voice mail messages received in the enterprise network system.
- This FBUI enables a user to retrieve and take various actions on voice mail messages using data of a form (referred to herein as the “FBUI FORM”) that is presented to the user's client device by the enterprise network email system.
- FBUI FORM data of a form
- Use of the FBUI Form thus provides the user with access to the integrated messaging functions offered by the ICS without a requirement to install or run a dedicated client application on the user's client device.
- FIG. 11 is a block diagram of a system 11 that includes ICS 1100 with FBUI 1180 , under an embodiment.
- System 11 includes an enterprise network 1101 that provides integrated voice mail and email messaging through the use of ICS 1100 .
- Enterprise network 1101 includes a LAN that couples to components of ICS 1100 and a messaging server environment 1140 .
- ICS 1100 includes MCS 1110 IM 1120 , and FBUI 1180 , but is not so limited.
- FBUI 1180 is presented to a user (e.g., USER Z) via one or more local devices like PCs or other processor-based devices.
- Messaging server environment 1140 includes the MSERV and a Database 1144 , but is not so limited.
- the LAN couples to any number of other networks 150 and 160 using any of a variety of communication protocols, where the networks 1150 and 1160 may be of the same or of different types.
- the networks may include a public communications network 1150 and a private communications network 1160 .
- Private communications network 1160 may be a PBX coupled to the LAN of the enterprise network, for example.
- Networks 1150 and 1160 allow for information transfers between client devices 1170 that are local to enterprise network 1101 and client devices 1199 that are external to enterprise network 1101 .
- the client devices may alternatively be referred to as “user devices” 1170 and 1199 .
- ICS 1100 replaces the voice mail server typically found in enterprise networks with at least one MCS 1110 .
- MCS 1110 is coupled to the private communications network (e.g., PBX) of each network enterprise. While one MCS is shown in this example system 11 , the enterprise network may include multiple MCSs 1110 coupled to enterprise network in an “N+1” configuration, where “N” is any number 1, 2 . . . X.
- the MCS communicates with the IM servers, the private communications network, other MCSs and selected client devices.
- communications with the MCS may be restricted to network components having particular known addresses.
- communications with the MCS may require authentication by passcode or other security measures for certain kinds of access, for example, for access by the administrator.
- Security may also or alternatively be encrypted and/or provided by requiring a physical connection between the MCS and other component, such as in the case of a connection between an MCS and a private communications network through a direct cable connection.
- the MCS via the FBUI generally provides a form to a client device from a first server (e.g., messaging server, MSERV, etc.) via a network connection.
- the form includes data or code that when executed by the receiving client device results in presentation of a FBUI on a display of the client device.
- the FBUI includes a number of buttons or icons that allow a user to select an action on an item via a second server (e.g., communication server, MCS, etc.), where the item is stored on the first and/or second servers, and the first and second servers are different servers.
- the FBUI of an embodiment uses a web browser embedded in the form as the means for coupling and/or communicating with a corresponding browser control of the second server. Communications between the client device and the second server thus avoid security and/or other network policy issues that would prohibit the client device from communicating with the second server via the network coupling between the client device and the first server.
- the FBUI operates as a form-based messaging interface to transfer a first message (e.g., voice mail message) to a messaging server (e.g., MSERV) from a communication server (e.g., MCS) via a first coupling (e.g., IM).
- the messaging server generates a second message (e.g., email message) in response to a type of the first message and transfers the second message to a client device via a second coupling (e.g., LAN).
- the type of the first message is specified by the communication server using properties on the message that identify the message as a “Voice Mail Type” (“VMT”) message.
- VMT Voice Mail Type
- the second message is of a different type and includes data of the first message, but is not so limited.
- the communication server also transfers to the client device form data that corresponds to the first message.
- the client device uses the form data to establish a third coupling (e.g., browser link) between the client device and the communication server.
- the user may direct actions on the first message from the client device via the third coupling using the form data.
- the ICS of an embodiment provides the FBUI 1180 to a user via his/her local client device.
- the FBUI is provided to the client device through the use of a FBUI Form, where the structure of the FBUI Form conforms to the message structure of the messaging server environment.
- the FBUI Form is generated to comply with Microsoft formats as appropriate to Exchange and Outlook
- the FBUI Form includes code that generates information of the FBUI display as well as the buttons of the display.
- the FBUI Form further includes an embedded browser control for use in establishing communications between the client device displaying the FBUI Form and a web server (e.g., MCS, IM, other server) for example.
- the embedded browser control therefore allows the host client device to couple and communicate with a server that is different from the MSERV via a communication channel that is outside the enterprise network LAN.
- the FBUI Form enables a communication channel between the local client device currently executing the form and a component like the MCS and/or IM in spite of network policy issues that otherwise might prohibit the client device from communicating outside the enterprise network message infrastructure.
- a user can access/view and take a variety of actions on his/her voice mail messages within an email framework of the host enterprise network system.
- the MCS of an embodiment receives a voice mail message it transfers the voice mail message to the MSERV, as described above.
- the MCS specifies properties on the message that identify the message as a “Voice Mail Type” (“VMT”) message.
- VMT Voice Mail Type
- the message is received and stored by the MSERV as a VMT message using the same storage and retrieval structure as used with other message types like email messages.
- the active message browser of the client device receives the VMT message along with any other mail messages currently stored in his/her electronic mail box.
- the message browser corresponds to the message structure of the messaging server environment (e.g., Outlook in a Microsoft environment).
- the message browser identifies the message as a VMT message.
- the code that implements the FBUI Form is stored on the MSERV, implementation of the functionality and/or features associated with the FBUI Form uses communication between the user's client device and the MSERV via the LAN.
- the client device message browser requests the FBUI Form from the MSERV in response to identifying a message as a VMT message because this is the form that corresponds to the VMT message type.
- the MSERV transfers the FBUI Form to the requesting client device, and the client device message browser launches the form in response to the user selecting a VMT message for viewing.
- FIG. 12 is a sample FBUI 1200 as displayed on a client device, under an embodiment.
- the FBUI 1200 includes three areas 1202 - 1206 that present information to a user.
- the areas include a folder area 1202 , a contents area 1204 , and a function area 1206 , but are not limited to these areas as the UIs of alternative embodiments may present any number and/or type of areas.
- all three areas 1202 - 1206 may be presented at the same time, as shown in FBUI 1200 , or various subsets of the three areas may be presented at the same time in various combinations.
- Folder area 1202 presents one or more folders to which the user has access via the FBUI 1200 and the client device.
- the “INBOX” may contain a list of voice mail messages in the same listing as other messages, including email messages.
- the Inbox may include a subfolder (“VOICE MESSAGES”) which includes the voice mail messages, and selection of this folder results in the presentation of voice mail messages of the user's mail box in the contents area 1204 .
- the contents area 1204 generally presents the contents of the folder selected using the folder area 1202 .
- the contents area 1204 presents information corresponding to any number of voice mail messages in the user's mail box when the INBOX or VOICE MESSAGES folder is selected.
- Contents area 1204 allows the user to select a particular voice mail message by placing a cursor on “VOICE MESSAGE 1 INFORMATION” for example.
- a new window referred to as the “ICS Window” is displayed.
- the ICS Window now includes function are 1206 .
- Function area 1206 of FBUI 1200 presents one or more “voice mail action buttons” 1206 A- 1206 E (also referred to herein as “buttons”) each of which represents an action the user may select for a voice mail message.
- buttons also referred to herein as “buttons”
- the VOICE MESSAGES folder is selected, and selection of a message in contents area 1204 allows the user to take an action on the selected message using buttons 1206 A- 1206 E. Placing the cursor of contents area 1204 on a particular message and choosing an action on the selected message with a button 1206 A- 1206 E therefore invokes operations on the message via components of the ICS (e.g., MCS, Cache, IM).
- the ICS e.g., MCS, Cache, IM
- buttons 1206 A- 1206 E of an embodiment include a “Play on Phone” button 1206 A, a “Play on Computer” button 1206 B, a “Call Sender” button 1206 C, a “Reply by Voicemail” button 1206 D, and a “Forward by Voicemail” button 1206 E, but the embodiment is not limited to this same number of buttons or to buttons offering the same functionality.
- presentation of areas or information of the FBUI may vary in many ways.
- the action buttons 1206 appear after the user has selected (for example by double clicking a particular voice message from the contents area 1204 .
- Action buttons 1206 may also appear when the user right clicks on a particular voice message in the contents area 1204 .
- the folder area 1202 may also include a subfolder (“VOICE MESSAGE SYSTEM”) under the Public Folder.
- VOICE MESSAGE SYSTEM may not be considered an actual folder but instead a uniform resource locator (“URL”) that, when selected, sends an HTTP request to a web server and launches/displays an ICS browser inside the client device message browser.
- the web server may, for example, be a component of the MCS and/or IM, but is not so limited.
- the ICS browser is an embedded or hidden browser that displays the ICS Window in the area of the client device message browser where emails would typically appear, and the voice mail messages are displayed in the ICS Window.
- the ICS Window is displayed in the contents area 1204 of an embodiment.
- the ICS Window may be served from the IM and may contain any information related to the voice messaging system that is user specific.
- the ICS Window will display a user login prompt where the user enters the user name and PIN code. Subsequently, the system displays the user's configuration date, such as PIN code, attendant extension, greeting type, and other applicable information.
- the hidden browser enables an HTTP link and communications with the IM, for example, which then brokers communications (via HTTP) with the MCS via the MCS Web Server ( FIG. 6 ) for example. Therefore, while typical messaging servers and LANs use security policies that restrict the use of “special” code in form data, use of the hidden browser embedded in a form structure that is native to the host system overcomes this restriction because the browser is not detected or considered as special code. Use of the hidden browser thus supports communication with the corresponding browser control in the MCS and/or the IM, thereby allowing the integration of voice mail messaging provided by the MCS with the email messaging system of the enterprise network
- a “voice mail message” in the ICS is generally any message created using a client device generating an audio stream.
- a “voice mail message” is also any VMT message, such as a message created using the “Reply by Voice Message” and “Forward by Voice Message” buttons of the FBUI.
- An “email” is any message created using buttons of a host mail message system that function to generate a reply message or to forward a message in response to receipt of a message, even if replying or forwarding a voice mail message.
- the ICS of an embodiment presents a voice mail message to a user in an email message system using the FBUI as the presentation form.
- FBUI 1200 allows a user to take action on a voice mail message via buttons 1206 A- 1206 E of FBUI 1200 . Therefore, placing the cursor of contents area 1204 on a particular message and choosing an action on the selected message with a button 1206 A- 1206 E invokes the action on the message via components of the MCS and/or the enterprise network environment.
- the user may select a “Play on Phone” action using button 1206 A.
- the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI.
- the client device receives a pop-up message from the ICS via the browser link and the ICS Window, where the pop-up message allows the user to choose or enter a telephone number to which he/she would like the selected voice mail message routed.
- the pop-up message also includes a “connect” button by which the user initiates routing of the selected voice mail message to the selected telephone.
- the IM couples with an MCS, and the MCS causes the PBX to initiate a call to the telephone number selected by the user via the pop-up window.
- the MCS pushes the contents of the voice mail message to the selected telephone.
- Another example of an action on a voice mail message includes selection of a “Play on Computer” action by the user via button 1206 B.
- the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI.
- the IM couples with an MCS, and the MCS pushes a form to the user's computer that resembles a typical email.
- the form includes an attachment that is an audio file (e.g., WAVE, MP3, other audio formats, etc.).
- the client device may launch the default audio player of the client device.
- selection of the attachment in a “Play on Computer” action may result in the browser form controlling launch of a pre-specified audio player instead of the default audio player. This is similar to the hidden browser described above with reference to presentation of the FBUI.
- the user may also select a “Call Sender” action on a voice mail message using button 1206 C.
- the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI.
- the IM couples with an MCS, and the MCS retrieves the selected message from the Cache or the MSERV.
- the MCS uses the caller information from the retrieved message, the MCS causes the PBX to connect the call to the user's local telephone.
- the MCS causes the PBX to initiate a call to the sender's telephone number as determined from the caller information associated with the voice message.
- the user may select a “Reply by Voice Message” action on a voice mail message using button 1206 D.
- the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI.
- the IM couples with an MCS, and the MCS retrieves the selected message from the Cache or the MSERV.
- the MCS causes a reply message to be generated corresponding to the received message, and prompts the user to record an audio message for the reply.
- the user records the audio for the reply via a microphone coupled to his/her client device. Alternatively, the user may record the audio for the reply via his/her local telephone.
- the MCS causes the reply message to be transmitted to the designated addressees via the MSERV. A user is not required to listen to a message to invoke the “Reply by Voice Message” action.
- the user may also select a “Forward by Voice Message” action on a voice mail message using button 1206 E.
- the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI.
- the client device receives a pop-up message from the ICS via the browser link, where the pop-up message allows the user to choose or enter a telephone number to which he/she would like the selected voice mail message routed.
- the pop-up message also includes a “connect” button by which the user initiates routing of the selected voice mail message to the selected telephone.
- the IM couples with an MCS, and the MCS causes the PBX to initiate a call to the telephone number selected by the user via the pop-up window.
- the MCS pushes the contents of the voice mail message to the called telephone and the user.
- the MCS may provide a verbal prompt to the user requesting information of the party to whom the message is to be forwarded, and/or a prompt to the user to record an audio message to be forwarded along with the forwarded message.
- a user is not required to listen to a message to invoke the “Forward by Voice Message” action.
- FIG. 13 is a block diagram of a system 13 that includes multiple Sites (defined herein) and multiple components, under an alternative embodiment.
- System 13 includes multiple Sites, some of which may have multiple MCSs, IMs, private communication networks and MSERVs.
- system 13 includes MSERV 1390 and MSERV 1391 communicating via a network 1392 , which may comprise any of a public network, such as a PSTN, or private communications network or other network.
- the MSERVs are coupled to one or more IMs.
- MSERV 1390 is coupled to IMs 1385 (IM 1 and IM 2 )
- MSERV 1391 is coupled to IMs 1386 (IM 3 and IM 4 ).
- the IMs are coupled to one or more MCSs.
- IM 1 is coupled to MCS 1 , MCS 2 , and MCS 3 ;
- IM 2 is coupled to MCS 2 , MCS 3 , MCS 4 and MCS 5 ;
- IM 3 is coupled to MCS 6 and MCS 7 ;
- IM 4 is coupled to MCS 8 .
- the MCSs are coupled to private communications networks.
- MCS 1 , MCS 2 , MCS 3 , MCS 4 and MCS 5 are coupled to private communications network 11360 A;
- MCS 6 , and MCS 7 are coupled to private communications network 2 1360 B; and
- MCS 8 is coupled to private communications network 2 1360 B and private communications network 3 1360 C.
- FIG. 13 shows a system 13 that is scalable in a number of different dimensions, according to various embodiments of the invention.
- Two MSERVs are shown coupled by a network. This configuration allows for sharing of voicemail messages, user lists, global address lists, distribution lists and public folders between the various MSERVs that connected by a network and which may be placed at the same or different locations. Additionally, use of multiple MSERVs allows for scaling of the overall system through the increased capacity provided by the multiple MSERVs.
- MCSs Multiple MCSs are shown. Increased number of MCSs can help to increase overall system capacity and/or redundancy by providing increased number of ports, storage, and processing capacity.
- information on the MCSs is derived from the MSERVs and automatically cached on the MCSs. This allows for easy deployment of new MCSs by which the data and configuration settings for the new MCSs are acquired from the MSERV(s) and/or caches of other MCSs.
- an MCS may be coupled to more than one private communications network. In some cases an MCS may operate with multiple private communications networks simultaneously.
- an MCS that is coupled to multiple private communications networks may continue operation with a non-failing private communications network in the event that one of the private communications networks to which the MCS is coupled fails.
- the MCS that is coupled to multiple private communications networks operates with at least one of the private communications networks, but begins to operate with another, non-failing private communications network in the event that a private communications network to which the MCS is coupled fails.
- Multiple IMs are shown in FIG. 13 , which help to support the capacity of additional MCSs.
- the multiple IMs also may provide fail over support for each other in the event that one of the IMs fails.
- a user may have a Site identification.
- the Site identification may be used to filter user information associated with a particular Site from the a broader set of user information stored on the MSERV servicing multiple Sites.
- Sites may be combined into auto attendant groups.
- the auto attendant groups are Sites that share a common dial plan. For example, members of an auto attendant group may able to place calls using extension numbers instead of full numbers.
- various subsets of users may be defined from among the users in an MSERV or set of networked MSERVs. Such subsets of users may be defined by a Site identification. In this way, various subsets of users may be associated with different respective private communications networks, such that the users' access to respective Sites within a network of MSERVs depends on the users' membership in the various defined subsets of users. For example, members of a subgroup of users associated with a particular Site may be able to use functions such as message waiting indication and control of messaging actions at their associated Site but not at other Sites.
- An ICS of an embodiment includes an integrated messaging system.
- the integrated messaging system includes: a communication server that couples among networks of different types; an interface module that couples to the communication server, wherein the interface module pulls a plurality of user information from a messaging server of a network, wherein the user information includes information relevant to at least the network; and a cache store that couples to the communication server and to the interface module to hold at least one of information from the communication server and the user information pulled from messaging server, the interface module directing a message from at least one of the messaging server and the cache to at least one device on the networks using the user information.
- a type of the message includes at least one of a voice mail type, an email type, a multimedia messaging system type, an instant messaging type, and a short messaging system type.
- the communication server may further include a plurality of applications including at least one voice application, wherein at least one voice browser couples the applications to a communications exchange, wherein the plurality of applications further includes at least one mobile application.
- the system further includes a form-based interface that is transferable via an electronic message from the messaging server, the form-based interface enabling user actions on information of the messaging server using information of the cache via a coupling with at least one of the communication server and the interface module the actions on information of the messaging server include directing and playing a voice mail message to the device, generating a reply voice mail message for use in replying to the voice mail message, generating a forwarding voice mail message for use in forwarding the voice mail message, and generating an audio call to a caller leaving the voice mail message.
- the system further includes at least one form, wherein the messaging server transfers the form to a client device via a network coupling with the client device, wherein an embedded browser control of the form establishes a coupling between at least one client device and at least one of the interface module and the communication server.
- system further includes a web server that couples the communication server to the interface module.
- the interface module couples to a groupware application of the messaging server.
- An embodiment further includes a detector that detects at least one state of the messaging server, wherein the communication server operates in accordance with a plurality of operating modes, wherein the communication server selects an operating mode in response to the state of the messaging server.
- An embodiment further includes a first message of a first type, wherein the communication server generates the first message in response to receiving a data stream at an input, and may include a second message of a second type, wherein the messaging server generates the second message in response to determining the first type of the first message, wherein the second message includes data of the first message.
- the first type may be a voice mail type and the second type may be an electronic mail (email) type.
- the at least one device on the networks includes a first set of client devices coupled to the network and a second set of client devices coupled to a public network of the networks, wherein client devices of the first set and the second set include at least one of portable computers, portable telephones, cellular telephones, personal digital assistants, and multi-modal devices.
- An embodiment further includes: a second messaging server that couples to the messaging server via the networks; a second interface module that couples to at least one of the messaging server and the second messaging server; and a second communication server that couples among the networks via at least one of the interface module and the second interface module.
- the user information includes information of at least one user, the information including at least one of network mail box number, name, telephone extension, at least one telephone number, email address, greeting, site identification.
- the interface module is hosted on the messaging server.
- An ICS as described herein further includes a device comprising: at least one server that couples messaging applications among a communication network and a messaging network; at least one interface module that couples to the messaging applications and the messaging network, the interface module transferring message information between the messaging network and the messaging application and retrieving a plurality of user information from the messaging server, wherein the user information includes information of users of the messaging network; and a cache store that couples to the server and to the interface module to hold at least one of the message information and the user information, the server manipulating the message information using the user information.
- the messaging information may include information of messages that include at least one of a voice mail type, an email type, a multimedia messaging system type, an instant messaging type, and a short messaging system type.
- the server further comprises: at least one voice browser; and a plurality of applications that couple to the voice browser, the applications including at least one voice application and at least one mobile application, wherein the voice browser couples the applications to a communications exchange.
- An embodiment further includes a web server that couples at least one of the server and the interface module to a client device of the user via a form-based interface of the client device, wherein the server transfers the form-based interface via an electronic message to the client device via at least one of the interface module and the messaging network, and wherein the form-based interface allows the user to control actions on information of the messaging network using information of the cache store.
- the actions may include directing and playing a voice mail message to the client device, generating a reply voice mail message for use in replying to the voice mail message, generating a forwarding voice mail message for use in forwarding the voice mail message, and generating an audio call to a caller leaving the voice mail message.
- the server couples to a groupware application of the messaging network in an embodiment.
- An embodiment further includes a detector that detects at least one state of the messaging network, wherein the server selects an operating mode in response to a state of the messaging network.
- An embodiment further includes a first message of a first type, wherein the server generates the first message in response to receiving a data stream from the communication network; and a second message of a second type, wherein the messaging network generates the second message in response to determining the first type of the first message, wherein the second message includes data of the first message.
- the user information includes information of at least one user, the information including at least one of network mail box number, name, telephone extension, at least one telephone number, email address, greeting, site identification.
- An ICS as described herein further includes a method comprising: receiving data streams from networks of different types; generating messages at a communication server using information of the data streams; transferring the messages, wherein transferring includes at least one of caching information of the messages and forwarding the messages to a messaging server; retrieving user information from the messaging server, wherein the user information includes information relevant to at least the network; caching the user information from the pulling; and directing the message from at least one of the messaging server and a cache to at least one device on the networks using the cached user information.
- a type of the message includes at least one of a voice mail type, an email type, a multimedia messaging system type, an instant messaging type, and a short messaging system type.
- An embodiment further includes: transferring information of a form-based interface to the device via an electronic message; forming a coupling between the device and the communication server using information of the form-based interface; and directing the message by controlling actions on the messages using the cached user information, wherein a user directs actions on the messages from the device.
- the actions include directing and playing the message to the device, generating a reply message for use in replying to the message, generating a forwarding message for use in forwarding the message, and generating an audio call to a caller leaving the message.
- the method can include detecting at least one state of the messaging server, and
- the messages may include a first type message, wherein generating the messages includes generating messages of the first type in response to the received data streams, wherein the messages include a second type message, wherein transferring further includes transferring messages of the second type to the device in response to detecting the first type message.
- An embodiment further includes: assigning a site identification to a user; filtering the user information of users of a plurality of sites using the site identification; forming sets of users in accordance with the filtered user information; associating each set of users with at least one of the networks.
- An ICS as described herein further includes a device comprising: means for receiving data streams from networks of different types; means for generating messages at a communication server using information of the data streams; means for transferring the messages, wherein transferring includes at least one of caching information of the messages and forwarding the messages to a messaging server; means for retrieving user information from the messaging server, wherein the user information includes information relevant to at least the network; means for caching the user information from the pulling; and means for directing the message from at least one of the messaging server and the cache to at least one device on the networks using the user information of the cache.
- An ICS of an embodiment includes a device comprising a server including a plurality of messaging applications, wherein the server is coupled to a cache and a network of a plurality of networks, wherein an address of the network is assigned to the server and the server is configured, wherein the server retrieves a plurality of user information from the network and caches the retrieved user information, the user information including information of users of the network, wherein the server transfers message information between the plurality of networks and the messaging applications using the cached user information.
- An ICS of an embodiment includes a system comprising a plurality of servers each of which includes a plurality of messaging applications, wherein each server is coupled in succession to a cache and a network of a plurality of networks, wherein an address of the network is assigned to each server and each server is configured, wherein each server retrieves a plurality of user information from the network and caches the retrieved user information, the user information including information of users of the network, wherein each server transfers message information between the plurality of networks and the messaging applications using the cached user information.
- An ICS of an embodiment includes a method comprising at least one of providing a communication server and coupling the communication server to at least one network, assigning a network address to the communication server, configuring the communication server, retrieving and caching user information from a messaging server of the network, wherein the user information includes information relevant to at least the network, and transferring messages received at the communication server using the cached user information, wherein transferring includes at least one of caching information of the messages and forwarding the messages to the network.
- the method of an embodiment further comprises installing in succession a plurality of additional communication servers to the network.
- the installing of an embodiment comprises at least one of coupling each additional communication server to the network, assigning a network address to each additional communication server, configuring each additional communication server, retrieving and caching user information at each additional communication server from a messaging server of the network, wherein the user information includes information relevant to at least the network, and transferring messages received at each additional communication server using the cached user information, wherein transferring includes at least one of caching information of the messages and forwarding the messages to the network.
- the components of the ICS described above include any collection of computing components and devices operating together.
- the components of the ICS can also be components or subsystems within a larger computer system or network.
- the ICS components can also be coupled among any number of components (not shown), for example other buses, controllers, memory devices, and data input/output (I/O) devices, in any number of combinations. Further, components of the ICS can be distributed among any number/combination of other processor-based components.
- aspects of the ICS described herein may be implemented as functionality programmed into any of a variety of circuitry, including programmable logic devices (PLDs), such as field programmable gate arrays (FPGAs), programmable array logic (PAL) devices, electrically programmable logic and memory devices and standard cell-based devices, as well as application specific integrated circuits (ASICs).
- PLDs programmable logic devices
- FPGAs field programmable gate arrays
- PAL programmable array logic
- ASICs application specific integrated circuits
- microcontrollers with memory such as electronically erasable programmable read only memory (EEPROM)
- embedded microprocessors firmware, software, etc.
- aspects of the ICS may be embodied in microprocessors having software-based circuit emulation, discrete logic (sequential and combinatorial), custom devices, fuzzy (neural) logic, quantum devices, and hybrids of any of the above device types.
- the underlying device technologies may be provided in a variety of component types, e.g., metal-oxide semiconductor field-effect transistor (MOSFET) technologies like complementary metal-oxide semiconductor (CMOS), bipolar technologies like emitter-coupled logic (ECL), polymer technologies (e.g., silicon-conjugated polymer and metal-conjugated polymer-metal structures), mixed analog and digital, etc.
- MOSFET metal-oxide semiconductor field-effect transistor
- CMOS complementary metal-oxide semiconductor
- bipolar technologies like emitter-coupled logic (ECL)
- polymer technologies e.g., silicon-conjugated polymer and metal-conjugated polymer-metal structures
- mixed analog and digital etc.
- Computer-readable media in which such formatted data and/or instructions may be embodied include, but are not limited to, non-volatile storage media in various forms (e.g., optical, magnetic or semiconductor storage media) and carrier waves that may be used to transfer such formatted data and/or instructions through wireless, optical, or wired signaling media or any combination thereof.
- Examples of transfers of such formatted data and/or instructions by carrier waves include, but are not limited to, transfers (uploads, downloads, e-mail, etc.) over the Internet and/or other computer networks via one or more data transfer protocols (e.g., HTTP, FTP, SMTP, etc.).
- data transfer protocols e.g., HTTP, FTP, SMTP, etc.
- a processing entity e.g., one or more processors
- the words “comprise,” “comprising,” and the like are to be construed in an inclusive sense as opposed to an exclusive or exhaustive sense; that is to say, in a sense of “including, but not limited to.” Words using the singular or plural number also include the plural or singular number respectively. Additionally, the words “herein,” “hereunder,” “above,” “below,” and words of similar import refer to this application as a whole and not to any particular portions of this application. When the word “or” is used in reference to a list of two or more items, that word covers all of the following interpretations of the word: any of the items in the list, all of the items in the list and any combination of the items in the list.
- the terms used should not be construed to limit the ICS to the specific embodiments disclosed in the specification and the claims, but should be construed to include all processing systems that operate under the claims. Accordingly, the ICS is not limited by the disclosure, but instead the scope of the ICS is to be determined entirely by the claims.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Telephonic Communication Services (AREA)
Abstract
Description
- This application is related to the following United States patent applications:
- Form-Based User Interface For Controlling Messaging, U.S. application No. ______ [Attorney Docket No. 30519.703.201], invented by Heine Frifeldt, Anthony Shaffer, and Willem R. B. Potze, filed concurrently herewith;
- Controlling Messaging Actions Using Form-Based User Interface, U.S. application No. ______ [Attorney Docket No. 30519.704.201], invented by Heine Frifeldt, Anthony Shaffer, and Willem R. B. Potze, filed concurrently herewith;
- Caching Message Information In An Integrated Communication System, U.S. application No. ______ [Attorney Docket No. 30519.705.201], invented by Shahriar Vaghar, Yang Wang, and Jens Skakkebaek, filed concurrently herewith;
- Distributed Cache System, U.S. application No. ______ [Attorney Docket No. 30519.706.201], invented by Shahriar Vaghar, Yang Wang, and Jens Skakkebaek, filed concurrently herewith;
- Caching User Information In An Integrated Communication System, U.S. application No. ______ [Attorney Docket No. 30519.707.201], invented by Jens Skakkebaek, Willem R. B. Potze, and Heine Frifeldt, filed concurrently herewith;
- Integrating Messaging Server Directory Service With Communication System Voice Mail Message Interface, U.S. application No. ______ [Attorney Docket No. 30519.708.201], invented by Heine Frifeldt, David Forney, and Anthony Shaffer, filed concurrently herewith;
- Improved Message Data Access In Multi-Media Communication System, U.S. application No. ______ [Attorney Docket No. 30519.709.201], invented by Jens Skakkebaek and Heine Frifeldt, filed concurrently herewith;
- System And Method For Voicemail Privacy, U.S. application No. ______ [Attorney Docket No. 30519.710.201], invented by Anthony Shaffer, Heine Frifeldt and David Forney, filed concurrently herewith;
- Networked Voicemail, U.S. application No. ______ [Attorney Docket No. 30519.711.201], invented by David Forney, Jens Skakkebaek, Heine Frifeldt, and Anthony Shaffer, filed concurrently herewith;
- Extensible Diagnostic Tool, U.S. application No. ______ [Attorney Docket No. 30519.712.201], invented by David Forney, Heine Frifeldt, and Anthony Shaffer, filed concurrently herewith;
- System And Method For Providing Data On Voicemail Appliance, U.S. application No. ______ [Attorney Docket No. 30519.713.201], invented by Jens Skakkebaek and Lutz Birkhahn, filed concurrently herewith;
- Integrated Voice Mail User/Email System User Setup in Integrated Multi-Media Communication System, U.S. application No. ______ [Attorney Docket No. 30519.714.201], invented by Heine Frifeldt, David Forney, and Anthony Shaffer, filed concurrently herewith; and
- System And Method For Providing Code On Voicemail Appliance, U.S. application No. ______ [Attorney Docket No. 30519.715.201], invented by Jens Skakkebaek and Lutz Birkhahn, filed concurrently herewith. Each of the foregoing applications is incorporated herein by reference in its entirety.
- The disclosure herein relates generally to communication systems, and more particularly to integrated communication and messaging systems.
- As methods of communication continue to proliferate, enterprises continue to desire integrated systems for handling all aspects of multi-media communication for enterprise users. An enterprise can be any collection of users of communication media having some common purpose, but a typical example is a company with one or more sites and some number of employees who are users of communication media. Communication media include electronic mail (“email”) messaging, Short Messaging Service (“SMS”) messaging, voice messaging, and more. Users receive and send messages over a variety of wired and wireless networks via a variety of devices, such as desktop computers, wired phones, wireless devices (e.g., phones and personal digital assistants (“PDAs”)), and more.
- Enterprises currently have the ability to centralize and manage email messaging using commercially available groupware that centrally stores information about all of the users and their messages. Enterprises also have the ability to centrally manage traditional voice messaging using a Private Branch Exchange (“PBX”). However, the systems for managing email messaging and the systems for managing voice mail messaging are not at all well integrated. For example, when a new user is added to the enterprise, a system administrator for the enterprise sets up the user in the email system using the groupware application and its set methods, data and protocols. In addition, a different administrator specializing in telephony must set up the user in the voice messaging system using different methods, data and protocols. Voice data and email data are typically stored in separate databases. Both initial user setup and updating user information are complicated by the fact that the email and voice systems are so distinct.
- The management of and access to the voice mail message information and email information in the enterprise is also complicated by the current lack of integration of the two (voice and email) systems. There are various challenges to be overcome if one were to attempt to integrate the two systems.
- All publications and patent applications mentioned in this specification are herein incorporated by reference to the same extent as if each individual publication or patent application was specifically and individually indicated to be incorporated by reference.
-
FIG. 1 is a block diagram of a system that includes an integrated communication system (“ICS”), under an embodiment. -
FIG. 2 is a flow diagram for providing integrated communication processes using the ICS, under an embodiment. -
FIG. 3 is a block diagram of example information flows in a system that includes the ICS, under an embodiment. -
FIG. 4 is another flow diagram for providing integrated communication processes using the ICS, under an embodiment. -
FIG. 5 is a block diagram of an enterprise network system that includes a communication server and Interface Module (“IM”) of an ICS, under an embodiment. -
FIG. 6 is a block diagram of an enterprise network system that includes the ICS, under an embodiment. -
FIG. 7 is a block diagram that shows interactions between the IM and components of a messaging server (“MSERV”) environment, under an embodiment. -
FIG. 8 is an information flow for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment. -
FIG. 9 is an alternative information flow for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment. -
FIG. 10 is an information flow for routing and accessing voice mail messages via the ICS when the MSERV is in an offline state, under an embodiment. -
FIG. 11 is a block diagram of a system that includes the ICS with a Form-Based User Interface (“FBUI”), under an embodiment. -
FIG. 12 is a sample FBUI as displayed on a client device, under an embodiment. -
FIG. 13 is a block diagram of a system that includes multiple sites and multiple components, under an alternative embodiment. - In the drawings, the same reference numbers identify identical or substantially similar elements or acts. To easily identify the discussion of any particular element or act, the most significant digit or digits in a reference number refer to the Figure number in which that element is first introduced (e.g.,
element 110 is first introduced and discussed with respect toFIG. 1 ). - Integrated multi-media communication systems and methods are provided below. These communication systems and methods, collectively referred to herein as “integrated communication systems” or “ICS,” integrate different types of messaging so that a user of the ICS can access multiple types of messages (e.g., voice mail messages, electronic mail, email messages, instant messaging messages, SMS (Short Messaging System) messages, MMS (Multimedia Messaging System) messages, etc. with a single message interface. In providing integrated messaging functionality via a single message interface, the ICS of an embodiment relieves the dependency of a voice mail system, for example, by providing users with access to voice mail messages and capabilities of the voice mail system through the local groupware applications and email messaging system.
- The ICS generally includes a communication server, a cache system, and an interface module. The ICS integrates with a messaging and collaboration system and the corresponding groupware applications in a network environment for example. In providing integrated messaging capabilities, the communication server and interface module function to route a call received from a caller to a user and, in the event the user is not available, to receive and route a voice mail message left by the caller. The ICS uses caching processes during the receiving and routing of voice mail messages that provide users with fast access to voice mail messages, user information and contact information. Using caching process, the ICS also provides access to the voice mail messaging system during periods when the messaging and collaboration system is offline. The ICS also leverages the storage capability of the messaging and collaboration system to eliminate the need for a separate voice mail database.
- The message interface of the ICS includes a form-based interface for use in retrieving voice mail messages and controlling actions taken on voice mail messages received in the enterprise network system. This form-based interface enables a user to retrieve and take various actions on voice mail messages using data of a form provided to the user's client device by the enterprise network email system. Use of the form-based interface thus provides users with access to the integrated messaging functions offered by the ICS without a requirement to install or run a dedicated client application on the user's client device.
- In the following description, numerous specific details are introduced to provide a thorough understanding of, and enabling description for, embodiments of the ICS. One skilled in the relevant art, however, will recognize that these embodiments can be practiced without one or more of the specific details, or with other components, systems, etc. In other instances, well-known structures or operations are not shown, or are not described in detail, to avoid obscuring aspects of the disclosed embodiments.
-
FIG. 1 is a block diagram of asystem 10 that includes an integrated communication system (“ICS”) 100, under an embodiment.ICS 100 includes acommunication server 110, an interface module (“IM”) 120, and a cache system 130 (also referred to as the “cache”), but is not so limited.Communication server 110 couples to components of any number ofnetworks networks Networks various client devices user devices -
IM 120 ofICS 100 couples to transfer information or data withcommunication server 110. Additionally,IM 120 couples to transfer information with one or more components of amessaging server 140, where transferring information includes one or more of pulling, receiving, retrieving, polling, transmitting, and pushing operations, to name a few. As an example of an information transfer betweenIM 120 andmessaging server 140,IM 120 pulls user information frommessaging server 140 and makes the pulled user information available to other components ofICS 100, wherein the user information includes information relevant to atleast network 150. - The components of
messaging server 140 may include for example one ormore processors 142, also referred to as “central processing units” or “CPUs,” and one ormore databases 144 coupled toCPU 142. In an embodiment,IM 120 may be hosted on or running under control ofmessaging server 140, but is not limited to this configuration. Further,messaging server 140 may be a component ofnetwork 150 that hostscommunication server 10, but is not so limited. For example,messaging server 140 may be hosting a groupware application (e.g., Microsoft Exchange, LotusNotes, etc.) of anenterprise network 150. -
Cache 130 couples tocommunication server 110 and communicates to transfer information with one or more ofcommunication server 110,IM 120, and one or more components ofmessaging server 140, as described below.Cache 130 may also couple to additional components (not shown) ofnetwork 150. - As an example of information transfers between
cache 130 andcommunication server 110,cache 130 may receive caller information (e.g., voice mail messages, caller identification, etc.) fromclient devices 199 viacommunication server 110. An example of information transfers betweencache 130 andmessaging server 140 includes transfers in whichcache 130 receives user information frommessaging server 140, where the user information may be routed frommessaging server 140 viaIM 120 and/orcommunication server 110. Another example of information transfers betweencache 130 andmessaging server 140 includes transfers in whichmessaging server 140 receives information fromcache 130 routed fromcache 130 viacommunication server 110 and/orIM 120. - Examples of information transfers between
cache 130 andIM 120 include transfers of user information pulled frommessaging server 140 byIM 120 and directed tocache 130, and transfers in whichIM 120 directs a message from at least one ofmessaging server 140 andcache 130 to at least one device onnetworks Cache 130 holds or temporarily stores the received information under the above examples. -
Networks networks devices networks -
Client devices Client devices embodiment client devices 170 are client devices operating in a private network environment like an enterprise network, whileclient devices 199 are client devices operating in different private network environments or under any number of public networks. -
FIG. 2 is a flow diagram for providing integrated communication processes 200 usingICS 100, under an embodiment.Processes 200 include receiving data streams from networks of different types, atblock 202. The data streams may include a variety of data including, for example, audio or voice data. Further, the data streams may be received from any number of networks or client devices operating on the networks.Processes 200 further include generating messages at a communication server using information of the data streams, atblock 204. The generated messages may be any of a number of message types. Returning to the above example in which the received data stream includes audio data, the generated message is a voice mail message, but is not so limited.Processes 200 also include transferring the messages, atblock 206. The transferring operation includes for example caching information of the messages in the ICS cache and/or forwarding the messages to a messaging server. - Continuing, processes 200 include pulling user information from a messaging server coupled to the ICS, at
block 208, as described above. The user information includes information relevant to users of at least the network hosting the ICS, but is not so limited.Processes 200 also include caching pulled user information from the messaging server, atblock 210. Additionally, processes 200 include use of the user information of the cache to direct a message from at least one of the messaging server and the cache to one or more client devices on any of the networks, atblock 212. - The ICS of an embodiment integrates different types of messaging so that a user of the ICS can access all of the message types (e.g., voice mail messages, electronic mail or email messages, etc.) with a single message interface (also referred to as a “user interface” or “UI”). In providing integrated messaging functionality via a single message interface, the ICS of an embodiment relieves the dependency on a voice mail system with a dedicated voicemail and user database, for example, by providing users with access to voice mail messages and capabilities of the voice mail system through the local email messaging system.
-
FIG. 3 is a block diagram of example information flows 300 in asystem 30 that includesICS 100, under an embodiment. The system also includes amessaging server 140 and any number ofclient devices 170 that couple toICS 100. In addition,ICS 100 couples to acommunications network 160.ICS 100,messaging server 140, andclient devices 170 may be hosted under anetwork 150, but are not so limited.System 30 is shown with one each ofICS 100,messaging server 140, andclient device 170 for purposes of this description, but may include any number of each ofICS 100,messaging server 140, andclient device 170 coupled in any combination.System 30 may also couple to one or more other systems (not shown) or networks via any number of backend couplings (not shown) - Components of
ICS 100 include a communication server and an interface (not shown). The interface ofICS 100 may run under control ofmessaging server 140, as described above, but is not so limited.Information flow 300 begins when, in response to receiving data streams fromnetworks 160 of different types,ICS 100 generates afirst message 302 and transfersfirst message 302 tomessaging server 140 via a communication withmessaging server 140.First message 302 may be a voice mail message (“Voice Mail Type” or “VMT”) but is not limited to this type of message. For purposes of the description herein, a voice mail message is left by a “caller” to the ICS. For example, in an embodiment where Microsoft Exchange is themessaging server 140, the VMT may be implemented using “Message Class” and/or “Message Type” fields associated with messages in Microsoft Exchange. - Following or simultaneous with receipt of
first message 302, themessaging server 140 detects or identifies a type offirst message 302 using information of the first message and generates asecond message 312.Second message 312 is of a different type from that offirst message 302, and includes information offirst message 302.Second message 312 may for example be an email message but is not limited to this type of message.Second message 312 is transferred to aclient device 170 via a communication withclient device 170, where the communication uses a communication protocol ofnetwork 150. - Responsive to receipt of
second message 312,client device 170 determines a type of the second message and requests formdata 314 that corresponds tosecond message 312.Messaging server 140, in response to the request forform data 314, transfers formdata 314 toclient device 170 via the second coupling. One or more components ofICS 100 generate and/or provideform data 314 for storage inmessaging server 140, andform data 314 is generated under the communication infrastructure ofnetwork 150. The form data may be displayed to the user using the corresponding form. -
Client device 170 usesform data 314 to view contents ofsecond message 312. The client device also usesform data 314 to establish communications with communication server 110 (of ICS 100) via a third coupling. The communication protocol of the third coupling is different than the communication protocol of the second coupling, but is not so limited. An “embedded control” controls activation of the third coupling. Furthermore, the client device allows a “user” using the client device to directactions 322 onfirst message 302 via the third coupling with the ICS using the form data. For purposes of the description herein, a “user” is an individual with enabled capability to use functions within the ICS. - As an example under information flows 300,
FIG. 4 is a flow diagram for integrated communication processes 400 usingICS 100, under an embodiment.Processes 400 include transferring a first message to a messaging server from a communication server via a first coupling, atblock 402.Processes 400 also include generating a second message at the messaging server in response to a type of the first message and transferring the second message to a client device via a second coupling, atblock 404. The second message may be of a different type than the first message and includes data of the first message.Processes 400 further include transferring to the client device form data that corresponds to the first message, atblock 406. Additionally, processes 400 include establishing a third coupling between the client device and the communication server using the form data, atblock 408. Moreover, processes 400 include directing actions on the first message from the client device using the form data, the actions directed via the third coupling, atblock 410. - The ICS of an embodiment integrates messages of different types to enable a user to access a number of message types through components of the ICS. Thus, an application of the ICS of an embodiment is as a substitute for a voice mail system in an enterprise network, where the ICS enables a user to receive and/or take action on voice mail messages using the enterprise email system.
-
FIG. 5 is a block diagram of anenterprise network system 500 that includes acommunication server 110 andIM 120 of an ICS, under an embodiment.Communication server 110 couples to at least onemessaging server 140 viaIM 120.IM 120 runs undermessaging server 140, but is not limited to running under this server. Messaging server also couples to one ormore databases 144.Messaging server 140 of an embodiment supports the messaging capabilities ofenterprise network system 500 using a groupware application (e.g., Microsoft Exchange) (not shown) along with other applications as appropriate to the size and type ofenterprise network system 500.Messaging server 140,database 144, and groupware application (not shown) may be referred to as collectively forming a “messaging environment.” -
Communication server 110 couples to any number ofclient devices 199 external toenterprise network 500 via one or more networks (not shown), as described above with reference toFIG. 1 . Similarly,communication server 110 couples to any number ofclient devices 170 local toenterprise network 500. -
Communication server 110 includes anoperating system 518 as well as numerous components or subsystems. These components include but are not limited to one ormore Voice Applications 512, anExecution Engine 514, and any number ofMobile Application Modules 516, as described below, or any other type of application module. -
FIG. 6 is a block diagram of anenterprise network system 600 that includes an ICS, under an embodiment. The ICS includes acommunication server 610 as described above, also referred to as a “Messaging Communication Server” or “MCS.” The MCS may be highly scalable. According to an embodiment of the invention, the MCS may be configured as a modular “appliance” that is essentially self-contained, and may be, for example, encased in a stackable, “pizza-box” style server. The ICS also includes IM 620 (also referred to herein as the “IM”) and aManagement Console 660. The IM, which in one embodiment runs under control of a messaging server 640 (also referred to herein as “MSERV 640” or “MSERV”), couples to components of the MCS, the MSERV, and a Database 644 (also referred to herein as a “Database”) in a number of sequences as described herein and as appropriate toenterprise network system 600. The IM also couples toMCS Management Console 660. The MCS and the MSERV couple to the LAN for communication with other components (not shown) ofenterprise network system 600. - The MCS of an embodiment includes an “Operating System” along with an “Execution Engine,” some number of “Voice Applications,” and some number of “Mobile Applications.” The Operating System includes for example a Linux kernel with a journaling file system that provides integrity of file system tables and the data structure. The storage on the MCS may be configured as a RAID (Redundant Array of Independent Disks) configuration to provide high reliability access to software and data. The Operating System supports operations of numerous other components of the MCS as described below.
- With regard to the Operating System, the MCS includes a “Telephony Interface” that couples calls and connects callers and users to/from the MCS. The Telephony Interface couples call information to/from a private branch exchange (“PBX”) (not shown) for example, where the PBX is a component of
enterprise network system 600. The Telephony Interface couples to the PBX using a variety of telephony integrations that include one or more of analog, Simplified Message Desk Interface (“SMDI”), T1/E1, Voice over Internet Protocol (“VOIP”), and Digital Set Emulation (“DSE”) signals, but may couple using other signals/signaling protocols. When receiving a call from the PBX, for example, the MCS receives data of an incoming call from the PBX, where the data includes called party information, a reason for transfer of call (e.g., called party line busy, no answer by called party, called party using call forwarding, etc.), and calling parting information (caller ID, etc.). - A “Driver” couples information received at the Telephony Interface to the “Telephony Services” component of the MCS. The Driver may perform low level signaling and/or data conversion as appropriate to the received signals. The Telephony Services include one or more components for use in processing the received signals. These components include, for example, voice processing, switching/control, and PBX signaling, but are not limited to these components.
- The MCS of an embodiment includes at least one “Voice Browser” that, when the MCS receives a call, receives voice information of the call. The Voice Browser controls the use of automatic speech recognition (“ASR”) for speech recognition and DTMF recognition. The Voice Browser of an embodiment couples to a cache or other temporary store that holds voice recordings and/or name grammars (“Voice Recordings/Grammars”) (the name grammars are cached after being generated from names in a user list, as described below). The ASR may use information of the name grammars. Further, the Voice Browser controls the use of text-to-speech (“TTS”) as well as the play of any number of pre-recorded prompts (e.g., WAVE format files). The Voice Browser uses voice extensible markup language (“VXML”) but is not limited to this protocol. Alternative embodiments of the MCS may not include the Voice Browser. As an alternative to a Voice Browser, the MCS may directly communicate with, or use other software or processes, for communication between the voice application and the Telephony Services and/or Driver.
- The Virtual Machine, Voice Applications, and Execution Engine form a hierarchical state machine framework in which the Virtual Machine runs a number of APIs and modules. Consequently, the Voice Applications can include one component controlling the user interfaces (“UI”) to the MCS, and another component handling lower-level communications with the modules. Use of a loose coupling between the modules and the Voice Browser provided by the state machine framework allows independence between the languages used in the different modules and the Voice Browser. The state machine framework may receive hypertext transport protocol (“HTTP”) requests from the Voice Browser, for example, and generate VXML or Speech Application Language Tags (“SALT”) (SALT extends existing mark-up languages such as hypertext markup language (“HTML”), extensible hypertext markup language (“XHTML”), and extensible markup language (“XML”), and enables multimodal and telephony-enabled access to information, applications, and web services from devices like PCs, telephones, and PDAs for example).
- The Voice Applications of an embodiment include a number of components including an automatic attendant, a caller interface, a user interface, and a system main menu, but may include other types of voice applications. The automatic attendant is speech enabled, but may be dual tone multi-frequency (“DTMF”)-enabled. The automatic attendant, which can be enabled or disabled, uses information of contact lists (e.g., User List) in the Cache.
- The Voice Applications also include at least one voice mail application. The voice mail application uses information of the Cache (e.g., User List, Global Address List, Public Folders, Personal Contact Folders) in operations that include sending a new voice mail and/or forwarding a received voice mail. The voice mail application also uses Cache information in support of voice mail networking in which voice mails and corresponding information are exchanged with groupware applications of
enterprise network system 600, as described below. - The voice mail application couples to the MCS state machine framework described above via one or more application programming interfaces (“API”). The APIs handle the different data formats/types in use by enterprise network system 600 (e.g., greeting data, PIN (Personal Identification Number) code data, voice mail message data, system parameters, etc.). Similarly, the Cache also couples to the state machine framework, where the Cache includes one or more of local cache and distributed cache. Therefore, communications among the voice mail application, the Cache, and the MSERV take place via the state machine framework and the APIs as appropriate to the state (e.g., offline, online) of the MSERV.
- In addition to the Voice Applications, the modules running under the Virtual Machine of an embodiment include Mobile Applications. The Mobile Applications provide access to user information via mobile devices, where the access may include transferring information of email, calendar, and/or contacts to a user's mobile client device via an electronic message (e.g., SMS, MMS, and/or pager).
- The MCS also includes an “Administration/Configuration” manager. The Administration/Configuration manager provides access to and control of a unified configuration file of the MCS. The Administration/Configuration manager uses information of the unified configuration file to provide separate Configuration Files to one or more of the components of the MCS as appropriate. The unified configuration file can be copied from the MCS and stored for backup purposes. Additionally, a predefined configuration file may be uploaded to the MCS to provide the appropriate configuration for the MCS. A browser interface to the Administration/Configuration manager allows remote access to the MCS.
- The MCS also includes a “Self Maintenance Supervisor” or reliability server that monitors MCS components and restarts failed processes when necessary, for example. In addition, the MCS also includes “Security Restrictions” for use in controlling MCS/port security.
- As described above, the MCS of an embodiment interfaces with the MSERV via the IM. The MCS communicates with the IM via the Groupware Connector for example, but is not so limited. The Groupware Connector of an embodiment includes a “Web Server,” but is not so limited. The MSERV functions as a messaging and collaboration server. The IM is an interface that runs under the MSERV in one embodiment to provide communications and information transfers between components of the MCS and components of the MSERV. In other embodiments, the IM may run under control of the MCS, for example. The IM includes and/or couples with
Management Console 660 as well as with a diagnostics component (“Diagnostics Component”) and/or a run time component (“RTC”) (not shown). -
Management Console 660 supports access to the MCS by a system administrator ofenterprise network system 600 for purposes of managing user access. Consequently,Management Console 660 allows a system administrator to enable new users with integrated messaging functionality of the ICS and administer and monitor one or more MCSs. - The Diagnostics Component of the IM supports on-the-fly diagnostics gathering, computing, and/or compiling of pre-specified diagnostics information or parameters from the MSERV. In this manner the MCS may provide diagnostics information and a user may provide dynamically updateable diagnostics information.
- The RTC translates communications between components of the MCS and components of the MSERV. As an example the RTC may be used to retrieve user information from the directory service (e.g., Active Directory) of a groupware application in response to a request from the MCS, as described below. Communications between the RTC and components of the MCS use for example XML and Web Services.
- Communications between the RTC and the MSERV may use one or more APIs of the MSERV (e.g., MAPI, Collaboration Data Objects (“CDO”), Web Distributed Authoring and Versioning (“WebDAV”), etc.).
- The MSERV of an embodiment represents a messaging and collaboration server. The messaging and collaboration server includes a groupware application that runs on one or more servers and enables users via local client devices to send and/or receive electronic mail and other forms of interactive communication through computer networks. The MCS of an embodiment interoperates with groupware applications that include, but are not limited to, Microsoft Exchange Server, but alternative embodiments may use other types of messaging and collaboration servers. Therefore, the MCS of an embodiment interoperates with client device applications (“client applications”) such as Microsoft Outlook, as well as with other email client applications (e.g., Microsoft Outlook Express).
- The MSERV sends and receives email messages through what is commonly referred to as a client device such as a personal computer, workstation, or a mobile device including mobile phones or PDAs. The client device typically connects to the LAN, which may include any number and/or combination of servers or mainframe computers where the email mailboxes and public folders are stored. The centralized servers connect to numerous other types of networks (e.g., private or proprietary, and the Internet) to transmit and receive email messages to other email users. Consequently, the MCS uses the MSERV for storing and forwarding email messages in an embodiment.
- The MSERV also couples to a directory service (not shown), which is a database of information on each user account in the enterprise network system. Access to the directory service may use for example a Lightweight Directory Access Protocol (“LDAP”).
- With regard to client device access functionality, the MSERV provides integrated collaborative messaging features such as scheduling, contact, and task management capabilities. As an example MSERV configuration, when the MSERV is Microsoft Exchange, the MSERV runs on a version of the Microsoft Windows Server operating system. A version of Microsoft Office Outlook runs on Windows-based local client devices and communicates with the MSERV through the messaging application programming interface (“MAPI”) protocol. The MSERV also accommodates other client device access by supporting one or more of Post Office Protocol 3 (“POP3”) and Internet Message Access Protocol 4 (“IMAP4”) protocols as well as support for Simple Mail Transfer Protocol (“SMTP”). Using this same MSERV configuration example, the MCS of an embodiment, along with Microsoft Outlook Web Access (a service in Microsoft Exchange) accommodates web browser-based access clients, also referred to as thin clients.
- The MSERV collaboration features support information sharing among users. Collaborative scenarios include maintaining shared address lists that all users can view and edit, scheduling meetings that include people and conference rooms by viewing associated free or busy schedules, the ability to grant other people, such as administrators, access to user mailboxes on behalf of the user.
- As described above, the IM serves as an interface for the transfer of information between components of the MCS and components of the MSERV. Transferring information includes for example pulling, receiving, retrieving, polling, transmitting, and pushing operations, to name a few. As an example of information transfers between the MCS and the MSERV, the IM pulls information from one or more components of the MSERV and makes the pulled information available to, for example, the MCS Cache. The IM also pushes information from one or more components of the MCS to the MSERV.
- In serving as an interface between the MCS and the MSERV, the components of the IM (e.g., RTC) translate communications between components of the MCS (e.g., Virtual Machine, Cache, etc.) and components of the MSERV environment. As an example the IM retrieves user information from components of the directory service (e.g., Active Directory) in response to a request from the MCS/Cache.
- Embodiments of the IM may include one or more of the following components: an RTC, a Management Console, a desktop component, messaging actions control component, Diagnostics Component and/or a message waiting indication component. The desktop component allows the user to configure aspects of the user's integrated messaging account, such as voice message greetings, extended absence greeting, PIN code data, and presence information. The messaging actions control component receives and responds to user generated requests from the FBUI (defined herein) to take actions such as playing, replaying to and forwarding voice messages, as well as calling the sender of a voice mail message. The message waiting indication component receives events from the user's message inbox folder and requests corresponding action from the PBX or other aspect of the telephony system, such turning on message waiting indicators on the user's device(s). The message waiting indication component may send notifications by way of SMS, MMS and/or pager.
-
FIG. 7 is a block diagram 700 that shows interactions between the IM and components of theMSERV environment 740, under an embodiment. The components ofMSERV environment 740 include the MSERV and one or more Databases as described above. The Database of an embodiment includes adirectory service 742. -
Directory service 742 provides a location for storage of information about network-based entities, such as applications, files, and printers to name a few.Directory service 742 also stores information about individuals, also referred to as users, and this information is referred to herein as “User Information.” Assuch directory service 742 provides a consistent way to name, describe, locate, access, manage, and secure information about individual resources in an enterprise network environment.Directory service 742 uses the stored information to act as the main switchboard of the enterprise network operating system and is therefore the central authority that manages the identities and brokers the relationships between distributed resources of the enterprise network, thus enabling the resources to work together.Directory service 742 of an embodiment may be Microsoft Active Directory (“AD”), but is not so limited. - In embodiments including AD, there is a user object stored in an AD Database for each enterprise user. For example, the user object for
enterprise USER 2 is shown asUSER 2object 702. The user object includes many fixed attributes such as user name, user phone number, user mailbox location, and user email address. - The user object further includes a number of “Custom Attributes.” The number of Custom Attributes is small, for example fifteen, compared to the number of fixed attributes. The Custom Attributes are usable to store information not provided for in the predefined fixed attributes. In one embodiment, a Custom Attribute stores user-specific data that is used by the Voice Applications. Examples of such user-specific data include a class of service (“COS”) for the user, a voice mail extension for the user, whether voice mail is enabled for the user, etc. The data is stored as a data stream in the Custom Attribute with a maximum size of 2048 bytes. In an alternative embodiment, the user-specific data that is used by the Voice Applications is stored as individual data items in fixed attributes by extending AD in a known manner.
- The user mailbox location fixed attribute indicates where the user's email mailbox is stored in the enterprise. In some large enterprises, there may be many MSERVs, each including a database storing many user mailboxes. As shown, the mailbox location fixed attribute points to
USER 2mailbox 704 on an MSERV calledMSERV 1. -
User mailbox 704 stores email messages sent to the user, as well as outgoing messages and other items, for predetermined periods of time. In an embodiment, the messages can be of at least two types, one of which is a “normal” message that is routinely accessible by the user. Another message type is a “hidden” message that is not routinely accessible by the user through the normal user email interfaces. In an embodiment, a hidden message is used to store data used by the Voice Applications. In contrast to the data stored in the Custom Attribute, however, the data stored in the hidden message can be much larger than the 2048 byte limit of the custom attribute. In one embodiment, among the data stored in the hidden message are audio files stored as attachments to the hidden message, such as a “busy” greeting for the user's voice mail mailbox, a “no answer” greeting for the user's voice mail mailbox, and a recorded name for the user's voice mail mailbox. - An example of the MCS accessing the
MSERV environment 740 throughIM 620 is a phone caller calling the voice mail mailbox ofUSER 2 whenUSER 2 is on the phone. The MCS transmits an action viaIM 620 with a request to “play busy greeting.” The transmission includes information to access theUSER 2object 702 fixed attributes to determine the user's email mailbox location. In addition the transmission includes information to access theUSER 2object 702 Custom Attribute and to transfer the contents of the Custom Attribute to the MCS viaIM 620. When the user's email mailbox is accessed, the hidden message is opened to transfer the appropriate audio file (“busy” greeting in this case) to the MCS for playing over the phone to the caller. In many cases, it may not be necessary to transfer either the Custom Attribute or the audio file from theMSERV environment 740 because the current custom attributes and audio file are cached on the MCS. - As described above, operations of the Voice Applications and the Virtual Machine couple the Cache and other components of the MCS to components of the MSERV via the IM. As such, the MCS and the IM support the transfer of information between the Cache and backend network components like the MSERV and the database. This configuration provides transparency between the Voice Applications and data stored in the database when using information of the database to support voice mail messaging functions of the MCS, as described below.
- The information transfers between the Cache and the MSERV along with use of the Custom Attributes and Hidden Messages as described above allow the ICS to overcome the need for an external database to store information stored by a typical voice mail system. This is because the information used by the MCS in providing voice mail message capabilities integrated with the email messaging capabilities of the enterprise network is pulled by the MCS from the MSERV via the IM. The pulling or retrieving may be performed periodically, continually, on demand, and/or in response to particular events (e.g., update of the information in the MSERV) but is not so limited. The information pulled by the MCS includes information of a “Global Address List” (“GAL”), information of one or more “Public Folders,” “Personal Contacts,” and information of a “User List.”
- The GAL includes information of all users in the enterprise network having access privileges that include the use of email. Public Folders include information of the network enterprise (e.g., contacts, calendars, etc.) that are shared with all users. The Personal Contacts include contact information for each user.
- The User List includes User Information for a subset of users in the GAL each of whom has access privileged that include the use of the ICS. The User List therefore is a subset of the GAL and is retrieved and/or cached as a separate list or stream in order to improve efficiency of communications and minimize the delays associated with having the MCS search the entire contents of the GAL for information used in executing a user-requested action on a voice mail message. The User List of an embodiment includes one or more of the following parameters corresponding to each user, but is not limited to these parameters: Site identification, mail box number, pronounceable name, office telephone extension, COS, automatic attendant state (e.g., enabled, disabled), voice mail state (e.g., enabled, disabled), Voice User Interface (“VUI”) state (e.g., enabled, disabled), mobile access state (e.g., enabled, disabled), bad logins, locked out, attendant destination, force change of PIN code, mobile gateway identification, full name, first name, last name, user name, home telephone number, office telephone number, cellular telephone number, identification, email address, department, active greeting state, time and date announcement, voice mail notification state (e.g., enabled, disabled), mail box status, PIN code in encrypted or raw form, no answer greeting, busy greeting, extended absence greeting, recorded name, and system greeting.
- Instead of storing the information pulled from the MSERV in a separate voice mail database as would be done in a typical voice mail system, the pulled information is pushed by the IM to the MCS and held in the Cache. The MCS uses the pulled information in subsequent voice mail message manipulation operations as described below. This pulling and caching of information by the MCS improves the speed and efficiency of voice mail message operations and prevents unnecessary loads on the MSERV resulting from the nearly continuous stream of read requests to the MSERV database in typical messaging systems.
- The pulling of information from the MSERV by the MCS includes pulling and caching of information including the GAL, Public Folder, and User List. The pulled information is cached by the MCS on a system or non-individual basis because this information applies throughout the enterprise. This information is pulled and cached periodically, for example at 24-hour intervals (e.g., each morning at 2:00 am), or may be loaded on demand, but is not so limited.
- In contrast the MCS pulls and caches information of the Personal Contacts on a per user basis because this information is different for each user. The Personal Contacts may be requested and cached by the MCS periodically or on demand (e.g., at the time a user logs in to the ICS, in response to modifications of the Personal Contacts, etc.).
- In operating to provide integrated messaging capabilities, the MCS and the IM function to route a call placed by a caller to a user and, in the event the user is not available, to receive and route a voice mail message left by the caller. The MCS and the IM also function to provide a user with access to voice mail messages using the messaging server of the enterprise email system. The voice mail access supports both online and offline modes of the messaging server.
- An example of call routing by the MCS, and with further reference to
FIG. 6 , the MCS receives and detects a call at the Telephony Interface. Data of the call (e.g., called party information, calling party information, reason for call transfer, etc.) invokes the Voice Browser. The Voice Browser transfers a request to the Voice Applications in response to the call data. - A Dispatcher component of the Voice Applications routes the call to one or more other Voice Application components in accordance with information of the User List. As an example, the Dispatcher identifies the target user for the call, and determines whether the target user's automatic attendant is enabled. If the automatic attendant is enabled then the automatic attendant receives the call request and provides the caller with one or more call routing options (e.g., caller selects call routing by selecting and/or saying extension number, selecting and/or saying name, etc.) and routes the call according to the caller's input.
- As an example, one or more of the Voice Applications determine an active greeting currently designated by the user for use in responding to calls (e.g., system greeting, no answer greeting, busy greeting, extended absence greeting, etc.), and retrieve the designated active greeting from one of the Cache or MSERV as appropriate to a state of the MSERV. The respective application(s) play the greeting, activate a “record mode” to record the voice mail message of the caller, and provide the caller with additional options available for call and/or message routing (e.g., message marking options, message delivery options, send message, route message to additional users, etc.). Upon completion of the recording and/or selection of a message routing option by the caller, the respective application(s) terminate the call (hangs up) and transfer the recorded voice mail message to one or more locations in the Cache and/or MSERV (e.g., a mail box) that correspond to the user, as described below with reference to
FIGS. 8, 9 , and 10. Alternatively, the voice mail message may be transferred before the application terminates the call. - As referenced above, the MCS of an embodiment in conjunction with the IM supports availability of and access to the voice mail applications when the MSERV is both “online” and “offline” through the use of the Cache. The MCS of an embodiment includes an “Offline Detector” that monitors an availability state of the MSERV and detects unavailability (“offline condition” or “offline state”) of the MSERV. Upon detecting MSERV unavailability, the MCS transitions to a mode that supports voice mail message recording and retrieval during the MSERV offline condition.
- Caching of select information received and/or generated in the MCS, including User Information and voice mail information, enhances performance of the enterprise network voice messaging system by reducing the instances of data retrieval from the MSERV. Further, caching of select information improves the reliability of the enterprise network voice messaging system by allowing access to the voice messaging system during periods when the MSERV is offline.
- Information received at the MCS is routed and held in the Cache in accordance with policies running in the state machine framework and/or the availability state of the MSERV. Examples of information held in the Cache include but are not limited to the User List, Global Address List, information of Public Folders, information of Personal Contact Folders, voice mail message information (both the text description portion and the audio message portion of the voice mail message), greetings, and other user parameters/permissions, and personal information of users (e.g., PIN codes).
- Regarding actions taken by the MCS following receiving and recording of a voice mail message when the MSERV is online, the MCS generally holds information of the recorded message in the Cache. The MCS may also transfer the recorded voice mail message via the IM to the MSERV where it is stored in the Database.
- As an example,
FIG. 8 is aninformation flow 800 for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment. This information flow 800 shows one MCS and one MSERV in an enterprise network environment, but this is shown only as an example and does not limit the network environment to the types, numbers, and/or coupling of components shown as alternative embodiments may have any number of MCSs and/or MSERVs. -
Information flow 800 begins when a caller places acall 802 to a user and availability of the user results in the caller leaving a voice mail message (referred to herein as the “VMSG”) for the user. The voice mail message VMSG is received at the MCS and routed 804C to the Cache where it is assigned an identification (referred to herein as the “CACHEID”) and held. The voice mail message VMSG may be held in the Cache for a pre-specified period of time, but the embodiment is not so limited. The voice mail message VMSG and the CACHEID are also routed 804M to the MSERV via the IM, as described above. The MSERV assigns an identification (referred to herein as the “VMSGID”) to the incoming voice mail message VMSG andstores 806 the voice mail message VMSG along with the VMSGID and CACHEID in one or more areas of memory (not shown) available to the MSERV. Memory may include any various form of storage or computer-readable memories such as, but not limited to, volatile memory (random access memory (“RAM”), non-volatile memory (read-only memory (“ROM”), EEPROM, disk, and/or other storage devices that may include one or more of magnetic and optical storage media. - As described above, the MCS pulls information (e.g., periodically, on demand, etc.) from the MSERV via the IM and uses the pulled information in providing voice mail message capabilities integrated with email messaging capabilities of the enterprise network. Therefore, pulling operations by the IM include pulling of information identifying the stored voice mail message VMSG, where the information identifying the voice mail message VMSG includes but is not limited to the CACHEID. Upon request from the MCS, the IM may pull 808 a voice mail list (referred to herein as a “VMLIST” 809), which includes CACHEIDs and VMSGIDs for any stored messages from the MSERV environment. The IM pushes 810
VMLIST 809 to the MCS where it is held.VMLIST 809 may be generated from the user's inbox upon each request from the IM or may be stored and maintained in the MSERV or in the cache as a current representation of the contents of a user's voice mailbox, or inbox. If and when a time period for holding a VMSG in the Cache expires, the VMSG is still identifiable fromVMLIST 809, and can be found in the MSERV if requested, using the VMSGID. -
Information flow 800 continues when a user accesses 820 the enterprise network system to retrieve his/her voice mail messages. In an embodiment, theuser access 820 causes the VMLIST to be pulled 808 from the MSERV and pushed 810 by the IM to the Cache, and also or alternatively to the MCS Upon being provided with access to the MCS, the user selects one or many voice mail message(s) by selecting a VMSGID/CACHEID item from the VMLIST. In response to the user selection, MCS searches 822 the Cache for a message, using the Cache identification CACHEID of the selected message. In a scenario in which the message was left by the caller and the time period for holding the message VMSG in the Cache has not expired, the MCS will locate the CACHEID and the message contents VMSG in the Cache. Once located through use of the CACHEID, the MCS retrieves 814R the voice mail message contents VMSG from the Cache, and plays the voice mail message for the user as appropriate to the action selected by the user. - In this manner the MCS provides user access to the contents of the voice mail message VMSG via a mapping and without storing voice mail message contents in the MCS. The mapping includes a mapping of voice mail message contents to identification information of the email environment (MSERV environment), and mapping identification information of the email environment to identification information of the voice mail environment (MCS). In this embodiment, therefore, the mapping includes mapping of voice mail message contents to the message identification VMSGID, and mapping of the message identification VMSGID of the email environment to the MCS identification CACHEID.
- As used herein “pushing” data or information indicates an action of a component or entity that has the affect of transferring the data or information to another component or entity. Transferring includes sending in response to a request, query or command, and sending on the initiative of the transferring component or entity. The transfer may be an internetwork transfer, an intranetwork transfer, or a transfer between a network component or entity and a non-network component or entity.
- As used herein “pulling” data or information indicates a component or entity receiving transferred data or information. Receiving includes receiving in response to a request, query or command, and retrieving in response to a request, query or command. The transfer may be an inter-network transfer, an intra-network transfer, or a transfer between a network component or entity and a non-network component or entity.
-
FIG. 9 is analternative information flow 900 for routing and accessing voice mail messages via the ICS when the MSERV is in an online state, under an embodiment. Thisalternative information flow 900 describes the scenario in which the message VMSG is left by the caller and stored in the cache and in the MSERV environment, and after expiration of the time for holding the message VMSG in the cache. -
Information flow 900 begins when a caller places acall 802 to a user and availability of the user results in the caller leaving a voice mail message VMSG for the user. The voice mail message VMSG is received at the MCS and routed 804C to the cache as described above, and the VMSG and CACHEID is routed 804 to the MSERV via the IM, also as described above. The MSERV assigns identification VMSGID to the incoming voice mail message VMSG andstores 806 the voice mail message VMSG along with the VMSGID in one or more areas of memory (not shown) available to the MSERV. -
Information flow 900 continues when a user accesses 820 the enterprise network system to retrieve his/her voice mail messages.VMLIST 809 is pulled 808 from the MSERV and pushed 810 by the IM to the MCS. Upon being provided with access to the MCS, the user selects a voice mail message fromVMLIST 809, by selecting a CACHEID/VMSGID item. The MCS searches 822 the Cache for the Cache identification CACHEID of the selected message in response to the user selection. Because the message was left by the caller and stored in the MSERV environment and expired in the cache before the user calls in, the MCS will not locate the CACHEID in the Cache. Consequently, the MCS accesses the MSERV, identifies the message VMSG, and pulls 924R the voice mail message contents from the MSERV environment via the IM. The MCS plays the pulled voice mail message VMSG for the user as appropriate to the action selected by the user. - In addition to the online scenarios described above, the MCS of an embodiment provides offline behavior that allows for holding, storing, and retrieving voice mail messages when the MSERV is offline or unavailable for some reason, or during times when the connection between the MCS and the MSERV is unreliable. Offline behavior means absence of a coupling between the MSERV and the MCS. Regarding actions taken by the MCS following recording of a voice mail message when the MSERV is offline, a component of the MCS (e.g., Offline Detector) detects the MSERV is offline. The MCS holds the recorded voice mail message in the in response to detecting the MSERV state as offline. At such time as the MCS detects the MSERV is online, the Groupware Connector pulls the voice mail message from the Cache and transfers the recorded voice mail message via the IM to the MSERV where it is stored in the Database.
- As an example,
FIG. 10 is aninformation flow 1000 for routing and accessing voice mail messages via the ICS when the MSERV is in an offline state, under an embodiment. Thisinformation flow 1000 shows one MCS and one MSERV in an enterprise network environment, but this is shown only as an example and does not limit the network environment to these components as alternative embodiments may have any number of MCSs and/or MSERVs. - The
information flow 1000 begins when a caller places acall 802 to a user and availability of the user results in the caller leaving a voice mail message VMSG for the user. The voice mail message VMSG is received at the MCS, however a component of the MCS detects an unavailable or offline condition of the MSERV. In response to detecting the offline condition, the MCS assigns a CACHEID to the incoming message VMSG, and holds 1004C the message contents VMSG along with the CACHEID in the Cache. -
Information flow 1000 continues when a user accesses 820 the enterprise network system to retrieve his/her voice mail messages while the MSERV remains in an offline condition. Upon being provided with access to the MCS, the user selects a voice mail message from a list of CACHEIDs generated from the collection of voice mail messages held for him/her by in the cache. In response to the user selection, the MCS searches 1022 the Cache using the Cache identification CACHEID of the selected message. Upon locating the voice mail message by its CACHEID in the Cache, the MCS pulls 1014R the voice mail message contents from the Cache, and plays the voice mail message for the user as appropriate to the action selected by the user. - The MCS continues to monitor the condition of the MSERV. At such time as the MCS detects a return of the MSERV to an online condition, the MCS pulls 1004P the voice mail message VMSG and its CACHEID from the Cache, and transfers 1004M the voice mail message and CACHEID via the IM to the MSERV. The MSERV assigns an identification VMSGID to the incoming voice mail message VMSG and stores 1006 the voice mail message VMSG along with the VMSGID and CACHEID in one or more areas of memory as described above.
- In addition to the capabilities described above, the ICS of an embodiment provides a Form-Based User Interface (“FBUI”). The FBUI is a form-based messaging or communication interface for use by users in retrieving voice mail messages and controlling actions taken on voice mail messages received in the enterprise network system. This FBUI enables a user to retrieve and take various actions on voice mail messages using data of a form (referred to herein as the “FBUI FORM”) that is presented to the user's client device by the enterprise network email system. Use of the FBUI Form thus provides the user with access to the integrated messaging functions offered by the ICS without a requirement to install or run a dedicated client application on the user's client device.
-
FIG. 11 is a block diagram of asystem 11 that includesICS 1100 withFBUI 1180, under an embodiment.System 11 includes anenterprise network 1101 that provides integrated voice mail and email messaging through the use ofICS 1100.Enterprise network 1101 includes a LAN that couples to components ofICS 1100 and amessaging server environment 1140.ICS 1100 includes MCS 1110 IM 1120, andFBUI 1180, but is not so limited.FBUI 1180 is presented to a user (e.g., USER Z) via one or more local devices like PCs or other processor-based devices. -
Messaging server environment 1140 includes the MSERV and aDatabase 1144, but is not so limited. The LAN couples to any number ofother networks networks public communications network 1150 and aprivate communications network 1160.Private communications network 1160 may be a PBX coupled to the LAN of the enterprise network, for example.Networks client devices 1170 that are local toenterprise network 1101 andclient devices 1199 that are external toenterprise network 1101. The client devices may alternatively be referred to as “user devices” 1170 and 1199. -
ICS 1100 replaces the voice mail server typically found in enterprise networks with at least one MCS 1110. MCS 1110 is coupled to the private communications network (e.g., PBX) of each network enterprise. While one MCS is shown in thisexample system 11, the enterprise network may include multiple MCSs 1110 coupled to enterprise network in an “N+1” configuration, where “N” is anynumber - For security reasons, communication to and from the MCS is restricted in an embodiment. The MCS communicates with the IM servers, the private communications network, other MCSs and selected client devices. According to an embodiment of the invention, communications with the MCS may be restricted to network components having particular known addresses. Additionally or alternatively, communications with the MCS may require authentication by passcode or other security measures for certain kinds of access, for example, for access by the administrator. Security may also or alternatively be encrypted and/or provided by requiring a physical connection between the MCS and other component, such as in the case of a connection between an MCS and a private communications network through a direct cable connection.
- The MCS via the FBUI generally provides a form to a client device from a first server (e.g., messaging server, MSERV, etc.) via a network connection. The form includes data or code that when executed by the receiving client device results in presentation of a FBUI on a display of the client device. The FBUI includes a number of buttons or icons that allow a user to select an action on an item via a second server (e.g., communication server, MCS, etc.), where the item is stored on the first and/or second servers, and the first and second servers are different servers. The FBUI of an embodiment uses a web browser embedded in the form as the means for coupling and/or communicating with a corresponding browser control of the second server. Communications between the client device and the second server thus avoid security and/or other network policy issues that would prohibit the client device from communicating with the second server via the network coupling between the client device and the first server.
- As described above, the FBUI operates as a form-based messaging interface to transfer a first message (e.g., voice mail message) to a messaging server (e.g., MSERV) from a communication server (e.g., MCS) via a first coupling (e.g., IM). The messaging server generates a second message (e.g., email message) in response to a type of the first message and transfers the second message to a client device via a second coupling (e.g., LAN). The type of the first message is specified by the communication server using properties on the message that identify the message as a “Voice Mail Type” (“VMT”) message. The second message is of a different type and includes data of the first message, but is not so limited. The communication server also transfers to the client device form data that corresponds to the first message. The client device uses the form data to establish a third coupling (e.g., browser link) between the client device and the communication server. The user may direct actions on the first message from the client device via the third coupling using the form data.
- The ICS of an embodiment provides the
FBUI 1180 to a user via his/her local client device. The FBUI is provided to the client device through the use of a FBUI Form, where the structure of the FBUI Form conforms to the message structure of the messaging server environment. For example, when the messaging server environment includes the use of Microsoft Exchange and Microsoft Outlook, the FBUI Form is generated to comply with Microsoft formats as appropriate to Exchange and Outlook - Information for generation of the FBUI Form is provided to the messaging server environment by the MCS via the IM, and the code used for FBUI Form generation is hosted by the MSERV in an embodiment. The FBUI Form of an embodiment includes code that generates information of the FBUI display as well as the buttons of the display. The FBUI Form further includes an embedded browser control for use in establishing communications between the client device displaying the FBUI Form and a web server (e.g., MCS, IM, other server) for example. The embedded browser control therefore allows the host client device to couple and communicate with a server that is different from the MSERV via a communication channel that is outside the enterprise network LAN. Thus, the FBUI Form enables a communication channel between the local client device currently executing the form and a component like the MCS and/or IM in spite of network policy issues that otherwise might prohibit the client device from communicating outside the enterprise network message infrastructure.
- Using the FBUI, a user can access/view and take a variety of actions on his/her voice mail messages within an email framework of the host enterprise network system. As an example, when the MCS of an embodiment receives a voice mail message it transfers the voice mail message to the MSERV, as described above. In transferring the voice mail message to the MSERV, the MCS specifies properties on the message that identify the message as a “Voice Mail Type” (“VMT”) message. The message is received and stored by the MSERV as a VMT message using the same storage and retrieval structure as used with other message types like email messages.
- At such time as a user wishes to access his/her messages via his/her client device, the active message browser of the client device receives the VMT message along with any other mail messages currently stored in his/her electronic mail box. The message browser corresponds to the message structure of the messaging server environment (e.g., Outlook in a Microsoft environment). Upon receipt of the message, the message browser identifies the message as a VMT message. As the code that implements the FBUI Form is stored on the MSERV, implementation of the functionality and/or features associated with the FBUI Form uses communication between the user's client device and the MSERV via the LAN. For example, the client device message browser requests the FBUI Form from the MSERV in response to identifying a message as a VMT message because this is the form that corresponds to the VMT message type. The MSERV transfers the FBUI Form to the requesting client device, and the client device message browser launches the form in response to the user selecting a VMT message for viewing.
- The message browser uses data or code of the FBUI Form to display the FBUI on the user's client device.
FIG. 12 is asample FBUI 1200 as displayed on a client device, under an embodiment. TheFBUI 1200 includes three areas 1202-1206 that present information to a user. The areas include afolder area 1202, acontents area 1204, and afunction area 1206, but are not limited to these areas as the UIs of alternative embodiments may present any number and/or type of areas. In alternative embodiments, all three areas 1202-1206 may be presented at the same time, as shown inFBUI 1200, or various subsets of the three areas may be presented at the same time in various combinations. -
Folder area 1202 presents one or more folders to which the user has access via theFBUI 1200 and the client device. The “INBOX” may contain a list of voice mail messages in the same listing as other messages, including email messages. Alternatively, the Inbox may include a subfolder (“VOICE MESSAGES”) which includes the voice mail messages, and selection of this folder results in the presentation of voice mail messages of the user's mail box in thecontents area 1204. - The
contents area 1204 generally presents the contents of the folder selected using thefolder area 1202. As an example, thecontents area 1204 presents information corresponding to any number of voice mail messages in the user's mail box when the INBOX or VOICE MESSAGES folder is selected.Contents area 1204 allows the user to select a particular voice mail message by placing a cursor on “VOICE MESSAGE 1 INFORMATION” for example. By (double) clicking a message in thecontents area 1204 or otherwise indicating to the message browser to display a voice message, a new window (referred to as the “ICS Window”) is displayed. The ICS Window now includes function are 1206. -
Function area 1206 ofFBUI 1200 presents one or more “voice mail action buttons” 1206A-1206E (also referred to herein as “buttons”) each of which represents an action the user may select for a voice mail message. In this example, the VOICE MESSAGES folder is selected, and selection of a message incontents area 1204 allows the user to take an action on the selectedmessage using buttons 1206A-1206E. Placing the cursor ofcontents area 1204 on a particular message and choosing an action on the selected message with abutton 1206A-1206E therefore invokes operations on the message via components of the ICS (e.g., MCS, Cache, IM). Thebuttons 1206A-1206E of an embodiment include a “Play on Phone”button 1206A, a “Play on Computer”button 1206B, a “Call Sender”button 1206C, a “Reply by Voicemail”button 1206D, and a “Forward by Voicemail”button 1206E, but the embodiment is not limited to this same number of buttons or to buttons offering the same functionality. - In other embodiments, presentation of areas or information of the FBUI may vary in many ways. For example, in one embodiment, the
action buttons 1206 appear after the user has selected (for example by double clicking a particular voice message from thecontents area 1204.Action buttons 1206 may also appear when the user right clicks on a particular voice message in thecontents area 1204. - The
folder area 1202 may also include a subfolder (“VOICE MESSAGE SYSTEM”) under the Public Folder. As such, the VOICE MESSAGE SYSTEM folder may not be considered an actual folder but instead a uniform resource locator (“URL”) that, when selected, sends an HTTP request to a web server and launches/displays an ICS browser inside the client device message browser. The web server may, for example, be a component of the MCS and/or IM, but is not so limited. The ICS browser is an embedded or hidden browser that displays the ICS Window in the area of the client device message browser where emails would typically appear, and the voice mail messages are displayed in the ICS Window. - As an example, the ICS Window is displayed in the
contents area 1204 of an embodiment. The ICS Window may be served from the IM and may contain any information related to the voice messaging system that is user specific. In one embodiment, the ICS Window will display a user login prompt where the user enters the user name and PIN code. Subsequently, the system displays the user's configuration date, such as PIN code, attendant extension, greeting type, and other applicable information. - The hidden browser enables an HTTP link and communications with the IM, for example, which then brokers communications (via HTTP) with the MCS via the MCS Web Server (
FIG. 6 ) for example. Therefore, while typical messaging servers and LANs use security policies that restrict the use of “special” code in form data, use of the hidden browser embedded in a form structure that is native to the host system overcomes this restriction because the browser is not detected or considered as special code. Use of the hidden browser thus supports communication with the corresponding browser control in the MCS and/or the IM, thereby allowing the integration of voice mail messaging provided by the MCS with the email messaging system of the enterprise network - A “voice mail message” in the ICS is generally any message created using a client device generating an audio stream. A “voice mail message” is also any VMT message, such as a message created using the “Reply by Voice Message” and “Forward by Voice Message” buttons of the FBUI. An “email” is any message created using buttons of a host mail message system that function to generate a reply message or to forward a message in response to receipt of a message, even if replying or forwarding a voice mail message. The ICS of an embodiment presents a voice mail message to a user in an email message system using the FBUI as the presentation form.
- As described above,
FBUI 1200 allows a user to take action on a voice mail message viabuttons 1206A-1206E ofFBUI 1200. Therefore, placing the cursor ofcontents area 1204 on a particular message and choosing an action on the selected message with abutton 1206A-1206E invokes the action on the message via components of the MCS and/or the enterprise network environment. - As one example of an action on a voice mail message, and with further reference to
FIG. 11 , the user may select a “Play on Phone”action using button 1206A. In response the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI. The client device receives a pop-up message from the ICS via the browser link and the ICS Window, where the pop-up message allows the user to choose or enter a telephone number to which he/she would like the selected voice mail message routed. The pop-up message also includes a “connect” button by which the user initiates routing of the selected voice mail message to the selected telephone. In response to selection of the “connect” button, the IM couples with an MCS, and the MCS causes the PBX to initiate a call to the telephone number selected by the user via the pop-up window. Upon connection of the call from the PBX to the selected telephone, the MCS pushes the contents of the voice mail message to the selected telephone. - Another example of an action on a voice mail message includes selection of a “Play on Computer” action by the user via
button 1206B. In response the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI. In response to selection of the “Play on Computer” button, the IM couples with an MCS, and the MCS pushes a form to the user's computer that resembles a typical email. The form includes an attachment that is an audio file (e.g., WAVE, MP3, other audio formats, etc.). When the user selects the attachment the client device may launch the default audio player of the client device. - Alternatively, selection of the attachment in a “Play on Computer” action may result in the browser form controlling launch of a pre-specified audio player instead of the default audio player. This is similar to the hidden browser described above with reference to presentation of the FBUI.
- The user may also select a “Call Sender” action on a voice mail
message using button 1206C. In response the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI. In response to selection of the “Call Sender” button, the IM couples with an MCS, and the MCS retrieves the selected message from the Cache or the MSERV. Using the caller information from the retrieved message, the MCS causes the PBX to connect the call to the user's local telephone. Upon connection of the call from the PBX to the user's telephone, the MCS causes the PBX to initiate a call to the sender's telephone number as determined from the caller information associated with the voice message. - Additionally, the user may select a “Reply by Voice Message” action on a voice mail
message using button 1206D. In response the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI. In response to selection of the “Reply by Voice Message” button, the IM couples with an MCS, and the MCS retrieves the selected message from the Cache or the MSERV. The MCS causes a reply message to be generated corresponding to the received message, and prompts the user to record an audio message for the reply. The user records the audio for the reply via a microphone coupled to his/her client device. Alternatively, the user may record the audio for the reply via his/her local telephone. Upon completing the audio reply recording, the MCS causes the reply message to be transmitted to the designated addressees via the MSERV. A user is not required to listen to a message to invoke the “Reply by Voice Message” action. - The user may also select a “Forward by Voice Message” action on a voice mail
message using button 1206E. In response the user's client device couples to a component of the ICS (e.g., IM) using the hidden browser of the FBUI. The client device receives a pop-up message from the ICS via the browser link, where the pop-up message allows the user to choose or enter a telephone number to which he/she would like the selected voice mail message routed. The pop-up message also includes a “connect” button by which the user initiates routing of the selected voice mail message to the selected telephone. In response to selection of the “connect” button, the IM couples with an MCS, and the MCS causes the PBX to initiate a call to the telephone number selected by the user via the pop-up window. Upon connection of the call from the PBX to the called telephone selected by the user, the MCS pushes the contents of the voice mail message to the called telephone and the user. During the session, and in addition to the contents of the voice mail message, the MCS may provide a verbal prompt to the user requesting information of the party to whom the message is to be forwarded, and/or a prompt to the user to record an audio message to be forwarded along with the forwarded message. A user is not required to listen to a message to invoke the “Forward by Voice Message” action. -
FIG. 13 is a block diagram of asystem 13 that includes multiple Sites (defined herein) and multiple components, under an alternative embodiment.System 13 includes multiple Sites, some of which may have multiple MCSs, IMs, private communication networks and MSERVs. As shown,system 13 includesMSERV 1390 andMSERV 1391 communicating via anetwork 1392, which may comprise any of a public network, such as a PSTN, or private communications network or other network. The MSERVs are coupled to one or more IMs. For example, as shown here,MSERV 1390 is coupled to IMs 1385 (IM1 and IM2), andMSERV 1391 is coupled to IMs 1386 (IM3 and IM4). The IMs are coupled to one or more MCSs. For example, as shown here IM1 is coupled to MCS1, MCS2, and MCS3; IM2 is coupled to MCS2, MCS3, MCS4 and MCS5; IM3 is coupled to MCS6 and MCS7; andIM 4 is coupled to MCS8. The MCSs are coupled to private communications networks. As shown here, MCS1, MCS2, MCS3, MCS4 andMCS 5 are coupled to private communications network 11360A; MCS6, and MCS7 are coupled toprivate communications network 2 1360B; and MCS8 is coupled toprivate communications network 2 1360B andprivate communications network 3 1360C. - Thus,
FIG. 13 shows asystem 13 that is scalable in a number of different dimensions, according to various embodiments of the invention. Two MSERVs are shown coupled by a network. This configuration allows for sharing of voicemail messages, user lists, global address lists, distribution lists and public folders between the various MSERVs that connected by a network and which may be placed at the same or different locations. Additionally, use of multiple MSERVs allows for scaling of the overall system through the increased capacity provided by the multiple MSERVs. - Multiple MCSs are shown. Increased number of MCSs can help to increase overall system capacity and/or redundancy by providing increased number of ports, storage, and processing capacity. According to an embodiment of the invention, information on the MCSs is derived from the MSERVs and automatically cached on the MCSs. This allows for easy deployment of new MCSs by which the data and configuration settings for the new MCSs are acquired from the MSERV(s) and/or caches of other MCSs. Additionally, an MCS may be coupled to more than one private communications network. In some cases an MCS may operate with multiple private communications networks simultaneously. Also, an MCS that is coupled to multiple private communications networks may continue operation with a non-failing private communications network in the event that one of the private communications networks to which the MCS is coupled fails. In one embodiment, the MCS that is coupled to multiple private communications networks operates with at least one of the private communications networks, but begins to operate with another, non-failing private communications network in the event that a private communications network to which the MCS is coupled fails.
- Multiple IMs are shown in
FIG. 13 , which help to support the capacity of additional MCSs. The multiple IMs also may provide fail over support for each other in the event that one of the IMs fails. - In
FIG. 13 , the equipment and users associated with a particular private communications network referred to as members of a “Site.” Accordingly, a user may have a Site identification. The Site identification may be used to filter user information associated with a particular Site from the a broader set of user information stored on the MSERV servicing multiple Sites. Additionally, Sites may be combined into auto attendant groups. The auto attendant groups are Sites that share a common dial plan. For example, members of an auto attendant group may able to place calls using extension numbers instead of full numbers. - According to an embodiment of the invention, various subsets of users may be defined from among the users in an MSERV or set of networked MSERVs. Such subsets of users may be defined by a Site identification. In this way, various subsets of users may be associated with different respective private communications networks, such that the users' access to respective Sites within a network of MSERVs depends on the users' membership in the various defined subsets of users. For example, members of a subgroup of users associated with a particular Site may be able to use functions such as message waiting indication and control of messaging actions at their associated Site but not at other Sites.
- An ICS of an embodiment includes an integrated messaging system. The integrated messaging system includes: a communication server that couples among networks of different types; an interface module that couples to the communication server, wherein the interface module pulls a plurality of user information from a messaging server of a network, wherein the user information includes information relevant to at least the network; and a cache store that couples to the communication server and to the interface module to hold at least one of information from the communication server and the user information pulled from messaging server, the interface module directing a message from at least one of the messaging server and the cache to at least one device on the networks using the user information.
- In an embodiment, a type of the message includes at least one of a voice mail type, an email type, a multimedia messaging system type, an instant messaging type, and a short messaging system type.
- The communication server may further include a plurality of applications including at least one voice application, wherein at least one voice browser couples the applications to a communications exchange, wherein the plurality of applications further includes at least one mobile application.
- In an embodiment, the system further includes a form-based interface that is transferable via an electronic message from the messaging server, the form-based interface enabling user actions on information of the messaging server using information of the cache via a coupling with at least one of the communication server and the interface module the actions on information of the messaging server include directing and playing a voice mail message to the device, generating a reply voice mail message for use in replying to the voice mail message, generating a forwarding voice mail message for use in forwarding the voice mail message, and generating an audio call to a caller leaving the voice mail message.
- In an embodiment, the system further includes at least one form, wherein the messaging server transfers the form to a client device via a network coupling with the client device, wherein an embedded browser control of the form establishes a coupling between at least one client device and at least one of the interface module and the communication server.
- In an embodiment, the system further includes a web server that couples the communication server to the interface module.
- In an embodiment, the interface module couples to a groupware application of the messaging server.
- An embodiment further includes a detector that detects at least one state of the messaging server, wherein the communication server operates in accordance with a plurality of operating modes, wherein the communication server selects an operating mode in response to the state of the messaging server.
- An embodiment further includes a first message of a first type, wherein the communication server generates the first message in response to receiving a data stream at an input, and may include a second message of a second type, wherein the messaging server generates the second message in response to determining the first type of the first message, wherein the second message includes data of the first message.
- The first type may be a voice mail type and the second type may be an electronic mail (email) type.
- The at least one device on the networks includes a first set of client devices coupled to the network and a second set of client devices coupled to a public network of the networks, wherein client devices of the first set and the second set include at least one of portable computers, portable telephones, cellular telephones, personal digital assistants, and multi-modal devices.
- An embodiment further includes: a second messaging server that couples to the messaging server via the networks; a second interface module that couples to at least one of the messaging server and the second messaging server; and a second communication server that couples among the networks via at least one of the interface module and the second interface module.
- The user information includes information of at least one user, the information including at least one of network mail box number, name, telephone extension, at least one telephone number, email address, greeting, site identification.
- In an embodiment, the interface module is hosted on the messaging server.
- An ICS as described herein further includes a device comprising: at least one server that couples messaging applications among a communication network and a messaging network; at least one interface module that couples to the messaging applications and the messaging network, the interface module transferring message information between the messaging network and the messaging application and retrieving a plurality of user information from the messaging server, wherein the user information includes information of users of the messaging network; and a cache store that couples to the server and to the interface module to hold at least one of the message information and the user information, the server manipulating the message information using the user information.
- The messaging information may include information of messages that include at least one of a voice mail type, an email type, a multimedia messaging system type, an instant messaging type, and a short messaging system type.
- In an embodiment, the server further comprises: at least one voice browser; and a plurality of applications that couple to the voice browser, the applications including at least one voice application and at least one mobile application, wherein the voice browser couples the applications to a communications exchange.
- An embodiment further includes a web server that couples at least one of the server and the interface module to a client device of the user via a form-based interface of the client device, wherein the server transfers the form-based interface via an electronic message to the client device via at least one of the interface module and the messaging network, and wherein the form-based interface allows the user to control actions on information of the messaging network using information of the cache store.
- The actions may include directing and playing a voice mail message to the client device, generating a reply voice mail message for use in replying to the voice mail message, generating a forwarding voice mail message for use in forwarding the voice mail message, and generating an audio call to a caller leaving the voice mail message.
- The server couples to a groupware application of the messaging network in an embodiment.
- An embodiment further includes a detector that detects at least one state of the messaging network, wherein the server selects an operating mode in response to a state of the messaging network.
- An embodiment further includes a first message of a first type, wherein the server generates the first message in response to receiving a data stream from the communication network; and a second message of a second type, wherein the messaging network generates the second message in response to determining the first type of the first message, wherein the second message includes data of the first message.
- In an embodiment, the user information includes information of at least one user, the information including at least one of network mail box number, name, telephone extension, at least one telephone number, email address, greeting, site identification.
- An ICS as described herein further includes a method comprising: receiving data streams from networks of different types; generating messages at a communication server using information of the data streams; transferring the messages, wherein transferring includes at least one of caching information of the messages and forwarding the messages to a messaging server; retrieving user information from the messaging server, wherein the user information includes information relevant to at least the network; caching the user information from the pulling; and directing the message from at least one of the messaging server and a cache to at least one device on the networks using the cached user information.
- In an embodiment, a type of the message includes at least one of a voice mail type, an email type, a multimedia messaging system type, an instant messaging type, and a short messaging system type.
- An embodiment further includes: transferring information of a form-based interface to the device via an electronic message; forming a coupling between the device and the communication server using information of the form-based interface; and directing the message by controlling actions on the messages using the cached user information, wherein a user directs actions on the messages from the device.
- In an embodiment, the actions include directing and playing the message to the device, generating a reply message for use in replying to the message, generating a forwarding message for use in forwarding the message, and generating an audio call to a caller leaving the message.
- The method can include detecting at least one state of the messaging server, and
- controlling an operating mode of the communication server in response to the detected state.
- The messages may include a first type message, wherein generating the messages includes generating messages of the first type in response to the received data streams, wherein the messages include a second type message, wherein transferring further includes transferring messages of the second type to the device in response to detecting the first type message.
- An embodiment further includes: assigning a site identification to a user; filtering the user information of users of a plurality of sites using the site identification; forming sets of users in accordance with the filtered user information; associating each set of users with at least one of the networks.
- An ICS as described herein further includes a device comprising: means for receiving data streams from networks of different types; means for generating messages at a communication server using information of the data streams; means for transferring the messages, wherein transferring includes at least one of caching information of the messages and forwarding the messages to a messaging server; means for retrieving user information from the messaging server, wherein the user information includes information relevant to at least the network; means for caching the user information from the pulling; and means for directing the message from at least one of the messaging server and the cache to at least one device on the networks using the user information of the cache.
- An ICS of an embodiment includes a device comprising a server including a plurality of messaging applications, wherein the server is coupled to a cache and a network of a plurality of networks, wherein an address of the network is assigned to the server and the server is configured, wherein the server retrieves a plurality of user information from the network and caches the retrieved user information, the user information including information of users of the network, wherein the server transfers message information between the plurality of networks and the messaging applications using the cached user information.
- An ICS of an embodiment includes a system comprising a plurality of servers each of which includes a plurality of messaging applications, wherein each server is coupled in succession to a cache and a network of a plurality of networks, wherein an address of the network is assigned to each server and each server is configured, wherein each server retrieves a plurality of user information from the network and caches the retrieved user information, the user information including information of users of the network, wherein each server transfers message information between the plurality of networks and the messaging applications using the cached user information.
- An ICS of an embodiment includes a method comprising at least one of providing a communication server and coupling the communication server to at least one network, assigning a network address to the communication server, configuring the communication server, retrieving and caching user information from a messaging server of the network, wherein the user information includes information relevant to at least the network, and transferring messages received at the communication server using the cached user information, wherein transferring includes at least one of caching information of the messages and forwarding the messages to the network.
- The method of an embodiment further comprises installing in succession a plurality of additional communication servers to the network. The installing of an embodiment comprises at least one of coupling each additional communication server to the network, assigning a network address to each additional communication server, configuring each additional communication server, retrieving and caching user information at each additional communication server from a messaging server of the network, wherein the user information includes information relevant to at least the network, and transferring messages received at each additional communication server using the cached user information, wherein transferring includes at least one of caching information of the messages and forwarding the messages to the network.
- The components of the ICS described above include any collection of computing components and devices operating together. The components of the ICS can also be components or subsystems within a larger computer system or network. The ICS components can also be coupled among any number of components (not shown), for example other buses, controllers, memory devices, and data input/output (I/O) devices, in any number of combinations. Further, components of the ICS can be distributed among any number/combination of other processor-based components.
- Aspects of the ICS described herein may be implemented as functionality programmed into any of a variety of circuitry, including programmable logic devices (PLDs), such as field programmable gate arrays (FPGAs), programmable array logic (PAL) devices, electrically programmable logic and memory devices and standard cell-based devices, as well as application specific integrated circuits (ASICs). Some other possibilities for implementing aspects of the ICS include: microcontrollers with memory (such as electronically erasable programmable read only memory (EEPROM)), embedded microprocessors, firmware, software, etc. Furthermore, aspects of the ICS may be embodied in microprocessors having software-based circuit emulation, discrete logic (sequential and combinatorial), custom devices, fuzzy (neural) logic, quantum devices, and hybrids of any of the above device types. Of course the underlying device technologies may be provided in a variety of component types, e.g., metal-oxide semiconductor field-effect transistor (MOSFET) technologies like complementary metal-oxide semiconductor (CMOS), bipolar technologies like emitter-coupled logic (ECL), polymer technologies (e.g., silicon-conjugated polymer and metal-conjugated polymer-metal structures), mixed analog and digital, etc.
- It should be noted that the various functions or processes disclosed herein may be described as data and/or instructions embodied in various computer-readable media, in terms of their behavioral, register transfer, logic component, transistor, layout geometries, and/or other characteristics. Computer-readable media in which such formatted data and/or instructions may be embodied include, but are not limited to, non-volatile storage media in various forms (e.g., optical, magnetic or semiconductor storage media) and carrier waves that may be used to transfer such formatted data and/or instructions through wireless, optical, or wired signaling media or any combination thereof. Examples of transfers of such formatted data and/or instructions by carrier waves include, but are not limited to, transfers (uploads, downloads, e-mail, etc.) over the Internet and/or other computer networks via one or more data transfer protocols (e.g., HTTP, FTP, SMTP, etc.). When received within a computer system via one or more computer-readable media, such data and/or instruction-based expressions of components and/or processes under the ICS may be processed by a processing entity (e.g., one or more processors) within the computer system in conjunction with execution of one or more other computer programs.
- Unless the context clearly requires otherwise, throughout the description and the claims, the words “comprise,” “comprising,” and the like are to be construed in an inclusive sense as opposed to an exclusive or exhaustive sense; that is to say, in a sense of “including, but not limited to.” Words using the singular or plural number also include the plural or singular number respectively. Additionally, the words “herein,” “hereunder,” “above,” “below,” and words of similar import refer to this application as a whole and not to any particular portions of this application. When the word “or” is used in reference to a list of two or more items, that word covers all of the following interpretations of the word: any of the items in the list, all of the items in the list and any combination of the items in the list.
- The above description of illustrated embodiments of the ICS is not intended to be exhaustive or to limit the ICS to the precise form disclosed. While specific embodiments of, and examples for, the ICS are described herein for illustrative purposes, various equivalent modifications are possible within the scope of the ICS, as those skilled in the relevant art will recognize. The teachings of the ICS provided herein can be applied to other processing systems and methods, not only for the systems and methods described above.
- The elements and acts of the various embodiments described above can be combined to provide further embodiments. These and other changes can be made to the ICS in light of the above detailed description.
- In general, in the following claims, the terms used should not be construed to limit the ICS to the specific embodiments disclosed in the specification and the claims, but should be construed to include all processing systems that operate under the claims. Accordingly, the ICS is not limited by the disclosure, but instead the scope of the ICS is to be determined entirely by the claims.
- While certain aspects of the ICS are presented below in certain claim forms, the inventors contemplate the various aspects of the ICS in any number of claim forms. For example, while only one aspect of the ICS is recited as embodied in machine-readable medium, other aspects may likewise be embodied in machine-readable medium. Accordingly, the inventors reserve the right to add additional claims after filing the application to pursue such additional claim forms for other aspects of the ICS.
Claims (43)
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/053,271 US7808980B2 (en) | 2005-02-07 | 2005-02-07 | Integrated multi-media communication system |
AU2006212840A AU2006212840A1 (en) | 2005-02-07 | 2006-02-07 | Integrated multi-media communication system |
EP06720389A EP1851939A4 (en) | 2005-02-07 | 2006-02-07 | Integrated multi-media communication system |
PCT/US2006/004174 WO2006086335A2 (en) | 2005-02-07 | 2006-02-07 | Integrated multi-media communication system |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/053,271 US7808980B2 (en) | 2005-02-07 | 2005-02-07 | Integrated multi-media communication system |
Publications (2)
Publication Number | Publication Date |
---|---|
US20060177009A1 true US20060177009A1 (en) | 2006-08-10 |
US7808980B2 US7808980B2 (en) | 2010-10-05 |
Family
ID=36779925
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/053,271 Active 2028-10-16 US7808980B2 (en) | 2005-02-07 | 2005-02-07 | Integrated multi-media communication system |
Country Status (1)
Country | Link |
---|---|
US (1) | US7808980B2 (en) |
Cited By (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060177010A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | Caching user information in an integrated communication system |
US20060177006A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Controlling messaging actions using form-based user interface |
US20060177025A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Integrating messaging server directory service with a communication system voice mail message interface |
US20060177012A1 (en) * | 2005-02-07 | 2006-08-10 | David Forney | Networked voicemail |
US20060177011A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | System and method for providing code on voicemail appliance |
US20060177013A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Form-based user interface for controlling messaging |
US20080240082A1 (en) * | 2007-03-28 | 2008-10-02 | Lowell Phillip Feldman | System and method for managing interoperability of internet telephony networks and legacy telephony networks |
US20090217180A1 (en) * | 2008-02-21 | 2009-08-27 | Shoretel, Inc. | Programmable Buttons for Telephone User Interface |
US8059793B2 (en) | 2005-02-07 | 2011-11-15 | Avaya Inc. | System and method for voicemail privacy |
US8064576B2 (en) | 2007-02-21 | 2011-11-22 | Avaya Inc. | Voicemail filtering and transcription |
US8107598B2 (en) | 2007-02-21 | 2012-01-31 | Avaya Inc. | Voicemail filtering and transcription |
US8160212B2 (en) | 2007-02-21 | 2012-04-17 | Avaya Inc. | Voicemail filtering and transcription |
US8175233B2 (en) | 2005-02-07 | 2012-05-08 | Avaya Inc. | Distributed cache system |
US8233594B2 (en) | 2005-02-07 | 2012-07-31 | Avaya Inc. | Caching message information in an integrated communication system |
US8488751B2 (en) | 2007-05-11 | 2013-07-16 | Avaya Inc. | Unified messenging system and method |
US20130198398A1 (en) * | 2012-02-01 | 2013-08-01 | Raketu Communications, Inc. | System and method for an improved network client device |
US8559605B2 (en) | 2005-02-07 | 2013-10-15 | Avaya Inc. | Extensible diagnostic tool |
US11777892B1 (en) * | 2023-02-08 | 2023-10-03 | Citigroup Global Markets Inc. | Management of queries in electronic mail messages |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8412780B2 (en) | 2005-03-30 | 2013-04-02 | Google Inc. | Methods and systems for providing current email addresses and contact information for members within a social network |
US8073700B2 (en) | 2005-09-12 | 2011-12-06 | Nuance Communications, Inc. | Retrieval and presentation of network service results for mobile device using a multimodal browser |
US8843376B2 (en) | 2007-03-13 | 2014-09-23 | Nuance Communications, Inc. | Speech-enabled web content searching using a multimodal browser |
US9246870B2 (en) | 2008-07-01 | 2016-01-26 | David H. Parker | Sua sponte establishment of large-scale person-to-person emergency electronic messaging communications based in part on subscriber telephone numbers |
US8352546B1 (en) | 2011-12-08 | 2013-01-08 | Google Inc. | Contextual and location awareness for device interaction |
US8229471B1 (en) | 2011-12-08 | 2012-07-24 | Google Inc. | Techniques for automatically activating or deactivating a phone associated with a virtual phone number |
Citations (94)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5029199A (en) * | 1989-08-10 | 1991-07-02 | Boston Technology | Distributed control and storage for a large capacity messaging system |
US5345501A (en) * | 1991-07-15 | 1994-09-06 | Bell Atlantic Network Services, Inc. | Telephone central office based method of and system for processing customer orders |
US5568540A (en) * | 1993-09-13 | 1996-10-22 | Active Voice Corporation | Method and apparatus for selecting and playing a voice mail message |
US5572578A (en) * | 1993-11-26 | 1996-11-05 | Lin; Frank C. H. | Exchange of information between interconnected voice mail systems |
US5703942A (en) * | 1993-07-16 | 1997-12-30 | Mitel Corporation | Portable telephone user profiles using central computer |
US5742668A (en) * | 1994-09-19 | 1998-04-21 | Bell Communications Research, Inc. | Electronic massaging network |
US5778390A (en) * | 1996-06-07 | 1998-07-07 | Electronic Data Systems Corporation | Method and systems for creating duplicating, and archiving database files |
US5845203A (en) * | 1996-01-25 | 1998-12-01 | Aertis Cormmunications | Remote access application messaging wireless method |
US5909483A (en) * | 1994-07-22 | 1999-06-01 | Comverse Network Systems, Inc. | Remote subscriber migration |
US5915001A (en) * | 1996-11-14 | 1999-06-22 | Vois Corporation | System and method for providing and using universally accessible voice and speech data files |
US5995596A (en) * | 1997-03-12 | 1999-11-30 | Siemens Information And Communication Networks, Inc. | System and method for coordination of multimedia messages across multiple systems |
US6021181A (en) * | 1997-02-24 | 2000-02-01 | Wildfire Communications, Inc. | Electronic voice mail message handling system |
US6047053A (en) * | 1994-09-30 | 2000-04-04 | Wildfire Communications, Inc. | Network based knowledgeable assistant |
US6070081A (en) * | 1992-10-05 | 2000-05-30 | Ntt Mobile Communications Network, Inc. | Private mobile communication system easily connecting portable or mobile radio telephone equipment to public network |
US6076090A (en) * | 1997-11-26 | 2000-06-13 | International Business Machines Corporation | Default schema mapping |
US6085231A (en) * | 1998-01-05 | 2000-07-04 | At&T Corp | Method and system for delivering a voice message via an alias e-mail address |
US6138209A (en) * | 1997-09-05 | 2000-10-24 | International Business Machines Corporation | Data processing system and multi-way set associative cache utilizing class predict data structure and method thereof |
US6163794A (en) * | 1998-10-23 | 2000-12-19 | General Magic | Network system extensible by users |
US6233318B1 (en) * | 1996-11-05 | 2001-05-15 | Comverse Network Systems, Inc. | System for accessing multimedia mailboxes and messages over the internet and via telephone |
US6253206B1 (en) * | 1999-08-20 | 2001-06-26 | Inroads Technology, Inc. | Method and apparatus for a commercial network system designed to facilitate, manage and support the implementation and integration of technology systems |
US6275570B1 (en) * | 1998-04-22 | 2001-08-14 | Unisys Corporation | System and method of provisioning subscribers in a messaging environment comprising two messaging systems |
US6304636B1 (en) * | 1997-12-23 | 2001-10-16 | At&T Corp. | Forwarding voice messages to a called party using electronic mail |
US6317485B1 (en) * | 1998-06-09 | 2001-11-13 | Unisys Corporation | System and method for integrating notification functions of two messaging systems in a universal messaging system |
US6324265B1 (en) * | 1998-06-22 | 2001-11-27 | Nortel Networks Limited | Originator disposition options for communications session termination |
US6339776B2 (en) * | 1999-10-04 | 2002-01-15 | International Business Machines Corporation | Dynamic semi-structured repository for mining software and software-related information |
US6389276B1 (en) * | 1998-12-23 | 2002-05-14 | Bell Atlantic Mobile | Systems and methods for providing voice mail notification from a separate voice mail system to mobile telephone |
US6396907B1 (en) * | 1997-10-06 | 2002-05-28 | Avaya Technology Corp. | Unified messaging system and method providing cached message streams |
US6396908B1 (en) * | 1997-11-03 | 2002-05-28 | Nortel Networks Limited | Message transfer system |
US20020064149A1 (en) * | 1996-11-18 | 2002-05-30 | Elliott Isaac K. | System and method for providing requested quality of service in a hybrid network |
US6405035B1 (en) * | 2000-08-24 | 2002-06-11 | Telefonaktiebolaget L.M. Ericsson | System and method for forwarding messages to a subscriber device |
US6411685B1 (en) * | 1999-01-29 | 2002-06-25 | Microsoft Corporation | System and method for providing unified messaging to a user with a thin web browser |
US20020123342A1 (en) * | 2001-03-04 | 2002-09-05 | Adomo, Inc. | Mobile communication system for a network |
US20020123331A1 (en) * | 2001-03-04 | 2002-09-05 | Adomo, Inc. | Mobile communication system for a network |
US20020143877A1 (en) * | 2001-02-06 | 2002-10-03 | Hackbarth Randy L. | Apparatus and method for use in a data/conference call system to provide collaboration services |
US20020147801A1 (en) * | 2001-01-29 | 2002-10-10 | Gullotta Tony J. | System and method for provisioning resources to users based on policies, roles, organizational information, and attributes |
US20020165986A1 (en) * | 2001-01-22 | 2002-11-07 | Tarnoff Harry L. | Methods for enhancing communication of content over a network |
US20020169876A1 (en) * | 2001-03-06 | 2002-11-14 | Curie Jeffrey C. | Method and system for third party resource provisioning management |
US6493431B1 (en) * | 1999-11-17 | 2002-12-10 | Genuity Inc. | Method and system for capturing telephone calls |
US6501750B1 (en) * | 1998-06-05 | 2002-12-31 | Siemens Information & Communication Networks, Inc. | Method and device for device-to-device enablement of camp-on capability |
US6519327B1 (en) * | 1999-07-30 | 2003-02-11 | Lucent Technologies Inc. | System and method for selectively retrieving messages stored on telephony and data networks |
US6519571B1 (en) * | 1999-05-27 | 2003-02-11 | Accenture Llp | Dynamic customer profile management |
US6526274B1 (en) * | 1999-10-25 | 2003-02-25 | Comdial Corporation | Method, system, and computer program product for extending the functionality of a personal information manager to telephone system interactions |
US6549612B2 (en) * | 1998-05-06 | 2003-04-15 | Telecommunications Premium Services, Inc. | Unified communication services via e-mail |
US6553563B2 (en) * | 1998-11-30 | 2003-04-22 | Siebel Systems, Inc. | Development tool, method, and system for client server applications |
US20030140112A1 (en) * | 1999-11-04 | 2003-07-24 | Satish Ramachandran | Electronic messaging system method and apparatus |
US6618763B1 (en) * | 2000-02-04 | 2003-09-09 | Inphonic Inc. | Virtual private wireless network implementing message delivery preferences of the user |
US6629138B1 (en) * | 1997-07-21 | 2003-09-30 | Tibco Software Inc. | Method and apparatus for storing and delivering documents on the internet |
US20030195934A1 (en) * | 2002-04-15 | 2003-10-16 | Peterson Neil J. | Web services-based communications for use with process control systems |
US20030220975A1 (en) * | 2002-05-21 | 2003-11-27 | Malik Dale W. | Group access management system |
US6671800B1 (en) * | 1999-03-01 | 2003-12-30 | Canon Kabushiki Kaisha | Instructions for creating an extension data to create instances of an object with additional attributes without creating a new object type |
US20040002325A1 (en) * | 1997-07-22 | 2004-01-01 | Evans Michael Paul | Mobile handset with browser application to be used to recognize textual presentation |
US20040044687A1 (en) * | 2002-08-30 | 2004-03-04 | Thomas Vachuska | Apparatus and method using pre-described patterns and reflection to generate a database schema |
US20040044989A1 (en) * | 2002-08-30 | 2004-03-04 | Thomas Vachuska | Apparatus and method using pre-described patterns and reflection to generate source code |
US20040049696A1 (en) * | 2001-04-03 | 2004-03-11 | Baker Stuart D. | Privileged communication system with routing controls |
US6714778B2 (en) * | 2001-05-15 | 2004-03-30 | Nokia Corporation | Context sensitive web services |
US20040064502A1 (en) * | 2002-09-30 | 2004-04-01 | International Business Machines Corporation | Metadirectory agents having extensible functions |
US6731927B1 (en) * | 2000-07-14 | 2004-05-04 | Context Connect, Inc. | System and method for context association |
US20040109544A1 (en) * | 2001-06-29 | 2004-06-10 | Didcock Clifford Neil | Architecture for unified messaging |
US20040111702A1 (en) * | 2002-12-10 | 2004-06-10 | Chan Kin Ming | Method and apparatus for visual programming |
US20040120480A1 (en) * | 2002-12-24 | 2004-06-24 | Didcock Clifford Neil | Flexible distributed/centralaized architecture for voice/unified messaging system |
US20040171381A1 (en) * | 2000-09-06 | 2004-09-02 | Eric Inselberg | Method and apparatus for interactive audience participation at a live spectator event |
US20040225525A1 (en) * | 2003-05-05 | 2004-11-11 | Weitzman Vernon L. | Automatic contacts replication system and software |
US20040253956A1 (en) * | 2003-06-12 | 2004-12-16 | Samsung Electronics Co., Ltd. | System and method for providing an online software upgrade in load sharing servers |
US20040258231A1 (en) * | 1999-11-12 | 2004-12-23 | Metro One Telecommunications, Inc. | Technique for providing personalized information and communications services |
US20040267768A1 (en) * | 2003-06-27 | 2004-12-30 | Microsoft Corporation | Attribute based programming for data repositories |
US20050025297A1 (en) * | 1994-10-31 | 2005-02-03 | Finnigan Paul F. | Telephonic voice message transmission control method |
US6853714B2 (en) * | 2000-02-25 | 2005-02-08 | Keith A. Liljestrand | Apparatus and method for providing enhanced telecommunications services |
US6871346B1 (en) * | 2000-02-11 | 2005-03-22 | Microsoft Corp. | Back-end decoupled management model and management system utilizing same |
US20050132266A1 (en) * | 2003-11-21 | 2005-06-16 | Ambrosino Timothy J. | Method of authoring, deploying and using interactive, data-driven two or more dimensional content |
US6950990B2 (en) * | 2000-12-11 | 2005-09-27 | Microsoft Corporation | Navigation tool for accessing workspaces and modules in a graphical user interface |
US6950502B1 (en) * | 2002-08-23 | 2005-09-27 | Bellsouth Intellectual Property Corp. | Enhanced scheduled messaging system |
US20050216421A1 (en) * | 1997-09-26 | 2005-09-29 | Mci. Inc. | Integrated business systems for web based telecommunications management |
US6952558B2 (en) * | 2001-02-20 | 2005-10-04 | Sony Corporation | Wireless sports view display and business method of use |
US6957186B1 (en) * | 1999-05-27 | 2005-10-18 | Accenture Llp | System method and article of manufacture for building, managing, and supporting various components of a system |
US20060059107A1 (en) * | 2000-03-30 | 2006-03-16 | Kevin Elmore | System and method for establishing eletronic business systems for supporting communications servuces commerce |
US20060072720A1 (en) * | 2004-09-30 | 2006-04-06 | Blohm Jeffrey M | Presence enhanced outcalling |
US7072934B2 (en) * | 2000-01-14 | 2006-07-04 | Saba Software, Inc. | Method and apparatus for a business applications server management system platform |
US7082469B2 (en) * | 2000-06-09 | 2006-07-25 | Gold Mustache Publishing, Inc. | Method and system for electronic song dedication |
US20060177013A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Form-based user interface for controlling messaging |
US20060177008A1 (en) * | 2005-02-07 | 2006-08-10 | David Forney | Extensible diagnostic tool |
US20060177012A1 (en) * | 2005-02-07 | 2006-08-10 | David Forney | Networked voicemail |
US20060177011A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | System and method for providing code on voicemail appliance |
US20060177014A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | System and method for providing data on voicemail appliance |
US20060177024A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Integrated voice mail user/email system user setup in integrated multi-media communication system |
US20060177006A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Controlling messaging actions using form-based user interface |
US20060177007A1 (en) * | 2005-02-07 | 2006-08-10 | Shahriar Vaghar | Caching message information in an integrated communication system |
US20060177005A1 (en) * | 2005-02-07 | 2006-08-10 | Anthony Shaffer | System and method for voicemail privacy |
US20060177015A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | Message data access in multi-media integrated communication system |
US20060177025A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Integrating messaging server directory service with a communication system voice mail message interface |
US20060177023A1 (en) * | 2005-02-07 | 2006-08-10 | Shahriar Vaghar | Distributed cache system |
US20060177010A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | Caching user information in an integrated communication system |
US7136865B1 (en) * | 2001-03-28 | 2006-11-14 | Siebel Systems, Inc. | Method and apparatus to build and manage a logical structure using templates |
US7151823B2 (en) * | 1998-06-08 | 2006-12-19 | Hewlett-Packard Development Company, L.P. | Determining whether a telephony call is permitted based on permission data |
US7167550B2 (en) * | 1997-04-03 | 2007-01-23 | Southwestern Bell Telephone Company | Apparatus and method for facilitating service management of communications services in a communications network |
Family Cites Families (40)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
ATE136183T1 (en) | 1993-06-22 | 1996-04-15 | Vmx Inc | ELECTRONIC MESSAGING SYSTEM WITH INTEGRATED VOICE MESSAGES |
US5647002A (en) | 1995-09-01 | 1997-07-08 | Lucent Technologies Inc. | Synchronization of mailboxes of different types |
US5946386A (en) | 1996-03-11 | 1999-08-31 | Xantel Corporation | Call management system with call control from user workstation computers |
AU3218597A (en) | 1996-06-03 | 1998-01-05 | Worldvoice Inc. | Telephonic voice message store and forward method having network address and voice authentication |
US5712901A (en) | 1996-06-26 | 1998-01-27 | Mci Communications Corporation | Automatic voice/text translation of phone mail messages |
US6072862A (en) | 1996-07-02 | 2000-06-06 | Srinivasan; Thiru | Adaptable method and system for message delivery |
US5903627A (en) | 1996-11-13 | 1999-05-11 | Siemens Information And Communication Networks, Inc. | System and method for improving delivery of messages to a messaging system |
US6546005B1 (en) | 1997-03-25 | 2003-04-08 | At&T Corp. | Active user registry |
US7203288B1 (en) | 1997-11-21 | 2007-04-10 | Dictaphone Corporation | Intelligent routing of voice files in voice data management system |
US6052709A (en) | 1997-12-23 | 2000-04-18 | Bright Light Technologies, Inc. | Apparatus and method for controlling delivery of unsolicited electronic mail |
US6317484B1 (en) | 1998-04-08 | 2001-11-13 | Mcallister Alexander I. | Personal telephone service with transportable script control of services |
US6434222B1 (en) | 1998-04-17 | 2002-08-13 | Siemens Information And Communication Networks, Inc. | Apparatus and method for automated multi-media messaging system information updating |
US6389115B1 (en) | 1998-12-03 | 2002-05-14 | 3Com Corporation | System and method for notifying a user of voice mail messages at a cell phone site |
US6707890B1 (en) | 2002-09-03 | 2004-03-16 | Bell South Intellectual Property Corporation | Voice mail notification using instant messaging |
US6351523B1 (en) | 1999-03-22 | 2002-02-26 | Sharp Laboratories Of America, Inc. | Method and apparatus for management of EMail originated by thin client devices |
US6937724B1 (en) | 1999-03-29 | 2005-08-30 | Siemens Information & Communication Networks, Inc. | Apparatus and method for delivery of ringing and voice calls through a workstation |
US6725205B1 (en) | 1999-12-02 | 2004-04-20 | Ulysses Esd, Inc. | System and method for secure software installation |
EP1109390A3 (en) | 1999-12-08 | 2003-07-09 | AT&T Corp. | System and method for browsing and searching through voicemail using automatic speech recognition |
US6438215B1 (en) | 2000-02-29 | 2002-08-20 | Ameritech Corporation | Method and system for filter based message processing in a unified messaging system |
US7565403B2 (en) | 2000-03-16 | 2009-07-21 | Microsoft Corporation | Use of a bulk-email filter within a system for classifying messages for urgency or importance |
US6832373B2 (en) | 2000-11-17 | 2004-12-14 | Bitfone Corporation | System and method for updating and distributing information |
US7136461B1 (en) | 2001-02-16 | 2006-11-14 | Telesector Resources Group, Inc. | Method and apparatus for implementing voice messaging using E-mail |
US7225126B2 (en) | 2001-06-12 | 2007-05-29 | At&T Corp. | System and method for processing speech files |
US7668535B2 (en) | 2001-07-09 | 2010-02-23 | Palm, Inc. | Notification infrastructure for sending device-specific wireless notifications |
US7281269B1 (en) | 2002-03-06 | 2007-10-09 | Novell, Inc. | Methods, data structures, and systems to remotely validate a message |
US7680820B2 (en) | 2002-04-19 | 2010-03-16 | Fuji Xerox Co., Ltd. | Systems and methods for displaying text recommendations during collaborative note taking |
US20030220784A1 (en) | 2002-05-24 | 2003-11-27 | International Business Machines Corporation | System and method for automated voice message transcription and delivery |
US7624347B2 (en) | 2002-09-17 | 2009-11-24 | At&T Intellectual Property I, L.P. | System and method for forwarding full header information in email messages |
US20040121761A1 (en) | 2002-12-19 | 2004-06-24 | Abinash Tripathy | Method and apparatus for processing voicemail messages |
WO2004068469A2 (en) | 2003-01-17 | 2004-08-12 | Tacit Networks, Inc. | Method and system for use of storage caching with a distributed file system |
US7092504B1 (en) | 2003-03-18 | 2006-08-15 | Sprint Communications Company L.P. | Method and system for presenting data stored within a network component |
GB2411551B (en) | 2003-04-22 | 2006-05-03 | Spinvox Ltd | A method of providing voicemails to a wireless information device |
US7136462B2 (en) | 2003-07-15 | 2006-11-14 | Lucent Technologies Inc. | Network speech-to-text conversion and store |
US7379540B1 (en) | 2003-09-24 | 2008-05-27 | Shortel, Inc. | Server with backup capability for distributed IP telephony systems |
US20050091226A1 (en) | 2003-10-23 | 2005-04-28 | Yun Lin | Persistent caching directory level support |
WO2006086335A2 (en) | 2005-02-07 | 2006-08-17 | Adomo, Inc. | Integrated multi-media communication system |
US8064576B2 (en) | 2007-02-21 | 2011-11-22 | Avaya Inc. | Voicemail filtering and transcription |
US8160212B2 (en) | 2007-02-21 | 2012-04-17 | Avaya Inc. | Voicemail filtering and transcription |
US8107598B2 (en) | 2007-02-21 | 2012-01-31 | Avaya Inc. | Voicemail filtering and transcription |
US8488751B2 (en) | 2007-05-11 | 2013-07-16 | Avaya Inc. | Unified messenging system and method |
-
2005
- 2005-02-07 US US11/053,271 patent/US7808980B2/en active Active
Patent Citations (96)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5029199A (en) * | 1989-08-10 | 1991-07-02 | Boston Technology | Distributed control and storage for a large capacity messaging system |
US5345501A (en) * | 1991-07-15 | 1994-09-06 | Bell Atlantic Network Services, Inc. | Telephone central office based method of and system for processing customer orders |
US6070081A (en) * | 1992-10-05 | 2000-05-30 | Ntt Mobile Communications Network, Inc. | Private mobile communication system easily connecting portable or mobile radio telephone equipment to public network |
US5703942A (en) * | 1993-07-16 | 1997-12-30 | Mitel Corporation | Portable telephone user profiles using central computer |
US5568540A (en) * | 1993-09-13 | 1996-10-22 | Active Voice Corporation | Method and apparatus for selecting and playing a voice mail message |
US5572578A (en) * | 1993-11-26 | 1996-11-05 | Lin; Frank C. H. | Exchange of information between interconnected voice mail systems |
US5909483A (en) * | 1994-07-22 | 1999-06-01 | Comverse Network Systems, Inc. | Remote subscriber migration |
US5742668A (en) * | 1994-09-19 | 1998-04-21 | Bell Communications Research, Inc. | Electronic massaging network |
US6047053A (en) * | 1994-09-30 | 2000-04-04 | Wildfire Communications, Inc. | Network based knowledgeable assistant |
US20050025297A1 (en) * | 1994-10-31 | 2005-02-03 | Finnigan Paul F. | Telephonic voice message transmission control method |
US5845203A (en) * | 1996-01-25 | 1998-12-01 | Aertis Cormmunications | Remote access application messaging wireless method |
US5778390A (en) * | 1996-06-07 | 1998-07-07 | Electronic Data Systems Corporation | Method and systems for creating duplicating, and archiving database files |
US6233318B1 (en) * | 1996-11-05 | 2001-05-15 | Comverse Network Systems, Inc. | System for accessing multimedia mailboxes and messages over the internet and via telephone |
US5915001A (en) * | 1996-11-14 | 1999-06-22 | Vois Corporation | System and method for providing and using universally accessible voice and speech data files |
US20020064149A1 (en) * | 1996-11-18 | 2002-05-30 | Elliott Isaac K. | System and method for providing requested quality of service in a hybrid network |
US6021181A (en) * | 1997-02-24 | 2000-02-01 | Wildfire Communications, Inc. | Electronic voice mail message handling system |
US5995596A (en) * | 1997-03-12 | 1999-11-30 | Siemens Information And Communication Networks, Inc. | System and method for coordination of multimedia messages across multiple systems |
US7167550B2 (en) * | 1997-04-03 | 2007-01-23 | Southwestern Bell Telephone Company | Apparatus and method for facilitating service management of communications services in a communications network |
US6629138B1 (en) * | 1997-07-21 | 2003-09-30 | Tibco Software Inc. | Method and apparatus for storing and delivering documents on the internet |
US20040002325A1 (en) * | 1997-07-22 | 2004-01-01 | Evans Michael Paul | Mobile handset with browser application to be used to recognize textual presentation |
US6138209A (en) * | 1997-09-05 | 2000-10-24 | International Business Machines Corporation | Data processing system and multi-way set associative cache utilizing class predict data structure and method thereof |
US20050216421A1 (en) * | 1997-09-26 | 2005-09-29 | Mci. Inc. | Integrated business systems for web based telecommunications management |
US6396907B1 (en) * | 1997-10-06 | 2002-05-28 | Avaya Technology Corp. | Unified messaging system and method providing cached message streams |
US6396908B1 (en) * | 1997-11-03 | 2002-05-28 | Nortel Networks Limited | Message transfer system |
US6076090A (en) * | 1997-11-26 | 2000-06-13 | International Business Machines Corporation | Default schema mapping |
US6304636B1 (en) * | 1997-12-23 | 2001-10-16 | At&T Corp. | Forwarding voice messages to a called party using electronic mail |
US6085231A (en) * | 1998-01-05 | 2000-07-04 | At&T Corp | Method and system for delivering a voice message via an alias e-mail address |
US6275570B1 (en) * | 1998-04-22 | 2001-08-14 | Unisys Corporation | System and method of provisioning subscribers in a messaging environment comprising two messaging systems |
US6549612B2 (en) * | 1998-05-06 | 2003-04-15 | Telecommunications Premium Services, Inc. | Unified communication services via e-mail |
US6501750B1 (en) * | 1998-06-05 | 2002-12-31 | Siemens Information & Communication Networks, Inc. | Method and device for device-to-device enablement of camp-on capability |
US7151823B2 (en) * | 1998-06-08 | 2006-12-19 | Hewlett-Packard Development Company, L.P. | Determining whether a telephony call is permitted based on permission data |
US6317485B1 (en) * | 1998-06-09 | 2001-11-13 | Unisys Corporation | System and method for integrating notification functions of two messaging systems in a universal messaging system |
US6324265B1 (en) * | 1998-06-22 | 2001-11-27 | Nortel Networks Limited | Originator disposition options for communications session termination |
US6163794A (en) * | 1998-10-23 | 2000-12-19 | General Magic | Network system extensible by users |
US6553563B2 (en) * | 1998-11-30 | 2003-04-22 | Siebel Systems, Inc. | Development tool, method, and system for client server applications |
US6389276B1 (en) * | 1998-12-23 | 2002-05-14 | Bell Atlantic Mobile | Systems and methods for providing voice mail notification from a separate voice mail system to mobile telephone |
US6411685B1 (en) * | 1999-01-29 | 2002-06-25 | Microsoft Corporation | System and method for providing unified messaging to a user with a thin web browser |
US6671800B1 (en) * | 1999-03-01 | 2003-12-30 | Canon Kabushiki Kaisha | Instructions for creating an extension data to create instances of an object with additional attributes without creating a new object type |
US6957186B1 (en) * | 1999-05-27 | 2005-10-18 | Accenture Llp | System method and article of manufacture for building, managing, and supporting various components of a system |
US6519571B1 (en) * | 1999-05-27 | 2003-02-11 | Accenture Llp | Dynamic customer profile management |
US6519327B1 (en) * | 1999-07-30 | 2003-02-11 | Lucent Technologies Inc. | System and method for selectively retrieving messages stored on telephony and data networks |
US6253206B1 (en) * | 1999-08-20 | 2001-06-26 | Inroads Technology, Inc. | Method and apparatus for a commercial network system designed to facilitate, manage and support the implementation and integration of technology systems |
US6339776B2 (en) * | 1999-10-04 | 2002-01-15 | International Business Machines Corporation | Dynamic semi-structured repository for mining software and software-related information |
US6526274B1 (en) * | 1999-10-25 | 2003-02-25 | Comdial Corporation | Method, system, and computer program product for extending the functionality of a personal information manager to telephone system interactions |
US20030140112A1 (en) * | 1999-11-04 | 2003-07-24 | Satish Ramachandran | Electronic messaging system method and apparatus |
US20040258231A1 (en) * | 1999-11-12 | 2004-12-23 | Metro One Telecommunications, Inc. | Technique for providing personalized information and communications services |
US6493431B1 (en) * | 1999-11-17 | 2002-12-10 | Genuity Inc. | Method and system for capturing telephone calls |
US7072934B2 (en) * | 2000-01-14 | 2006-07-04 | Saba Software, Inc. | Method and apparatus for a business applications server management system platform |
US6618763B1 (en) * | 2000-02-04 | 2003-09-09 | Inphonic Inc. | Virtual private wireless network implementing message delivery preferences of the user |
US6871346B1 (en) * | 2000-02-11 | 2005-03-22 | Microsoft Corp. | Back-end decoupled management model and management system utilizing same |
US6853714B2 (en) * | 2000-02-25 | 2005-02-08 | Keith A. Liljestrand | Apparatus and method for providing enhanced telecommunications services |
US20060059107A1 (en) * | 2000-03-30 | 2006-03-16 | Kevin Elmore | System and method for establishing eletronic business systems for supporting communications servuces commerce |
US7082469B2 (en) * | 2000-06-09 | 2006-07-25 | Gold Mustache Publishing, Inc. | Method and system for electronic song dedication |
US6731927B1 (en) * | 2000-07-14 | 2004-05-04 | Context Connect, Inc. | System and method for context association |
US6405035B1 (en) * | 2000-08-24 | 2002-06-11 | Telefonaktiebolaget L.M. Ericsson | System and method for forwarding messages to a subscriber device |
US6996413B2 (en) * | 2000-09-06 | 2006-02-07 | Eric Inselberg | Method and apparatus for interactive audience participation at a live spectator event |
US20040171381A1 (en) * | 2000-09-06 | 2004-09-02 | Eric Inselberg | Method and apparatus for interactive audience participation at a live spectator event |
US6950990B2 (en) * | 2000-12-11 | 2005-09-27 | Microsoft Corporation | Navigation tool for accessing workspaces and modules in a graphical user interface |
US20020165986A1 (en) * | 2001-01-22 | 2002-11-07 | Tarnoff Harry L. | Methods for enhancing communication of content over a network |
US6947989B2 (en) * | 2001-01-29 | 2005-09-20 | International Business Machines Corporation | System and method for provisioning resources to users based on policies, roles, organizational information, and attributes |
US20020147801A1 (en) * | 2001-01-29 | 2002-10-10 | Gullotta Tony J. | System and method for provisioning resources to users based on policies, roles, organizational information, and attributes |
US20020143877A1 (en) * | 2001-02-06 | 2002-10-03 | Hackbarth Randy L. | Apparatus and method for use in a data/conference call system to provide collaboration services |
US6952558B2 (en) * | 2001-02-20 | 2005-10-04 | Sony Corporation | Wireless sports view display and business method of use |
US20020123342A1 (en) * | 2001-03-04 | 2002-09-05 | Adomo, Inc. | Mobile communication system for a network |
US20020123331A1 (en) * | 2001-03-04 | 2002-09-05 | Adomo, Inc. | Mobile communication system for a network |
US20020169876A1 (en) * | 2001-03-06 | 2002-11-14 | Curie Jeffrey C. | Method and system for third party resource provisioning management |
US7136865B1 (en) * | 2001-03-28 | 2006-11-14 | Siebel Systems, Inc. | Method and apparatus to build and manage a logical structure using templates |
US20040049696A1 (en) * | 2001-04-03 | 2004-03-11 | Baker Stuart D. | Privileged communication system with routing controls |
US6714778B2 (en) * | 2001-05-15 | 2004-03-30 | Nokia Corporation | Context sensitive web services |
US20040109544A1 (en) * | 2001-06-29 | 2004-06-10 | Didcock Clifford Neil | Architecture for unified messaging |
US20030195934A1 (en) * | 2002-04-15 | 2003-10-16 | Peterson Neil J. | Web services-based communications for use with process control systems |
US20030220975A1 (en) * | 2002-05-21 | 2003-11-27 | Malik Dale W. | Group access management system |
US6950502B1 (en) * | 2002-08-23 | 2005-09-27 | Bellsouth Intellectual Property Corp. | Enhanced scheduled messaging system |
US20040044989A1 (en) * | 2002-08-30 | 2004-03-04 | Thomas Vachuska | Apparatus and method using pre-described patterns and reflection to generate source code |
US20040044687A1 (en) * | 2002-08-30 | 2004-03-04 | Thomas Vachuska | Apparatus and method using pre-described patterns and reflection to generate a database schema |
US20040064502A1 (en) * | 2002-09-30 | 2004-04-01 | International Business Machines Corporation | Metadirectory agents having extensible functions |
US20040111702A1 (en) * | 2002-12-10 | 2004-06-10 | Chan Kin Ming | Method and apparatus for visual programming |
US20040120480A1 (en) * | 2002-12-24 | 2004-06-24 | Didcock Clifford Neil | Flexible distributed/centralaized architecture for voice/unified messaging system |
US20040225525A1 (en) * | 2003-05-05 | 2004-11-11 | Weitzman Vernon L. | Automatic contacts replication system and software |
US20040253956A1 (en) * | 2003-06-12 | 2004-12-16 | Samsung Electronics Co., Ltd. | System and method for providing an online software upgrade in load sharing servers |
US20040267768A1 (en) * | 2003-06-27 | 2004-12-30 | Microsoft Corporation | Attribute based programming for data repositories |
US20050132266A1 (en) * | 2003-11-21 | 2005-06-16 | Ambrosino Timothy J. | Method of authoring, deploying and using interactive, data-driven two or more dimensional content |
US20060072720A1 (en) * | 2004-09-30 | 2006-04-06 | Blohm Jeffrey M | Presence enhanced outcalling |
US20060177011A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | System and method for providing code on voicemail appliance |
US20060177014A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | System and method for providing data on voicemail appliance |
US20060177024A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Integrated voice mail user/email system user setup in integrated multi-media communication system |
US20060177006A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Controlling messaging actions using form-based user interface |
US20060177007A1 (en) * | 2005-02-07 | 2006-08-10 | Shahriar Vaghar | Caching message information in an integrated communication system |
US20060177005A1 (en) * | 2005-02-07 | 2006-08-10 | Anthony Shaffer | System and method for voicemail privacy |
US20060177015A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | Message data access in multi-media integrated communication system |
US20060177025A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Integrating messaging server directory service with a communication system voice mail message interface |
US20060177023A1 (en) * | 2005-02-07 | 2006-08-10 | Shahriar Vaghar | Distributed cache system |
US20060177010A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | Caching user information in an integrated communication system |
US20060177012A1 (en) * | 2005-02-07 | 2006-08-10 | David Forney | Networked voicemail |
US20060177008A1 (en) * | 2005-02-07 | 2006-08-10 | David Forney | Extensible diagnostic tool |
US20060177013A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Form-based user interface for controlling messaging |
Cited By (30)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7346150B2 (en) | 2005-02-07 | 2008-03-18 | Adomo, Inc. | Controlling messaging actions using form-based user interface |
US20060177025A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Integrating messaging server directory service with a communication system voice mail message interface |
US20080133548A1 (en) * | 2005-02-07 | 2008-06-05 | Adomo, Inc. | Caching User Information in an Integrated Communication System |
US8559605B2 (en) | 2005-02-07 | 2013-10-15 | Avaya Inc. | Extensible diagnostic tool |
US20060177011A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | System and method for providing code on voicemail appliance |
US20060177013A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Form-based user interface for controlling messaging |
US7321655B2 (en) | 2005-02-07 | 2008-01-22 | Adomo, Inc. | Caching user information in an integrated communication system |
US7330537B2 (en) | 2005-02-07 | 2008-02-12 | Adomo, Inc. | Integrating messaging server directory service with a communication system voice mail message interface |
US7907704B2 (en) | 2005-02-07 | 2011-03-15 | Avaya Inc. | Caching user information in an integrated communication system |
US20060177006A1 (en) * | 2005-02-07 | 2006-08-10 | Heine Frifeldt | Controlling messaging actions using form-based user interface |
US20060177012A1 (en) * | 2005-02-07 | 2006-08-10 | David Forney | Networked voicemail |
US8233594B2 (en) | 2005-02-07 | 2012-07-31 | Avaya Inc. | Caching message information in an integrated communication system |
US8175233B2 (en) | 2005-02-07 | 2012-05-08 | Avaya Inc. | Distributed cache system |
US7564954B2 (en) | 2005-02-07 | 2009-07-21 | Adomo, Inc. | Form-based user interface for controlling messaging |
US20060177010A1 (en) * | 2005-02-07 | 2006-08-10 | Jens Skakkebaek | Caching user information in an integrated communication system |
US7724880B2 (en) | 2005-02-07 | 2010-05-25 | Avaya Inc. | Networked voicemail |
US7885275B2 (en) | 2005-02-07 | 2011-02-08 | Avaya Inc. | Integrating messaging server directory service with a communication system voice mail message interface |
US8059793B2 (en) | 2005-02-07 | 2011-11-15 | Avaya Inc. | System and method for voicemail privacy |
US8160212B2 (en) | 2007-02-21 | 2012-04-17 | Avaya Inc. | Voicemail filtering and transcription |
US8064576B2 (en) | 2007-02-21 | 2011-11-22 | Avaya Inc. | Voicemail filtering and transcription |
US8107598B2 (en) | 2007-02-21 | 2012-01-31 | Avaya Inc. | Voicemail filtering and transcription |
US20080240083A1 (en) * | 2007-03-28 | 2008-10-02 | Lowell Phillip Feldman | System and method for managing interoperability of internet telephony networks and legacy telephony networks |
US20080244260A1 (en) * | 2007-03-28 | 2008-10-02 | Lowell Phillip Feldman | System and method for managing interoperability of internet telephony networks and legacy telephony networks |
US20080240082A1 (en) * | 2007-03-28 | 2008-10-02 | Lowell Phillip Feldman | System and method for managing interoperability of internet telephony networks and legacy telephony networks |
US8488751B2 (en) | 2007-05-11 | 2013-07-16 | Avaya Inc. | Unified messenging system and method |
US20090217180A1 (en) * | 2008-02-21 | 2009-08-27 | Shoretel, Inc. | Programmable Buttons for Telephone User Interface |
US8490020B2 (en) * | 2008-02-21 | 2013-07-16 | Shoretel, Inc. | Programmable buttons for telephone user interface |
US20130198398A1 (en) * | 2012-02-01 | 2013-08-01 | Raketu Communications, Inc. | System and method for an improved network client device |
US11777892B1 (en) * | 2023-02-08 | 2023-10-03 | Citigroup Global Markets Inc. | Management of queries in electronic mail messages |
US11777886B1 (en) | 2023-02-08 | 2023-10-03 | Citigroup Global Markets Inc. | Management of queries in electronic mail messages |
Also Published As
Publication number | Publication date |
---|---|
US7808980B2 (en) | 2010-10-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7808980B2 (en) | Integrated multi-media communication system | |
US7564954B2 (en) | Form-based user interface for controlling messaging | |
US7321655B2 (en) | Caching user information in an integrated communication system | |
US7346150B2 (en) | Controlling messaging actions using form-based user interface | |
US7885275B2 (en) | Integrating messaging server directory service with a communication system voice mail message interface | |
US8175233B2 (en) | Distributed cache system | |
US8059793B2 (en) | System and method for voicemail privacy | |
US7724880B2 (en) | Networked voicemail | |
US8233594B2 (en) | Caching message information in an integrated communication system | |
US8160212B2 (en) | Voicemail filtering and transcription | |
US20060177015A1 (en) | Message data access in multi-media integrated communication system | |
EP2126684B1 (en) | Voicemail filtering and transcription | |
US8064576B2 (en) | Voicemail filtering and transcription | |
US8559605B2 (en) | Extensible diagnostic tool | |
US20060177024A1 (en) | Integrated voice mail user/email system user setup in integrated multi-media communication system | |
US20060177014A1 (en) | System and method for providing data on voicemail appliance | |
US20060177011A1 (en) | System and method for providing code on voicemail appliance |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: ADOMO, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SKAKKEBAEK, JENS;FRIFELDT, HEINE;POTZE, WILLAM R.B.;REEL/FRAME:016667/0189 Effective date: 20050513 |
|
AS | Assignment |
Owner name: AVAYA INC., NEW JERSEY Free format text: MERGER;ASSIGNOR:ADOMO, INC.;REEL/FRAME:023154/0362 Effective date: 20090818 Owner name: AVAYA INC.,NEW JERSEY Free format text: MERGER;ASSIGNOR:ADOMO, INC.;REEL/FRAME:023154/0362 Effective date: 20090818 |
|
FEPP | Fee payment procedure |
Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: BANK OF NEW YORK MELLON TRUST, NA, AS NOTES COLLATERAL AGENT, THE, PENNSYLVANIA Free format text: SECURITY AGREEMENT;ASSIGNOR:AVAYA INC., A DELAWARE CORPORATION;REEL/FRAME:025863/0535 Effective date: 20110211 Owner name: BANK OF NEW YORK MELLON TRUST, NA, AS NOTES COLLAT Free format text: SECURITY AGREEMENT;ASSIGNOR:AVAYA INC., A DELAWARE CORPORATION;REEL/FRAME:025863/0535 Effective date: 20110211 |
|
AS | Assignment |
Owner name: BANK OF NEW YORK MELLON TRUST COMPANY, N.A., THE, PENNSYLVANIA Free format text: SECURITY AGREEMENT;ASSIGNOR:AVAYA, INC.;REEL/FRAME:030083/0639 Effective date: 20130307 Owner name: BANK OF NEW YORK MELLON TRUST COMPANY, N.A., THE, Free format text: SECURITY AGREEMENT;ASSIGNOR:AVAYA, INC.;REEL/FRAME:030083/0639 Effective date: 20130307 |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: CITIBANK, N.A., AS ADMINISTRATIVE AGENT, NEW YORK Free format text: SECURITY INTEREST;ASSIGNORS:AVAYA INC.;AVAYA INTEGRATED CABINET SOLUTIONS INC.;OCTEL COMMUNICATIONS CORPORATION;AND OTHERS;REEL/FRAME:041576/0001 Effective date: 20170124 |
|
AS | Assignment |
Owner name: AVAYA INTEGRATED CABINET SOLUTIONS INC., CALIFORNIA Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 041576/0001;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:044893/0531 Effective date: 20171128 Owner name: OCTEL COMMUNICATIONS LLC (FORMERLY KNOWN AS OCTEL COMMUNICATIONS CORPORATION), CALIFORNIA Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 041576/0001;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:044893/0531 Effective date: 20171128 Owner name: AVAYA INC., CALIFORNIA Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 025863/0535;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST, NA;REEL/FRAME:044892/0001 Effective date: 20171128 Owner name: AVAYA INTEGRATED CABINET SOLUTIONS INC., CALIFORNI Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 041576/0001;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:044893/0531 Effective date: 20171128 Owner name: VPNET TECHNOLOGIES, INC., CALIFORNIA Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 041576/0001;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:044893/0531 Effective date: 20171128 Owner name: AVAYA INC., CALIFORNIA Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 041576/0001;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:044893/0531 Effective date: 20171128 Owner name: OCTEL COMMUNICATIONS LLC (FORMERLY KNOWN AS OCTEL Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 041576/0001;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:044893/0531 Effective date: 20171128 Owner name: AVAYA INC., CALIFORNIA Free format text: BANKRUPTCY COURT ORDER RELEASING ALL LIENS INCLUDING THE SECURITY INTEREST RECORDED AT REEL/FRAME 030083/0639;ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A.;REEL/FRAME:045012/0666 Effective date: 20171128 |
|
AS | Assignment |
Owner name: GOLDMAN SACHS BANK USA, AS COLLATERAL AGENT, NEW YORK Free format text: SECURITY INTEREST;ASSIGNORS:AVAYA INC.;AVAYA INTEGRATED CABINET SOLUTIONS LLC;OCTEL COMMUNICATIONS LLC;AND OTHERS;REEL/FRAME:045034/0001 Effective date: 20171215 Owner name: GOLDMAN SACHS BANK USA, AS COLLATERAL AGENT, NEW Y Free format text: SECURITY INTEREST;ASSIGNORS:AVAYA INC.;AVAYA INTEGRATED CABINET SOLUTIONS LLC;OCTEL COMMUNICATIONS LLC;AND OTHERS;REEL/FRAME:045034/0001 Effective date: 20171215 |
|
AS | Assignment |
Owner name: CITIBANK, N.A., AS COLLATERAL AGENT, NEW YORK Free format text: SECURITY INTEREST;ASSIGNORS:AVAYA INC.;AVAYA INTEGRATED CABINET SOLUTIONS LLC;OCTEL COMMUNICATIONS LLC;AND OTHERS;REEL/FRAME:045124/0026 Effective date: 20171215 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552) Year of fee payment: 8 |
|
AS | Assignment |
Owner name: WILMINGTON TRUST, NATIONAL ASSOCIATION, MINNESOTA Free format text: SECURITY INTEREST;ASSIGNORS:AVAYA INC.;AVAYA MANAGEMENT L.P.;INTELLISIST, INC.;AND OTHERS;REEL/FRAME:053955/0436 Effective date: 20200925 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 12 |
|
AS | Assignment |
Owner name: WILMINGTON TRUST, NATIONAL ASSOCIATION, AS COLLATERAL AGENT, DELAWARE Free format text: INTELLECTUAL PROPERTY SECURITY AGREEMENT;ASSIGNORS:AVAYA INC.;INTELLISIST, INC.;AVAYA MANAGEMENT L.P.;AND OTHERS;REEL/FRAME:061087/0386 Effective date: 20220712 |
|
AS | Assignment |
Owner name: AVAYA INTEGRATED CABINET SOLUTIONS LLC, NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS AT REEL 45124/FRAME 0026;ASSIGNOR:CITIBANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:063457/0001 Effective date: 20230403 Owner name: AVAYA MANAGEMENT L.P., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS AT REEL 45124/FRAME 0026;ASSIGNOR:CITIBANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:063457/0001 Effective date: 20230403 Owner name: AVAYA INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS AT REEL 45124/FRAME 0026;ASSIGNOR:CITIBANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:063457/0001 Effective date: 20230403 Owner name: AVAYA HOLDINGS CORP., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS AT REEL 45124/FRAME 0026;ASSIGNOR:CITIBANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:063457/0001 Effective date: 20230403 |
|
AS | Assignment |
Owner name: WILMINGTON SAVINGS FUND SOCIETY, FSB (COLLATERAL AGENT), DELAWARE Free format text: INTELLECTUAL PROPERTY SECURITY AGREEMENT;ASSIGNORS:AVAYA MANAGEMENT L.P.;AVAYA INC.;INTELLISIST, INC.;AND OTHERS;REEL/FRAME:063742/0001 Effective date: 20230501 |
|
AS | Assignment |
Owner name: CITIBANK, N.A., AS COLLATERAL AGENT, NEW YORK Free format text: INTELLECTUAL PROPERTY SECURITY AGREEMENT;ASSIGNORS:AVAYA INC.;AVAYA MANAGEMENT L.P.;INTELLISIST, INC.;REEL/FRAME:063542/0662 Effective date: 20230501 |
|
AS | Assignment |
Owner name: AVAYA MANAGEMENT L.P., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: CAAS TECHNOLOGIES, LLC, NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: HYPERQUALITY II, LLC, NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: HYPERQUALITY, INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: ZANG, INC. (FORMER NAME OF AVAYA CLOUD INC.), NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: VPNET TECHNOLOGIES, INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: OCTEL COMMUNICATIONS LLC, NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: AVAYA INTEGRATED CABINET SOLUTIONS LLC, NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: INTELLISIST, INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: AVAYA INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 045034/0001);ASSIGNOR:GOLDMAN SACHS BANK USA., AS COLLATERAL AGENT;REEL/FRAME:063779/0622 Effective date: 20230501 Owner name: AVAYA INTEGRATED CABINET SOLUTIONS LLC, NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 53955/0436);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063705/0023 Effective date: 20230501 Owner name: INTELLISIST, INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 53955/0436);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063705/0023 Effective date: 20230501 Owner name: AVAYA INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 53955/0436);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063705/0023 Effective date: 20230501 Owner name: AVAYA MANAGEMENT L.P., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 53955/0436);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063705/0023 Effective date: 20230501 Owner name: AVAYA INTEGRATED CABINET SOLUTIONS LLC, NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 61087/0386);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063690/0359 Effective date: 20230501 Owner name: INTELLISIST, INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 61087/0386);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063690/0359 Effective date: 20230501 Owner name: AVAYA INC., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 61087/0386);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063690/0359 Effective date: 20230501 Owner name: AVAYA MANAGEMENT L.P., NEW JERSEY Free format text: RELEASE OF SECURITY INTEREST IN PATENTS (REEL/FRAME 61087/0386);ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION, AS NOTES COLLATERAL AGENT;REEL/FRAME:063690/0359 Effective date: 20230501 |
|
AS | Assignment |
Owner name: AVAYA LLC, DELAWARE Free format text: (SECURITY INTEREST) GRANTOR'S NAME CHANGE;ASSIGNOR:AVAYA INC.;REEL/FRAME:065019/0231 Effective date: 20230501 |
|
AS | Assignment |
Owner name: AVAYA MANAGEMENT L.P., NEW JERSEY Free format text: INTELLECTUAL PROPERTY RELEASE AND REASSIGNMENT;ASSIGNOR:WILMINGTON SAVINGS FUND SOCIETY, FSB;REEL/FRAME:066894/0227 Effective date: 20240325 Owner name: AVAYA LLC, DELAWARE Free format text: INTELLECTUAL PROPERTY RELEASE AND REASSIGNMENT;ASSIGNOR:WILMINGTON SAVINGS FUND SOCIETY, FSB;REEL/FRAME:066894/0227 Effective date: 20240325 Owner name: AVAYA MANAGEMENT L.P., NEW JERSEY Free format text: INTELLECTUAL PROPERTY RELEASE AND REASSIGNMENT;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:066894/0117 Effective date: 20240325 Owner name: AVAYA LLC, DELAWARE Free format text: INTELLECTUAL PROPERTY RELEASE AND REASSIGNMENT;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:066894/0117 Effective date: 20240325 |
|
AS | Assignment |
Owner name: ARLINGTON TECHNOLOGIES, LLC, TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:AVAYA LLC;REEL/FRAME:067022/0780 Effective date: 20240329 |