Class: Zold::Key
- Inherits:
-
Object
- Object
- Zold::Key
- Defined in:
- lib/zold/key.rb
Overview
A key
Constant Summary collapse
- ROOT =
Public key of the root wallet
Key.new(file: File.(File.join(File.dirname(__FILE__), '../../resources/root.pub')))
Instance Method Summary collapse
- #==(other) ⇒ Object
-
#initialize(file: nil, text: nil) ⇒ Key
constructor
A new instance of Key.
- #root? ⇒ Boolean
- #sign(text) ⇒ Object
- #to_pub ⇒ Object
- #to_s ⇒ Object
- #verify(signature, text) ⇒ Object
Constructor Details
#initialize(file: nil, text: nil) ⇒ Key
Returns a new instance of Key.
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/zold/key.rb', line 35 def initialize(file: nil, text: nil) @body = lambda do unless file.nil? path = File.(file) raise "Can't find RSA key at #{file} (#{path})" unless File.exist?(path) return File.read(path) end unless text.nil? return text if text.start_with?('-----') return [ '-----BEGIN PUBLIC KEY-----', text.gsub(/(?<=\G.{64})/, "\n"), '-----END PUBLIC KEY-----' ].join("\n") end raise 'Either file or text must be set' end end |
Instance Method Details
#==(other) ⇒ Object
61 62 63 |
# File 'lib/zold/key.rb', line 61 def ==(other) to_s == other.to_s end |
#sign(text) ⇒ Object
73 74 75 |
# File 'lib/zold/key.rb', line 73 def sign(text) Base64.encode64(rsa.sign(OpenSSL::Digest.new('SHA256'), text)).delete("\n") end |
#to_pub ⇒ Object
69 70 71 |
# File 'lib/zold/key.rb', line 69 def to_pub to_s.delete("\n").gsub(/-{5}[ A-Z]+-{5}/, '') end |
#to_s ⇒ Object
65 66 67 |
# File 'lib/zold/key.rb', line 65 def to_s rsa.to_s.strip end |
#verify(signature, text) ⇒ Object
77 78 79 |
# File 'lib/zold/key.rb', line 77 def verify(signature, text) rsa.verify(OpenSSL::Digest.new('SHA256'), Base64.decode64(signature), text) end |