diff options
Diffstat (limited to 'Troublegun.scptd/Contents/Resources')
-rw-r--r-- | Troublegun.scptd/Contents/Resources/Scripts/main.scpt | bin | 0 -> 1128 bytes | |||
-rw-r--r-- | Troublegun.scptd/Contents/Resources/config.ini | 8 | ||||
-rw-r--r-- | Troublegun.scptd/Contents/Resources/description.rtfd/TXT.rtf | 4 | ||||
-rw-r--r-- | Troublegun.scptd/Contents/Resources/entourage.scpt | 6 | ||||
-rw-r--r-- | Troublegun.scptd/Contents/Resources/gethelper.sh | 1 | ||||
-rw-r--r-- | Troublegun.scptd/Contents/Resources/mail.scpt | 10 | ||||
-rwxr-xr-x | Troublegun.scptd/Contents/Resources/main.py | 62 |
7 files changed, 91 insertions, 0 deletions
diff --git a/Troublegun.scptd/Contents/Resources/Scripts/main.scpt b/Troublegun.scptd/Contents/Resources/Scripts/main.scpt Binary files differnew file mode 100644 index 0000000..b93bd15 --- /dev/null +++ b/Troublegun.scptd/Contents/Resources/Scripts/main.scpt diff --git a/Troublegun.scptd/Contents/Resources/config.ini b/Troublegun.scptd/Contents/Resources/config.ini new file mode 100644 index 0000000..f33ab05 --- /dev/null +++ b/Troublegun.scptd/Contents/Resources/config.ini @@ -0,0 +1,8 @@ +[message] +name: Our IT guy +address: you@example.com +subject: Problem Report +message: Application: + Problem: + +attachments: screencapture diff --git a/Troublegun.scptd/Contents/Resources/description.rtfd/TXT.rtf b/Troublegun.scptd/Contents/Resources/description.rtfd/TXT.rtf new file mode 100644 index 0000000..116a631 --- /dev/null +++ b/Troublegun.scptd/Contents/Resources/description.rtfd/TXT.rtf @@ -0,0 +1,4 @@ +{\rtf1\ansi\ansicpg1252\cocoartf1265\cocoasubrtf210 +{\fonttbl} +{\colortbl;\red255\green255\blue255;} +}
\ No newline at end of file diff --git a/Troublegun.scptd/Contents/Resources/entourage.scpt b/Troublegun.scptd/Contents/Resources/entourage.scpt new file mode 100644 index 0000000..b893a61 --- /dev/null +++ b/Troublegun.scptd/Contents/Resources/entourage.scpt @@ -0,0 +1,6 @@ +tell application "Microsoft Entourage" + set theRecipients to {{address:{display name:"%@", address:"%@"}, recipient type:to recipient}} + set theMessage to make new outgoing message with properties {recipient:theRecipients, subject:"%@", attachment:{file:(POSIX file "%@")}} + open theMessage + activate +end tell diff --git a/Troublegun.scptd/Contents/Resources/gethelper.sh b/Troublegun.scptd/Contents/Resources/gethelper.sh new file mode 100644 index 0000000..2071ec7 --- /dev/null +++ b/Troublegun.scptd/Contents/Resources/gethelper.sh @@ -0,0 +1 @@ +defaults read com.apple.launchservices LSHandlers | grep -B 1 mailto | grep RoleAll | awk 'IFS="=" { print $3; }' diff --git a/Troublegun.scptd/Contents/Resources/mail.scpt b/Troublegun.scptd/Contents/Resources/mail.scpt new file mode 100644 index 0000000..ee447a9 --- /dev/null +++ b/Troublegun.scptd/Contents/Resources/mail.scpt @@ -0,0 +1,10 @@ +tell application "Mail" + set theMessage to make new outgoing message with properties {visible:true, subject:"$subject", content:"$message"} + tell theMessage + make new to recipient at end of to recipients with properties {name:"$name", address:"$address"} + end tell + tell content of theMessage + make new attachment with properties {file name:"$filename"} + end tell + activate +end tell diff --git a/Troublegun.scptd/Contents/Resources/main.py b/Troublegun.scptd/Contents/Resources/main.py new file mode 100755 index 0000000..76cbbb0 --- /dev/null +++ b/Troublegun.scptd/Contents/Resources/main.py @@ -0,0 +1,62 @@ +#! /usr/bin/env python + +import os +import subprocess +import ConfigParser +from string import Template +from tempfile import NamedTemporaryFile + + +def getresource(res): + from os.path import realpath, join, dirname + return join(dirname(realpath(__file__)), res) + +def getconfig(): + config = dict() + ini = ConfigParser.ConfigParser() + inipath = getresource('config.ini') + ini.read(inipath) + for i in ini.options('message'): + config[i] = ini.get('message', i) + + return config + +def gethelper(): + helper = subprocess.check_output(['sh', getresource('gethelper.sh')]) + return helper.strip() + +def screencapture(): + f = NamedTemporaryFile(delete=False, suffix=".png") + f.close() + subprocess.call(['screencapture', '-C', f.name]) + return f.name + +def makemail(config): + helper = gethelper() + + if "com.apple.mail" in helper: + scpt = file(getresource("mail.scpt"), "r") + elif "entourage" in helper: + scpt = file(getresource("entourage.scpt"), "r") + else: + raise Exception("%s is not a supported mail app" % helper) + + compiled_scpt = Template.substitute(Template(scpt.read()), config) + exe = NamedTemporaryFile(delete=False, suffix=".scpt") + exe.write(compiled_scpt) + exe.close() + return exe.name + +def main(): + config = getconfig() + + if 'screencapture' in config.get('attachments'): + config['filename'] = screencapture() + + exe = makemail(config) + subprocess.call(['osascript', exe]) + os.unlink(exe) + + +if __name__ == '__main__': + main() |