123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- from __future__ import division
- import random
- from logit import logit
- from utils.algorithm.b64 import b64_decrypt, b64_encrypt
- from utils.algorithm.rsalg import rsa_decrypt, rsa_encrypt
- from utils.error.response_utils import response
- CIPHER_ALGORITHM = ('B64', )
- CIPHER_PREFIX = {
- 'B64': 'alg1',
- 'RSA': 'alg2',
- }
- @logit(res=True)
- def encrypt(request):
- plaintext = request.POST.get('plaintext', '')
- alg = random.choice(CIPHER_ALGORITHM)
- if alg == 'B64':
- ciphertext = b64_encrypt(plaintext)
- elif alg == 'RSA':
- ciphertext = rsa_encrypt(plaintext)
- else:
- ciphertext = plaintext
- return response(200, data={
- 'ciphertext': u'%s+%s' % (CIPHER_PREFIX.get(alg, ''), ciphertext),
- })
- @logit(res=True)
- def decrypt(request):
- ciphertext = request.POST.get('ciphertext', '')
- alg, ciphertext = ciphertext.split('+', 1)
- if alg == CIPHER_PREFIX['B64']:
- plaintext = b64_decrypt(ciphertext)
- elif alg == CIPHER_PREFIX['RSA']:
- plaintext = rsa_decrypt(ciphertext)
- else:
- plaintext = ciphertext
- return response(200, data={
- 'plaintext': plaintext,
- })
|