Planning the future of Botwiki! - Help us bring Botwiki up to date, contribute to our strategy discussion, add bot scripts, and contribute manuals, guides, and tutorials! Almost anything related to bots, particularly those used to edit mediawiki, is welcome.
UNABLE TO EDIT? - We've experienced attacks by spambots lately and now require you to confirm your e-mail before you can edit (go to your preferences, enter an e-mail address, and request a confirmation e-mail, then go to your e-mail and click on the confirmation link). We also require new accounts to make a few edits and wait a few minutes before before you can create a page; however, if this is a problem contact us in #botwiki and we can manually confirm your account. Sorry for the inconvenience.
Python:BotSottile/stuff.py
#!/usr/bin/env python """ hi.py - Perform Greetings Author: Sean B. Palmer, inamidst.com About: http://inamidst.com/phenny/ """ import random, re def f_ciao(self, origin, match, args): reply = random.choice(['Ciao', 'Hey', 'ciao', 'ciao', 'Salve', 'Buon giorno']) self.msg(origin.sender, '%s %s! :-)' % (reply, origin.nick)) f_ciao.rule = r"(?i)^(hey|hello|welcome|hi|ciao|aloha|buon giorno|salve),? ?($nick|all|a tutti)\!? ?(|:\)|:D|XD|^__^)?$" def f_exclaim(self, origin, match, args): self.msg(origin.sender, 'ciao ' + origin.nick + '!') f_exclaim.rule = r"(?i)^$nick(\:|) ciao(\!|)$" def f_empty(self, origin, match, args): #reply2 = random.choice(['lol', ':)', ':D', 'rotfl', 'XD', ':P']) self.msg(origin.sender, "%s: What do you want?" % origin.nick) f_empty.rule = r"(?i)^BotSottile(\:|\: |)$" def f_info(self, origin, match, args): import urllib, re frase = match.group(1) sito = frase.split(' ')[-1] user = frase.replace(sito, '').strip() print urllib.quote('http://' + sito + '.org/w/api.php?action=query&list=users&ususers=' + user + '&usprop=groups|editcount&format=xml', '/?=&:!|_') try: api = urllib.URLopener().open(urllib.quote('http://' + sito + '.org/w/api.php?action=query&list=users&ususers=' + user + '&usprop=groups|editcount&format=xml', '/?=&:!|_')).read() except IOError: self.msg(origin.sender, '%s: Errore nel caricamento della API, controlla di aver specificato correttamente la wiki desiderata' % (origin.nick)) self.msg(origin.sender, 'Sintassi: .info /utente/ it.wikipedia') return try: utente = api[69:api.index('" editcount="')] except ValueError: self.msg(origin.sender, '%s: Utente non trovato su %s' % (origin.nick, sito)) return # print utente # api = api.lower().replace(' ', '_') if str(api.find('</groups>')) == '-1': result = api.replace('<?xml version="1.0" encoding="utf-8"?><api><query><users><user name="' + utente + '" editcount="', 'editcount = "').replace('" /></users></query></api>', '"') #result = api.replace('<?xml version="1.0" encoding="utf-8"?><api><query><users><user name="' + user.replace(' ', '_').lower() + '" editcount="', 'editcount = "').replace('" /></users></query></api>', '"') self.msg(origin.sender, '%s: Informazioni per l\'utente "%s" su "%s": %s, gruppo = "users"' % (origin.nick, utente, sito, result)) else: result = api.replace('<?xml version="1.0" encoding="utf-8"?><api><query><users><user name="' + utente + '" editcount="', 'editcount = "').replace('"><groups><g>', '", gruppo = "').replace('</g></groups></user></users></query></api>', '"').replace('</g><g>', ', ') self.msg(origin.sender, '%s: Informazioni per l\'utente "%s" su "%s": %s' % (origin.nick, utente, sito, result)) f_info.rule = (['info'], r"(.*)") f_info.thread = True def siteFinder(term, raw_term, oldsite): little_research = re.findall('(.*?):.*?', raw_term) if len(little_research) > 2: site = little_research[1] if len(site) > 3: site = oldsite elif ':' in site: site = site.split(':')[0] term = term.replace('%s:' % site, '') else: term = term.replace('%s:' % site, '') else: site = oldsite return (site, term) def f_brakets(self, origin, match, args): #reply2 = random.choice(['lol', ':)', ':D', 'rotfl', 'XD', ':P']) if match.group(2) != '': return raw_term = match.group(3).replace(' ', '_') if match.group(4) == '[[': grafbrak1 = '[' grafbrak2 = ']' else: grafbrak1 = '{' grafbrak2 = '}' research = re.findall('\[\[(.*?):.*?', raw_term) if research != []: term = raw_term.split('%s%s' % (grafbrak1, grafbrak1) + str(research[0]) + ':') else: term = raw_term.split('%s%s' % (grafbrak1, grafbrak1)) term = term[1] if term != '': domain = 'wikipedia.org' site = 'en' msg = False if self.chan == '#thucydides': site = 'en' domain = 'wikiversity.org' if self.chan == '##Lorolichannel' or self.chan == '##botsottile' or self.chan == '##nome' \ or self.chan == '##Acropolis' or self.chan == '##Pizza_Bella_napoli' or self.chan == '#botolatori' \ or self.chan == '##DarkApTELEVISION'or '-it' in self.chan: site = 'it' if self.chan == '#wiktionary-it': domain = 'wiktionary.org' site = 'it' if self.chan == '#wikipedia-it': domain = 'wikipedia.org' site = 'it' if self.chan == '#wikibooks-it': domain = 'wikibooks.org' site = 'it' if self.chan == '#wikinews-it': domain = 'wikinews.org' site = 'it' if self.chan == '#wikiversity-it': domain = 'wikiversity.org' site = 'it' if self.chan == '#wikiquote-it': domain = 'wikiquote.org' site = 'it' if self.chan == '#wikisource-it': domain = 'wikisource.org' site = 'it' if research != []: newsite = research[0].lower() if newsite == 'meta' or newsite == 'commons' or newsite == 'm': domain = 'wikimedia.org' if newsite == 'm' or newsite == 'meta': site = 'meta' if newsite == 'commons': site = 'commons' elif newsite == 'botwiki:': site = 'botwiki' domain = 'sno.cc' elif newsite == 'betawiki:': site = 'www' domain = 'translatewiki.net' elif newsite == 'b': (site, term) = siteFinder(term, raw_term, site) domain = 'wikibooks.org' elif newsite == 'n': (site, term) = siteFinder(term, raw_term, site) domain = 'wikinews.org' elif newsite == 'v': (site, term) = siteFinder(term, raw_term, site) domain = 'wikiversity.org' elif newsite == 'q': (site, term) = siteFinder(term, raw_term, site) domain = 'wikiquote.org' elif newsite == 's': (site, term) = siteFinder(term, raw_term, site) domain = 'wikisource.org' elif newsite == 'wikt': (site, term) = siteFinder(term, raw_term, site) domain = 'wiktionary.org' elif newsite == 'wikispecies': (site, term) = siteFinder(term, raw_term, site) site = 'species' domain = 'wikimedia.org' else: term = newsite + ':' + term domain = 'wikipedia.org' if '|' in term: term = term.split('|')[0] wikis = ['aa','af','ak','als','am','ang','ab','ar','an', 'arc','roa-rup','frp','as','ast','gn','av','ay','az','id','ms','bm', 'bn','zh-min-nan','map-bms','jv','su','ban','ba','be','be-x-old','bh', 'bi','bo','bs','br','bug','bg','bxr','ca','ceb','cv','cs','ch', 'ny','sn', 'tum','cho','co','za','cy','da','pdc','de','dv','nv','dz','mh','et', 'na','el','eml','en','es','eo','eu','ee','to','fab','fa','fo','fr','fy','ff', 'fur','ga','gv','sm','gd','gl','gay','ki','glk','gu','got','zh-classical','hak','xal','ko','ha','haw', 'hy','hi','ho','hsb','hr','io','ig','ilo','bpy','ia','ie','iu','ik','os','xh','zu', 'is','it','he','kl','pam','kn','kr','ka','ks','csb','kk','kk-cn','kk-kz','kw','rw','ky', 'rn','sw','kv','kg','ht','kj','ku','lad','lbe','lo','ltg','la','lv','lb','lij','lt', 'li','ln','jbo','lg','lmo','hu','mk','mg','ml','mt','mi','mr','mzn','chm','cdo','mo', 'mn','mus','my','nah','fj','nl','nds-nl','cr','ne','new','ja','nap','ce', 'pih','no','nn','nrm','nov','oc','or','om','ng','hz','ug','uz','pa', 'pi','pag','pap','ps','km','pms','nds','pl','pt','kk-tr','ty','ksh','ro', 'rmy','rm','qu','ru','se','sa','sg','sc','sco','st','tn','sq','scn', 'si','simple','sd','ss','sk','sl','cu','so','sr','sh','fi','sv','tl', 'ta','kab','roa-tara','tt','te','tet','th','vi','ti','tg','tpi','chr','chy', 've','tr','tk','tw','udm','uk','ur','vec','vo','fiu-vro','wa', 'vls','war','wo','wuu','ts','ii','yi','yo','zh-yue','cbk-zam','diq','zea','bat-smg', 'zh','zh-tw','zh-cn'] if ':' in raw_term: for x in wikis: res = re.findall('[\[:\{]%s:' % x, raw_term.lower()) if res != []: site = x term = term.replace('%s:' % x, '') for i in self.config.otherbot: if origin.nick.lower() == i.lower(): msg = True if msg == False: if grafbrak1 == '{': self.msg(origin.sender, '%s: http://%s.%s/wiki/Template:%s?redirect=no' % (origin.nick, site, domain, term)) else: self.msg(origin.sender, '%s: http://%s.%s/wiki/%s?redirect=no' % (origin.nick, site, domain, term)) f_brakets.rule = r"(?i)^(.*?)([\.\*\!]|) ?((\[\[|\{\{).*?)(?:\]\]|\}\})(.*?)$" def f_luxo(self, origin, match, args): term = match.group(1) self.msg(origin.sender, '%s: http://toolserver.org/~luxo/contributions/contributions.php?user=%s&blocks=true&lang=it' % (origin.nick, term.strip())) f_luxo.rule = (['luxo'], r"(.*)") def f_contr(self, origin, match, args): term = match.group(1) self.msg(origin.sender, '%s: http://it.wikipedia.org/w/index.php?title=Speciale:Contributi&target=%s&bot=1' % (origin.nick, term.strip())) f_contr.rule = (['c'], r"(.*)") def f_voicecia(self, origin, match, args): try: if 'CIA-' in self.xr[0]: self.msg('ChanServ', 'voice ' + self.xr[3] + ' ' + self.xr[0]) self.msg(self.xr[3], "%s flaggato automaticamente" % self.xr[0]) except: print 'fail' f_voicecia.rule = '(.*)' f_voicecia.command = 'JOIN' #