Recovering lost emails. Or maybe you get duplicates. Sorry about that if so, Linus ---------- Forwarded message ---------- From: Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> Date: Tue, Sep 13, 2011 at 10:48 AM Subject: Re: [Survey] Signed push To: Junio C Hamano <gitster@xxxxxxxxx> Cc: git@xxxxxxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx On Tue, Sep 13, 2011 at 9:45 AM, Junio C Hamano <gitster@xxxxxxxxx> wrote: > > We have a tentative patch to add an extra line after the "URL branch" line > that is for your cut & paste that looks like: > > are available in the git repository at: > git://git.kernel.org/pub/flobar.git/ master > for you to fetch changes up to 5738c9c21e53356ab5020912116e7f82fd2d428f > > I often see you respond to a pull request on the kernel mailing list with > "I see nothing new; forgot to push?", and having this extra line may also > help communication. I think that would probably be a good idea, although I'd actually prefer you to be more verbose, and more human-friendly, and actually talk about the commit in a readable way. Get rid of the *horrible* BRANCH-NOT-VERIFIED message (that actually messes up pull requests if mirroring is a bit delayed and throws away more important information), and instead just have a blurb afterwards saying something human-readable like Top commit 1f51b001cccf: "Merge branches 'cns3xxx/fixes', 'omap/fixes' and 'davinci/fixes' into fixes" and at *that* point you might have a "UNVERIFIED" notice for people to check if they forgot to push. So I'd much prefer something like that over: > An alternative that I am considering is to let the requester say this > instead: > > are available in the git repository at: > git://git.kernel.org/pub/flobar.git/ 5738c9c21e53356ab5020912116e7f82fd2d428f > > without adding the extra line. The extra line in the pull request is cheap - it's not like we need to ration them. The above format, in contrast, requires that the person doing the *pull* have a recent enough git client, otherwise the merge commit message will be just horrible. And even if you do have a new git client that turns the commit into a branch name, that's ambigious. What if both 'master' and 'experimental' have the same top commit, because experimental ended up being tested and was percolated to master? Which branch name would you pick? And what if the branch was updated since, so *no* branch name matches - does that mean that you'd disallow the pull entirely? > 2. Signed pushes. > > You tag official releases and release candidates with your GPG key, and > everybody who works within the kernel ecosystem trusts the history behind > the commits pointed by them, but there is no easy way to verify that > commits and merges between the last tagged commit and the tip of your > branch(es) are indeed from you, or if an intruder piled fake ones on top > of your commits (until you try to push again and discover that the history > does not fast-forward, that is). > > We have been discussing an addition of "git push -s" to let people sign > their pushes (instead of having to sign every commit or add signed > tag). The implementation alternatives were being bikeshed but not of much > interest in this message, but the user experience would go like this: Also, if we're adding branch information, I'd say that a description of the branch is more important than a signature. Right now we lack even that. It would be lovely if people could annotate their branches with descriptions, so that when I pull a "for-linus" branch, if it has a description, the description of the branch makes it into the merge message. Our merge messages are often not very informative. I realize that cryptographic signature sound very important right now, but in the end, *real* trust comes from people, not from signatures. Realistically, I checked a few signatures this time around due to the k.org issues, but at the same thing, the thing that made me trust most of it was just looking at commits and the email messages. The unconscious and non-cryptographic "signature" of a person acting like you expect a person to act. Technical measures can be subverted, and I think we should also think about the social side. Every time somebody mentions a signature, I want to also mention "human readability", because I think that matters as much, if not more. So I'm not against signed pushes, but quite frankly, if you add some per-branch signature, I would argue against it unless that signature also comes with information that allows us to do a better job of human communication too. Like a branch description. Imagine, for example, than when you do a git push -s .. git would *require* you to actually write a message about what you are pushing. And when somebody pulls it, and creates a merge commit, that explanation would become part of the merge message. The "signature" part of the "-s" should be thought of as the *much* less interesting part - that's just a small detail that git can use to verify something, but it doesn't actually matter for the contents of the pull. Not like the actual human-readable message would. Now *that* would be lovely. No? Linus -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html