class OpenSSL::PKCS12

def self.create(pass, name, key, cert)

def self.create(pass, name, key, cert)
  pkcs12 = self.new(pass, name, key, cert)
  pkcs12.generate
  pkcs12
end

def generate

def generate
  key_reader = StringReader.new(key.to_pem)
  key_pair = PEMReader.new(key_reader).read_object
  cert_input_stream = StringBufferInputStream.new(certificate.to_pem)
  certs = CertificateFactory.get_instance("X.509").generate_certificates(cert_input_stream)
  store = KeyStore.get_instance("PKCS12", "BC")
  store.load(nil, nil)
  store.set_key_entry(@name, key_pair.get_private, nil, certs.to_array(Java::java.security.cert.Certificate[certs.size].new))
  pkcs12_output_stream = ByteArrayOutputStream.new
  store.store(pkcs12_output_stream, @pass.to_java.to_char_array)
  @der = String.from_java_bytes(pkcs12_output_stream.to_byte_array)
end

def initialize(pass, name, key, cert)

def initialize(pass, name, key, cert)
  @pass = pass
  @name = name
  @key = key
  @certificate = cert
end

def to_der

def to_der
  @der
end