X-Git-Url: http://gitweb.michael.orlitzky.com/?p=mailshears.git;a=blobdiff_plain;f=lib%2Fmv%2Fplugins%2Fdovecot_mailstore.rb;h=f16f1165af99ad055384e20862594829d2db72bd;hp=f0824528b438c3ab7cf9f823ce7dc13209ea3741;hb=e3826d8926e11763837a591986d453e9ef5d9dec;hpb=ec3c9099a29f40d95f055ea0f7fb25a99d913de3 diff --git a/lib/mv/plugins/dovecot_mailstore.rb b/lib/mv/plugins/dovecot_mailstore.rb index f082452..f16f116 100644 --- a/lib/mv/plugins/dovecot_mailstore.rb +++ b/lib/mv/plugins/dovecot_mailstore.rb @@ -1,38 +1,13 @@ -# Needed for rm_rf. -require 'fileutils' - require 'common/filesystem' require 'common/mailstore' -require 'common/plugin' +require 'common/dovecot_mailstore_plugin' require 'mv/mv_plugin' class DovecotMailstoreMv < Mailstore - include Plugin + include DovecotMailstorePlugin include MvPlugin - def initialize - cfg = Configuration.new() - @domain_root = cfg.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 - 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 - end def mv_domain(from, to) from_path = self.get_domain_path(from) @@ -46,47 +21,4 @@ class DovecotMailstoreMv < Mailstore FileUtils.mv(from_path, to_path) end - protected; - - - def get_domain_path(domain) - # 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 - 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?('@') - raise InvalidAccountError.new("#{account}: Accounts must contain an '@' symbol.") - 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(account) - end - end - end