Class: PQCrypto::KEM::Keypair

Inherits:
Object
  • Object
show all
Defined in:
lib/pq_crypto/kem.rb

Direct Known Subclasses

HybridKEM::Keypair

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(public_key, secret_key) ⇒ Keypair

Returns a new instance of Keypair.



75
76
77
78
79
80
81
82
# File 'lib/pq_crypto/kem.rb', line 75

def initialize(public_key, secret_key)
  @public_key = public_key
  @secret_key = secret_key

  unless @public_key.algorithm == @secret_key.algorithm
    raise InvalidKeyError, "KEM keypair algorithms do not match"
  end
end

Instance Attribute Details

#public_keyObject (readonly)

Returns the value of attribute public_key.



73
74
75
# File 'lib/pq_crypto/kem.rb', line 73

def public_key
  @public_key
end

#secret_keyObject (readonly)

Returns the value of attribute secret_key.



73
74
75
# File 'lib/pq_crypto/kem.rb', line 73

def secret_key
  @secret_key
end

Instance Method Details

#algorithmObject



84
85
86
# File 'lib/pq_crypto/kem.rb', line 84

def algorithm
  @public_key.algorithm
end