/** * This file is part of GpgFrontend. * * GpgFrontend is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Foobar is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Foobar. If not, see . * * The initial version of the source code is inherited from gpg4usb-team. * Their source code version also complies with GNU General Public License. * * The source code version of this software was modified and released * by Saturneric starting on May 12, 2021. * */ #include "advance/UnknownSignersChecker.h" UnknownSignersChecker::UnknownSignersChecker(GpgFrontend::GpgContext *ctx, gpgme_verify_result_t result) : appPath(qApp->applicationDirPath()), settings(RESOURCE_DIR(appPath) + "/conf/gpgfrontend.ini"), mCtx(ctx), mResult(result) {} void UnknownSignersChecker::start() { auto sign = mResult->signatures; bool canContinue = true; while (sign && canContinue) { switch (gpg_err_code(sign->status)) { case GPG_ERR_BAD_SIGNATURE: break; case GPG_ERR_NO_ERROR: if (!(sign->status & GPGME_SIGSUM_KEY_MISSING)) check_signer(sign); break; case GPG_ERR_NO_PUBKEY: case GPG_ERR_CERT_REVOKED: case GPG_ERR_SIG_EXPIRED: case GPG_ERR_KEY_EXPIRED: check_signer(sign); break; case GPG_ERR_GENERAL: canContinue = false; break; default: break; } sign = sign->next; } if (!unknownFprs.isEmpty()) { PubkeyGetter pubkeyGetter(mCtx, unknownFprs); pubkeyGetter.start(); if (!pubkeyGetter.result()) { } } } void UnknownSignersChecker::check_signer(gpgme_signature_t sign) { auto key = mCtx->getKeyRefByFpr(sign->fpr); if (!key.good) { qDebug() << "Find Unknown FingerPrint " << sign->fpr; unknownFprs.append(sign->fpr); } }