Class: Zold::Key

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

Overview

A key

Instance Method Summary collapse

Constructor Details

#initialize(file: nil, text: nil) ⇒ Key

Returns a new instance of Key.


34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/zold/key.rb', line 34

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 AtomicFile.new(path).read
    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


53
54
55
# File 'lib/zold/key.rb', line 53

def ==(other)
  to_s == other.to_s
end

#sign(text) ⇒ Object


65
66
67
# File 'lib/zold/key.rb', line 65

def sign(text)
  Base64.encode64(rsa.sign(OpenSSL::Digest::SHA256.new, text)).delete("\n")
end

#to_pubObject


61
62
63
# File 'lib/zold/key.rb', line 61

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

#to_sObject


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

def to_s
  rsa.to_s.strip
end

#verify(signature, text) ⇒ Object


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

def verify(signature, text)
  rsa.verify(OpenSSL::Digest::SHA256.new, Base64.decode64(signature), text)
end