libpurple/ciphers/des3cipher.c

Mon, 23 Sep 2013 14:41:07 +0530

author
Ankit Vani <a@nevitus.org>
date
Mon, 23 Sep 2013 14:41:07 +0530
branch
soc.2013.gobjectification
changeset 34965
9abd15d6da07
parent 34889
4ea2da14cd0e
child 35014
21864c2f543f
permissions
-rw-r--r--

Removed 'get_name' from PurpleCipher

34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
1 /*
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
2 * Original des taken from gpg
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
3 *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
4 * des.c - Triple-DES encryption/decryption Algorithm
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
5 * Copyright (C) 1998 Free Software Foundation, Inc.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
6 *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
7 * Please see below for more legal information!
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
8 *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
9 * According to the definition of DES in FIPS PUB 46-2 from December 1993.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
10 * For a description of triple encryption, see:
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
11 * Bruce Schneier: Applied Cryptography. Second Edition.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
12 * John Wiley & Sons, 1996. ISBN 0-471-12845-7. Pages 358 ff.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
13 *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
14 * Purple is the legal property of its developers, whose names are too numerous
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
15 * to list here. Please refer to the COPYRIGHT file distributed with this
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
16 * source distribution.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
17 *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
18 * This program is free software; you can redistribute it and/or modify
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
19 * it under the terms of the GNU General Public License as published by
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
20 * the Free Software Foundation; either version 2 of the License, or
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
21 * (at your option) any later version.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
22 *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
23 * This program is distributed in the hope that it will be useful,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
24 * but WITHOUT ANY WARRANTY; without even the implied warranty of
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
26 * GNU General Public License for more details.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
27 *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
28 * You should have received a copy of the GNU General Public License
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
29 * along with this program; if not, write to the Free Software
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
30 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
31 */
34566
e0f887dee077 Split PurpleCipher into PurpleCipher and PurpleHash. Hashes will subclass PurpleHash.
Ankit Vani <a@nevitus.org>
parents: 34563
diff changeset
32 #include "des3cipher.h"
e0f887dee077 Split PurpleCipher into PurpleCipher and PurpleHash. Hashes will subclass PurpleHash.
Ankit Vani <a@nevitus.org>
parents: 34563
diff changeset
33 #include "descipher.h"
34644
368d270dc0c3 Included enums.h in AES, DES and DES3 cipher to use the PURPLE_TYPE_BATCH_MODE GType for batch_mode property
Ankit Vani <a@nevitus.org>
parents: 34603
diff changeset
34 #include "enums.h"
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
35
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
36 #include <string.h>
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
37
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
38 /******************************************************************************
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
39 * Structs
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
40 *****************************************************************************/
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
41
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
42 #define PURPLE_DES3_CIPHER_GET_PRIVATE(obj) \
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
43 (G_TYPE_INSTANCE_GET_PRIVATE((obj), PURPLE_TYPE_DES3_CIPHER, PurpleDES3CipherPrivate))
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
44
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
45 typedef struct _PurpleDES3CipherPrivate PurpleDES3CipherPrivate;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
46 struct _PurpleDES3CipherPrivate
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
47 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
48 PurpleCipherBatchMode mode;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
49 guchar iv[8];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
50 /* First key for encryption */
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
51 PurpleCipher *key1;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
52 /* Second key for decryption */
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
53 PurpleCipher *key2;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
54 /* Third key for encryption */
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
55 PurpleCipher *key3;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
56 };
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
57
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
58 /******************************************************************************
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
59 * Enums
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
60 *****************************************************************************/
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
61 enum {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
62 PROP_NONE,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
63 PROP_BATCH_MODE,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
64 PROP_IV,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
65 PROP_KEY,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
66 PROP_LAST,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
67 };
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
68
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
69 /******************************************************************************
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
70 * Globals
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
71 *****************************************************************************/
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
72 static GObjectClass *parent_class = NULL;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
73
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
74 /******************************************************************************
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
75 * Cipher Stuff
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
76 *****************************************************************************/
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
77
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
78 static size_t
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
79 purple_des3_cipher_get_key_size(PurpleCipher *cipher)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
80 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
81 return 24;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
82 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
83
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
84 /*
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
85 * Fill a DES3 context with subkeys calculated from 3 64bit key.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
86 * Does not check parity bits, but simply ignore them.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
87 * Does not check for weak keys.
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
88 **/
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
89 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
90 purple_des3_cipher_set_key(PurpleCipher *cipher, const guchar *key, size_t len)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
91 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
92 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
93 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
94
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
95 g_return_if_fail(len == 24);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
96
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
97 purple_cipher_set_key(PURPLE_CIPHER(priv->key1), key + 0,
34563
5c76133baa15 Fixed DES and DES3 ciphers according to the test suite.
Ankit Vani <a@nevitus.org>
parents: 34550
diff changeset
98 purple_cipher_get_key_size(PURPLE_CIPHER(priv->key1)));
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
99 purple_cipher_set_key(PURPLE_CIPHER(priv->key2), key + 8,
34563
5c76133baa15 Fixed DES and DES3 ciphers according to the test suite.
Ankit Vani <a@nevitus.org>
parents: 34550
diff changeset
100 purple_cipher_get_key_size(PURPLE_CIPHER(priv->key2)));
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
101 purple_cipher_set_key(PURPLE_CIPHER(priv->key3), key + 16,
34563
5c76133baa15 Fixed DES and DES3 ciphers according to the test suite.
Ankit Vani <a@nevitus.org>
parents: 34550
diff changeset
102 purple_cipher_get_key_size(PURPLE_CIPHER(priv->key3)));
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
103
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
104 g_object_notify(G_OBJECT(des3_cipher), "key");
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
105 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
106
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
107 static ssize_t
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
108 purple_des3_cipher_ecb_encrypt(PurpleDES3Cipher *des3_cipher, const guchar input[],
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
109 size_t in_len, guchar output[], size_t out_size)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
110 {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
111 gsize offset = 0;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
112 int i = 0;
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
113 gsize tmp;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
114 guint8 buf[8] = {0,0,0,0,0,0,0,0};
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
115 gsize out_len;
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
116 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
117
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
118 g_return_val_if_fail(out_size >= in_len, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
119
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
120 while (offset + 8 <= in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
121 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
122 input + offset, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
123 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
124 output + offset, buf, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
125 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
126 buf, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
127
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
128 offset += 8;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
129 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
130
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
131 out_len = in_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
132 if (offset < in_len) {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
133 g_return_val_if_fail(in_len >= offset, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
134 out_len += in_len - offset;
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
135 g_return_val_if_fail(out_size >= out_len, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
136 tmp = offset;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
137 memset(buf, 0, 8);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
138 while (tmp < in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
139 buf[i++] = input[tmp];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
140 tmp++;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
141 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
142
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
143 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
144 buf, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
145 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
146 output + offset, buf, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
147 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
148 buf, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
149 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
150
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
151 return out_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
152 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
153
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
154 static ssize_t
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
155 purple_des3_cipher_cbc_encrypt(PurpleDES3Cipher *des3_cipher, const guchar input[],
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
156 size_t in_len, guchar output[], size_t out_size)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
157 {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
158 gsize offset = 0;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
159 int i = 0;
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
160 gsize tmp;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
161 guint8 buf[8];
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
162 gsize out_len;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
163 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
164
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
165 memcpy(buf, priv->iv, 8);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
166
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
167 g_return_val_if_fail(out_size >= in_len, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
168
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
169 while (offset + 8 <= in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
170 for (i = 0; i < 8; i++)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
171 buf[i] ^= input[offset + i];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
172
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
173 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
174 buf, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
175 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
176 output + offset, buf, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
177 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
178 buf, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
179
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
180 memcpy(buf, output+offset, 8);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
181 offset += 8;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
182 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
183
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
184 out_len = in_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
185 if (offset < in_len) {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
186 g_return_val_if_fail(in_len >= offset, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
187 out_len += in_len - offset;
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
188 g_return_val_if_fail(out_size >= out_len, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
189 tmp = offset;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
190 i = 0;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
191 while (tmp < in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
192 buf[i++] ^= input[tmp];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
193 tmp++;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
194 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
195
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
196 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
197 buf, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
198 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
199 output + offset, buf, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
200 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
201 buf, output + offset, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
202 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
203
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
204 return out_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
205 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
206
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
207 static ssize_t
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
208 purple_des3_cipher_encrypt(PurpleCipher *cipher, const guchar input[],
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
209 size_t in_len, guchar output[], size_t out_size)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
210 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
211 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
212 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
213
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
214 if (priv->mode == PURPLE_CIPHER_BATCH_MODE_ECB) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
215 return purple_des3_cipher_ecb_encrypt(des3_cipher, input, in_len, output, out_size);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
216 } else if (priv->mode == PURPLE_CIPHER_BATCH_MODE_CBC) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
217 return purple_des3_cipher_cbc_encrypt(des3_cipher, input, in_len, output, out_size);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
218 } else {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
219 g_return_val_if_reached(0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
220 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
221
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
222 return 0;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
223 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
224
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
225 static ssize_t
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
226 purple_des3_cipher_ecb_decrypt(PurpleDES3Cipher *des3_cipher, const guchar input[],
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
227 size_t in_len, guchar output[], size_t out_size)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
228 {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
229 gsize offset = 0;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
230 int i = 0;
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
231 gsize tmp;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
232 guint8 buf[8] = {0,0,0,0,0,0,0,0};
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
233 gsize out_len;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
234 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
235
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
236 g_return_val_if_fail(out_size >= in_len, -1);
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
237
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
238 while (offset + 8 <= in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
239 /* NOTE: Apply key in reverse */
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
240 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
241 input + offset, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
242 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
243 output + offset, buf, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
244 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
245 buf, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
246
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
247 offset += 8;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
248 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
249
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
250 out_len = in_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
251 if (offset < in_len) {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
252 g_return_val_if_fail(in_len >= offset, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
253 out_len += in_len - offset;
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
254 g_return_val_if_fail(out_size >= out_len, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
255 tmp = offset;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
256 memset(buf, 0, 8);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
257 while (tmp < in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
258 buf[i++] = input[tmp];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
259 tmp++;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
260 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
261
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
262 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
263 buf, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
264 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
265 output + offset, buf, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
266 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
267 buf, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
268 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
269
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
270 return out_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
271 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
272
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
273 static ssize_t
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
274 purple_des3_cipher_cbc_decrypt(PurpleDES3Cipher *des3_cipher, const guchar input[],
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
275 size_t in_len, guchar output[], size_t out_size)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
276 {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
277 gsize offset = 0;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
278 int i = 0;
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
279 gsize tmp;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
280 guint8 buf[8] = {0,0,0,0,0,0,0,0};
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
281 guint8 link[8];
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
282 gsize out_len;
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
283 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
284
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
285 g_return_val_if_fail(out_size >= in_len, -1);
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
286
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
287 memcpy(link, priv->iv, 8);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
288 while (offset + 8 <= in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
289 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
290 input + offset, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
291 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
292 output + offset, buf, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
293 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
294 buf, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
295
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
296 for (i = 0; i < 8; i++)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
297 output[offset + i] ^= link[i];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
298
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
299 memcpy(link, input + offset, 8);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
300
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
301 offset+=8;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
302 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
303
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
304 out_len = in_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
305 if(offset<in_len) {
34889
4ea2da14cd0e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 34644
diff changeset
306 g_return_val_if_fail(in_len >= offset, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
307 out_len += in_len - offset;
34603
292fcbdaf528 Merged with default branch
Ankit Vani <a@nevitus.org>
parents: 34566
diff changeset
308 g_return_val_if_fail(out_size >= out_len, -1);
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
309 tmp = offset;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
310 memset(buf, 0, 8);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
311 i = 0;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
312 while(tmp<in_len) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
313 buf[i++] = input[tmp];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
314 tmp++;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
315 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
316
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
317 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key3),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
318 buf, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
319 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key2),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
320 output + offset, buf, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
321 purple_des_cipher_ecb_crypt(PURPLE_DES_CIPHER(priv->key1),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
322 buf, output + offset, 1);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
323
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
324 for (i = 0; i < 8; i++)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
325 output[offset + i] ^= link[i];
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
326 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
327
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
328 return out_len;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
329 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
330
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
331 static ssize_t
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
332 purple_des3_cipher_decrypt(PurpleCipher *cipher, const guchar input[],
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
333 size_t in_len, guchar output[], size_t out_size)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
334 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
335 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
336 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
337
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
338 if (priv->mode == PURPLE_CIPHER_BATCH_MODE_ECB) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
339 return purple_des3_cipher_ecb_decrypt(des3_cipher, input, in_len, output, out_size);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
340 } else if (priv->mode == PURPLE_CIPHER_BATCH_MODE_CBC) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
341 return purple_des3_cipher_cbc_decrypt(des3_cipher, input, in_len, output, out_size);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
342 } else {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
343 g_return_val_if_reached(0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
344 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
345
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
346 return 0;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
347 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
348
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
349 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
350 purple_des3_cipher_set_batch_mode(PurpleCipher *cipher, PurpleCipherBatchMode mode)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
351 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
352 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
353 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
354
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
355 priv->mode = mode;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
356
34545
3df1bdf7b238 Updated the property name batchMode to batch_mode used in g_object_notify.
Ankit Vani <a@nevitus.org>
parents: 34544
diff changeset
357 g_object_notify(G_OBJECT(des3_cipher), "batch_mode");
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
358 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
359
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
360 static PurpleCipherBatchMode
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
361 purple_des3_cipher_get_batch_mode(PurpleCipher *cipher)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
362 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
363 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
364 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
365
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
366 return priv->mode;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
367 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
368
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
369 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
370 purple_des3_cipher_set_iv(PurpleCipher *cipher, guchar *iv, size_t len)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
371 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
372 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
373 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
374
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
375 g_return_if_fail(len == 8);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
376
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
377 memcpy(priv->iv, iv, len);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
378
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
379 g_object_notify(G_OBJECT(des3_cipher), "iv");
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
380 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
381
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
382 /******************************************************************************
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
383 * Object Stuff
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
384 *****************************************************************************/
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
385 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
386 purple_des3_cipher_get_property(GObject *obj, guint param_id, GValue *value,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
387 GParamSpec *pspec)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
388 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
389 PurpleCipher *cipher = PURPLE_CIPHER(obj);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
390
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
391 switch(param_id) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
392 case PROP_BATCH_MODE:
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
393 g_value_set_enum(value,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
394 purple_cipher_get_batch_mode(cipher));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
395 break;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
396 default:
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
397 G_OBJECT_WARN_INVALID_PROPERTY_ID(obj, param_id, pspec);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
398 break;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
399 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
400 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
401
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
402 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
403 purple_des3_cipher_set_property(GObject *obj, guint param_id,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
404 const GValue *value, GParamSpec *pspec)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
405 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
406 PurpleCipher *cipher = PURPLE_CIPHER(obj);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
407
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
408 switch(param_id) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
409 case PROP_BATCH_MODE:
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
410 purple_cipher_set_batch_mode(cipher,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
411 g_value_get_enum(value));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
412 break;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
413 case PROP_IV:
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
414 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
415 guchar *iv = (guchar *)g_value_get_string(value);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
416 purple_cipher_set_iv(cipher, iv, strlen((gchar*)iv));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
417 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
418 break;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
419 case PROP_KEY:
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
420 purple_cipher_set_key(cipher, (guchar *)g_value_get_string(value),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
421 purple_des3_cipher_get_key_size(cipher));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
422 break;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
423 default:
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
424 G_OBJECT_WARN_INVALID_PROPERTY_ID(obj, param_id, pspec);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
425 break;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
426 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
427 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
428
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
429 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
430 purple_des3_cipher_finalize(GObject *obj)
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
431 {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
432 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(obj);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
433 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
434
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
435 g_object_unref(G_OBJECT(priv->key1));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
436 g_object_unref(G_OBJECT(priv->key2));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
437 g_object_unref(G_OBJECT(priv->key3));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
438
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
439 memset(priv->iv, 0, sizeof(priv->iv));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
440
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
441 parent_class->finalize(obj);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
442 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
443
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
444 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
445 purple_des3_cipher_class_init(PurpleDES3CipherClass *klass) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
446 GObjectClass *obj_class = G_OBJECT_CLASS(klass);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
447 PurpleCipherClass *cipher_class = PURPLE_CIPHER_CLASS(klass);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
448 GParamSpec *pspec;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
449
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
450 parent_class = g_type_class_peek_parent(klass);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
451
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
452 obj_class->finalize = purple_des3_cipher_finalize;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
453 obj_class->get_property = purple_des3_cipher_get_property;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
454 obj_class->set_property = purple_des3_cipher_set_property;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
455
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
456 cipher_class->set_iv = purple_des3_cipher_set_iv;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
457 cipher_class->encrypt = purple_des3_cipher_encrypt;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
458 cipher_class->decrypt = purple_des3_cipher_decrypt;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
459 cipher_class->set_key = purple_des3_cipher_set_key;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
460 cipher_class->set_batch_mode = purple_des3_cipher_set_batch_mode;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
461 cipher_class->get_batch_mode = purple_des3_cipher_get_batch_mode;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
462 cipher_class->get_key_size = purple_des3_cipher_get_key_size;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
463
34544
a41098b81e93 Changed property string batchMode to batch_mode
Ankit Vani <a@nevitus.org>
parents: 34537
diff changeset
464 pspec = g_param_spec_enum("batch_mode", "batch_mode", "batch_mode",
34537
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
465 PURPLE_TYPE_CIPHER_BATCH_MODE, 0,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
466 G_PARAM_READWRITE);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
467 g_object_class_install_property(obj_class, PROP_BATCH_MODE, pspec);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
468
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
469 pspec = g_param_spec_string("iv", "iv", "iv", NULL,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
470 G_PARAM_WRITABLE);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
471 g_object_class_install_property(obj_class, PROP_IV, pspec);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
472
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
473 pspec = g_param_spec_string("key", "key", "key", NULL,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
474 G_PARAM_WRITABLE);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
475 g_object_class_install_property(obj_class, PROP_KEY, pspec);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
476
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
477 g_type_class_add_private(klass, sizeof(PurpleDES3CipherPrivate));
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
478 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
479
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
480 static void
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
481 purple_des3_cipher_init(PurpleCipher *cipher) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
482 PurpleDES3Cipher *des3_cipher = PURPLE_DES3_CIPHER(cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
483 PurpleDES3CipherPrivate *priv = PURPLE_DES3_CIPHER_GET_PRIVATE(des3_cipher);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
484
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
485 priv->key1 = purple_des_cipher_new();
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
486 priv->key2 = purple_des_cipher_new();
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
487 priv->key3 = purple_des_cipher_new();
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
488 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
489
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
490 /******************************************************************************
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
491 * API
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
492 *****************************************************************************/
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
493 GType
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
494 purple_des3_cipher_get_gtype(void) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
495 static GType type = 0;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
496
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
497 if(type == 0) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
498 static const GTypeInfo info = {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
499 sizeof(PurpleDES3CipherClass),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
500 NULL,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
501 NULL,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
502 (GClassInitFunc)purple_des3_cipher_class_init,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
503 NULL,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
504 NULL,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
505 sizeof(PurpleDES3Cipher),
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
506 0,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
507 (GInstanceInitFunc)purple_des3_cipher_init,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
508 NULL
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
509 };
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
510
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
511 type = g_type_register_static(PURPLE_TYPE_CIPHER,
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
512 "PurpleDES3Cipher",
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
513 &info, 0);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
514 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
515
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
516 return type;
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
517 }
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
518
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
519 PurpleCipher *
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
520 purple_des3_cipher_new(void) {
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
521 return g_object_new(PURPLE_TYPE_DES3_CIPHER, NULL);
fb40b0460a36 GObjectify the DES and Triple-DES ciphers
Ankit Vani <a@nevitus.org>
parents:
diff changeset
522 }

mercurial