Class: Zold::Key

Inherits:
Object
  • Object
show all
Defined in:
lib/zold/key.rb

Overview

A key

Constant Summary collapse

ROOT =

Public key of the root wallet

Key.new(file: File.expand_path(File.join(File.dirname(__FILE__), '../../resources/root.pub')))

Instance Method Summary collapse

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.expand_path(file)
      raise "Can't find RSA key at #{file} (#{path})" unless File.exist?(path)
      return IO.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

#root?Boolean

Returns:

  • (Boolean)


57
58
59
# File 'lib/zold/key.rb', line 57

def root?
  to_s == ROOT.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::SHA256.new, text)).delete("\n")
end

#to_pubObject



69
70
71
# File 'lib/zold/key.rb', line 69

def to_pub
  to_s.delete("\n").gsub(/-{5}[ A-Z]+-{5}/, '')
end

#to_sObject



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::SHA256.new, Base64.decode64(signature), text)
end