Module: PkernelJce::CSR
- Included in:
- Pkernel::CSR, CSRProxy
- Defined in:
- lib/pkernel_jce/csr.rb
Instance Method Summary collapse
-
#dump(csr, params = {}) ⇒ Object
end generate().
- #generate(identity, opts = {}) ⇒ Object
-
#is_signature_valid?(csr) ⇒ Boolean
end load.
- #load(options = {}) ⇒ Object
-
#public_key(csr) ⇒ Object
end is_signature_valid?.
Instance Method Details
#dump(csr, params = {}) ⇒ Object
end generate()
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/pkernel_jce/csr.rb', line 44 def dump(csr, params = {}) if csr.nil? raise PkernelJce::Error, "CSR object to be written is nil" end file = params[:file] baos = java.io.ByteArrayOutputStream.new if not file.nil? PkernelJce::GConf.instance.glog.debug "Dump CRL to file '#{file}'" writer = org.bouncycastle.openssl.jcajce.JcaPEMWriter.new(java.io.OutputStreamWriter.new(java.io.FileOutputStream.new(file))) else PkernelJce::GConf.instance.glog.debug "Dump CRL to memory" writer = org.bouncycastle.openssl.jcajce.JcaPEMWriter.new(java.io.OutputStreamWriter.new(baos)) end begin writer.writeObject(csr) ensure writer.flush writer.close end if file.nil? baos.toByteArray end end |
#generate(identity, opts = {}) ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/pkernel_jce/csr.rb', line 11 def generate(identity, opts = {} ) owner = opts[:owner] if owner.nil? and identity.certificate.nil? raise PkernelJce::Error, "Either Owner or Certificate must exist to issue CSR" elsif not owner.nil? subject = owner.to_x500_subject elsif not identity.certificate.nil? subject = PkernelJce::Certificate.ensure_java_cert(identity.certificate).subject_dn end signHash = opts[:signHash] || "SHA256" signAlgo = opts[:signAlgo] if signAlgo.nil? signAlgo = PkernelJce::KeyPair.derive_signing_algo(identity.privKey,signHash) end provider = opts[:provider] if provider.nil? PkernelJce::GConf.instance.glog.debug "Adding default provider" prov = PkernelJce::Provider.add_default else PkernelJce::GConf.instance.glog.debug "Adding provider #{provider.name}" prov = PkernelJce::Provider.add_provider(provider) end #p10Builder = org.bouncycastle.pkcs.jcajce.JcaPKCS10CertificationRequestBuilder.new(subject, PkernelJce::KeyPair.public_key(identity.privKey)) p10Builder = org.bouncycastle.pkcs.jcajce.JcaPKCS10CertificationRequestBuilder.new(subject, identity.pubKey) sign = org.bouncycastle.operator.jcajce.JcaContentSignerBuilder.new(signAlgo).setProvider(prov).build(identity.privKey) csr = p10Builder.build(sign) csr end |
#is_signature_valid?(csr) ⇒ Boolean
end load
101 102 103 104 |
# File 'lib/pkernel_jce/csr.rb', line 101 def is_signature_valid?(csr) cvProv = org.bouncycastle.operator.jcajce.JcaContentVerifierProviderBuilder.new.build(csr.getSubjectPublicKeyInfo) csr.isSignatureValid(cvProv) end |
#load(options = {}) ⇒ Object
75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
# File 'lib/pkernel_jce/csr.rb', line 75 def load( = {}) #todo is this content pem or binary? # now assumed is pem file = [:file] bin = [:bin] if not file.nil? and not file.empty? PkernelJce::GConf.instance.glog.debug "Load CSR from #{file}" f = java.io.File.new(file) if f.exists? reader = org.bouncycastle.openssl.PEMParser.new(java.io.InputStreamReader.new(java.io.FileInputStream.new(f))) else raise PkernelJce::Error, "File '#{f.absolute_path}' not found" end elsif not bin.nil? PkernelJce::GConf.instance.glog.debug "Load CSR from memory" reader = org.bouncycastle.openssl.PEMParser.new(java.io.InputStreamReader.new(java.io.ByteArrayInputStream.new(bin))) else raise PkernelJce::Error, "No bin or file input is given to load" end obj = reader.readObject end |
#public_key(csr) ⇒ Object
end is_signature_valid?
107 108 109 110 111 112 113 |
# File 'lib/pkernel_jce/csr.rb', line 107 def public_key(csr) if csr.nil? raise PkernelJce::Error, "CSR given to extract public key is nil" end org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter.new.getPublicKey(csr.getSubjectPublicKeyInfo) end |