Tuesday, 21 November 2017

DiceLockSecurity Knowledge

DicelockSecurity (version 9.X)

Windows - Source Code

DiceLock 9.0.0.1
DiceChecker 6.0.0.1
HashDigester 6.0.0.1
DiceLockTime 4.0.0.1
Previous Versions
DEA.h (Data Encryption Algorithm DEA with 64 key bits C++ header source code file) Print E-mail
Get C++ DiceLock cipher architecture source code packages of DiceLock for Microsoft Visual Studio 2013 and DiceLock-x for Linux with Test Driver Programs and Response Test Vector files to verify that both them work as expected.
DiceLock for Windows and Linux
DiceLock Security governing software licenses are Free/Libre Source Code License and Educational and Research License
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
 
//
// Creator:    http://www.dicelocksecurity.com
// Version:    vers.9.0.0.1
//
// Copyright (C) 2012-2013 DiceLock Security, LLC. All rights reserved.
//
//                               DISCLAIMER
//
// THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES,
// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
// AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
// REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// 
// DICELOCK IS A REGISTERED TRADEMARK OR TRADEMARK OF THE OWNERS.
// 
// DICELOCK IS PROTECTED BY US PATENT 7508945 AND EUROPEAN PATENT 1182777 WHERE APPLICABLE.
//
// LICENSE INFORMATION CAN BE OBTAINED AT CORPORATE WEB SITE
//
 
#ifndef DEA_HPP
 
#define DEA_HPP
 
#ifdef DICELOCKCIPHER_EXPORTS
   #define CLASS_DECLSPEC    __declspec(dllexport)
#else
   #define CLASS_DECLSPEC    __declspec(dllimport)
#endif
 
#include "baseBlockCipher.h"
#include "defaultCryptoRandomStream.h"
 
 
// Number of DEA subkeys
#define DEA_SUBKEYS          32
 
// Number of DEA weak keys
#define DEA_WEAK_KEYS        4
// Number of DEA semi-weak keys
#define DEA_SEMI_WEAK_KEYS      12
// Number of DEA possibly weak keys
#define DEA_POSSIBLY_WEAK_KEYS    48
 
 
 
namespace DiceLockSecurity {
 
  namespace Cipher {
    
    namespace SymmetricCipher {
      
      namespace BlockCipher {
 
 
  class DEA : public BaseBlockCipher {
 
    protected:
 
      // Block cipher enumerator name
      static const BlockCiphers      blockCipherType; 
 
      // Number of cipher key bits
      static const unsigned short int    deaKeyBits; 
      // Number of cipher key unsigned chars
      static const unsigned short int    deaKeyUCs; 
      // Number of cipher key unsigned short ints
      static const unsigned short int    deaKeyUSs; 
      // Number of cipher key unsigned long ints
      static const unsigned short int    deaKeyULs; 
 
      // Number of cipher block bits
      static const unsigned short int    deaBlockBits; 
      // Number of cipher block unsigned chars
      static const unsigned short int    deaBlockUCs; 
      // Number of cipher block unsigned short ints
      static const unsigned short int    deaBlockUSs; 
      // Number of cipher block unsigned long ints
      static const unsigned short int    deaBlockULs; 
 
      // DEA operation to be performed
      // true : encryption
      // false: decryption
      bool                decryptMode;
 
      // DEA SubKeys array
      unsigned long int          deaSubkeys[DEA_SUBKEYS];
 
      // DEA S-Boxes 
      static const unsigned long int    sBox1[];
      static const unsigned long int    sBox2[];
      static const unsigned long int    sBox3[];
      static const unsigned long int    sBox4[];
      static const unsigned long int    sBox5[];
      static const unsigned long int    sBox6[];
      static const unsigned long int    sBox7[];
      static const unsigned long int    sBox8[];
 
      // DEA halves bit swap 
      static const unsigned long int    leftHalves[];
      static const unsigned long int    rightHalves[];
 
      // DEA weak keys
      static const char*          weakKeys[DEA_WEAK_KEYS];
      DefaultCryptoRandomStream*      weakKeysStream[DEA_WEAK_KEYS];
      // DEA semi-weak keys
      static const char*          semiWeakKeys[DEA_SEMI_WEAK_KEYS];
      DefaultCryptoRandomStream*      semiWeakKeysStream[DEA_SEMI_WEAK_KEYS];
      // DEA possibly weak keys
      static const char*          possiblyWeakKeys[DEA_POSSIBLY_WEAK_KEYS];
      DefaultCryptoRandomStream*      possiblyWeakKeysStream[DEA_POSSIBLY_WEAK_KEYS];
 
      // Sets DEA weak keys
      CLASS_DECLSPEC void SetWeakKeys(void);
 
      // Sets DEA semi-weak keys
      CLASS_DECLSPEC void SetSemiWeakKeys(void);
 
      // Sets DEA possibly semi-weak keys
      CLASS_DECLSPEC void SetPossiblyWeakKeys(void);
 
      // Remove DEA weak keys
      CLASS_DECLSPEC void RemoveWeakKeys(void);
 
      // Remove DEA semi-weak keys
      CLASS_DECLSPEC void RemoveSemiWeakKeys(void);
 
      // Remove DEA possibly semi-weak keys
      CLASS_DECLSPEC void RemovePossiblyWeakKeys(void);
 
      // Processes one 64 bit data block 
      CLASS_DECLSPEC void ProcessBlock(BaseCryptoRandomStream* in, BaseCryptoRandomStream* out);
 
    public:
 
      // Constructor, default 
      CLASS_DECLSPEC DEA();
 
      // Destructor
      CLASS_DECLSPEC ~DEA();
 
      // Initialize BaseBlockCipher
      CLASS_DECLSPEC void Initialize();
 
      // Sets object encryption mode
      CLASS_DECLSPEC void SetEncryptionMode(void);
 
      // Sets object decryption mode
      CLASS_DECLSPEC void SetDecryptionMode(void);
 
      // Gets if current object encryption mode is encryption
      CLASS_DECLSPEC bool GetEncryptionMode(void);
 
      // Gets if current object decryption mode is decryption
      CLASS_DECLSPEC bool GetDecryptionMode(void);
 
      // Sets the symmetric key BaseCryptoRandomStream
      CLASS_DECLSPEC void SetSymmetricKey(BaseCryptoRandomStream* key);
 
      // Sets the symmetric key BaseCryptoRandomStream for encryption
      CLASS_DECLSPEC void SetEncryptionSymmetricKey(BaseCryptoRandomStream* key);
 
      // Sets the symmetric key BaseCryptoRandomStream for decryption
      CLASS_DECLSPEC void SetDecryptionSymmetricKey(BaseCryptoRandomStream* key);
 
      // Ciphers the plaintext BaseCryptoRandomStream to ciphertext BaseCryptoRandomStream
      CLASS_DECLSPEC void Cipher(BaseCryptoRandomStream* plaintext, BaseCryptoRandomStream* ciphertext);
 
      // Deciphers the ciphertext BaseCryptoRandomStream to plaintext BaseCryptoRandomStream 
      CLASS_DECLSPEC void Decipher(BaseCryptoRandomStream* ciphertext, BaseCryptoRandomStream* decipheredtext);
 
      // Gets cipher block key length in bits
      CLASS_DECLSPEC unsigned short int GetBitKeyLength(void);
 
      // Gets cipher block key length in unsigned chars
      CLASS_DECLSPEC unsigned short int GetUCKeyLength(void);
 
      // Gets cipher block key length in unsigned short ints
      CLASS_DECLSPEC unsigned short int GetUSKeyLength(void);
 
      // Gets cipher block key length in unsigned long ints
      CLASS_DECLSPEC unsigned short int GetULKeyLength(void);
 
      // Gets cipher block length in bits
      CLASS_DECLSPEC unsigned short int GetBitBlockLength(void);
 
      // Gets cipher block length in unsigned chars
      CLASS_DECLSPEC unsigned short int GetUCBlockLength(void);
 
      // Gets cipher block length in unsigned short ints
      CLASS_DECLSPEC unsigned short int GetUSBlockLength(void);
 
      // Gets cipher block length in unsigned long ints
      CLASS_DECLSPEC unsigned short int GetULBlockLength(void);
 
      // Verifies if key is a weak key
      // true:  weak key
      // false: no weak key
      CLASS_DECLSPEC bool VerifyWeakKey(BaseCryptoRandomStream* key);
 
      // Verifies if key is a semi-weak key
      // true:  semi-weak key
      // false: no semi-weak key
      CLASS_DECLSPEC bool VerifySemiWeakKey(BaseCryptoRandomStream* key);
 
      // Verifies if key is a possibly weak key
      // true:  possibly weak key
      // false: no possibly weak key
      CLASS_DECLSPEC bool VerifyPossiblyWeakKey(BaseCryptoRandomStream* key);
 
      // Gets the type of the object
      CLASS_DECLSPEC BlockCiphers GetBlockCipherType(void);
 
  };
  
    }
  }
  }
}
 
#endif