25'ten fazla konu seçemezsiniz Konular bir harf veya rakamla başlamalı, kısa çizgiler ('-') içerebilir ve en fazla 35 karakter uzunluğunda olabilir.
 
 
 
 
 
 

55 satır
1.7 KiB

  1. """
  2. XTEA Block Encryption Algorithm
  3. Author: Paul Chakravarti (paul_dot_chakravarti_at_gmail_dot_com)
  4. License: Public Domain
  5. """
  6. def get_key():
  7. # Encryption key is datetime of creation of DocType, DocType"
  8. import webnotes
  9. return webnotes.conn.sql("select creation from tabDocType where name='DocType'")[0][0].strftime('%Y%m%d%H%M%s')[:16]
  10. def encrypt(data, encryption_key = None):
  11. if not encryption_key:
  12. encryption_key = get_key()
  13. return crypt(encryption_key, data).encode('hex')
  14. def decrypt(data, encryption_key = None):
  15. if not encryption_key:
  16. encryption_key = get_key()
  17. return crypt(encryption_key, data.decode('hex'))
  18. def crypt(key,data,iv='\00\00\00\00\00\00\00\00',n=32):
  19. def keygen(key,iv,n):
  20. while True:
  21. iv = xtea_encrypt(key,iv,n)
  22. for k in iv:
  23. yield ord(k)
  24. xor = [ chr(x^y) for (x,y) in zip(map(ord,data),keygen(key,iv,n)) ]
  25. return "".join(xor)
  26. def xtea_encrypt(key,block,n=32,endian="!"):
  27. import struct
  28. v0,v1 = struct.unpack(endian+"2L",block)
  29. k = struct.unpack(endian+"4L",key)
  30. sum,delta,mask = 0L,0x9e3779b9L,0xffffffffL
  31. for round in range(n):
  32. v0 = (v0 + (((v1<<4 ^ v1>>5) + v1) ^ (sum + k[sum & 3]))) & mask
  33. sum = (sum + delta) & mask
  34. v1 = (v1 + (((v0<<4 ^ v0>>5) + v0) ^ (sum + k[sum>>11 & 3]))) & mask
  35. return struct.pack(endian+"2L",v0,v1)
  36. def xtea_decrypt(key,block,n=32,endian="!"):
  37. import struct
  38. v0,v1 = struct.unpack(endian+"2L",block)
  39. k = struct.unpack(endian+"4L",key)
  40. delta,mask = 0x9e3779b9L,0xffffffffL
  41. sum = (delta * n) & mask
  42. for round in range(n):
  43. v1 = (v1 - (((v0<<4 ^ v0>>5) + v0) ^ (sum + k[sum>>11 & 3]))) & mask
  44. sum = (sum - delta) & mask
  45. v0 = (v0 - (((v1<<4 ^ v1>>5) + v1) ^ (sum + k[sum & 3]))) & mask
  46. return struct.pack(endian+"2L",v0,v1)