File indexing completed on 2024-09-08 04:18:39

0001 /*
0002  Copyright (C) 2003 Justin Karneges <justin@affinix.com>
0003  Copyright (C) 2005 Brad Hards <bradh@frogmouth.net>
0004 
0005  Permission is hereby granted, free of charge, to any person obtaining a copy
0006  of this software and associated documentation files (the "Software"), to deal
0007  in the Software without restriction, including without limitation the rights
0008  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
0009  copies of the Software, and to permit persons to whom the Software is
0010  furnished to do so, subject to the following conditions:
0011 
0012  The above copyright notice and this permission notice shall be included in
0013  all copies or substantial portions of the Software.
0014 
0015  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
0016  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
0017  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
0018  AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
0019  AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
0020  CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
0021 */
0022 
0023 #include <QtCrypto>
0024 
0025 #include <QCoreApplication>
0026 
0027 #include <iostream>
0028 
0029 #ifdef QT_STATICPLUGIN
0030 #include "import_plugins.h"
0031 #endif
0032 
0033 int main(int argc, char **argv)
0034 {
0035     // the Initializer object sets things up, and
0036     // also does cleanup when it goes out of scope
0037     QCA::Initializer init;
0038 
0039     QCoreApplication app(argc, argv);
0040 
0041     // We need to ensure that we have certificate handling support
0042     if (!QCA::isSupported("cert")) {
0043         std::cout << "Sorry, no PKI certificate support" << std::endl;
0044         return 1;
0045     }
0046 
0047     // Read in a private key
0048     QCA::PrivateKey    privKey;
0049     QCA::ConvertResult convRes;
0050     QCA::SecureArray   passPhrase = "start";
0051     privKey                       = QCA::PrivateKey::fromPEMFile(QStringLiteral("Userkey.pem"), passPhrase, &convRes);
0052     if (convRes != QCA::ConvertGood) {
0053         std::cout << "Sorry, could not import Private Key" << std::endl;
0054         return 1;
0055     }
0056 
0057     // Read in a matching public key cert
0058     // you could also build this using the fromPEMFile() method
0059     QCA::Certificate pubCert(QStringLiteral("User.pem"));
0060     if (pubCert.isNull()) {
0061         std::cout << "Sorry, could not import public key certificate" << std::endl;
0062         return 1;
0063     }
0064     // We are building the certificate into a SecureMessageKey object, via a
0065     // CertificateChain
0066     QCA::SecureMessageKey secMsgKey;
0067     QCA::CertificateChain chain;
0068     chain += pubCert;
0069     secMsgKey.setX509CertificateChain(chain);
0070 
0071     // build up a SecureMessage object, based on our public key certificate
0072     QCA::CMS           cms;
0073     QCA::SecureMessage msg(&cms);
0074     msg.setRecipient(secMsgKey);
0075 
0076     // Some plain text - we use the first command line argument if provided
0077     QByteArray plainText = (argc >= 2) ? argv[1] : "What do ya want for nuthin'";
0078 
0079     // Now use the SecureMessage object to encrypt the plain text.
0080     msg.startEncrypt();
0081     msg.update(plainText);
0082     msg.end();
0083     // I think it is reasonable to wait for 1 second for this
0084     msg.waitForFinished(1000);
0085 
0086     // check to see if it worked
0087     if (!msg.success()) {
0088         std::cout << "Error encrypting: " << msg.errorCode() << std::endl;
0089         return 1;
0090     }
0091 
0092     // get the result
0093     QCA::SecureArray cipherText = msg.read();
0094     QCA::Base64      enc;
0095     std::cout << plainText.data() << " encrypts to (in base 64): ";
0096     std::cout << qPrintable(enc.arrayToString(cipherText)) << std::endl;
0097 
0098     // Show we can decrypt it with the private key
0099     if (!privKey.canDecrypt()) {
0100         std::cout << "Private key cannot be used to decrypt" << std::endl;
0101         return 1;
0102     }
0103     QCA::SecureArray plainTextResult;
0104     if (0 == privKey.decrypt(cipherText, &plainTextResult, QCA::EME_PKCS1_OAEP)) {
0105         std::cout << "Decryption process failed" << std::endl;
0106         return 1;
0107     }
0108 
0109     std::cout << qPrintable(enc.arrayToString(cipherText));
0110     std::cout << " (in base 64) decrypts to: ";
0111     std::cout << plainTextResult.data() << std::endl;
0112 
0113     return 0;
0114 }