X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=data%2Frbot%2Fplugins%2Fnickserv.rb;h=768840d38522b13ce73fd986816c5ae0966e7a88;hb=783ffa4235330029d661752b1023db635b26f2b3;hp=f23705e38448b716151e0e183588063886243e5e;hpb=9b1197d23b9353e27ffae3d687bc5b35ba9e78b5;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/data/rbot/plugins/nickserv.rb b/data/rbot/plugins/nickserv.rb index f23705e3..768840d3 100644 --- a/data/rbot/plugins/nickserv.rb +++ b/data/rbot/plugins/nickserv.rb @@ -20,63 +20,63 @@ # previously identified successfully class NickServPlugin < Plugin - - BotConfig.register BotConfigStringValue.new('nickserv.name', + + Config.register Config::StringValue.new('nickserv.name', :default => "nickserv", :requires_restart => false, - :desc => "Name of the nick server (all lowercase)") + :desc => _("Name of the nick server (all lowercase)")) - BotConfig.register BotConfigStringValue.new('nickserv.ident_request', + Config.register Config::StringValue.new('nickserv.ident_request', :default => "IDENTIFY", :requires_restart => false, :on_change => Proc.new { |bot, v| bot.plugins.delegate "set_ident_request", v }, - :desc => "String to look for to see if the nick server is asking us to identify") - BotConfig.register BotConfigStringValue.new('nickserv.nick_avail', + :desc => _("String to look for to see if the nick server is asking us to identify")) + Config.register Config::StringValue.new('nickserv.nick_avail', :default => "not (currently )?online|killed|recovered|disconnesso|libero", :requires_restart => false, :on_change => Proc.new { |bot, v| bot.plugins.delegate "set_nick_avail", v }, - :desc => "String to look for to see if the nick server is informing us that our nick is now available") - BotConfig.register BotConfigStringValue.new('nickserv.identified_string', - :default => "(Password|Contrase|Mot de passe).+(acce[pt]t|r[ie]cog?n).+(identif|r[ie]cog?n)", + :desc => _("String to look for to see if the nick server is informing us that our nick is now available")) + Config.register Config::StringValue.new('nickserv.identified_string', + :default => "((Password|Contrase|Mot de passe).+(acce[pt]t|r[ie]cog?n).+)?(you|tu|vous).+(identif|r[ie]cog?n)", :requires_restart => false, :on_change => Proc.new { |bot, v| bot.plugins.delegate "set_identified_string", v }, - :desc => "String to look for to see if the nick server is informing us that we have identified successfully") + :desc => _("String to look for to see if the nick server is informing us that we have identified successfully")) - BotConfig.register BotConfigBooleanValue.new('nickserv.wants_nick', + Config.register Config::BooleanValue.new('nickserv.wants_nick', :default => false, :requires_restart => false, - :desc => "Set to false if the nick server doesn't expect the nick as a parameter in the identify command") + :desc => _("Set to false if the nick server doesn't expect the nick as a parameter in the identify command")) - BotConfig.register BotConfigIntegerValue.new('nickserv.wait', + Config.register Config::IntegerValue.new('nickserv.wait', :default => 30, :validate => Proc.new { |v| v > 0 }, :requires_restart => false, - :desc => "Seconds to wait after sending a message to nickserv, e.g. after ghosting") + :desc => _("Seconds to wait after sending a message to nickserv, e.g. after ghosting")) def help(plugin, topic="") case topic when "" - return "nickserv plugin: handles nickserv protected IRC nicks. topics password, register, identify, listnicks" + return _("nickserv plugin: handles nickserv protected IRC nicks. topics password, register, identify, listnicks") when "password" - return "nickserv password [] : remember the password for nick and use it to identify in future" + return _("nickserv password [] : remember the password for nick and use it to identify in future") when "register" - return "nickserv register [ []]: register the current nick, choosing a random password unless is supplied - current nick must not already be registered for this to work. Also specify email if required by your services" + return _("nickserv register [ []]: register the current nick, choosing a random password unless is supplied - current nick must not already be registered for this to work. Also specify email if required by your services") when "identify" - return "nickserv identify: identify with nickserv - shouldn't be needed - bot should identify with nickserv immediately on request - however this could be useful after splits or service disruptions, or when you just set the password for the current nick" + return _("nickserv identify: identify with nickserv - shouldn't be needed - bot should identify with nickserv immediately on request - however this could be useful after splits or service disruptions, or when you just set the password for the current nick") when "listnicks" - return "nickserv listnicks: lists nicknames and associated password the bot knows about - you will need config level auth access to do this one and it will reply by privmsg only" + return _("nickserv listnicks: lists nicknames and associated password the bot knows about - you will need config level auth access to do this one and it will reply by privmsg only") end end - + def genpasswd - return Irc::Auth.random_password + return Irc::Bot::Auth.random_password end def set_ident_request(val) - @ident_request = Regexp.new(val) + @ident_request = Regexp.new(val, true) end def set_nick_avail(val) - @nick_avail = Regexp.new(val) + @nick_avail = Regexp.new(val, true) end def set_identified_string(val) - @identified_string = Regexp.new(val) + @identified_string = Regexp.new(val, true) end def initialize @@ -92,7 +92,7 @@ class NickServPlugin < Plugin end set_ident_request(@bot.config['nickserv.ident_request']) set_nick_avail(@bot.config['nickserv.nick_avail']) - set_identified_string(@bot.config['nickserv.identified']) + set_identified_string(@bot.config['nickserv.identified_string']) @identified = false end @@ -112,7 +112,7 @@ class NickServPlugin < Plugin if nick == @bot.nick ns_say "SET PASSWORD #{passwd}" else - m.reply "I'm only changing this in my database, I won't inform #{ns_nick} of the change" + m.reply(_("I'm only changing this in my database, I won't inform %{ns_nick} of the change") % {:ns_nick => ns_nick}) end @registry[nick] = passwd m.okay @@ -133,7 +133,7 @@ class NickServPlugin < Plugin @bot.say m.sourcenick, "#{k} => #{v}" } else - m.reply "none known" + m.reply _("none known") end end @@ -160,27 +160,26 @@ class NickServPlugin < Plugin when true m.okay when false - m.reply "I cannot identify for a this nick" + m.reply _("I cannot identify for a this nick") when nil - m.reply "I dunno the nickserv password for the nickname #{@bot.nick} :(" + m.reply(_("I dunno the nickserv password for the nickname %{botnick} :(") % {:botnick => @bot.nick}) else - m.reply "uh ... something went wrong ..." + m.reply _("uh ... something went wrong ...") end end - + def connect @identified = false do_identify end - + def nicktaken(nick) if @registry.has_key?(nick) ns_say "GHOST #{nick} #{@registry[nick]}" end end - def listen(m) - return unless(m.kind_of? NoticeMessage) + def notice(m) return unless m.source.downcase == ns_nick.downcase case m.message