Email to Fax Gateway
Email to Fax Gateway for HylaFAX.HylaFAX email to fax gateway
One of the main uses for HylaFAX is as an email to fax gateway. This gateway unifies a users communications, so that faxing is as simple as using an email client. The user can email john@08812345678.fax and know that the message typed, and any attachment will be faxed via HylaFAX.
*** NOTE*** This describe the old pre 4.4 version of faxmail. Begining with version 4.4.0, faxmail now handles attachments natively, according to the same typerules logic as sendfax.
To setup an email to fax gateway using HylaFAX, a few simple scripts are needed to convert attachments into postscript so that HylaFAX can then use them. You can send emails with pdf attachments, postscript attachments or tiff attachments. By default, HylaFAX will not decode any attachments, so you need to edit:
#/etc/hylafax/hyla.conf # This line tells hylafax(faxmail) to decode attachments using scripts # located here. MIMEConverters: /var/spool/hylafax/mimetype #
Create the mimetype directory, then inside that, a directory for the attachment mime type, eg application or image, then create a script inside that. The script is passed $1 as the decoded attachments filename, and HylaFAX expects postscript on standard out. The tree looks like this:
/var/spool/hylafax/mimetype/ /var/spool/hylafax/mimetype/application/pdf /var/spool/hylafax/mimetype/application/ps /var/spool/hylafax/mimetype/image/tiff
The Scripts you will need (make sure to chmod +x them to make them executable):
For PDF attachments:
#!/bin/sh #/application/pdf # convert PDF attachment to Postscript for HylaFAX to send pdf2ps $1 - # if you want to send multipage pdf attachments it is better to use "pdftops" # use the line below instead of "pdf2ps $1 -" # /usr/bin/pdftops $1 -
For PS attachments:
#!/bin/sh #/application/ps # convert PS attachment to Postscript for HylaFAX to send echo $1
For TIF attachments:
#!/bin/sh #/image/tif # convert TIF attachment to Postscript for HylaFAX to send /usr/bin/tiff2ps $1 # if you want to send multipage tiff images, than you have to add the option "-a" # for example: #/usr/bin/tiff2ps -a $1
For RTF attachments:
#!/bin/sh #/application/rtf # convert RTF attachment to Postscript for HylaFAX to send /usr/bin/unrtf --html $1 | /usr/bin/html2ps #NOTE that this script does not work! #Although it will work just fine from command line #HylaFAX will not accept the Postscript output. #any help is welcome...
For HTML attachments and HTML formatted e-mails:
#!/bin/sh #/text/html # convert HTML attachment and HTML formatted e-mails to Postscript for HylaFAX to send /usr/bin/html2ps $1
For HTML emails that contain inline graphics
This is a preprocessor script that will split the email message into parts. These parts include the main html part and any inline graphics. The pyhton module tempfile is used to safely and securely create a temp directory to write all the parts out to. Then html2ps is called to convert the temporary directory to a PS stream that is sent to stdout. Once this work is completed the script removes the temporary directory.
#!/usr/bin/python """Unpack a MIME message into a directory of files.""" import os import sys import email import mimetypes import re import tempfile import shutil def main(): #Get the message from stdin fp = sys.stdin.read() #Convert this to a message object msg = email.message_from_string(fp) #Create temp directory to store contents tempcon = tempfile.mkdtemp() #Change to our tempcon os.chdir(tempcon) patt1 = re.compile('<') patt2 = re.compile('>') for part in msg.walk(): # multipart/* are just containers if part.get_content_maintype() == 'multipart': continue # Applications should really sanitize the given filename so that an # email message can't be used to overwrite important files ext = mimetypes.guess_extension(part.get_content_type()) ctype = part.get('content-id') if ctype: doit = re.sub(patt2, '', re.sub(patt1, 'cid:', ctype)) else: doit = 'main.html' if not ext: # Use a generic bag-of-bits extension ext = '.bin' fp = open(tempcon + '/' + doit, 'wb') fp.write(part.get_payload(decode=True)) fp.close() os.system('/usr/local/bin/html2ps main.html') os.chdir('..') shutil.rmtree(tempcon) if __name__ == '__main__': main()
You will likely call the above preprocessor from an initial bash script that is first called from your MTA (ie, sendmail, postfix, etc). For example, my sendmail calls this first script. Note that ‘multi-write-0.1.py’ is the HTML multipart script listed above.
#!/bin/bash #/usr/bin/formail -a 'X-FAX-Headers: clear' | /usr/local/bin/multi-write-0.1.py | \ /usr/bin/sendfax -n -m -R -f "$2" -d "$1"