PSK : Stunnel and/or OpenSSL (undocumented) handles PSK better without special chars, apparently
authorEdouard Tisserant
Tue, 30 Oct 2018 14:08:28 +0100 (2018-10-30)
changeset 2328 7eb6cb70bf5b
parent 2327 569d7fbc0bd4
child 2329 e5703dc8848e
PSK : Stunnel and/or OpenSSL (undocumented) handles PSK better without special chars, apparently
runtime/Stunnel.py
--- a/runtime/Stunnel.py	Tue Oct 30 13:47:24 2018 +0100
+++ b/runtime/Stunnel.py	Tue Oct 30 14:08:28 2018 +0100
@@ -1,23 +1,17 @@
 import os
-#from binascii import hexlify
+from binascii import b2a_hqx
 from runtime.spawn_subprocess import call
 
 restart_stunnel_cmdline = ["/etc/init.d/S50stunnel","restart"]
 
-# stunnel takes no encoding for PSK, so we try to lose minimum entropy 
-# by using all possible chars except '\0\n\r' (checked stunnel parser to be sure)
-translator = ''.join([(lambda c: '#' if c in '\0\n\r' else c)(chr(i)) for i in xrange(256)])
-
 _PSKpath = None
 
 def PSKgen(ID, PSKpath):
 
-    # 236 bytes is empirical maximum when using :
-    #  - stunnel 5.36 on server with openssl 1.0.2k
-    #  - python-sslpsk 1.0.0 on client with openssl 1.0.2k
-    secret = os.urandom(236) 
+    # b2a_hqx output len is 4/3 input len
+    secret = os.urandom(192) # int(256/1.3333)
+    secretstring = b2a_hqx(secret)
 
-    secretstring = secret.translate(translator)
     PSKstring = ID+":"+secretstring
     with open(PSKpath, 'w') as f:
         f.write(PSKstring)