Purple exclamation mark.svg 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.

Red exclamation mark.svg 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

From Botwiki
Jump to: navigation, search
#!/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'
 
#
Personal tools
Share