This application claims the benefit under 35 U.S.C. § 119 of Australian Patent Application No. 2006 203 578 filed on Aug. 16, 2006, and of Australian Patent Application No. 2007201506 filed on Apr. 4, 2007, which applications are incorporated entirely herein by this reference.
The present invention relates to a method, system, computer program product and/or computer readable medium of instructions for improved delivery of electronic documents using regular expressions. More particularly, a graphic image file is created at a sender's computer terminal and transmitted to a server as part of an electronic document for onward delivery of the graphic image file to a recipient via various means such as, for example, a standard postal or mail network, email and/or facsimile.
Australian Patent No. 2003254402, filed on 28 Aug. 2003 by the present Applicant, is directed to an automated hybrid mail system/method which sends a graphic image file from a sender's terminal into a postal network via a remote printing facility. The system can check the recipient's address is correctly located on the graphic image file before sending and (optionally) verifying the recipient's address and adding a correct Delivery Point ID and bar code. However, the subject matter of Australian Patent No. 2003254402 does not provide suitable ability to handle “regular expressions”, as hereinafter discussed, which provides a significant advantage and improvement over the subject matter disclosed in Australian Patent No. 2003254402.
In the system disclosed in Australian Patent No. 2003254402, addresses can be extracted and printed on cover sheets that are visible through an address window of a windowed envelope. In this prior system it can be beneficial for a user to include a reference, for example alpha-numeric characters, on the first line of an address for document identification purposes. These forms of references, allow the user to identify letters/documents. Such a reference can be included in an address as non-printing, non-printable or non-visible text, for example as white text on a white background. The server software can then suppress them from cover sheets and returned mail reports.
In various legacy systems/software, for example used to produce an application document, it may be impractical to colour a reference in a particular colour, for example as white text or as the same colour as a particular background, to blend into the background and not be visible. In this situation, the prior system/software can delete the reference from the files after processing but prior to printing. This allows legacy systems to print the reference in black in the print stream, but for the reference not to been seen on the final printed document/letter. However, no additional use is made of the reference.
Moreover, Australian Patent No. 2003254402 is directed delivery of a hardcopy document via a postal or mail network, whereas the present invention is not limited to delivery of documents only into a postal network.
This identifies a need for a method, system, computer program product and/or computer readable medium of instructions to provide for new or improved uses of regular expressions, for example non-printable regular expressions.
‘Terminal’ means a device in a networked data or information communications system which is capable of requesting and receiving information from local or remote information sources. The capability of the terminal to request and/or receive information can be provided by an application program, hardware or other such entity. A terminal may be provided with associated devices, for example an information storage device such as a hard disk drive and a display screen. A terminal may be a computer or computerised device, a personal computer (PC), a type of mobile or cellular phone, a mobile data terminal, a portable computer, a personal digital assistant (PDA), a pager, a thin client, or any other similar type of electronic device.
‘Computer Network’ as referenced in this specification should be taken to include all forms of connected or communicating terminals having at least two terminals connected or communicating so as to be able to transfer information or data. That is, the term computer network should be taken to include any type of terminal or part thereof, as defined herein, which is rendered such that it is capable of communicating with at least one other terminal. The communication of information or data can occur over any data communications network, computer network, wireless network, inter-network, intra-network, local area network (LAN), wide area network (WAN), the Internet and developments thereof, transient or temporary network, combinations of the above or any other type of network providing for computerised, electronic or digital devices.
‘Postal Network’ means any form of network or system for distribution of physical mail, such as hardcopy documents or letters, and includes government or private postal services, a firm of couriers, or any other network or system whereby a hardcopy document can be delivered to a recipient's physical address.
‘Application Document’ means a document produced by a user on a terminal using any application program, or received by a user on a terminal. Examples of application documents include word-processing documents produced by, say, Microsoft Word, a spreadsheet, an invoice produced from an accounting package, or a document produced by a desktop publishing package.
‘Graphic Image File’ means an electronic file with graphical information that can be used to reproduce an original application document in a form whereby what the user sees on the terminal screen is the same as when the graphic image file is printed. An example of a graphic image file could be a file in Postscript, Portable Document Format (PDF), Printer Command Language (PCL) or Microsoft Enhanced Metafile Format (EMF).
‘Electronic Document’ means an electronic file that can be stored on a terminal or transmitted over a computer network.
‘Hardcopy Document’ means a document printed on paper or a similar medium.
According to a first broad form, there is provided a method of delivering a document to a recipient, the method including: receiving an electronic document from a terminal, the electronic document including at least a graphic image file, the graphic image file obtained from an application document and a regular expression extracted or obtained from the graphic image file; and, sending the graphic image file to the recipient, with at least one sending option specified by the regular expression.
According to a second broad form, there is provided a system for delivering a document to a recipient, the system including one or more servers configured to receive an electronic document, the electronic document including at least a graphic image file, the graphic image file obtained from an application document and a regular expression extracted or obtained from the graphic image file, the one or more servers also configured to send the graphic image file to the recipient, with at least one sending option specified by the regular expression.
According to a third broad form, there is provided a computer program product for delivering a document to a recipient, the computer product configured to: process, at one or more servers, an electronic document transmitted from a terminal, the electronic document including at least a graphic image file, the graphic image file obtained from an application document and a regular expression extracted from the graphic image file; and, transmit the graphic image file, from the one or more servers, to the recipient, with at least one sending option specified by the regular expression.
According to a fourth broad form, there is provided a computer program product for delivering a document to a recipient, the computer product configured to: produce, at a terminal, an electronic document including at least a graphic image file, the graphic image file obtained from an application document and a regular expression extracted from the graphic image file; and, transmit the electronic document from the terminal to one or more servers, whereby the one or more servers are configured to send the graphic image file to the recipient, with at least one sending option specified by the regular expression.
In various non-limiting example aspects: the regular expression is not printed or is suppressed from printing as part of the graphic image file; the regular expression is extracted by software resident on the terminal; the regular expression is an alpha-numeric string; the regular expression is located within or near an address area; and/or the regular expression is part of the name of the application document.
Preferably, though not necessarily, the sending option specified by the regular expression is selected from one or more of the group: a processing option; a delivery option; an attachment option; a letterhead option; an account option; an envelope option; an insert option; a delivery time option; an archive option; and a stock option.
In other various non-limiting example aspects: the regular expression includes an option parameter; the regular expression triggers a rule that automatically includes an option parameter; and/or the regular expression is an alpha-numeric reference.
According to further specific but non-limiting examples: the processing option suppresses printing a first page of the graphic image file; the delivery option sets delivery via one or more of: post; email; and facsimile; the attachment option attaches one or more attachments to the graphic image file; the letterhead option controls which particular letterhead is under-laid the graphic image file; the account option associates a particular account with delivery of the document; the envelope option controls which particular logo is presented on an envelope, when document delivery is via post; the insert option inserts one or more inserts into an envelope, when document delivery is via post; the delivery time option controls when the graphic image file is transmitted or printed; the archive option controls archiving of the graphic image file or a version of the graphic image file; the stock option controls on which particular stock the graphic image file is printed, when document delivery is via post; and/or the regular expression is suppressed from the application document before producing the graphic image file.
Preferably, though not necessarily, the regular expression includes a unique identifier.
In a further particular example embodiment, the electronic document includes an instruction file containing printing or delivery instructions. The instruction file may also contain a unique identification number and/or a representation of the unique identification number may be printed on the graphic image file and/or a hardcopy document.
It should be appreciated that the preferred embodiment is not limited to delivery of printed documents into a postal network. For example, a document may be delivered by post, email or facsimile from the server. However, further description of an embodiment utilizing delivery by post is given by way of example.
It should be noted that the application document itself need not necessarily actually be produced on the client terminal, the application document could be produced elsewhere and sent to the client terminal. Also, the sender need not necessarily be the creator of the application document.
In a particular form, a representation of the unique identification number is added to the graphic image file or the hardcopy document, for example as a bar code or magnetic code, and this representation of the unique identification number can be used for tracking, for example within a postal network until a hardcopy document reaches the recipient or recipient's address. Preferably, if an optical code, such as a bar code, is used the code is readable through the window of an envelope. This allows the document to be tracked from creation to delivery in both electronic and physical form.
In a further particular form, the server (or network of servers) receives notification of receipt and/or printing and onward delivery of the hardcopy document and updates records in a database, and/or notifies the sender of this action by electronic mail. Details of the transaction can also be recorded in the database for billing purposes.
In another embodiment, an electronic document received by the server can be quarantined on the server if a sender's account is not active, for example if the sender has not made previous payments, has no account or has no credit. An electronic notification can be sent to the client terminal alerting the sender to the electronic document having been quarantined.
In a particular example, when intended for delivery into a postal network the graphic image file may be routed to a printer close or closest to, or most conveniently located to, the indicated recipient's address. Also preferably, the sender is only required to instruct the client-side software to transmit the electronic document to the server, with the client-side software and/or server-side software handling further aspects of delivery into the postal network.
In various alternative forms, the position of the recipient's address, for example in a graphic image file, can be checked by:
the client-side software;
the sender, by way of the graphic image file being presented in a preview screen with a recipient address boundary mask overlayed; and/or
the server-side software rechecking the position.
In a further example embodiment, the client-side software resident on the client terminal, or the server-side software, extracts the text positioned at the location of the recipient's address area from the graphic image file and attempts to verify that the text constitutes a valid address. For example, by checking that a valid postcode or suburb name has been included. In another form, optical scanning recognition software is used to convert the recipient address component of the graphic image file to text form, which is then checked to seek to verify that the text constitutes a valid address.
According to still further aspects, the graphic image file can be checked to verify the graphic image file can be processed by a mailhouse. The checks can include: that the fonts in the graphic image file are supported by the mailhouse; an address is provided; and/or a valid address is provided according to parameters for correct addressing in the destination country. Also, the graphic image file could be moved or re-sized to allow for page barcodes, or other indicia inserted by the mailhouse.
In another example form, the client-side software, or the server-side software, reads and looks up the recipient's address in a postal address file and generates an address representation, for example a barcode representation of the recipient's address or a suitable Delivery Point Identification (DPID) to facilitate transmission to an appropriate printer and/or the recipient.
In a particular embodiment, the client-side software allows the sender to preview the graphic image file and displays an overlay or mask showing the preferred location for the recipient's address. Moreover, the client-side software allows the sender to relocate or delete the graphical elements that form the graphic image file whilst in this preview mode. For example, the position of the recipient's address could be relocated if not within the preferred location. The software may also provide the sender with the option to delete components in the address area and to manually type in text indicating a correct address, which is then incorporated into the graphic image file before transmission of the electronic document to the server.
The client-side software can compress and/or encode the graphic image file into a format suitable for electronic transmission. Furthermore, according to a particular embodiment, the client-side software encrypts the electronic document using public key encryption before electronically transmitting the electronic document to the server. The electronic document can also be digitally signed.
In a particular example form, the server is programmed with rules that enable the server to forward the graphic image file from the received electronic document to a printer close or closest to, or most conveniently located to, the recipient's address.
According to a further particular form, in the case where the application document consists of a set of separate documents to be delivered to separate recipients—for example, the results of a mail merge job in a word-processing application—special codes are incorporated at the end and/or beginning of the mail merge template to establish the start and the end of individual application documents. This allows a large mail merge job to be separated into the individual component documents at the client terminal, which further allows the documents to be processed on the server without human intervention. Also, an analysis of the structure of each application document can be performed to determine start and end points of each of the documents or collection of documents.
In a particular embodiment, one or more printers, when utilised, may be managed by a printer server which receives the graphic image file and sends an electronic notification message back to the originating server.
In a further example mode of operation, one or more printers, when utilised, are integrated into a postal network and all necessary facilities for printing, folding, inserting and lodgement of hardcopy documents into the postal network is provided.
In a particular embodiment, one or more printers, when utilised, can be managed by a server computer (or network of servers) which manages the process of receiving the graphic image files, decoding the graphic image files, and printing the hardcopy document. In another embodiment, these printer servers can be programmed with rules to forward graphic image files to other printers in the event of printer breakdown or overloading.
According to another embodiment, the system/method can be designed to operate as a multi-level distribution system/method where intermediate resellers and individual salespersons can be cross-linked to the final mailed hardcopy document and be provided with a commission based on transaction value.
The present invention should become better understood from the following detailed description of a preferred but non-limiting embodiment thereof, described in connection with the accompanying figures, wherein:
In preferred, but non-limiting embodiments of the present invention, there is provided a method, system, computer program product and/or computer readable medium of instructions to facilitate improved delivery of a hardcopy and/or an electronic copy of an application document, which in one example form is delivery of a hardcopy via a postal network. However, it should be appreciated that the present invention is not limited to delivery of printed documents into a postal network. For example, a document may be delivered by post, email or facsimile via the server.
Referring to
The sender 11 uses software resident on the client terminal 14 to convert the application document 13 into a graphic image file by using an image capture tool 15. Preferably, this image capture tool exists as a printer driver which can be selected from within a standard software program provided with a print function. This produces a graphic image file from the application document, or multiple graphic image files of a multiple page application document.
The automated address checking procedure 16 checks the location of the recipient's address in the graphic image file. The automated address checking procedure 16 can also check that the postal address is valid. The automated address checking procedure 16 determines if there is text in the correct location or uses a preview screen with a mask overlay to determine address field boundaries, or allow the sender to manually inspect the address position. If there is text and the text appears to be a valid address, for example there is a recognisable postcode or suburb name, then the automated address checking procedure 16 can generate a barcode representation of the address and/or look up the address in a postal address file and generate a suitable address representation (e.g. barcode) or Delivery Point Identification (DPID) to assist in forwarding the graphic image file to an appropriate printer. If the address is not satisfactory or not valid, the software can prompt the sender 11 to correct the address. In an alternative particular embodiment, the user checks the address location visually using a preview screen with a boundary mask showing the correct location of the address. In a further alternative embodiment, the sender can type in the recipient's address manually or retrieve the recipient's address from an electronic address book database on the terminal.
According to various non-limiting embodiments, the following general steps can be provided:
1. Letters and attachments, as application documents, are captured or generated using a printer driver.
2. The graphic image file produced by the printer driver has a default standard address area, that may or may not correspond to a standard location for the address to be visible through the window of a window envelope. The default standard address area occurs if no previous manual selection has been made.
3. The address location that was last manually selected by the user/sender can be remembered, for example if the application document has the same name or other indicator.
4. The user can overwrite any automatic or previous manual address location selection by manually selecting an address area. This manual selection can occur by the user making a single mouse click, multiple mouse clicks, or drawing or dragging a rectangle around or over all or part of the address.
5. Application documents or graphic image files can be automatically identified and an associated target address can be extracted, even if parts of the address stray outside of a selected address area.
6. Margins in an application document or corresponding graphic image file can be checked to ensure that room is provided for page barcodes, optical mark recognition codes, or other suitable identifiers/codes. If the margins are too small the page image can be automatically, or manually, shifted or reduced to clear the required margin space.
7. The address location/window can be checked to see that it only includes the target or intended address. If the address window is not clear, i.e. it may contain unwanted text or images, a cover page can be added to the graphic image file (i.e. letter to be mailed) with the address located in a correct position on the cover page, for example for correct display of the address through the window of a window envelope. The address location in the cover sheet could be inserted or manipulated as per preceding steps 2, 3 or 4.
8. Optionally, the target address can be analysed to check that it appears to be a correct or valid address. Preferably, but not necessarily, this process occurs on the client terminal, it could occur on the server. The address may be corrected according to local postal standards, for example for format, barcode or DPID. If the address is amended, the new address is then placed in the address window, whether it be a first page of a letter or a cover page as previously discussed. Alternatively, the address can be checked against a database of correct or valid addresses. If the address does not match, an address from the database can be used. The database could reside local or remote to the client terminal.
9. Page barcodes, optical mark recognition codes, or other suitable identifiers/codes, can be added to any or all of the pages of the graphic image file (letter), including any cover sheet.
10. A graphic image file, i.e. letter, once transmitted, can then be sorted according to local postal standards, for example by postcode or suburb, and then printed, folded, inserted into an envelope for entry into the standard physical postal network.
When the recipient's address is satisfactory, the graphic image file is (optionally) compressed and encoded, the client-side software then creates an electronic document 17 which includes the graphic image file 17a, a unique identification number 17b (for tracking the graphic image file or electronic document) and an instruction file 17c. Preferably, but not necessarily, the electronic document 17 is also encrypted and can include a digital signature. Also preferably, but not necessarily, the unique identification number 17b may form part of the instruction file 17c. The instruction file 17c is preferably an XML file containing instructions for the handling of the electronic document 17, for example the instruction file 17c may contain, inter alia:
the unique identification number 17b, used to track the electronic document and for billing purposes;
the sender's account number or details, used for billing and verification purposes, and for the prevention of fraudulent use;
a unique identifier for the client terminal 14, used for tracking and verification of authenticity;
the number of pages or a return email address;
identification numbers for any intermediate resellers, and any individual salespersons, who are involved in a multi-level distribution of the present system, the identification numbers could be used to calculate commissions due to salespersons or sales-teams, for example the intermediate reseller identification numbers can be stored in the database 22 indexed against the sender's account number; and/or
printing instructions, for example colour or black and white, post via express mail, etc.
The electronic document 17 is passed to a queue manager 18 and then electronically transmitted 19 from the client terminal 14 over the computer network 20 to the server computer 21 (which may be a network of computers).
The queue manager 18 can send the electronic document 17 immediately or send several electronic documents in a batch. A server computer message handler receives the electronic document 17, and if required performs decoding/decrypting, verifies the digital signature, and extracts the recipient's address, postcode and/or DPID from the instruction file 17c. Optionally, the server-side software resident on the server 21 can perform further address checking, similar to the automated address checking procedure 16 on the client terminal 14, as an additional checking procedure.
The server-side software can handle incoming electronic documents, check the sender's account status, parse the instruction file associated with an electronic document, decode any encoded format files, decrypt and verify data, extract a recipient's address, track the incoming electronic document, record billing data, handle errors, manage the printing of the hardcopy document, re-encrypt and forward an electronic document to another remote server, or transmit the electronic document using another form of communication. Furthermore, the server-side software can handle onward sending of an email including at least the graphic image file and/or facsimile transmission of at least the graphic image file. Email or facsimile transmission to a recipient may be handled by a separate server(s) or the server receiving the electronic document.
An electronic document 17 received by the server 21 can be quarantined on the server 21 if a sender's account is not active, for example if the sender has not made previous payments, has no account or has no credit. An electronic notification 28 can be sent to the client terminal 14 alerting the sender 11 to the electronic document 17 having been quarantined.
After verifying the sender's account details, this information is passed to a message forwarder in the server computer 21 which follows a set of rules to decide which is a suitable mail distribution centre printer to receive the graphic image file 17a, for example which is the closest mail distribution centre printer to the recipient's address. Information concerning the receipt or transmittal of electronic documents, graphic image files or any other information relating to the transaction, for example data from the instruction file 17c, can be recorded in the database 22.
The graphic image file 17a is electronically transmitted 23 to the selected printer/printer server 24, and the server 21 records the transaction in the database 22, which can be indexed by the unique identification number 17b.
The printer/printer server 24 sends an electronic notification message 27 back to the server computer 21 detailing the results of the printing operation. On receipt of the electronic notification message 27, the server-side software updates the database 22 and, either automatically or if requested (i.e. optionally), forwards a further electronic notification message 28 to the client terminal 14 so as to inform the sender 11 of the success, or otherwise, of the delivery of the hardcopy document 25 into the postal network 26. The electronic notification message 28 could also be initially either automatically or if requested (i.e. optionally), transmitted to the client terminal 14 to confirm receipt of the electronic document 17 by the server 21.
In an alternate non-limiting embodiment, the complete electronic document 17 could be sent to the printer server. If the complete electronic document 17 is transmitted, the electronic document 17 is received by the printer server's message handler, which, if required, decodes the electronic document 17 and sends the graphic image file 17a to it's local printer.
The resulting hardcopy document 25 is inserted into an envelope to form a letter which is then submitted into the postal network 26 for distribution to the recipient's address, and thus the recipient 12, via the postal network 26. The formation of the letter could be an automated process performed at the mail distribution centre.
In a further possible embodiment, server-side software resident on the server 21 reads the recipient's address and generates a suitable barcode or DPID, or uses a barcode or DPID generated at the client terminal 14, so as to add the barcode or DPID to the hardcopy document 25 or the envelope for faster, cheaper or more efficient delivery via the postal network 26.
In a further example, the splitting of mail merges into individual letters is provided. A mail merge is a set of similar documents generated on a computer and intended for multiple recipients. It is normally sent to a printer as a single document print job and the user then is required to manually sort the printed hardcopy pages for each recipient. Therefore, if the mail merge is a two-page document to one hundred recipients, it is sent to the printer as a single two hundred page document. The system can use special codes at the end and/or beginning of a mail merge template to establish the start and the end of each individual document and can therefore break-up a two hundred page single document into the one hundred separate two-page documents. This therefore allows the system to automatically process the documents on the server without human intervention. If this was not the case, it would be required to manually process/sort the documents before posting, or the first recipient would receive all the merged documents in the post. This allows the mail merge to be performed on the client terminal 14 rather than the server 21. This same principle applies to any job where multiple letters are sent to the printer as one job, i.e. end of month statement runs, etc. Alternatively, the entire mail merge job can be sent as a whole and the processing into separate documents is carried out by software on the server.
Referring to
In another embodiment, access to the status of delivery of documents can be provided by allowing a sender 11 to log into the server 21 via a web browser and query the status of electronic or hardcopy documents by using the unique identification number and an account number and password.
In a further alternative embodiment, a mail distribution centre, for example a local post office, prints the graphic image file 17a. This ensures that the first time the hardcopy document 25 enters the postal network the hardcopy document 25 is free from dangerous biological or chemical agents, or other hazardous material. This procedure also ensures that the hardcopy document 25 is “least cost” routed by electronic means to a physical printing point closest or close to the recipient's address, and not the sender. That is, physical transportation costs associated with hardcopy documents are reduced.
According to a further aspect of a non-limiting embodiment, and referring to
Virtual Letterhead
According to a further aspect, there is provided a “virtual letterhead”. In one form, users may elect to print one or more letters in a single print stream using image capture tool 15, for example which can be provided as a selectable specific printer. In this form, content that needs to be repeated for each letter (e.g. logo, return address, contact information, disclaimers, etc.) must be included in the original print steam. This makes the original print stream larger than necessary thereby causing processing delays (e.g. the letters take longer to print and to analyse). In some cases, users may have existing application documents 13 that were designed to be printed on a page of paper provided with a pre-printed letterhead. It may not be cost effective for these users to change the legacy applications that generate such letters.
In an enhanced form, users are able to print a letterhead or the like using image capture tool 15, for example a printer driver, and save the letterhead as a “virtual letterhead”. Users would then be able to select one or more virtual letterheads to be used with one or more letters. Furthermore, a user's letterhead might be split up into composite parts, for example one set for the headers and another for the footers. The virtual letterhead, or composite parts thereof, could be applied to letters using the following rules:
1. If the letterhead consists of a single page, then the letterhead would be printed on the first page of each letter.
2. If the letterhead consists of n pages (where n is greater than 1), then the first n−1 pages of the letterhead would be printed on the first n−1 pages of each letter. The last page of the letterhead could then be printed on all of the remaining pages of each letter.
With respect to printing a page of the letterhead on a page of the letter, the letterhead would preferably be rendered first and then the corresponding page of the letter (to simulate the process of printing the letter to traditional letterhead).
A virtual letterhead would be associated with a specific document ID (unique GUID). If the document ID is not recognised on server 21, the letter could be printed on plain paper. For large customers, server 21 could be set-up to divert letters that included a specific document ID to be printed on an actual hardcopy letterhead (quicker and less costly). In the alternative, printer(s)/printer server(s) 24 could be pre-loaded with the softcopy virtual letterhead and server 21 and/or printer(s)/printer server(s) 24 could substitute specific document ID's with the appropriate printer commands to render the softcopy virtual letterhead, for example using PPML. Alternatively, the softcopy virtual letterhead could be passed to the printer(s)/printer server(s) 24 at the same time as the actual print stream.
In a particular method embodiment for printing a hardcopy document with a letterhead, the method includes, at the server, receiving the electronic document from the terminal. The electronic document includes at least the graphic image file and the document ID, the document ID being associated with a particular letterhead and the graphic image file having been obtained from an application document. A document ID may be unique to each unique instance of a letterhead, but a document ID can be reused when a letterhead is required again. The graphic image file is transmitted to the printer server to be printed with the letterhead as the hardcopy document by the printer, the letterhead having been obtained or retrieved using the document ID.
The letterhead can be obtained or retrieved in a variety of ways, for example the letterhead can be obtained from the database and transmitted to the printer server with the graphic image file. Alternatively, the letterhead can be obtained from the database and transmitted to the printer server separately to the graphic image file. Also alternatively, the letterhead can be obtained from a memory associated with the printer or the printer server, e.g. a local or internal hard disk or solid state memory.
A user is preferably provided with a selectable option at the terminal so as to be able to select one of a plurality of letterheads for printing, which produces the document ID. For example, the user could select a specific letterhead prior to printing or have previously selected a default letterhead. In another form, the letterhead can include composite parts. A user can be provided with a further option at the terminal to simply select all of a letterhead, or only part or parts of the letterhead, e.g. only a logo or a header section, for printing.
In a particular example, the instruction file may contain the document ID. The instruction file may also still contain the unique identification number or any other required or useful information. In one possible form, the document ID (GUID) could be the same as the unique identification number, although this is not essential and may not be preferable.
Silent Send
According to a still further aspect, there is provided a “silent send” mode. In one form, users print one or more letters in a single print stream to the image capture tool 15, for example a printer driver. Users may preview their letters, select attachments and/or virtual letterhead, and then submit their letters. However, in this form, there is no provision of any function for attachments, virtual letterhead, physical inserts, envelope stock, etc., to be automatically used with submitted letters.
In an enhanced form with “silent send” mode, letters are automatically submitted for production with no further user intervention. A user selectable option can be provided to enable the user to simply and readily select a resource for a printing job. For example, the user selectable option may be a wildcard string. Lists of wildcard strings can be associated with an attachment, physical insert, virtual letterhead, a type of physical paper (e.g. with a hardcopy letterhead already present or a size of paper), a type of envelope, etc., (herein referred to as “resources”). When a new set of letters is printed to image capture tool 15, for example a printer driver, the name (or other identifier) for the new print stream can be compared with the wildcard strings associated with each available resource. For every match found, the corresponding resource would be added to the original letters. In a standard mode, this would save the user several steps as the letters would automatically include required resources. This would also allow for features such as attachments and virtual letterhead to be used for letters printed using the “silent send” mode.
The document ID and/or the wildcard string can be utilised to cause the graphic image file, when printed, to be selectively associated with the resource, which may have been preprinted. That is, the user can select a virtual resource, such as an attachment or physical insert, which is then physically used with a printed graphic image file. For example, the resource could be a preprinted attachment or physical insert which is associated with the printed graphic image file by both the printed graphic image file and the attachment or physical insert being inserted in an envelope together for mailing.
Additionally, the following example characteristics/features could also be controlled by using wildcards:
1. Colourmode (colour of B&W);
2. Simplex/duplex;
3. Ignore first page;
4. Department (billing codes);
5. Email Address (contact information); and/or
6. Return address.
Ignore Page
According to a still further aspect, there is provided an “ignore page” command or function. In one form, users print one or more letters in a single print stream to the image capture tool 15, for example a printer driver. The first page of each letter should include a delivery address. The delivery address is then extracted from each letter. If a user wishes to send a standard (not personalised) brochure or document to a distribution list, the user must add the delivery addresses to the brochure (which may be white on white, that is not visible to the recipient). This process requires that the user modifies their standard brochure and print a large print stream (since the entire brochure must be printed for each recipient).
Another problem with this form is that it is difficult or problematic to use with many document imaging systems. Many document imaging systems store documents as images (e.g. TIFF). Although such documents may be printed to the image capture tool 15, for example a printer driver, software resident on server 21 may not be able to extract the delivery addresses because they are not included in the print stream as text. Although the delivery address is known by the document imaging system, there is no way to pass this information to server 21.
In an enhanced form, the user is able to specify that a page of each letter is to be ignored, preferably, for example, the first page of each letter is to be ignored (not printed) except for address extraction. Using this enhancement, users could print a standard brochure or other document as an attachment (only printed once) and then create a simple mail-merge from their distribution list. Such a mail-merge could include nothing but the delivery addresses. This would greatly simplify (and reduce resources required including disk storage and network bandwidth) the process of mailing of standard brochures or other documents. The recipient's address may be extracted from the graphic image file at the server or at the printer server.
This enhanced form would also facilitate the use of system 10 with document imaging systems. The document imaging systems could be modified to print a trivial cover page with a delivery address for each letter. These trivial cover pages would be used to extract the delivery address but otherwise be ignored.
Consolidation of Application Documents
In the system disclosed in Australian Patent No. 2003254402, filed on 28 Aug. 2003 by the Applicant, a software application prints one or more letters in a single print job. A user is then able to parse the print stream to determine where the letters start and end. After the user has reviewed the letters, they may be submitted together to a server. In some situations, software applications (for example MYOB, FASTRACK, etc.) have been designed to print letters individually. Although such letters can be submitted for processing, the additional time and actions required to open, review and submit each letter individually makes the use of the system uneconomical. Attempts to merge the letters before submission to the server have proved ineffective because the separate letters can often use different embedded fonts and other elements. These differences make it very difficult to separate the letters in such a merged print stream.
According to a particular aspect, there is provided a means for “consolidation of application documents”. An arbitrary number of print streams may be consolidated into a single job as a virtual print stream for submission to the server. This can dramatically reduce the time it takes for some users to submit mail. In one form, the steps are as follows:
1. The print driver is set to print the application documents without initiating submission to the server;
2. The user “prints” a series of application documents (as would normally be done to a local printer);
3. The user opens an application, for example a “Mailroom” application, and/or navigates to a specific folder or virtual folder being a collection of objects in different locations, for example called a “New” folder or virtual folder;
4. The “New” folder or virtual folder contains all of the graphic image files (e.g. letters in WYSIWYG form as previously described) obtained from the application documents to be printed by a remote printer;
5. The user selects all (or a subset) of the graphic image files in the “New” folder or virtual folder;
6. The selected graphic image files can then be consolidated into one virtual print stream;
7. The user can then review and submit the selected graphic image files to the server for subsequent printing using the same tools that would have been used had each application document been printed separately as single print streams.
In another form, a user is not required to review/open the “Mailroom” application or the “New” folder or virtual folder. By associating a timer with the “New” folder or virtual folder all graphic image files (or the application documents from which they are derived) that match a certain description or condition can be automatically or semi-automatically uploaded/submitted periodically, for example by setting a timing parameter to upload the files every x minutes/hours. As a specific illustrative example, all graphic image files starting with “Invoice*.*” could be aggregated and uploaded every 30 minutes, but graphic image files starting with “Statement*.*” could be uploaded every 240 minutes.
Internally, the application documents are kept separate so that different fonts and other elements within the application documents do not cause parsing errors. In fact, application documents with completely different structures and formats could be consolidated in this manner. Preferably, a pre-requisite for such consolidation is that the address for all the application documents is in roughly the same location (e.g. a user should be able to draw a rectangle that could contain the addresses for all the application documents but no other blocks of text that could be mistaken as part of an address).
Regular Expressions
As discussed hereinbefore, in Australian Patent No. 2003254402 addresses can be extracted and printed on cover sheets that are visible through an address window of a windowed envelope. In this prior system it can be beneficial for a user to include a reference, for example alpha-numeric characters, on the first line of an address for document identification purposes. These forms of references, allow the user to identify letters/documents. Such a reference can be included in an address as non-printable or non-visible text, for example as white text on a white background. The server software can then suppress them from cover sheets and returned mail reports.
In various legacy systems/software, for example used to produce an application document, it may be impractical to colour a reference in a particular colour, for example as white text or as the same colour as a particular background, to blend into the background and not be visible. In this situation, the prior system/software can delete the reference from the files after processing but prior to printing. This allows legacy systems to print the reference in black in the print stream, but for the reference not to been seen on the final printed document/letter.
To at least partially address these issues, and according to a particular embodiment, there is provided a means to provide and handle regular expressions, preferably non-printable regular expressions. The client software is adapted to be able to recognize and parse such regular expressions. The regular expressions can include, for example, alpha-numeric references, processing options and delivery options. The client software can suppress the regular expressions from the address extraction procedure so that the added text, i.e. the regular expression, does not take up one or more lines of the address and so that the user can preview the results. The user is then able to determine the format for the regular expression such that one or more of the following sending options, provided by way of example, may be extracted:
1. Reference characters/number—used for letter tracking;
2. Processing options—to control processing options such as the suppression of first page printing (e.g. the first page of a letter is used for address extraction only);
3. Attachment options—to control which attachments are included with a letter (e.g. arbitrarily, REF=12345 has a rule that attaches attachments 1, 3 and 5);
4. Letterhead options—to control which letterhead is under-laid on a letter (e.g. arbitrarily, REF=12345 has a rule that attaches letterhead “My Letterhead 1);
5. Account options—to control which account a letter is charged to. A particular company may have numerous accounts (e.g. arbitrarily, REF=12345 charges a letter to account ADR12345);
6. Logo on envelope option—to control which logo shows on an envelope. A company may want to use different logo's on their envelopes for different documents (e.g. arbitrarily, REF=12345 uses logo1);
7. Insert options—to control which inserts are included with a letter (e.g. arbitrarily, REF=12345 includes a reply raid envelope with stock code RPE12349);
8. Delivery Time options—to control when a letter is printed (e.g. arbitrarily, REF=12345 DATE=120606 can print a letter on the 12th day of Jun. 2006);
9. Archive options—to control whether the item is archived locally or if a rendered copy (e.g. a PDF copy) is sent back from the processing centre to the company/user along with relevant details (e.g. a XML file) so that the copy can be ingested into an archiving system;
10. Stock options—to control the stock on which a letter is printed (e.g. arbitrarily, REF=12345 STOCK=GFDR3); and/or,
11. Delivery options—to determine how the letter/document should be delivered to the end user (e.g. via post, email or FAX). The delivery option may be preset to a default delivery option, for example via post as hereinbefore described.
The regular expression may include a unique identifier such as a Globally Unique Identifier (GUID) to ensure a line of the address is not mistakenly parsed as part of such a regular expression.
For example, the following regular expression could be used to send a letter by FAX:
<KMT2VCH976GQM32C2RJF84GJ9KFD REF=D123456 FAX=0730100567>;
or the following regular expression could be used to send a letter by email:
<KMT2VCH976GQM32C2RJF84GJ9KFD REF=D123456 EMAIL=solutions easymail.com>;
or the following regular expression could be used to send a letter through the post with suppression of first page printing:
<KMT2VCH976GQM32C2RJF84GJ9KFD REF=D123456 NOFIRSTPAGE>.
Additionally or alternatively, the regular expression may be located or positioned in another area of the document, that is besides the address location. If the user selects this other area, the document can be processed using the same rules, that is the regular expression does not have to be located in or as part of the address.
Furthermore, the user could use a regular expression as part of the actual name of the document, eg. Word Invoice 12345 REF=D123456 FAX=0730100567, or Word invoice FAX=0730100567.
It is also possible that certain elements are treated as regular expressions and certain elements are triggered to look up a rule. For example, if REF=12345 and a user wanted the document to be associated with account ADR12349 and also include Attachment1a, options include either:
using regular expression—REF=12345 ACCOUNT=ADR12349 ATTACHMENT=Attachment1; or
using regular expression—REF=12345, and using a rule in a rules engine that automatically knows to associate with account ADR12349 and include Attachment 1.
Referring to
Image processing tool 15, or equivalently printer driver 15, is resident on terminal 14 and operates on the application document 13 to generate graphic image file 47a and to extract or parse regular expression 42. Graphic image file 47a and regular expression 42 can be associated or collated with, in or as part of electronic document 47, or equivalently electronic file 47. Thus, electronic document/file 47 includes at least graphic image file 47a and one or more regular expressions 42, with graphic image file 47a obtained from application document 13 and one or more regular expressions 42 extracted or parsed from application document 13, which is also taken to mean the one or more regular expressions 42 can be extracted or parsed from the graphic image file 47a itself after being produced from the application document 13.
Graphic image file 47a is transmitted 44 to one or more servers 21 via network 20 together with one or more regular expressions 42 as part of electronic document/file 47. Electronic document/file 47 is received at one or more servers 21. Processing software resident on one or more servers 21 processes the one or more regular expressions 42 to obtain, for example, delivery options concerning how graphic image file 47a should be delivered to recipient 12. As non-limiting examples, delivery options may include via post 51, facsimile 52 and/or e-mail 53. One or more servers 21 can act on one or more regular expressions 42 to effect delivery of graphic image file 47a via the delivery mode indicated in one or more regular expressions 42. Alternatively, a delivery option may not be specified in one or more regular expressions 42 and a default delivery option may be used, for example which may be known as a preference for recipient 12 and such information can be retrieved by one or more servers 21 from a database.
This allows a wide variety of instructions to be sent as one or more regular expressions 42 by incorporating such one or more regular expressions 42 in or with an application document 13. The one or more regular expressions 42 are extracted or parsed and thus not printed as part of graphic image file 47a.
By default, image processing tool 15 may look in an address area or other location in application document 13 for regular expression 42. However, such a default is not essential and it may be provided that a user can specify another part or location of application document 13 where one or more regular expressions 42 are located.
A regular expression can include an option perimeter when appropriate, for example, an option perimeter for delivery options may be “post”, “fax” or “e-mail”. Alternatively, a regular expression may trigger a rule from a rules database that automatically includes or associates a specific option parameter with the regular expression. For example, a specific regular expression for a particular recipient/client may always have a default delivery option, account number, attachment, etc.
Image processing tool 15, i.e. printer driver 15, provided on terminal 14 thus provides a computer program product for delivering a document to a recipient 12. Software resident on one or more servers 21 for processing electronic document/file 47 and forwarding graphic image file 47a provides another form of computer program product for delivering a document to recipient 12.
Detailed Specific Embodiment
The following example provides a more detailed description of one particular embodiment. This example is intended to be merely illustrative and not limiting to the scope of the present invention.
An example embodiment uses a computer program that runs on the sender's computer. The computer program consists of software written in the C programming language to run on the Microsoft Windows 32-bit operating system (WIN32) together with a custom printer driver developed using the Microsoft Windows Driver Development Kit (DDK).
After the sender has created or received an application document on their WIN32 computer terminal, the sender selects a custom printer driver which “prints” the application document by saving the application document as a series of Postscript, Portable Document Format (PDF), Printer Command Language (PCL) or Enhanced Metafile Format (EMF) files on the terminal's storage medium. The printer driver then, in turn, initiates the client-side software. The software displays the Postscript, PDF, PCL or EMF files in WYSIWYG format on the sender's (i.e. user's) computer screen with the relevant area for the correct location of the postal address highlighted. Thus the sender can tell by inspection that the recipient's address is in the correct location and can instruct the software to send an electronic document or cancel the operation. In an alternative embodiment, the software automatically examines the Postscript, PDF, PCL or EMF file for graphical text elements in the relevant area of the page and then analyses this text according to pre-programmed rules to ascertain whether the document contains a valid postal address.
The Postscript, PDF, PCL or EMF files are then digitally compressed using the ZLIB compression algorithm as specified in RFC1950 “ZLIB Compressed Data Format Specification version 3.3” (P. Deutsch and J-L Gailly, May 1996) and are then encoded using Basic Encoding Rules (BER) in accordance with ITU-T Recommendations X.690-X.691 (2002) and CCITT Recommendation X.209.
The software generates a unique identification number by using Windows internal software that creates a global unique identifier (GUID), a bit string guaranteed to be unique to a very high degree of certainty. This number is encoded in base 24 format and is used as a reference to the message in all subsequent stages, and also as key in a local database of messages maintained by the software on the sender's local terminal.
The software then generates an instruction file in Extensible Markup Language (XML) containing instructions for this particular message including the unique identification number, sender's account details, number of pages, return email address, and so forth. This XML instruction file is combined with the BER-encoded Postscript, PDF, PCL or EMF files and converted into a Secure Multipurpose Internet Mail Extensions (S/MIME) message using public key encryption in accordance with RFC2633 “S/MIME Version 3 Message Specification” (B. Ramsdell, June 1999) and RFC2630 “Cryptographic Message Syntax” (R. Housley, June 1999).
The software then opens a Transmission Control Protocol/Internet Protocol (TCP/IP) connection with the server computer over the Internet and sends the S/MIME message to the server, for example using the HyperText Transfer Protocol (HTTP) or Simple Mail Transfer Protocol (SMTP) as per RFC821. The message can also be encrypted prior to being sent using, for example, HTTP or SMTP. The message transmission is independent of any email client applications that may exist on the sender's terminal. Alternatively, the software stores the information in a queue so the message can be sent by HTTP or SMTP transmission at a later time. After transmission, the software stores the result (success or failure) in the local database.
When the sender uses a Document Manager to query the status of documents, the software looks up the local database for the identifiers of any outstanding documents. It then sends a request on these outstanding documents to the server computer using Hypertext Transfer Protocol (HTTP) commands and receives back the latest status details (received, being printed, successfully posted, rejected, not found, etc.). The software then updates the local database with this information and displays the results to the user in a Graphical User Interface (GUI).
Thus there has been provided a method, system, computer program product and/or computer readable medium of instructions to provide for new or improved uses of regular expressions, for example non-printable regular expressions.
The invention may also be said broadly to consist in the parts, elements and features referred to or indicated in the specification of the application, individually or collectively, in any or all combinations of two or more of said parts, elements or features, and where specific integers are mentioned herein which have known equivalents in the art to which the invention relates, such known equivalents are deemed to be incorporated herein as if individually set forth.
Although the preferred embodiment has been described in detail, it should be understood that various changes, substitutions, and alterations can be made herein by one of ordinary skill in the art without departing from the spirit or scope of the present invention.
The present invention may take the form of an entirely hardware embodiment, an entirely software embodiment, or an embodiment combining software and hardware aspects.
Throughout this specification and the claims which follow, unless the context requires otherwise, the word “comprise”, and variations such as “comp rises” or “comprising”, will be understood to imply the inclusion of a stated integer or step or group of integers or steps but not the exclusion of any other integer or step or group of integers or steps.
The reference in this specification to any prior publication (or information derived from the prior publication), or to any matter which is known, is not, and should not be taken as an acknowledgment or admission or any form of suggestion that the prior publication (or information derived from the prior publication) or known matter forms part of the common general knowledge in the field of endeavour to which this specification relates.
Number | Date | Country | Kind |
---|---|---|---|
2006203578 | Aug 2006 | AU | national |
2007201506 | Apr 2007 | AU | national |