EP0629329A1 - Telephone network application platform for supporting facsimile applications - Google Patents

Telephone network application platform for supporting facsimile applications

Info

Publication number
EP0629329A1
EP0629329A1 EP93907247A EP93907247A EP0629329A1 EP 0629329 A1 EP0629329 A1 EP 0629329A1 EP 93907247 A EP93907247 A EP 93907247A EP 93907247 A EP93907247 A EP 93907247A EP 0629329 A1 EP0629329 A1 EP 0629329A1
Authority
EP
European Patent Office
Prior art keywords
facsimile
command
fax
commands
nap
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.)
Withdrawn
Application number
EP93907247A
Other languages
German (de)
French (fr)
Inventor
Bruce Goldhagen
Michael S. Recant
David W. Heileman, Jr.
Frederick C. Kruesi
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Unisys Corp
Original Assignee
Unisys Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Unisys Corp filed Critical Unisys Corp
Publication of EP0629329A1 publication Critical patent/EP0629329A1/en
Withdrawn legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N1/32358Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device using picture signal storage, e.g. at transmitter
    • H04N1/324Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device using picture signal storage, e.g. at transmitter intermediate the transmitter and receiver terminals, e.g. at an exchange
    • H04N1/32406Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device using picture signal storage, e.g. at transmitter intermediate the transmitter and receiver terminals, e.g. at an exchange in connection with routing or relaying, e.g. using a fax-server or a store-and-forward facility
    • H04N1/32411Handling instructions for routing or relaying
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/50Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
    • H04M3/53Centralised arrangements for recording incoming messages, i.e. mailbox systems
    • H04M3/5307Centralised arrangements for recording incoming messages, i.e. mailbox systems for recording messages comprising any combination of audio and non-audio components
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00281Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a telecommunication apparatus, e.g. a switched network of teleprinters for the distribution of text-based information, a selective call terminal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N1/32358Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device using picture signal storage, e.g. at transmitter
    • H04N1/324Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device using picture signal storage, e.g. at transmitter intermediate the transmitter and receiver terminals, e.g. at an exchange
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N1/32561Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device using a programmed control device, e.g. a microprocessor
    • H04N1/32566Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device using a programmed control device, e.g. a microprocessor at the transmitter or at the receiver

Definitions

  • the invention relates to providing facsimile (fax) services over the telephone network via application software for such services and involves a telephone network digital computer platform for supporting such application software.
  • the facsimile machine has become ubiquitous in present day communication for transmission of documents. Facsimile transmission over the Public Switched Telecommunications Network (PSTN) annually generates billions of dollars in toll revenues.
  • PSTN Public Switched Telecommunications Network
  • a variety of facsimile related services and enhanced services are currently available, such as Call Answer, Fax Store and Forward, Fax Mailbox, and the like.
  • Such services are provided by dedicated systems specifically designed for the service and for the hardware environment in which the system will be deployed.
  • Such systems tend to lack flexibility, in that desired changes in functionality often require extensive, and hence expensive, modifications to the application software.
  • application software for providing such services are not portable in that a change in hardware environment usually requires substantial application software re-writing.
  • BOCs Bell Operating Companies
  • Telcos Independent Telephone Companies
  • One source of increased revenue would be to offer new facsimile related services that integrate into, or interface with the existing network, resulting in greater utilization thereof.
  • BOCs and Telcos are designed to switch calls, not support data base or special service related functionality.
  • Each Central Office (CO) utilizes a predetermined set of functions provided by the switch manufacturer. Only the manufacturer could add new services to the switching system which usually involves substantial lead times, such as two years or more. Additionally, the switch manufacturers have been particularly slow in responding to the needs of the BOCs and Telcos for enhanced service provisioning.
  • a major limiting factor to providing new facsimile related services is a dependence on the telephone switch provider for implementing the capabilities required by these new services.
  • the present invention overcomes the above-described disadvantages of the prior art by providing, for the first time, a Telephone Network Applications Platform that interfaces with the telephone network and supports facsimile oriented application software that provides facsimile oriented services.
  • the present invention is an enhancement and extension of the Telephone Network Applications Platform disclosed in said S.N. 521,210.
  • the NAP interfaces between the telephone network and a facsimile application program and comprises a digital computer programmed to perform facsimile oriented telephone network f ctionality in response to -facsimile oriented com an ⁇ issued by the facsimile application program.
  • the facsimile oriented telephone network functionality resides in the computer independent of the facsimile application program and is actuatable in response to the commands.
  • the commands include a Send Fax command and a Receive Fax command, the telephone network facsimile functionality including sending a facsimile message to the network and receiving a facsimile message from the network in response to the Send Fax command and the Receive Fax command, respectively.
  • An application interface coupled between the facsimile application program and the computer responds to the commands from the application for actuating the telephone network facsimile functionality in response to and in accordance with the commands.
  • the application interface is responsive to the Send Fax command and the Receive Fax command from the application for activating the telephone network facsimile functionality by causing a facsimile message to be sent to the network and causing a facsimile message to be received from the network in response to the Send Fax command and the Receive Fax command, respectively.
  • a network facsimile interface coupled between the network and the computer conveys the facsimile messages therebetween.
  • the NAP includes a data base and voice file for storing voice messages.
  • the fax messages are also stored in the voice file and managed by the data base.
  • the computer also includes the telephone network functionality relating to voice messages and call connectivity actuatable by AIM commands as described in said S.N. 521,210.
  • the network facsimile interface preferably includes a Fax Processor for accepting facsimile messages from and delivering facsimile message to the network.
  • the facsimile extensions of NAP preferably include a Fax Server for interpreting and expanding the facsimile commands into FP coiiimands for controlling the Fax Proc ssor and into AIM commands for performing the NAP functionality required to execute the facsimile commands
  • communication means interposed between the application and the application interface directs AIM commands to NAP to be executed i ' - the manner described in said S.N. 521,210 and facsimi commands to the Fax Server for execution.
  • the Fax Server and communication means can be integrated into NAP with AIM commands and facsimile commands appropriately directed and executed.
  • a recovery process is utilized with respect to a Recovery Token for assuring that no faxes are lost between receipt at the FP and entry into the NAP storage file.
  • Figure 1 is a schematic block diagram illustrati the overall architecture of the NAP with Fax Extensions (NAPFE) in accordance with the present invention and the environment in which the NAPFE is deployed.
  • Figure 2 is a diagram illustrating the format of the NAPFE command and response common header utilized within the NAPFE of Figure 1. The command body is. also illustrated.
  • Figure 3 is a schematic block diagram illustrati functional details of the COMS interface of the NAPFE of Figure 1.
  • Figure 4A is a diagram illustrating the format of the FS to FP command.
  • Figure 4B is a diagram illustrating the format of the FP file transfer command.
  • FIG. 5 is a schematic block diagram illustrating functional details of the Fax Server (FS) of the NAPFE of Figure 1.
  • FS Fax Server
  • FIG. 6 is a schematic block diagram illustrating functional details of the Fax Processor (FP) of the NAPFE of Figure 1.
  • FP Fax Processor
  • FIG. 7 is a schematic block diagram which describes the Voice Interface Module (VIM) protocol.
  • VIP Voice Interface Module
  • Figure 8 is a diagram illustrating the formats of the commands of the Data Transfer Command Set.
  • NAP 10 and disk system 23 is illustrated with the NAPFE components utilized to extend the NAP 10 to provide facsimile oriented functionality.
  • Reference numerals below 100 refer to NAP and reference numerals above 100 refer to NAPFE.
  • the NAP 10 with the disk system " 23 is preferably implemented on an A-Series digital computer system commercially available from Unisys Corporation of Blue Bell, Pennsylvania, and is described in detail in said NAPSNs. The NAP 10 will be briefly described herein for continuity.
  • Zhe NAP 10 interfaces between telephone network application programs 00 and a telephone network 12.
  • the applications 100 may comprise voice oriented programs that are managed by the NAP 10 in the manner described in said NAPSNs, facsimile oriented applications, and a coabination of voice and facsimile.
  • the applications 100 communicate with the NAP 10 through message passing communication apparatus 101 such as the A-Series COMS.
  • message passing communication apparatus 101 such as the A-Series COMS.
  • the NAP 10 is comprised of an AIM 15, a VMMM 16, an NIUM 17, and NIUs 19.
  • the applications 100 communicate with the AIM 15 via dialogs comprising sequences of NAP commands and responses.
  • NAP protocol requires that the commands and responses occur in pairs with a response returned by the AIM 15 to the application for each command issued by the application to the AIM 15.
  • the COMS 101 directs NAP commands received from an application 100 to the AIM 15 along a path 13 and receives NAP responses from the AIM 15 along the path 13.
  • the COMS 101 conceptually intercepts NAPFE commands from the applications 100 and sends the NAPFE commands along a path 102 to a Fax Server (FS) 103 for interpretatio and processing.
  • FS Fax Server
  • the NAPFE of the present invention includes a plurality of Fax Processors (FP) 104 which are utilized for delivering facsimile messages to the network 12 and for receiving facsimile messages therefrom via ports 105.
  • FP Fax Processors
  • the facsimile communication between the Fax Processors 104 and the network can be direct to a Central Office 27, via a link 106, or via the NIU 19 through NIU ports 20.
  • Each Fax Processor 104 performs all of the functions associated with sending and receiving facsimile messages in accordance with present day facsimile messaging protocol.
  • the Fax Processors 104 are compatible with Group III CCITT specifications T.4, T.30, and V.29.
  • the Fax Processors 104 communicate with the Fax Server 103 through ports 113 via a path 107 and a high-speed parallel link 108 through Fax Processor Data Link Processors (FP DLP) 109.
  • FP DLP Fax Processor Data Link Processors
  • Each Fax Processor 104 communicates with the Fax Server 103 via a respective FP DLP 109.
  • a fax command from an application 100 is transmitted by COMS 101 along the path 102 to the Fax Server 103.
  • the Fax Server 103 interprets each fax command as a sequence of FP commands for the Fax Processors 104 and normal NAP AIM commands to be processed by the NAP 10.
  • the FP commands are issu to the Fax Processors 104 via the path 107, the FP DLP 1 and the high-speed link 108.
  • the Fax Processors 104 return FP responses to the Fax Server 103 via the path comprising the components 107, 108 and 109.
  • Facsimile data is also communicated between the Fax Processors 104 and the Fax Server 103 via this path.
  • the NAP AIM commands that form part of the fax commands are transmitted by the Fax Server 103 to the AIM 15 through the COMS 101 via a path 110.
  • Concomitant NAP responses are returned to the Fax Server 103 through the COMS 101 via the path 110.
  • COMS 101 intercepts the NAP and NAPFE commands from the applications 100 and the FS 103 and the responses from AIM 15 and FS 103 and calls a processing item (from FS 103), functionally illustrated in Figure 3, to appropriately direct the messages.
  • the NAP AIM commands from the applications and the NAP AIM con nds used in NAPFE processing are forwarded to the AIM 15.
  • the NAPFE commands from the applications are processed by FS 103.
  • Responses resulting from NAP AIM commands from an application 100 are returned to the application.
  • Responses resulting from NAP AIM commands used in NAPFE processing are returned to FS 103.
  • the Fax Server 103 maintains temporary storage files 115 on the disk system 23 through the A-Series
  • Fax data is written to and read from this file by the Fax Server 103 via a path 111 utilizing standard A-Series file access mechanisms. Additionally, other A-Series files 50, such as application files, are maintained on the disk system 23.
  • the VMMM 16 under direction of the AIM 15 maintains a data base voice file 40 on the disk system 23 for storing voice messages that are received from and sent to the network 12.
  • the NAP 10 assigns a unique Message Number (MN) to ecich voice message in the file.
  • MN Message Number
  • f ⁇ . ⁇ . messages that are received from and transmitted by the Fax Processors 104 are also maintained in the NAP data base file 40.
  • the NAP 10 also assigns unique MNs to the fax messages stored in the NAP data base 40 on the disk system 23.
  • the AIM 15 controls the switching of the ports 20 of the NIU 19 through the NIUM 17 and manages the call signalling, as described in said S.N. 521,210. Furthermore, as described in said NAPSNs, the VIM DLPs 25 manage the communication of voice messages to and from the network 12 through the NIUs 19 under control of commands from the voice channel command queue 26 as described in further detail in said S.N. 503,195.
  • the NAP 10 is programmed with telephone network functionality invoked by AIM commands from the applications.
  • These commands include DELETE VOICE MESSAGE, CONNECT CALL, TERMINATE DIALOG , COLLECT DIGITS, INITIATE CALL, TERMINATE CALL, GET MESSAGE NUMBERS, GET VOICE MESSAGE, CREATE VOICE MESSAGE, and PIVOT CALL.
  • the details of these commands and the invoked functionality are set forth in said S.N. 521,210.
  • the DELETE VOICE MESSAGE command deletes a named message from the NAP data base.
  • the CONNECT CALL command switches the incoming NIU port of the call from the current outgoing port to a new outgoing port.
  • the TERMINATE DIALOG command terminates the dialog represented by the dialog ID.
  • the command is utilized by NAPFE as a time-out.
  • the INITIATE CALL command initiates a call to the network.
  • the TERMINATE CALL command terminates a call.
  • the GET MESSAGE NUMBERS command causes the NAP 1 to provide to the application all of the Message Numbers of the messages stored in the NAP data base file that are associated with the application. This command is used for message reconciliation as described in said S.N..
  • the GET VOICE MESSAG command controls the NAP 10 to place the d&t-.. of & named message in the NAP data base file into a named A-Series disk file.
  • the CREATE VOICE MESSAGE command copies a message from a named A-Series file into the NAP data base file.
  • the PIVOT CALL command changes the outgoing NIU port to an incoming port and establishes a new outgoing port.
  • the Fax Processors 104 send to and receive from the network fax messages over a currently existing connection upon receipt of a NAPFE command.
  • the applications 100 utilize the following AIM commands: CONNECT CALL, INITIAT CALL, and PIVOT CALL.
  • the NAPFE utilizes the following AIM commands as part of the NAPFE commands: CONNECT CALL, COLLECT DIGITS, GET VOICE MESSAGE, and CREATE VOICE MESSAGE.
  • the COLLECT DIGITS command is utilized as a time-out to get an on-hook notification from the NIU 20, in a manner to be described.
  • the GET VOICE MESSAGE and CREATE VOICE MESSAGE commands are utilized by the Fax Server 103 to transfer fax messages between the Fax Processors 104 and the NAP data base message file in a manner to be explained.
  • the NAP 10 establishes a platform to provide basic voice management services to an application.
  • NAPFE provides a similar set of fax management services by the addition of elements 102-111 and the modification of COMS 101 to direct fax commands to the Fax Server 103.
  • the Fax Server 103 adds a set of fax oriented commands to the AIM command set of the AIM 15 thereby providing extensions to the AIM command set.
  • NAPFE performs four basic facsimile oriented functions as follows:
  • NAPFE will answer an incoming call and receive a fax message. The call may be answered directly or a voice dialog first performed.
  • NAPFE supports the capability of answering an incoming call and transmitting a fax at the originator's request.
  • the subscriber can request that the existing connection be used to send a fax to the subscriber's fax machine. This function can also be used during polling where a fax machine polls NAPFE over the network to receive a fax therefrom.
  • Originate and Send a Fax This basic fax machine function involves the fax application dialing out over a telephone line, connecting to a remote fax machine and transmitting a fax image thereto. Originate and Receive a Fax. This function is utilized when NAPFE polls a remote fax machine to receive faxes that reside thereat for pick-up.
  • the NAPFE command and response have a common header, the format of which is illustrated at 120.
  • the command and response body is also depicted at 121.
  • the header 120 includes a Message Type field 122 for containing a numerical representation of the command or response type.
  • a Dialog ID field 123 identifies the NAP or NAPFE dialog with which the command or response is associated.
  • the header 120 is substantially the same as the AIM command and response common header described in said S.N. 521,210.
  • the body 121 of the command or response includes any or all of the following: a Recovery Token field 124, a Data Base Number field 125, a Message Number field 126 and a Fax File Name field 127 for conveying a Recovery Token, a Data Base Number, one or more NAP Message Numbers (MN), and an A-Series file title, respectively.
  • the Recovery Token is utilized in a recovery process, to be described, to receive potentially lost faxes.
  • the Data Base Number identifies the application associated with the command or response. Each NAP and NAPFE application has a unique Data Base Numb r assigned by NAP.
  • the MN identifies fax message(s) involved in the command or response.
  • the Fax File Name identifies a file containing a fax message.
  • the COMS 101 utilizes NAPFE processing item comprised of a Fax Commands and Responses block 130 and a NAP Commands and Responses block 131.
  • Standard NAP commands from the applications 100 are directed by the block 131 to the AIM 15 along the path 13.
  • standard NAP commands that form part of the fax commands are also transmitted by the block 131 from the path 110 to the AIM 15 via the path 13.
  • the fax commands intercepted by the block 130 are transmitted to the Fax Server 103 along the path 102. All standard NAP commands and responses and all fax commands and responses have unique Message Type numbers stored in the field 122 of the command header ( Figure 2).
  • the blocks 130 and 131 direct the commands from the applications 100 either to the Fax Server 03 or to AIM 1 on the basis of the Message Type numbers.
  • Fax responses received at the block 130 from the Fax Server 103 along the path 102 are transmitted back to the applications 100.
  • AIM responses received at the block 131 from AIM 15 along the path 13 that belon to non-fax dialogs are transmitted back to the applications 100 in the manner described in said S.N. 521,210.
  • AIM responses received at the block 131 along the path 13 that belong to fax dialogs are transmitted back to the Fax Server 103 along the path 110.
  • the separation between fax and non-fax responses is based on the unique Message Type numbers or on the dialog ID stored in the fields 122 or 123, respectively, of the response headers ( Figure 2).
  • a dialog table (not shown) maintained by NAPFE (Fax Server 103), and available to COMS 101, identifies the fax and non-fax dialogs.
  • h Fax Server 103 appears as an application to the AIM ';._> communicating therewith through the COMS portion 131 utilizing the standard AIM protocols described herein and in said S.N. 521,210.
  • the COMS 101 also includes a command trap 132 for reasons to be explained.
  • the Fax Server 103 sends Fax Processor (FP) commands to the Fax Processors 104 and receives FP responses therefrom.
  • the FP commands are of two types; viz., FP commands for sending and receiving faxes and FP commands for file transfers between the Fax Processors 104 and NAP disk. Referring to Figure 4A, the format of the FP command and response involved in fax communication is illustrated.
  • a Message Type field 140 designates the type of command or response.
  • An FP number field 141 designates the Fax Processor selected in the dialog.
  • a port number field 142 designates the FP port selected in the dialog.
  • a fax name field 143 identifies the files with which the command is involved and a phone number field 144 designates a phone number to be out-dialed by the Fax Processor in performance of the command.
  • a Message Type field 150 designates the command or response type.
  • a fax name field 151 identifies the fax files with which the command or response is involved and a port number field 152 denotes the FP port with which the file transfer is associated.
  • a fax command set 160 is conceptually illustrated as comprising FP commands 161 and AIM commands 162. The fax commands are received from the applications 100 through the COMS portion 130 along the path 102. As previously described, the FP commands 161 are transmitted along the path 107 to the Fax Processors 104 via the FP DLP 109.
  • FP responses from the Fax Processors 104 ar «? received at the FS 103 along the path 107 as conceptually indicated at, 163.
  • the FP responses are utilized by the FS 103 in performing the steps and commands comprising each fax command in the fax command set 160.
  • the AIM commands 162 are transmitted to AIM 15 ( Figure 1 ) through the COMS portion 131.
  • the NAP responses to the AIM commands 162 are received at the FS 103 through the COMS portion 131 as conceptually illustrated at 164.
  • the FS 103 utilizes the NAP responses 164 in executing the various steps and command that comprise each fax command in the fax command set 160 Additionally, the NAP responses 164, as well as the FP responses 163, are utilized by the FS 103 to form the fax response for each received fax command as conceptuall illustrated at 165.
  • the fax responses 165 are transmitt back to the applications 100 ( Figure 1) through the COMS portion 130. It is appreciated that when a NAPFE comman is issued by the application, it may result in issuance of multiple AIM and FP commands and responses.
  • the NAP 10 maintains fax and voice messages stor in the NAP data base file on the disk 23.
  • the FS 103 maintains A-Series files for temporary storag on the disk system 23 and, as discussed in said S.N. 521,210, the applications 100 may maintain A-Series files thereon. Furthermore, the Fax Processors 104 stor fax message files for transmission to the network 12 or after receipt therefrom. There are differences in the file formats of the application files, the FS files, the NAP data base files, and the FP files that may require conversion.
  • the FS 103 receives fax data from the Fax Processors 104 along the path 107 and temporarily holds the data as schematically indicated at 166. Requisite file conversions are performed at 167 and the FS 103 transmits the converted fax file to the I/O processor 24 along the path 111 for storage i ⁇ - ' ⁇ .
  • temporary A-Series disk file of the FS 103. 'r e i_- « ⁇ porarily stored file is transferred to the NAP data base message file utilizing the NAP CREATE VOICE MESSAGE command in the manner described in said S.N. 521,210.
  • a fax message to the network is provided along the path 107 from the fax data storage block 166 after appropriate file conversion 167 is performed.
  • the FS 103 obtains this fax data from its temporary A-Series file via the I/O processor 24 along the path 111.
  • this file may be obtained from the NAP data base message file into the FS temporary disk file via a NAP GET VOICE MESSAGE command.
  • the Fax Server 103 also includes a Recovery Table 168 utilized in a fax message recovery process to be described.
  • the Fax Processor 104 is a conventional AT/PC with commercially available facsimile cards installed in the AT slots thereof.
  • a CPU 180 controls the ports 105 for direct connection to the network via the path 106 and for connection to the network via the NIUs 19 as illustrated.
  • the Fax Processor 104 includes a hard disk 181, controlled by the CPU 180, for temporarily storing the facsimile messages after receipt from, or before transmission to, a facsimile machine via the network or CO 27.
  • the fax communication is through fax cards 182 and the ports 105.
  • the fax cards 182 are installed in the AT slots and communicate with the ports 105 under control of the CPU 180.
  • the fax cards are commercially procurable and may, for example, be implemented by GammaLink PC facsimile cards available from GammaLink Corporation of Sunnyvale, California.
  • the fax cards 182 communicate with the hard disk 181 under control of the CPU 180, as conceptually illustrated at 185. It is appreciated that the fax cards 182 access the disk 181 through the CPU 180 via a software interface (not shown) procurable with the cards and installed on the fax cards 182 and the CPU 180.
  • the hard disk 181 communicates through the ports 113, as controlled by the CPU 180, to the link 108 for intra-system file transfers in a manner to be described. It is appreciated that disk communication is effected through the PC DOS operating system in a well known manner.
  • the Fax Processor 104 receives the FP commands from the FP DLP 109 over the link 108 through the ports 113 as conceptually indicated at 183.
  • the Fax Processor 104 sends FP responses back over the link 108 through the ports 113 as conceptually indicated at 184.
  • the CPU 180 may, for example, be implemented by an 80286/12 MHz processor card.
  • the Fax Processor 104 is preferably of an industrialized rack-mounted hardware configuration, but is a conventional 286 class PC running standard PC DOS from the hard disk 181.
  • the FP 104 can dial out to the phone number in the phone number field 144 ( Figure 4A) via the fax cards 182.
  • the Fax Processor 104 operates asynchronously with respect to the Fax Server 103. After the Fax Processor 104 is commanded by the Fax Server 103 to receive a fax from the network, the fax message is completely received and stored on the disk 181 without NAPFE intervention. Similarly, after a fax is stored from the Fax Server 103 on the disk 181 for transmission to the network and the Fax Processor 104 is commanded by the Fax Server 103 to effect the transmission, the fax message is sent by the Fax Processor 104 without intervention from NAPFE.
  • NAPFE Command Set 160 ( Figure 5), which commands are expected from an application in a dialog. Commands are sent from an a plication 100 to NAPFE when the application wants NAP.7, to perform a facsimile oriented function. Within each dialog there is a one-to-one relationship between commands and responses; i.e., for each command sent by the application 100, NAPFE will return a response and for each response returned by NAPFE, the application 100 will issue a command.
  • cosamands 01-12 control facsimile message transmission and reception functions
  • commands 90 and 92 control functions relating to transferring files between the NAP disk 23 and the FP disk 181.
  • file transfer is specified in terms of Send File and Receive File commands, A-Series file transfer mecha - ⁇ ms may be utilized that separately transfer Headers , Blocks and Records.
  • the FP commands represent the total functionality that the NAPFE requires from the FP 104 so that the NAPFE can provide the facsimile oriented capabilities required by the applications 100. All FP commands result in a single response. These commands are used to control the actual fax operations that the FP 104 must execute.
  • Answer and Receive (Message Type 01).
  • This command places the specified FP port into a mode where it will wait for ring, answer the phone and receive an incoming fax.
  • the command generates an immediate respons of FaxPortReady (Message Type 50) that will indicate that the FP port is ready and the call can be routed thereto.
  • Two methods can be used to determine when the fax reception is complete.
  • a PortState (Message Type 06) command can be issued to the FP port on a periodic basis. This permits the Fax Server 103 to determine the state of the fax operation. Alternatively, the Fax Server 103 can issue a WaitCompleted (Message Type 12) command causing a ReceiveDone (Message Type 51 ) response to be generated when the fax reception is complete.
  • Originate and Receive (Message Type 02). This command is used to cause the specified fax port to originate a call to the specified phone number and poll the answering machine for a fax. Thus, the FP 103 dials out through the specified fax port to poll for an incoming fax. The response to this command is a ReceiveDone (Message Type 51 ) which is issued when the operation is completed.
  • This command causes the designated FP port to call the specified phone number and to transmit the designated faxes.
  • the FP 103 dials, out through the specified fax port and sends the faxes.
  • the response to this command is a TransmitDone (Message Type 52) which is issued at the completion of the fax operation.
  • Answer then Transmit (Message Type 04).
  • This command causes the FP port to go into a state where it will wait for an incoming call, answer the phone and transmit the specified faxes when a poll is received from the other fax machine.
  • the FP prepares to answer the incoming call on the specified fax port, be polled and then transmit the faxes.
  • the response to this command is a TransmitDone (Message Type 52) which is received when the fax operation is complete.
  • Remove File (Message Type 05). This command causes the named files to be removed from the hard disk drive 181 of the FP. The command generates an immediate response of FileRemoved (Message Type 54).
  • Port State (Message Type 06). This command is used to inquire of the current status of the specified port and the results of the last fax operation of that port. The command generates an immediate result of PortStatus (Message Type 55) which details the current status of the port.
  • Port Initialize (Message Type 08). This command causes the specified fax port to be initialized. The port state is initialized to an Idle state. This command includes a field for a RerooveFile Flag which, if set, causes the F? 104 to remove all files on the FP hard disk 181 associated with the designated fax port. The command generates an immediate response of Initialized (Message Type 57).
  • NIU Originate and Transmit through NIU (Message Type 11).
  • This command causes the designated FP port to originate a call through the NIU 19.
  • the command generates an immediate response of FaxPortReady (Message Type 50) denoting that the FP port is ready and a call will be initiated to the NIU 19 through a predetermined port 20.
  • FaxPortReady Message Type 50
  • Two methods can be utilized to determine when the fax transmission is complete.
  • a PortState (Message Type 06) command can be issued by the Fax Server 103 on a periodic basis. This permits the Fax Server to determine the state of the fax operation. Alternatively, the Fax Server can issue a WaitCompleted (Message Type 12 command. This causes a TransmitDone (Message Type 51) response to be generated when the fax transmission is complete.
  • This command is utilized on the selected fax port that has had a fax operation initiated using the AnswerRecv (Message Type 01 ) or the OriginateXmitNIU (Message Type 11) commands. While the port is in an Inuse state, this command causes a ReceiveDone (Message Type 51 ) or a TransmitDone (Message Type 52) response to be generated when the fax operation is complete. If the port is in a Completed state, the ReceiveDone and TransmitDone will be issued immediately. Receive File (Message Type 92). This command transfers the named file from the PC hard disk 181 to the NAP memory disk system 23. When the operation is completed, the FileXfered response (Message Type 91 ) is issued.
  • Send File (Message Type 90). This command transfers the named file from the NAP memory disk system 23 to the PC hard disk 181. When the operation is complete, the FileXfered (Message Type 91 response is issued.
  • file transfer is accomplished utilizing the file transfer message types 90 and 91.
  • the file transfers are initiated by the File Server 103 ( Figure 1).
  • the Fax Processor 104 never initiates a file transfer operation.
  • the FP 104 has a specific response for each of the above-described FP commands as conceptually illustrated at 184 of Figure 6.
  • the responses are as follows: Fax Port Ready (Message Type 50). This response is the result of an AnswerRcv command (Message Type 01 ) or an OriginateXmitNIU (Message Type 11) command.
  • the response indicates that the designated fax port is ready to receive or transmit a fax in an asynchronous fashion.
  • Receive Done (Message Type 51).
  • This response is the result of an OriginateRcv command (Message Type 02).
  • the response indicates that a fax has been successfully or unsuccessfully received.
  • a Result field of the response indicates the success or failure of the received fax processing.
  • Transmit Done (Message Type 52). This is a response to either the OriginateXmit (Message Type 03) or the AnswerXmit (Message Type 04) commands.
  • the response indicates the results of the fax transmit operation.
  • a Status field of the response indicates the success or failure of the transmit fax processing.
  • File Removed (Message Type 54). This is the response to the RemoveFile command (Message Type 05). The response indicates the results of the RemoveFile request.
  • the fax name field designates the names of the files removed from the FP hard disk 181.
  • Port Status (Message Type 55). This is the response to the PortState command (Message Type 06). It indicates the current state of the fax port specified by the Port Number field of the response.
  • the response also includes a Result field indicating the success or failure of the last command's fax processing.
  • a Port State field of the response indicates the current state of the port. The Port State field may indicate Idle, Inuse or Completed.
  • a File Name field of the response lists the FP file names of the
  • Initialized (Message Type 57). This is the response to .the Portlnitialize (Message Type 08) command. The response indicates the results of the initialize operation.
  • File Transferred (Message Type 91 ). This is the response to the SendFile (Message Type 90) and ReceiveFile (Message Type 92) commands. The response indicates the results of the last file transfer request.
  • the Fax Server 103 will generate a fax response 165 ( Figure 5) and the COMS portion 130 ( Figure 3) will respond to the application 100. There is a one-to-one correspondence between commands and responses. All standard NAP functionality is available to a fax application. The primary difference between a NAP fax application and a standard NAP application is the additional NAPFE commands that are available.
  • Receive Fax (Message Type 23). This command is sent by the application to the Fax Server 103 of NAPFE to request that the FP receive a fax from a fax machine. The connection associated with the specified Dialog ID is used for the fax reception.
  • the Fax Server 103 issues the AnswerRecv FP command to the Fax Processor which responds with FaxPortReady back to the Fax Server indicating that FP is ready to receive an incoming call from the NIU.
  • the Fax Server then issues the NAP command Connect Call to switch the current NIU call connection of the specified dialog ID to the NIU port for the selected FP port. Thus, the incoming call is switched to the selected fax port.
  • the NAP "returns the Call Connected response to the Fax Server.
  • the Fax Server issues the Collect Digits command to the NAP as a timeout waiting to receive on-hook notification from the NIU. Collect Digits is set to specify 50 digits and a maximum timeout.
  • the incoming line to the NIU is now connected to FP which, like a fax machine, receives the data and then hangs up.
  • the NAP Upon receipt of the On-Hook, the NAP returns the Command Executed response to the
  • the Fax Server then checks the Fax Processor to determine the receive status by issuing a PortState FP command and receiving a return of the PortStatus response from the FP. Alternatively, the Fax Server can issue the WaitCompleted command to the FP after receiving Call Connected from the NAP and then await receipt of ReceiveDone from the FP. ReceiveDone provides notification when the fax receipt has been accomplished by the FP.
  • the Fax Server then issues a file transfer command to the Fax Processor to move the fax from the PC hard disk 181 to the A-Series disk 23. To accomplish this. the FS issues the ReceiveFile command to the FP which transfers the fax file to the FS issuing a FileXfered response.
  • the FS converts the file, if necessary, to A-Series format utilizing the file conversions 167 (Figur 5).
  • the FS stores the converted file in its temporary A-Series disk file 115 through the I/O processor 24 ( Figure 1).
  • the FS then transfers the temporarily stored A-Series disk file to the VMMM data base 40 and removes it from the FP hard disk 181. This is accomplished by the FS issuing the Create Voice Message command to NAP to store the converted file in the VMMM data base.
  • NAP responds to FS with the NAP Message Created response.
  • the FS then issues RemoveFile to the FP which responds with FileRemoved.
  • the FS issues the FP command Portlnitialize setting the RemoveFile flag.
  • the FS then notifies the application of the successful receipt of the fax and the new fax's Message Number. This is accomplished by the FS issuing the NAPFE Fax Received (Message Type 114) response through the COMS portion 130 ( Figure 3) back to the application.
  • the Fax Received response from the FS to the application consummates the Receive Fax command originally received by the FS from the application.
  • the Receive Fax command has a Recovery Token field that is used in the case of a system, COMS, NAP or application outage. During the recovery processing, to be described, the application uses this token to recover a fax that was in process at the time of an outage.
  • the Receive Fax command also includes a DB Numbe field for containing the NAP application number for the current application. The DB Number is utilized to uniquely identify the application's Recovery Tokens.
  • a standard NAP Terminate Dialog command issued by the application to NAP can close out the dialog. Send Fax (Message Type 24).
  • This command is sent by the application to the Fax Server 103 of NAPFE to request that the Fax Processor send a fax to a fax machine.
  • the connection associated with the specified Dialog ID is used for the fax transmission.
  • the command identifies the fax message or messages to be sent by Message Number utilizing the Message Number field 126 ( Figure 2).
  • the FS retrieves the message from VMMM and has it transferred to the FP hard disk. This is accomplished by the FS first issuing to NAP the NAP Get Voice Message command for each message to be sent and waiting for the response from NAP of Command Executed for each Get Voice Message issued.
  • the FS selects the FP port through which the fax transmission will occur.
  • the FS issues the FP SendFile command to the File Processor listing the file names of the files built by the NAP Get Voice Message commands.
  • the fax files obtained by FS from NAP VMMM are transferred to the FP hard disk for transmission.
  • FS converts the files, if necessary, from A-Series format into the appropriate format for transmission such as PC text.
  • the FS 103 utilizes File Conversions 167 ( Figure 5) to effect the conversion.
  • the FS then waits for the FileXfered response from the FP. If required, the FS 103 switches the incoming line at the NIU 19 from the VIM DLP 25 to the selected FP port.
  • the FS issuing the NAP Connect Call command to NAP and receiving the Call Connected response from NAP.
  • the NAPFE uses the Connect Call command to switch the existing connection to the specified FP port.
  • the FS then issues the FP command OriginateXmit to the FP specifying the phone number derived from the dialog specified in the NAPFE command.
  • the OriginateXmit command is sent to the FP port specified in the FP command.
  • the FS then waits for the TransmitDone command from the FP indicating that the fax has been sent.
  • the FS then removes the file from the FP hard disk.
  • two procedures may be utilized to remove the file from FP disk.
  • the FS issues the RemoveFile command to the FP naming the file and the FP responds to FS with FileRemoved.
  • FS can issue the Portlnitialize command to the FP setting the Removefile flag and receiving the Initialized respons from the FP after the file has been deleted.
  • the FS then issues the NAPFE Fax Sent (Message Type 115) response back to the application through the COMS portion 130 ( Figure 3) consummating the Send Fax command originally sent by the application.
  • the transmitted fax may be deleted from the NAP VMMM data base. This is accomplished by the application issuing the standard NAP command Delete Voice Message and receiving from NAP the corresponding NAP response Message Deleted.
  • a standard NAP Terminate Dialog command issued by the application to NAP can close out the dialog.
  • Poll and Receive Fax (Message Type 25).
  • This command is sent by the application to the FS of NAPFE to request that the FP poll a fax machine to determine if that machine has an outgoing fax pending. If the fax machine does have an outgoing fax, then the fax is received by the FP. The connection associated with the specified Dialog ID is used for the fax polling and the fax receipt. If required, the FS uses a Connect Call NAP command to switch the existing NIU connection to the appropriate fax port. The FS issues the FP comman OriginateRcv to the FP specifying the phone number of the fax machine to be polled, as derived from the current dialog. The FP returns the ReceiveDone response.
  • the FS then issues the ReceiveFile command to the FP for transferring the file from FP disk to the FS A-Series disk file.
  • the file is converted, if necessary, to the A-Series Fax Format by the File Conversions 167 ( Figure 5).
  • the FP returns the FileXfered response to the FS.
  • the FS then issues the NAP command Create Voice Message to the NAP to store the converted file in the VMMM data base 40 as described above with respect to Receive Fax (Message Type 23).
  • the FS then removes the file from the FP hard disk in the manner described above with respect to Receive Fax and thereafter issues the NAPFE response Fax Received back to the application consummating the original Poll and Receive Fax command.
  • the command includes Recovery Token and DB Number fields for the reasons discussed above with respect to Receive Fax.
  • the above operations of Poll and Receive Fax results in the FS having the FP dial-out, poll the designated fax machine and receive the fax.
  • the network connection may be effected by the NIU but the FP performs the dial-out procedure.
  • the fax is then stored in the VMMM data base and the application is notified of its Message Number.
  • a standard NAP Terminate Dialog command from the application can close out the sequence.
  • Send Fax after Poll (Message Type 26). This command is sent by the application to the FS of NAPFE to indicate that a fax machine will be polling the FP.
  • the specified fax is transmitted by the FP to the fax machine.
  • the connection associated with the specified Dialog ID is used for the poll reception and fax transmission.
  • the NAPFE uses the Connect Call NAP command to switch the existing connection to the FP. This NAPFE command results in a Fax Sent (Message Type 115) response.
  • the command includes a Message Numbers field 126 ( Figure 2) to specify which fax messages are to be processed.
  • the FS uses either the OriginateXmit FP command or the OrigXmitNIU FP command depending on the connection protocol utilized. Create Fax Message (Message Type 27).
  • This command sent from the application to the FS, informs NAPFE that a fax message is to be copied from a file and placed in the fax file maintained by NAP.
  • the command creates a NAP fax message from the contents of a specified A-Series disk file.
  • the FS converts the specified file to NAP VMMM format utilizing File Conversions 167 ( Figure 5).
  • the command includes a Fax File Name field 127 ( Figure 2) containing an A-Series file title which will be used to identify the file containing the fax message.
  • the command also includes the Recovery Token and DB Number fields for the reasons discussed above with respect to Receive Fax. This command is utilized to originate a fax without having a fax machine.
  • a file created on a main frame computer or on a PC can be sent as a fax.
  • the protocol of this command is utilized by the application to externally introduce such a file into the NAP system.
  • the data is stored in the VMMM data base and the application is notified of the new Message Number.
  • the FS converts the file and issues a NAP Create Voice Message command to NAP which transfers the file into the VMMM data base.
  • NAP responds to the FS with the NAP Message Created response and the FS issues the NAPFE Fax Created response back to the application.
  • Get Fax Message (Message Type 28).
  • This command informs NAPFE to copy the indicated fax message into the specified A-Series file for storage therein.
  • the command provides a way to store the fax other than in the VMMM data base.
  • the application can then manage the resultant file in the same manner as a normal A-Series disk file.
  • the application issues the command specifying the VMMM Message Number and the name of the A-Series disk file to contain the message.
  • the FS retrieves the fax from the VMMM data base and copies it into the specified A-Series file.
  • the Fax File Name field 127 ( Figure 2) contains an A-Series file title which will be used to create the file containing the fax message.
  • the command also includes Message Number field 126 ( Figure 2) which contains the Message Number representing the fax message to be placed in the specified disk file.
  • the FS issues the NAP Get Voice Message command to NAP specifying the Message Num er.
  • NAP returns the NAP Message Created response to FS.
  • FS converts the VMMM file to an appropriate format such as A-Series Fax Format thus creating the file specified in the Get Fax command.
  • FS then issues the NAPFE Fax Obtained response back to the application. Recover Fax Message (Message Type 29).
  • This NAPFE command sent from the application to FS is utilized by the application to initiate a fax recovery process to be described below.
  • Both the application and NAPFE maintain tables of Recovery Tokens.
  • the command is utilized by the application to recover any faxes that were received by the FP when an outage occurred.
  • the NAPFE searches its table for the Recovery Token specified in the command. If the token is found, a Fax Received (Message Type 114) response is returned to the application along with the associated fax Message Number.
  • a flag is set in NAPFE so that when the next NAP command is received (of any type), the entry is removed from the NAPFE recovery table.
  • the command includes the Recovery Token field 124 and the Data Base Number field 125 to uniquely identify the application's Recovery Tokens which identify fax receptions that were in process at the time of a system or application outage.
  • Send Fax from File Message (Message Type 30).
  • This command sent by the application to FS informs NAPFE that a fax message is to be copied from a file and then sent to a fax machine. The connection associated with the specified Dialog ID will be used for the fax transmission.
  • the command results in a Fax Sent (Message Type 115) response.
  • the FS utilizes a Connect Call NAP command to switch the existing connectio to the FP.
  • the command contains the Fax File Name field 127 containing the A-Series file title utilized to identify the file containing the fax message.
  • the NAPFE provides one of the following four responses for all NAPFE commands that execute properly.
  • the NAPFE responses are conceptually illustrated in Figure 5 at 165 as described above.
  • This response is generated by FS and returned to the application through the COMS portion 130 ( Figure 3) for any NAPFE command that receives a fax message.
  • the response includes the Message Number field 126 ( Figure 2) for containing the NAP Message Number of the received fax message.
  • the response also returns the results of the fax reception.
  • Fax Sent (Message Type 115). This response is generated by FS and returned to the application through the COMS portion 130 for any NAPFE command that transmits a fax message. The response returns the results of the fax transmission.
  • Fax Created (Message Type 116). This response is generated by FS and returned to the application through the COMS portion 130 for the NAPFE Create Fax (Message Type 27) command. The response indicates that a NAP fax message was successfully created from the contents of an external A-Series disk file. The response includes the Message Number field 126 ( Figure 2) for containing the Message Number of the created fax message.
  • Fax Obtained (Message Type 117). This response is generated by FS and returned to the application through the COMS portion 130 for the NAPFE Get Fax (Message Type 28) command. The response indicates that a NAP fax message was successfully retrieved and placed into an external A-Series disk file.
  • fax functionality is added to the NAP system of said S.N. 521,210 by the insertion of the COMS 101, as explained with respect to Figures 1 and 3, between the NAP 10 and the application 100 and the addition of the Fax Server 103 and Fax Processors 104.
  • a fax application is designed to run as a normal NAP application in that the application is coded to use the existing AIM specification, as described in said S.N. 521,210, to communicate with NAP 10.
  • COMS 101 and the Fax Server 103 adds the additional NAPFE command and responses to the existing AIM command/response set.
  • COMS 101 transmits all of the NAP and NAPFE commands and responses between the application and the platform as described above. It is further appreciated that the functions attributed herein to COMS 101 and the Fax Server 103 may be integrated into NAP (preferably into AIM 15) to perform the described functions.
  • the NAPFE commands and responses add additional functionality to permit the application to manage the transmission and reception of faxes in the manner that the standard NAP manages the transmission and reception of voice messages.
  • Faxes are stored within NAP in exactly the same way that voice messages are stored as described in said S.N. 521,210. All NAPFE commands reference faxes by Message Number just as NAP commands reference Voice Messages by Message Number.
  • a fax application can use several standard NAP message processing commands on fax messages. These commands are DELETE MESSAGE (Message Type 03) and GET MESSAGE NUMBERS (Message Type 12).
  • DELETE MESSAGE Message Type 03
  • GET MESSAGE NUMBERS Message Type 12
  • the application Prior to issuing a NAPFE command, the application can conduct a voice dialog with NAP over the connection. Because of the capabilities described in said S.N. 521,210 and the capabilities described herein, the NAP can switch the NIU 19 between voice and facsimile ports. Thus, all NAP and NAPFE commands and responses are available to the application through a common interface. In this way, the application can blend fax and voice functionality.
  • the FP 104 has the responsibility to physically send and receive faxes.
  • the NIU 19 switches incoming fax lines over to the FP so that the fax can be received.
  • Outgoing faxes are sent directly out over the CO lines 106 ( Figure 1) or through the NIU 19.
  • the FP hare " : disk drive 181 ( Figure 6 is used to stage the incoming and outgoing faxes.
  • the fax functions that NAP with NAPFE can invoke are: Receive Fax where the FP receives the fax over the current connection; Send Fax and Send Fax from File where the FP sends a fax over the current connection or over a newly originated connection; Poll and Receive Fax where the FP polls a fax machine over the current connection or over a newly originated connection to receive a fax; and Send Fax after Poll where the FP receives a poll over the current connection and then transmits the specified fax.
  • the application In response to detecting ring at an NIU port, the application receives an Incoming Call respons from NAP. In accordance with NAP protocol, the application then issues a Connect Call command to NAP. Optionally, a voice dialog can occur prior to the fax operation.
  • the signalling accompanying the incoming call identifies that a fax transaction is required. For example, if the call was transferred by the Central Office to the NAP from a busy fax machine, the Called Number Identification permits the NAP to determi that a fax application is involved from the application tables maintained in NAP.
  • the application issues an Initiate Call command followed by a Pivot Call command.
  • the application places the phone number for the outgoing call in the body of the Initiate Call command.
  • the call is out-dialed by the NAP and pivoted to an NIU port connected to an FP port.
  • the FP command issued as part of the NAPFE command, includes a code in the phone number field so that the fax port connects with the NIU port to which the call vc pivoted.
  • the Initiate Call and Pivot Call commands are intercepted by the trap 132 ( Figure 3) and the phone number for the outgoing call is transferred to the phone number field of the FP command that forms part of the NAPFE command.
  • the FP When the NAPFE command is issued including an FP command of OriginateRcv or OriginateXmit, the FP then out-dials the call. The above establishes a call associated with the current dialog.
  • the NAPFE command is issued, the requested fax action is performed utilizing the network connection associated with the Dialog ID in the command header. It is appreciated from the foregoing descriptions of the NAPFE commands, that a NAP Connect Call command is utilized to connect the existing call with the selected FP port. After the fax function is complete, the FP goes on-hook causing the connection to be terminated. The application then closes out the dialog with a Terminate Dialog command.
  • the described approach allows the application to have full control of the fax operations. Fax functions can be performed over any network connection that an application can establish using NAP.
  • the described design renders the NAPFE functionally independent of, and compatible with, NAP capabilities.
  • the .execution of NAPFE commands often requires that standard NAP commands be used as part of the program steps to perform the desired fax function.
  • a flag (not shown) is set for that Dialog ID to intercept the next response for that dialog and utiliz it to trigger execution of the remaining program steps.
  • an application has answered an incoming call to the NIU, it may be desirable for the application to transmit a fax over that connection.
  • the OriginateXmitNIU FP command and the WaitCompleted FP command are utilized.
  • the OriginateXmitNIU provides an immediate response to the Fax Services software.
  • the WaitCompleted command only responds when the selected fax port completes its current receive or transmit. Specifically, the NAP receives Ring Detect from the NIU incoming call and responds to the application with the unsolicited response Incoming Call. The application issues Connect Call to the NAP and the NAP responds to the application with Call Connected. A voice dialog may now occur between the application and NAP. After the voice dialog, the application issues the NAPFE comman Send Fax to the FS. The FS obtains the fax message by issuing the NAP command Get Voice Message to the NAP which responds to the FS with Command Executed. The FS transmits the fax obtained from NAP to the FP by issuing the FP command SendFile.
  • the FP When the file has been received by the FP, the FP responds to the FS with FileXfered.
  • the FS then commands the FP to dial-out to the NIU and transmit the fax thereto by issuing the FP command OrigXmitNIU.
  • the FP responds back to the FS with FaxPortReady.
  • the FS then issues Connect Call to the NAP which responds with Call Connected.
  • the FS then issues WaitCompleted to the FP which in response to detecting On-Hook from the NIU issues TransmitDone to the FS.
  • the FS then removes the file from the FP hard disk by issuing RemoveFile thereto which responds back to the FS with FileRemoved.
  • the FS then consummates the Send Fax command from the application by returning Fax Sent thereto.
  • the application may delete the message from the NAP data base by issuing the NAP command Delete Voice Message to the NAP which responds to the application with Message Deleted.
  • the dialog is closed out by the application by issuing Terminate Dialog to the NAP.
  • NAPFE it may also be desirable for NAPFE to be able to initiate a call through the NIU and to then transmit a fax over that outgoing connection.
  • a procedure for accomplishing this utilizes the trap 132 ( Figure 3).
  • the application issues Initiate Call to the FS which responds to the application with Call Connected.
  • the application issues a Pivot Call to the FS which responds to the application with Call Connected.
  • NAPFE traps the Initiate Call in the trap 132 and saves off the outgoing port specification.
  • NAPFE also traps the Pivot Call command.
  • the application then issues a Send Fax command to FS and NAPFE downloads the fax to the FP disk and has the fax port go off-hook. This is accomplished by FS issuing Get Voice Message to NAP which responds back to FS with Command Executed. FS then issues SendFile to FP which responds back to FS with FileXfered. FS then issues OriginateXmit to FP which goes off-hook to the NIU. NAPFE traps this Incoming Call in the trap 132 and issues a Connect Call using the saved outgoing port specification. This causes an outgoing call to the network and connects the fax port to the outgoing connection. Normal fax transmission then occurs.
  • NAP sends the unsolicited response Incoming Call to FS which responds to NAP with the Connect Call command. NAP responds back to the FS with Call Connected and the FS issues Collect Digits to the NAP as a time-out.
  • FP goes on-hook to the NIU
  • the NAP responds to FS with Command Executed, and FS sends the Terminate Dialog command to NAP for the new dialog.
  • the FP then responds to FS with TransmitDone and FS commands FP with RemoveFile.
  • FP responds to FS with FileRemoved.
  • the original Send Fax command from the application to FS is consummated by FS responding to the application with Fax Sent.
  • the fax may then be deleted from NAP by the application issuing Delete Voice Message thereto.
  • NAP responds to the application with Message Deleted and the application terminates the original dialog by issuing Terminate Dialogue to NAP.
  • AIM commands such as Connect Call and Pivot Call can be utilized to effect the appropriate connections between FP, NIU and the network.
  • AIM commands such as Connect Call and Pivot Call can be utilized to effect the appropriate connections between FP, NIU and the network.
  • the Initiate Call command is utilized followed by appropriate AIM call switching commands.
  • NAPFE commands utilize a predetermined outpulse rule that is detected by NAPFE to provide discrimination between fax and non-fax transactions.
  • the Fax For the purpose of appropriately routing fax messages and calls to appropriate NIU ports, NAPFE commands utilize a predetermined outpulse rule that is detected by NAPFE to provide discrimination between fax and non-fax transactions.
  • the Fax For the purpose of appropriately routing fax messages and calls to appropriate NIU ports, NAPFE commands utilize a predetermined outpulse rule that is detected by NAPFE to provide discrimination between fax and non-fax transactions.
  • the Fax the Fax
  • Processor 104 can connect directly with the Central Offic or with the network through the NIU 19.
  • the trap 132 can optionally be utilized, as described above.
  • call connectivity AIM commands such as Pivot Call
  • S.N. 521,210 may not provide precisely the switching functionality required for NAPFE commands.
  • the FP DLP 109 and the high-speed parallel link 108 comprise a commercially procurable A-Series computer to PC data transfer connection available, for example, from Express-Link, Inc., of Richmond, Virginia.
  • the FP DLP 109 is implemented by the Express-Link DLP and is a well known type of A-Series communication interface.
  • the FP DLP 109 appears to the A-Series system like a GCR tape DLP.
  • the FP operates independently from the A-Series host on which NAP and NAPFE are installed. Once an FP command is issued to receive a fax, the FP will, in the absence of a hardware failure or powerdown, receive the fax. The FP reception process confirms to the fax machine that the FP received the fax and has it stored on its hard disk.
  • NAPFE utilizes a recovery mechanism that guarantees fax reception.
  • the mechanism ensures that the application will be aware of all faxes received by the FP so that fax messages will not get lost.
  • the timing window results, for example, when a system or an application interrupt occurs between the time a fax is received on the FP disk and the time the fax Message Number is entered into the application data base.
  • the basis of the NAPFE guaranteed fax reception is the Recovery Token and the NAP application Data Base Number stored in fields 124 and 125 of the NAPFE command body 121, as illustrated in Figure 2.
  • the Recovery Token is specified on all commands where faxes are received or created.
  • the application assigns a new and unique Recovery Token to each Receive Fax, Poll and Receive
  • the Recovery Token combined with the application Data Base Number creates a unique ID for each fax reception. This unique ID is utilized by NAPFE to ensure the complete reception and archiving of all incoming faxes.
  • the recovery information is maintained in the Recovery Table 168 illustrated in Figure 5.
  • the Recovery Table 168 stores, inter alia, the application's NAP Data Base Number and the defined application Recovery Token.
  • the application also maintains a list of issued Recovery Tokens and information pertinent thereto.
  • the application places a new Recovery Token in its Recovery Token list for commands that have not been completed.
  • the application issues a desired NAPFE command specifying the associated Recovery Token.
  • ReceiveFile Message Type 92
  • FS records the associated Recovery Token and Data Base Number in the Recovery Table 168, as well as the associated FP port number.
  • the port number is in the field 152 of the FP command ( Figure 4B) .
  • the involved FP port remains Inuse and cannot be used for reception or transmission of further fax messages until cleared by, for example, Initialization.
  • the entry in the Recovery Table 168 uniquely identifies received faxes until reception and archiving is complete. Created faxes are alsp uniquely identified by the information in the Recovery Table 168 because of the manner in which the Create Fax Message protocol functions.
  • the associated entries in the application Recovery Token list and the Recovery Table 168 of NAPFE are deleted.
  • the recovery process involves the application issuing the NAPFE Recover Fax command for each token remaining on the application list with the entries from the application list and NAPFE Recovery Table 168 being deleted upon successful transfer of the fax.
  • the Recover Fax command is issued by the application, the FP is checked for faxes that were received but never moved to the VMMM. If such f xes are found, they are transferred utilizing the file transfer protocol discussed above with respect to the NAPFE Receive Fax command.
  • the recovered fax is successfully transferred and archived, the entry is removed from the Recovery Table.
  • NAPFE When a Receive Fax, Poll and Receive Fax or Create Fax command is issued to FS, the Recovery Table entry is allocated. After FS issues a Fax Received response (resulting from a Receive Fax, Poll and Receive Fax or Recovery Fax command), NAPFE considers the next received NAP or NAPFE command as a positive acknowledgment from the application that the application has saved the fax Message Number and information to disk and that the application has archived the data in VMMM. In response thereto, NAPFE clears the Recovery Token entry associated with the previous Fax Received response from the Recovery Table.
  • Recovery may be executed as part of application initialization.
  • the application performs the recovery processing as follows:
  • Fax Server 103 performs normal NAP message reconciliation utilizing the Get Message Numbers command as described in said S.N. 521,210 and S.N. 514,783. It is appreciated from the foregoing with respect to Figure 1 , that although the Fax Server 103 is illustrated as a separate block for convenience of description, the Fax Server 103 is part of NAP 10 and resides in main memory 18. FS 103 may be considered as an extension of AIM 15. The physical devices such as phone lines, switches or fax machines, as well as the actual voice or fax data, are not visible to the application. The application makes high level requests (Send Fax, Receive Fax) referencing the fax image by Message Number and referencing the destination by phone number or other appropriate identification such as subscriber ID. In this manner, the application concentrates on management of the faxes, as they flow through the system, and avoids the details of handling the hardware.
  • Send Fax, Receive Fax referencing the fax image by Message Number and referencing the destination by phone number or other appropriate identification such as
  • the above-described embodiment was explained in terms of utilizing file conversion with respect to file format in transferring files between the FP hard disk and the VMMM. It is appreciated that the fax messag data from a facsimile station can be received and stored in the VMMM message data base without conversion as, for example, a Group III image in accordance with the CCITT T.4 and T.30 recommendations. The stored message data can also be sent to a facsimile station by NAP without conversion. Thus, no conversion is required in the process of storage or retrieval of Group III compressed fax message data.
  • the Fax Processors 104 are integrated into the NAP architecture using the NIU 19 which provides the FP with interfaces to the network.
  • the NIU also provides the capability to switch between an incoming or outgoing telephone line and a facsimile or voice port. This allows the same call to carry voice prompts, DTMF responses, voice annotations, and facsimile messages.
  • NAP has been extended to send fax messages to a fax station, receive fax messages from a fax station, send fax messages to a polling fax station, and receive fax messages from a polled fax station. These commands can be used on a call that was either originated or answered by the ' system.
  • the NAP has been extended to support the transmission and reception of facsimile message documents. This was accomplished by adding the additional commands and responses described herein to those supported by NAP as disclosed in said NAPSNs.
  • the extensions allow an enhanced service on NAP that provides for the storage and retrieval of facsimile documents between a facsimile machine (Group III compliant, for example) and NAP.
  • the present invention allows NAP to provide facsimile messaging- services together with the voice messaging services described in said NAPSNs. Voice prompts, DTMF responses, voice storage and retrieval, and facsimile storage and retrieval are combined in a single service.
  • the FP can store the entire fax image prior to transmission to the network and can also store the entire fax image after reception from the network prior to sending it up to the VMMM. Initiating transmission to the network one page at a time after storage of several pages of a fax in FP is also contemplated within the scope of the present invention. It is further appreciated that if NAPFE is integrated into NAP, COMS will no longer be the agent that directs commands. AIM will then determine whether the incoming command is a fax or voice type command and will direct the command accordingly. While the invention has been described in its preferred embodiment, it is to be understood that the words which have been used are words of description rather than limitation and that changes may be made within the purview of the appended claims without departing from the true scope and spirit of the invention in its broader aspects.
  • the Interface 510 couples a Data Link (DL) 511 with a host computer system 5 generally indicated at 512.
  • the DL 511 is a communication link on which data of interest is sent/received and may be of any conventional form including one or more of the following: asynchronous or synchronous data stream, full/half/simplex connectivity and with or without - embedded protocol.
  • the host 512 includes an Instruction Processor (IP) 513 and a Central Data Storage (CDS) " 514.
  • IP 513 is a data processing entity, that performs tasks or applications utilizing data transferred over the DL 511.
  • the IP 513 schematically includes a set 515 of Data Transfer Commands (DTC) to be further described with respect to Figure 8.
  • the host 512 is illustrated running an application 516 that exercises ultimate control over the data transferred between the host 512 and the Data Link 511.
  • the application 516 i s responsive to external stimuli schematically represented at 517.
  • the stimuli 517 may comprise off-hook and busy or ring-no-answer with the telephone system central office switch connecting the calling party to the Data Link 511.
  • the application 516 may instruct the IP 513 to issue.-a -sequence of DTCs that will result in sending a voice prompt to the caller that the caller may leave a message at the tone, sending a tone over the DL 511 and receiving the voice message from the caller.
  • the Interface 510 includes a Command Queue (CQ) 520 that receives and stacks a sequence of DTCs issued from the IP 513.
  • An Interface Control Processor (ICP) 521 sequentially receives the queued DTCs from the CQ 520 as schematically represented at 522.
  • the CQ 520 is a FIFO queuing arrangement in which the IP 513 issues a sequence of DTCs that are executed by the ICP 521 individually without intervention of the IP 513.
  • the ICP 521 also receives a TERMINATE DTC directly from the IP 513 bypassing the CQ 520.
  • the TERMINATE DTC is received by the ICP 521 as schematically indicated at 523.
  • the ICP 521 issues Data Transfer Results (DTR) to the CDS 514 as schematically indicated at 524.
  • the IP 513 is appropriately notified when the ICP 521 issues the DTR to the CDS 514,
  • the ICP 521 issues a DTR corresponding to each of the DTC types; viz, SEND, GET, TAG and TERMINATE to be described below in further detail.
  • the ICP 521 also includes a buffering strategy control 525 to be further explained below.
  • the Interface 510 includes Interface Data Storage (IDS) 526 which comprises a data storage device where data to/from the DL 511 is buffered.
  • IDS Interface Data Storage
  • the IDS 526 ir ⁇ ludes receive buffers 527 for buffering data received from the DL 511 to be stored in the CDS 514 and transmit buffers 528 for buffering data to be sent from the CDS 514 to the DL 511.
  • the amount of storage provided by the receive buffers 527 and the transmit buffers 528 must be adequate to maintain a buffering strategy, as controlled by the buffering strategy control 525, between the CDS 514 and the IDS 526 which prevents starving the DL 511 when sending data or overrunning the IDS 526 when receiving data.
  • the Interface 510 further includes a Data Link Interface (DLI) 529- comprising an entity which provides interface capability between the DL 511 and the IDS 526.
  • the DLI 529 may include one or more of the following techniques: serial/parallel conversion, DL protocol, coding technique and electrical conversion.
  • the coding techniques may, for example, comprise Pulse Code Modulation (PCM) and the electrical conversion may comprise such techniques as digital-to-analog and analog-to-digital conversion.
  • PCM Pulse Code Modulation
  • the CDS 514 comprises a data storage device from which the IP 513 utilizes data received from the DL 511, generates data to be sent over the DL 511, or examines the DTR of DTCs issued to the ICP 521.
  • the ICP 521 comprises a control entity which receives, performs, and acknowledges DTCs from the IP 513; coordinates data transfer between the CDS 514 and the IDS 526; and performs data transfer between the DLI 529 and the IDS 526.
  • the CDS 514 and IDS 526 are responsive to the buffering strategy control 525 to effect data transfer coordination therebetween. '
  • the objective of data transfer to/from the CDS 51 over the DL 511 through the DTC interface 51 is accomplished through the use of DTCs issued from the IP 513 to the ICP 521.
  • the four commands of the DTC command set 515 (SET-TAG, SEND, GET, and TERMINATE) provide capability for the IP 513 to communicate over the DL 511 while remaining decoupled from the operating details of the DL 511.
  • All DTC except TERMINATE, are sent to the ICP 521 through the CQ 520. If the ICP 521 is not already executing a DTC, a DTC is transferred from the CQ 520 to the ICP 521. When the ICP 521 completes processing of any DTC, a Data Transfer Result (DTR) is issued and stored in the CDS 514 as status information which the IP 513 can examine after being notified. In this manner, the ICP 521 is sequentially and continuously processing single DTCs from the CQ 520 as long as DTCs remain in the CQ 520.
  • DTR Data Transfer Result
  • the TERMINATE DTC is not sent to the ICP 521 through the CQ 520. Instead, TERMINATE is sent directly from the IP 513 to the ICP 521 as an immediate command.
  • the ICP 521 continuously awaits the direct arrival of the TERMINATE DTC from the IP 513 notwithstanding concurrent execution of a DTC from the CQ 520.
  • the functions of TERMINATE, to be described below, are performed immediately with processing of a DTC issued from the CQ 520 being suspended, a DTR for the TERMINATE command being returned to the CDS 514 and the IP 513 being notified.
  • the DTC set 515 is comprised of SEND, GET, SET-TAG, and TERMINATE. Referring to Figur 8, the formats of the DTCs are illustrated.
  • Each of the DTCs has an op code field 540 and parameter fields 541 that contain the parameters associated with the command.
  • the SEND DTC transfers data stored in the CDS 514 to the DL 511.
  • the SEND DTC has four associated parameters: LINK, TAG, LAST, and RECEIVE.
  • the LINK parameter provides information to the ICP 521 on appropriate use of the CDS 51 .
  • the LINK parameter may contain a CDS pointer providing an address in the CDS 514 at which information may be found, such as the address in the CDS 514 of the data to be sent, the amount of the data to be sent, and the address in the CDS 514 for storing the DTR.
  • the Link parameter itself may contain the information.
  • the TAG parameter provides information to the ICP 521 with respect to grouping separate DTC operations into logical entities.
  • the LAST parameter which is boolean, informs the ICP 521 that the data associated with the current SEND DTC completes transmission activity to the DL 511.
  • the RECEIVE parameter which is boolean, directs the ICP 521 to begin receiving data from the DL 511 after the data associated with the current SEND DTC completes transmission to the DL 511.
  • the transmit buffers 528 in the IDS 526 will be maintained as full as possible according to a buffering strategy, to be described below, between the CDS 514 and the IDS 526 as controlled by the buffering strategy control 525. Maintaining the IDS transmission buffers 528 full allows the IDS bufferin to absorb latency anticipated in implementing the buffering strategy. To avoid transmission underrun, the buffering strategy must be able to absorb anticipated latency and sustain an average transmission rate equivalent to the transmission rate of the DL 511.
  • a SEND DTR from the DTR block 524 is issued by the ICP 521 while the buffered data continues to be sent over the DL 511. This allows for the next SEND DTC in the CQ 520 to be processed by the ICP 521 so as to continue transmitting data over the DL 511 without interruption.
  • the operation of a SEND DTC in progress can be modified by a TERMINATE DTC or an internal terminating condition, such as DL protocol, in a manner to be described in further detail below.
  • the GET DTC transfers to the CDS 514 receive data buffered from the DL 511 in the receive buffers 527 of the IDS 526. Reception is only initiated as the result of the RECEIVE parameter of a previous SEND DTC being set to TRUE.
  • the GET DTC has three associated parameters: LINK, TAG, and LAST.
  • the LINK parameter provides information to the ICP 521 on appropriate use of the CDS 514.
  • the LINK parameter may contain a CDS pointer to a location in the CDC 514 containing such information as the address in the CDS 514 of the locationo to store the receive data, the maximum amount of data to store, and the address for storing the DTR.
  • the LINK parameter itself may contain the information.
  • the TAG parameter provides information to the ICP 521 with respect to grouping separate DTC operations into logical entities.
  • the LAST parameter which is boolean, directs the ICP 521. that DL reception and buffering must conclude with the current GET DTC.
  • the receive buffers 527 in the IDS 526 will be maintained as empty as possible according to the buffering strategy between the CDS 514 and the IDS 526 to be further described below.
  • the buffering strategy is controlled by the buffering strategy control 525. Maintaining the receive buffers 527 of the IDS 526 as empty as possible, allows the IDS buffering to absorb latency anticipated in implementing the buffering strategy. To avoid receiv buffer overrun, the buffering strategy must absorb anticipated latency and sustain an average transfer rate equivalent to the DL reception rate.
  • a GET DTR is issued from the DTR block 524 of the ICP 521 and receive data continues to be buffered from the DL 511. This allows for additional buffered data to be received from the DL 511 by the next GET DTC in the CQ 520 without interruption.
  • a GET completes the transfer of associated data from the IDS 526 and the LAST parameter is TRUE
  • receiving buffering is stopped (if not already stopped by TERMINATE) and a DTR is issued.
  • the DTR includes the additional status information that the receive operation was completed by the LAST parameter.
  • a RECEIVE operation in progress can be modified by a TERMINATE DTC or an internal terminating condition, such as DL protocol, in a manner to be described below.
  • the SET-TAG DTC establishes a working TAG identifier for a following sequence or group of SEND and GET DTCs.
  • the SET-TAG DTC has two associated parameters: LINK and TAG.
  • the LINK parameter provides information to the ICP 521 with respect to appropriate use of the CDS 514.
  • the LINK parameter could include such information (or a pointer to such information) as the address for storing the DTR.
  • the TAG parameter indicates the specific working TAG identifier associated with the SEND and GET DTCs that follow the SET-TAG DTC.
  • the TERMINATE DTC causes the ICP 521 to possibly modify the behavior of the currently processing SEND DTC or data reception operation.
  • the TERMINATE DTC has two associated parameters: LINK and TAG.
  • the LINK parameter provides information to the ICP 521 with respect to the appropriate use of the CDS 514-.
  • the LINK parameter could include such information (or a pointer to such information) as the address for storing the DTR.
  • the TAG parameter indicates the specific group of DTCs that the TERMINATE DTC should address.
  • the TERMINATE DTR is issued by the ICP 521 from the block 524.
  • the SEND DTR is issued.
  • Status informatio in the SEND DTR can include information regarding the state of transmission such as the amount of data transmitted and the termination reason.
  • the status information in the DTR indicates this condition. If a data reception operation is currently in progress by the ICP 521 and the working TAG does not match the TAG parameter of the TERMINATE, the TERMINATE DTR is issued.
  • DTC(s) This operation is referred to as a receive buffer purge.
  • a DTMF digit entered by a caller over the DL 511 may be recognized by the ICP 521 as requiring immediate termination of voice data transmission.
  • Actions executed in response to internal termination conditions are exactly equivalent to those that are performed for a TERMINATE DTC with a TAG value equal to the DTC currently being executed, except that no TERMINATE DTR is issued.
  • the receive buffers 527 and transmit buffers 528 each comprises a set of individually actuatable buffers.
  • the buffering strategy control 525 prefetches the number of bytes of SEND data to fill the transmit buffers 528 or the number of the bytes of available SEND data, whichever is less.
  • the buffering strategy control 525 rotates the buffers such that the next buffer becomes the current buffer.
  • the buffering strategy control 525 After a predetermined number of buffers are empty, the buffering strategy control 525 connects the IDS 526 to the CDS 514 to fetch further data to refill the emptied buffers. When receiving data, with respect to RECEIVE, after the current receive buffer is filled, buffer rotation occurs and the next receive buffer becomes the current buffer. After a predetermined number of buffers are filled, the buffering strategy control 525 controls the IDS 526 to send the data to the CDS 514, rendering the filled receive buffers empty and again available.
  • the example comprises a voice messaging scheme where data transmitted and received over the DL 511 is a full duplex PCM representation of the voice band signals.
  • the IP 513 maintains a data base of voice storage wholly or partially in the CDS 51 and generates DTCs to control the playback from and recording to this data base.
  • the following scenario details a series of events whereby a voice prompt is played out and a message is recorded: )
  • the following DTC are queued into the CQ by the IP for processing:
  • This SET-TAG establishes the beginning of a group of SEND DTC which transmits the voice prompt data for recording a message.
  • This SEND transmits the second portion of the voice prompt: "state message after the tone, when finished with your”.
  • This SEND transmits this third portion of the voice pro ⁇ pt: "message please press pound key.”
  • This SET-TAG establishes the beginning of a group of DTC which transmits a tone, initiates recording, and receives the recorded voice data.
  • This SEND corresponds to the prompt tone: "beep”, and the initiation of receiving voice data for recording.
  • This GET returns the first portion of received voice data .
  • This GET returns the second portion of received voice data.
  • This GET returns the third portion of received voice data.
  • This SET-TAG establishes the beginning of a group of DTC which transmits a final concluding prompt.
  • the ICP recognizes that the CQ is no longer empty, dequeues the first DTC, SET-TAG. This DTC establishes a new working tag, "1", for DTC processing. The ICP then returns a ETR for link "a".
  • the ICP dequeues the next ETC, SEND.
  • the ETC fills the IDS transmit data buffers with data from the CDS to be transmitted.
  • the transmission of data over the DL is started.
  • ICP then returns a DTR for link "b" and continues to transfer data from the IDS over the DL. 5 4) The ICP dequeues the next DTC, SEND. The DTC continues to keep the IDS transmit data buffers filled with additional data to be transmitted.
  • the ICP detects the DTMF digit as a DL protocol event and initiates "internal termination” actions.
  • the transmission of the data buffered in the IDS over the DL is stopped and data buffered in the IDS is discarded.
  • the DTR, link "c" is returned for the current SEND.
  • the ICP dequeues the next DTC, SEND. Because the TAG matches the working tag "1" an immediate DTR is returned for link "d" without any transmission.
  • the ICP dequeues the next DTC, SET-TAG. This DTC establishes a new working tag, "2", for DTC processing. The ICP then returns a DTR for link "e".
  • the ICP dequeues the next DTC, SEND.
  • the DTC then fills the IDS transmit data buffers with data from the CDS to be transmitted.
  • the transmission of the data over the DL is started.
  • additional data from the CDS is transferred to the IDS keeping the transmit buffers of the IDS as full as possible.
  • IAST EALSE
  • the ICP returns a DTR for link "h". 5 11
  • the ICP dequeues the next ETC, GET. As the recording continues, additional IDS buffers are enptied to the CDS.
  • the ICP detects the "#" DTMF digit as a DL protocol event
  • the ICP dequeues the next ETC, SET-TAG. This ETC establishes a new working tag, "3", for ETC processing. The ICP then returns a ETR for link "k".
  • the ICP dequeues the next DTC, SEND.
  • the DTC fills the IDS transmit data buffers with data from the CDS to be transmitted.
  • the transmission of data over the DL is started.
  • additional data from the CDS is transferred to the IDS keeping the transmit buffers of the 25 IDS as full as possible.
  • the CQ now e ⁇ pty the ICP awaits new DTC to arrive.
  • the SET-TAG DTC can be eliminated and incorporated as an additional parameter to the SEND DTC.
  • the SET-TAG function is performed by any means for grouping the queued DTCs into 35 logical or related sequences of commands .
  • the invention provides an abstract interface between the computer system and the DL. This abstraction places the burden of interface details on the ICP/IDS/DLI implementation. This permits IP software to be structured around this high level abstract interface, providing software which is easier to develop and maintain. Additionally, the ICP/IDS/DLI implementation provides the capability of distributing DL oriented processing into elements that operate in parallel with the computer system. This is very significant when multiple DLs are utilized.

Abstract

Plate-forme d'applications de réseau téléphonique (NAP) (10) améliorée de manière qu'elle puisse prendre en charge les messages télécopiés ainsi que les messages vocaux, grâce à l'apport d'une fonctionnalité de télécopie (103, 104) pouvant être actionnée par des commandes de télécopie de haut niveau (160) provenant d'applications prises en charge par la plate-forme. Les commandes comprennent l'envoi et la réception de messages télécopiés. Un processeur de télécopie PC (FP) (104) constituant l'interface entre la plate-forme et le réseau téléphonique (12) stocke sur un disque dur (181) les messages télécopiés reçus en provenance du réseau et les messages télécopiés à transmettre vers le réseau. Une commande de télécopie (160) provenant d'une application est étendue de manière à obtenir des commandes NAP (162) servant à commander la plate-forme, et des commandes FP (161) servant à commander le processeur de télécopie afin d'exécuter la fonctionnalité de télécopie associée à la commande de télécopie. Un processus de récupération utilisant un jeton de récupération empêche les messages télécopiés de s'égarer entre leur réception au niveau du FP et leur stockage dans la plate-forme.Telephone Network Applications Platform (NAP) (10) enhanced to support fax messages as well as voice messages by providing fax functionality (103, 104) operable by high level fax commands (160) from applications supported by the platform. The commands include sending and receiving fax messages. A PC facsimile processor (FP) (104) constituting the interface between the platform and the telephone network (12) stores on a hard disk (181) the facsimile messages received from the network and the facsimile messages to be transmitted to the network. A facsimile command (160) from an application is extended to obtain NAP commands (162) for controlling the platform, and FP commands (161) for controlling the facsimile processor to execute the fax functionality associated with the fax command. A recovery process using a recovery token prevents faxed messages from straying between their receipt at the FP and their storage in the platform.

Description

TELEPHONE NETWORK APPLICATION PLATFORM FOR SUPPORTING FACSIMILE APPLICATIONS
PREFACE
References in this Description to S.N. 521,210 are published in U.S. Patent 5,133,004 issued July 21, 1992. References in this Description to S.N. 514,783 are published in U.S. Patent 5,138,710 issued August 11, 1992.
References in this Description to S.N. 503,195 are attached hereto as APPENDIX I.
BACKGROUND OF INVENTION
1. Field of the Invention
The invention relates to providing facsimile (fax) services over the telephone network via application software for such services and involves a telephone network digital computer platform for supporting such application software. 2. Description of the Prior Art
The facsimile machine has become ubiquitous in present day communication for transmission of documents. Facsimile transmission over the Public Switched Telecommunications Network (PSTN) annually generates billions of dollars in toll revenues. A variety of facsimile related services and enhanced services are currently available, such as Call Answer, Fax Store and Forward, Fax Mailbox, and the like. Generally, such services are provided by dedicated systems specifically designed for the service and for the hardware environment in which the system will be deployed. Such systems tend to lack flexibility, in that desired changes in functionality often require extensive, and hence expensive, modifications to the application software. Additionally, application software for providing such services are not portable in that a change in hardware environment usually requires substantial application software re-writing. Although such systems are usually computer based, such systems can only perform the functions for which they were designed and, thus, cannot also be utilized to perform general purpose data processing. Also, such systems generally do not have access to data bases stored on general purpose computers. Additionally, if it is desired to provide a wide variety of services, utilization of a large number of dedicated systems tends to be prohibitively expensive.
Since the divestiture, the Bell Operating Companies (BOCs) and Independent Telephone Companies (Telcos) have been seeking ways to increase the return on their primary asset; viz, the installed network. One source of increased revenue would be to offer new facsimile related services that integrate into, or interface with the existing network, resulting in greater utilization thereof. It is generally difficult for BOCs and Telcos to provide new services because network switches are designed to switch calls, not support data base or special service related functionality. Each Central Office (CO) utilizes a predetermined set of functions provided by the switch manufacturer. Only the manufacturer could add new services to the switching system which usually involves substantial lead times, such as two years or more. Additionally, the switch manufacturers have been particularly slow in responding to the needs of the BOCs and Telcos for enhanced service provisioning. A major limiting factor to providing new facsimile related services is a dependence on the telephone switch provider for implementing the capabilities required by these new services.
In addition to the above disadvantages, it is believed that currently available facsimile service systems do not have the capability of sending and receiving facsimile transmissions over a currently established voice connection. Present day systems are believed to terminate a voice connection and then re-dial a fax machine for the facsimile transmission. It is furthermore believed that present day systems do not have the capability of common storage of voice and fax images in the same data base. Separate facilities are believed to be required. It is furthermore believed that present day facsimile systems effect fax transmissions in an inefficient interactive mode utilizin flow control such as transmitting one page at a time.
Although the system of said S.N. 521,210 overcome the disadvantages described above with respect to voice communication, the advantages realized by the platform of said S.N. 521,210 for voice has not, prior to the present invention, been achieved for fax.
SUMMARY OF THE INVENTION
The present invention overcomes the above-described disadvantages of the prior art by providing, for the first time, a Telephone Network Applications Platform that interfaces with the telephone network and supports facsimile oriented application software that provides facsimile oriented services. The present invention is an enhancement and extension of the Telephone Network Applications Platform disclosed in said S.N. 521,210. The NAP interfaces between the telephone network and a facsimile application program and comprises a digital computer programmed to perform facsimile oriented telephone network f ctionality in response to -facsimile oriented com anάε issued by the facsimile application program. The facsimile oriented telephone network functionality resides in the computer independent of the facsimile application program and is actuatable in response to the commands. The commands include a Send Fax command and a Receive Fax command, the telephone network facsimile functionality including sending a facsimile message to the network and receiving a facsimile message from the network in response to the Send Fax command and the Receive Fax command, respectively. An application interface coupled between the facsimile application program and the computer responds to the commands from the application for actuating the telephone network facsimile functionality in response to and in accordance with the commands. The application interface is responsive to the Send Fax command and the Receive Fax command from the application for activating the telephone network facsimile functionality by causing a facsimile message to be sent to the network and causing a facsimile message to be received from the network in response to the Send Fax command and the Receive Fax command, respectively. A network facsimile interface coupled between the network and the computer conveys the facsimile messages therebetween.
As described in said S.N. 521,210, the NAP includes a data base and voice file for storing voice messages. The fax messages are also stored in the voice file and managed by the data base. The computer also includes the telephone network functionality relating to voice messages and call connectivity actuatable by AIM commands as described in said S.N. 521,210. The network facsimile interface preferably includes a Fax Processor for accepting facsimile messages from and delivering facsimile message to the network. The facsimile extensions of NAP preferably include a Fax Server for interpreting and expanding the facsimile commands into FP coiiimands for controlling the Fax Proc ssor and into AIM commands for performing the NAP functionality required to execute the facsimile commands In the preferred embodiment, communication means interposed between the application and the application interface directs AIM commands to NAP to be executed i'- the manner described in said S.N. 521,210 and facsimi commands to the Fax Server for execution. Alternatively, the Fax Server and communication means can be integrated into NAP with AIM commands and facsimile commands appropriately directed and executed. Additionally, a recovery process is utilized with respect to a Recovery Token for assuring that no faxes are lost between receipt at the FP and entry into the NAP storage file.
BRIEF DESCRIPTION OF THE DRAWINGS
Figure 1 is a schematic block diagram illustrati the overall architecture of the NAP with Fax Extensions (NAPFE) in accordance with the present invention and the environment in which the NAPFE is deployed. Figure 2 is a diagram illustrating the format of the NAPFE command and response common header utilized within the NAPFE of Figure 1. The command body is. also illustrated.
Figure 3 is a schematic block diagram illustrati functional details of the COMS interface of the NAPFE of Figure 1.
Figure 4A is a diagram illustrating the format of the FS to FP command.
Figure 4B is a diagram illustrating the format of the FP file transfer command.
Figure 5 is a schematic block diagram illustrating functional details of the Fax Server (FS) of the NAPFE of Figure 1.
Figure 6 is a schematic block diagram illustrating functional details of the Fax Processor (FP) of the NAPFE of Figure 1.
Figure 7 is a schematic block diagram which describes the Voice Interface Module (VIM) protocol.
Figure 8 is a diagram illustrating the formats of the commands of the Data Transfer Command Set.
DESCRIPTION OF THE PREFERRED EMBODIMENT Referring to Figure 1, a NAP 10 and disk system 23 is illustrated with the NAPFE components utilized to extend the NAP 10 to provide facsimile oriented functionality. Reference numerals below 100 refer to NAP and reference numerals above 100 refer to NAPFE. The NAP 10 with the disk system "23 is preferably implemented on an A-Series digital computer system commercially available from Unisys Corporation of Blue Bell, Pennsylvania, and is described in detail in said NAPSNs. The NAP 10 will be briefly described herein for continuity.
Zhe NAP 10 interfaces between telephone network application programs 00 and a telephone network 12. The applications 100 may comprise voice oriented programs that are managed by the NAP 10 in the manner described in said NAPSNs, facsimile oriented applications, and a coabination of voice and facsimile. The applications 100 communicate with the NAP 10 through message passing communication apparatus 101 such as the A-Series COMS. As described in said S.N. 521,210, the NAP 10 is comprised of an AIM 15, a VMMM 16, an NIUM 17, and NIUs 19. The applications 100 communicate with the AIM 15 via dialogs comprising sequences of NAP commands and responses. NAP protocol requires that the commands and responses occur in pairs with a response returned by the AIM 15 to the application for each command issued by the application to the AIM 15. In the manner described with respect to S.N. 521,210, the COMS 101 directs NAP commands received from an application 100 to the AIM 15 along a path 13 and receives NAP responses from the AIM 15 along the path 13. In a manner to be described with respect to the present invention, the COMS 101 conceptually intercepts NAPFE commands from the applications 100 and sends the NAPFE commands along a path 102 to a Fax Server (FS) 103 for interpretatio and processing. NAPFE responses returned to the Fax
Server 103 in response to a NAPFE command are transmitted back to the applications 100 through COMS 101 via the ' path 102.
All of the AIM protocols described in said S.N. 521,210 with respect to dialogs, commands and responses apply to the NAPFE of the present invention. Thus, communication is via the exchange of command and response messages. For every command, there will be only one response. The applications 100 cannot spontaneously generate a command. The applications 100 can only issue a command after receipt of a response from NAP or NAPFE. After issuing a command, the applications 100 wait until a response is received before issuing another command. The NAPFE of the present invention includes a plurality of Fax Processors (FP) 104 which are utilized for delivering facsimile messages to the network 12 and for receiving facsimile messages therefrom via ports 105. The facsimile communication between the Fax Processors 104 and the network can be direct to a Central Office 27, via a link 106, or via the NIU 19 through NIU ports 20. Each Fax Processor 104 performs all of the functions associated with sending and receiving facsimile messages in accordance with present day facsimile messaging protocol. For example, the Fax Processors 104 are compatible with Group III CCITT specifications T.4, T.30, and V.29. The Fax Processors 104 communicate with the Fax Server 103 through ports 113 via a path 107 and a high-speed parallel link 108 through Fax Processor Data Link Processors (FP DLP) 109. Each Fax Processor 104 communicates with the Fax Server 103 via a respective FP DLP 109. As described above, a fax command from an application 100 is transmitted by COMS 101 along the path 102 to the Fax Server 103. The Fax Server 103 interprets each fax command as a sequence of FP commands for the Fax Processors 104 and normal NAP AIM commands to be processed by the NAP 10. The FP commands are issu to the Fax Processors 104 via the path 107, the FP DLP 1 and the high-speed link 108. The Fax Processors 104 return FP responses to the Fax Server 103 via the path comprising the components 107, 108 and 109. Facsimile data is also communicated between the Fax Processors 104 and the Fax Server 103 via this path. The NAP AIM commands that form part of the fax commands are transmitted by the Fax Server 103 to the AIM 15 through the COMS 101 via a path 110. Concomitant NAP responses are returned to the Fax Server 103 through the COMS 101 via the path 110.
In operation, COMS 101 intercepts the NAP and NAPFE commands from the applications 100 and the FS 103 and the responses from AIM 15 and FS 103 and calls a processing item (from FS 103), functionally illustrated in Figure 3, to appropriately direct the messages. The NAP AIM commands from the applications and the NAP AIM con nds used in NAPFE processing are forwarded to the AIM 15. The NAPFE commands from the applications are processed by FS 103. Responses resulting from NAP AIM commands from an application 100 are returned to the application. Responses resulting from NAP AIM commands used in NAPFE processing are returned to FS 103.
The Fax Server 103 maintains temporary storage files 115 on the disk system 23 through the A-Series
I/O processor 24. Fax data is written to and read from this file by the Fax Server 103 via a path 111 utilizing standard A-Series file access mechanisms. Additionally, other A-Series files 50, such as application files, are maintained on the disk system 23.
As described in said S.N. 521,210 and said S.N. 514,783, the VMMM 16 under direction of the AIM 15 maintains a data base voice file 40 on the disk system 23 for storing voice messages that are received from and sent to the network 12. The NAP 10 assigns a unique Message Number (MN) to ecich voice message in the file. In a manner to be later described, fζ.ι. messages that are received from and transmitted by the Fax Processors 104 are also maintained in the NAP data base file 40. The NAP 10 also assigns unique MNs to the fax messages stored in the NAP data base 40 on the disk system 23. The AIM 15 controls the switching of the ports 20 of the NIU 19 through the NIUM 17 and manages the call signalling, as described in said S.N. 521,210. Furthermore, as described in said NAPSNs, the VIM DLPs 25 manage the communication of voice messages to and from the network 12 through the NIUs 19 under control of commands from the voice channel command queue 26 as described in further detail in said S.N. 503,195.
As described in said S.N. 521,210, the NAP 10 is programmed with telephone network functionality invoked by AIM commands from the applications. These commands include DELETE VOICE MESSAGE, CONNECT CALL, TERMINATE DIALOG , COLLECT DIGITS, INITIATE CALL, TERMINATE CALL, GET MESSAGE NUMBERS, GET VOICE MESSAGE, CREATE VOICE MESSAGE, and PIVOT CALL. The details of these commands and the invoked functionality are set forth in said S.N. 521,210. Briefly, the DELETE VOICE MESSAGE command deletes a named message from the NAP data base. The CONNECT CALL command switches the incoming NIU port of the call from the current outgoing port to a new outgoing port. The TERMINATE DIALOG command terminates the dialog represented by the dialog ID. With respect to the COLLECT DIGITS command, it is appreciated that NAPFE does not process digits. The command is utilized by NAPFE as a time-out. The INITIATE CALL command initiates a call to the network. The TERMINATE CALL command terminates a call. The GET MESSAGE NUMBERS command causes the NAP 1 to provide to the application all of the Message Numbers of the messages stored in the NAP data base file that are associated with the application. This command is used for message reconciliation as described in said S.N.. 521,210 and said S.N. 514,783. The GET VOICE MESSAG command controls the NAP 10 to place the d&t-.. of & named message in the NAP data base file into a named A-Series disk file. The CREATE VOICE MESSAGE command copies a message from a named A-Series file into the NAP data base file. The PIVOT CALL command changes the outgoing NIU port to an incoming port and establishes a new outgoing port.
The Fax Processors 104 send to and receive from the network fax messages over a currently existing connection upon receipt of a NAPFE command. In order to establish such connections, the applications 100 utilize the following AIM commands: CONNECT CALL, INITIAT CALL, and PIVOT CALL. The NAPFE utilizes the following AIM commands as part of the NAPFE commands: CONNECT CALL, COLLECT DIGITS, GET VOICE MESSAGE, and CREATE VOICE MESSAGE. The COLLECT DIGITS command is utilized as a time-out to get an on-hook notification from the NIU 20, in a manner to be described. The GET VOICE MESSAGE and CREATE VOICE MESSAGE commands are utilized by the Fax Server 103 to transfer fax messages between the Fax Processors 104 and the NAP data base message file in a manner to be explained.
The NAP 10 establishes a platform to provide basic voice management services to an application. NAPFE provides a similar set of fax management services by the addition of elements 102-111 and the modification of COMS 101 to direct fax commands to the Fax Server 103. The Fax Server 103 adds a set of fax oriented commands to the AIM command set of the AIM 15 thereby providing extensions to the AIM command set. NAPFE performs four basic facsimile oriented functions as follows:
Answer and Receive a Fax. This function is basic to facsimile machines. NAPFE will answer an incoming call and receive a fax message. The call may be answered directly or a voice dialog first performed.
Answer and Send a Fax. NAPFE supports the capability of answering an incoming call and transmitting a fax at the originator's request. In a fax mail application, after a voice dialog, the subscriber can request that the existing connection be used to send a fax to the subscriber's fax machine. This function can also be used during polling where a fax machine polls NAPFE over the network to receive a fax therefrom.
Originate and Send a Fax. This basic fax machine function involves the fax application dialing out over a telephone line, connecting to a remote fax machine and transmitting a fax image thereto. Originate and Receive a Fax. This function is utilized when NAPFE polls a remote fax machine to receive faxes that reside thereat for pick-up. Referring to Figure 2, the NAPFE command and response have a common header, the format of which is illustrated at 120. The command and response body is also depicted at 121. The header 120 includes a Message Type field 122 for containing a numerical representation of the command or response type. A Dialog ID field 123 identifies the NAP or NAPFE dialog with which the command or response is associated. The header 120 is substantially the same as the AIM command and response common header described in said S.N. 521,210. The body 121 of the command or response includes any or all of the following: a Recovery Token field 124, a Data Base Number field 125, a Message Number field 126 and a Fax File Name field 127 for conveying a Recovery Token, a Data Base Number, one or more NAP Message Numbers (MN), and an A-Series file title, respectively. The Recovery Token is utilized in a recovery process, to be described, to receive potentially lost faxes. The Data Base Number identifies the application associated with the command or response. Each NAP and NAPFE application has a unique Data Base Numb r assigned by NAP. The MN identifies fax message(s) involved in the command or response. The Fax File Name identifies a file containing a fax message.
Referring to Figure 3, functional details of the COMS 101 are illustrated. The COMS 101 utilizes NAPFE processing item comprised of a Fax Commands and Responses block 130 and a NAP Commands and Responses block 131. Standard NAP commands from the applications 100 are directed by the block 131 to the AIM 15 along the path 13. Similarly, standard NAP commands that form part of the fax commands are also transmitted by the block 131 from the path 110 to the AIM 15 via the path 13.
The fax commands intercepted by the block 130 are transmitted to the Fax Server 103 along the path 102. All standard NAP commands and responses and all fax commands and responses have unique Message Type numbers stored in the field 122 of the command header (Figure 2). The blocks 130 and 131 direct the commands from the applications 100 either to the Fax Server 03 or to AIM 1 on the basis of the Message Type numbers.
Fax responses received at the block 130 from the Fax Server 103 along the path 102 are transmitted back to the applications 100. AIM responses received at the block 131 from AIM 15 along the path 13 that belon to non-fax dialogs are transmitted back to the applications 100 in the manner described in said S.N. 521,210. AIM responses received at the block 131 along the path 13 that belong to fax dialogs are transmitted back to the Fax Server 103 along the path 110. The separation between fax and non-fax responses is based on the unique Message Type numbers or on the dialog ID stored in the fields 122 or 123, respectively, of the response headers (Figure 2). A dialog table (not shown) maintained by NAPFE (Fax Server 103), and available to COMS 101, identifies the fax and non-fax dialogs.
It is appreciated from the foregoing, that h Fax Server 103 appears as an application to the AIM ';._> communicating therewith through the COMS portion 131 utilizing the standard AIM protocols described herein and in said S.N. 521,210. The COMS 101 also includes a command trap 132 for reasons to be explained. As discussed above, the Fax Server 103 sends Fax Processor (FP) commands to the Fax Processors 104 and receives FP responses therefrom. The FP commands are of two types; viz., FP commands for sending and receiving faxes and FP commands for file transfers between the Fax Processors 104 and NAP disk. Referring to Figure 4A, the format of the FP command and response involved in fax communication is illustrated. A Message Type field 140 designates the type of command or response. An FP number field 141 designates the Fax Processor selected in the dialog. A port number field 142 designates the FP port selected in the dialog. A fax name field 143 identifies the files with which the command is involved and a phone number field 144 designates a phone number to be out-dialed by the Fax Processor in performance of the command.
Referring to Figure 4B, the format of the FP file transfer command and response is illustrated.. A Message Type field 150 designates the command or response type. A fax name field 151 identifies the fax files with which the command or response is involved and a port number field 152 denotes the FP port with which the file transfer is associated. Referring to Figure 5, with continued reference to Figure 1, functional details of the Fax Server (FS) 1 are illustrated. A fax command set 160 is conceptually illustrated as comprising FP commands 161 and AIM commands 162. The fax commands are received from the applications 100 through the COMS portion 130 along the path 102. As previously described, the FP commands 161 are transmitted along the path 107 to the Fax Processors 104 via the FP DLP 109. FP responses from the Fax Processors 104 ar«? received at the FS 103 along the path 107 as conceptually indicated at, 163. The FP responses are utilized by the FS 103 in performing the steps and commands comprising each fax command in the fax command set 160. The AIM commands 162 are transmitted to AIM 15 (Figure 1 ) through the COMS portion 131. The NAP responses to the AIM commands 162 are received at the FS 103 through the COMS portion 131 as conceptually illustrated at 164. The FS 103 utilizes the NAP responses 164 in executing the various steps and command that comprise each fax command in the fax command set 160 Additionally, the NAP responses 164, as well as the FP responses 163, are utilized by the FS 103 to form the fax response for each received fax command as conceptuall illustrated at 165. The fax responses 165 are transmitt back to the applications 100 (Figure 1) through the COMS portion 130. It is appreciated that when a NAPFE comman is issued by the application, it may result in issuance of multiple AIM and FP commands and responses. The NAP 10 maintains fax and voice messages stor in the NAP data base file on the disk 23. Additionally, the FS 103 maintains A-Series files for temporary storag on the disk system 23 and, as discussed in said S.N. 521,210, the applications 100 may maintain A-Series files thereon. Furthermore, the Fax Processors 104 stor fax message files for transmission to the network 12 or after receipt therefrom. There are differences in the file formats of the application files, the FS files, the NAP data base files, and the FP files that may require conversion.
The FS 103 receives fax data from the Fax Processors 104 along the path 107 and temporarily holds the data as schematically indicated at 166. Requisite file conversions are performed at 167 and the FS 103 transmits the converted fax file to the I/O processor 24 along the path 111 for storage i\- ' ς. temporary A-Series disk file of the FS 103. 'r e i_-«αporarily stored file is transferred to the NAP data base message file utilizing the NAP CREATE VOICE MESSAGE command in the manner described in said S.N. 521,210. Conversely, a fax message to the network is provided along the path 107 from the fax data storage block 166 after appropriate file conversion 167 is performed. The FS 103 obtains this fax data from its temporary A-Series file via the I/O processor 24 along the path 111. In the manner described in said S.N. 521,210, this file may be obtained from the NAP data base message file into the FS temporary disk file via a NAP GET VOICE MESSAGE command.
The Fax Server 103 also includes a Recovery Table 168 utilized in a fax message recovery process to be described. Referring to Figure 6, with continued reference to Figure 1 , functional details of the Fax Processor 104 are illustrated. The Fax Processor 104 is a conventional AT/PC with commercially available facsimile cards installed in the AT slots thereof. A CPU 180 controls the ports 105 for direct connection to the network via the path 106 and for connection to the network via the NIUs 19 as illustrated. The Fax Processor 104 includes a hard disk 181, controlled by the CPU 180, for temporarily storing the facsimile messages after receipt from, or before transmission to, a facsimile machine via the network or CO 27. The fax communication is through fax cards 182 and the ports 105. The fax cards 182 are installed in the AT slots and communicate with the ports 105 under control of the CPU 180. The fax cards are commercially procurable and may, for example, be implemented by GammaLink PC facsimile cards available from GammaLink Corporation of Sunnyvale, California.
The fax cards 182 communicate with the hard disk 181 under control of the CPU 180, as conceptually illustrated at 185. It is appreciated that the fax cards 182 access the disk 181 through the CPU 180 via a software interface (not shown) procurable with the cards and installed on the fax cards 182 and the CPU 180.
Functionally, the hard disk 181 communicates through the ports 113, as controlled by the CPU 180, to the link 108 for intra-system file transfers in a manner to be described. It is appreciated that disk communication is effected through the PC DOS operating system in a well known manner.
The Fax Processor 104 receives the FP commands from the FP DLP 109 over the link 108 through the ports 113 as conceptually indicated at 183. The Fax Processor 104 sends FP responses back over the link 108 through the ports 113 as conceptually indicated at 184.
The CPU 180 may, for example, be implemented by an 80286/12 MHz processor card. The Fax Processor 104 is preferably of an industrialized rack-mounted hardware configuration, but is a conventional 286 class PC running standard PC DOS from the hard disk 181. The FP 104 can dial out to the phone number in the phone number field 144 (Figure 4A) via the fax cards 182.
With reference to Figure 1 , it is appreciated that the Fax Processor 104 operates asynchronously with respect to the Fax Server 103. After the Fax Processor 104 is commanded by the Fax Server 103 to receive a fax from the network, the fax message is completely received and stored on the disk 181 without NAPFE intervention. Similarly, after a fax is stored from the Fax Server 103 on the disk 181 for transmission to the network and the Fax Processor 104 is commanded by the Fax Server 103 to effect the transmission, the fax message is sent by the Fax Processor 104 without intervention from NAPFE.
The following table provides a list of the NAPFE Command Set 160 (Figure 5), which commands are expected from an application in a dialog. Commands are sent from an a plication 100 to NAPFE when the application wants NAP.7, to perform a facsimile oriented function. Within each dialog there is a one-to-one relationship between commands and responses; i.e., for each command sent by the application 100, NAPFE will return a response and for each response returned by NAPFE, the application 100 will issue a command.
NAPFE COMMANDS AND VALID RESPONSES
The following table provides a list of the fax responses 165 (Figure 5).
NAPFE RESPONSES Response Type Response
114 FaxReceived
115 FaxSent
116 FaxCreated*
117 FaxObtained
The following table sets forth the FP Command Set 161 (Figure 5) and the FP Responses 184 (Figure 6) with the preceding number representing the Message Type, FP COMMANDS AND VALID RESPONSES FP Commands Valid Responses
01 AnswerRecv 50 FaxPortReady
02 OriginateRecv 51 ReceiveDone
03 OriginateXmit 52 TransmitDone
04 AnswerXmit 52 TransmitDone
05 RemoveFile 54 FileRemoved
06 PortState 55 Portstatus 08 Portlnitialize 57 Initialized
11 OrigXmitNIU 50 FaxPortReady
12 WaitCompleted 51 ReceiveDone
52 TransmitDone 90 SendFile 91 FileXfered
92 ReceiveFile 91 FileXfered
It is appreciated that cosamands 01-12 control facsimile message transmission and reception functions, whereas commands 90 and 92 control functions relating to transferring files between the NAP disk 23 and the FP disk 181. Although file transfer is specified in terms of Send File and Receive File commands, A-Series file transfer mecha -~ms may be utilized that separately transfer Headers , Blocks and Records.
Details of the FP commands and responses sent from the FS 103 to the FP 104 and from the FP 104 to the FS 103, respectively, will now be described. The FP commands represent the total functionality that the NAPFE requires from the FP 104 so that the NAPFE can provide the facsimile oriented capabilities required by the applications 100. All FP commands result in a single response. These commands are used to control the actual fax operations that the FP 104 must execute.
Answer and Receive (Message Type 01). This command places the specified FP port into a mode where it will wait for ring, answer the phone and receive an incoming fax. The command generates an immediate respons of FaxPortReady (Message Type 50) that will indicate that the FP port is ready and the call can be routed thereto. Two methods can be used to determine when the fax reception is complete. A PortState (Message Type 06) command can be issued to the FP port on a periodic basis. This permits the Fax Server 103 to determine the state of the fax operation. Alternatively, the Fax Server 103 can issue a WaitCompleted (Message Type 12) command causing a ReceiveDone (Message Type 51 ) response to be generated when the fax reception is complete.
Originate and Receive (Message Type 02). This command is used to cause the specified fax port to originate a call to the specified phone number and poll the answering machine for a fax. Thus, the FP 103 dials out through the specified fax port to poll for an incoming fax. The response to this command is a ReceiveDone (Message Type 51 ) which is issued when the operation is completed.
Originate and Transmit (Message Type 03). This command causes the designated FP port to call the specified phone number and to transmit the designated faxes. The FP 103 dials, out through the specified fax port and sends the faxes. The response to this command is a TransmitDone (Message Type 52) which is issued at the completion of the fax operation.
Answer then Transmit (Message Type 04). This command causes the FP port to go into a state where it will wait for an incoming call, answer the phone and transmit the specified faxes when a poll is received from the other fax machine. The FP prepares to answer the incoming call on the specified fax port, be polled and then transmit the faxes. The response to this command is a TransmitDone (Message Type 52) which is received when the fax operation is complete.
Remove File (Message Type 05). This command causes the named files to be removed from the hard disk drive 181 of the FP. The command generates an immediate response of FileRemoved (Message Type 54).
Port State (Message Type 06). This command is used to inquire of the current status of the specified port and the results of the last fax operation of that port. The command generates an immediate result of PortStatus (Message Type 55) which details the current status of the port. Port Initialize (Message Type 08). This command causes the specified fax port to be initialized. The port state is initialized to an Idle state. This command includes a field for a RerooveFile Flag which, if set, causes the F? 104 to remove all files on the FP hard disk 181 associated with the designated fax port. The command generates an immediate response of Initialized (Message Type 57).
Originate and Transmit through NIU (Message Type 11). This command causes the designated FP port to originate a call through the NIU 19. The command generates an immediate response of FaxPortReady (Message Type 50) denoting that the FP port is ready and a call will be initiated to the NIU 19 through a predetermined port 20. Two methods can be utilized to determine when the fax transmission is complete. A PortState (Message Type 06) command can be issued by the Fax Server 103 on a periodic basis. This permits the Fax Server to determine the state of the fax operation. Alternatively, the Fax Server can issue a WaitCompleted (Message Type 12 command. This causes a TransmitDone (Message Type 51) response to be generated when the fax transmission is complete.
Wait for Completed Fax (Message Type 12). This command is utilized on the selected fax port that has had a fax operation initiated using the AnswerRecv (Message Type 01 ) or the OriginateXmitNIU (Message Type 11) commands. While the port is in an Inuse state, this command causes a ReceiveDone (Message Type 51 ) or a TransmitDone (Message Type 52) response to be generated when the fax operation is complete. If the port is in a Completed state, the ReceiveDone and TransmitDone will be issued immediately. Receive File (Message Type 92). This command transfers the named file from the PC hard disk 181 to the NAP memory disk system 23. When the operation is completed, the FileXfered response (Message Type 91 ) is issued.
Send File (Message Type 90). This command transfers the named file from the NAP memory disk system 23 to the PC hard disk 181. When the operation is complete, the FileXfered (Message Type 91 response is issued.
It is appreciated from the above, that file transfer is accomplished utilizing the file transfer message types 90 and 91. The file transfers are initiated by the File Server 103 (Figure 1). The Fax Processor 104 never initiates a file transfer operation.
The FP 104 has a specific response for each of the above-described FP commands as conceptually illustrated at 184 of Figure 6. The responses are as follows: Fax Port Ready (Message Type 50). This response is the result of an AnswerRcv command (Message Type 01 ) or an OriginateXmitNIU (Message Type 11) command. The response indicates that the designated fax port is ready to receive or transmit a fax in an asynchronous fashion. Receive Done (Message Type 51). This response is the result of an OriginateRcv command (Message Type 02). The response indicates that a fax has been successfully or unsuccessfully received. A Result field of the response indicates the success or failure of the received fax processing.
Transmit Done (Message Type 52). This is a response to either the OriginateXmit (Message Type 03) or the AnswerXmit (Message Type 04) commands. The response indicates the results of the fax transmit operation. A Status field of the response indicates the success or failure of the transmit fax processing. File Removed (Message Type 54). This is the response to the RemoveFile command (Message Type 05). The response indicates the results of the RemoveFile request. The fax name field designates the names of the files removed from the FP hard disk 181. Port Status (Message Type 55). This is the response to the PortState command (Message Type 06). It indicates the current state of the fax port specified by the Port Number field of the response. The response also includes a Result field indicating the success or failure of the last command's fax processing. A Port State field of the response indicates the current state of the port. The Port State field may indicate Idle, Inuse or Completed. A File Name field of the response lists the FP file names of the files of the current Send/Receive Fax command.
Initialized (Message Type 57). This is the response to .the Portlnitialize (Message Type 08) command. The response indicates the results of the initialize operation. File Transferred (Message Type 91 ). This is the response to the SendFile (Message Type 90) and ReceiveFile (Message Type 92) commands. The response indicates the results of the last file transfer request. As discussed above, when a fax specific command is issued by the application 100, the FS 103 will interpret it and execute it as a series of NAP commands associated with a series of FP commands. When the commands are processed, the Fax Server 103 will generate a fax response 165 (Figure 5) and the COMS portion 130 (Figure 3) will respond to the application 100. There is a one-to-one correspondence between commands and responses. All standard NAP functionality is available to a fax application. The primary difference between a NAP fax application and a standard NAP application is the additional NAPFE commands that are available.
Thus, the NAPFE commands sent from the applications 100 to NAPFE are interpreted by the Fax Server 103 and converted into the appropriate NAP and FP commands necessary to execute the desired function. Specifics of the NAPFE commands and responses will now be described. Receive Fax (Message Type 23). This command is sent by the application to the Fax Server 103 of NAPFE to request that the FP receive a fax from a fax machine. The connection associated with the specified Dialog ID is used for the fax reception. In response to the Receive Fax command, the Fax Server 103 issues the AnswerRecv FP command to the Fax Processor which responds with FaxPortReady back to the Fax Server indicating that FP is ready to receive an incoming call from the NIU. The Fax Server then issues the NAP command Connect Call to switch the current NIU call connection of the specified dialog ID to the NIU port for the selected FP port. Thus, the incoming call is switched to the selected fax port. The NAP "returns the Call Connected response to the Fax Server. The Fax Server issues the Collect Digits command to the NAP as a timeout waiting to receive on-hook notification from the NIU. Collect Digits is set to specify 50 digits and a maximum timeout. The incoming line to the NIU is now connected to FP which, like a fax machine, receives the data and then hangs up. Upon receipt of the On-Hook, the NAP returns the Command Executed response to the
Fax Server. The Fax Server then checks the Fax Processor to determine the receive status by issuing a PortState FP command and receiving a return of the PortStatus response from the FP. Alternatively, the Fax Server can issue the WaitCompleted command to the FP after receiving Call Connected from the NAP and then await receipt of ReceiveDone from the FP. ReceiveDone provides notification when the fax receipt has been accomplished by the FP. The Fax Server then issues a file transfer command to the Fax Processor to move the fax from the PC hard disk 181 to the A-Series disk 23. To accomplish this. the FS issues the ReceiveFile command to the FP which transfers the fax file to the FS issuing a FileXfered response. The FS converts the file, if necessary, to A-Series format utilizing the file conversions 167 (Figur 5). The FS stores the converted file in its temporary A-Series disk file 115 through the I/O processor 24 (Figure 1). The FS then transfers the temporarily stored A-Series disk file to the VMMM data base 40 and removes it from the FP hard disk 181. This is accomplished by the FS issuing the Create Voice Message command to NAP to store the converted file in the VMMM data base. NAP responds to FS with the NAP Message Created response. The FS then issues RemoveFile to the FP which responds with FileRemoved. Alternatively, the FS issues the FP command Portlnitialize setting the RemoveFile flag. The FS then notifies the application of the successful receipt of the fax and the new fax's Message Number. This is accomplished by the FS issuing the NAPFE Fax Received (Message Type 114) response through the COMS portion 130 (Figure 3) back to the application.
The Fax Received response from the FS to the application consummates the Receive Fax command originally received by the FS from the application.
The Receive Fax command has a Recovery Token field that is used in the case of a system, COMS, NAP or application outage. During the recovery processing, to be described, the application uses this token to recover a fax that was in process at the time of an outage. The Receive Fax command also includes a DB Numbe field for containing the NAP application number for the current application. The DB Number is utilized to uniquely identify the application's Recovery Tokens. A standard NAP Terminate Dialog command issued by the application to NAP can close out the dialog. Send Fax (Message Type 24).
This command is sent by the application to the Fax Server 103 of NAPFE to request that the Fax Processor send a fax to a fax machine. The connection associated with the specified Dialog ID is used for the fax transmission. The command identifies the fax message or messages to be sent by Message Number utilizing the Message Number field 126 (Figure 2). The FS retrieves the message from VMMM and has it transferred to the FP hard disk. This is accomplished by the FS first issuing to NAP the NAP Get Voice Message command for each message to be sent and waiting for the response from NAP of Command Executed for each Get Voice Message issued. The FS selects the FP port through which the fax transmission will occur. This can either be a port connected directly to the CO 27 or a port connected to the NIU 19 (Figure 1). The FS issues the FP SendFile command to the File Processor listing the file names of the files built by the NAP Get Voice Message commands. Thus, the fax files obtained by FS from NAP VMMM are transferred to the FP hard disk for transmission. In this process FS converts the files, if necessary, from A-Series format into the appropriate format for transmission such as PC text. The FS 103 utilizes File Conversions 167 (Figure 5) to effect the conversion. The FS then waits for the FileXfered response from the FP. If required, the FS 103 switches the incoming line at the NIU 19 from the VIM DLP 25 to the selected FP port. This is accomplished by the FS issuing the NAP Connect Call command to NAP and receiving the Call Connected response from NAP. Thus, the NAPFE uses the Connect Call command to switch the existing connection to the specified FP port. The FS then issues the FP command OriginateXmit to the FP specifying the phone number derived from the dialog specified in the NAPFE command. The OriginateXmit command is sent to the FP port specified in the FP command. The FS then waits for the TransmitDone command from the FP indicating that the fax has been sent.
The FS then removes the file from the FP hard disk. In a manner similar to that described above with respect to Receive Fax, two procedures may be utilized to remove the file from FP disk. The FS issues the RemoveFile command to the FP naming the file and the FP responds to FS with FileRemoved. Alternatively, FS can issue the Portlnitialize command to the FP setting the Removefile flag and receiving the Initialized respons from the FP after the file has been deleted.
The FS then issues the NAPFE Fax Sent (Message Type 115) response back to the application through the COMS portion 130 (Figure 3) consummating the Send Fax command originally sent by the application. At the discretion of the application, the transmitted fax may be deleted from the NAP VMMM data base. This is accomplished by the application issuing the standard NAP command Delete Voice Message and receiving from NAP the corresponding NAP response Message Deleted. A standard NAP Terminate Dialog command issued by the application to NAP can close out the dialog. Poll and Receive Fax (Message Type 25).
This command is sent by the application to the FS of NAPFE to request that the FP poll a fax machine to determine if that machine has an outgoing fax pending. If the fax machine does have an outgoing fax, then the fax is received by the FP. The connection associated with the specified Dialog ID is used for the fax polling and the fax receipt. If required, the FS uses a Connect Call NAP command to switch the existing NIU connection to the appropriate fax port. The FS issues the FP comman OriginateRcv to the FP specifying the phone number of the fax machine to be polled, as derived from the current dialog. The FP returns the ReceiveDone response. The FS then issues the ReceiveFile command to the FP for transferring the file from FP disk to the FS A-Series disk file. The file is converted, if necessary, to the A-Series Fax Format by the File Conversions 167 (Figure 5). The FP returns the FileXfered response to the FS.
The FS then issues the NAP command Create Voice Message to the NAP to store the converted file in the VMMM data base 40 as described above with respect to Receive Fax (Message Type 23). The FS then removes the file from the FP hard disk in the manner described above with respect to Receive Fax and thereafter issues the NAPFE response Fax Received back to the application consummating the original Poll and Receive Fax command. The command includes Recovery Token and DB Number fields for the reasons discussed above with respect to Receive Fax.
The above operations of Poll and Receive Fax results in the FS having the FP dial-out, poll the designated fax machine and receive the fax. The network connection may be effected by the NIU but the FP performs the dial-out procedure. The fax is then stored in the VMMM data base and the application is notified of its Message Number. A standard NAP Terminate Dialog command from the application can close out the sequence. Send Fax after Poll (Message Type 26). This command is sent by the application to the FS of NAPFE to indicate that a fax machine will be polling the FP. When the poll is received, the specified fax is transmitted by the FP to the fax machine. The connection associated with the specified Dialog ID is used for the poll reception and fax transmission. The NAPFE uses the Connect Call NAP command to switch the existing connection to the FP. This NAPFE command results in a Fax Sent (Message Type 115) response. The command includes a Message Numbers field 126 (Figure 2) to specify which fax messages are to be processed. The FS uses either the OriginateXmit FP command or the OrigXmitNIU FP command depending on the connection protocol utilized. Create Fax Message (Message Type 27).
This command, sent from the application to the FS, informs NAPFE that a fax message is to be copied from a file and placed in the fax file maintained by NAP. Thus, the command creates a NAP fax message from the contents of a specified A-Series disk file. The FS converts the specified file to NAP VMMM format utilizing File Conversions 167 (Figure 5). The command includes a Fax File Name field 127 (Figure 2) containing an A-Series file title which will be used to identify the file containing the fax message. The command also includes the Recovery Token and DB Number fields for the reasons discussed above with respect to Receive Fax. This command is utilized to originate a fax without having a fax machine. Since the fax cards 182 (Figure 6) support direct conversion of text to fax images, a file created on a main frame computer or on a PC can be sent as a fax. The protocol of this command is utilized by the application to externally introduce such a file into the NAP system. After conversion, the data is stored in the VMMM data base and the application is notified of the new Message Number. In response to the Create Fax Message command, the FS converts the file and issues a NAP Create Voice Message command to NAP which transfers the file into the VMMM data base. NAP responds to the FS with the NAP Message Created response and the FS issues the NAPFE Fax Created response back to the application. Get Fax Message (Message Type 28). This command, issued by the application to the FS, informs NAPFE to copy the indicated fax message into the specified A-Series file for storage therein. Thus, once a fax has been received or created, the command provides a way to store the fax other than in the VMMM data base. The application can then manage the resultant file in the same manner as a normal A-Series disk file. The application issues the command specifying the VMMM Message Number and the name of the A-Series disk file to contain the message. The FS retrieves the fax from the VMMM data base and copies it into the specified A-Series file. The Fax File Name field 127 (Figure 2) contains an A-Series file title which will be used to create the file containing the fax message. The command also includes Message Number field 126 (Figure 2) which contains the Message Number representing the fax message to be placed in the specified disk file.
In order to obtain the file from the VMMM, the FS issues the NAP Get Voice Message command to NAP specifying the Message Num er. NAP returns the NAP Message Created response to FS. FS converts the VMMM file to an appropriate format such as A-Series Fax Format thus creating the file specified in the Get Fax command. FS then issues the NAPFE Fax Obtained response back to the application. Recover Fax Message (Message Type 29).
This NAPFE command sent from the application to FS, is utilized by the application to initiate a fax recovery process to be described below. Both the application and NAPFE maintain tables of Recovery Tokens. The command is utilized by the application to recover any faxes that were received by the FP when an outage occurred. The NAPFE searches its table for the Recovery Token specified in the command. If the token is found, a Fax Received (Message Type 114) response is returned to the application along with the associated fax Message Number. A flag is set in NAPFE so that when the next NAP command is received (of any type), the entry is removed from the NAPFE recovery table. The command includes the Recovery Token field 124 and the Data Base Number field 125 to uniquely identify the application's Recovery Tokens which identify fax receptions that were in process at the time of a system or application outage. Send Fax from File Message (Message Type 30). This command sent by the application to FS, informs NAPFE that a fax message is to be copied from a file and then sent to a fax machine. The connection associated with the specified Dialog ID will be used for the fax transmission. The command results in a Fax Sent (Message Type 115) response. The FS utilizes a Connect Call NAP command to switch the existing connectio to the FP. The command contains the Fax File Name field 127 containing the A-Series file title utilized to identify the file containing the fax message.
The NAPFE provides one of the following four responses for all NAPFE commands that execute properly. The NAPFE responses are conceptually illustrated in Figure 5 at 165 as described above.
Fax Received (Message Type 114). This response is generated by FS and returned to the application through the COMS portion 130 (Figure 3) for any NAPFE command that receives a fax message. The response includes the Message Number field 126 (Figure 2) for containing the NAP Message Number of the received fax message. The response also returns the results of the fax reception.
Fax Sent (Message Type 115). This response is generated by FS and returned to the application through the COMS portion 130 for any NAPFE command that transmits a fax message. The response returns the results of the fax transmission.
Fax Created (Message Type 116). This response is generated by FS and returned to the application through the COMS portion 130 for the NAPFE Create Fax (Message Type 27) command. The response indicates that a NAP fax message was successfully created from the contents of an external A-Series disk file. The response includes the Message Number field 126 (Figure 2) for containing the Message Number of the created fax message.
Fax Obtained (Message Type 117). This response is generated by FS and returned to the application through the COMS portion 130 for the NAPFE Get Fax (Message Type 28) command. The response indicates that a NAP fax message was successfully retrieved and placed into an external A-Series disk file.
It is appreciated from the foregoing, that fax functionality is added to the NAP system of said S.N. 521,210 by the insertion of the COMS 101, as explained with respect to Figures 1 and 3, between the NAP 10 and the application 100 and the addition of the Fax Server 103 and Fax Processors 104. A fax application is designed to run as a normal NAP application in that the application is coded to use the existing AIM specification, as described in said S.N. 521,210, to communicate with NAP 10.: COMS 101 and the Fax Server 103 adds the additional NAPFE command and responses to the existing AIM command/response set. COMS 101 transmits all of the NAP and NAPFE commands and responses between the application and the platform as described above. It is further appreciated that the functions attributed herein to COMS 101 and the Fax Server 103 may be integrated into NAP (preferably into AIM 15) to perform the described functions.
The NAPFE commands and responses add additional functionality to permit the application to manage the transmission and reception of faxes in the manner that the standard NAP manages the transmission and reception of voice messages. Faxes are stored within NAP in exactly the same way that voice messages are stored as described in said S.N. 521,210. All NAPFE commands reference faxes by Message Number just as NAP commands reference Voice Messages by Message Number. A fax application can use several standard NAP message processing commands on fax messages. These commands are DELETE MESSAGE (Message Type 03) and GET MESSAGE NUMBERS (Message Type 12). Thus it is appreciated, that an application can intermix voice and fax functionality over a currently established network connection. Prior to issuing a NAPFE command, the application can conduct a voice dialog with NAP over the connection. Because of the capabilities described in said S.N. 521,210 and the capabilities described herein, the NAP can switch the NIU 19 between voice and facsimile ports. Thus, all NAP and NAPFE commands and responses are available to the application through a common interface. In this way, the application can blend fax and voice functionality. The FP 104 has the responsibility to physically send and receive faxes. The NIU 19 switches incoming fax lines over to the FP so that the fax can be received. Outgoing faxes are sent directly out over the CO lines 106 (Figure 1) or through the NIU 19. The FP hare": disk drive 181 (Figure 6 is used to stage the incoming and outgoing faxes.
As discussed above, the fax functions that NAP with NAPFE can invoke are: Receive Fax where the FP receives the fax over the current connection; Send Fax and Send Fax from File where the FP sends a fax over the current connection or over a newly originated connection; Poll and Receive Fax where the FP polls a fax machine over the current connection or over a newly originated connection to receive a fax; and Send Fax after Poll where the FP receives a poll over the current connection and then transmits the specified fax. Before issuing any of these commands, it is the responsibility of the application to establish a network connection to the fax machine. This can be done in two ways:
1. In response to detecting ring at an NIU port, the application receives an Incoming Call respons from NAP. In accordance with NAP protocol, the application then issues a Connect Call command to NAP. Optionally, a voice dialog can occur prior to the fax operation. The signalling accompanying the incoming call identifies that a fax transaction is required. For example, if the call was transferred by the Central Office to the NAP from a busy fax machine, the Called Number Identification permits the NAP to determi that a fax application is involved from the application tables maintained in NAP.
2. The application issues an Initiate Call command followed by a Pivot Call command. The application places the phone number for the outgoing call in the body of the Initiate Call command. The call is out-dialed by the NAP and pivoted to an NIU port connected to an FP port. The FP command, issued as part of the NAPFE command, includes a code in the phone number field so that the fax port connects with the NIU port to which the call vc pivoted. Alternatively, the Initiate Call and Pivot Call commands are intercepted by the trap 132 (Figure 3) and the phone number for the outgoing call is transferred to the phone number field of the FP command that forms part of the NAPFE command. When the NAPFE command is issued including an FP command of OriginateRcv or OriginateXmit, the FP then out-dials the call. The above establishes a call associated with the current dialog. When the NAPFE command is issued, the requested fax action is performed utilizing the network connection associated with the Dialog ID in the command header. It is appreciated from the foregoing descriptions of the NAPFE commands, that a NAP Connect Call command is utilized to connect the existing call with the selected FP port. After the fax function is complete, the FP goes on-hook causing the connection to be terminated. The application then closes out the dialog with a Terminate Dialog command.
The described approach allows the application to have full control of the fax operations. Fax functions can be performed over any network connection that an application can establish using NAP. The described design renders the NAPFE functionally independent of, and compatible with, NAP capabilities. As discussed above, the .execution of NAPFE commands often requires that standard NAP commands be used as part of the program steps to perform the desired fax function. When a program step in a fax transaction causes a NAP command to be issued, a flag (not shown) is set for that Dialog ID to intercept the next response for that dialog and utiliz it to trigger execution of the remaining program steps. When an application has answered an incoming call to the NIU, it may be desirable for the application to transmit a fax over that connection. The OriginateXmitNIU FP command and the WaitCompleted FP command are utilized. The OriginateXmitNIU provides an immediate response to the Fax Services software.
The WaitCompleted command only responds when the selected fax port completes its current receive or transmit. Specifically, the NAP receives Ring Detect from the NIU incoming call and responds to the application with the unsolicited response Incoming Call. The application issues Connect Call to the NAP and the NAP responds to the application with Call Connected. A voice dialog may now occur between the application and NAP. After the voice dialog, the application issues the NAPFE comman Send Fax to the FS. The FS obtains the fax message by issuing the NAP command Get Voice Message to the NAP which responds to the FS with Command Executed. The FS transmits the fax obtained from NAP to the FP by issuing the FP command SendFile. When the file has been received by the FP, the FP responds to the FS with FileXfered. The FS then commands the FP to dial-out to the NIU and transmit the fax thereto by issuing the FP command OrigXmitNIU. The FP responds back to the FS with FaxPortReady. The FS then issues Connect Call to the NAP which responds with Call Connected. The FS then issues WaitCompleted to the FP which in response to detecting On-Hook from the NIU issues TransmitDone to the FS. The FS then removes the file from the FP hard disk by issuing RemoveFile thereto which responds back to the FS with FileRemoved. The FS then consummates the Send Fax command from the application by returning Fax Sent thereto. The application may delete the message from the NAP data base by issuing the NAP command Delete Voice Message to the NAP which responds to the application with Message Deleted. The dialog is closed out by the application by issuing Terminate Dialog to the NAP. it may also be desirable for NAPFE to be able to initiate a call through the NIU and to then transmit a fax over that outgoing connection. A procedure for accomplishing this utilizes the trap 132 (Figure 3). The application issues Initiate Call to the FS which responds to the application with Call Connected. The application issues a Pivot Call to the FS which responds to the application with Call Connected. NAPFE traps the Initiate Call in the trap 132 and saves off the outgoing port specification. NAPFE also traps the Pivot Call command.
The application then issues a Send Fax command to FS and NAPFE downloads the fax to the FP disk and has the fax port go off-hook. This is accomplished by FS issuing Get Voice Message to NAP which responds back to FS with Command Executed. FS then issues SendFile to FP which responds back to FS with FileXfered. FS then issues OriginateXmit to FP which goes off-hook to the NIU. NAPFE traps this Incoming Call in the trap 132 and issues a Connect Call using the saved outgoing port specification. This causes an outgoing call to the network and connects the fax port to the outgoing connection. Normal fax transmission then occurs.
It is appreciated that when the fax port goes off-hook, the Incoming Call initiates a new Dialog ID. Specifically, after the file is on FP disk and after the FP goes off-hook to the NIU, NAP sends the unsolicited response Incoming Call to FS which responds to NAP with the Connect Call command. NAP responds back to the FS with Call Connected and the FS issues Collect Digits to the NAP as a time-out. When FP goes on-hook to the NIU, the NAP responds to FS with Command Executed, and FS sends the Terminate Dialog command to NAP for the new dialog.
The FP then responds to FS with TransmitDone and FS commands FP with RemoveFile. FP responds to FS with FileRemoved. The original Send Fax command from the application to FS is consummated by FS responding to the application with Fax Sent.
The fax may then be deleted from NAP by the application issuing Delete Voice Message thereto. NAP responds to the application with Message Deleted and the application terminates the original dialog by issuing Terminate Dialogue to NAP. The Incoming Call unsolicited response from NAP to FS and the subsequent new dialog . therebetween, was performed in the capacity of the FS as an application with respect to NAP. It is appreciated from the foregoing that because of the sophisticated NIU call connectivity control by NAP, the application can establish appropriate network connections for reception and transmission of fax messages. For calls coming into the NAP, either for the purpose of sending a fax thereto or for polling the NAP for a fax, the NAP issues an unsolicited Incoming Call response to the application. Because of signalling accompanying the call, the NAP determines that a fax transaction is desired. AIM commands such as Connect Call and Pivot Call can be utilized to effect the appropriate connections between FP, NIU and the network. For calls initiated by the NAP, either for sending a fax or for polling a fax machine, the Initiate Call command is utilized followed by appropriate AIM call switching commands.
For the purpose of appropriately routing fax messages and calls to appropriate NIU ports, NAPFE commands utilize a predetermined outpulse rule that is detected by NAPFE to provide discrimination between fax and non-fax transactions. In this regard, the Fax
Processor 104 can connect directly with the Central Offic or with the network through the NIU 19. The trap 132 can optionally be utilized, as described above.
It is noted that the call connectivity AIM commands, such as Pivot Call, as set forth in said
S.N. 521,210, may not provide precisely the switching functionality required for NAPFE commands. The trap 132
(Figure 3) is utilized in the manner described above to effect the appropriate connections. Alternatively, the requisite switching functionality can be added to the AIM command set by the inclusion of a new appropriate NAP command, thus obviating the need for the trap 132. Referring again to Figure 1, the FP DLP 109 and the high-speed parallel link 108 comprise a commercially procurable A-Series computer to PC data transfer connection available, for example, from Express-Link, Inc., of Richmond, Virginia. The FP DLP 109 is implemented by the Express-Link DLP and is a well known type of A-Series communication interface. The FP DLP 109 appears to the A-Series system like a GCR tape DLP.
As discussed above, the FP operates independently from the A-Series host on which NAP and NAPFE are installed. Once an FP command is issued to receive a fax, the FP will, in the absence of a hardware failure or powerdown, receive the fax. The FP reception process confirms to the fax machine that the FP received the fax and has it stored on its hard disk.
A timing window, however, exists between the application, NAPFE and the FP where an incoming fax message can get lost. NAPFE utilizes a recovery mechanism that guarantees fax reception. The mechanism ensures that the application will be aware of all faxes received by the FP so that fax messages will not get lost. The timing window results, for example, when a system or an application interrupt occurs between the time a fax is received on the FP disk and the time the fax Message Number is entered into the application data base.
The basis of the NAPFE guaranteed fax reception is the Recovery Token and the NAP application Data Base Number stored in fields 124 and 125 of the NAPFE command body 121, as illustrated in Figure 2. The Recovery Token is specified on all commands where faxes are received or created. The application assigns a new and unique Recovery Token to each Receive Fax, Poll and Receive
Fax and Create Fax command. The Recovery Token combined with the application Data Base Number creates a unique ID for each fax reception. This unique ID is utilized by NAPFE to ensure the complete reception and archiving of all incoming faxes.
The recovery information is maintained in the Recovery Table 168 illustrated in Figure 5. The Recovery Table 168 stores, inter alia, the application's NAP Data Base Number and the defined application Recovery Token. The application also maintains a list of issued Recovery Tokens and information pertinent thereto. The application places a new Recovery Token in its Recovery Token list for commands that have not been completed. The application issues a desired NAPFE command specifying the associated Recovery Token. When the FS issues the FP file transfer command ReceiveFile (Message Type 92), FS records the associated Recovery Token and Data Base Number in the Recovery Table 168, as well as the associated FP port number. The port number is in the field 152 of the FP command (Figure 4B) .
If the receipt of the file by FS and the archiving in VMMM is not successful, the involved FP port remains Inuse and cannot be used for reception or transmission of further fax messages until cleared by, for example, Initialization. Thus, the entry in the Recovery Table 168 uniquely identifies received faxes until reception and archiving is complete. Created faxes are alsp uniquely identified by the information in the Recovery Table 168 because of the manner in which the Create Fax Message protocol functions.
When a received or created fax message is completely transferred from FP disk and archived in the VMMM data base, the associated entries in the application Recovery Token list and the Recovery Table 168 of NAPFE are deleted. The recovery process involves the application issuing the NAPFE Recover Fax command for each token remaining on the application list with the entries from the application list and NAPFE Recovery Table 168 being deleted upon successful transfer of the fax. When the Recover Fax command is issued by the application, the FP is checked for faxes that were received but never moved to the VMMM. If such f xes are found, they are transferred utilizing the file transfer protocol discussed above with respect to the NAPFE Receive Fax command. When the recovered fax is successfully transferred and archived, the entry is removed from the Recovery Table.
When a Receive Fax, Poll and Receive Fax or Create Fax command is issued to FS, the Recovery Table entry is allocated. After FS issues a Fax Received response (resulting from a Receive Fax, Poll and Receive Fax or Recovery Fax command), NAPFE considers the next received NAP or NAPFE command as a positive acknowledgment from the application that the application has saved the fax Message Number and information to disk and that the application has archived the data in VMMM. In response thereto, NAPFE clears the Recovery Token entry associated with the previous Fax Received response from the Recovery Table.
Recovery may be executed as part of application initialization. The application performs the recovery processing as follows:
1. Issue a Recover Fax command for the first token in the application Recovery Token 1.st. This causes the fax to be transferred from the
FP to the VMMM resulting in a normal Fax Received response specifying the Message Number and information for the associated fax.
2. Log the Message Number for the fax in the 41 application data base.
3. Delete the Recovery Token from the applicatio list.
4. Issue the next NAP or NAPFE command. This clears the Recovery Token entry from the NAPFE
Recovery Table.
5. Repeat the above steps 1-4 for each Recovery Token in the application list.
6. Perform normal NAP message reconciliation utilizing the Get Message Numbers command as described in said S.N. 521,210 and S.N. 514,783. It is appreciated from the foregoing with respect to Figure 1 , that although the Fax Server 103 is illustrated as a separate block for convenience of description, the Fax Server 103 is part of NAP 10 and resides in main memory 18. FS 103 may be considered as an extension of AIM 15. The physical devices such as phone lines, switches or fax machines, as well as the actual voice or fax data, are not visible to the application. The application makes high level requests (Send Fax, Receive Fax) referencing the fax image by Message Number and referencing the destination by phone number or other appropriate identification such as subscriber ID. In this manner, the application concentrates on management of the faxes, as they flow through the system, and avoids the details of handling the hardware.
The above-described embodiment was explained in terms of utilizing file conversion with respect to file format in transferring files between the FP hard disk and the VMMM. It is appreciated that the fax messag data from a facsimile station can be received and stored in the VMMM message data base without conversion as, for example, a Group III image in accordance with the CCITT T.4 and T.30 recommendations. The stored message data can also be sent to a facsimile station by NAP without conversion. Thus, no conversion is required in the process of storage or retrieval of Group III compressed fax message data.
The Fax Processors 104 are integrated into the NAP architecture using the NIU 19 which provides the FP with interfaces to the network. The NIU also provides the capability to switch between an incoming or outgoing telephone line and a facsimile or voice port. This allows the same call to carry voice prompts, DTMF responses, voice annotations, and facsimile messages. Basically, NAP has been extended to send fax messages to a fax station, receive fax messages from a fax station, send fax messages to a polling fax station, and receive fax messages from a polled fax station. These commands can be used on a call that was either originated or answered by the' system.
It is appreciated from the foregoing, that the NAP has been extended to support the transmission and reception of facsimile message documents. This was accomplished by adding the additional commands and responses described herein to those supported by NAP as disclosed in said NAPSNs. The extensions allow an enhanced service on NAP that provides for the storage and retrieval of facsimile documents between a facsimile machine (Group III compliant, for example) and NAP. The present invention allows NAP to provide facsimile messaging- services together with the voice messaging services described in said NAPSNs. Voice prompts, DTMF responses, voice storage and retrieval, and facsimile storage and retrieval are combined in a single service. It is appreciated that the FP can store the entire fax image prior to transmission to the network and can also store the entire fax image after reception from the network prior to sending it up to the VMMM. Initiating transmission to the network one page at a time after storage of several pages of a fax in FP is also contemplated within the scope of the present invention. It is further appreciated that if NAPFE is integrated into NAP, COMS will no longer be the agent that directs commands. AIM will then determine whether the incoming command is a fax or voice type command and will direct the command accordingly. While the invention has been described in its preferred embodiment, it is to be understood that the words which have been used are words of description rather than limitation and that changes may be made within the purview of the appended claims without departing from the true scope and spirit of the invention in its broader aspects.
APPENDIX
" Referring to Figure 7, a Data Transfer Command (DTC) Interface 510 implemented in accordance with the present invention is illustrated. The Interface 510 couples a Data Link (DL) 511 with a host computer system 5 generally indicated at 512. The DL 511 is a communication link on which data of interest is sent/received and may be of any conventional form including one or more of the following: asynchronous or synchronous data stream, full/half/simplex connectivity and with or without - embedded protocol. The host 512 includes an Instruction Processor (IP) 513 and a Central Data Storage (CDS) "514. The IP 513 is a data processing entity, that performs tasks or applications utilizing data transferred over the DL 511. The IP 513 schematically includes a set 515 of Data Transfer Commands (DTC) to be further described with respect to Figure 8. The host 512 is illustrated running an application 516 that exercises ultimate control over the data transferred between the host 512 and the Data Link 511. The application 516 is responsive to external stimuli schematically represented at 517. For example, if the DL 511 links to a telephone network and the application 516 is a Call Answer program, the stimuli 517 may comprise off-hook and busy or ring-no-answer with the telephone system central office switch connecting the calling party to the Data Link 511. The application 516 may instruct the IP 513 to issue.-a -sequence of DTCs that will result in sending a voice prompt to the caller that the caller may leave a message at the tone, sending a tone over the DL 511 and receiving the voice message from the caller.
The Interface 510 includes a Command Queue (CQ) 520 that receives and stacks a sequence of DTCs issued from the IP 513. An Interface Control Processor (ICP) 521 sequentially receives the queued DTCs from the CQ 520 as schematically represented at 522. The CQ 520 is a FIFO queuing arrangement in which the IP 513 issues a sequence of DTCs that are executed by the ICP 521 individually without intervention of the IP 513. The ICP 521 also receives a TERMINATE DTC directly from the IP 513 bypassing the CQ 520. The TERMINATE DTC is received by the ICP 521 as schematically indicated at 523. The ICP 521 issues Data Transfer Results (DTR) to the CDS 514 as schematically indicated at 524. The IP 513 is appropriately notified when the ICP 521 issues the DTR to the CDS 514, The ICP 521 issues a DTR corresponding to each of the DTC types; viz, SEND, GET, TAG and TERMINATE to be described below in further detail. The ICP 521 also includes a buffering strategy control 525 to be further explained below.
The Interface 510 includes Interface Data Storage (IDS) 526 which comprises a data storage device where data to/from the DL 511 is buffered. The IDS 526 ir^ludes receive buffers 527 for buffering data received from the DL 511 to be stored in the CDS 514 and transmit buffers 528 for buffering data to be sent from the CDS 514 to the DL 511. The amount of storage provided by the receive buffers 527 and the transmit buffers 528 must be adequate to maintain a buffering strategy, as controlled by the buffering strategy control 525, between the CDS 514 and the IDS 526 which prevents starving the DL 511 when sending data or overrunning the IDS 526 when receiving data.
The Interface 510 further includes a Data Link Interface (DLI) 529- comprising an entity which provides interface capability between the DL 511 and the IDS 526. The DLI 529 may include one or more of the following techniques: serial/parallel conversion, DL protocol, coding technique and electrical conversion. The coding techniques may, for example, comprise Pulse Code Modulation (PCM) and the electrical conversion may comprise such techniques as digital-to-analog and analog-to-digital conversion.
The CDS 514 comprises a data storage device from which the IP 513 utilizes data received from the DL 511, generates data to be sent over the DL 511, or examines the DTR of DTCs issued to the ICP 521. The ICP 521 comprises a control entity which receives, performs, and acknowledges DTCs from the IP 513; coordinates data transfer between the CDS 514 and the IDS 526; and performs data transfer between the DLI 529 and the IDS 526. The CDS 514 and IDS 526 are responsive to the buffering strategy control 525 to effect data transfer coordination therebetween. '
The objective of data transfer to/from the CDS 51 over the DL 511 through the DTC interface 51 is accomplished through the use of DTCs issued from the IP 513 to the ICP 521. The four commands of the DTC command set 515 (SET-TAG, SEND, GET, and TERMINATE) provide capability for the IP 513 to communicate over the DL 511 while remaining decoupled from the operating details of the DL 511.
All DTC, except TERMINATE, are sent to the ICP 521 through the CQ 520. If the ICP 521 is not already executing a DTC, a DTC is transferred from the CQ 520 to the ICP 521. When the ICP 521 completes processing of any DTC, a Data Transfer Result (DTR) is issued and stored in the CDS 514 as status information which the IP 513 can examine after being notified. In this manner, the ICP 521 is sequentially and continuously processing single DTCs from the CQ 520 as long as DTCs remain in the CQ 520.
The TERMINATE DTC is not sent to the ICP 521 through the CQ 520. Instead, TERMINATE is sent directly from the IP 513 to the ICP 521 as an immediate command. The ICP 521 continuously awaits the direct arrival of the TERMINATE DTC from the IP 513 notwithstanding concurrent execution of a DTC from the CQ 520. The functions of TERMINATE, to be described below, are performed immediately with processing of a DTC issued from the CQ 520 being suspended, a DTR for the TERMINATE command being returned to the CDS 514 and the IP 513 being notified. As discussed above, the DTC set 515 is comprised of SEND, GET, SET-TAG, and TERMINATE. Referring to Figur 8, the formats of the DTCs are illustrated. Each of the DTCs has an op code field 540 and parameter fields 541 that contain the parameters associated with the command.
Referring to Figures 7 and 8, the SEND DTC transfers data stored in the CDS 514 to the DL 511. The SEND DTC has four associated parameters: LINK, TAG, LAST, and RECEIVE. The LINK parameter provides information to the ICP 521 on appropriate use of the CDS 51 . The LINK parameter may contain a CDS pointer providing an address in the CDS 514 at which information may be found, such as the address in the CDS 514 of the data to be sent, the amount of the data to be sent, and the address in the CDS 514 for storing the DTR.
Alternatively, the Link parameter itself may contain the information. The TAG parameter provides information to the ICP 521 with respect to grouping separate DTC operations into logical entities. The LAST parameter, which is boolean, informs the ICP 521 that the data associated with the current SEND DTC completes transmission activity to the DL 511. The RECEIVE parameter, which is boolean, directs the ICP 521 to begin receiving data from the DL 511 after the data associated with the current SEND DTC completes transmission to the DL 511.
During a SEND operation, the transmit buffers 528 in the IDS 526 will be maintained as full as possible according to a buffering strategy, to be described below, between the CDS 514 and the IDS 526 as controlled by the buffering strategy control 525. Maintaining the IDS transmission buffers 528 full allows the IDS bufferin to absorb latency anticipated in implementing the buffering strategy. To avoid transmission underrun, the buffering strategy must be able to absorb anticipated latency and sustain an average transmission rate equivalent to the transmission rate of the DL 511.
When a SEND completes the transfer of associated data from the CDS 514 with the LAST and RECEIVE parameters FALSE, a SEND DTR from the DTR block 524 is issued by the ICP 521 while the buffered data continues to be sent over the DL 511. This allows for the next SEND DTC in the CQ 520 to be processed by the ICP 521 so as to continue transmitting data over the DL 511 without interruption.
When a SEND completes the transfer of associated data from the CDS 51 with the LAST parameter TRUE and the RECEIVE parameter FALSE, the DTR is not issued until all buffered data has been sent over the DL 511. This allows for. the SEND DTR to provide synchronization of, and to indicate confirmation of, data transmission completion.
When a SEND completes the transfer of associated data from the CDS 514 with the RECEIVE parameter TRUE, the DTR is not issued until all buffered data has been sent over the DL 511. Once the DTR is issued, data received from the DL 511 will begin to be buffered in the receive buffers 527 of the IDS 526. This technique provides the ability to initiate receiving data from the DL 511 without -introducing large processing or communication delays between the termination of sending data over the DL and receiving data from the DL.
The operation of a SEND DTC in progress can be modified by a TERMINATE DTC or an internal terminating condition, such as DL protocol, in a manner to be described in further detail below. The GET DTC transfers to the CDS 514 receive data buffered from the DL 511 in the receive buffers 527 of the IDS 526. Reception is only initiated as the result of the RECEIVE parameter of a previous SEND DTC being set to TRUE. The GET DTC has three associated parameters: LINK, TAG, and LAST. The LINK parameter provides information to the ICP 521 on appropriate use of the CDS 514. The LINK parameter may contain a CDS pointer to a location in the CDC 514 containing such information as the address in the CDS 514 of the locatio to store the receive data, the maximum amount of data to store, and the address for storing the DTR. Alternatively, the LINK parameter itself may contain the information. The TAG parameter provides information to the ICP 521 with respect to grouping separate DTC operations into logical entities. The LAST parameter, which is boolean, directs the ICP 521. that DL reception and buffering must conclude with the current GET DTC.
During a GET operation and after data reception has been initiated pursuant to a previous RECEIVE, the receive buffers 527 in the IDS 526 will be maintained as empty as possible according to the buffering strategy between the CDS 514 and the IDS 526 to be further described below. The buffering strategy is controlled by the buffering strategy control 525. Maintaining the receive buffers 527 of the IDS 526 as empty as possible, allows the IDS buffering to absorb latency anticipated in implementing the buffering strategy. To avoid receiv buffer overrun, the buffering strategy must absorb anticipated latency and sustain an average transfer rate equivalent to the DL reception rate.
When a GET completes the transfer of associated data from the IDS 526, and the LAST parameter is FALSE, a GET DTR is issued from the DTR block 524 of the ICP 521 and receive data continues to be buffered from the DL 511. This allows for additional buffered data to be received from the DL 511 by the next GET DTC in the CQ 520 without interruption.
When a GET completes the transfer of associated data from the IDS 526 and the LAST parameter is TRUE, receiving buffering is stopped (if not already stopped by TERMINATE) and a DTR is issued. The DTR includes the additional status information that the receive operation was completed by the LAST parameter. A RECEIVE operation in progress can be modified by a TERMINATE DTC or an internal terminating condition, such as DL protocol, in a manner to be described below.
The SET-TAG DTC establishes a working TAG identifier for a following sequence or group of SEND and GET DTCs. The SET-TAG DTC has two associated parameters: LINK and TAG. The LINK parameter provides information to the ICP 521 with respect to appropriate use of the CDS 514. The LINK parameter could include such information (or a pointer to such information) as the address for storing the DTR. The TAG parameter indicates the specific working TAG identifier associated with the SEND and GET DTCs that follow the SET-TAG DTC.
The TERMINATE DTC causes the ICP 521 to possibly modify the behavior of the currently processing SEND DTC or data reception operation. The TERMINATE DTC has two associated parameters: LINK and TAG. The LINK parameter provides information to the ICP 521 with respect to the appropriate use of the CDS 514-. The LINK parameter could include such information (or a pointer to such information) as the address for storing the DTR. The TAG parameter indicates the specific group of DTCs that the TERMINATE DTC should address.
If a SEND DTC.is currently in progress by the ICP 521 and the working TAG does not match the TAG parameter of the TERMINATE, the TERMINATE DTR is issued by the ICP 521 from the block 524.
If a SEND DTC is currently in progress by the ICP 521 and the working TAG matches the TAG parameter of the TERMINATE, the following sequence of actions are controlled by the ICP 521:
1 ) The TERMINATE DTR is issued.
2) The transmission of data through the DL 511 from the IDS 526 is immediately stoppe and all data buffered in the IDS 526 is discarded.
3) The SEND DTR is issued. Status informatio in the SEND DTR can include information regarding the state of transmission such as the amount of data transmitted and the termination reason.
4) All other DTCs in the CQ 520 with a TAG parameter which matches the working TAG
. will cause an immediate DTR to be issued without performing any communication activity. The status information in the DTR indicates this condition. If a data reception operation is currently in progress by the ICP 521 and the working TAG does not match the TAG parameter of the TERMINATE, the TERMINATE DTR is issued.
If a data reception operation is currently in progress by the ICP 521 and the working TAG matches the TAG parameter of the TERMINATE, the following sequence of actions are controlled by the ICP 521: 1 ) The TERMINATE DTR is issued.
2) The reception of additional data from the DL 511 to the IDS 526 is immediately stopped.
3) The transfer to the CDS 514 of receive data already buffered in the receive buffers 527 of the IDS 526 continues throu the current and possibly following GET
DTC(s). This operation is referred to as a receive buffer purge.
4) When the receive buffer purge is complete, all following DTCs with a TAG parameter that matches the working TAG will cause an immediate DTR to be issued without performing any communication activity. The DTR status information will indicate this condition. As described above, external stimuli 517 may be detected and interpreted by the application 516 as requiring the termination of data being sent out over the DL 511 or being received therefrom. The application 516 instructs the IP 513 to issue a TERMINATE DTC with the TAG set for the currently executing sequence of SEND and GET DTCs in the CQ 520. Alternatively, an internal termination may be effected by the ICP 521 recognizing conditions of DL communication, such as DL protocol, which require the processing of SEND and GET DTCs to be modified. For example, in a telephone network environment, a DTMF digit entered by a caller over the DL 511 may be recognized by the ICP 521 as requiring immediate termination of voice data transmission. Actions executed in response to internal termination conditions are exactly equivalent to those that are performed for a TERMINATE DTC with a TAG value equal to the DTC currently being executed, except that no TERMINATE DTR is issued.
With continued reference to Figure 7, a buffering strategy implemented by the buffering strategy control 525 to minimize underrun of the transmit buffers 528 during a data transmitting operation and overrun of the receive buffers 527 during a data receiving operation, will now be described. The receive buffers 527 and transmit buffers 528 each comprises a set of individually actuatable buffers. At the start of a SEND operation, the buffering strategy control 525 prefetches the number of bytes of SEND data to fill the transmit buffers 528 or the number of the bytes of available SEND data, whichever is less. When the current buffer empties, the buffering strategy control 525 rotates the buffers such that the next buffer becomes the current buffer. After a predetermined number of buffers are empty, the buffering strategy control 525 connects the IDS 526 to the CDS 514 to fetch further data to refill the emptied buffers. When receiving data, with respect to RECEIVE, after the current receive buffer is filled, buffer rotation occurs and the next receive buffer becomes the current buffer. After a predetermined number of buffers are filled, the buffering strategy control 525 controls the IDS 526 to send the data to the CDS 514, rendering the filled receive buffers empty and again available. An example of a system utilizing the interface of the present invention will now be described. The example comprises a voice messaging scheme where data transmitted and received over the DL 511 is a full duplex PCM representation of the voice band signals. The IP 513 maintains a data base of voice storage wholly or partially in the CDS 51 and generates DTCs to control the playback from and recording to this data base. The following scenario details a series of events whereby a voice prompt is played out and a message is recorded: ) The following DTC are queued into the CQ by the IP for processing:
SET-TAG (L_ENK="a", TAG=1 )
This SET-TAG establishes the beginning of a group of SEND DTC which transmits the voice prompt data for recording a message. SEND . (LINK="b", TAG=1, IAST=FALSE, RECEIVE=FALSE)
This SEND transmits the first portion of the voice prompt: "Hello. This is John Smith. I'm out of the office right now. Please". SEND (LINK="c", TAG=1, LAST=FALSE, RECEIVE=FALSE)
This SEND transmits the second portion of the voice prompt: "state message after the tone, when finished with your". SEND (LINK«="d", TAG=1, IAST=TRUE, RECEEVE= FALSE) This SEND transmits this third portion of the voice proπpt: "message please press pound key." SET-TAG (LINK="e", TAG»2)
This SET-TAG establishes the beginning of a group of DTC which transmits a tone, initiates recording, and receives the recorded voice data.
SEND (LINK*"f", TAG=2, LAST=FA SE, RECEIVE=3RUE)
This SEND corresponds to the prompt tone: "beep", and the initiation of receiving voice data for recording. GET (LINK="g", TAG=2, IASTVFALSE)
This GET returns the first portion of received voice data . GET (LINK-'V, TAG=2, LAST=FALSE)
This GET returns the second portion of received voice data.
GET (LINK=ni", TAG=2, IAST=FA SE)
This GET returns the third portion of received voice data. GET (LINK="j", TAG=2, L&ST=TRUE). This GET returns the fourth portion of received voice data. SET-TAG (LINK="k", TAG=3)
This SET-TAG establishes the beginning of a group of DTC which transmits a final concluding prompt.
SEND (LINK=I,1", TAG=3, IAST=TRUE, RECEIVE=FAL_SE)
This SEND corresponds to the final prαipt: "Thank, you, Good-bye".
2) The ICP recognizes that the CQ is no longer empty, dequeues the first DTC, SET-TAG. This DTC establishes a new working tag, "1", for DTC processing. The ICP then returns a ETR for link "a".
3) The ICP dequeues the next ETC, SEND. The ETC fills the IDS transmit data buffers with data from the CDS to be transmitted. The transmission of data over the DL is started. As buffers within the IDS are emptied, additional data from the CDS is transferred to the IDS keeping the transmit buffers of the 55 1 IDS as full as possible. Because IAST=FALSE, when all data associated with SEND have been transferred to the IDS, the
ICP then returns a DTR for link "b" and continues to transfer data from the IDS over the DL. 5 4) The ICP dequeues the next DTC, SEND. The DTC continues to keep the IDS transmit data buffers filled with additional data to be transmitted.
5) The calling person, familiar with the voice messaging system and not desiring to hear the remainder of the voice prompting, - presses a DIMF key to skip forward.
6) The ICP detects the DTMF digit as a DL protocol event and initiates "internal termination" actions. The transmission of the data buffered in the IDS over the DL is stopped and data buffered in the IDS is discarded. The DTR, link "c", is returned for the current SEND. The ICP dequeues the next DTC, SEND. Because the TAG matches the working tag "1" an immediate DTR is returned for link "d" without any transmission.
7) The ICP dequeues the next DTC, SET-TAG. This DTC establishes a new working tag, "2", for DTC processing. The ICP then returns a DTR for link "e".
8) The ICP dequeues the next DTC, SEND. The DTC then fills the IDS transmit data buffers with data from the CDS to be transmitted. The transmission of the data over the DL is started. As buffers within the IDS are emptied, additional data from the CDS is transferred to the IDS keeping the transmit buffers of the IDS as full as possible. Because RECEIVE=TRUE, when all data associated with SEND has been transferred to the IDS and this data has been sent over the Π , the ICP initiates recording and returns a DTR for link "f". Data received from the DL is buffered in the IDS.
9) The ICP dequeues the next DTC, GET. As the recording of voice proceeds and buffers within the IDS are filled, these IDS buffers are emptied fr n the IDS to the CDS. Because LAST=FALSE, when all data associated with this GET has been transferred to the CDS, the ICP returns a DTR for link "g". 10) The ICP dequeues the next DTC, GET. As the recording 1 continues, additional IDS buffers are emptied to the CDS.
Because IAST=EALSE, when all data associated with this GET has been transferred to the CDS, the ICP returns a DTR for link "h". 5 11 ) The ICP dequeues the next ETC, GET. As the recording continues, additional IDS buffers are enptied to the CDS.
12) The user recording the message completes the message and as directed presses the "#" DTMF key.
13) The ICP detects the "#" DTMF digit as a DL protocol event
10 and initiates "internal termination" actions. The reception of data from the DL to the IDS is stopped. Receive data already buffered in the IDS continues to be enptied to the CDS. After all buffered data is enptied, the ICP returns a DTR for link "i". The ICP dequeues the next DTC, GET.
15 Because the IDS buffers are empty and the TAG matches the working tag an iπmediate UTR is returned for link "j".
14) The ICP dequeues the next ETC, SET-TAG. This ETC establishes a new working tag, "3", for ETC processing. The ICP then returns a ETR for link "k".
20 15) The ICP dequeues the next DTC, SEND. The DTC fills the IDS transmit data buffers with data from the CDS to be transmitted. The transmission of data over the DL is started. As buffers within the IDS are emptied, additional data from the CDS is transferred to the IDS keeping the transmit buffers of the 25 IDS as full as possible. Because IAST=TKUE, when all data associated with this SEND have been transferred to the IDS and all data has been sent over the DL, the ICP then returns a DTR for link "1". 16) The CQ now eπpty, the ICP awaits new DTC to arrive. 30 Although SET-TAG is described above as a separate
DTC, it is appreciated that the SET-TAG DTC can be eliminated and incorporated as an additional parameter to the SEND DTC. Generically, the SET-TAG function is performed by any means for grouping the queued DTCs into 35 logical or related sequences of commands .
The invention, as described above, provides an abstract interface between the computer system and the DL. This abstraction places the burden of interface details on the ICP/IDS/DLI implementation. This permits IP software to be structured around this high level abstract interface, providing software which is easier to develop and maintain. Additionally, the ICP/IDS/DLI implementation provides the capability of distributing DL oriented processing into elements that operate in parallel with the computer system. This is very significant when multiple DLs are utilized.

Claims

CLAIMS 1. A telephone network application platform for interfacing between a telephone network and at least one facsimile application program, said platform comprising: digital computer means programmed to be operative to perform telephone network facsimile functionality in response to facsimile commands issued by said facsimile application program, said telephone network facsimile functionality residing in said computer means independent of said facsimile application program and actuatable in response to said facsimile commands, said facsimile commands including a Send Fax command and a Receive Fax * command, said telephone network facsimile functionality including sending a facsimile message to said network and receiving a facsimile message from said network in response to said Send Fax command and said Receive Fax command, respectively, application interface means coupled to receive said facsimile commands from said facsimile application program and responsive to said facsimile commands for actuating said telephone network facsimile functionality in response to and in accordance with said facsimile commands, said application interface means being responsive to said Send Fax command and said Receive Fax command from said facsimile application program for activating said telephone network facsimile functionality by causing a facsimile message to be sent to said network and causing a facsimile message to be received from said network in response to said Send Fax command and said Receive Fax command, respectively, and facsimile interface means coupled between said network and said computer means for conveying said facsimile messages therebetween.
2. The platform of Claim 1 wherein said facsimile commands include a Poll and Recei Fax command, and said telephone network facsimile functionality includes sending a poll to a facsimile machine through said network and, in response to said poll, receiving a facsimile message from said facsimile machine through said nei rk in response to said Poll and Receive Fax command.
3. The platform of Claim 1 wherein said facsimile commands include a Send Fax after Poll command, and said telephone network facsimile functionality includes receiving a poll from a facsimile machine throu said network and, in response to said poll, sending a facsimile rr 3sage to said facsimile machine through said network in response to said Send Fax after Poll command.
4. The platform of Claim 1 further including platfo data storage means coupled to said computer means for storing said facsimile messages.
5. The platform of Claim 4 wherein said facsimile commands include a Create Fax command, and said telephone network facsimile functionality includes creating a facsimile message for storage in said platform data storage means in response to said Create Fax Message command by copying a message residing in a file of said facsimile application program into said platform data storage means.
6. The platform of Claim 4 wherein said facsimile commands include a Get Fax command, and said telephone network facsimile functionality includes getting a facsimile message from said platform data storage means into a file of said facsimile application program in response to said Get Fax command by copying a message residing" in said platform data storage means into a file of said facsimile application program.
7. The platform of Claim 4 wherein said facsimile commands include a Send Fax from File command, and said telephone network facsimile functionality includes sending a facsimile message from a file external to said platform data storage means to said network in response to said Send Fax from File command.
8. The platform of Claim 4 wherein said facsimile interface means comprises facsimile processor (FP) means including FP storage means for storing said facsimile messages to be sent to said networ and said facsimile messages received from said network, said facsimile processor means being programmed to be operative to perform FP functionality in response to FP commands, said FP functionality including transmitting a facsimile message stored in said FP storage means to said network and storing a facsimile message received from said network in said FP storage means.
9. The platform of Claim 8 wherein said application interface means includes facsimile server (FS) means responsive to said facsimile commands and operative to expand said facsimile commands into said FP commands and to issue said FP commands to said facsimile processor means for execution of said FP functionality in accordance therewith.
10. The platform of Claim 9 wherein said FP functionality includes answering an incoming call to said facsimile processor means and originating an outgoing call from said facsimile process means.
11. The platform of Claim 10 wherein said FP commands include an AnswerRcv command, and said F» functionality includes, in response to said AnswerRcv command, answering an incoming call to said facsimile processor means, receiving an incoming facsimile message over said incoming call and storing said incoming facsimile message in said FP storage means
12. The platform of Claim 10 wherein said FP commands include an OriginateRcv command and said FP functionality includes, in response to said OriginateRcv command, originating a call to a specified phone number, polling over said originated call for a facsimile message, receiving a facsimile message over said originated call and storing said received facsimile message in said FP storage means.
13. The platform of Claim 10 wherein said FP commands include an OriginateXmit command, and said FP functionality includes, in response to said OriginateXmit command, originating a call to a specified phone number and transmitting a facsimile message from said FP storage means over said originated call.
14. The platform of Claim 10 wherein said FP commands include an AnswerXmit command, and said FP functionality includes, in response to said AnswerXmit command, answering an incoming call and transmitting a facsimile message over said incoming call from said FP storage means when a poll is received over said incoming call.
15. The platform of Claim 10 wherein said FP commands include a RemoveFile command, and said FP functionality includes deleting a specified facsimile message from said FP storage means in response to said RemoveFile command.
16. The platform of Claim 10 wherein said FP commands include a SendFile command, and ' said FP functionality includes transferring a specified facsimile message from said facsimile server means to said FP storage means in response to said SendFile command.
17. The platform of Claim 10 wherein said FP commands include a ReceiveFile command, and said FP functionality includes transferring a specified facsimile message from said FP storage means to said facsimile server means in response to said ReceiveFile command.
18. The platform of Claim 9 wherein said facsimile processor means comprises a personal computer, and said FP storage means comprises a personal computer hard disk drive.
19. The pJ tform of Claim 10 wherein said facsimile processor means includes FP ports through which said facsimile messages conveyed etween said FP storage means and said network are transmitted.
20. The platform of Claim 19 further including network interface means (NIU) having NIU ports coupled to said network, to said computer means and to said FP ports, and wherein said platform interfaces between said telephone network and one or more application programs requiring voice functionality, facsimile functionality and call connectivity functionality, said digital computer means is programmed to be operative to perform telephone network functionality in response to commands issued by said application programs, said telephone network functionality residing in said computer means independent of said application programs and actuatable in response to said commands, said application interface means is coupled between said application programs and said computer means and responsive to said commands from said application programs for actuating said telephone network functionality in response to and in accordance with said commands, said commands include NAP cail connectivity commands, NAP voice commands and said facsimile commands, said telephone network functionality comprises NAP telephone network call connectivity functionality, NAP telephone network voice functionality and said telephone network facsimile functionality actuatable in response to said NAP call connectivity commands, said NAP voice commands and said facsimile commands, respectively, said NAP call connectivity commands and said NAP voice commands comprises NAP commands, said NAP telephone network call connectivity functionality and said NAP telephone network voice functionality comprising NAP functionality, and said NAP telephone network call connectivity functionality is operative to activate and interconnect said NIU ports.
21. The platform of Claim 20 wherein said application interface means includes said facsimile server means for actuating said facsimile functionality in response to said facsimile commands and further includes an AIM portion for actuating said NAP functionality in response to said NAP commands.
22. The platform of Claim' 21 wherein said facsimile server means is further operative to expand said facsimile commands into said FP commands and said NAP commands and to issue said NAP commands to said AIM portion for actuation of said NAP functionality in accordance with said NAP commands. •
23. The platform of Claim 22 further including communication means (COMS) interposed between said applications and said application interface means for directing said facsimile commands to said facsimile serve means and said NAP commands to said AIM portion.
24. The platform of Claim 23 wherein said facsimile server means is further operative to issue said NAP commands to said AIM portion through said COMS.
25. The platform of Claim 22 wherein said application interface means is operative to provide Responses to said application program, said Responses including an Incoming Call response engendered by said platform receiving a telephone call from said network, said NAP commands include a CONNECT CALL command and said NAP functionality includes switching said NIU ports in response to said CONNECT CALL command, said NAP commands include an INITIATE CALL command and said NAP functionality includes initiating a telephone call to said network in response to said INITIATE CALL command, said NAP commands include a CREATE VOICE MESSAGE command and said NAP functionality includes creating. a message for storage in said platform data storage means in response to said CREATE VOICE MESSAGE command by copying a message residing in a file external to said platform data storage means into said platform data storage means, and said NAP commands include a GET VOICE MESSAGE command and said NAP functionality includes getting a message from said platform data storage means into a file external to said platform data storage means in response to said GET VOICE MESSAGE command by copying a message residing in said platform data storage means into a file external to said platform data storage means.
26. The platform of Claim 25 wherein said facsimile server means is further operative to expand said facsimile commands to include said CONNECT CALL command for switching said NIU ports so as to connect an NIU port with an FP port.
27. The platform of Claim 25 further including FS storage means, said facsimile server means being operative to temporarily store facsimile messages in said FS storage means.
28. The platform of Claim 27 wherein said facsimile commands include facsimile sending commands for sending facsimile messages to said network and facsimile receiving commands for receiving facsimile messages from said network, said Send Fax command and said Receive Fax command being a facsimile sending comman and a facsimile receiving command, respectively, said facsimile server means is operative to expan a facsimile sending commari into said GET VOICE MESSAGE command for transferring facsimile message from said platform data storage ι_ιea».j to said FS storage means and into an FP command for transferring said facsimile message from said FS storage means to said FP storage means, and said facsimile server means is operative to expan a facsimile receiving command into an FP command for transferring a facsimile message from said FP storage means to said FS storage means and into said CREATE VOICE MESSAGE command for transferring said facsimile message from said FS storage means to said platform data storage means.
29. The platform of Claim 20 wherein said application interface means communicates with said application program in dialogs, voice messages and facsimile messages are conveyed through said NIU over a common connection currently established during a dialog,
NIU ports are switched between voice ports and facsimile ports, and voice messages and facsimile messages are commonly stored in said platform data storage means.
30. The platform of Claim 9 wherein said facsimile commands include at least one command operative to transfer a facsimile message from said FP storage means to said platform data storage means, said facsimile message having been received from said network, said application program is operative to assign a unique Recovery Token to a facsimile message to be received from said network pursuant to a facsimile command, said application program having an application Recovery Token table for storing said Recovery Tokens, said Recovery Token being passed to said facsimile server means as part of a facsimile command issued thereto, said facsimile server means includes an FS Recovery Token table for storing said Recovery Tokens passed thereto from said application program, and said facsimile server means is operative to notify said application program of a successful transfer of a facsimile message from said FP storage means to said platform data storage means and further operative to remove from said FS Recovery Token table, a Recovery Token associated with a facsimile message successfully transferred from said FP storage means to said platform data storage means.
31. The platform of Claim 30 wherein said FS is operative to remove said Recovery
Token from said FS Recovery Token table upon receipt by said platform from said application program of a next command following notification of said application program by said facsimile server means of said successful transfer of a facsimile message.
32. The platform of Claim 30 wherein said facsimile commands include a Recover Fax command, said Recover Fax command conveying a Recovery
Token therewith, and said telephone network facsimile functionality includes transferring a facsimile message identified by said Recovery Token from said FP storage means to said platform data storage means and notifying said application program of said transfer.
EP93907247A 1992-03-05 1993-03-05 Telephone network application platform for supporting facsimile applications Withdrawn EP0629329A1 (en)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US07/847,150 US5323450A (en) 1992-03-05 1992-03-05 Telephone network application platform for supporting facsimile applications
US847150 1992-03-05
PCT/US1993/002005 WO1993018610A1 (en) 1992-03-05 1993-03-05 Telephone network application platform for supporting facsimile applications

Publications (1)

Publication Number Publication Date
EP0629329A1 true EP0629329A1 (en) 1994-12-21

Family

ID=25299896

Family Applications (1)

Application Number Title Priority Date Filing Date
EP93907247A Withdrawn EP0629329A1 (en) 1992-03-05 1993-03-05 Telephone network application platform for supporting facsimile applications

Country Status (5)

Country Link
US (1) US5323450A (en)
EP (1) EP0629329A1 (en)
JP (1) JPH07504553A (en)
CA (1) CA2130112A1 (en)
WO (1) WO1993018610A1 (en)

Families Citing this family (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
ES2070731B1 (en) * 1993-04-05 1997-10-16 Telelinea S L RECEIVING SYSTEM OF INFORMATION WRITTEN THROUGH A FAX, FROM A DATABASE.
US5590339A (en) * 1993-08-23 1996-12-31 Macronix International Co., Ltd. Input device interface with power connect state and serial data channel enabling power to the device from time to time
US5828836A (en) * 1993-10-08 1998-10-27 International Business Machines Corporation Networked information communication system
JPH07210475A (en) * 1994-01-14 1995-08-11 Fujitsu Ltd Method and device for data transmission processing
JPH07288630A (en) * 1994-04-20 1995-10-31 Canon Inc Image processor
US5633916A (en) * 1994-12-30 1997-05-27 Unisys Corporation Universal messaging service using single voice grade telephone line within a client/server architecture
JP3471988B2 (en) * 1995-09-19 2003-12-02 株式会社リコー Facsimile machine
US5826026A (en) 1995-11-09 1998-10-20 Connect-One, Ltd. Internet message communicator with direct output to a hard copy device
US7898675B1 (en) * 1995-11-13 2011-03-01 Netfax Development, Llc Internet global area networks fax system
US5695331A (en) * 1996-01-18 1997-12-09 Btu International Multiple width boat carrier for vertical ovens
US5937029A (en) * 1996-08-02 1999-08-10 Nice Systems, Ltd. Data logging system employing M N +1! redundancy
WO1998013993A1 (en) * 1996-09-25 1998-04-02 British Telecommunications Public Limited Company Apparatus for communications service provision
US6473404B1 (en) 1998-11-24 2002-10-29 Connect One, Inc. Multi-protocol telecommunications routing optimization
US6016307A (en) 1996-10-31 2000-01-18 Connect One, Inc. Multi-protocol telecommunications routing optimization
US6046824A (en) * 1997-02-06 2000-04-04 Nice Systems, Ltd. Facsimile long term storage and retrieval system
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
US6430177B1 (en) 1998-06-09 2002-08-06 Unisys Corporation Universal messaging system providing integrated voice, data and fax messaging services to pc/web-based clients, including a content manager for receiving information from content providers and formatting the same into multimedia containers for distribution to web-based clients
US6148329A (en) * 1998-07-20 2000-11-14 Unisys Corporation Method and system for maintaining the format of messages in a messaging system database
US6504915B1 (en) 1998-09-25 2003-01-07 Unisys Corporation Multiple node messaging system wherein nodes have shared access to message stores of other nodes
EP1236338A4 (en) * 1999-06-14 2004-08-25 Ascendent Telecommunications I Method and apparatus for communicating with one of plural devices associated with a single telephone number
US7162020B1 (en) 1999-06-14 2007-01-09 Ascendent Telecommunications, Inc. Method and apparatus for selectively establishing communication with one of plural devices associated with a single telephone number
US7292858B2 (en) 1999-06-14 2007-11-06 Ascendent Telecommunications, Inc. Method and apparatus for communicating with one of plural devices associated with a single telephone number during a disaster and disaster recovery
US7680511B2 (en) 2000-06-14 2010-03-16 Ascendent Telecommunications Inc. Method and apparatus for communicating via virtual office telephone extensions
US7327832B1 (en) 2000-08-11 2008-02-05 Unisys Corporation Adjunct processing of multi-media functions in a messaging system
US7095828B1 (en) 2000-08-11 2006-08-22 Unisys Corporation Distributed network applications platform architecture
US7116764B1 (en) 2000-08-11 2006-10-03 Unisys Corporation Network interface unit having an embedded services processor
US7965825B1 (en) 2005-05-02 2011-06-21 Callwave, Inc. Methods and systems for transferring voice messages and faxes over a network

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4827349A (en) * 1985-04-30 1989-05-02 Canon Kabushiki Kaisha Communication terminal device
JPS62227269A (en) * 1986-03-28 1987-10-06 Ricoh Co Ltd Facsimile communication system
US4935955A (en) * 1988-06-03 1990-06-19 Neudorfer Julius N Facsimile PBX with storage and security
JPH0813075B2 (en) * 1988-07-01 1996-02-07 村田機械株式会社 Facsimile communication system
US4994926C1 (en) * 1988-09-22 2001-07-03 Audiofax Ip L L C Facsimile telecommunications system and method
US4922348B1 (en) * 1989-02-10 1994-10-11 Bell Telephone Labor Inc Facsimile service
US4974254A (en) * 1989-05-10 1990-11-27 Perine Michael C Interactive data retrieval system for producing facsimile reports
WO1991003115A1 (en) * 1989-08-18 1991-03-07 The Complete Pc A system and method for forwarding facsimile messages
US5133004A (en) * 1990-05-07 1992-07-21 Unisys Corporation Digital computer platform for supporting telephone network applications

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See references of WO9318610A1 *

Also Published As

Publication number Publication date
JPH07504553A (en) 1995-05-18
WO1993018610A1 (en) 1993-09-16
US5323450A (en) 1994-06-21
CA2130112A1 (en) 1993-09-16

Similar Documents

Publication Publication Date Title
EP0629329A1 (en) Telephone network application platform for supporting facsimile applications
JP3429415B2 (en) Video messaging system and video communication terminal and video message server
US5633916A (en) Universal messaging service using single voice grade telephone line within a client/server architecture
US5488651A (en) Fax message system
US5349636A (en) Interface system and method for interconnecting a voice message system and an interactive voice response system
US5193110A (en) Integrated services platform for telephone communication system
US5291546A (en) Fax message system
JP3201765B2 (en) Digital computer platform to support telephone network applications.
US6157464A (en) Facsimile store and forward system with local interface
US5260990A (en) Multiple integrations unit for coupling different switching systems to a message storage system
JP3510492B2 (en) A system for coordinating calls between ancillary equipment and the switching system
US6088126A (en) Fax overflow loopback prevention
EP0662762A2 (en) Voice mail network
US5455852A (en) Method and apparatus for defining parameter transmission protocols for a call intercept/message delivery telephone system
WO1991001608A1 (en) Electronic mail broadcasting system
US8054947B2 (en) Apparatus and method for multiplexing communication signals
JPH07212746A (en) Network system allowing picture communication
JP4142265B2 (en) Multimedia message transmission based on Internet protocol standards
JPH09186782A (en) Isdn terminal unit with data interface
JPH03270537A (en) Electronic mail information storage transfer system
JP2823389B2 (en) Facsimile mail service system
JP3114742B2 (en) Mail processing device
JPH0351344B2 (en)
JP2763122B2 (en) Facsimile storage and switching equipment
JP2729696B2 (en) Automatic switching system with facsimile terminal proxy function

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

17P Request for examination filed

Effective date: 19940819

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): DE FR GB IT SE

17Q First examination report despatched

Effective date: 19960216

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN

18D Application deemed to be withdrawn

Effective date: 19960627