mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-08 12:44:23 +01:00
gpg: Improve UID selction of --quick-sign-key.
* g10/keyedit.c (keyedit_quick_sign): Improve UID selection and print error for non-found userids. -- GnuPG-bug-id: 2315
This commit is contained in:
parent
085b19fc9a
commit
d02de6c0a4
@ -973,9 +973,12 @@ Directly sign a key from the passphrase without any further user
|
|||||||
interaction. The @code{fpr} must be the verified primary fingerprint
|
interaction. The @code{fpr} must be the verified primary fingerprint
|
||||||
of a key in the local keyring. If no @code{names} are given, all
|
of a key in the local keyring. If no @code{names} are given, all
|
||||||
useful user ids are signed; with given [@code{names}] only useful user
|
useful user ids are signed; with given [@code{names}] only useful user
|
||||||
ids matching one of theses names are signed. The command
|
ids matching one of theses names are signed. By default, or if a name
|
||||||
@option{--quick-lsign-key} marks the signatures as non-exportable. If
|
is prefixed with a '*', a case insensitive substring match is used.
|
||||||
such a non-exportable signature already exists the
|
If a name is prefixed with a '=' a case sensitive exact match is done.
|
||||||
|
|
||||||
|
The command @option{--quick-lsign-key} marks the signatures as
|
||||||
|
non-exportable. If such a non-exportable signature already exists the
|
||||||
@option{--quick-sign-key} turns it into a exportable signature.
|
@option{--quick-sign-key} turns it into a exportable signature.
|
||||||
|
|
||||||
This command uses reasonable defaults and thus does not provide the
|
This command uses reasonable defaults and thus does not provide the
|
||||||
|
@ -2927,12 +2927,11 @@ keyedit_quick_adduid (ctrl_t ctrl, const char *username, const char *newuid)
|
|||||||
|
|
||||||
|
|
||||||
/* Unattended key signing function. If the key specifified by FPR is
|
/* Unattended key signing function. If the key specifified by FPR is
|
||||||
availabale and FPR is the primary fingerprint all user ids of the
|
available and FPR is the primary fingerprint all user ids of the
|
||||||
user ids of the key are signed using the default signing key. If
|
key are signed using the default signing key. If UIDS is an empty
|
||||||
UIDS is an empty list all usable UIDs are signed, if it is not
|
list all usable UIDs are signed, if it is not empty, only those
|
||||||
empty, only those user ids matching one of the entries of the loist
|
user ids matching one of the entries of the list are signed. With
|
||||||
are signed. With LOCAL being true kthe signatures are marked as
|
LOCAL being true the signatures are marked as non-exportable. */
|
||||||
non-exportable. */
|
|
||||||
void
|
void
|
||||||
keyedit_quick_sign (ctrl_t ctrl, const char *fpr, strlist_t uids,
|
keyedit_quick_sign (ctrl_t ctrl, const char *fpr, strlist_t uids,
|
||||||
strlist_t locusr, int local)
|
strlist_t locusr, int local)
|
||||||
@ -3025,27 +3024,72 @@ keyedit_quick_sign (ctrl_t ctrl, const char *fpr, strlist_t uids,
|
|||||||
menu_select_uid (keyblock, 0); /* Better clear the flags first. */
|
menu_select_uid (keyblock, 0); /* Better clear the flags first. */
|
||||||
for (sl=uids; sl; sl = sl->next)
|
for (sl=uids; sl; sl = sl->next)
|
||||||
{
|
{
|
||||||
|
const char *name = sl->d;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
sl->flags &= ~(1|2); /* Clear flags used for error reporting. */
|
||||||
|
|
||||||
for (node = keyblock; node; node = node->next)
|
for (node = keyblock; node; node = node->next)
|
||||||
{
|
{
|
||||||
if (node->pkt->pkttype == PKT_USER_ID)
|
if (node->pkt->pkttype == PKT_USER_ID)
|
||||||
{
|
{
|
||||||
PKT_user_id *uid = node->pkt->pkt.user_id;
|
PKT_user_id *uid = node->pkt->pkt.user_id;
|
||||||
|
|
||||||
if (!uid->attrib_data
|
if (uid->attrib_data)
|
||||||
&& ascii_memistr (uid->name, uid->len, sl->d))
|
;
|
||||||
{
|
else if (*name == '='
|
||||||
|
&& strlen (name+1) == uid->len
|
||||||
|
&& !memcmp (uid->name, name + 1, uid->len))
|
||||||
|
{ /* Exact match - we don't do a check for ambiguity
|
||||||
|
* in this case. */
|
||||||
node->flag |= NODFLG_SELUID;
|
node->flag |= NODFLG_SELUID;
|
||||||
|
if (any != -1)
|
||||||
|
{
|
||||||
|
sl->flags |= 1; /* Report as found. */
|
||||||
any = 1;
|
any = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (ascii_memistr (uid->name, uid->len,
|
||||||
|
*name == '*'? name+1:name))
|
||||||
|
{
|
||||||
|
node->flag |= NODFLG_SELUID;
|
||||||
|
if (any != -1)
|
||||||
|
{
|
||||||
|
sl->flags |= 1; /* Report as found. */
|
||||||
|
any = 1;
|
||||||
|
}
|
||||||
|
count++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (uids && !any)
|
if (count > 1)
|
||||||
|
{
|
||||||
|
any = -1; /* Force failure at end. */
|
||||||
|
sl->flags |= 2; /* Report as ambiguous. */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check whether all given user ids were found. */
|
||||||
|
for (sl=uids; sl; sl = sl->next)
|
||||||
|
if (!(sl->flags & 1))
|
||||||
|
any = -1; /* That user id was not found. */
|
||||||
|
|
||||||
|
/* Print an error if there was a problem with the user ids. */
|
||||||
|
if (uids && any < 1)
|
||||||
{
|
{
|
||||||
if (!opt.verbose)
|
if (!opt.verbose)
|
||||||
show_key_with_all_names (ctrl, es_stdout, keyblock, 0, 0, 0, 0, 0, 1);
|
show_key_with_all_names (ctrl, es_stdout, keyblock, 0, 0, 0, 0, 0, 1);
|
||||||
es_fflush (es_stdout);
|
es_fflush (es_stdout);
|
||||||
|
for (sl=uids; sl; sl = sl->next)
|
||||||
|
{
|
||||||
|
if ((sl->flags & 2))
|
||||||
|
log_info (_("Invalid user ID '%s': %s\n"),
|
||||||
|
sl->d, gpg_strerror (GPG_ERR_AMBIGUOUS_NAME));
|
||||||
|
else if (!(sl->flags & 1))
|
||||||
|
log_info (_("Invalid user ID '%s': %s\n"),
|
||||||
|
sl->d, gpg_strerror (GPG_ERR_NOT_FOUND));
|
||||||
|
}
|
||||||
log_error ("%s %s", _("No matching user IDs."), _("Nothing to sign.\n"));
|
log_error ("%s %s", _("No matching user IDs."), _("Nothing to sign.\n"));
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user