Module: EllipticCurve::Ecdsa

Defined in:
lib/ecdsa.rb

Class Method Summary collapse

Class Method Details

.sign(message, privateKey, hashfunc = nil) ⇒ Object



10
11
12
13
14
15
16
17
18
19
# File 'lib/ecdsa.rb', line 10

def self.sign(message, privateKey, hashfunc=nil)
    if hashfunc.nil?
        message = Digest::SHA256.digest(message)
    else
        message = hashfunc(message)
    end

    signature = privateKey.openSslPrivateKey.dsa_sign_asn1(message)
    return Signature.new(signature)
end

.verify(message, signature, publicKey, hashfunc = nil) ⇒ Object



21
22
23
24
25
26
27
28
# File 'lib/ecdsa.rb', line 21

def self.verify(message, signature, publicKey, hashfunc=nil)
    if hashfunc.nil?
        message = Digest::SHA256.digest(message)
    else
        message = hashfunc(message)
    end
    return publicKey.openSslPublicKey.dsa_verify_asn1(message, signature.toDer())
end