Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | File List | Namespace Members | Class Members | File Members

validat3.cpp

00001 // validat3.cpp - written and placed in the public domain by Wei Dai
00002 
00003 #include "pch.h"
00004 #include "validate.h"
00005 
00006 #include "smartptr.h"
00007 #include "crc.h"
00008 #include "adler32.h"
00009 #include "md2.h"
00010 #include "md4.h"
00011 #include "md5.h"
00012 #include "sha.h"
00013 #include "tiger.h"
00014 #include "ripemd.h"
00015 #include "haval.h"
00016 #include "panama.h"
00017 
00018 #include "md5mac.h"
00019 #include "hmac.h"
00020 #include "xormac.h"
00021 
00022 #include "integer.h"
00023 #include "pwdbased.h"
00024 #include "filters.h"
00025 #include "hex.h"
00026 #include "files.h"
00027 
00028 #include <iostream>
00029 #include <iomanip>
00030 
00031 USING_NAMESPACE(CryptoPP)
00032 USING_NAMESPACE(std)
00033 
00034 struct HashTestTuple
00035 {
00036         HashTestTuple(const char *input, const char *output, unsigned int repeatTimes=1)
00037                 : input((byte *)input), output((byte *)output), inputLen(strlen(input)), repeatTimes(repeatTimes) {}
00038         
00039         HashTestTuple(const char *input, unsigned int inputLen, const char *output, unsigned int repeatTimes)
00040                 : input((byte *)input), output((byte *)output), inputLen(inputLen), repeatTimes(repeatTimes) {}
00041 
00042         const byte *input, *output;
00043         unsigned int inputLen, repeatTimes;
00044 };
00045 
00046 bool HashModuleTest(HashTransformation &md, const HashTestTuple *testSet, unsigned int testSetSize)
00047 {
00048         bool pass=true, fail;
00049         SecByteBlock digest(md.DigestSize());
00050 
00051         for (unsigned int i=0; i<testSetSize; i++)
00052         {
00053                 unsigned j;
00054 
00055                 for (j=0; j<testSet[i].repeatTimes; j++)
00056                         md.Update(testSet[i].input, testSet[i].inputLen);
00057                 md.Final(digest);
00058                 fail = memcmp(digest, testSet[i].output, md.DigestSize()) != 0;
00059                 pass = pass && !fail;
00060 
00061                 cout << (fail ? "FAILED   " : "passed   ");
00062                 for (j=0; j<md.DigestSize(); j++)
00063                         cout << setw(2) << setfill('0') << hex << (int)digest[j];
00064                 cout << "   \"" << (char *)testSet[i].input << '\"';
00065                 if (testSet[i].repeatTimes != 1)
00066                         cout << " repeated " << dec << testSet[i].repeatTimes << " times";
00067                 cout  << endl;
00068         }
00069 
00070         return pass;
00071 }
00072 
00073 bool ValidateCRC32()
00074 {
00075         HashTestTuple testSet[] = 
00076         {
00077                 HashTestTuple("", "\x00\x00\x00\x00"),
00078                 HashTestTuple("a", "\x43\xbe\xb7\xe8"),
00079                 HashTestTuple("abc", "\xc2\x41\x24\x35"),
00080                 HashTestTuple("message digest", "\x7f\x9d\x15\x20"),
00081                 HashTestTuple("abcdefghijklmnopqrstuvwxyz", "\xbd\x50\x27\x4c"),
00082                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", "\xd2\xe6\xc2\x1f"),
00083                 HashTestTuple("12345678901234567890123456789012345678901234567890123456789012345678901234567890", "\x72\x4a\xa9\x7c"),
00084                 HashTestTuple("123456789", "\x26\x39\xf4\xcb")
00085         };
00086 
00087         CRC32 crc;
00088 
00089         cout << "\nCRC-32 validation suite running...\n\n";
00090         return HashModuleTest(crc, testSet, sizeof(testSet)/sizeof(testSet[0]));
00091 }
00092 
00093 bool ValidateAdler32()
00094 {
00095         HashTestTuple testSet[] = 
00096         {
00097                 HashTestTuple("", "\x00\x00\x00\x01"),
00098                 HashTestTuple("a", "\x00\x62\x00\x62"),
00099                 HashTestTuple("abc", "\x02\x4d\x01\x27"),
00100                 HashTestTuple("message digest", "\x29\x75\x05\x86"),
00101                 HashTestTuple("abcdefghijklmnopqrstuvwxyz", "\x90\x86\x0b\x20"),
00102                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", "\x8a\xdb\x15\x0c"),
00103                 HashTestTuple("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", "\x15\xd8\x70\xf9", 15625)
00104         };
00105 
00106         Adler32 md;
00107 
00108         cout << "\nAdler-32 validation suite running...\n\n";
00109         return HashModuleTest(md, testSet, sizeof(testSet)/sizeof(testSet[0]));
00110 }
00111 
00112 bool ValidateMD2()
00113 {
00114         HashTestTuple testSet[] = 
00115         {
00116                 HashTestTuple("", "\x83\x50\xe5\xa3\xe2\x4c\x15\x3d\xf2\x27\x5c\x9f\x80\x69\x27\x73"),
00117                 HashTestTuple("a", "\x32\xec\x01\xec\x4a\x6d\xac\x72\xc0\xab\x96\xfb\x34\xc0\xb5\xd1"),
00118                 HashTestTuple("abc", "\xda\x85\x3b\x0d\x3f\x88\xd9\x9b\x30\x28\x3a\x69\xe6\xde\xd6\xbb"),
00119                 HashTestTuple("message digest", "\xab\x4f\x49\x6b\xfb\x2a\x53\x0b\x21\x9f\xf3\x30\x31\xfe\x06\xb0"),
00120                 HashTestTuple("abcdefghijklmnopqrstuvwxyz", "\x4e\x8d\xdf\xf3\x65\x02\x92\xab\x5a\x41\x08\xc3\xaa\x47\x94\x0b"),
00121                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", "\xda\x33\xde\xf2\xa4\x2d\xf1\x39\x75\x35\x28\x46\xc3\x03\x38\xcd"),
00122                 HashTestTuple("12345678901234567890123456789012345678901234567890123456789012345678901234567890", "\xd5\x97\x6f\x79\xd8\x3d\x3a\x0d\xc9\x80\x6c\x3c\x66\xf3\xef\xd8")
00123         };
00124 
00125         MD2 md2;
00126 
00127         cout << "\nMD2 validation suite running...\n\n";
00128         return HashModuleTest(md2, testSet, sizeof(testSet)/sizeof(testSet[0]));
00129 }
00130 
00131 bool ValidateMD4()
00132 {
00133         HashTestTuple testSet[] = 
00134         {
00135                 HashTestTuple("", "\x31\xd6\xcf\xe0\xd1\x6a\xe9\x31\xb7\x3c\x59\xd7\xe0\xc0\x89\xc0"),
00136                 HashTestTuple("a", "\xbd\xe5\x2c\xb3\x1d\xe3\x3e\x46\x24\x5e\x05\xfb\xdb\xd6\xfb\x24"),
00137                 HashTestTuple("abc", "\xa4\x48\x01\x7a\xaf\x21\xd8\x52\x5f\xc1\x0a\xe8\x7a\xa6\x72\x9d"),
00138                 HashTestTuple("message digest", "\xd9\x13\x0a\x81\x64\x54\x9f\xe8\x18\x87\x48\x06\xe1\xc7\x01\x4b"),
00139                 HashTestTuple("abcdefghijklmnopqrstuvwxyz", "\xd7\x9e\x1c\x30\x8a\xa5\xbb\xcd\xee\xa8\xed\x63\xdf\x41\x2d\xa9"),
00140                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", "\x04\x3f\x85\x82\xf2\x41\xdb\x35\x1c\xe6\x27\xe1\x53\xe7\xf0\xe4"),
00141                 HashTestTuple("12345678901234567890123456789012345678901234567890123456789012345678901234567890", "\xe3\x3b\x4d\xdc\x9c\x38\xf2\x19\x9c\x3e\x7b\x16\x4f\xcc\x05\x36")
00142         };
00143 
00144         MD4 md4;
00145 
00146         cout << "\nMD4 validation suite running...\n\n";
00147         return HashModuleTest(md4, testSet, sizeof(testSet)/sizeof(testSet[0]));
00148 }
00149 
00150 bool ValidateMD5()
00151 {
00152         HashTestTuple testSet[] = 
00153         {
00154                 HashTestTuple("", "\xd4\x1d\x8c\xd9\x8f\x00\xb2\x04\xe9\x80\x09\x98\xec\xf8\x42\x7e"),
00155                 HashTestTuple("a", "\x0c\xc1\x75\xb9\xc0\xf1\xb6\xa8\x31\xc3\x99\xe2\x69\x77\x26\x61"),
00156                 HashTestTuple("abc", "\x90\x01\x50\x98\x3c\xd2\x4f\xb0\xd6\x96\x3f\x7d\x28\xe1\x7f\x72"),
00157                 HashTestTuple("message digest", "\xf9\x6b\x69\x7d\x7c\xb7\x93\x8d\x52\x5a\x2f\x31\xaa\xf1\x61\xd0"),
00158                 HashTestTuple("abcdefghijklmnopqrstuvwxyz", "\xc3\xfc\xd3\xd7\x61\x92\xe4\x00\x7d\xfb\x49\x6c\xca\x67\xe1\x3b"),
00159                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", "\xd1\x74\xab\x98\xd2\x77\xd9\xf5\xa5\x61\x1c\x2c\x9f\x41\x9d\x9f"),
00160                 HashTestTuple("12345678901234567890123456789012345678901234567890123456789012345678901234567890", "\x57\xed\xf4\xa2\x2b\xe3\xc9\x55\xac\x49\xda\x2e\x21\x07\xb6\x7a")
00161         };
00162 
00163         MD5 md5;
00164 
00165         cout << "\nMD5 validation suite running...\n\n";
00166         return HashModuleTest(md5, testSet, sizeof(testSet)/sizeof(testSet[0]));
00167 }
00168 
00169 bool ValidateSHA()
00170 {
00171         HashTestTuple testSet[] = 
00172         {
00173                 HashTestTuple("abc", "\xA9\x99\x3E\x36\x47\x06\x81\x6A\xBA\x3E\x25\x71\x78\x50\xC2\x6C\x9C\xD0\xD8\x9D"),
00174                 HashTestTuple("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq", "\x84\x98\x3E\x44\x1C\x3B\xD2\x6E\xBA\xAE\x4A\xA1\xF9\x51\x29\xE5\xE5\x46\x70\xF1"),
00175                 HashTestTuple("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", "\x34\xAA\x97\x3C\xD4\xC4\xDA\xA4\xF6\x1E\xEB\x2B\xDB\xAD\x27\x31\x65\x34\x01\x6F", 15625)
00176         };
00177 
00178         SHA sha;
00179 
00180         cout << "\nSHA validation suite running...\n\n";
00181         return HashModuleTest(sha, testSet, sizeof(testSet)/sizeof(testSet[0]));
00182 }
00183 
00184 bool ValidateSHA2()
00185 {
00186         HashTestTuple testSet256[] = 
00187         {
00188                 HashTestTuple("abc", "\xba\x78\x16\xbf\x8f\x01\xcf\xea\x41\x41\x40\xde\x5d\xae\x22\x23\xb0\x03\x61\xa3\x96\x17\x7a\x9c\xb4\x10\xff\x61\xf2\x00\x15\xad"),
00189                 HashTestTuple("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq", "\x24\x8d\x6a\x61\xd2\x06\x38\xb8\xe5\xc0\x26\x93\x0c\x3e\x60\x39\xa3\x3c\xe4\x59\x64\xff\x21\x67\xf6\xec\xed\xd4\x19\xdb\x06\xc1"),
00190         };
00191 
00192         HashTestTuple testSet384[] = 
00193         {
00194                 HashTestTuple("abc", "\xcb\x00\x75\x3f\x45\xa3\x5e\x8b\xb5\xa0\x3d\x69\x9a\xc6\x50\x07\x27\x2c\x32\xab\x0e\xde\xd1\x63\x1a\x8b\x60\x5a\x43\xff\x5b\xed\x80\x86\x07\x2b\xa1\xe7\xcc\x23\x58\xba\xec\xa1\x34\xc8\x25\xa7"),
00195                 HashTestTuple("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu", "\x09\x33\x0c\x33\xf7\x11\x47\xe8\x3d\x19\x2f\xc7\x82\xcd\x1b\x47\x53\x11\x1b\x17\x3b\x3b\x05\xd2\x2f\xa0\x80\x86\xe3\xb0\xf7\x12\xfc\xc7\xc7\x1a\x55\x7e\x2d\xb9\x66\xc3\xe9\xfa\x91\x74\x60\x39"),
00196         };
00197 
00198         HashTestTuple testSet512[] = 
00199         {
00200                 HashTestTuple("abc", "\xdd\xaf\x35\xa1\x93\x61\x7a\xba\xcc\x41\x73\x49\xae\x20\x41\x31\x12\xe6\xfa\x4e\x89\xa9\x7e\xa2\x0a\x9e\xee\xe6\x4b\x55\xd3\x9a\x21\x92\x99\x2a\x27\x4f\xc1\xa8\x36\xba\x3c\x23\xa3\xfe\xeb\xbd\x45\x4d\x44\x23\x64\x3c\xe8\x0e\x2a\x9a\xc9\x4f\xa5\x4c\xa4\x9f"),
00201                 HashTestTuple("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu", "\x8e\x95\x9b\x75\xda\xe3\x13\xda\x8c\xf4\xf7\x28\x14\xfc\x14\x3f\x8f\x77\x79\xc6\xeb\x9f\x7f\xa1\x72\x99\xae\xad\xb6\x88\x90\x18\x50\x1d\x28\x9e\x49\x00\xf7\xe4\x33\x1b\x99\xde\xc4\xb5\x43\x3a\xc7\xd3\x29\xee\xb6\xdd\x26\x54\x5e\x96\xe5\x5b\x87\x4b\xe9\x09"),
00202         };
00203 
00204         bool pass = true;
00205 
00206         cout << "\nSHA-256 validation suite running...\n\n";
00207         SHA256 sha256;
00208         pass = HashModuleTest(sha256, testSet256, sizeof(testSet256)/sizeof(testSet256[0])) && pass;
00209 
00210         cout << "\nSHA-384 validation suite running...\n\n";
00211         SHA384 sha384;
00212         pass = HashModuleTest(sha384, testSet384, sizeof(testSet384)/sizeof(testSet384[0])) && pass;
00213 
00214         cout << "\nSHA-512 validation suite running...\n\n";
00215         SHA512 sha512;
00216         pass = HashModuleTest(sha512, testSet512, sizeof(testSet512)/sizeof(testSet512[0])) && pass;
00217 
00218         return pass;
00219 }
00220 
00221 bool ValidateTiger()
00222 {
00223         cout << "\nTiger validation suite running...\n\n";
00224 
00225 #ifdef WORD64_AVAILABLE
00226         HashTestTuple testSet[] =
00227         {
00228                 HashTestTuple("", "\x32\x93\xac\x63\x0c\x13\xf0\x24\x5f\x92\xbb\xb1\x76\x6e\x16\x16\x7a\x4e\x58\x49\x2d\xde\x73\xf3"),
00229                 HashTestTuple("abc", "\x2a\xab\x14\x84\xe8\xc1\x58\xf2\xbf\xb8\xc5\xff\x41\xb5\x7a\x52\x51\x29\x13\x1c\x95\x7b\x5f\x93"),
00230                 HashTestTuple("Tiger", "\xdd\x00\x23\x07\x99\xf5\x00\x9f\xec\x6d\xeb\xc8\x38\xbb\x6a\x27\xdf\x2b\x9d\x6f\x11\x0c\x79\x37"),
00231                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-", "\xf7\x1c\x85\x83\x90\x2a\xfb\x87\x9e\xdf\xe6\x10\xf8\x2c\x0d\x47\x86\xa3\xa5\x34\x50\x44\x86\xb5"),
00232                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZ=abcdefghijklmnopqrstuvwxyz+0123456789", "\x48\xce\xeb\x63\x08\xb8\x7d\x46\xe9\x5d\x65\x61\x12\xcd\xf1\x8d\x97\x91\x5f\x97\x65\x65\x89\x57"),
00233                 HashTestTuple("Tiger - A Fast New Hash Function, by Ross Anderson and Eli Biham", "\x8a\x86\x68\x29\x04\x0a\x41\x0c\x72\x9a\xd2\x3f\x5a\xda\x71\x16\x03\xb3\xcd\xd3\x57\xe4\xc1\x5e"),
00234                 HashTestTuple("Tiger - A Fast New Hash Function, by Ross Anderson and Eli Biham, proceedings of Fast Software Encryption 3, Cambridge.", "\xce\x55\xa6\xaf\xd5\x91\xf5\xeb\xac\x54\x7f\xf8\x4f\x89\x22\x7f\x93\x31\xda\xb0\xb6\x11\xc8\x89"),
00235                 HashTestTuple("Tiger - A Fast New Hash Function, by Ross Anderson and Eli Biham, proceedings of Fast Software Encryption 3, Cambridge, 1996.", "\x63\x1a\xbd\xd1\x03\xeb\x9a\x3d\x24\x5b\x6d\xfd\x4d\x77\xb2\x57\xfc\x74\x39\x50\x1d\x15\x68\xdd"),
00236                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-", "\xc5\x40\x34\xe5\xb4\x3e\xb8\x00\x58\x48\xa7\xe0\xae\x6a\xac\x76\xe4\xff\x59\x0a\xe7\x15\xfd\x25")
00237         };
00238 
00239         Tiger tiger;
00240 
00241         return HashModuleTest(tiger, testSet, sizeof(testSet)/sizeof(testSet[0]));
00242 #else
00243         cout << "word64 not available, skipping Tiger validation." << endl;
00244         return true;
00245 #endif
00246 }
00247 
00248 bool ValidateRIPEMD()
00249 {
00250         HashTestTuple testSet[] = 
00251         {
00252                 HashTestTuple("", "\x9c\x11\x85\xa5\xc5\xe9\xfc\x54\x61\x28\x08\x97\x7e\xe8\xf5\x48\xb2\x25\x8d\x31"),
00253                 HashTestTuple("a", "\x0b\xdc\x9d\x2d\x25\x6b\x3e\xe9\xda\xae\x34\x7b\xe6\xf4\xdc\x83\x5a\x46\x7f\xfe"),
00254                 HashTestTuple("abc", "\x8e\xb2\x08\xf7\xe0\x5d\x98\x7a\x9b\x04\x4a\x8e\x98\xc6\xb0\x87\xf1\x5a\x0b\xfc"),
00255                 HashTestTuple("message digest", "\x5d\x06\x89\xef\x49\xd2\xfa\xe5\x72\xb8\x81\xb1\x23\xa8\x5f\xfa\x21\x59\x5f\x36"),
00256                 HashTestTuple("abcdefghijklmnopqrstuvwxyz", "\xf7\x1c\x27\x10\x9c\x69\x2c\x1b\x56\xbb\xdc\xeb\x5b\x9d\x28\x65\xb3\x70\x8d\xbc"),
00257                 HashTestTuple("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq", "\x12\xa0\x53\x38\x4a\x9c\x0c\x88\xe4\x05\xa0\x6c\x27\xdc\xf4\x9a\xda\x62\xeb\x2b"),
00258                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", "\xb0\xe2\x0b\x6e\x31\x16\x64\x02\x86\xed\x3a\x87\xa5\x71\x30\x79\xb2\x1f\x51\x89"),
00259                 HashTestTuple("12345678901234567890123456789012345678901234567890123456789012345678901234567890", "\x9b\x75\x2e\x45\x57\x3d\x4b\x39\xf4\xdb\xd3\x32\x3c\xab\x82\xbf\x63\x32\x6b\xfb"),
00260                 HashTestTuple("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", "\x52\x78\x32\x43\xc1\x69\x7b\xdb\xe1\x6d\x37\xf9\x7f\x68\xf0\x83\x25\xdc\x15\x28", 15625)
00261         };
00262 
00263         RIPEMD160 md;
00264 
00265         cout << "\nRIPEMD-160 validation suite running...\n\n";
00266         return HashModuleTest(md, testSet, sizeof(testSet)/sizeof(testSet[0]));
00267 }
00268 
00269 bool ValidateHAVAL()
00270 {
00271         HashTestTuple testSet[] = 
00272         {
00273                 HashTestTuple("", "\xC6\x8F\x39\x91\x3F\x90\x1F\x3D\xDF\x44\xC7\x07\x35\x7A\x7D\x70"),
00274                 HashTestTuple("a", "\x4D\xA0\x8F\x51\x4A\x72\x75\xDB\xC4\xCE\xCE\x4A\x34\x73\x85\x98\x39\x83\xA8\x30"),
00275                 HashTestTuple("HAVAL", "\x0C\x13\x96\xD7\x77\x26\x89\xC4\x67\x73\xF3\xDA\xAC\xA4\xEF\xA9\x82\xAD\xBF\xB2\xF1\x46\x7E\xEA"),
00276                 HashTestTuple("0123456789", "\xBE\xBD\x78\x16\xF0\x9B\xAE\xEC\xF8\x90\x3B\x1B\x9B\xC6\x72\xD9\xFA\x42\x8E\x46\x2B\xA6\x99\xF8\x14\x84\x15\x29"),
00277                 HashTestTuple("abcdefghijklmnopqrstuvwxyz", "\xC9\xC7\xD8\xAF\xA1\x59\xFD\x9E\x96\x5C\xB8\x3F\xF5\xEE\x6F\x58\xAE\xDA\x35\x2C\x0E\xFF\x00\x55\x48\x15\x3A\x61\x55\x1C\x38\xEE"),
00278                 HashTestTuple("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", "\xB4\x5C\xB6\xE6\x2F\x2B\x13\x20\xE4\xF8\xF1\xB0\xB2\x73\xD4\x5A\xDD\x47\xC3\x21\xFD\x23\x99\x9D\xCF\x40\x3A\xC3\x76\x36\xD9\x63")
00279         };
00280 
00281         bool pass=true;
00282 
00283         cout << "\nHAVAL validation suite running...\n\n";
00284         {
00285                 HAVAL3 md(16);
00286                 pass = HashModuleTest(md, testSet+0, 1) && pass;
00287         }
00288         {
00289                 HAVAL3 md(20);
00290                 pass = HashModuleTest(md, testSet+1, 1) && pass;
00291         }
00292         {
00293                 HAVAL4 md(24);
00294                 pass = HashModuleTest(md, testSet+2, 1) && pass;
00295         }
00296         {
00297                 HAVAL4 md(28);
00298                 pass = HashModuleTest(md, testSet+3, 1) && pass;
00299         }
00300         {
00301                 HAVAL5 md(32);
00302                 pass = HashModuleTest(md, testSet+4, 1) && pass;
00303         }
00304         {
00305                 HAVAL5 md(32);
00306                 pass = HashModuleTest(md, testSet+5, 1) && pass;
00307         }
00308 
00309         return pass;
00310 }
00311 
00312 bool ValidatePanama()
00313 {
00314         bool pass=true;
00315 
00316         // the first two test vectors are from the reference implementation
00317         // the rest were generated by Crypto++
00318         HashTestTuple testSet1[] = 
00319         {
00320                 HashTestTuple("", "\xaa\x0c\xc9\x54\xd7\x57\xd7\xac\x77\x79\xca\x33\x42\x33\x4c\xa4\x71\xab\xd4\x7d\x59\x52\xac\x91\xed\x83\x7e\xcd\x5b\x16\x92\x2b"),
00321                 HashTestTuple("The quick brown fox jumps over the lazy dog", "\x5f\x5c\xa3\x55\xb9\x0a\xc6\x22\xb0\xaa\x7e\x65\x4e\xf5\xf2\x7e\x9e\x75\x11\x14\x15\xb4\x8b\x8a\xfe\x3a\xdd\x1c\x6b\x89\xcb\xa1"),
00322                 HashTestTuple("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", "\xaf\x9c\x66\xfb\x60\x58\xe2\x23\x2a\x5d\xfb\xa0\x63\xee\x14\xb0\xf8\x6f\x0e\x33\x4e\x16\x58\x12\x55\x94\x35\x46\x4d\xd9\xbb\x60", 15625)
00323         };
00324         HashTestTuple testSet2[] = 
00325         {
00326                 HashTestTuple("", "\xe8\x1a\xa0\x45\x23\x53\x2d\xd7\x26\x7e\x5c\x5b\xc3\xba\x0e\x28\x98\x37\xa6\x2b\xa0\x32\x35\x03\x51\x98\x0e\x96\x0a\x84\xb0\xaf"),
00327                 HashTestTuple("The quick brown fox jumps over the lazy dog", "\x8f\xa7\xda\xdc\xe0\x11\x0f\x97\x9a\x0b\x79\x5e\x76\xb2\xc2\x56\x28\xd8\xbd\xa8\x87\x47\x75\x81\x49\xc4\x2e\x3b\xc1\x3f\x85\xbc"),
00328                 HashTestTuple("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", "\xcb\x34\xf0\x93\x7e\x8d\x87\x0d\x3b\xd7\xff\x63\x11\x76\x5f\x2c\x22\x9a\x6c\x21\x54\xe4\xdb\x11\x95\x38\xdb\x51\x59\x43\x7c\xab", 15625)
00329         };
00330 
00331         cout << "\nPanama Hash Function (little endian) validation suite running...\n\n";
00332         PanamaHash<LittleEndian> panamaLE;
00333         pass = HashModuleTest(panamaLE, testSet1, sizeof(testSet1)/sizeof(testSet1[0])) && pass;
00334 
00335         cout << "\nPanama Hash Function (big endian) validation suite running...\n\n";
00336         PanamaHash<BigEndian> panamaBE;
00337         pass = HashModuleTest(panamaBE, testSet2, sizeof(testSet2)/sizeof(testSet2[0])) && pass;
00338 
00339         // these were generated by Crypto++
00340         unsigned char Key0[] = {
00341                 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
00342                 0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f,
00343                 0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,
00344                 0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f,
00345                 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
00346                 0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f,
00347                 0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,
00348                 0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f};
00349         unsigned char Input0l[] = {
00350                 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
00351                 0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f,
00352                 0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,
00353                 0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f};
00354         unsigned char Output0l[] = {
00355                 0xF0,0x7F,0x5F,0xF2,0xCC,0xD0,0x1A,0x0A,
00356                 0x7D,0x44,0xAC,0xD6,0xD2,0x39,0xC2,0xAF,
00357                 0x0D,0xA1,0xFF,0x35,0x27,0x5B,0xAF,0x5D,
00358                 0xFA,0x6E,0x09,0x41,0x1B,0x79,0xD8,0xB9};
00359         unsigned char Input0b[] = {
00360                 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
00361                 0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f,
00362                 0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,
00363                 0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f};
00364         unsigned char Output0b[] = {
00365                 0xE1,0x2E,0x2F,0x6B,0xA4,0x1A,0xE8,0x32,
00366                 0xD8,0x88,0xDA,0x9F,0xA6,0x86,0x3B,0xC3,
00367                 0x7C,0x0E,0x99,0x6F,0x19,0x0A,0x17,0x11,
00368                 0x33,0x03,0x22,0xD3,0x7B,0xD9,0x8C,0xA4};
00369 
00370         // VC60 workaround: auto_ptr lacks reset()
00371         member_ptr<StreamTransformation> cipher;
00372         bool fail;
00373 
00374         cout << "\nPanama Cipher (little endian) validation suite running...\n\n";
00375 
00376         cipher.reset(new PanamaCipher<LittleEndian>::Encryption(Key0, 64));
00377         cipher->ProcessString(Input0l, sizeof(Input0l));
00378         fail = memcmp(Input0l, Output0l, sizeof(Input0l)) != 0;
00379         cout << (fail ? "FAILED" : "passed") << "    Test 0" << endl;
00380         pass = pass && !fail;
00381 
00382         cout << "\nPanama Cipher (big endian) validation suite running...\n\n";
00383 
00384         cipher.reset(new PanamaCipher<BigEndian>::Encryption(Key0, 64));
00385         cipher->ProcessString(Input0b, sizeof(Input0b));
00386         fail = memcmp(Input0b, Output0b, sizeof(Input0b)) != 0;
00387         cout << (fail ? "FAILED" : "passed") << "    Test 0" << endl;
00388         pass = pass && !fail;
00389 
00390         return pass;
00391 }
00392 
00393 bool ValidateMD5MAC()
00394 {
00395         const byte keys[2][MD5MAC::KEYLENGTH]={
00396                 {0x00,0x11,0x22,0x33,0x44,0x55,0x66,0x77,0x88,0x99,0xaa,0xbb,0xcc,0xdd,0xee,0xff},
00397                 {0x01,0x23,0x45,0x67,0x89,0xab,0xcd,0xef,0xfe,0xdc,0xba,0x98,0x76,0x54,0x32,0x10}};
00398 
00399         const char *TestVals[7]={
00400                 "",
00401                 "a",
00402                 "abc",
00403                 "message digest",
00404                 "abcdefghijklmnopqrstuvwxyz",
00405                 "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",
00406                 "12345678901234567890123456789012345678901234567890123456789012345678901234567890"};
00407 
00408         const byte output[2][7][MD5MAC::DIGESTSIZE]={
00409                 {{0x1f,0x1e,0xf2,0x37,0x5c,0xc0,0xe0,0x84,0x4f,0x98,0xe7,0xe8,0x11,0xa3,0x4d,0xa8},
00410                 {0x7a,0x76,0xee,0x64,0xca,0x71,0xef,0x23,0x7e,0x26,0x29,0xed,0x94,0x52,0x73,0x65},
00411                 {0xe8,0x01,0x3c,0x11,0xf7,0x20,0x9d,0x13,0x28,0xc0,0xca,0xa0,0x4f,0xd0,0x12,0xa6},
00412                 {0xc8,0x95,0x53,0x4f,0x22,0xa1,0x74,0xbc,0x3e,0x6a,0x25,0xa2,0xb2,0xef,0xd6,0x30},
00413                 {0x91,0x72,0x86,0x7e,0xb6,0x00,0x17,0x88,0x4c,0x6f,0xa8,0xcc,0x88,0xeb,0xe7,0xc9},
00414                 {0x3b,0xd0,0xe1,0x1d,0x5e,0x09,0x4c,0xb7,0x1e,0x35,0x44,0xac,0xa9,0xb8,0xbf,0xa2},
00415                 {0x93,0x37,0x16,0x64,0x44,0xcc,0x95,0x35,0xb7,0xd5,0xb8,0x0f,0x91,0xe5,0x29,0xcb}},
00416                 {{0x2f,0x6e,0x73,0x13,0xbf,0xbb,0xbf,0xcc,0x3a,0x2d,0xde,0x26,0x8b,0x59,0xcc,0x4d},
00417                 {0x69,0xf6,0xca,0xff,0x40,0x25,0x36,0xd1,0x7a,0xe1,0x38,0x03,0x2c,0x0c,0x5f,0xfd},
00418                 {0x56,0xd3,0x2b,0x6c,0x34,0x76,0x65,0xd9,0x74,0xd6,0xf7,0x5c,0x3f,0xc6,0xf0,0x40},
00419                 {0xb8,0x02,0xb2,0x15,0x4e,0x59,0x8b,0x6f,0x87,0x60,0x56,0xc7,0x85,0x46,0x2c,0x0b},
00420                 {0x5a,0xde,0xf4,0xbf,0xf8,0x04,0xbe,0x08,0x58,0x7e,0x94,0x41,0xcf,0x6d,0xbd,0x57},
00421                 {0x18,0xe3,0x49,0xa5,0x24,0x44,0xb3,0x0e,0x5e,0xba,0x5a,0xdd,0xdc,0xd9,0xf1,0x8d},
00422                 {0xf2,0xb9,0x06,0xa5,0xb8,0x4b,0x9b,0x4b,0xbe,0x95,0xed,0x32,0x56,0x4e,0xe7,0xeb}}};
00423 
00424         byte digest[MD5MAC::DIGESTSIZE];
00425         bool pass=true, fail;
00426 
00427         cout << "\nMD5MAC validation suite running...\n";
00428 
00429         for (int k=0; k<2; k++)
00430         {
00431                 MD5MAC mac(keys[k]);
00432                 cout << "\nKEY: ";
00433                 for (int j=0;j<MD5MAC::KEYLENGTH;j++)
00434                         cout << setw(2) << setfill('0') << hex << (int)keys[k][j];
00435                 cout << endl << endl;
00436                 for (int i=0;i<7;i++)
00437                 {
00438                         mac.Update((byte *)TestVals[i], strlen(TestVals[i]));
00439                         mac.Final(digest);
00440                         fail = memcmp(digest, output[k][i], MD5MAC::DIGESTSIZE)
00441                                  || !mac.VerifyDigest(output[k][i], (byte *)TestVals[i], strlen(TestVals[i]));
00442                         pass = pass && !fail;
00443                         cout << (fail ? "FAILED   " : "passed   ");
00444                         for (int j=0;j<MD5MAC::DIGESTSIZE;j++)
00445                                 cout << setw(2) << setfill('0') << hex << (int)digest[j];
00446                         cout << "   \"" << TestVals[i] << '\"' << endl;
00447                 }
00448         }
00449 
00450         return pass;
00451 }
00452 
00453 bool ValidateHMAC()
00454 {
00455         typedef HMAC<MD5> HMAC_MD5;
00456 
00457         const char* keys[]=
00458         {
00459                 "\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b\x0b",
00460                 "Jefe",
00461                 "\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA",
00462                 "\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
00463                         "\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
00464                         "\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
00465                         "\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
00466                         "\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA\xAA"
00467         };
00468 
00469         HashTestTuple testSet[] = 
00470         {
00471                 HashTestTuple("Hi There", "\x92\x94\x72\x7a\x36\x38\xbb\x1c\x13\xf4\x8e\xf8\x15\x8b\xfc\x9d"),
00472                 HashTestTuple("what do ya want for nothing?", "\x75\x0c\x78\x3e\x6a\xb0\xb5\x03\xea\xa8\x6e\x31\x0a\x5d\xb7\x38"),
00473                 HashTestTuple("\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD\xDD",
00474                         "\x56\xbe\x34\x52\x1d\x14\x4c\x88\xdb\xb8\xc7\x33\xf0\xe8\xb3\xf6"),
00475                 HashTestTuple("Test Using Larger Than Block-Size Key - Hash Key First", "\x6b\x1a\xb7\xfe\x4b\xd7\xbf\x8f\x0b\x62\xe6\xce\x61\xb9\xd0\xcd")
00476         };
00477 
00478         bool pass=true;
00479 
00480         cout << "\nHMAC/MD5 validation suite running...\n";
00481 
00482         for (int k=0; k<4; k++)
00483         {
00484                 HMAC_MD5 mac((byte *)keys[k], strlen(keys[k]));
00485                 cout << "\nKEY: ";
00486                 for (int j=0; keys[k][j] != 0; j++)
00487                         cout << setw(2) << setfill('0') << hex << (int)(byte)keys[k][j];
00488                 cout << endl;
00489 
00490                 pass = HashModuleTest(mac, testSet+k, 1) && pass;
00491         }
00492 
00493         return pass;
00494 }
00495 
00496 bool ValidateXMACC()
00497 {
00498         typedef XMACC<MD5> XMACC_MD5;
00499 
00500         const byte keys[2][XMACC_MD5::KEYLENGTH]={
00501                 {0x00,0x11,0x22,0x33,0x44,0x55,0x66,0x77,0x88,0x99,0xaa,0xbb},
00502                 {0x01,0x23,0x45,0x67,0x89,0xab,0xcd,0xef,0xfe,0xdc,0xba,0x98}};
00503 
00504         const word32 counters[2]={0xccddeeff, 0x76543210};
00505 
00506         const char *TestVals[7]={
00507                 "",
00508                 "a",
00509                 "abc",
00510                 "message digest",
00511                 "abcdefghijklmnopqrstuvwxyz",
00512                 "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",
00513                 "12345678901234567890123456789012345678901234567890123456789012345678901234567890"};
00514 
00515         const byte output[2][7][XMACC_MD5::DIGESTSIZE]={
00516                 {{0xcc,0xdd,0xef,0x00,0xfa,0x89,0x54,0x92,0x86,0x32,0xda,0x2a,0x3f,0x29,0xc5,0x52,0xa0,0x0d,0x05,0x13},
00517                 {0xcc,0xdd,0xef,0x01,0xae,0xdb,0x8b,0x7b,0x69,0x71,0xc7,0x91,0x71,0x48,0x9d,0x18,0xe7,0xdf,0x9d,0x5a},
00518                 {0xcc,0xdd,0xef,0x02,0x5e,0x01,0x2e,0x2e,0x4b,0xc3,0x83,0x62,0xc2,0xf4,0xe6,0x18,0x1c,0x44,0xaf,0xca},
00519                 {0xcc,0xdd,0xef,0x03,0x3e,0xa9,0xf1,0xe0,0x97,0x91,0xf8,0xe2,0xbe,0xe0,0xdf,0xf3,0x41,0x03,0xb3,0x5a},
00520                 {0xcc,0xdd,0xef,0x04,0x2e,0x6a,0x8d,0xb9,0x72,0xe3,0xce,0x9f,0xf4,0x28,0x45,0xe7,0xbc,0x80,0xa9,0xc7},
00521                 {0xcc,0xdd,0xef,0x05,0x1a,0xd5,0x40,0x78,0xfb,0x16,0x37,0xfc,0x7a,0x1d,0xce,0xb4,0x77,0x10,0xb2,0xa0},
00522                 {0xcc,0xdd,0xef,0x06,0x13,0x2f,0x11,0x47,0xd7,0x1b,0xb5,0x52,0x36,0x51,0x26,0xb0,0x96,0xd7,0x60,0x81}},
00523                 {{0x76,0x54,0x32,0x11,0xe9,0xcb,0x74,0x32,0x07,0x93,0xfe,0x01,0xdd,0x27,0xdb,0xde,0x6b,0x77,0xa4,0x56},
00524                 {0x76,0x54,0x32,0x12,0xcd,0x55,0x87,0x5c,0xc0,0x35,0x85,0x99,0x44,0x02,0xa5,0x0b,0x8c,0xe7,0x2c,0x68},
00525                 {0x76,0x54,0x32,0x13,0xac,0xfd,0x87,0x50,0xc3,0x8f,0xcd,0x58,0xaa,0xa5,0x7e,0x7a,0x25,0x63,0x26,0xd1},
00526                 {0x76,0x54,0x32,0x14,0xe3,0x30,0xf5,0xdd,0x27,0x2b,0x76,0x22,0x7f,0xaa,0x90,0x73,0x6a,0x48,0xdb,0x00},
00527                 {0x76,0x54,0x32,0x15,0xfc,0x57,0x00,0x20,0x7c,0x9d,0xf6,0x30,0x6f,0xbd,0x46,0x3e,0xfb,0x8a,0x2c,0x60},
00528                 {0x76,0x54,0x32,0x16,0xfb,0x0f,0xd3,0xdf,0x4c,0x4b,0xc3,0x05,0x9d,0x63,0x1e,0xba,0x25,0x2b,0xbe,0x35},
00529                 {0x76,0x54,0x32,0x17,0xc6,0xfe,0xe6,0x5f,0xb1,0x35,0x8a,0xf5,0x32,0x7a,0x80,0xbd,0xb8,0x72,0xee,0xae}}};
00530 
00531         byte digest[XMACC_MD5::DIGESTSIZE];
00532         bool pass=true, fail;
00533 
00534         cout << "\nXMACC/MD5 validation suite running...\n";
00535 
00536         for (int k=0; k<2; k++)
00537         {
00538                 XMACC_MD5 mac(keys[k], counters[k]);
00539                 cout << "\nKEY: ";
00540                 for (int j=0;j<XMACC_MD5::KEYLENGTH;j++)
00541                         cout << setw(2) << setfill('0') << hex << (int)keys[k][j];
00542                 cout << "    COUNTER: 0x" << hex << counters[k] << endl << endl;
00543                 for (int i=0;i<7;i++)
00544                 {
00545                         mac.Update((byte *)TestVals[i], strlen(TestVals[i]));
00546                         mac.Final(digest);
00547                         fail = memcmp(digest, output[k][i], XMACC_MD5::DIGESTSIZE)
00548                                  || !mac.VerifyDigest(output[k][i], (byte *)TestVals[i], strlen(TestVals[i]));
00549                         pass = pass && !fail;
00550                         cout << (fail ? "FAILED   " : "passed   ");
00551                         for (int j=0;j<XMACC_MD5::DIGESTSIZE;j++)
00552                                 cout << setw(2) << setfill('0') << hex << (int)digest[j];
00553                         cout << "   \"" << TestVals[i] << '\"' << endl;
00554                 }
00555         }
00556 
00557         return pass;
00558 }
00559 
00560 struct PBKDF_TestTuple
00561 {
00562         byte purpose;
00563         unsigned int iterations;
00564         const char *hexPassword, *hexSalt, *hexDerivedKey;
00565 };
00566 
00567 bool TestPBKDF(PasswordBasedKeyDerivationFunction &pbkdf, const PBKDF_TestTuple *testSet, unsigned int testSetSize)
00568 {
00569         bool pass = true;
00570 
00571         for (unsigned int i=0; i<testSetSize; i++)
00572         {
00573                 const PBKDF_TestTuple &tuple = testSet[i];
00574 
00575                 string password, salt, derivedKey;
00576                 StringSource(tuple.hexPassword, true, new HexDecoder(new StringSink(password)));
00577                 StringSource(tuple.hexSalt, true, new HexDecoder(new StringSink(salt)));
00578                 StringSource(tuple.hexDerivedKey, true, new HexDecoder(new StringSink(derivedKey)));
00579 
00580                 SecByteBlock derived(derivedKey.size());
00581                 pbkdf.GeneralDeriveKey(derived, derived.size(), tuple.purpose, (byte *)password.data(), password.size(), (byte *)salt.data(), salt.size(), tuple.iterations);
00582                 bool fail = memcmp(derived, derivedKey.data(), derived.size()) != 0;
00583                 pass = pass && !fail;
00584 
00585                 HexEncoder enc(new FileSink(cout));
00586                 cout << (fail ? "FAILED   " : "passed   ");
00587                 enc.Put(tuple.purpose);
00588                 cout << " " << tuple.iterations;
00589                 cout << " " << tuple.hexPassword << " " << tuple.hexSalt << " ";
00590                 enc.Put(derived, derived.size());
00591                 cout << endl;
00592         }
00593 
00594         return pass;
00595 }
00596 
00597 bool ValidatePBKDF()
00598 {
00599         bool pass = true;
00600 
00601         {
00602         // from OpenSSL PKCS#12 Program FAQ v1.77, at http://www.drh-consultancy.demon.co.uk/test.txt
00603         PBKDF_TestTuple testSet[] = 
00604         {
00605                 {1, 1, "0073006D006500670000", "0A58CF64530D823F", "8AAAE6297B6CB04642AB5B077851284EB7128F1A2A7FBCA3"},
00606                 {2, 1, "0073006D006500670000", "0A58CF64530D823F", "79993DFE048D3B76"},
00607                 {1, 1, "0073006D006500670000", "642B99AB44FB4B1F", "F3A95FEC48D7711E985CFE67908C5AB79FA3D7C5CAA5D966"},
00608                 {2, 1, "0073006D006500670000", "642B99AB44FB4B1F", "C0A38D64A79BEA1D"},
00609                 {3, 1, "0073006D006500670000", "3D83C0E4546AC140", "8D967D88F6CAA9D714800AB3D48051D63F73A312"},
00610                 {1, 1000, "007100750065006500670000", "05DEC959ACFF72F7", "ED2034E36328830FF09DF1E1A07DD357185DAC0D4F9EB3D4"},
00611                 {2, 1000, "007100750065006500670000", "05DEC959ACFF72F7", "11DEDAD7758D4860"},
00612                 {1, 1000, "007100750065006500670000", "1682C0FC5B3F7EC5", "483DD6E919D7DE2E8E648BA8F862F3FBFBDC2BCB2C02957F"},
00613                 {2, 1000, "007100750065006500670000", "1682C0FC5B3F7EC5", "9D461D1B00355C50"},
00614                 {3, 1000, "007100750065006500670000", "263216FCC2FAB31C", "5EC4C7A80DF652294C3925B6489A7AB857C83476"}
00615         };
00616 
00617         PKCS12_PBKDF<SHA1> pbkdf;
00618 
00619         cout << "\nPKCS #12 PBKDF validation suite running...\n\n";
00620         pass = TestPBKDF(pbkdf, testSet, sizeof(testSet)/sizeof(testSet[0])) && pass;
00621         }
00622 
00623         {
00624         // from draft-ietf-smime-password-03.txt, at http://www.imc.org/draft-ietf-smime-password
00625         PBKDF_TestTuple testSet[] = 
00626         {
00627                 {0, 5, "70617373776f7264", "1234567878563412", "D1DAA78615F287E6"},
00628                 {0, 500, "416C6C206E2D656E746974696573206D75737420636F6D6D756E69636174652077697468206F74686572206E2d656E74697469657320766961206E2D3120656E746974656568656568656573", "1234567878563412","6A8970BF68C92CAEA84A8DF28510858607126380CC47AB2D"}
00629         };
00630 
00631         PKCS5_PBKDF2_HMAC<SHA1> pbkdf;
00632 
00633         cout << "\nPKCS #5 PBKDF2 validation suite running...\n\n";
00634         pass = TestPBKDF(pbkdf, testSet, sizeof(testSet)/sizeof(testSet[0])) && pass;
00635         }
00636 
00637         return pass;
00638 }

Generated on Mon Apr 19 18:12:33 2004 for Crypto++ by doxygen 1.3.6-20040222