# Erebus IRC bot - Author: Erebus Team
+# vim: fileencoding=utf-8
# weather module
# This file is released into the public domain; see http://unlicense.org/
modinfo = {
'author': 'Erebus Team',
'license': 'public domain',
- 'compatible': [2],
+ 'compatible': [0],
'depends': ['userinfo'],
'softdeps': ['help'],
}
modstop = lib.modstop
# module code
-import json, urllib, time, rfc822
+import json, time, sys
+from email.utils import parsedate
-def location(person, default=None): return lib.mod('userinfo')._get(person, 'location', default=None)
+if sys.version_info.major < 3:
+ from urllib import urlopen
+else:
+ from urllib.request import urlopen
-@lib.hook(('weather','w'), needchan=False)
-@lib.help('[<location>]', 'show weather for your location')
-def weather(bot, user, chan, realtarget, *args):
- if len(args) == 0:
- place = location(user)
- else:
- place = ' '.join(args)
+def location(person, default=None): return lib.mod('userinfo').get(person, 'location', default=None)
+def _dayofweek(dayname):
+ return ['mon','tue','wed','thu','fri','sat','sun'].index(dayname.lower())
+
+def _weather(place):
if place is not None:
- weather = json.load(urllib.urlopen('http://api.wunderground.com/api/8670e6d2e69ff3c7/conditions/q/%s.json' % (place)))
- print `weather`
+ weather = json.load(urlopen(('http://api.wunderground.com/api/8670e6d2e69ff3c7/conditions/q/%s.json' % (place)).encode('utf8')))
+ if lib.parent.cfg.getboolean('debug', 'weather'):
+ lib.parent.log('*', "?", repr(weather))
if 'response' in weather:
if 'error' in weather['response']:
- bot.msg(chan, "Error from Wunderground: %s" % (weather['response']['error']['description']))
- return
+ return "Error from Wunderground: %s" % (weather['response']['error']['description'])
if 'results' in weather['response']:
- bot.msg(chan, "That search term is ambiguous. Please be more specific.")
- return
+ return "That search term is ambiguous. Please be more specific."
current = weather['current_observation']
- measuredat = rfc822.parsedate_tz(current['observation_time_rfc822'])[:-1] # parsedate_tz returns a 10-tuple which strftime DOESN'T ACCEPT
- measuredatTZ = current['local_tz_short']
- output = u"Weather in %(location)s: As of %(time)s %(tz)s, %(conditions)s, %(cel)s\u00B0C (%(far)s\u00B0F) (feels like %(flcel)s\u00B0C (%(flfar)s\u00B0F)). Wind %(wind)s. %(link)s" % {
- 'location': current['observation_location']['full'],
- 'time': time.strftime("%a %H:%M", measuredat), 'tz': measuredatTZ,
+ try:
+ measuredat = list(parsedate(current['observation_time_rfc822'])) # we have to turn this into a list so that we can assign to it.
+ measuredat[6] = _dayofweek(current['observation_time_rfc822'][0:3])
+ measuredatTZ = current['local_tz_short']
+ except:
+ measuredat = time.gmtime()
+ measuredatTZ = '(actual time unknown)'
+ loc = current['observation_location']
+ if loc['city'] == "" or loc['state'] == "": loc = current['display_location']
+ return u"Weather in %(location)s: As of %(time)s %(tz)s, %(conditions)s, %(cel)s°C (%(far)s°F) (feels like %(flcel)s°C (%(flfar)s°F)). Wind %(wind)s. %(link)s" % {
+ 'location': loc['full'],
+ 'time': time.strftime("%a %H:%M", tuple(measuredat)), # now we have to turn it back into a tuple because Py3's time.strftime requires it.
+ 'tz': measuredatTZ,
'conditions': current['weather'],
'cel': current['temp_c'], 'far': current['temp_f'],
'flcel': current['feelslike_c'], 'flfar': current['feelslike_f'],
'wind': current['wind_string'],
'link': current['forecast_url'],
}
- bot.msg(chan, output)
else:
- bot.msg(chan, "I don't know where to look! Try SETINFO LOCATION <your location>")
+ return "I don't know where to look! Try %sSETINFO LOCATION <your location>" % (lib.parent.trigger,)
+
+@lib.hook(('weather','w'), needchan=False, wantchan=True)
+@lib.help('[<location>]', 'show weather for your location')
+def weather(bot, user, chan, realtarget, *args):
+ if chan is None:
+ chan = user
+ if len(args) == 0:
+ place = location(user)
+ else:
+ place = ' '.join(args)
+ bot.msg(chan, _weather(place))
+
+@lib.hook(('weatheruser','wu'))
+@lib.help('<user>', 'show weather for <user>\'s location')
+@lib.argsEQ(1)
+def wu(bot, user, chan, realtarget, *args):
+ bot.msg(chan, _weather(location(' '.join(args))))