# -*- coding: utf-8 -*-

from __future__ import division

import random

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', 'RSA')
CIPHER_ALGORITHM = ('B64', )

CIPHER_PREFIX = {
    'B64': 'alg1',
    'RSA': 'alg2',
}


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),
    })


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,
    })