summaryrefslogtreecommitdiff
path: root/plugins/translate.py
diff options
context:
space:
mode:
authorFlorent Le Coz <louiz@louiz.org>2011-09-25 20:12:43 +0200
committerFlorent Le Coz <louiz@louiz.org>2011-09-25 20:12:43 +0200
commitc80022e816e96580d48286011337528a929f4ec8 (patch)
tree6ede4e9d16e4fc2916a99dff6e0fbf3c065fae39 /plugins/translate.py
parentfa5044f423e30db386d6d24d39f60d0735a44355 (diff)
parent00ed9b4842169111238b86d0bfc1465176b7d2d8 (diff)
downloadpoezio-c80022e816e96580d48286011337528a929f4ec8.tar.gz
poezio-c80022e816e96580d48286011337528a929f4ec8.tar.bz2
poezio-c80022e816e96580d48286011337528a929f4ec8.tar.xz
poezio-c80022e816e96580d48286011337528a929f4ec8.zip
merge default into plugins branch. So that branch is still up to date too
Diffstat (limited to 'plugins/translate.py')
-rw-r--r--plugins/translate.py33
1 files changed, 33 insertions, 0 deletions
diff --git a/plugins/translate.py b/plugins/translate.py
new file mode 100644
index 00000000..625d78e7
--- /dev/null
+++ b/plugins/translate.py
@@ -0,0 +1,33 @@
+from plugin import BasePlugin
+import urllib.request
+from urllib.parse import urlencode
+import xhtml
+import json
+
+TARGET_LANG = 'en'
+
+def translate(s, target=TARGET_LANG, source=''):
+ f = urllib.request.urlopen('http://ajax.googleapis.com/ajax/services/language/translate', urlencode({ 'v': '1.0', 'q': s, 'langpair': '%s|%s' % (source, target) }))
+ response = json.loads(str(f.read(), 'utf-8'))['responseData']
+ return (response['translatedText'], response['detectedSourceLanguage'])
+
+class Plugin(BasePlugin):
+ def init(self):
+ self.add_event_handler('groupchat_message', self.on_groupchat_message)
+
+ def on_groupchat_message(self, message):
+ try:
+ room_from = message.getMucroom()
+ if message['type'] == 'error':
+ return
+
+ if room_from == 'poezio@kikoo.louiz.org':
+ nick_from = message['mucnick']
+ body = xhtml.get_body_from_message_stanza(message)
+ room = self.core.get_room_by_name(room_from)
+ text, lang = translate(body)
+ if lang != TARGET_LANG:
+ room.add_message(text, nickname=nick_from)
+ except Exception as e:
+ import traceback
+ self.core.information("Exception in translator! %s" % (traceback.format_exc(),))