mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-11-09 20:27:26 +01:00
Added webutils module; used it in Http.
This commit is contained in:
parent
17d9a59845
commit
8d9ed6bf87
@ -47,37 +47,15 @@ from itertools import imap, ifilter
|
|||||||
|
|
||||||
import conf
|
import conf
|
||||||
import utils
|
import utils
|
||||||
|
import webutils
|
||||||
import privmsgs
|
import privmsgs
|
||||||
import callbacks
|
import callbacks
|
||||||
|
|
||||||
class FreshmeatException(Exception):
|
class FreshmeatException(Exception):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def getPage(url, size=None):
|
|
||||||
"""Gets a page. Returns a string that is the page gotten."""
|
|
||||||
fd = urllib2.urlopen(url)
|
|
||||||
if size is None:
|
|
||||||
text = fd.read()
|
|
||||||
else:
|
|
||||||
text = fd.read(size)
|
|
||||||
fd.close()
|
|
||||||
return text
|
|
||||||
|
|
||||||
class Http(callbacks.Privmsg):
|
class Http(callbacks.Privmsg):
|
||||||
threaded = True
|
threaded = True
|
||||||
def callCommand(self, method, irc, msg, *L):
|
|
||||||
try:
|
|
||||||
callbacks.Privmsg.callCommand(self, method, irc, msg, *L)
|
|
||||||
except socket.error, e:
|
|
||||||
if e.args[0] == 111:
|
|
||||||
irc.error(msg, 'Connection refused.')
|
|
||||||
elif e.args[0] in (110, 10060):
|
|
||||||
irc.error(msg, 'Connection timed out.')
|
|
||||||
else:
|
|
||||||
irc.error(msg, e.args[1])
|
|
||||||
except (urllib2.HTTPError, urllib2.URLError), e:
|
|
||||||
irc.error(msg, str(e))
|
|
||||||
|
|
||||||
_titleRe = re.compile(r'<title>(.*?)</title>', re.I | re.S)
|
_titleRe = re.compile(r'<title>(.*?)</title>', re.I | re.S)
|
||||||
def title(self, irc, msg, args):
|
def title(self, irc, msg, args):
|
||||||
"""<url>
|
"""<url>
|
||||||
@ -88,7 +66,7 @@ class Http(callbacks.Privmsg):
|
|||||||
if '://' not in url:
|
if '://' not in url:
|
||||||
url = 'http://%s' % url
|
url = 'http://%s' % url
|
||||||
try:
|
try:
|
||||||
text = getPage(url, size=4096)
|
text = webutils.getUrl(url, size=4096)
|
||||||
m = self._titleRe.search(text)
|
m = self._titleRe.search(text)
|
||||||
if m is not None:
|
if m is not None:
|
||||||
irc.reply(msg, utils.htmlToText(m.group(1).strip()))
|
irc.reply(msg, utils.htmlToText(m.group(1).strip()))
|
||||||
@ -105,7 +83,7 @@ class Http(callbacks.Privmsg):
|
|||||||
project = privmsgs.getArgs(args)
|
project = privmsgs.getArgs(args)
|
||||||
url = 'http://www.freshmeat.net/projects-xml/%s' % project
|
url = 'http://www.freshmeat.net/projects-xml/%s' % project
|
||||||
try:
|
try:
|
||||||
text = getPage(url)
|
text = webutils.getUrl(url)
|
||||||
if text.startswith('Error'):
|
if text.startswith('Error'):
|
||||||
raise FreshmeatException, text
|
raise FreshmeatException, text
|
||||||
dom = xml.dom.minidom.parseString(text)
|
dom = xml.dom.minidom.parseString(text)
|
||||||
@ -133,7 +111,7 @@ class Http(callbacks.Privmsg):
|
|||||||
symbol = privmsgs.getArgs(args)
|
symbol = privmsgs.getArgs(args)
|
||||||
url = 'http://finance.yahoo.com/d/quotes.csv?s=%s'\
|
url = 'http://finance.yahoo.com/d/quotes.csv?s=%s'\
|
||||||
'&f=sl1d1t1c1ohgv&e=.csv' % symbol
|
'&f=sl1d1t1c1ohgv&e=.csv' % symbol
|
||||||
quote = getPage(url)
|
quote = webutils.getUrl(url)
|
||||||
data = quote.split(',')
|
data = quote.split(',')
|
||||||
if data[1] != '0.00':
|
if data[1] != '0.00':
|
||||||
irc.reply(msg,
|
irc.reply(msg,
|
||||||
@ -205,13 +183,13 @@ class Http(callbacks.Privmsg):
|
|||||||
'pass=&dpp=&forecast=zandh&config=&'\
|
'pass=&dpp=&forecast=zandh&config=&'\
|
||||||
'place=%s&state=%s&country=%s' % \
|
'place=%s&state=%s&country=%s' % \
|
||||||
(city, state, country)
|
(city, state, country)
|
||||||
html = getPage(url)
|
html = webutils.getUrl(url)
|
||||||
if 'was not found' in html:
|
if 'was not found' in html:
|
||||||
url = 'http://www.hamweather.net/cgi-bin/hw3/hw3.cgi?'\
|
url = 'http://www.hamweather.net/cgi-bin/hw3/hw3.cgi?'\
|
||||||
'pass=&dpp=&forecast=zandh&config=&'\
|
'pass=&dpp=&forecast=zandh&config=&'\
|
||||||
'place=%s&state=&country=%s' % \
|
'place=%s&state=&country=%s' % \
|
||||||
(city, state)
|
(city, state)
|
||||||
html = getPage(url)
|
html = webutils.getUrl(url)
|
||||||
if 'was not found' in html:
|
if 'was not found' in html:
|
||||||
irc.error(msg, 'No such location could be found.')
|
irc.error(msg, 'No such location could be found.')
|
||||||
return
|
return
|
||||||
@ -223,7 +201,7 @@ class Http(callbacks.Privmsg):
|
|||||||
zip = zip.lower().split()
|
zip = zip.lower().split()
|
||||||
url = 'http://www.hamweather.net/cgi-bin/hw3/hw3.cgi?'\
|
url = 'http://www.hamweather.net/cgi-bin/hw3/hw3.cgi?'\
|
||||||
'config=&forecast=zandh&pands=%s&Submit=GO' % args[0]
|
'config=&forecast=zandh&pands=%s&Submit=GO' % args[0]
|
||||||
html = getPage(url)
|
html = webutils.getUrl(url)
|
||||||
if 'was not found' in html:
|
if 'was not found' in html:
|
||||||
irc.error(msg, 'No such location could be found.')
|
irc.error(msg, 'No such location could be found.')
|
||||||
return
|
return
|
||||||
@ -267,7 +245,7 @@ class Http(callbacks.Privmsg):
|
|||||||
irc.error(msg, 'Invalid id: %s' % e)
|
irc.error(msg, 'Invalid id: %s' % e)
|
||||||
return
|
return
|
||||||
|
|
||||||
html = getPage('http://bash.org/?%s' % id)
|
html = webutils.getUrl('http://bash.org/?%s' % id)
|
||||||
m = self._mlgeekquotere.search(html)
|
m = self._mlgeekquotere.search(html)
|
||||||
if m is None:
|
if m is None:
|
||||||
irc.error(msg, 'No quote found.')
|
irc.error(msg, 'No quote found.')
|
||||||
@ -288,7 +266,7 @@ class Http(callbacks.Privmsg):
|
|||||||
'af-query.asp?String=exact&Acronym=%s' % acronym
|
'af-query.asp?String=exact&Acronym=%s' % acronym
|
||||||
request = urllib2.Request(url, headers={'User-agent':
|
request = urllib2.Request(url, headers={'User-agent':
|
||||||
'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT 4.0)'})
|
'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT 4.0)'})
|
||||||
html = getPage(request)
|
html = webutils.getUrl(request)
|
||||||
# The following definitions are stripped and empties are removed.
|
# The following definitions are stripped and empties are removed.
|
||||||
defs = filter(None, imap(str.strip, self._acronymre.findall(html)))
|
defs = filter(None, imap(str.strip, self._acronymre.findall(html)))
|
||||||
utils.sortBy(lambda s: not s.startswith('[not an acronym]'), defs)
|
utils.sortBy(lambda s: not s.startswith('[not an acronym]'), defs)
|
||||||
@ -310,7 +288,7 @@ class Http(callbacks.Privmsg):
|
|||||||
"""
|
"""
|
||||||
hostname = privmsgs.getArgs(args)
|
hostname = privmsgs.getArgs(args)
|
||||||
url = 'http://uptime.netcraft.com/up/graph/?host=%s' % hostname
|
url = 'http://uptime.netcraft.com/up/graph/?host=%s' % hostname
|
||||||
html = getPage(url)
|
html = webutils.getUrl(url)
|
||||||
m = self._netcraftre.search(html)
|
m = self._netcraftre.search(html)
|
||||||
if m:
|
if m:
|
||||||
html = m.group(1)
|
html = m.group(1)
|
||||||
|
|||||||
63
src/webutils.py
Normal file
63
src/webutils.py
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
###
|
||||||
|
# Copyright (c) 2002, Jeremiah Fincher
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# * Redistributions of source code must retain the above copyright notice,
|
||||||
|
# this list of conditions, and the following disclaimer.
|
||||||
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
# this list of conditions, and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
# * Neither the name of the author of this software nor the name of
|
||||||
|
# contributors to this software may be used to endorse or promote products
|
||||||
|
# derived from this software without specific prior written consent.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
# POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
###
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import fix
|
||||||
|
|
||||||
|
import urllib2
|
||||||
|
|
||||||
|
class WebException(Exception):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def getUrl(url, size=None):
|
||||||
|
"""Gets a page. Returns a string that is the page gotten."""
|
||||||
|
try:
|
||||||
|
fd = urllib2.urlopen(url)
|
||||||
|
except socket.error, e:
|
||||||
|
if e.args[0] == 111:
|
||||||
|
raise WebException, 'Connection refused.'
|
||||||
|
elif e.args[0] in (110, 10060):
|
||||||
|
raise WebException, 'Connection timed out.'
|
||||||
|
else:
|
||||||
|
raise WebException, str(e)
|
||||||
|
except (urllib2.HTTPError, urllib2.URLError), e:
|
||||||
|
raise WebException, str(e)
|
||||||
|
if size is None:
|
||||||
|
text = fd.read()
|
||||||
|
else:
|
||||||
|
text = fd.read(size)
|
||||||
|
fd.close()
|
||||||
|
return text
|
||||||
|
|
||||||
|
|
||||||
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user