/src/main/java/ch/ethz/ssh2/crypto/cipher/BlockCipherFactory.java
https://github.com/guitarpoet/iproxy · Java · 109 lines · 87 code · 15 blank · 7 comment · 7 complexity · 035a902cd41fd54b0ab9a52fad388bdc MD5 · raw file
- package ch.ethz.ssh2.crypto.cipher;
- import java.util.Vector;
- /**
- * BlockCipherFactory.
- *
- * @author Christian Plattner
- * @version 2.50, 03/15/10
- */
- @SuppressWarnings("unchecked")
- public class BlockCipherFactory {
- static class CipherEntry {
- String type;
- int blocksize;
- int keysize;
- String cipherClass;
- public CipherEntry(String type, int blockSize, int keySize,
- String cipherClass) {
- this.type = type;
- this.blocksize = blockSize;
- this.keysize = keySize;
- this.cipherClass = cipherClass;
- }
- }
- static Vector ciphers = new Vector();
- static {
- /* Higher Priority First */
- ciphers.addElement(new CipherEntry("aes256-ctr", 16, 32,
- "ch.ethz.ssh2.crypto.cipher.AES"));
- ciphers.addElement(new CipherEntry("aes192-ctr", 16, 24,
- "ch.ethz.ssh2.crypto.cipher.AES"));
- ciphers.addElement(new CipherEntry("aes128-ctr", 16, 16,
- "ch.ethz.ssh2.crypto.cipher.AES"));
- ciphers.addElement(new CipherEntry("blowfish-ctr", 8, 16,
- "ch.ethz.ssh2.crypto.cipher.BlowFish"));
- ciphers.addElement(new CipherEntry("aes256-cbc", 16, 32,
- "ch.ethz.ssh2.crypto.cipher.AES"));
- ciphers.addElement(new CipherEntry("aes192-cbc", 16, 24,
- "ch.ethz.ssh2.crypto.cipher.AES"));
- ciphers.addElement(new CipherEntry("aes128-cbc", 16, 16,
- "ch.ethz.ssh2.crypto.cipher.AES"));
- ciphers.addElement(new CipherEntry("blowfish-cbc", 8, 16,
- "ch.ethz.ssh2.crypto.cipher.BlowFish"));
- ciphers.addElement(new CipherEntry("3des-ctr", 8, 24,
- "ch.ethz.ssh2.crypto.cipher.DESede"));
- ciphers.addElement(new CipherEntry("3des-cbc", 8, 24,
- "ch.ethz.ssh2.crypto.cipher.DESede"));
- }
- public static String[] getDefaultCipherList() {
- String list[] = new String[ciphers.size()];
- for (int i = 0; i < ciphers.size(); i++) {
- CipherEntry ce = (CipherEntry) ciphers.elementAt(i);
- list[i] = new String(ce.type);
- }
- return list;
- }
- public static void checkCipherList(String[] cipherCandidates) {
- for (int i = 0; i < cipherCandidates.length; i++)
- getEntry(cipherCandidates[i]);
- }
- public static BlockCipher createCipher(String type, boolean encrypt,
- byte[] key, byte[] iv) {
- try {
- CipherEntry ce = getEntry(type);
- Class cc = Class.forName(ce.cipherClass);
- BlockCipher bc = (BlockCipher) cc.newInstance();
- if (type.endsWith("-cbc")) {
- bc.init(encrypt, key);
- return new CBCMode(bc, iv, encrypt);
- } else if (type.endsWith("-ctr")) {
- bc.init(true, key);
- return new CTRMode(bc, iv, encrypt);
- }
- throw new IllegalArgumentException("Cannot instantiate " + type);
- } catch (Exception e) {
- throw new IllegalArgumentException("Cannot instantiate " + type);
- }
- }
- private static CipherEntry getEntry(String type) {
- for (int i = 0; i < ciphers.size(); i++) {
- CipherEntry ce = (CipherEntry) ciphers.elementAt(i);
- if (ce.type.equals(type))
- return ce;
- }
- throw new IllegalArgumentException("Unkown algorithm " + type);
- }
- public static int getBlockSize(String type) {
- CipherEntry ce = getEntry(type);
- return ce.blocksize;
- }
- public static int getKeySize(String type) {
- CipherEntry ce = getEntry(type);
- return ce.keysize;
- }
- }