verbose pgp failures

pull/13/head
bqv 3 years ago
parent a2124fea2e
commit 22fc7d188e
No known key found for this signature in database
GPG Key ID: 9E2FF3BDEBDFC910

@ -1043,7 +1043,8 @@ signal.hh:
/usr/include/signal/curve.h: /usr/include/signal/curve.h:
gcrypt.hh: gcrypt.hh:
util.hh: util.hh:
.pgp.o: pgp.cpp plugin.hh pgp.hh .pgp.o: pgp.cpp deps/fmt/include/fmt/core.h plugin.hh pgp.hh
deps/fmt/include/fmt/core.h:
plugin.hh: plugin.hh:
pgp.hh: pgp.hh:
.user.o: user.cpp plugin.hh account.hh omemo.hh \ .user.o: user.cpp plugin.hh account.hh omemo.hh \

@ -2,16 +2,53 @@
// License, version 2.0. If a copy of the MPL was not distributed with this // License, version 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/. // file, You can obtain one at http://mozilla.org/MPL/2.0/.
#include <stdlib.h> #include <cstdlib>
#include <stdint.h> #include <cstdint>
#include <string.h> #include <cstring>
#include <time.h> #include <ctime>
#include <string_view>
#include <numeric>
#include <fmt/core.h>
#include <gpgme.h> #include <gpgme.h>
#include <weechat/weechat-plugin.h> #include <weechat/weechat-plugin.h>
#include "plugin.hh" #include "plugin.hh"
#include "pgp.hh" #include "pgp.hh"
std::string format_key(struct t_pgp *pgp, std::string_view keyid)
{
gpgme_key_t key = nullptr;
gpgme_error_t err = gpgme_get_key(pgp->gpgme, keyid.data(), &key, false);
if (err) {
return fmt::format("{} (none)", keyid);
}
std::string result(keyid);
result += '{';
{
std::string keyids;
for (auto subkey = key->subkeys; subkey; subkey = subkey->next)
{
if (!keyids.empty()) keyids += ", ";
std::string keyid(subkey->keyid);
if (keyid.length() > 8) keyid = keyid.substr(keyid.length()-8, 8);
keyids += keyid;
}
result += keyids;
}
result += "}[";
{
std::string userids;
for (auto uid = key->uids; uid; uid = uid->next)
{
if (!userids.empty()) userids += ", ";
userids += fmt::format("{} ({})", uid->name, uid->email);
}
result += userids;
}
result += ']';
return result;
}
#define PGP_MESSAGE_HEADER "-----BEGIN PGP MESSAGE-----\r\n" #define PGP_MESSAGE_HEADER "-----BEGIN PGP MESSAGE-----\r\n"
#define PGP_MESSAGE_FOOTER "\r\n-----END PGP MESSAGE-----" #define PGP_MESSAGE_FOOTER "\r\n-----END PGP MESSAGE-----"
#define PGP_SIGNATURE_HEADER "-----BEGIN PGP SIGNATURE-----\r\n" #define PGP_SIGNATURE_HEADER "-----BEGIN PGP SIGNATURE-----\r\n"
@ -153,6 +190,7 @@ char *pgp__decrypt(struct t_gui_buffer *buffer, struct t_pgp *pgp, const char *c
buf = (uint8_t*)malloc(sizeof(char) * buf_len); buf = (uint8_t*)malloc(sizeof(char) * buf_len);
buf_len = snprintf((char *)buf, buf_len, PGP_MESSAGE_HEADER "%s" PGP_MESSAGE_FOOTER, ciphertext); buf_len = snprintf((char *)buf, buf_len, PGP_MESSAGE_HEADER "%s" PGP_MESSAGE_FOOTER, ciphertext);
std::string keyids;
gpgme_error_t err; gpgme_error_t err;
gpgme_data_t in, out; gpgme_data_t in, out;
@ -170,14 +208,22 @@ char *pgp__decrypt(struct t_gui_buffer *buffer, struct t_pgp *pgp, const char *c
/* Decrypt data. */ /* Decrypt data. */
err = gpgme_op_decrypt(pgp->gpgme, in, out); err = gpgme_op_decrypt(pgp->gpgme, in, out);
if (err) {
goto decrypt_finish;
}
if (gpgme_decrypt_result_t dec_result = gpgme_op_decrypt_result(pgp->gpgme); if (gpgme_decrypt_result_t dec_result = gpgme_op_decrypt_result(pgp->gpgme);
dec_result->unsupported_algorithm) dec_result)
{
for (auto recip = dec_result->recipients; recip; recip = recip->next)
{
if (!keyids.empty()) keyids += ", ";
keyids += format_key(pgp, recip->keyid);
}
if (dec_result->unsupported_algorithm)
{ {
goto decrypt_finish; goto decrypt_finish;
} }
}
if (err) {
goto decrypt_finish;
}
gpgme_data_seek(out, 0, SEEK_SET); gpgme_data_seek(out, 0, SEEK_SET);
char data[512 + 1]; char data[512 + 1];
while ((ret = gpgme_data_read(out, data, 512)) > 0) while ((ret = gpgme_data_read(out, data, 512)) > 0)
@ -191,8 +237,8 @@ char *pgp__decrypt(struct t_gui_buffer *buffer, struct t_pgp *pgp, const char *c
result = strndup(decrypted.data(), decrypted.size()); result = strndup(decrypted.data(), decrypted.size());
decrypt_finish: decrypt_finish:
if (err) { if (err) {
weechat_printf(buffer, "[PGP]\t%s - %s", weechat_printf(buffer, "[PGP]\t%s - %s (%s)",
gpgme_strsource(err), gpgme_strerror(err)); gpgme_strsource(err), gpgme_strerror(err), keyids.data());
} }
return result; return result;
} }

Loading…
Cancel
Save