mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-02-09 02:54:13 +01:00
RFE 1030244: Added cycle timer to random results and turned them into a stack so multiple random results can be harvested from a single web page service.
Minor grammatical changes Corrected screen-scrape regexp for (yet another) qdb format change
This commit is contained in:
parent
f92e37704b
commit
ac1930b7de
@ -32,6 +32,8 @@ Provides commands and snarfers for the various different Geekquote-based sites
|
|||||||
out there
|
out there
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
import supybot
|
import supybot
|
||||||
|
|
||||||
__author__ = supybot.authors.skorobeus
|
__author__ = supybot.authors.skorobeus
|
||||||
@ -43,12 +45,14 @@ import supybot.plugins as plugins
|
|||||||
|
|
||||||
import re
|
import re
|
||||||
import sets
|
import sets
|
||||||
|
import time
|
||||||
import getopt
|
import getopt
|
||||||
import socket
|
import socket
|
||||||
import urllib
|
import urllib
|
||||||
import xml.dom.minidom
|
import xml.dom.minidom
|
||||||
from itertools import imap, ifilter
|
from itertools import imap, ifilter
|
||||||
|
|
||||||
|
import supybot.fix as fix
|
||||||
import supybot.conf as conf
|
import supybot.conf as conf
|
||||||
import supybot.utils as utils
|
import supybot.utils as utils
|
||||||
from supybot.commands import wrap
|
from supybot.commands import wrap
|
||||||
@ -60,7 +64,7 @@ import supybot.callbacks as callbacks
|
|||||||
def configure(advanced):
|
def configure(advanced):
|
||||||
from supybot.questions import output, expect, anything, something, yn
|
from supybot.questions import output, expect, anything, something, yn
|
||||||
conf.registerPlugin('Geekquote', True)
|
conf.registerPlugin('Geekquote', True)
|
||||||
output("""The Http plugin has the ability to watch for geekquote
|
output("""The Geekquote plugin has the ability to watch for geekquote
|
||||||
(bash.org / qdb.us) URLs and respond to them as though the user
|
(bash.org / qdb.us) URLs and respond to them as though the user
|
||||||
had asked for the geekquote by ID""")
|
had asked for the geekquote by ID""")
|
||||||
if yn('Do you want the Geekquote snarfer enabled by default?'):
|
if yn('Do you want the Geekquote snarfer enabled by default?'):
|
||||||
@ -69,21 +73,33 @@ def configure(advanced):
|
|||||||
conf.registerPlugin('Geekquote')
|
conf.registerPlugin('Geekquote')
|
||||||
conf.registerChannelValue(conf.supybot.plugins.Geekquote, 'geekSnarfer',
|
conf.registerChannelValue(conf.supybot.plugins.Geekquote, 'geekSnarfer',
|
||||||
registry.Boolean(False, """Determines whether the bot will automatically
|
registry.Boolean(False, """Determines whether the bot will automatically
|
||||||
'snarf' Geekquote auction URLs and print information about them."""))
|
'snarf' Geekquote URLs and print information about them."""))
|
||||||
|
|
||||||
class Geekquote(callbacks.PrivmsgCommandAndRegexp):
|
class Geekquote(callbacks.PrivmsgCommandAndRegexp):
|
||||||
threaded = True
|
threaded = True
|
||||||
callBefore = ['URL']
|
callBefore = ['URL']
|
||||||
regexps = ['geekSnarfer']
|
regexps = ['geekSnarfer']
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
self.__parent = super(Geekquote, self)
|
||||||
|
self.__parent.__init__()
|
||||||
|
self.maxqdbPages = 403
|
||||||
|
self.lastqdbRandomTime = 0
|
||||||
|
self.randomData = {'qdb.us':[],
|
||||||
|
'bash.org':[]
|
||||||
|
}
|
||||||
|
|
||||||
def callCommand(self, method, irc, msg, *L, **kwargs):
|
def callCommand(self, method, irc, msg, *L, **kwargs):
|
||||||
try:
|
try:
|
||||||
super(Geekquote, self).callCommand(method, irc, msg, *L, **kwargs)
|
super(Geekquote, self).callCommand(method, irc, msg, *L, **kwargs)
|
||||||
except webutils.WebError, e:
|
except webutils.WebError, e:
|
||||||
irc.error(str(e))
|
irc.error(str(e))
|
||||||
|
|
||||||
_gkREDict = {'bash.org':re.compile('<p class="qt">(?P<text>.*?)</p>', re.M | re.DOTALL),
|
_qdbReString = r'<tr><td bgcolor="#(?:ffffff|e8e8e8)"><a href="/\d*?">'\
|
||||||
'qdb.us':re.compile('<a href=\"/\?\d*\">.*<p>(?P<text>.*?)</p>', re.M | re.DOTALL)}
|
r'#\d*?</a>.*?<p>(?P<text>.*?)</p></td></tr>'
|
||||||
|
_gkREDict = {'bash.org':re.compile(r'<p class="qt">(?P<text>.*?)</p>',
|
||||||
|
re.M | re.DOTALL),
|
||||||
|
'qdb.us':re.compile(_qdbReString, re.M | re.DOTALL)}
|
||||||
def _gkBackend(self, irc, msg, site, id):
|
def _gkBackend(self, irc, msg, site, id):
|
||||||
if id:
|
if id:
|
||||||
try:
|
try:
|
||||||
@ -93,17 +109,48 @@ class Geekquote(callbacks.PrivmsgCommandAndRegexp):
|
|||||||
#id = 'quote=%s' % id
|
#id = 'quote=%s' % id
|
||||||
else:
|
else:
|
||||||
id = 'random'
|
id = 'random'
|
||||||
html = webutils.getUrl('http://%s/?%s' % (site, id))
|
fetchData = True
|
||||||
m = self._gkREDict[site].search(html)
|
quote = ''
|
||||||
if m is None:
|
if id == 'random':
|
||||||
irc.error('No quote found on %s. %s' % (site, id))
|
timeRemaining = int(time.time()) - self.lastqdbRandomTime
|
||||||
return
|
if self.randomData[site]:
|
||||||
quote = utils.htmlToText(m.group(1))
|
quote = self.randomData[site].pop()
|
||||||
quote = ' // '.join(quote.splitlines())
|
else:
|
||||||
|
if (site == 'qdb.us' and
|
||||||
|
int(time.time()) - self.lastqdbRandomTime <= 90):
|
||||||
|
id = 'browse=%s' % fix.choice(range(self.maxqdbPages))
|
||||||
|
quote = self._gkFetchData(site, id, random=True)
|
||||||
|
else:
|
||||||
|
quote = self._gkFetchData(site, id)
|
||||||
irc.reply(quote)
|
irc.reply(quote)
|
||||||
|
|
||||||
|
def _gkFetchData(self, site, id, random=False):
|
||||||
|
html = ''
|
||||||
|
try:
|
||||||
|
html = webutils.getUrl('http://%s/?%s' % (site, id))
|
||||||
|
except webutils.WebError, e:
|
||||||
|
self.log.info('%s server returned the error: %s' % \
|
||||||
|
(site, webutils.strError(e)))
|
||||||
|
s = ''
|
||||||
|
for item in self._gkREDict[site].finditer(html):
|
||||||
|
s = item.groupdict()['text']
|
||||||
|
s = ' // '.join(s.splitlines())
|
||||||
|
s = utils.htmlToText(s)
|
||||||
|
if random and s:
|
||||||
|
if s not in self.randomData[site]:
|
||||||
|
self.randomData[site].append(s)
|
||||||
|
else:
|
||||||
|
break
|
||||||
|
if not s:
|
||||||
|
return 'Could not find a quote for id %s.' % id
|
||||||
|
else:
|
||||||
|
if random:
|
||||||
|
# To make sure and remove the first quote from the list so it
|
||||||
|
self.randomData[site].pop()
|
||||||
|
return s
|
||||||
|
|
||||||
def geekSnarfer(self, irc, msg, match):
|
def geekSnarfer(self, irc, msg, match):
|
||||||
r"http://(?:www\.)?(?P<site>bash\.org|qdb\.us)/\?(?P<id>\d+)"
|
r'http://(?:www\.)?(?P<site>bash\.org|qdb\.us)/\?(?P<id>\d+)'
|
||||||
if not self.registryValue('geekSnarfer', msg.args[0]):
|
if not self.registryValue('geekSnarfer', msg.args[0]):
|
||||||
return
|
return
|
||||||
id = match.groupdict()['id']
|
id = match.groupdict()['id']
|
||||||
@ -116,7 +163,7 @@ class Geekquote(callbacks.PrivmsgCommandAndRegexp):
|
|||||||
"""[<id>]
|
"""[<id>]
|
||||||
|
|
||||||
Returns a random geek quote from bash.org; the optional argument
|
Returns a random geek quote from bash.org; the optional argument
|
||||||
id specifies which quote to retrieve.
|
<id> specifies which quote to retrieve.
|
||||||
"""
|
"""
|
||||||
id = privmsgs.getArgs(args, required=0, optional=1)
|
id = privmsgs.getArgs(args, required=0, optional=1)
|
||||||
site = 'bash.org'
|
site = 'bash.org'
|
||||||
@ -126,7 +173,7 @@ class Geekquote(callbacks.PrivmsgCommandAndRegexp):
|
|||||||
"""[<id>]
|
"""[<id>]
|
||||||
|
|
||||||
Returns a random geek quote from qdb.us; the optional argument
|
Returns a random geek quote from qdb.us; the optional argument
|
||||||
id specifies which quote to retrieve.
|
<id> specifies which quote to retrieve.
|
||||||
"""
|
"""
|
||||||
id = privmsgs.getArgs(args, required=0, optional=1)
|
id = privmsgs.getArgs(args, required=0, optional=1)
|
||||||
site = 'qdb.us'
|
site = 'qdb.us'
|
||||||
|
Loading…
Reference in New Issue
Block a user