NeoMutt  2025-12-11-769-g906513
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
find_keys()

Find the keyids of the recipients of a message. More...

+ Collaboration diagram for find_keys():

Functions

char * pgp_gpgme_find_keys (const struct AddressList *addrlist, bool oppenc_mode)
 Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.
 
char * smime_gpgme_find_keys (const struct AddressList *addrlist, bool oppenc_mode)
 Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.
 
char * pgp_class_find_keys (const struct AddressList *addrlist, bool oppenc_mode)
 Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.
 
char * smime_class_find_keys (const struct AddressList *al, bool oppenc_mode)
 Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.
 

Detailed Description

Find the keyids of the recipients of a message.

Parameters
addrlistAddress List
oppenc_modeIf true, use opportunistic encryption
Return values
ptrSpace-separated string of keys
NULLAt least one of the keys can't be found

If oppenc_mode is true, only keys that can be determined without prompting will be used.

Function Documentation

◆ pgp_gpgme_find_keys()

char * pgp_gpgme_find_keys ( const struct AddressList * addrlist,
bool oppenc_mode )

Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.

Definition at line 3675 of file crypt_gpgme.c.

3676{
3677 return find_keys(addrlist, APPLICATION_PGP, oppenc_mode);
3678}
static char * find_keys(const struct AddressList *addrlist, unsigned int app, bool oppenc_mode)
Find keys of the recipients of the message.
#define APPLICATION_PGP
Use PGP to encrypt/sign.
Definition lib.h:99
+ Here is the call graph for this function:

◆ smime_gpgme_find_keys()

char * smime_gpgme_find_keys ( const struct AddressList * addrlist,
bool oppenc_mode )

Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.

Definition at line 3683 of file crypt_gpgme.c.

3684{
3685 return find_keys(addrlist, APPLICATION_SMIME, oppenc_mode);
3686}
#define APPLICATION_SMIME
Use SMIME to encrypt/sign.
Definition lib.h:100
+ Here is the call graph for this function:

◆ pgp_class_find_keys()

char * pgp_class_find_keys ( const struct AddressList * addrlist,
bool oppenc_mode )

Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.

Definition at line 1463 of file pgp.c.

1464{
1465 struct ListHead crypt_hook_list = STAILQ_HEAD_INITIALIZER(crypt_hook_list);
1466 struct ListNode *crypt_hook = NULL;
1467 const char *keyid = NULL;
1468 char *keylist = NULL;
1469 size_t keylist_size = 0;
1470 size_t keylist_used = 0;
1471 struct Address *p = NULL;
1472 struct PgpKeyInfo *k_info = NULL;
1473 const char *fqdn = mutt_fqdn(true, NeoMutt->sub);
1474 char buf[1024] = { 0 };
1475 bool key_selected;
1476 struct AddressList hookal = TAILQ_HEAD_INITIALIZER(hookal);
1477
1478 struct Address *a = NULL;
1479 const bool c_crypt_confirm_hook = cs_subset_bool(NeoMutt->sub, "crypt_confirm_hook");
1480 /* Iterate through each recipient address to find an encryption key */
1481 TAILQ_FOREACH(a, addrlist, entries)
1482 {
1483 key_selected = false;
1484 /* Check for crypt-hook overrides for this recipient */
1485 mutt_crypt_hook(&crypt_hook_list, a);
1486 crypt_hook = STAILQ_FIRST(&crypt_hook_list);
1487 do
1488 {
1489 p = a;
1490 k_info = NULL;
1491
1492 /* If a crypt-hook provides a key ID, confirm with the user unless
1493 * in opportunistic encryption mode */
1494 if (crypt_hook)
1495 {
1496 keyid = crypt_hook->data;
1497 enum QuadOption ans = MUTT_YES;
1498 if (!oppenc_mode && c_crypt_confirm_hook && isatty(STDIN_FILENO))
1499 {
1500 snprintf(buf, sizeof(buf), _("Use keyID = \"%s\" for %s?"), keyid,
1501 buf_string(p->mailbox));
1502 ans = query_yesorno_help(buf, MUTT_YES, NeoMutt->sub, "crypt_confirm_hook");
1503 }
1504 if (ans == MUTT_YES)
1505 {
1506 if (crypt_is_numerical_keyid(keyid))
1507 {
1508 if (mutt_strn_equal(keyid, "0x", 2))
1509 keyid += 2;
1510 goto bypass_selection; /* you don't see this. */
1511 }
1512
1513 /* check for e-mail address */
1514 mutt_addrlist_clear(&hookal);
1515 if (strchr(keyid, '@') && (mutt_addrlist_parse(&hookal, keyid) != 0))
1516 {
1517 mutt_addrlist_qualify(&hookal, fqdn);
1518 p = TAILQ_FIRST(&hookal);
1519 }
1520 else if (!oppenc_mode)
1521 {
1523 }
1524 }
1525 else if (ans == MUTT_NO)
1526 {
1527 if (key_selected || STAILQ_NEXT(crypt_hook, entries))
1528 {
1529 crypt_hook = STAILQ_NEXT(crypt_hook, entries);
1530 continue;
1531 }
1532 }
1533 else if (ans == MUTT_ABORT)
1534 {
1535 FREE(&keylist);
1536 mutt_addrlist_clear(&hookal);
1537 mutt_list_free(&crypt_hook_list);
1538 return NULL;
1539 }
1540 }
1541
1542 /* If no key found yet, try looking up by address in the keyring */
1543 if (!k_info)
1544 {
1546 k_info = pgp_getkeybyaddr(p, KEYFLAG_CANENCRYPT, PGP_PUBRING, oppenc_mode);
1547 }
1548
1549 /* Last resort: prompt the user to enter a key ID interactively */
1550 if (!k_info && !oppenc_mode && isatty(STDIN_FILENO))
1551 {
1552 snprintf(buf, sizeof(buf), _("Enter keyID for %s: "), buf_string(p->mailbox));
1554 }
1555
1556 if (!k_info)
1557 {
1558 FREE(&keylist);
1559 mutt_addrlist_clear(&hookal);
1560 mutt_list_free(&crypt_hook_list);
1561 return NULL;
1562 }
1563
1564 keyid = pgp_fpr_or_lkeyid(k_info);
1565
1566 bypass_selection:
1567 /* Append the selected key ID to the space-separated keylist string */
1568 keylist_size += mutt_str_len(keyid) + 4;
1569 MUTT_MEM_REALLOC(&keylist, keylist_size, char);
1570 sprintf(keylist + keylist_used, "%s0x%s", keylist_used ? " " : "", keyid);
1571 keylist_used = mutt_str_len(keylist);
1572
1573 key_selected = true;
1574
1575 pgp_key_free(&k_info);
1576 mutt_addrlist_clear(&hookal);
1577
1578 if (crypt_hook)
1579 crypt_hook = STAILQ_NEXT(crypt_hook, entries);
1580
1581 } while (crypt_hook);
1582
1583 mutt_list_free(&crypt_hook_list);
1584 }
1585 return keylist;
1586}
void mutt_addrlist_qualify(struct AddressList *al, const char *host)
Expand local names in an Address list using a hostname.
Definition address.c:685
void mutt_addrlist_clear(struct AddressList *al)
Unlink and free all Address in an AddressList.
Definition address.c:1469
int mutt_addrlist_parse(struct AddressList *al, const char *s)
Parse a list of email addresses.
Definition address.c:480
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition buffer.h:96
bool cs_subset_bool(const struct ConfigSubset *sub, const char *name)
Get a boolean config item by name.
Definition helpers.c:47
bool crypt_is_numerical_keyid(const char *s)
Is this a numerical keyid.
Definition crypt.c:1484
void pgp_class_invoke_getkeys(struct Address *addr)
Run a command to download a PGP key - Implements CryptModuleSpecs::pgp_invoke_getkeys() -.
Definition pgpinvoke.c:315
void mutt_crypt_hook(struct ListHead *list, struct Address *addr)
Find crypto hooks for an Address.
Definition exec.c:319
void mutt_list_free(struct ListHead *h)
Free a List AND its strings.
Definition list.c:123
#define FREE(x)
Free memory and set the pointer to NULL.
Definition memory.h:68
#define MUTT_MEM_REALLOC(pptr, n, type)
Definition memory.h:55
#define _(a)
Definition message.h:28
bool mutt_strn_equal(const char *a, const char *b, size_t num)
Check for equality of two strings (to a maximum), safely.
Definition string.c:429
size_t mutt_str_len(const char *a)
Calculate the length of a string, safely.
Definition string.c:503
#define KEYFLAG_CANENCRYPT
Key is suitable for encryption.
Definition lib.h:137
char * pgp_fpr_or_lkeyid(struct PgpKeyInfo *k)
Get the fingerprint or long keyid.
Definition pgp.c:231
struct PgpKeyInfo * pgp_ask_for_key(char *tag, const char *whatfor, KeyFlags abilities, enum PgpRing keyring)
Ask the user for a PGP key.
Definition pgpkey.c:196
struct PgpKeyInfo * pgp_getkeybyaddr(struct Address *a, KeyFlags abilities, enum PgpRing keyring, bool oppenc_mode)
Find a PGP key by address.
Definition pgpkey.c:373
struct PgpKeyInfo * pgp_getkeybystr(const char *cp, KeyFlags abilities, enum PgpRing keyring)
Find a PGP key by string.
Definition pgpkey.c:512
@ PGP_PUBRING
Public keys.
Definition pgpkey.h:39
void pgp_key_free(struct PgpKeyInfo **kpp)
Free a PGP key info.
Definition pgplib.c:201
QuadOption
Possible values for a quad-option.
Definition quad.h:36
@ MUTT_ABORT
User aborted the question (with Ctrl-G)
Definition quad.h:37
@ MUTT_NO
User answered 'No', or assume 'No'.
Definition quad.h:38
@ MUTT_YES
User answered 'Yes', or assume 'Yes'.
Definition quad.h:39
enum QuadOption query_yesorno_help(const char *prompt, enum QuadOption def, struct ConfigSubset *sub, const char *name)
Ask the user a Yes/No question offering help.
Definition question.c:357
#define TAILQ_FOREACH(var, head, field)
Definition queue.h:782
#define STAILQ_HEAD_INITIALIZER(head)
Definition queue.h:324
#define STAILQ_FIRST(head)
Definition queue.h:388
#define TAILQ_FIRST(head)
Definition queue.h:780
#define TAILQ_HEAD_INITIALIZER(head)
Definition queue.h:694
#define STAILQ_NEXT(elm, field)
Definition queue.h:439
const char * mutt_fqdn(bool may_hide_host, const struct ConfigSubset *sub)
Get the Fully-Qualified Domain Name.
Definition sendlib.c:713
An email address.
Definition address.h:35
struct Buffer * mailbox
Mailbox and host address.
Definition address.h:37
A List node for strings.
Definition list.h:37
char * data
String.
Definition list.h:38
Container for Accounts, Notifications.
Definition neomutt.h:41
struct ConfigSubset * sub
Inherited config items.
Definition neomutt.h:49
Information about a PGP key.
Definition pgplib.h:49
+ Here is the call graph for this function:

◆ smime_class_find_keys()

char * smime_class_find_keys ( const struct AddressList * al,
bool oppenc_mode )

Find the keyids of the recipients of a message - Implements CryptModuleSpecs::find_keys() -.

Definition at line 650 of file smime.c.

651{
652 struct SmimeKey *key = NULL;
653 char *keyid = NULL, *keylist = NULL;
654 size_t keylist_size = 0;
655 size_t keylist_used = 0;
656
657 struct Address *a = NULL;
658 TAILQ_FOREACH(a, al, entries)
659 {
660 key = smime_get_key_by_addr(buf_string(a->mailbox), KEYFLAG_CANENCRYPT, true, oppenc_mode);
661 if (!key && !oppenc_mode && isatty(STDIN_FILENO))
662 {
663 struct Buffer *prompt = buf_pool_get();
664 buf_printf(prompt, _("Enter keyID for %s: "), buf_string(a->mailbox));
665 key = smime_ask_for_key(buf_string(prompt), KEYFLAG_CANENCRYPT, true);
666 buf_pool_release(&prompt);
667 }
668 if (!key)
669 {
670 if (!oppenc_mode)
671 mutt_message(_("No (valid) certificate found for %s"), buf_string(a->mailbox));
672 FREE(&keylist);
673 return NULL;
674 }
675
676 keyid = key->hash;
677 keylist_size += mutt_str_len(keyid) + 2;
678 MUTT_MEM_REALLOC(&keylist, keylist_size, char);
679 sprintf(keylist + keylist_used, "%s%s", keylist_used ? " " : "", keyid);
680 keylist_used = mutt_str_len(keylist);
681
682 smime_key_free(&key);
683 }
684 return keylist;
685}
int buf_printf(struct Buffer *buf, const char *fmt,...)
Format a string overwriting a Buffer.
Definition buffer.c:161
#define mutt_message(...)
Definition logging2.h:93
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
Definition pool.c:91
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
Definition pool.c:111
static struct SmimeKey * smime_get_key_by_addr(const char *mailbox, KeyFlags abilities, bool only_public_key, bool oppenc_mode)
Find an SIME key by address.
Definition smime.c:407
static void smime_key_free(struct SmimeKey **keylist)
Free a list of SMIME keys.
Definition smime.c:91
static struct SmimeKey * smime_ask_for_key(const char *prompt, KeyFlags abilities, bool only_public_key)
Ask the user to select a key.
Definition smime.c:534
String manipulation buffer.
Definition buffer.h:36
An SIME key.
Definition smime.h:42
char * hash
Key hash.
Definition smime.h:44
+ Here is the call graph for this function: