From d7e953b25a28a846b0aafa7003f33432b7e107f5 Mon Sep 17 00:00:00 2001 From: Saturneric Date: Mon, 29 Nov 2021 10:57:43 +0800 Subject: Fix Known Bugs. 1. Import Keys. 2. Import Keys From Server. 3. UID Management. --- src/gpg/function/GpgKeyOpera.cpp | 25 +++++++++++++++++-------- 1 file changed, 17 insertions(+), 8 deletions(-) (limited to 'src/gpg/function/GpgKeyOpera.cpp') diff --git a/src/gpg/function/GpgKeyOpera.cpp b/src/gpg/function/GpgKeyOpera.cpp index 0a222c3f..c7775d10 100644 --- a/src/gpg/function/GpgKeyOpera.cpp +++ b/src/gpg/function/GpgKeyOpera.cpp @@ -61,23 +61,28 @@ void GpgFrontend::GpgKeyOpera::DeleteKeys( * @param expires date and time * @return if successful */ -void GpgFrontend::GpgKeyOpera::SetExpire( - const GpgKey& key, const SubkeyId& subkey_id, +GpgFrontend::GpgError GpgFrontend::GpgKeyOpera::SetExpire( + const GpgKey& key, const SubkeyId& subkey_fpr, std::unique_ptr& expires) { unsigned long expires_time = 0; if (expires != nullptr) { using namespace boost::posix_time; - expires_time = to_time_t(ptime(*expires)); + using namespace std::chrono; + expires_time = to_time_t(ptime(*expires)) - + system_clock::to_time_t(system_clock::now()); } + LOG(INFO) << "GpgFrontend::GpgKeyOpera::SetExpire" << key.id() << subkey_fpr + << expires_time; + GpgError err; - if (subkey_id.empty()) + if (subkey_fpr.empty()) err = gpgme_op_setexpire(ctx, gpgme_key_t(key), expires_time, nullptr, 0); else err = gpgme_op_setexpire(ctx, gpgme_key_t(key), expires_time, - subkey_id.c_str(), 0); + subkey_fpr.c_str(), 0); - assert(gpg_err_code(err) != GPG_ERR_NO_ERROR); + return err; } /** @@ -124,7 +129,9 @@ GpgFrontend::GpgError GpgFrontend::GpgKeyOpera::GenerateKey( unsigned long expires = 0; { using namespace boost::posix_time; - expires = to_time_t(ptime(params->getExpired())); + using namespace std::chrono; + expires = to_time_t(ptime(params->getExpired())) - + system_clock::to_time_t(system_clock::now()); } unsigned int flags = 0; @@ -158,7 +165,9 @@ GpgFrontend::GpgError GpgFrontend::GpgKeyOpera::GenerateSubkey( unsigned long expires = 0; { using namespace boost::posix_time; - expires = to_time_t(ptime(params->getExpired())); + using namespace std::chrono; + expires = to_time_t(ptime(params->getExpired())) - + system_clock::to_time_t(system_clock::now()); } unsigned int flags = 0; -- cgit v1.2.3