Re: [PATCH] gpg-interface: Look up signing keys with only email address

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Marco Sirabella <marco@xxxxxxxxxxxxx> writes:

> Sometimes gpg signing key UIDs include a comment between the name and
> parenthesis in the form of:
>
>   John Smith (example) jsmith@xxxxxxxxxxx
>
> There's no way for git to find signing keys associated with just these
> UIDs, so look up a partial match on the email only.

This codepath is about finding the key for the current user who is
in control of what committer is found by the git_committer_info()
call, no?  It is not like we are finding the key that corresponds to
a random name and e-mail address on "From:" line, right?

Assuming that it is the case, it is unclear where the claim "There's
no way for git to find" comes from.  It isn't a statement that is so
obviously true, at least to me, without some explanation.

> -	return git_committer_info(IDENT_STRICT | IDENT_NO_DATE);
> +	return git_committer_info(IDENT_NO_NAME | IDENT_STRICT | IDENT_NO_DATE);

With this change, those who use more than one identities associated
with the same e-mail address, but different human-readable names,
will get their workflow broken, won't they?

They may be using "Will <a@xxxxxxxx>" when they work on a project,
while using "Bill <a@xxxxxxxx>" for another project, configured via
their .git/config in the repositories used for these two projects.
And each name+address combination they have may map to a distinct
GPG key, used to sign for each project.  With this change, since the
call no longer returns the name they were using to differentiate the
two keys, one of the projects they manage would lose out, no?

In general, there may be more than one signing keys that correspond
to a given human user, and the user may choose a specific key based
on what project the signatures are made for, and in such a case,
with or without the proposed change, the fallback code based on the
git_committer_info() is an unreliable way to specify the key to be
used, especially for an action as important as cryptographic
signing.  I have always assumed that people use something like this
in practice:

    $ git config user.signingkey = 955980DA!

that can be used to more reliably identify a specific key in their
keyring, among the ones associated with similar identifiers meant
for human consumption such as name/e-mail pairs.

So, I am not convinced that the patch is trying to address the right
problem, and I have a mild suspicion that the proposed solution to
tweak NO_NAME may simply be robbing Peter to pay Paul.  If you have
named your GPG key in your keyring with a name-email pair that is
different from how you configured your committer identity, the right
solution for such a case already exists in the form of user.signingkey
configuration variable already.

Thanks.




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux