summaryrefslogtreecommitdiff
path: root/lib/nickserver/request_handler.rb
diff options
context:
space:
mode:
authorazul <azul@riseup.net>2016-07-21 19:25:38 +0200
committerGitHub <noreply@github.com>2016-07-21 19:25:38 +0200
commit6663a070f6b34d5af4c1812b1255c64534a7a59a (patch)
treeb01cf32a0a95a11b3ea9bd279c2b251a1fb5b58e /lib/nickserver/request_handler.rb
parentd7599715c6d24534dcccbe29cfc058e534039053 (diff)
parent59263baee9fc04524c8a69af1f7293fa4315d3ff (diff)
Merge pull request #6 from pixelated/by_fingerprint
By fingerprint
Diffstat (limited to 'lib/nickserver/request_handler.rb')
-rw-r--r--lib/nickserver/request_handler.rb32
1 files changed, 23 insertions, 9 deletions
diff --git a/lib/nickserver/request_handler.rb b/lib/nickserver/request_handler.rb
index 608db83..856ec5d 100644
--- a/lib/nickserver/request_handler.rb
+++ b/lib/nickserver/request_handler.rb
@@ -10,14 +10,14 @@ module Nickserver
end
def respond_to(params, headers)
- email = get_email_from_params(params)
- if email.nil?
- send_not_found
- elsif email.invalid?
- send_error("Not a valid address")
+ if params && params["address"] && params["address"].any?
+ by_email(params, headers)
+ elsif params && params["fingerprint"] && params["fingerprint"].any?
+ by_fingerprint(params)
else
- send_key(email, headers)
+ send_not_found
end
+
rescue RuntimeError => exc
puts "Error: #{exc}"
puts exc.backtrace
@@ -26,9 +26,23 @@ module Nickserver
protected
- def get_email_from_params(params)
- if params && params["address"] && params["address"].any?
- EmailAddress.new(params["address"].first)
+ def by_email(params, headers)
+ email = EmailAddress.new(params["address"].first)
+ if email.invalid?
+ send_error("Not a valid address")
+ else
+ send_key(email, headers)
+ end
+ end
+
+ def by_fingerprint(params)
+ fingerprint = params["fingerprint"].first
+ if fingerprint.length == 40 && !fingerprint[/\H/]
+ source = Nickserver::Hkp::Source.new(adapter)
+ key_response = source.get_key_by_fingerprint(fingerprint)
+ send_response key_response.status, key_response.content
+ else
+ send_error('Fingerprint invalid: ' + fingerprint)
end
end