2004-12-30 09:32:01 +00:00
|
|
|
/*
|
|
|
|
Copyright (C) 2003 Justin Karneges
|
2005-03-17 09:38:05 +00:00
|
|
|
Copyright (C) 2005 Brad Hards <bradh@frogmouth.net>
|
2004-12-30 09:32:01 +00:00
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
|
|
AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
2005-03-17 09:38:05 +00:00
|
|
|
// QtCrypto has the declarations for all of QCA
|
|
|
|
#include <QtCrypto>
|
|
|
|
#include <stdio.h>
|
2003-09-17 00:53:41 +00:00
|
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
2005-03-17 09:38:05 +00:00
|
|
|
// the Initializer object sets things up, and
|
|
|
|
// also does cleanup when it goes out of scope
|
2004-12-30 09:32:01 +00:00
|
|
|
QCA::Initializer init;
|
2005-03-17 09:38:05 +00:00
|
|
|
|
|
|
|
QCoreApplication app(argc, argv);
|
|
|
|
|
|
|
|
// we use the first argument if provided, or
|
|
|
|
// use "hello" if no arguments
|
|
|
|
QSecureArray arg = (argc >= 2) ? argv[1] : "hello";
|
2003-09-17 00:53:41 +00:00
|
|
|
|
|
|
|
// AES128 test
|
2005-03-22 09:16:08 +00:00
|
|
|
if(!QCA::isSupported("aes128-cbc-pkcs7"))
|
2005-03-17 09:38:05 +00:00
|
|
|
printf("AES128-CBC not supported!\n");
|
2003-09-17 00:53:41 +00:00
|
|
|
else {
|
|
|
|
// encrypt
|
2005-03-17 09:38:05 +00:00
|
|
|
QCA::AES128 c(QCA::Cipher::CBC, QCA::Cipher::DefaultPadding, QCA::Encode);
|
2005-03-22 11:15:41 +00:00
|
|
|
c.setup(QCA::Encode, QCA::SymmetricKey(16));
|
2005-03-22 09:16:08 +00:00
|
|
|
QSecureArray u = c.update(arg);
|
|
|
|
if (c.ok()) {
|
|
|
|
printf("Update OK\n");
|
|
|
|
} else {
|
|
|
|
printf("Update failed\n");
|
|
|
|
}
|
|
|
|
QString result = QCA::arrayToHex(u);
|
|
|
|
printf(">aes128(\"%s\") = [%s]\n", arg.data(),qPrintable(result) );
|
2005-03-17 09:38:05 +00:00
|
|
|
QSecureArray f = c.final();
|
2005-03-22 09:16:08 +00:00
|
|
|
if (c.ok()) {
|
|
|
|
printf("Final OK\n");
|
|
|
|
} else {
|
|
|
|
printf("Final failed\n");
|
|
|
|
}
|
|
|
|
result = QCA::arrayToHex(f);
|
2005-03-17 09:38:05 +00:00
|
|
|
printf(">aes128(\"%s\") = [%s]\n", arg.data(),qPrintable(result) );
|
2003-09-17 00:53:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|