X-Git-Url: http://gitweb.michael.orlitzky.com/?p=mailshears.git;a=blobdiff_plain;f=lib%2Fcommon%2Fdovecot_plugin.rb;h=4718483bec420e0e11731502597069300c816cb4;hp=02e92957cf6994df0e01ebc1a67fa4d07ffbe591;hb=f819b178c5c1cb8adda0182c610e5c52fad8bea7;hpb=72696d3f6e95ef773af9727e9c3459b9038b0fc2 diff --git a/lib/common/dovecot_plugin.rb b/lib/common/dovecot_plugin.rb index 02e9295..4718483 100644 --- a/lib/common/dovecot_plugin.rb +++ b/lib/common/dovecot_plugin.rb @@ -1,5 +1,8 @@ -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 @@ -29,52 +32,31 @@ module DovecotPlugin end + def domain_exists(domain) + domains = list_domains() + return domains.include?(domain) + 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 + return File.join(@domain_root, domain.to_s()) end def get_user_path(user) # Return the filesystem path of this user's mailbox. - # Only works if the user exists! - if not user.include?('@') - msg = "#{user}: Users must contain an '@' symbol." - raise InvalidUserError.new(msg) - end - - user_parts = user.split('@') - local_part = user_parts[0] - domain_part = user_parts[1] - - begin - domain_path = get_domain_path(domain_part) - rescue NonexistentDomainError - raise NonexistentUserError.new(user) - end - - user_path = File.join(domain_path, local_part) - - if File.directory?(user_path) - return user_path - else - raise NonexistentUserError.new(user) - end + 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) @@ -89,7 +71,7 @@ module DovecotPlugin usernames = Filesystem.get_subdirs(domain_path) usernames.each do |username| - users << "#{username}@#{domain}" + users << User.new("#{username}@#{domain}") end rescue NonexistentDomainError # Party hard.