Sha256: 9b2748cee13f308f12d422a2527794b82f44653d776193d8229563fda24355f5
Contents?: true
Size: 1.55 KB
Versions: 9
Compression:
Stored size: 1.55 KB
Contents
# encoding: UTF-8 module Vines module Command class Cert def run(opts) raise 'vines cert <domain>' unless opts[:args].size == 1 dir = File.expand_path('../certs', opts[:config]) create_cert(opts[:args].first, dir) end def create_cert(domain, dir) domain = domain.downcase key = OpenSSL::PKey::RSA.generate(2048) ca = OpenSSL::X509::Name.parse("/C=US/ST=Colorado/L=Denver/O=Vines XMPP Server/CN=#{domain}") cert = OpenSSL::X509::Certificate.new cert.version = 2 cert.subject = ca cert.issuer = ca cert.serial = Time.now.to_i cert.public_key = key.public_key cert.not_before = Time.now - (24 * 60 * 60) cert.not_after = Time.now + (365 * 24 * 60 * 60) factory = OpenSSL::X509::ExtensionFactory.new factory.subject_certificate = cert factory.issuer_certificate = cert cert.extensions = [ %w[basicConstraints CA:TRUE], %w[subjectKeyIdentifier hash], %w[subjectAltName] << [domain, hostname].map {|n| "DNS:#{n}" }.join(',') ].map {|k, v| factory.create_ext(k, v) } cert.sign(key, OpenSSL::Digest::SHA1.new) {'key' => key, 'crt' => cert}.each_pair do |ext, o| name = File.join(dir, "#{domain}.#{ext}") File.open(name, "w") {|f| f.write(o.to_pem) } File.chmod(0600, name) if ext == 'key' end end private def hostname Socket.gethostbyname(Socket.gethostname).first.downcase end end end end
Version data entries
9 entries across 9 versions & 1 rubygems