All Downloads are FREE. Search and download functionalities are using the official Maven repository.

edu.vt.middleware.crypt.util.CryptWriter Maven / Gradle / Ivy

/*
  $Id$

  Copyright (C) 2007-2010 Virginia Tech.
  All rights reserved.

  SEE LICENSE FOR MORE INFORMATION

  Author:  Middleware Services
  Email:   [email protected]
  Version: $Revision$
  Updated: $Date$
*/
package edu.vt.middleware.crypt.util;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.security.Key;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.SecureRandom;
import java.security.cert.Certificate;
import java.security.cert.CertificateEncodingException;
import edu.vt.middleware.crypt.CryptException;

/**
 * Helper class for performing I/O write operations on cryptographic data.
 *
 * @author  Middleware Services
 * @version  $Revision: 3 $
 */

public final class CryptWriter
{

  /** Protected constructor of utility class. */
  protected CryptWriter() {}


  /**
   * Writes the supplied key to the file using its native encoding. The format
   * and encoding of the key is commonly determined by the key type. See {@link
   * #writeEncodedKey(Key, OutputStream)} for more information.
   *
   * @param  key  Key to write to file.
   * @param  file  Output file descriptor.
   *
   * @throws  IOException  On write errors.
   */
  public static void writeEncodedKey(final Key key, final File file)
    throws IOException
  {
    writeEncodedKey(key, new BufferedOutputStream(new FileOutputStream(file)));
  }


  /**
   * Writes the supplied key to the output stream using its native encoding. The
   * format and encoding of the key is commonly determined by the key type:
   *
   * 
    *
  • SecretKey - RAW format consisting of unmodified key * material bytes.
  • *
  • PrivateKey - DER-encoded PKCS#8 format key.
  • *
  • PublicKey - DER-encoded X.509 format key.
  • *
* * @param key Key to write. * @param out Ouput stream to write key data to. * * @throws IOException On write errors. */ public static void writeEncodedKey(final Key key, final OutputStream out) throws IOException { writeData(out, key.getEncoded()); } /** * Writes the supplied public key to the supplied file in PEM format. * * @param key Public key to write to file. * @param file Output file descriptor. * * @throws IOException On write errors. */ public static void writePemKey(final PublicKey key, final File file) throws IOException { writePemKey(key, new BufferedOutputStream(new FileOutputStream(file))); } /** * Writes the supplied public key to the supplied output stream in PEM format. * * @param key Public key to write to file. * @param out Ouput stream to write key data to. * * @throws IOException On write errors. */ public static void writePemKey(final PublicKey key, final OutputStream out) throws IOException { writeData(out, Convert.toAsciiBytes(PemHelper.encodeKey(key))); } /** * Writes the supplied private key to the supplied file in encrypted PEM * format. * * @param key Private key to write to file. * @param password Password used to encrypt private key using 256-bit AES * encryption; may be null to indicate no encryption. * @param random Secure random provider used for encrypting private key. * @param file Output file descriptor. * * @throws IOException On write errors. */ public static void writePemKey( final PrivateKey key, final char[] password, final SecureRandom random, final File file) throws IOException { writePemKey( key, password, random, new BufferedOutputStream(new FileOutputStream(file))); } /** * Writes the supplied private key to the supplied output stream in PEM * format. * * @param key Private key to write to file. * @param password Password used to encrypt private key using 256-bit AES * encryption; may be null to indicate no encryption. * @param random Secure random provider used for encrypting private key. * @param out Ouput stream to write key data to. * * @throws IOException On write errors. */ public static void writePemKey( final PrivateKey key, final char[] password, final SecureRandom random, final OutputStream out) throws IOException { writeData( out, Convert.toAsciiBytes(PemHelper.encodeKey(key, password, random))); } /** * Writes the supplied certificate to the file using its native encoding. It * is assumed that each certificate type would have only a single form of * encoding; for example, X.509 certificates would be encoded as ASN.1 DER. * * @param cert Certificate to write to file. * @param file Output file descriptor. * * @throws IOException On write errors. * @throws CryptException If the given cert cannot be decoded to bytes. */ public static void writeEncodedCertificate( final Certificate cert, final File file) throws CryptException, IOException { writeEncodedCertificate( cert, new BufferedOutputStream(new FileOutputStream(file))); } /** * Writes the supplied certificate to the output stream using its native * encoding. It is assumed that each certificate type would have only a single * form of encoding; for example, X.509 certificates would be encoded as ASN.1 * DER. * * @param cert Certificate to write to file. * @param out Ouput stream to write cert data to. * * @throws IOException On write errors. * @throws CryptException If the given cert cannot be decoded to bytes. */ public static void writeEncodedCertificate( final Certificate cert, final OutputStream out) throws CryptException, IOException { try { writeData(out, cert.getEncoded()); } catch (CertificateEncodingException e) { throw new CryptException("Cannot generate encoded certificate.", e); } } /** * Writes the supplied certificate to the supplied file in PEM format. * * @param cert Certificate to write to file. * @param file Output file descriptor. * * @throws IOException On write errors. */ public static void writePemCertificate( final Certificate cert, final File file) throws IOException { writePemCertificate( cert, new BufferedOutputStream(new FileOutputStream(file))); } /** * Writes the supplied certificate to the supplied output stream in PEM * format. * * @param cert Certificate to write to the output stream. * @param out Ouput stream to write cert data to. * * @throws IOException On write errors. */ public static void writePemCertificate( final Certificate cert, final OutputStream out) throws IOException { writeData(out, Convert.toAsciiBytes(PemHelper.encodeCert(cert))); } /** * Writes the supplied certificates in sequence to the file using their native * encoding. It is assumed that each certificate type would have only a single * form of encoding; for example, X.509 certificates would be encoded as ASN.1 * DER. * * @param certs Certificates to write to file. * @param file Output file descriptor. * * @throws IOException On write errors. * @throws CryptException If the given cert cannot be decoded to bytes. */ public static void writeEncodedCertificates( final Certificate[] certs, final File file) throws CryptException, IOException { writeEncodedCertificates( certs, new BufferedOutputStream(new FileOutputStream(file))); } /** * Writes the supplied certificates in sequence to the output stream using * their native encoding. It is assumed that each certificate type would have * only a single form of encoding; for example, X.509 certificates would be * encoded as ASN.1 DER. * * @param certs Certificates to write to the output stream. * @param out Ouput stream to write cert data to. * * @throws IOException On write errors. * @throws CryptException If the given cert cannot be decoded to bytes. */ public static void writeEncodedCertificates( final Certificate[] certs, final OutputStream out) throws CryptException, IOException { try { for (int i = 0; i < certs.length; i++) { out.write(certs[i].getEncoded()); } } catch (CertificateEncodingException e) { throw new CryptException("Cannot generate encoded certificate.", e); } finally { out.close(); } } /** * Writes the concatenation of the given certificates in PEM format to the * given file. * * @param certs Certificates to write to file. * @param file Output file descriptor. * * @throws IOException On write errors. */ public static void writePemCertificates( final Certificate[] certs, final File file) throws IOException { writePemCertificates( certs, new BufferedOutputStream(new FileOutputStream(file))); } /** * Writes the concatenation of the given certificates in PEM format to the * given output stream. * * @param certs Certificates to write to the output stream. * @param out Ouput stream to write cert data to. * * @throws IOException On write errors. */ public static void writePemCertificates( final Certificate[] certs, final OutputStream out) throws IOException { try { for (int i = 0; i < certs.length; i++) { out.write(Convert.toAsciiBytes(PemHelper.encodeCert(certs[i]))); } } finally { out.close(); } } /** * Writes the given data to the given stream and closes it on completion. * * @param out Output stream to write data to. * @param data Data to be written. * * @throws IOException On write errors. */ private static void writeData(final OutputStream out, final byte[] data) throws IOException { try { out.write(data); } finally { if (out != null) { out.close(); } } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy