summaryrefslogtreecommitdiffstats
path: root/src/crypt/cryptrc4.cpp
blob: 2154b04aa8627b2de870c756bcf23f429774dfaf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include "cryptrc4.h"

void swap(RC4_INT &a, RC4_INT &b)
{
    RC4_INT tmp;

    tmp = a;
    a = b;
    b = tmp;
}

CryptRc4::CryptRc4()
{

}

void CryptRc4::rc4SetKey(QByteArray key)
{
    RC4_set_key(&m_rc4Key, key.length(), (const unsigned char *) key.data());
}

void CryptRc4::rc4SetKeyOwn(QByteArray key)
{
    m_rc4Key.x = 0;
    m_rc4Key.y = 0;

    for (int i = 0; i < 256; i++)
    {
        m_rc4Key.data[i] = i;
    }

    RC4_INT j = 0;

    for (int i = 0; i < 256; i++)
    {
        j = (j + m_rc4Key.data[i] + key[i % key.length()]) % 256;
        swap(m_rc4Key.data[i], m_rc4Key.data[j]);
    }
}

QByteArray CryptRc4::rc4Run(QByteArray clear)
{
    QByteArray crypt(clear);
    RC4(&m_rc4Key, clear.length(), (const unsigned char *) clear.data(),
        (unsigned char *) crypt.data());
    return crypt;
}

QByteArray CryptRc4::rc4RunOwn(QByteArray clear)
{
    QByteArray crypt(clear);

    RC4_INT i = 0;
    RC4_INT j = 0;

    for (int k = 0; k < crypt.length(); k++)
    {
        i = (i + 1) % 256;
        j = (j + m_rc4Key.data[i]) % 256;

        swap(m_rc4Key.data[i], m_rc4Key.data[j]);

        crypt[k] = crypt[k] ^ m_rc4Key.data[(m_rc4Key.data[i] + m_rc4Key.data[j]) %
                                            256];
    }

    return crypt;
}