diff options
author | Azul <azul@riseup.net> | 2016-08-29 11:59:54 +0200 |
---|---|---|
committer | Azul <azul@riseup.net> | 2016-08-29 12:03:16 +0200 |
commit | 0784391a21b75ca52892e992a614b0f927ade00e (patch) | |
tree | 4efa7445db3a0521a14d75e626d64f85434a3ea5 /lib/nickserver/request_handlers/local_email_handler.rb | |
parent | 55006b3ce5967fde08081bfd56d56f76dbaf7c53 (diff) |
refactor: split EmailHandler in 3
InvalidEmailHandler - handle emails with an invalid format
LocalEmailHandler - handle emails on the local domain
EmailHandler - handle all other emails by using hkp
This is a preparation to add leap provider email lookup and remove
hkp eventually. But for now we keep the behaviour the same and only
refactor.
Diffstat (limited to 'lib/nickserver/request_handlers/local_email_handler.rb')
-rw-r--r-- | lib/nickserver/request_handlers/local_email_handler.rb | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/lib/nickserver/request_handlers/local_email_handler.rb b/lib/nickserver/request_handlers/local_email_handler.rb new file mode 100644 index 0000000..1f2abc2 --- /dev/null +++ b/lib/nickserver/request_handlers/local_email_handler.rb @@ -0,0 +1,32 @@ +require 'nickserver/email_address' +require 'nickserver/error_response' +require 'nickserver/couch_db/source' + +module Nickserver + module RequestHandlers + class LocalEmailHandler + + def call(request) + return nil unless request.email + domain = Config.domain || request.domain + return missing_domain_response if domain.nil? || domain == '' + email = EmailAddress.new(request.email) + return nil unless email.domain?(domain) + source.query email + end + + protected + + attr_reader :domain + + def source + Nickserver::CouchDB::Source.new + end + + def missing_domain_response + ErrorResponse.new "HTTP request must include a Host header." + end + + end + end +end |