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

io.github.astrapi69.crypt.data.factory.CipherFactory Maven / Gradle / Ivy

Go to download

Utility project that provides data beans, writers and readers for encryption and decryption

There is a newer version: 10
Show newest version
/**
 * The MIT License
 *
 * Copyright (C) 2015 Asterios Raptis
 *
 * Permission is hereby granted, free of charge, to any person obtaining
 * a copy of this software and associated documentation files (the
 * "Software"), to deal in the Software without restriction, including
 * without limitation the rights to use, copy, modify, merge, publish,
 * distribute, sublicense, and/or sell copies of the Software, and to
 * permit persons to whom the Software is furnished to do so, subject to
 * the following conditions:
 *
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */
package io.github.astrapi69.crypt.data.factory;

import java.io.UnsupportedEncodingException;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.spec.AlgorithmParameterSpec;
import java.security.spec.InvalidKeySpecException;
import java.security.spec.KeySpec;
import java.text.Normalizer;

import javax.crypto.Cipher;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.PBEKeySpec;
import javax.crypto.spec.PBEParameterSpec;

import io.github.astrapi69.crypt.api.algorithm.compound.CompoundAlgorithm;
import io.github.astrapi69.crypt.data.model.CryptModel;

/**
 * The factory class {@link CipherFactory} holds methods for creating {@link Cipher} objects
 */
public final class CipherFactory
{

	private CipherFactory()
	{
	}

	/**
	 * Factory method for creating a new {@link Cipher} from the given parameters
	 *
	 * @param model
	 *            the model bean for creating the cipher
	 * @return the cipher
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws InvalidKeySpecException
	 *             if generation of the SecretKey object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 * @throws InvalidKeyException
	 *             if initialization of the cipher object fails
	 * @throws InvalidAlgorithmParameterException
	 *             if initialization of the cipher object fails
	 * @throws UnsupportedEncodingException
	 *             if the named charset is not supported
	 */
	public static Cipher newCipher(final CryptModel model)
		throws NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException,
		InvalidKeyException, InvalidAlgorithmParameterException, UnsupportedEncodingException
	{
		final KeySpec keySpec = KeySpecFactory.newPBEKeySpec(model.getKey(), model.getSalt(),
			model.getIterationCount());
		final SecretKeyFactory factory = SecretKeyFactoryExtensions
			.newSecretKeyFactory(model.getAlgorithm().getAlgorithm());
		final SecretKey key = factory.generateSecret(keySpec);
		final AlgorithmParameterSpec paramSpec = AlgorithmParameterSpecFactory
			.newPBEParameterSpec(model.getSalt(), model.getIterationCount());
		return newCipher(model.getOperationMode(), key, paramSpec, key.getAlgorithm());
	}

	/**
	 * Factory method for creating a new {@link Cipher} from the given parameters
	 *
	 * @param operationMode
	 *            the operation mode
	 * @param key
	 *            the key
	 * @param algorithm
	 *            the algorithm
	 * @return the new {@link Cipher}
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 * @throws InvalidKeyException
	 *             if initialization of the cipher object fails
	 */
	public static Cipher newCipher(final int operationMode, final SecretKey key,
		final String algorithm)
		throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException
	{
		final Cipher cipher = newCipher(algorithm);
		cipher.init(operationMode, key);
		return cipher;
	}

	/**
	 * Factory method for creating a new {@link Cipher} from the given parameters
	 *
	 * @param operationMode
	 *            the operation mode
	 * @param key
	 *            the key
	 * @param paramSpec
	 *            the param spec
	 * @param algorithm
	 *            the algorithm
	 * @return the new {@link Cipher}
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 * @throws InvalidKeyException
	 *             if initialization of the cipher object fails
	 * @throws InvalidAlgorithmParameterException
	 *             if initialization of the cipher object fails
	 */
	public static Cipher newCipher(final int operationMode, final SecretKey key,
		final AlgorithmParameterSpec paramSpec, final String algorithm)
		throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException,
		InvalidAlgorithmParameterException
	{
		final Cipher cipher = newCipher(algorithm);
		cipher.init(operationMode, key, paramSpec);
		return cipher;
	}

	/**
	 * Factory method for creating a new {@link Cipher} from the given algorithm
	 *
	 * @param algorithm
	 *            the algorithm
	 * @return the new {@link Cipher}
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 */
	public static Cipher newCipher(final String algorithm)
		throws NoSuchAlgorithmException, NoSuchPaddingException
	{
		final Cipher cipher = Cipher.getInstance(algorithm);
		return cipher;
	}

	/**
	 * Factory method for creating a new {@link Cipher} from the given algorithm and provider
	 *
	 * @param algorithm
	 *            the algorithm
	 * @param provider
	 *            the provider
	 * @return the new {@link Cipher}
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws NoSuchProviderException
	 *             if the specified provider is not registered in the security provider list
	 * @throws NoSuchPaddingException
	 *             if the algorithm contains a padding scheme that is not available
	 */
	public static Cipher newCipher(final String algorithm, final String provider)
		throws NoSuchAlgorithmException, NoSuchProviderException, NoSuchPaddingException
	{
		final Cipher cipher = Cipher.getInstance(algorithm, provider);
		return cipher;
	}

	/**
	 * Factory method for creating a new {@link Cipher} from the given parameters
	 *
	 * @param password
	 *            the password
	 * @param algorithm
	 *            the algorithm
	 * @param salt
	 *            the salt
	 * @param iterationCount
	 *            the iteration count
	 * @param operationMode
	 *            the operation mode for the new cipher object
	 * @return the cipher
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws InvalidKeySpecException
	 *             if generation of the SecretKey object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 * @throws InvalidKeyException
	 *             if initialization of the cipher object fails
	 * @throws InvalidAlgorithmParameterException
	 *             if initialization of the cipher object fails
	 */
	public static Cipher newCipher(final String password, final String algorithm, final byte[] salt,
		final int iterationCount, final int operationMode)
		throws NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException,
		InvalidKeyException, InvalidAlgorithmParameterException
	{
		final KeySpec keySpec = KeySpecFactory.newPBEKeySpec(password, salt, iterationCount);
		final SecretKeyFactory factory = SecretKeyFactoryExtensions.newSecretKeyFactory(algorithm);
		final SecretKey key = factory.generateSecret(keySpec);
		final AlgorithmParameterSpec paramSpec = AlgorithmParameterSpecFactory
			.newPBEParameterSpec(salt, iterationCount);
		return newCipher(operationMode, key, paramSpec, key.getAlgorithm());
	}

	/**
	 * Factory method for creating a new PBE {@link Cipher} from the given parameters
	 *
	 * @param password
	 *            the password
	 * @param operationMode
	 *            the operation mode
	 * @param algorithm
	 *            the algorithm
	 * @return the cipher
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws InvalidKeySpecException
	 *             if generation of the SecretKey object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 * @throws InvalidAlgorithmParameterException
	 *             if initialization of the cipher object fails
	 * @throws InvalidKeyException
	 *             if initialization of the cipher object fails
	 */
	public static Cipher newPBECipher(char[] password, int operationMode, String algorithm)
		throws NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException,
		InvalidAlgorithmParameterException, InvalidKeyException
	{
		return newPBECipher(password, operationMode, algorithm, CompoundAlgorithm.SALT,
			CompoundAlgorithm.ITERATIONCOUNT);
	}

	/**
	 * Factory method for creating a new PBE {@link Cipher} from the given parameters
	 *
	 * @param password
	 *            the password
	 * @param operationMode
	 *            the operation mode
	 * @param algorithm
	 *            the algorithm
	 * @param salt
	 *            the salt
	 * @param iterationCount
	 *            the iteration count
	 * @return the cipher
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws InvalidKeySpecException
	 *             if generation of the SecretKey object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 * @throws InvalidAlgorithmParameterException
	 *             if initialization of the cipher object fails
	 * @throws InvalidKeyException
	 *             if initialization of the cipher object fails
	 */
	public static Cipher newPBECipher(char[] password, int operationMode, String algorithm,
		final byte[] salt, final int iterationCount)
		throws NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException,
		InvalidAlgorithmParameterException, InvalidKeyException
	{
		final PBEKeySpec keySpec = new PBEKeySpec(password);
		final SecretKeyFactory factory = SecretKeyFactory.getInstance(algorithm);
		final SecretKey key = factory.generateSecret(keySpec);
		final PBEParameterSpec paramSpec = new PBEParameterSpec(salt, iterationCount);
		return newCipher(operationMode, key, paramSpec, key.getAlgorithm());
	}

	/**
	 * Factory method for creating a new PBE {@link Cipher} from the given parameters
	 *
	 * @param privateKey
	 *            the private key
	 * @param algorithm
	 *            the algorithm
	 * @param salt
	 *            the salt
	 * @param iterationCount
	 *            the iteration count
	 * @param operationMode
	 *            the operation mode for the new cipher object
	 * @return the cipher
	 * @throws NoSuchAlgorithmException
	 *             if instantiation of the SecretKeyFactory object fails
	 * @throws InvalidKeySpecException
	 *             if generation of the SecretKey object fails
	 * @throws NoSuchPaddingException
	 *             if instantiation of the cipher object fails
	 * @throws InvalidKeyException
	 *             if initialization of the cipher object fails
	 * @throws InvalidAlgorithmParameterException
	 *             if initialization of the cipher object fails
	 */
	public static Cipher newPBECipher(final String privateKey, final String algorithm,
		final byte[] salt, final int iterationCount, final int operationMode)
		throws NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException,
		InvalidKeyException, InvalidAlgorithmParameterException
	{
		String normalizedPassword = Normalizer.normalize(privateKey, Normalizer.Form.NFC);
		final Cipher cipher = CipherFactory.newPBECipher(normalizedPassword.toCharArray(),
			operationMode, algorithm, salt, iterationCount);
		return cipher;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy