Tue, 09 Oct 2007 13:42:15 +0000
Remove explicit setting of wants_to_die from prpls.
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
1 | /** |
|
15087
78879d4adf13
[gaim-migrate @ 17807]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14672
diff
changeset
|
2 | * @file crypt.c |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
3 | * |
| 15884 | 4 | * purple |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
5 | * |
| 15884 | 6 | * Purple is the legal property of its developers, whose names are too numerous |
|
15087
78879d4adf13
[gaim-migrate @ 17807]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14672
diff
changeset
|
7 | * to list here. Please refer to the COPYRIGHT file distributed with this |
|
78879d4adf13
[gaim-migrate @ 17807]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14672
diff
changeset
|
8 | * source distribution. |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
9 | * |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
10 | * This program is free software; you can redistribute it and/or modify |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
11 | * it under the terms of the GNU General Public License as published by |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
12 | * the Free Software Foundation; either version 2 of the License, or |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
13 | * (at your option) any later version. |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
14 | * |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
15 | * This program is distributed in the hope that it will be useful, |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
16 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
17 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
18 | * GNU General Public License for more details. |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
19 | * |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
20 | * You should have received a copy of the GNU General Public License |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
21 | * along with this program; if not, write to the Free Software |
|
19859
71d37b57eff2
The FSF changed its address a while ago; our files were out of date.
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
15884
diff
changeset
|
22 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
23 | * |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
24 | * |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
25 | * QQ encryption algorithm |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
26 | * Convert from ASM code provided by PerlOICQ |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
27 | * |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
28 | * Puzzlebird, Nov-Dec 2002 |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
29 | */ |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
30 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
31 | /*Notes: (QQ uses 16 rounds, and modified something...) |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
32 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
33 | IN : 64 bits of data in v[0] - v[1]. |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
34 | OUT: 64 bits of data in w[0] - w[1]. |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
35 | KEY: 128 bits of key in k[0] - k[3]. |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
36 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
37 | delta is chosen to be the real part of |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
38 | the golden ratio: Sqrt(5/4) - 1/2 ~ 0.618034 multiplied by 2^32. |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
39 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
40 | 0x61C88647 is what we can track on the ASM codes.!! |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
41 | */ |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
42 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
43 | #include <string.h> |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
44 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
45 | #include "crypt.h" |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
46 | #include "debug.h" |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
47 | |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
48 | /******************************************************************** |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
49 | * encryption |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
50 | *******************************************************************/ |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
51 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
52 | /* Tiny Encryption Algorithm (TEA) */ |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
53 | static void qq_encipher(guint32 *const v, const guint32 *const k, guint32 *const w) |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
54 | { |
|
14672
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
55 | register guint32 y = g_ntohl(v[0]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
56 | z = g_ntohl(v[1]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
57 | a = g_ntohl(k[0]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
58 | b = g_ntohl(k[1]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
59 | c = g_ntohl(k[2]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
60 | d = g_ntohl(k[3]), |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
61 | n = 0x10, |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
62 | sum = 0, |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
63 | delta = 0x9E3779B9; /* 0x9E3779B9 - 0x100000000 = -0x61C88647 */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
64 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
65 | while (n-- > 0) { |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
66 | sum += delta; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
67 | y += ((z << 4) + a) ^ (z + sum) ^ ((z >> 5) + b); |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
68 | z += ((y << 4) + c) ^ (y + sum) ^ ((y >> 5) + d); |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
69 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
70 | |
|
14672
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
71 | w[0] = g_htonl(y); |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
72 | w[1] = g_htonl(z); |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
73 | } |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
74 | |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
75 | static gint rand(void) { /* it can be the real random seed function */ |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
76 | return 0xdead; |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
77 | } /* override with number, convenient for debug */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
78 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
79 | /* 64-bit blocks and some kind of feedback mode of operation */ |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
80 | static void encrypt_block(guint8 *plain, guint8 *plain_pre_8, guint8 **crypted, |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
81 | guint8 **crypted_pre_8, const guint8 *const key, gint *count, |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
82 | gint *pos_in_block, gint *is_header) |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
83 | { |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
84 | /* prepare input text */ |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
85 | if (!*is_header) |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
86 | *(guint64 *) plain ^= **(guint64 **) crypted_pre_8; |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
87 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
88 | /* encrypt it */ |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
89 | qq_encipher((guint32 *) plain, (guint32 *) key, (guint32 *) *crypted); |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
90 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
91 | **(guint64 **) crypted ^= *(guint64 *) plain_pre_8; |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
92 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
93 | memcpy(plain_pre_8, plain, 8); /* prepare next */ |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
94 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
95 | *crypted_pre_8 = *crypted; /* store position of previous 8 byte */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
96 | *crypted += 8; /* prepare next output */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
97 | *count += 8; /* outstrlen increase by 8 */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
98 | *pos_in_block = 0; /* back to start */ |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
99 | *is_header = 0; /* and exit header */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
100 | } /* encrypt_block */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
101 | |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
102 | static void qq_encrypt(const guint8 *const instr, gint instrlen, |
|
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
103 | const guint8 *const key, |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
104 | guint8 *outstr, gint *outstrlen_ptr) |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
105 | { |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
106 | guint8 plain[8], /* plain text buffer */ |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
107 | plain_pre_8[8], /* plain text buffer, previous 8 bytes */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
108 | *crypted, /* crypted text */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
109 | *crypted_pre_8; /* crypted text, previous 8 bytes */ |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
110 | const guint8 *inp; /* current position in instr */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
111 | gint pos_in_block = 1, /* loop in the byte */ |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
112 | is_header = 1, /* header is one byte */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
113 | count = 0, /* number of bytes being crypted */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
114 | padding = 0; /* number of padding stuff */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
115 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
116 | pos_in_block = (instrlen + 0x0a) % 8; /* header padding decided by instrlen */ |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
117 | if (pos_in_block) |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
118 | pos_in_block = 8 - pos_in_block; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
119 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
120 | /* initialization vector */ |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
121 | plain[0] = (rand() & 0xf8) | pos_in_block; |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
122 | memset(plain + 1, rand() & 0xff, pos_in_block++); |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
123 | |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
124 | memset(plain_pre_8, 0x00, sizeof(plain_pre_8)); |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
125 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
126 | crypted = crypted_pre_8 = outstr; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
127 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
128 | padding = 1; /* pad some stuff in header */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
129 | while (padding <= 2) { /* at most two bytes */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
130 | if (pos_in_block < 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
131 | plain[pos_in_block++] = rand() & 0xff; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
132 | padding++; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
133 | } |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
134 | if (pos_in_block == 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
135 | encrypt_block(plain, plain_pre_8, &crypted, &crypted_pre_8, |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
136 | key, &count, &pos_in_block, &is_header); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
137 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
138 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
139 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
140 | inp = instr; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
141 | while (instrlen > 0) { |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
142 | if (pos_in_block < 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
143 | plain[pos_in_block++] = *(inp++); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
144 | instrlen--; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
145 | } |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
146 | if (pos_in_block == 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
147 | encrypt_block(plain, plain_pre_8, &crypted, &crypted_pre_8, |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
148 | key, &count, &pos_in_block, &is_header); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
149 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
150 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
151 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
152 | padding = 1; /* pad some stuff in tail */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
153 | while (padding <= 7) { /* at most seven bytes */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
154 | if (pos_in_block < 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
155 | plain[pos_in_block++] = 0x00; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
156 | padding++; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
157 | } |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
158 | if (pos_in_block == 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
159 | encrypt_block(plain, plain_pre_8, &crypted, &crypted_pre_8, |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
160 | key, &count, &pos_in_block, &is_header); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
161 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
162 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
163 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
164 | *outstrlen_ptr = count; |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
165 | } |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
166 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
167 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
168 | /******************************************************************** |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
169 | * decryption |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
170 | ********************************************************************/ |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
171 | |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
172 | static void qq_decipher(guint32 *const v, const guint32 *const k, guint32 *const w) |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
173 | { |
|
14672
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
174 | register guint32 y = g_ntohl(v[0]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
175 | z = g_ntohl(v[1]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
176 | a = g_ntohl(k[0]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
177 | b = g_ntohl(k[1]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
178 | c = g_ntohl(k[2]), |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
179 | d = g_ntohl(k[3]), |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
180 | n = 0x10, |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
181 | sum = 0xE3779B90, /* why this ? must be related with n value */ |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
182 | delta = 0x9E3779B9; |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
183 | |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
184 | /* sum = delta<<5, in general sum = delta * n */ |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
185 | while (n-- > 0) { |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
186 | z -= ((y << 4) + c) ^ (y + sum) ^ ((y >> 5) + d); |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
187 | y -= ((z << 4) + a) ^ (z + sum) ^ ((z >> 5) + b); |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
188 | sum -= delta; |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
189 | } |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
190 | |
|
14672
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
191 | w[0] = g_htonl(y); |
|
432897ba0662
[gaim-migrate @ 17338]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14627
diff
changeset
|
192 | w[1] = g_htonl(z); |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
193 | } |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
194 | |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
195 | static gint decrypt_block(const guint8 **crypt_buff, const gint instrlen, |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
196 | const guint8 *const key, gint *context_start, |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
197 | guint8 *decrypted, gint *pos_in_block) |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
198 | { |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
199 | if (*context_start == instrlen) |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
200 | return 1; |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
201 | |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
202 | *(guint64 *) decrypted ^= **(guint64 **) crypt_buff; |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
203 | |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
204 | qq_decipher((guint32 *) decrypted, (guint32 *) key, (guint32 *) decrypted); |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
205 | |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
206 | *context_start += 8; |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
207 | *crypt_buff += 8; |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
208 | *pos_in_block = 0; |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
209 | |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
210 | return 1; |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
211 | } |
|
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
212 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
213 | /* return 0 if failed, 1 otherwise */ |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
214 | static gint qq_decrypt(const guint8 *const instr, gint instrlen, |
|
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
215 | const guint8 *const key, |
|
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
216 | guint8 *outstr, gint *outstrlen_ptr) |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
217 | { |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
218 | guint8 decrypted[8], m[8], *outp; |
|
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
219 | const guint8 *crypt_buff, *crypt_buff_pre_8; |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
220 | gint count, context_start, pos_in_block, padding; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
221 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
222 | /* at least 16 bytes and %8 == 0 */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
223 | if ((instrlen % 8) || (instrlen < 16)) { |
| 15884 | 224 | purple_debug(PURPLE_DEBUG_ERROR, "QQ", |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
225 | "Ciphertext len is either too short or not a multiple of 8 bytes, read %d bytes\n", |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
226 | instrlen); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
227 | return 0; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
228 | } |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
229 | /* get information from header */ |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
230 | qq_decipher((guint32 *) instr, (guint32 *) key, (guint32 *) decrypted); |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
231 | pos_in_block = decrypted[0] & 0x7; |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
232 | count = instrlen - pos_in_block - 10; /* this is the plaintext length */ |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
233 | /* return if outstr buffer is not large enough or error plaintext length */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
234 | if (*outstrlen_ptr < count || count < 0) { |
| 15884 | 235 | purple_debug(PURPLE_DEBUG_ERROR, "QQ", "Buffer len %d is less than real len %d", |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
236 | *outstrlen_ptr, count); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
237 | return 0; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
238 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
239 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
240 | memset(m, 0, 8); |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
241 | crypt_buff_pre_8 = m; |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
242 | *outstrlen_ptr = count; /* everything is ok! set return string length */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
243 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
244 | crypt_buff = instr + 8; /* address of real data start */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
245 | context_start = 8; /* context is at the second block of 8 bytes */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
246 | pos_in_block++; /* start of paddng stuff */ |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
247 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
248 | padding = 1; /* at least one in header */ |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
249 | while (padding <= 2) { /* there are 2 byte padding stuff in header */ |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
250 | if (pos_in_block < 8) { /* bypass the padding stuff, it's nonsense data */ |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
251 | pos_in_block++; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
252 | padding++; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
253 | } |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
254 | if (pos_in_block == 8) { |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
255 | crypt_buff_pre_8 = instr; |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
256 | if (!decrypt_block(&crypt_buff, instrlen, key, |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
257 | &context_start, decrypted, &pos_in_block)) { |
| 15884 | 258 | purple_debug(PURPLE_DEBUG_ERROR, "QQ", "decrypt every 8 bytes error A"); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
259 | return 0; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
260 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
261 | } |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
262 | } |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
263 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
264 | outp = outstr; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
265 | while (count != 0) { |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
266 | if (pos_in_block < 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
267 | *outp = crypt_buff_pre_8[pos_in_block] ^ decrypted[pos_in_block]; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
268 | outp++; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
269 | count--; |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
270 | pos_in_block++; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
271 | } |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
272 | if (pos_in_block == 8) { |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
273 | crypt_buff_pre_8 = crypt_buff - 8; |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
274 | if (!decrypt_block(&crypt_buff, instrlen, key, |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
275 | &context_start, decrypted, &pos_in_block)) { |
| 15884 | 276 | purple_debug(PURPLE_DEBUG_ERROR, "QQ", "decrypt every 8 bytes error B"); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
277 | return 0; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
278 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
279 | } |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
280 | } |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
281 | |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
282 | for (padding = 1; padding < 8; padding++) { |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
283 | if (pos_in_block < 8) { |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
284 | if (crypt_buff_pre_8[pos_in_block] ^ decrypted[pos_in_block]) |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
285 | return 0; |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
286 | pos_in_block++; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
287 | } |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
288 | if (pos_in_block == 8) { |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
289 | crypt_buff_pre_8 = crypt_buff; |
|
14627
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
290 | if (!decrypt_block(&crypt_buff, instrlen, key, |
|
b594f7e38363
[gaim-migrate @ 17289]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14616
diff
changeset
|
291 | &context_start, decrypted, &pos_in_block)) { |
| 15884 | 292 | purple_debug(PURPLE_DEBUG_ERROR, "QQ", "decrypt every 8 bytes error C"); |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
293 | return 0; |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
294 | } |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
295 | } |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
296 | } |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
297 | return 1; |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
298 | } |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
299 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
300 | /* return 1 is succeed, otherwise return 0 */ |
|
14298
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
301 | gint qq_crypt(gint flag, |
|
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
302 | const guint8 *const instr, gint instrlen, |
|
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
303 | const guint8 *const key, |
|
3b1b5a48e75b
[gaim-migrate @ 16918]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14254
diff
changeset
|
304 | guint8 *outstr, gint *outstrlen_ptr) |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
305 | { |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
306 | if (flag == DECRYPT) |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
307 | return qq_decrypt(instr, instrlen, key, outstr, outstrlen_ptr); |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
308 | else if (flag == ENCRYPT) |
|
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
309 | qq_encrypt(instr, instrlen, key, outstr, outstrlen_ptr); |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
310 | else |
|
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
311 | return 0; |
|
13932
4d131bd2b40f
[gaim-migrate @ 16340]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
diff
changeset
|
312 | |
|
14083
2b68bb18a66c
[gaim-migrate @ 16618]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
14039
diff
changeset
|
313 | return 1; |
|
14039
961b2520f7ef
[gaim-migrate @ 16536]
Mark Huetsch <markhuetsch@users.sourceforge.net>
parents:
13932
diff
changeset
|
314 | } |