X-Git-Url: http://gitweb.michael.orlitzky.com/?p=mailshears.git;a=blobdiff_plain;f=lib%2Fprune%2Fprune_runner.rb;h=74455d6b2ba8903655ce385b8e4c16d81ad4ccf6;hp=789ed573623ef3b72cd0e5d983c45e9f1bbc68c1;hb=4e7ef12d3d47aa7ec68419de46c51269c40eb158;hpb=ef1b9dcb21d2e084408de19d844d438b99a00dc2 diff --git a/lib/prune/prune_runner.rb b/lib/prune/prune_runner.rb index 789ed57..74455d6 100644 --- a/lib/prune/prune_runner.rb +++ b/lib/prune/prune_runner.rb @@ -1,10 +1,35 @@ require 'common/runner' +# This is always needed, regardless of which plugin is running. +require 'prune/plugins/postfixadmin' + 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 + + pfa = PostfixadminPrune.new() + + db_users = pfa.list_users() + db_domains = pfa.list_domains() + + leftover_users = plugin.get_leftover_accounts(db_users) + leftover_domains = plugin.get_leftover_domains(db_domains) + + leftover_users.each do |user| + user_description = plugin.describe_account(user) + plugin.delete_account(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