File indexing completed on 2024-09-15 04:15:56
0001 /* 0002 Copyright (C) 2004, 2006 Brad Hards <bradh@frogmouth.net> 0003 0004 Permission is hereby granted, free of charge, to any person obtaining a copy 0005 of this software and associated documentation files (the "Software"), to deal 0006 in the Software without restriction, including without limitation the rights 0007 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 0008 copies of the Software, and to permit persons to whom the Software is 0009 furnished to do so, subject to the following conditions: 0010 0011 The above copyright notice and this permission notice shall be included in 0012 all copies or substantial portions of the Software. 0013 0014 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 0015 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 0016 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 0017 AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 0018 AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 0019 CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 0020 */ 0021 0022 // QtCrypto has the declarations for all of QCA 0023 #include <QtCrypto> 0024 0025 #include <QCoreApplication> 0026 #include <QDebug> 0027 0028 // needed for printf 0029 #include <cstdio> 0030 0031 #ifdef QT_STATICPLUGIN 0032 #include "import_plugins.h" 0033 #endif 0034 0035 int main(int argc, char **argv) 0036 { 0037 // the Initializer object sets things up, and 0038 // also does cleanup when it goes out of scope 0039 QCA::Initializer init; 0040 0041 QCoreApplication app(argc, argv); 0042 0043 qDebug() << "This example shows hashed MAC"; 0044 0045 // we use the first argument as the data to authenticate 0046 // if an argument is provided. Use "hello" if no argument 0047 QByteArray arg = (argc >= 2) ? argv[1] : "hello"; 0048 0049 // we use the second argument as the key to authenticate 0050 // with, if two arguments are provided. Use "secret" as 0051 // the key if less than two arguments. 0052 QCA::SecureArray key((argc >= 3) ? argv[2] : "secret"); 0053 0054 // must always check that an algorithm is supported before using it 0055 if (!QCA::isSupported("hmac(sha1)")) { 0056 printf("HMAC(SHA1) not supported!\n"); 0057 } else { 0058 // create the required object using HMAC with SHA-1, and an 0059 // empty key. 0060 QCA::MessageAuthenticationCode hmacObject(QStringLiteral("hmac(sha1)"), QCA::SecureArray()); 0061 0062 // create the key 0063 QCA::SymmetricKey keyObject(key); 0064 0065 // set the HMAC object to use the key 0066 hmacObject.setup(key); 0067 // that could also have been done in the 0068 // QCA::MessageAuthenticationCode constructor 0069 0070 // we split it into two parts to show incremental update 0071 QCA::SecureArray part1(arg.left(3)); // three chars - "hel" 0072 QCA::SecureArray part2(arg.mid(3)); // the rest - "lo" 0073 hmacObject.update(part1); 0074 hmacObject.update(part2); 0075 0076 // no more updates after calling final. 0077 QCA::SecureArray resultArray = hmacObject.final(); 0078 0079 // convert the result into printable hexadecimal. 0080 QString result = QCA::arrayToHex(resultArray.toByteArray()); 0081 printf("HMAC(SHA1) of \"%s\" with \"%s\" = [%s]\n", arg.data(), key.data(), result.toLatin1().data()); 0082 } 0083 0084 return 0; 0085 }