aboutsummaryrefslogtreecommitdiffstats
path: root/Troublegun.scptd/Contents/Resources
diff options
context:
space:
mode:
Diffstat (limited to 'Troublegun.scptd/Contents/Resources')
-rw-r--r--Troublegun.scptd/Contents/Resources/Scripts/main.scptbin0 -> 1128 bytes
-rw-r--r--Troublegun.scptd/Contents/Resources/config.ini8
-rw-r--r--Troublegun.scptd/Contents/Resources/description.rtfd/TXT.rtf4
-rw-r--r--Troublegun.scptd/Contents/Resources/entourage.scpt6
-rw-r--r--Troublegun.scptd/Contents/Resources/gethelper.sh1
-rw-r--r--Troublegun.scptd/Contents/Resources/mail.scpt10
-rwxr-xr-xTroublegun.scptd/Contents/Resources/main.py62
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
new file mode 100644
index 0000000..b93bd15
--- /dev/null
+++ b/Troublegun.scptd/Contents/Resources/Scripts/main.scpt
Binary files differ
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()