X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=lib%2Frbot%2Fcore%2Fbasics.rb;h=0473028aceff3899813b029ea60bbd2370367e30;hb=a2eeb15faadf94c879d749e211d160cb86b659c6;hp=832cbb25e73bf79ff1a080ab29a65ad5857ced4f;hpb=783ffa4235330029d661752b1023db635b26f2b3;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/lib/rbot/core/basics.rb b/lib/rbot/core/basics.rb index 832cbb25..0473028a 100644 --- a/lib/rbot/core/basics.rb +++ b/lib/rbot/core/basics.rb @@ -30,7 +30,11 @@ class BasicsModule < CoreBotModule # identification. Observe that this means the bot may not connect any channels # until the 'identified' method gets delegated def connect - join_channels unless @bot.config['irc.join_after_identify'] + if @bot.config['irc.join_after_identify'] + log "waiting for identififcation before JOINing default channels" + else + join_channels + end end def ctcp_listen(m) @@ -65,6 +69,20 @@ class BasicsModule < CoreBotModule end end + def bot_channel_list(m, param) + ret = _('I am in: ') + # sort the channels by the base name and then map with prefixes for the + # mode and display. + ret << @bot.channels.compact.sort { |a,b| + a.name.downcase <=> b.name.downcase + }.map { |c| + c.modes_of(@bot.myself).map{ |mo| + m.server.prefix_for_mode(mo) + }.to_s + c.name + }.join(', ') + m.reply ret + end + def bot_quit(m, param) @bot.quit param[:msg].to_s end @@ -73,6 +91,10 @@ class BasicsModule < CoreBotModule @bot.restart param[:msg].to_s end + def bot_reconnect(m, param) + @bot.reconnect param[:msg].to_s + end + def bot_hide(m, param) @bot.join 0 end @@ -81,6 +103,10 @@ class BasicsModule < CoreBotModule @bot.say param[:where], param[:what].to_s end + def bot_notify(m, param) + @bot.notice param[:where], param[:what].to_s + end + def bot_action(m, param) @bot.action param[:where], param[:what].to_s end @@ -133,6 +159,8 @@ class BasicsModule < CoreBotModule _("quit [] => quit IRC with message ") when "restart" _("restart => completely stop and restart the bot (including reconnect)") + when "reconnect" + _("reconnect => ask the bot to disconnect and then connect again") when "join" _("join [] => join channel with secret key if specified. #{@bot.myself} also responds to invites if you have the required access level") when "part" @@ -172,6 +200,10 @@ basics.map "restart *msg", :action => 'bot_restart', :defaults => { :msg => nil }, :auth_path => 'quit' +basics.map "reconnect *msg", + :action => 'bot_reconnect', + :defaults => { :msg => nil }, + :auth_path => 'quit' basics.map "quiet [in] [:where]", :action => 'bot_quiet', @@ -183,6 +215,9 @@ basics.map "talk [in] [:where]", basics.map "say :where *what", :action => 'bot_say', :auth_path => 'talk::do' +basics.map "notify :where *what", + :action => 'bot_notify', + :auth_path => 'talk::do' basics.map "action :where *what", :action => 'bot_action', :auth_path => 'talk::do' @@ -198,6 +233,9 @@ basics.map "part :chan", :action => 'bot_part', :defaults => {:chan => nil}, :auth_path => 'move' +basics.map "channels", + :action => 'bot_channel_list', + :auth_path => 'move' basics.map "hide", :action => 'bot_hide', :auth_path => 'move'