X-Git-Url: http://gitweb.michael.orlitzky.com/?p=mailshears.git;a=blobdiff_plain;f=lib%2Fcommon%2Fdovecot_plugin.rb;h=fa61d5367b593d959c1839de143f1f0c767490db;hp=2496bae2eade64be5889c4a5057b8ac00e4b5228;hb=371cc929cd8832f2a45ef75d7ed8db3e6ea3ed7c;hpb=7f8654ed6582062a295e1be75ae70e99de41b323 diff --git a/lib/common/dovecot_plugin.rb b/lib/common/dovecot_plugin.rb index 2496bae..fa61d53 100644 --- a/lib/common/dovecot_plugin.rb +++ b/lib/common/dovecot_plugin.rb @@ -1,32 +1,24 @@ -require 'common/plugin' +require 'common/domain' require 'common/filesystem' +require 'common/plugin' +require 'common/user' + module DovecotPlugin # Code that all Dovecot plugins (Prune, Rm, Mv...) will # share. That is, we implement the Plugin interface. include Plugin - def initialize - cfg = Configuration.new() - @domain_root = cfg.mail_root + def initialize(cfg) + @domain_root = cfg.dovecot_mail_root end def describe_domain(domain) - begin - domain_path = get_domain_path(domain) - return domain_path - rescue NonexistentDomainError => e - return "Doesn't exist: #{e.to_s}" - end + return get_domain_path(domain) end - def describe_account(account) - begin - account_path = get_account_path(account) - return account_path - rescue NonexistentAccountError => e - return "Doesn't exist: #{e.to_s}" - end + def describe_user(user) + return get_user_path(user) end @@ -36,68 +28,41 @@ module DovecotPlugin # Return the filesystem path for the given domain. # That is, the directory where its mail is stored. # Only works if the domain directory exists! - domain_path = File.join(@domain_root, domain) - - if File.directory?(domain_path) - return domain_path - else - raise NonexistentDomainError.new(domain) - end + return File.join(@domain_root, domain.to_s()) end - def get_account_path(account) - # Return the filesystem path of this account's mailbox. - # Only works if the account exists! - if not account.include?('@') - msg = "#{account}: Accounts must contain an '@' symbol." - raise InvalidAccountError.new(msg) - end - - account_parts = account.split('@') - user_part = account_parts[0] - domain_part = account_parts[1] - - begin - domain_path = get_domain_path(domain_part) - rescue NonexistentDomainError - raise NonexistentAccountError.new(account) - end - - account_path = File.join(domain_path, user_part) - - if File.directory?(account_path) - return account_path - else - raise NonexistentAccountError.new(account) - end + def get_user_path(user) + # Return the filesystem path of this user's mailbox. + domain_path = get_domain_path(user.domain()) + return File.join(domain_path, user.localpart()) end def list_domains() - return Filesystem.get_subdirs(@domain_root) + return Filesystem.get_subdirs(@domain_root).map{ |d| Domain.new(d) } end def list_domains_users(domains) - accounts = [] + users = [] domains.each do |domain| begin # Throws a NonexistentDomainError if the domain's path # doesn't exist on the filesystem. In this case, we want - # to report zero accounts. + # to report zero users. domain_path = get_domain_path(domain) usernames = Filesystem.get_subdirs(domain_path) usernames.each do |username| - accounts << "#{username}@#{domain}" + users << User.new("#{username}@#{domain}") end rescue NonexistentDomainError # Party hard. end end - return accounts + return users end