1
0
mirror of git://git.gnupg.org/gnupg.git synced 2024-12-22 10:19:57 +01:00

agent: Add option --status to the LISTRUSTED command.

* agent/trustlist.c (istrusted_internal): Add arg listmode and print
new status line in this mode.  Adjust callers.
(agent_listtrusted): Add new args ctrl and status_mode.  Get all
trusted keys and then call is_trusted_internal for all of them.

* agent/command.c (cmd_listtrusted): Add new option --status.
--

This allows in a non-restricted connection to list all trusted keys in
one go.
This commit is contained in:
Werner Koch 2024-10-01 18:07:32 +02:00
parent f50dde6269
commit 4275d5fa7a
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B
3 changed files with 60 additions and 16 deletions

View File

@ -637,7 +637,8 @@ gpg_error_t agent_write_shadow_key (ctrl_t ctrl, const unsigned char *grip,
/*-- trustlist.c --*/ /*-- trustlist.c --*/
void initialize_module_trustlist (void); void initialize_module_trustlist (void);
gpg_error_t agent_istrusted (ctrl_t ctrl, const char *fpr, int *r_disabled); gpg_error_t agent_istrusted (ctrl_t ctrl, const char *fpr, int *r_disabled);
gpg_error_t agent_listtrusted (void *assuan_context); gpg_error_t agent_listtrusted (ctrl_t ctrl, void *assuan_context,
int status_mode);
gpg_error_t agent_marktrusted (ctrl_t ctrl, const char *name, gpg_error_t agent_marktrusted (ctrl_t ctrl, const char *name,
const char *fpr, int flag); const char *fpr, int flag);
void agent_reload_trustlist (void); void agent_reload_trustlist (void);

View File

@ -569,22 +569,24 @@ cmd_istrusted (assuan_context_t ctx, char *line)
static const char hlp_listtrusted[] = static const char hlp_listtrusted[] =
"LISTTRUSTED\n" "LISTTRUSTED [--status]\n"
"\n" "\n"
"List all entries from the trustlist."; "List all entries from the trustlist. With --status the\n"
"keys are listed using status line similar to ISTRUSTED";
static gpg_error_t static gpg_error_t
cmd_listtrusted (assuan_context_t ctx, char *line) cmd_listtrusted (assuan_context_t ctx, char *line)
{ {
ctrl_t ctrl = assuan_get_pointer (ctx); ctrl_t ctrl = assuan_get_pointer (ctx);
int rc; gpg_error_t err;
int opt_status;
(void)line; opt_status = has_option (line, "--status");
if (ctrl->restricted) if (ctrl->restricted)
return leave_cmd (ctx, gpg_error (GPG_ERR_FORBIDDEN)); return leave_cmd (ctx, gpg_error (GPG_ERR_FORBIDDEN));
rc = agent_listtrusted (ctx); err = agent_listtrusted (ctrl, ctx, opt_status);
return leave_cmd (ctx, rc); return leave_cmd (ctx, err);
} }

View File

@ -430,10 +430,13 @@ read_trustfiles (void)
/* Check whether the given fpr is in our trustdb. We expect FPR to be /* Check whether the given fpr is in our trustdb. We expect FPR to be
an all uppercase hexstring of 40 characters. If ALREADY_LOCKED is * an all uppercase hexstring of 40 characters. If ALREADY_LOCKED is
true the function assumes that the trusttable is already locked. */ * true the function assumes that the trusttable is already locked.
* If LISTMODE is set, a status line TRUSTLISTFPR is emitted first and
* disabled keys are not listed.
*/
static gpg_error_t static gpg_error_t
istrusted_internal (ctrl_t ctrl, const char *fpr, int *r_disabled, istrusted_internal (ctrl_t ctrl, const char *fpr, int listmode, int *r_disabled,
int already_locked) int already_locked)
{ {
gpg_error_t err = 0; gpg_error_t err = 0;
@ -472,6 +475,8 @@ istrusted_internal (ctrl_t ctrl, const char *fpr, int *r_disabled,
for (ti=trusttable, len = trusttablesize; len; ti++, len--) for (ti=trusttable, len = trusttablesize; len; ti++, len--)
if (!memcmp (ti->fpr, fprbin, 20)) if (!memcmp (ti->fpr, fprbin, 20))
{ {
if (listmode && ti->flags.disabled)
continue;
if (ti->flags.disabled && r_disabled) if (ti->flags.disabled && r_disabled)
*r_disabled = 1; *r_disabled = 1;
@ -485,7 +490,13 @@ istrusted_internal (ctrl_t ctrl, const char *fpr, int *r_disabled,
unlock_trusttable (); unlock_trusttable ();
locked = 0; locked = 0;
err = 0; err = 0;
if (ti->flags.relax) if (listmode)
{
char hexfpr[2*20+1];
bin2hex (ti->fpr, 20, hexfpr);
err = agent_write_status (ctrl,"TRUSTLISTFPR", hexfpr,NULL);
}
if (!err && ti->flags.relax)
err = agent_write_status (ctrl,"TRUSTLISTFLAG", "relax",NULL); err = agent_write_status (ctrl,"TRUSTLISTFLAG", "relax",NULL);
if (!err && ti->flags.cm) if (!err && ti->flags.cm)
err = agent_write_status (ctrl,"TRUSTLISTFLAG", "cm", NULL); err = agent_write_status (ctrl,"TRUSTLISTFLAG", "cm", NULL);
@ -514,20 +525,24 @@ istrusted_internal (ctrl_t ctrl, const char *fpr, int *r_disabled,
gpg_error_t gpg_error_t
agent_istrusted (ctrl_t ctrl, const char *fpr, int *r_disabled) agent_istrusted (ctrl_t ctrl, const char *fpr, int *r_disabled)
{ {
return istrusted_internal (ctrl, fpr, r_disabled, 0); return istrusted_internal (ctrl, fpr, 0, r_disabled, 0);
} }
/* Write all trust entries to FP. */ /* Write all trust entries to FP. */
gpg_error_t gpg_error_t
agent_listtrusted (void *assuan_context) agent_listtrusted (ctrl_t ctrl, void *assuan_context, int status_mode)
{ {
trustitem_t *ti; trustitem_t *ti;
char key[51]; char key[51];
int table_locked;
gpg_error_t err; gpg_error_t err;
size_t len; size_t len;
strlist_t allhexgrips = NULL;
strlist_t sl;
lock_trusttable (); lock_trusttable ();
table_locked = 1;
if (!trusttable) if (!trusttable)
{ {
err = read_trustfiles (); err = read_trustfiles ();
@ -539,6 +554,7 @@ agent_listtrusted (void *assuan_context)
} }
} }
err = 0;
if (trusttable) if (trusttable)
{ {
for (ti=trusttable, len = trusttablesize; len; ti++, len--) for (ti=trusttable, len = trusttablesize; len; ti++, len--)
@ -546,6 +562,15 @@ agent_listtrusted (void *assuan_context)
if (ti->flags.disabled) if (ti->flags.disabled)
continue; continue;
bin2hex (ti->fpr, 20, key); bin2hex (ti->fpr, 20, key);
if (status_mode)
{
if (!add_to_strlist_try (&allhexgrips, key))
{
err = gpg_error_from_syserror ();
goto leave;
}
continue;
}
key[40] = ' '; key[40] = ' ';
key[41] = ((ti->flags.for_smime && ti->flags.for_pgp)? '*' key[41] = ((ti->flags.for_smime && ti->flags.for_pgp)? '*'
: ti->flags.for_smime? 'S': ti->flags.for_pgp? 'P':' '); : ti->flags.for_smime? 'S': ti->flags.for_pgp? 'P':' ');
@ -555,8 +580,24 @@ agent_listtrusted (void *assuan_context)
} }
} }
unlock_trusttable (); if (status_mode)
return 0; {
unlock_trusttable ();
table_locked = 0;
/* The back and forth converting of the fingerprint and all the
* locking and unlocking is somewhat clumsy but helps to re-use
* existing code. */
for (sl = allhexgrips; sl; sl = sl->next)
if ((err = istrusted_internal (ctrl, sl->d, 1, NULL, 0)))
goto leave;
}
leave:
if (table_locked)
unlock_trusttable ();
free_strlist (allhexgrips);
return err;
} }
@ -770,7 +811,7 @@ agent_marktrusted (ctrl_t ctrl, const char *name, const char *fpr, int flag)
sure that nobody else plays with our file and force a reread. */ sure that nobody else plays with our file and force a reread. */
lock_trusttable (); lock_trusttable ();
clear_trusttable (); clear_trusttable ();
if (!istrusted_internal (ctrl, fpr, &is_disabled, 1) || is_disabled) if (!istrusted_internal (ctrl, fpr, 0, &is_disabled, 1) || is_disabled)
{ {
unlock_trusttable (); unlock_trusttable ();
xfree (fprformatted); xfree (fprformatted);