summaryrefslogtreecommitdiff
path: root/lib/nickserver/wkd/url.rb
diff options
context:
space:
mode:
authorazul <azul@riseup.net>2017-09-23 14:44:56 +0000
committerazul <azul@riseup.net>2017-09-23 14:44:56 +0000
commit787287318c54b019a12ef79525c9f5b10d93724d (patch)
tree653c56240d681e1aaf5f7f0ef00904d0bd24301f /lib/nickserver/wkd/url.rb
parentbc48ac30c232f1e3fa5f5ad455f14d5fec17abeb (diff)
parentc0410a5a5c5dbdd5fa182ac25d72ebb99e48bbb3 (diff)
Merge branch 'wkd' into 'master'
Fetch keys from web key directory See merge request leap/nickserver!18
Diffstat (limited to 'lib/nickserver/wkd/url.rb')
-rw-r--r--lib/nickserver/wkd/url.rb31
1 files changed, 31 insertions, 0 deletions
diff --git a/lib/nickserver/wkd/url.rb b/lib/nickserver/wkd/url.rb
new file mode 100644
index 0000000..965e7ec
--- /dev/null
+++ b/lib/nickserver/wkd/url.rb
@@ -0,0 +1,31 @@
+require 'digest/sha1'
+require 'zbase32'
+
+module Nickserver
+ module Wkd
+ class Url
+
+ def initialize(email)
+ @domain = email.domain.downcase
+ @local_part = email.local_part.downcase
+ end
+
+ def to_s
+ "https://#{domain}/.well-known/openpgpkey" +
+ "/hu/#{domain}/#{encoded_digest}"
+ end
+
+ protected
+
+ attr_reader :domain, :local_part
+
+ def encoded_digest
+ ZBase32.encode32(digest.to_i(16).to_s(2))
+ end
+
+ def digest
+ Digest::SHA1.hexdigest local_part
+ end
+ end
+ end
+end