edu.wisc.doit.tcrypt.BouncyCastleFileEncrypterDecrypterIT.java Source code

Java tutorial

Introduction

Here is the source code for edu.wisc.doit.tcrypt.BouncyCastleFileEncrypterDecrypterIT.java

Source

/**
 * Copyright 2012, Board of Regents of the University of
 * Wisconsin System. See the NOTICE file distributed with
 * this work for additional information regarding copyright
 * ownership. Board of Regents of the University of Wisconsin
 * System licenses this file to you under the Apache License,
 * Version 2.0 (the "License"); you may not use this file
 * except in compliance with the License. You may obtain a
 * copy of the License at:
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on
 * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied. See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package edu.wisc.doit.tcrypt;

import static org.junit.Assert.assertEquals;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.nio.charset.Charset;

import org.apache.commons.io.FileUtils;
import org.apache.commons.io.IOUtils;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.TemporaryFolder;

/**
 * Uses Runtime.exec to verify the java code interacts correctly with openssl
 */
public class BouncyCastleFileEncrypterDecrypterIT {
    @Rule
    public TemporaryFolder testFolder = new TemporaryFolder();

    private FileEncrypter fileEncrypter;
    private FileDecrypter fileDecrypter;

    @Before
    public void setup() throws IOException {
        fileEncrypter = new BouncyCastleFileEncrypter(
                new InputStreamReader(this.getClass().getResourceAsStream("/my.wisc.edu-public.pem")));
        fileDecrypter = new BouncyCastleFileDecrypter(
                new InputStreamReader(this.getClass().getResourceAsStream("/my.wisc.edu-private.pem")));
    }

    @Test
    public void testOpenSSLEncJavaDec() throws Exception {
        //Encrypt with openssl
        final File encryptFileScript = setupTempFile("encryptFile.sh");
        encryptFileScript.setExecutable(true);

        final File publicKey = setupTempFile("my.wisc.edu-public.pem");
        final File testFile = setupTempFile("testFile.txt");

        final ProcessBuilder pb = new ProcessBuilder(encryptFileScript.getAbsolutePath(),
                publicKey.getAbsolutePath(), testFile.getAbsolutePath());

        final Process p = pb.start();
        final int ret = p.waitFor();
        if (ret != 0) {
            final String pOut = IOUtils.toString(p.getInputStream(), TokenEncrypter.CHARSET).trim();
            System.out.println(pOut);
            final String pErr = IOUtils.toString(p.getErrorStream(), TokenEncrypter.CHARSET).trim();
            System.out.println(pErr);
        }
        assertEquals(0, ret);

        //Decrypt with java
        final File encryptedFile = new File(testFile.getParentFile(), "testFile.txt.tar");

        final InputStream encTestFileInStream = new FileInputStream(encryptedFile);
        final ByteArrayOutputStream testFileOutStream = new ByteArrayOutputStream();
        fileDecrypter.decrypt(encTestFileInStream, testFileOutStream);
        final String actual = new String(testFileOutStream.toByteArray(), Charset.defaultCharset()).trim();

        //Verify
        final String expected = FileUtils.readFileToString(testFile);
        assertEquals(expected, actual);
    }

    @Test
    public void testJavaEncOpenSSLDec() throws Exception {
        //Encrypt with Java
        final File testFile = setupTempFile("testFile.txt");

        InputStream testFileInStream = new FileInputStream(testFile);

        final File encFile = this.testFolder.newFile("testFile.txt.tar");
        this.fileEncrypter.encrypt("testFile.txt", (int) testFile.length(), testFileInStream,
                new FileOutputStream(encFile));

        //Decrypt with OpenSSL
        final File decryptFileScript = setupTempFile("decryptFile.sh");
        decryptFileScript.setExecutable(true);

        final File privateKey = setupTempFile("my.wisc.edu-private.pem");

        final ProcessBuilder pb = new ProcessBuilder(decryptFileScript.getAbsolutePath(),
                privateKey.getAbsolutePath(), encFile.getAbsolutePath());

        final Process p = pb.start();
        final int ret = p.waitFor();
        if (ret != 0) {
            final String pOut = IOUtils.toString(p.getInputStream(), TokenEncrypter.CHARSET).trim();
            System.out.println(pOut);
            final String pErr = IOUtils.toString(p.getErrorStream(), TokenEncrypter.CHARSET).trim();
            System.out.println(pErr);
        }
        assertEquals(0, ret);

        final File decryptedFile = new File(encFile.getParentFile(), "testFile.txt");

        //Verify
        final String expected = FileUtils.readFileToString(testFile);
        final String actual = FileUtils.readFileToString(decryptedFile);
        assertEquals(expected, actual);
    }

    protected File setupTempFile(final String fileName) throws IOException {
        final File encryptFileScript = testFolder.newFile(fileName);
        FileUtils.copyInputStreamToFile(this.getClass().getResourceAsStream("/" + fileName), encryptFileScript);
        return encryptFileScript;
    }
}