Bug #5600

OpenSSL::X509::Request can't sign() an OpenSSL::PKey::EC

Added by scaligo (Steve Caligo) 7 months ago. Updated 7 months ago.

[ruby-core:40853]
Status:Assigned Start date:11/09/2011
Priority:Normal Due date:
Assignee:MartinBosslet (Martin Bosslet) % Done:

0%

Category:ext
Target version:2.0.0
ruby -v:ruby 1.9.3p0 (2011-10-30 revision 33570) [x86_64-linux]

Description

Unlike the PKey::DSA and PKey::RSA classes, PKey::EC provides a private_key?() rather than private?() method and is thus incompatible with the other OpenSSL classes that rely on them, i.e. it makes impossible to generate a certificate signing request: key = OpenSSL::PKey::EC.new('secp521r1') key.generate_key req = OpenSSL::X509::Request.new req.public_key = key req.subject = OpenSSL::X509::Name.parse('CN=whatever') req.sign(key, OpenSSL::Digest::SHA384.new) which produces the error: in `sign': undefined method `private?' for #<OpenSSL::PKey::EC:0x000000021b4980> (NoMethodError) ossl_pkey_ec.c should either: - rb_define_method() the missing private? and public? methods - rename public_key? to public? and private_key? to private? Judging by the source code, this should be present in branch 1.8 as well.

History

Updated by MartinBosslet (Martin Bosslet) 7 months ago

  • Status changed from Open to Assigned
  • Assignee set to MartinBosslet (Martin Bosslet)
  • Target version set to 2.0.0

Also available in: Atom PDF