summaryrefslogtreecommitdiffstats
path: root/module/lib/beaker/crypto/jcecrypto.py
diff options
context:
space:
mode:
authorGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2011-02-05 20:07:24 +0100
committerGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2011-02-05 20:07:24 +0100
commiteebac2b463b6e1db1f128d78b8151761c09448a6 (patch)
tree15f01d8496960b7d6a11c1948bd6fbdfc139e5b2 /module/lib/beaker/crypto/jcecrypto.py
parentupdate notice (diff)
downloadpyload-eebac2b463b6e1db1f128d78b8151761c09448a6.tar.xz
beaker + jinja2 lib
Diffstat (limited to 'module/lib/beaker/crypto/jcecrypto.py')
-rw-r--r--module/lib/beaker/crypto/jcecrypto.py30
1 files changed, 30 insertions, 0 deletions
diff --git a/module/lib/beaker/crypto/jcecrypto.py b/module/lib/beaker/crypto/jcecrypto.py
new file mode 100644
index 000000000..4062d513e
--- /dev/null
+++ b/module/lib/beaker/crypto/jcecrypto.py
@@ -0,0 +1,30 @@
+"""
+Encryption module that uses the Java Cryptography Extensions (JCE).
+
+Note that in default installations of the Java Runtime Environment, the
+maximum key length is limited to 128 bits due to US export
+restrictions. This makes the generated keys incompatible with the ones
+generated by pycryptopp, which has no such restrictions. To fix this,
+download the "Unlimited Strength Jurisdiction Policy Files" from Sun,
+which will allow encryption using 256 bit AES keys.
+"""
+from javax.crypto import Cipher
+from javax.crypto.spec import SecretKeySpec, IvParameterSpec
+
+import jarray
+
+# Initialization vector filled with zeros
+_iv = IvParameterSpec(jarray.zeros(16, 'b'))
+
+def aesEncrypt(data, key):
+ cipher = Cipher.getInstance('AES/CTR/NoPadding')
+ skeySpec = SecretKeySpec(key, 'AES')
+ cipher.init(Cipher.ENCRYPT_MODE, skeySpec, _iv)
+ return cipher.doFinal(data).tostring()
+
+# magic.
+aesDecrypt = aesEncrypt
+
+def getKeyLength():
+ maxlen = Cipher.getMaxAllowedKeyLength('AES/CTR/NoPadding')
+ return min(maxlen, 256) / 8