From 8d566aa8ef469c09f147ec1532e79b3c8cacbdca Mon Sep 17 00:00:00 2001 From: Giuseppe Bilotta Date: Sun, 6 Aug 2006 17:40:21 +0000 Subject: Fix some bugs when setting permissions; introduce the new 'permissions view for ' command --- lib/rbot/botuser.rb | 1 + lib/rbot/core/auth.rb | 37 +++++++++++++++++++++++++++++++++++-- 2 files changed, 36 insertions(+), 2 deletions(-) (limited to 'lib/rbot') diff --git a/lib/rbot/botuser.rb b/lib/rbot/botuser.rb index 952776d8..3363d583 100644 --- a/lib/rbot/botuser.rb +++ b/lib/rbot/botuser.rb @@ -110,6 +110,7 @@ module Irc # This class describes a permission set class PermissionSet + attr_reader :perm # Create a new (empty) PermissionSet # def initialize diff --git a/lib/rbot/core/auth.rb b/lib/rbot/core/auth.rb index 5662c119..2d8b00d0 100644 --- a/lib/rbot/core/auth.rb +++ b/lib/rbot/core/auth.rb @@ -72,7 +72,7 @@ class AuthModule < CoreBotModule warns << ArgumentError("#{x} doesn't look like a channel name") unless @bot.server.supports[:chantypes].include?(x[0]) locs << x end - unless wants_more + unless want_more last_idx = i break end @@ -94,7 +94,7 @@ class AuthModule < CoreBotModule begin user = @bot.auth.get_botuser(splits[-1].sub(/^all$/,"everyone")) rescue - return m.reply("couldn't find botuser #{user}") + return m.reply("couldn't find botuser #{splits[-1]}") end return m.reply("you can't change permissions for #{user.username}") if user == @bot.auth.botowner splits.slice!(-2,2) if has_for @@ -139,6 +139,35 @@ class AuthModule < CoreBotModule end def auth_view_perm(m, params) + begin + user = @bot.auth.get_botuser(params[:user].sub(/^all$/,"everyone")) + rescue + return m.reply("couldn't find botuser #{params[:user]}") + end + perm = user.perm + str = [] + perm.each { |k, val| + next if val.perm.empty? + case k + when :* + str << "on any channel: " + when :"?" + str << "in private: " + else + str << "on #{k}: " + end + sub = [] + val.perm.each { |cmd, bool| + sub << (bool ? "+" : "-") + sub.last << cmd.to_s + } + str.last << sub.join(', ') + } + if str.empty? + m.reply "no permissions set for #{user.username}" + else + m.reply "permissions for #{user.username}:: #{str.join('; ')}" + end end def get_botuser_for(user) @@ -684,5 +713,9 @@ auth.map "permissions reset *args", :action => 'auth_edit_perm', :auth_path => ':edit::reset:' +auth.map "permissions view for :user", + :action => 'auth_view_perm', + :auth_path => '::' + auth.default_auth('*', false) -- cgit v1.2.3