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:
parent
f50dde6269
commit
4275d5fa7a
@ -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);
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -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)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (status_mode)
|
||||||
|
{
|
||||||
unlock_trusttable ();
|
unlock_trusttable ();
|
||||||
return 0;
|
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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user