/* Copyright 2019-2020 Dmitry Isaenko This file is part of Konogonka. Konogonka is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Konogonka is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Konogonka. If not, see . */ package libKonogonka.ctraes; import org.bouncycastle.jce.provider.BouncyCastleProvider; import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import java.security.Security; public class AesCtr { private static boolean BCinitialized = false; private void initBCProvider(){ Security.addProvider(new BouncyCastleProvider()); BCinitialized = true; } private Cipher cipher; private SecretKeySpec key; public AesCtr(byte[] keyArray) throws Exception{ if ( ! BCinitialized) initBCProvider(); key = new SecretKeySpec(keyArray, "AES"); cipher = Cipher.getInstance("AES/CTR/NoPadding", "BC"); } public byte[] decrypt(byte[] encryptedData, byte[] IVarray) throws Exception{ IvParameterSpec iv = new IvParameterSpec(IVarray); cipher.init(Cipher.DECRYPT_MODE, key, iv); return cipher.doFinal(encryptedData); } }