summaryrefslogtreecommitdiff
path: root/tools/write-mime-multipart
diff options
context:
space:
mode:
Diffstat (limited to 'tools/write-mime-multipart')
-rwxr-xr-xtools/write-mime-multipart108
1 files changed, 0 insertions, 108 deletions
diff --git a/tools/write-mime-multipart b/tools/write-mime-multipart
deleted file mode 100755
index 46032728..00000000
--- a/tools/write-mime-multipart
+++ /dev/null
@@ -1,108 +0,0 @@
-#!/usr/bin/python
-# largely taken from python examples
-# http://docs.python.org/library/email-examples.html
-
-import os
-import sys
-import smtplib
-# For guessing MIME type based on file name extension
-import mimetypes
-
-from email import encoders
-from email.message import Message
-from email.mime.base import MIMEBase
-from email.mime.multipart import MIMEMultipart
-from email.mime.text import MIMEText
-from optparse import OptionParser
-import gzip
-
-COMMASPACE = ', '
-
-starts_with_mappings={
- '#include' : 'text/x-include-url',
- '#!' : 'text/x-shellscript',
- '#cloud-config' : 'text/cloud-config',
- '#upstart-job' : 'text/upstart-job',
- '#part-handler' : 'text/part-handler',
- '#cloud-boothook' : 'text/cloud-boothook'
-}
-
-def get_type(fname,deftype):
- f = file(fname,"rb")
- line = f.readline()
- f.close()
- rtype = deftype
- for str,mtype in starts_with_mappings.items():
- if line.startswith(str):
- rtype = mtype
- break
- return(rtype)
-
-def main():
- outer = MIMEMultipart()
- #outer['Subject'] = 'Contents of directory %s' % os.path.abspath(directory)
- #outer['To'] = COMMASPACE.join(opts.recipients)
- #outer['From'] = opts.sender
- #outer.preamble = 'You will not see this in a MIME-aware mail reader.\n'
-
- parser = OptionParser()
-
- parser.add_option("-o", "--output", dest="output",
- help="write output to FILE [default %default]", metavar="FILE",
- default="-")
- parser.add_option("-z", "--gzip", dest="compress", action="store_true",
- help="compress output", default=False)
- parser.add_option("-d", "--default", dest="deftype",
- help="default mime type [default %default]", default="text/plain")
- parser.add_option("--delim", dest="delim",
- help="delimiter [default %default]", default=":")
-
- (options, args) = parser.parse_args()
-
- if (len(args)) < 1:
- parser.error("Must give file list see '--help'")
-
- for arg in args:
- t = arg.split(options.delim, 1)
- path=t[0]
- if len(t) > 1:
- mtype = t[1]
- else:
- mtype = get_type(path,options.deftype)
-
- maintype, subtype = mtype.split('/', 1)
- if maintype == 'text':
- fp = open(path)
- # Note: we should handle calculating the charset
- msg = MIMEText(fp.read(), _subtype=subtype)
- fp.close()
- else:
- fp = open(path, 'rb')
- msg = MIMEBase(maintype, subtype)
- msg.set_payload(fp.read())
- fp.close()
- # Encode the payload using Base64
- encoders.encode_base64(msg)
-
- # Set the filename parameter
- msg.add_header('Content-Disposition', 'attachment',
- filename=os.path.basename(path))
-
- outer.attach(msg)
-
- if options.output is "-":
- ofile = sys.stdout
- else:
- ofile = file(options.output,"wb")
-
- if options.compress:
- gfile = gzip.GzipFile(fileobj=ofile, filename = options.output )
- gfile.write(outer.as_string())
- gfile.close()
- else:
- ofile.write(outer.as_string())
-
- ofile.close()
-
-if __name__ == '__main__':
- main()