Sha256: eec85d504c17f396f87503521e44d61880c91b331f4acd1bc034cf702bb9b618

Contents?: true

Size: 1.22 KB

Versions: 137

Compression:

Stored size: 1.22 KB

Contents

require 'openssl'

module Kontena
  module Machine
    module CertHelper

      def certificate_public_key(cert)
        cert[/(-----BEGIN CERTIFICATE-----.+?-----END CERTIFICATE-----)/m, 1]
      end

      def generate_self_signed_cert
        key = OpenSSL::PKey::RSA.new(2048)
        public_key = key.public_key

        subject = "/C=FI/O=Test/OU=Test/CN=Test"

        cert = OpenSSL::X509::Certificate.new
        cert.subject = cert.issuer = OpenSSL::X509::Name.parse(subject)
        cert.not_before = Time.now
        cert.not_after = Time.now + (10 * 365 * 24 * 60 * 60)
        cert.public_key = public_key
        cert.serial = 0x0
        cert.version = 2

        ef = OpenSSL::X509::ExtensionFactory.new
        ef.subject_certificate = cert
        ef.issuer_certificate = cert
        cert.extensions = [
          ef.create_extension("basicConstraints","CA:TRUE", true),
          ef.create_extension("subjectKeyIdentifier", "hash")
        ]
        cert.add_extension ef.create_extension("authorityKeyIdentifier",
                                               "keyid:always,issuer:always")

        cert.sign key, OpenSSL::Digest::SHA1.new

        pem = cert.to_pem
        pem << key.to_s
        pem
      end
    end
  end
end

Version data entries

137 entries across 137 versions & 2 rubygems

Version Path
krates-1.7.11 lib/kontena/machine/cert_helper.rb
krates-1.7.10 lib/kontena/machine/cert_helper.rb
krates-1.7.9 lib/kontena/machine/cert_helper.rb
krates-1.7.8 lib/kontena/machine/cert_helper.rb
krates-1.7.7 lib/kontena/machine/cert_helper.rb
krates-1.7.6 lib/kontena/machine/cert_helper.rb
krates-1.7.5 lib/kontena/machine/cert_helper.rb
krates-1.7.4 lib/kontena/machine/cert_helper.rb
krates-1.7.3 lib/kontena/machine/cert_helper.rb
krates-1.7.2 lib/kontena/machine/cert_helper.rb
krates-1.7.1 lib/kontena/machine/cert_helper.rb
krates-1.7.0 lib/kontena/machine/cert_helper.rb
krates-1.6.9 lib/kontena/machine/cert_helper.rb
krates-1.6.8 lib/kontena/machine/cert_helper.rb
krates-1.6.7 lib/kontena/machine/cert_helper.rb
krates-1.6.6 lib/kontena/machine/cert_helper.rb
krates-1.6.5 lib/kontena/machine/cert_helper.rb
krates-1.6.4 lib/kontena/machine/cert_helper.rb
krates-1.6.3 lib/kontena/machine/cert_helper.rb
krates-1.6.2 lib/kontena/machine/cert_helper.rb