#!/usr/bin/python # -*- coding: utf-8 -*- # --------------------------------------------------------------------------- # # # # Plugin for iSida Jabber Bot # # Copyright (C) diSabler # # # # This program is free software: you can redistribute it and/or modify # # it under the terms of the GNU General Public License as published by # # the Free Software Foundation, either version 3 of the License, or # # (at your option) any later version. # # # # This program is distributed in the hope that it will be useful, # # but WITHOUT ANY WARRANTY; without even the implied warranty of # # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # # GNU General Public License for more details. # # # # You should have received a copy of the GNU General Public License # # along with this program. If not, see . # # # # --------------------------------------------------------------------------- # google_last_res = {} def replace_bold(t,b,e): return t.replace('',b).replace('',e) def wiki_search(type, jid, nick, text): if text not in ['next','']: text = L('%s site:en.wikipedia.org','%s/%s'%(jid,nick)) % text google(type, jid, nick, text) def xep_show(type, jid, nick,text): ntext = 'xep '+text+' inurl:xmpp.org' url = 'http://ajax.googleapis.com/ajax/services/search/web?' search_results = html_encode(load_page(url, {'v': '1.0', 'q': ntext.encode("utf-8")})) jsonl = json.loads(search_results) try: results = jsonl['responseData']['results'] title = results[0]['title'] content = results[0]['content'] noh_title = replace_bold(title,'','') content = replace_bold(content,'','') msg = '\n'.join((replacer(noh_title),replacer(content),results[0]['unescapedUrl'])) except: msg = L('xep \"%s\" not found!','%s/%s'%(jid,nick)) % text send_msg(type, jid, nick, msg) def google(type, jid, nick, text): global google_last_res results = '' text = text.strip() if text in ['next','']: if google_last_res.has_key(jid) and google_last_res[jid].has_key(nick) and google_last_res[jid][nick]: first = google_last_res[jid][nick][0] google_last_res[jid][nick] = google_last_res[jid][nick][1:] else: results = L('No results!','%s/%s'%(jid,nick)) else: try: url = 'http://ajax.googleapis.com/ajax/services/search/web?' search_results = html_encode(load_page(url, {'v': '1.0', 'q': text.encode("utf-8")})) jsonl = json.loads(search_results) data = jsonl['responseData']['results'] first = data[0] if google_last_res.has_key(jid): google_last_res[jid].update({nick: data[1:]}) else: google_last_res[jid] = {nick: data[1:]} except: results = L('Expression \"%s\" not found!','%s/%s'%(jid,nick)) % text if not results: title = first['title'] content = first['content'] noh_title = replace_bold(title,u'«',u'»') content = replace_bold(content,u'«',u'»') url = urllib.unquote(first['unescapedUrl'].encode('utf8')).decode('utf8','ignore') results = replacer(noh_title)+'\n'+replacer(content)+'\n'+url send_msg(type, jid, nick, results) def google_clear(room,jid,nick,type,arr): if type == 'unavailable' and google_last_res.has_key(room) and google_last_res[room].has_key(nick): del google_last_res[room][nick] def translate(type, jid, nick, text): text = text.strip() trlang = {'sq':L('Albanian','%s/%s'%(jid,nick)),'en':L('English','%s/%s'%(jid,nick)),'ar':L('Arabic','%s/%s'%(jid,nick)),'af':L('Afrikaans','%s/%s'%(jid,nick)), 'be':L('Belarusian','%s/%s'%(jid,nick)),'bg':L('Bulgarian','%s/%s'%(jid,nick)),'cy':L('Welsh','%s/%s'%(jid,nick)), 'hu':L('Hungarian','%s/%s'%(jid,nick)),'vi':L('Vietnamese','%s/%s'%(jid,nick)),'gl':L('Galician','%s/%s'%(jid,nick)), 'nl':L('Dutch','%s/%s'%(jid,nick)),'el':L('Greek','%s/%s'%(jid,nick)),'da':L('Danish','%s/%s'%(jid,nick)),'iw':L('Hebrew','%s/%s'%(jid,nick)), 'yi':L('Yiddish','%s/%s'%(jid,nick)),'id':L('Indonesian','%s/%s'%(jid,nick)),'ga':L('Irish','%s/%s'%(jid,nick)),'is':L('Icelandic','%s/%s'%(jid,nick)), 'es':L('Spanish','%s/%s'%(jid,nick)),'it':L('Italian','%s/%s'%(jid,nick)),'ca':L('Catalan','%s/%s'%(jid,nick)),'zh':L('Chinese','%s/%s'%(jid,nick)), 'ko':L('Korean','%s/%s'%(jid,nick)),'lv':L('Latvian','%s/%s'%(jid,nick)),'lt':L('Lithuanian','%s/%s'%(jid,nick)), 'mk':L('Macedonian','%s/%s'%(jid,nick)),'ms':L('Malay','%s/%s'%(jid,nick)),'mt':L('Maltese','%s/%s'%(jid,nick)),'de':L('German','%s/%s'%(jid,nick)), 'no':L('Norwegian','%s/%s'%(jid,nick)),'fa':L('Persian','%s/%s'%(jid,nick)),'pl':L('Polish','%s/%s'%(jid,nick)),'pt':L('Portuguese','%s/%s'%(jid,nick)), 'ro':L('Romanian','%s/%s'%(jid,nick)),'ru':L('Russian','%s/%s'%(jid,nick)),'sr':L('Serbian','%s/%s'%(jid,nick)),'sk':L('Slovak','%s/%s'%(jid,nick)), 'sl':L('Slovenian','%s/%s'%(jid,nick)),'sw':L('Swahili','%s/%s'%(jid,nick)),'tl':L('Tagalog','%s/%s'%(jid,nick)),'th':L('Thai','%s/%s'%(jid,nick)), 'tr':L('Turkish','%s/%s'%(jid,nick)),'uk':L('Ukrainian','%s/%s'%(jid,nick)),'fi':L('Finnish','%s/%s'%(jid,nick)),'fr':L('French','%s/%s'%(jid,nick)), 'hi':L('Hindi','%s/%s'%(jid,nick)),'hr':L('Croatian','%s/%s'%(jid,nick)),'cs':L('Czech','%s/%s'%(jid,nick)),'sv':L('Swedish','%s/%s'%(jid,nick)), 'et':L('Estonian','%s/%s'%(jid,nick)),'ja':L('Japanese','%s/%s'%(jid,nick)),'ht':L('Creole','%s/%s'%(jid,nick))} if text.lower() == 'list': msg = L('Available languages for translate:','%s/%s'%(jid,nick)) + ' ' + ', '.join(sorted(trlang.keys())) elif text[:5].lower() == 'info ': text = text.lower().split(' ') msg = '' for tmp in text: if tmp in trlang: msg += '%s - %s, ' % (tmp,trlang[tmp]) if len(msg): msg = L('Available languages: %s','%s/%s'%(jid,nick)) % msg[:-2] else: msg = L('I don\'t know this language','%s/%s'%(jid,nick)) elif text[:5].lower() == 'lang ' and text.count(' ')==1: text = text.lower().split(' ')[1] msg = ', '.join(['%s - %s' % (k,trlang[k]) for k in trlang.keys() if text in trlang[k].lower()]) if len(msg): msg = L('Available languages: %s','%s/%s'%(jid,nick)) % msg else: msg = L('I don\'t know this language','%s/%s'%(jid,nick)) else: if ' ' in text: text = text.split(' ',2) url = 'http://translate.google.ru/translate_a/t?' if len(text)>1 and trlang.has_key(text[0].lower()): if len(text)>2 and trlang.has_key(text[1].lower()): lfrom,lto,tr_text = text[0].lower(),text[1].lower(),text[2] else: lfrom,lto,tr_text = '',text[0].lower(),' '.join(text[1:]) search_results = load_page(url, {'client':'x',\ 'text':tr_text.encode("utf-8"),\ 'hl':lfrom,\ 'sl':lfrom,\ 'tl':lto}) try: jsonl = json.loads(search_results)['sentences'] except ValueError: jsonl = None try: src = trlang[json.loads(search_results)['src']].capitalize() except: src = None if jsonl: msg = rss_replace(''.join(f['trans'] for f in jsonl)) if src and not lfrom: msg = L('%s [Source: %s]','%s/%s'%(jid,nick)) % (msg,src.strip()) else: msg = L('I can\'t translate it!','%s/%s'%(jid,nick)) else: msg = L('Incorrect language settings for translate. tr list - available languages.','%s/%s'%(jid,nick)) else: msg = L('Command\'s format: tr [from] to text','%s/%s'%(jid,nick)) send_msg(type, jid, nick, msg) global execute, presence_control presence_control = [google_clear] execute = [(3, 'tr', translate, 2, 'Translator.\ntr [from_language] to_language text - translate text\ntr list - list for available languages for translate\ntr info - get info about language reduction\ntr lang - get languages by expression'), (3, 'google', google, 2, 'Search in google'), (3, 'xep', xep_show, 2, 'Search XEP'), (3, 'wiki', wiki_search, 2, 'Search in en.wikipedia.org')]