Converted to commands.wrap. These are all untested, so someone should test them at some point.

This commit is contained in:
Jeremy Fincher 2004-11-19 23:54:14 +00:00
parent 4a4a0915b7
commit 8071e0236b
2 changed files with 40 additions and 71 deletions

View File

@ -41,8 +41,8 @@ import re
import supybot.conf as conf
import supybot.utils as utils
from supybot.commands import *
import supybot.ircutils as ircutils
import supybot.privmsgs as privmsgs
import supybot.registry as registry
import supybot.webutils as webutils
import supybot.callbacks as callbacks
@ -76,24 +76,12 @@ class Currency(callbacks.Privmsg):
r'(.*)</body>', re.I | re.S)
_xeConvert = re.compile(r'<TD[^>]+><FONT[^>]+>\s+([\d.]+\s+\w{3}\s+='
r'\s+[\d.]+\s+\w{3})', re.I | re.S)
def xe(self, irc, msg, args):
"""[<number>] <currency1> to <currency2>
def xe(self, irc, msg, args, number, curr1, to, curr2):
"""[<number>] <currency1> [to] <currency2>
Converts from <currency1> to <currency2>. If number isn't given, it
defaults to 1.
"""
(number, curr1, curr2) = privmsgs.getArgs(args, required=2,
optional=1)
try:
number = float(number)
except ValueError:
curr2 = curr1
curr1 = number
number = 1
curr1 = curr1.lower()
curr2 = curr2.lower()
if curr2.startswith('to '):
curr2 = curr2[3:]
if len(curr1) != 3 and len(curr2) != 3:
irc.error(self._symbolError)
return
@ -119,25 +107,15 @@ class Currency(callbacks.Privmsg):
else:
irc.error('XE must\'ve changed the format of their site.')
return
xe = wrap(xe, [optional('float', 1.0), 'lowered',
optional(literal('to')), 'lowered'])
def yahoo(self, irc, msg, args):
def yahoo(self, irc, msg, args, number, curr1, to, curr2):
"""[<number>] <currency1> to <currency2>
Converts from <currency1> to <currency2>. If number isn't given, it
defaults to 1.
"""
(number, curr1, curr2) = privmsgs.getArgs(args, required=2,
optional=1)
try:
number = float(number)
except ValueError:
curr2 = curr1
curr1 = number
number = 1
curr1 = curr1.upper()
curr2 = curr2.upper()
if curr2.startswith('TO '):
curr2 = curr2[3:]
if len(curr1) != 3 and len(curr2) != 3:
irc.error(self._symbolError)
return
@ -157,6 +135,8 @@ class Currency(callbacks.Privmsg):
if '.' not in resp[0] and 'e' not in resp[0]:
resp[0] = '%s.00' % resp[0]
irc.reply(' '.join(resp))
yahoo = wrap(yahoo, [optional(float, 1.0), 'lowered',
optional(literal('to')), 'lowered'])
conf.registerPlugin('Currency')
conf.registerChannelValue(conf.supybot.plugins.Currency, 'command',

View File

@ -43,8 +43,8 @@ import time
import supybot.conf as conf
import supybot.utils as utils
from supybot.commands import *
import supybot.ircmsgs as ircmsgs
import supybot.privmsgs as privmsgs
import supybot.ircutils as ircutils
import supybot.registry as registry
import supybot.schedule as schedule
@ -123,7 +123,7 @@ conf.registerChannelValue(conf.supybot.plugins.Services.ChanServ, 'voice',
voiced by the ChanServ when it joins the channel."""))
class Services(privmsgs.CapabilityCheckingPrivmsg):
class Services(callbacks.Privmsg):
"""This plugin handles dealing with Services on networks that provide them.
Basically, you should use the "password" command to tell the bot a nick to
identify with and what password to use to identify with that nick. You can
@ -132,7 +132,6 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
configuration variables to match the NickServ and ChanServ nicks on your
network. Other commands such as identify, getops, etc. should not be
necessary if the bot is properly configured."""
capability = 'admin'
def __init__(self):
self.__parent = super(Services, self)
self.__parent.__init__()
@ -436,35 +435,29 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
irc.error('You must set supybot.plugins.Services.ChanServ '
'before I\'m able to do get voiced.', Raise=True)
def op(self, irc, msg, args):
def op(self, irc, msg, args, channel):
"""[<channel>]
Attempts to get opped by ChanServ in <channel>. <channel> is only
necessary if the message isn't sent in the channel itself.
"""
channel = privmsgs.getChannel(msg, args)
try:
if irc.nick in irc.state.channels[channel].ops:
irc.error('I\'m already opped in %s.' % channel)
else:
self._chanservCommand(irc, channel, 'op')
except KeyError:
irc.error('I\'m not in %s.' % channel)
op = wrap(op, [('checkChannelCapability', 'op'), 'inChannel'])
def voice(self, irc, msg, args):
def voice(self, irc, msg, args, channel):
"""[<channel>]
Attempts to get voiced by ChanServ in <channel>. <channel> is only
necessary if the message isn't sent in the channel itself.
"""
channel = privmsgs.getChannel(msg, args)
try:
if irc.nick in irc.state.channels[channel].voices:
irc.error('I\'m already voiced in %s.' % channel)
else:
self._chanservCommand(irc, channel, 'voice')
except KeyError:
irc.error('I\'m not in %s.' % channel)
voice = wrap(voice, [('checkChannelCapability', 'op'), 'inChannel'])
def do474(self, irc, msg):
channel = msg.args[1]
@ -472,7 +465,7 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
self._chanservCommand(irc, channel, 'unban', log=True)
# Success log in doChanservNotice.
def unban(self, irc, msg, args):
def unban(self, irc, msg, args, channel):
"""[<channel>]
Attempts to get unbanned by ChanServ in <channel>. <channel> is only
@ -480,19 +473,16 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
are, if you need this command, you're not sending it in the channel
itself.
"""
channel = privmsgs.getChannel(msg, args)
try:
self._chanservCommand(irc, channel, 'unban')
irc.replySuccess()
except KeyError:
irc.error('I\'m not in %s.' % channel)
unban = wrap(unban, [('checkChannelCapability', 'op')])
def do473(self, irc, msg):
channel = msg.args[1]
self.log.info('%s is +i, attempting ChanServ invite.', channel)
self._chanservCommand(irc, channel, 'invite', log=True)
def invite(self, irc, msg, args):
def invite(self, irc, msg, args, channel):
"""[<channel>]
Attempts to get invited by ChanServ to <channel>. <channel> is only
@ -500,12 +490,9 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
are, if you need this command, you're not sending it in the channel
itself.
"""
channel = privmsgs.getChannel(msg, args)
try:
self._chanservCommand(irc, channel, 'invite')
irc.replySuccess()
except KeyError:
irc.error('I\'m not in %s.' % channel)
invite = wrap(invite, [('checkChannelCapability', 'op'), 'inChannel'])
def doInvite(self, irc, msg):
if ircutils.strEqual(msg.nick, self.registryValue('ChanServ')):
@ -516,7 +503,7 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
def identify(self, irc, msg, args):
"""takes no arguments
Identifies with NickServ.
Identifies with NickServ using the current nick.
"""
if self.registryValue('NickServ'):
if irc.nick in self.registryValue('nicks'):
@ -528,15 +515,15 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
else:
irc.error('You must set supybot.plugins.Services.NickServ before '
'I\'m able to do identify.')
identify = wrap(identify, ['checkCapability', 'admin'])
def ghost(self, irc, msg, args):
def ghost(self, irc, msg, args, nick):
"""[<nick>]
Ghosts the bot's given nick and takes it. If no nick is given,
ghosts the bot's configured nick and takes it.
"""
if self.registryValue('NickServ'):
nick = privmsgs.getArgs(args, required=0, optional=1)
if not nick:
nick = self._getNick()
if ircutils.strEqual(nick, irc.nick):
@ -547,16 +534,14 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
else:
irc.error('You must set supybot.plugins.Services.NickServ before '
'I\'m able to ghost a nick.')
ghost = wrap(ghost, [('checkCapability', 'admin'), additional('nick')])
def password(self, irc, msg, args):
def password(self, irc, msg, args, nick, password):
"""<nick> [<password>]
Sets the NickServ password for <nick> to <password>. If <password> is
not given, removes <nick> from the configured nicks.
"""
if ircutils.isChannel(msg.args[0]):
irc.errorRequiresPrivacy(Raise=True)
(nick, password) = privmsgs.getArgs(args, optional=1)
if not password:
try:
self.registryValue('nicks').remove(nick)
@ -568,18 +553,22 @@ class Services(privmsgs.CapabilityCheckingPrivmsg):
self.registryValue('nicks').add(nick)
registerNick(nick, password)
irc.replySuccess()
password = wrap(password, [('checkCapability', 'admin'),
'private', 'nick', 'text'])
def nicks(self, irc, msg, args):
"""takes no arguments
Returns the nicks that this plugin is configured to identify and ghost
with."""
with.
"""
L = list(self.registryValue('nicks'))
if L:
utils.sortBy(ircutils.toLower, L)
irc.reply(utils.commaAndify(L))
else:
irc.reply('I\'m not currently configured for any nicks.')
nicks = wrap(nicks, [('checkCapability', 'admin')])
Class = Services