]> gitweb.michael.orlitzky.com - mailshears.git/blobdiff - lib/prune/prune_runner.rb
Replace 'account' with 'user' everywhere.
[mailshears.git] / lib / prune / prune_runner.rb
index 789ed573623ef3b72cd0e5d983c45e9f1bbc68c1..7ea61919ca46981c4284c4744854355756f9e3be 100644 (file)
@@ -1,10 +1,36 @@
 require 'common/runner'
 
 require 'common/runner'
 
+# This is always needed, regardless of which plugin is running.
+require 'prune/plugins/postfixadmin'
+
 class PruneRunner
   include Runner
 
   def run(plugin)
 class PruneRunner
   include Runner
 
   def run(plugin)
-    puts "Not implemented"
+    # We don't want to check the PostfixAdmin database against itself.
+    return if plugin.class == PostfixadminPrune
+
+    cfg = Configuration.new()
+    pfa = PostfixadminPrune.new(cfg)
+
+    db_users = pfa.list_users()
+    db_domains = pfa.list_domains()
+
+    leftover_users = plugin.get_leftover_users(db_users)
+    leftover_domains = plugin.get_leftover_domains(db_domains)
+
+    leftover_users.each do |user|
+      user_description = plugin.describe_users(user)
+      plugin.delete_user(user)
+      report(plugin, "Removed user: #{user} (#{user_description})")
+    end
+
+    leftover_domains.each do |domain|
+      domain_description = plugin.describe_domain(domain)
+      plugin.delete_domain(domain)
+      report(plugin, "Removed domain: #{domain} (#{domain_description})")
+    end
+
   end
 
 end
   end
 
 end