]> git.netwichtig.de Git - user/henk/code/ruby/rbot.git/blobdiff - lib/rbot/core/userdata.rb
botuser: add command to reset the netmasks list
[user/henk/code/ruby/rbot.git] / lib / rbot / core / userdata.rb
index 6d7b748962a91bc556af151a3687dc2688bafd45..f7c74a4a5fa7f9b0657910e7c5c01241fe016413 100644 (file)
@@ -56,7 +56,8 @@ class UserDataModule < CoreBotModule
     @botuser = @registry.sub_registry('botuser')
   end
 
-  def get_data_hash(user)
+  def get_data_hash(user, opts={})
+    plain = opts[:plain]
     iu = user.to_irc_user
     bu = iu.botuser
 
@@ -71,10 +72,12 @@ class UserDataModule < CoreBotModule
     end
     ih.merge!(bh)
 
-    class << ih
-      alias :single_retrieve :[]
-      alias :single_assign :[]=
-      include DottedIndex
+    unless plain
+      class << ih
+        alias :single_retrieve :[]
+        alias :single_assign :[]=
+          include DottedIndex
+      end
     end
 
     return ih
@@ -87,10 +90,14 @@ class UserDataModule < CoreBotModule
     return h[key]
   end
 
-  def set_data_hash(user, h)
+  def set_data_hash(user, hh)
     iu = user.to_irc_user
     bu = iu.botuser
 
+    # we .dup the hash to remove singleton methods
+    # and make it dump-able
+    h = hh.dup
+
     @ircuser[iu.nick] = h
     return h if bu.default?
 
@@ -171,7 +178,7 @@ class UserDataModule < CoreBotModule
     when :pre_perm
       @permification ||= {}
       k = [opts[:irc_user], opts[:bot_user]]
-      @permification[k] = get_data_hash(opts[:irc_user])
+      @permification[k] = get_data_hash(opts[:irc_user], :plain => true)
     when :post_perm
       @permification ||= {}
       k = [opts[:irc_user], opts[:bot_user]]