git@vger.kernel.org mailing list mirror (one of many)
 help / color / mirror / code / Atom feed
From: Emily Shaffer <emilyshaffer@google.com>
To: "Ævar Arnfjörð Bjarmason" <avarab@gmail.com>
Cc: Junio C Hamano <gitster@pobox.com>,
	"brian m. carlson" <sandals@crustytoothpaste.net>,
	git@vger.kernel.org
Subject: Re: What's cooking in git.git (Jan 2021, #02; Fri, 8)
Date: Thu, 14 Jan 2021 15:52:42 -0800	[thread overview]
Message-ID: <YADZSsVqyGnArF0n@google.com> (raw)
In-Reply-To: <87k0si5k75.fsf@evledraar.gmail.com>

On Tue, Jan 12, 2021 at 03:00:30PM +0100, Ævar Arnfjörð Bjarmason wrote:
> 
> 
> On Mon, Jan 11 2021, Junio C Hamano wrote:
> 
> > "brian m. carlson" <sandals@crustytoothpaste.net> writes:
> >
> >> On 2021-01-09 at 23:20:25, Junio C Hamano wrote:
> >>> "brian m. carlson" <sandals@crustytoothpaste.net> writes:
> >>> 
> >>> > On 2021-01-09 at 21:28:58, Junio C Hamano wrote:
> >>> >> Ævar Arnfjörð Bjarmason <avarab@gmail.com> writes:
> >>> >> > FWIW there was since a re-roll on 2021-01-03, but the discussion is
> >>> >> > sort-of outstanding, so maybe that's intentional...
> >>> >> 
> >>> >> I had an impression that those 4 or 5 patches haven't gained
> >>> >> concensus that they are good as-is.
> >>> >
> >>> > There will be another reroll.  I'm hoping to get to it this weekend.
> >>> 
> >>> Thanks.
> >>
> >> Having read Ævar's latest comment, I've decided instead to drop this, so
> >> feel free to do so whenever it's convenient.
> >
> > That's kind of sad.
> 
> Agreed. I mean, I'm just one contributor with an opinion. I certainly
> don't mean my "meh" on a patch to be some sort of veto.
> 
> If you follow this list you'll see that if you're going to take anyone's
> opinion on whether a thing should make it into git as a matter of
> empirical data on patches I submit that aren't changed meaningfully,
> then, uh, maybe pick someone else :)
> 
> > I view that this is the kind of topic where perfect easily can
> > become an enemy of good, as there is by definition no perfection
> > available to us without breaking existing Git.
> >
> > I do not know about Ævar, but to me, my initial impression while
> > reading the discussion from sideline was that the goal was to
> > prevent a mechanical scan of a recent version of .mailmap from
> > learning that Joe used to use Jane as his/her name, and that was the
> > reason why I asked to be convinced why encoding for obfuscation was
> > insufficient.  In the above, I meant "mechanical scan" as something
> > like "a web search engine crawls and finds a .mailmap---a query for
> > Joe produces a line with some garbage on it that is not Jane." and a
> > casual attacker would stop there.
> >
> > But of course, a casual attacker who knows urlencode or whatever
> > obfuscation in use can read that "garbage" once he/she knows that
> > "garbage" is worth attacking (i.e. it is known to be associated to
> > Joe, the person the attacker is interested in).
> >
> > If your goal is to make it harder than just urlencode, even though
> > we all have to accept that scanning "git log --all" for all names
> > that appear in the history and hashing them all to see what name
> > hashes to the "garbage" in question, then @sha256:<hash> approach
> > does make sense as a stopping point.  Perhaps we need to sell this
> > with a clear definition of what kind of attackes we are protecting
> > the name data from:
> >
> >     The attacker is required to obtain sufficient amount of history
> >     in the project to uncover the obfuscation; a more casual
> >     attackers will fail to uncover, and we declare that it is better
> >     than nothing and it is good enough in practice.
> >
> > or something like that?  I am not sure if I drew the line at the
> > level you intended to draw in the above, if I think that it is good
> > enough in practice, or if I agree to a change that is better than
> > nothing but not good enough in practice, but having such a statement
> > would help to see where we agree or disagree.
> 
> My reading of the general thread & brian's reply at [1] is that the
> difference in the minds of the users who want the feature (who're not
> on-list, and we're getting brian's's summary of their views) is closer
> to:
> 
>     We want the X-Y problem of "hide this data" solved with solution "Y"
>     because git's current tooling to retrieve the data is currently
>     rather tedious & obscure.
> 
> So when I asked whether those users would feel the same if the tooling
> was less tedious and suggested that I might patch it to be so brian
> replied with "[yes,] we do rely on this being inconvenient".
> 
> I do have a 20-something series patch to the mailmap code in my local
> queue that in the light of this series's status I think I'll submit
> soon.
> 
> It doesn't have anything to do with adding a "spew out a materialized
> map" feature currently, nor do I really plan to do that any time soon. I
> do genuinely think it would be a good addition to git for reasons that
> have nothing to do with trying to make a point about this
> series. E.g. you'd be able to more easily validate/check/fsck a mailmap
> that way. Or e.g. use a git repository's .mailmap as a source to export
> to your MTA rules or whatever.
> 
> The external tools I referred to which consume the exported .mailmap
> data are something I worked on at a previous job, but I no longer have
> that immediate itch to scratch personally.
> 
> The "march of history" point was rather that if the difference between
> URI encoding and this solution is current tooling, it seems all but
> inevitable that we'll bridge that gap sooner than later in a way that
> makes that difference useless to some of the users that want this now.
> 
> And not even because some people don't like this feature in particular
> and wish to submit patches to make it less useful. But just because we
> continue implementing stuff that's been talked about for years & is
> being generally slowly worked towards. E.g. more client<->server
> cooperation for expensive queries over protocol v2, or a filter clone
> mode where you get only commit objects.
> 
> It even seems like something brian's series itself could benefit
> from. I.e. having the hashed values in the history is a performance hit
> in some cases. The patch caches the computation.
> 
> Another way to do it would be to just save a
> ".git/objects/info/mailmap.{hash-of-original-file}". Either on the fly
> or generated by "maintenance" or whatever. It would guarantee a 0%
> performance hit. At that point we'd already have the plumbing to
> materialize the file & would need to go out of our way to make it
> inaccessible in porcelain.

I've got quite a few sporadic thoughts about this series and this
discussion, so I'll braindump and hopefully it turns into something
useful.

Firstly: this design comes from a conversation amongst a pretty small (4
people? 6 people?) group at the virtual inclusion summit some months
ago. At that time, we discussed the ease of brute-force decoding the
one-way-hashed mailmap and decided that, as long as Git didn't ship a
tool to do this for you for free, it was better than the current
solution for avoiding deadnames (i.e. "sorry"). I'm disappointed to see
the larger list feel otherwise, but not terribly surprised, since the
list contains more people than the group who came up with the design.

Secondly: it seems like a restatement of the goals of this patch would
help guide a discussion of designs; I would be so pleased to see a
cleaner solution than any that's been proposed so far, because I agree
that this feature is not perfect. So please append what I have missed:

Axiom: The current Git solution for avoiding deadnaming is insufficient.
Axiom: We want to improve Git's solution for avoiding deadnaming.
(That is, I don't think either of these statements are or should be up
for discussion.)

Goal: Projects which are contributed to by trans individuals who
transition during their contribution period should provide a good,
supportive experience, which does not deadname the individual.
Goal: Git's performance should not suffer unduly from any change unless
necessary.
Goal: Project maintainers should have an understanding of the threat
model (e.g. automated tools scraping for names, malicious individuals
with time on their hands and experience with the project, etc)
Goal: Audit trails required by e.g. SOB lines should exist for the
project maintainer, if necessary
Goal: Mailmap, in general, should work better than it does now
Goal: An imperfect solution should not disallow a more perfect solution
later down the road
Bonus goal: For the sake of Git project contributors, it would be nice
to avoid a troll storm on list.

Thirdly: As is stated elsewhere, I think this topic is falling victim to
perfect vs. good. Git is gaining increasing notoriety in circles I can
see about the ultimately crappy experience for people who change their
names and don't want to hear the old names (and don't want to know the
old names). In my opinion, literally anything we could do to improve
this experience would be better than doing nothing. So I feel sad to see
the topic dropped because of pushback, especially when that pushback is
"I'd like to write a tool to reverse this thing, because <vague reasons>
- and I don't mean that tool maliciously so that should be OK."

Fourthly: The perfect solution, as has been mentioned, is to stop using
user.name/user.email in commits and start using some generic ID instead.
I think I mentioned this during the summit as well, but one meh idea -
which maybe someone else can be inspired by and come up with something
better - may be to just start wedging genericness into those fields
anyways. That is, generating commits with user.name like "abc123def" and
user.email like "<requires-git-v2-31-or-later@generic.submitter>". I
don't like the idea of carrying that technical debt around forever, but
the experience it provides on older Git versions isn't terrible,
especially if you pair it with a mailmap entry from "abc123def" to
"Emily Shaffer <emilyshaffer@google.com>", for example.

Food for thought.
 - Emily

> 
> 1. https://lore.kernel.org/git/X%2FtxB8b3%2FqqbwbmC@camp.crustytoothpaste.net/

  reply	other threads:[~2021-01-14 23:55 UTC|newest]

Thread overview: 34+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-01-08 19:22 What's cooking in git.git (Jan 2021, #02; Fri, 8) Junio C Hamano
2021-01-09 10:55 ` Ævar Arnfjörð Bjarmason
2021-01-09 21:28   ` Junio C Hamano
2021-01-09 22:05     ` brian m. carlson
2021-01-09 23:20       ` Junio C Hamano
2021-01-11  1:53         ` brian m. carlson
2021-01-11 19:04           ` Junio C Hamano
2021-01-12 14:00             ` Ævar Arnfjörð Bjarmason
2021-01-14 23:52               ` Emily Shaffer [this message]
2021-01-14 23:56                 ` Emily Shaffer
2021-01-15  7:22                   ` Junio C Hamano
2021-01-15  0:29                 ` brian m. carlson
2021-01-15  1:44                 ` Junio C Hamano
2021-01-16 16:23                 ` Ævar Arnfjörð Bjarmason
2021-01-17 17:15                   ` Jeff King
2021-01-17 20:22                     ` Ævar Arnfjörð Bjarmason
2021-01-10 19:00     ` Ævar Arnfjörð Bjarmason
2021-01-11  0:21       ` Junio C Hamano
2021-01-09 21:38 ` David Aguilar
2021-01-09 23:08   ` Junio C Hamano
2021-01-14 23:06 ` Emily Shaffer
2021-01-15  1:50   ` Junio C Hamano
2021-01-15  2:24     ` Taylor Blau
2021-01-15  2:44       ` Taylor Blau
2021-01-15  2:36   ` Derrick Stolee
2021-01-15  2:54     ` Derrick Stolee
2021-01-15  6:36     ` Junio C Hamano
2021-01-15  6:38       ` Junio C Hamano
2021-01-15 11:36         ` Derrick Stolee
2021-01-15 19:44           ` Junio C Hamano
2021-01-15 20:08             ` Emily Shaffer
2021-01-15 20:59               ` Junio C Hamano
2021-01-15 19:52 ` Jeff King
2021-01-15 21:40   ` Junio C Hamano

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: http://vger.kernel.org/majordomo-info.html

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=YADZSsVqyGnArF0n@google.com \
    --to=emilyshaffer@google.com \
    --cc=avarab@gmail.com \
    --cc=git@vger.kernel.org \
    --cc=gitster@pobox.com \
    --cc=sandals@crustytoothpaste.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://80x24.org/mirrors/git.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).