* Removing options from build
@ 2009-01-13 21:43 R. Tyler Ballance
2009-01-13 21:53 ` Thomas Rast
` (3 more replies)
0 siblings, 4 replies; 12+ messages in thread
From: R. Tyler Ballance @ 2009-01-13 21:43 UTC (permalink / raw)
To: git
[-- Attachment #1: Type: text/plain, Size: 672 bytes --]
One of our developers "discovered" the --force option on `git push` and
used it without taking the appropriate care and hosed one of the project
branches we have running around in our central repository.
Besides a vigorous flogging, we're looking at other ways to prevent this
sort of thing from happening again; the option we've settled on is to
remove the "--force" flag from our internal build of v1.6.1
I'm wondering if somebody could point me in the right direction to
remove "--force" (safely) from the builtin-push.c and removing the
"rebase" command (we've got no use for it, and would prefer it gone).
Cheers
--
-R. Tyler Ballance
Slide, Inc.
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 197 bytes --]
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: Removing options from build 2009-01-13 21:43 Removing options from build R. Tyler Ballance @ 2009-01-13 21:53 ` Thomas Rast 2009-01-13 21:56 ` Thomas Rast 2009-01-13 22:00 ` R. Tyler Ballance 2009-01-13 21:55 ` Björn Steinbrink ` (2 subsequent siblings) 3 siblings, 2 replies; 12+ messages in thread From: Thomas Rast @ 2009-01-13 21:53 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: git [-- Attachment #1: Type: text/plain, Size: 825 bytes --] R. Tyler Ballance wrote: > Besides a vigorous flogging, we're looking at other ways to prevent this > sort of thing from happening again; the option we've settled on is to > remove the "--force" flag from our internal build of v1.6.1 > > I'm wondering if somebody could point me in the right direction to > remove "--force" (safely) from the builtin-push.c and removing the > "rebase" command (we've got no use for it, and would prefer it gone). IMHO your update (or pre-receive) hook should just disallow non-fast-forward updates. This doesn't really address git-rebase, but it will disallow pushing a "harmfully" rebased branch since those are by definition non-ff. Why take away the option to correct a mistake in the last commit with 'git rebase -i'? -- Thomas Rast trast@{inf,student}.ethz.ch [-- Attachment #2: This is a digitally signed message part. --] [-- Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 21:53 ` Thomas Rast @ 2009-01-13 21:56 ` Thomas Rast 2009-01-13 22:00 ` R. Tyler Ballance 1 sibling, 0 replies; 12+ messages in thread From: Thomas Rast @ 2009-01-13 21:56 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: git [-- Attachment #1: Type: text/plain, Size: 701 bytes --] Thomas Rast wrote: > R. Tyler Ballance wrote: > > I'm wondering if somebody could point me in the right direction to > > remove "--force" (safely) from the builtin-push.c > > IMHO your update (or pre-receive) hook should just disallow > non-fast-forward updates. Actually there's even this config option: receive.denyNonFastForwards If set to true, git-receive-pack will deny a ref update which is not a fast forward. Use this to prevent such an update via a push, even if that push is forced. This configuration variable is set when initializing a shared repository. -- Thomas Rast trast@{inf,student}.ethz.ch [-- Attachment #2: This is a digitally signed message part. --] [-- Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 21:53 ` Thomas Rast 2009-01-13 21:56 ` Thomas Rast @ 2009-01-13 22:00 ` R. Tyler Ballance 2009-01-13 22:07 ` Björn Steinbrink ` (2 more replies) 1 sibling, 3 replies; 12+ messages in thread From: R. Tyler Ballance @ 2009-01-13 22:00 UTC (permalink / raw) To: Thomas Rast; +Cc: git [-- Attachment #1: Type: text/plain, Size: 1653 bytes --] On Tue, 2009-01-13 at 22:53 +0100, Thomas Rast wrote: > R. Tyler Ballance wrote: > > Besides a vigorous flogging, we're looking at other ways to prevent this > > sort of thing from happening again; the option we've settled on is to > > remove the "--force" flag from our internal build of v1.6.1 > > > > I'm wondering if somebody could point me in the right direction to > > remove "--force" (safely) from the builtin-push.c and removing the > > "rebase" command (we've got no use for it, and would prefer it gone). > > IMHO your update (or pre-receive) hook should just disallow > non-fast-forward updates. Don't merges count as non-fast-forward updates? We generate merge commits with almost every merge, rarely do we actually have fast-forwards anymore (highly active repository) > > This doesn't really address git-rebase, but it will disallow pushing a > "harmfully" rebased branch since those are by definition non-ff. Why > take away the option to correct a mistake in the last commit with 'git > rebase -i'? I'm a strong proponent of revision history only moving forward, I would much rather see a series of revert commits than having somebody who is inexperienced with the tools they're using muck about an jeopardize the stability of our central repository. Used correctly, both --force and `rebase` have good reason to exist in the Git codebase; they just haven't been used correctly, and proper bamboo to flog developers with will take a couple days to ship from Asia, so removing the options from our internal build is a lot easier and faster ;) Cheers :D -- -R. Tyler Ballance Slide, Inc. [-- Attachment #2: This is a digitally signed message part --] [-- Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 22:00 ` R. Tyler Ballance @ 2009-01-13 22:07 ` Björn Steinbrink 2009-01-13 22:10 ` Boyd Stephen Smith Jr. 2009-01-13 22:47 ` Daniel Barkalow 2 siblings, 0 replies; 12+ messages in thread From: Björn Steinbrink @ 2009-01-13 22:07 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: Thomas Rast, git On 2009.01.13 14:00:45 -0800, R. Tyler Ballance wrote: > On Tue, 2009-01-13 at 22:53 +0100, Thomas Rast wrote: > > R. Tyler Ballance wrote: > > > Besides a vigorous flogging, we're looking at other ways to prevent this > > > sort of thing from happening again; the option we've settled on is to > > > remove the "--force" flag from our internal build of v1.6.1 > > > > > > I'm wondering if somebody could point me in the right direction to > > > remove "--force" (safely) from the builtin-push.c and removing the > > > "rebase" command (we've got no use for it, and would prefer it gone). > > > > IMHO your update (or pre-receive) hook should just disallow > > non-fast-forward updates. > > Don't merges count as non-fast-forward updates? We generate merge > commits with almost every merge, rarely do we actually have > fast-forwards anymore (highly active repository) No, merges are "fast-forward". In rev-list terms: git rev-list new_head..old_head ==> Empty IOW: No commits are lost by the push. Merges only add commits to the history, they don't remove anything. Björn ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 22:00 ` R. Tyler Ballance 2009-01-13 22:07 ` Björn Steinbrink @ 2009-01-13 22:10 ` Boyd Stephen Smith Jr. 2009-01-13 22:47 ` Daniel Barkalow 2 siblings, 0 replies; 12+ messages in thread From: Boyd Stephen Smith Jr. @ 2009-01-13 22:10 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: Thomas Rast, git [-- Attachment #1: Type: text/plain, Size: 597 bytes --] On Tuesday 2009 January 13 16:00:45 R. Tyler Ballance wrote: >On Tue, 2009-01-13 at 22:53 +0100, Thomas Rast wrote: >> IMHO your update (or pre-receive) hook should just disallow >> non-fast-forward updates. > >Don't merges count as non-fast-forward updates? No. If there is a chain of parent links X ~> Y then updating a ref Y -> X is a fast-forward. -- Boyd Stephen Smith Jr. ,= ,-_-. =. bss@iguanasuicide.net ((_/)o o(\_)) ICQ: 514984 YM/AIM: DaTwinkDaddy `-'(. .)`-' http://iguanasuicide.net/ \_/ [-- Attachment #2: This is a digitally signed message part. --] [-- Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 22:00 ` R. Tyler Ballance 2009-01-13 22:07 ` Björn Steinbrink 2009-01-13 22:10 ` Boyd Stephen Smith Jr. @ 2009-01-13 22:47 ` Daniel Barkalow 2 siblings, 0 replies; 12+ messages in thread From: Daniel Barkalow @ 2009-01-13 22:47 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: Thomas Rast, git On Tue, 13 Jan 2009, R. Tyler Ballance wrote: > On Tue, 2009-01-13 at 22:53 +0100, Thomas Rast wrote: > > R. Tyler Ballance wrote: > > > Besides a vigorous flogging, we're looking at other ways to prevent this > > > sort of thing from happening again; the option we've settled on is to > > > remove the "--force" flag from our internal build of v1.6.1 > > > > > > I'm wondering if somebody could point me in the right direction to > > > remove "--force" (safely) from the builtin-push.c and removing the > > > "rebase" command (we've got no use for it, and would prefer it gone). > > > > IMHO your update (or pre-receive) hook should just disallow > > non-fast-forward updates. > > Don't merges count as non-fast-forward updates? We generate merge > commits with almost every merge, rarely do we actually have > fast-forwards anymore (highly active repository) Creating a merge is a non-fast-forward update, but sending the merge to a repository that is currently at one of the parents is a fast-forward. Hopefully, you're generating merge commits with merge, not with push. :) > > This doesn't really address git-rebase, but it will disallow pushing a > > "harmfully" rebased branch since those are by definition non-ff. Why > > take away the option to correct a mistake in the last commit with 'git > > rebase -i'? > > I'm a strong proponent of revision history only moving forward, I would > much rather see a series of revert commits than having somebody who is > inexperienced with the tools they're using muck about an jeopardize the > stability of our central repository. > > > Used correctly, both --force and `rebase` have good reason to exist in > the Git codebase; they just haven't been used correctly, and proper > bamboo to flog developers with will take a couple days to ship from > Asia, so removing the options from our internal build is a lot easier > and faster ;) Denying non-fast-forward updates means that people can rebase, but if they rebase anything that they've pushed (or anyone else has pushed), they can't push. You can't really disallow rebasing of private commits while still using git; a user can always clone the upstream repository again, get diffs from the repository where they don't like the history, apply them to the new clone, and throw away the repository with the bad history. Or they can call up a coworker, tell them what changes to make, commit, and push, and then lose their work in a hard drive crash. People can always make the excuse "My identical twin did stuff wrong, but I knocked him out before he could push and did everything right." As long as they can't say "My evil twin pushed the changes to the repository's evil twin, but I knocked him out and destoryed the evil repository, and now we've got the good repository." -Daniel *This .sig left intentionally blank* ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 21:43 Removing options from build R. Tyler Ballance 2009-01-13 21:53 ` Thomas Rast @ 2009-01-13 21:55 ` Björn Steinbrink 2009-01-13 22:05 ` Jakub Narebski 2009-01-13 22:06 ` Boyd Stephen Smith Jr. 3 siblings, 0 replies; 12+ messages in thread From: Björn Steinbrink @ 2009-01-13 21:55 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: git On 2009.01.13 13:43:22 -0800, R. Tyler Ballance wrote: > One of our developers "discovered" the --force option on `git push` and > used it without taking the appropriate care and hosed one of the project > branches we have running around in our central repository. > > Besides a vigorous flogging, we're looking at other ways to prevent this > sort of thing from happening again; the option we've settled on is to > remove the "--force" flag from our internal build of v1.6.1 > > I'm wondering if somebody could point me in the right direction to > remove "--force" (safely) from the builtin-push.c and removing the > "rebase" command (we've got no use for it, and would prefer it gone). git help config receive.denyNonFastForwards (to refuse non-fast-forwards, even with -f) receive.denyDeletes (to stop users from working around the non-ff using a delete + recreate operation) Björn ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 21:43 Removing options from build R. Tyler Ballance 2009-01-13 21:53 ` Thomas Rast 2009-01-13 21:55 ` Björn Steinbrink @ 2009-01-13 22:05 ` Jakub Narebski 2009-01-13 22:06 ` Boyd Stephen Smith Jr. 3 siblings, 0 replies; 12+ messages in thread From: Jakub Narebski @ 2009-01-13 22:05 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: git "R. Tyler Ballance" <tyler@slide.com> writes: > One of our developers "discovered" the --force option on `git push` and > used it without taking the appropriate care and hosed one of the project > branches we have running around in our central repository. > > Besides a vigorous flogging, we're looking at other ways to prevent this > sort of thing from happening again; the option we've settled on is to > remove the "--force" flag from our internal build of v1.6.1 > > I'm wondering if somebody could point me in the right direction to > remove "--force" (safely) from the builtin-push.c and removing the > "rebase" command (we've got no use for it, and would prefer it gone). First, the title (subject) of this email is misleading: it is about your solution, and not about the problem you have (protecting against "git push --force"). Second, there are two possible solutions: use receive.denyNonFastForwards and perhaps also receive.denyDeletes (see git-config(1)) to forbid forced pushes on server (target of push); removing '--force' is a client solution. Or, better, use update or post-receive hook on server, forbidding non-fastforward updates to selected set of 'stable' branches; you can use contrib/hooks/update-paranoid for that. -- Jakub Narebski Poland ShadeHawk on #git ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 21:43 Removing options from build R. Tyler Ballance ` (2 preceding siblings ...) 2009-01-13 22:05 ` Jakub Narebski @ 2009-01-13 22:06 ` Boyd Stephen Smith Jr. 2009-01-13 22:18 ` R. Tyler Ballance 3 siblings, 1 reply; 12+ messages in thread From: Boyd Stephen Smith Jr. @ 2009-01-13 22:06 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: git [-- Attachment #1: Type: text/plain, Size: 967 bytes --] On Tuesday 2009 January 13 15:43:22 R. Tyler Ballance wrote: >One of our developers "discovered" the --force option on `git push` and >used it without taking the appropriate care and hosed one of the project >branches we have running around in our central repository. Reflogs should let you recover from this. >Besides a vigorous flogging, we're looking at other ways to prevent this >sort of thing from happening again; receive.denyNonFastForwards If set to true, git-receive-pack will deny a ref update which is not a fast forward. Use this to prevent such an update via a push, even if that push is forced. This configuration variable is set when initializing a shared repository. -- Boyd Stephen Smith Jr. ,= ,-_-. =. bss@iguanasuicide.net ((_/)o o(\_)) ICQ: 514984 YM/AIM: DaTwinkDaddy `-'(. .)`-' http://iguanasuicide.net/ \_/ [-- Attachment #2: This is a digitally signed message part. --] [-- Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 22:06 ` Boyd Stephen Smith Jr. @ 2009-01-13 22:18 ` R. Tyler Ballance 2009-01-13 22:34 ` Boyd Stephen Smith Jr. 0 siblings, 1 reply; 12+ messages in thread From: R. Tyler Ballance @ 2009-01-13 22:18 UTC (permalink / raw) To: Boyd Stephen Smith Jr.; +Cc: git [-- Attachment #1: Type: text/plain, Size: 1067 bytes --] On Tue, 2009-01-13 at 16:06 -0600, Boyd Stephen Smith Jr. wrote: > On Tuesday 2009 January 13 15:43:22 R. Tyler Ballance wrote: > >One of our developers "discovered" the --force option on `git push` and > >used it without taking the appropriate care and hosed one of the project > >branches we have running around in our central repository. > > Reflogs should let you recover from this. > > >Besides a vigorous flogging, we're looking at other ways to prevent this > >sort of thing from happening again; > > receive.denyNonFastForwards > If set to true, git-receive-pack will deny a ref update which > is not a fast forward. Use this to prevent such an update via a > push, even if that push is forced. This configuration variable > is set when initializing a shared repository. Looks good, thanks; sorry I missed it, didn't even think to look at the git-config(1) page for such an option. I'm assuming this will actually cover the rebase -i case as well? Cheers -- -R. Tyler Ballance Slide, Inc. [-- Attachment #2: This is a digitally signed message part --] [-- Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Removing options from build 2009-01-13 22:18 ` R. Tyler Ballance @ 2009-01-13 22:34 ` Boyd Stephen Smith Jr. 0 siblings, 0 replies; 12+ messages in thread From: Boyd Stephen Smith Jr. @ 2009-01-13 22:34 UTC (permalink / raw) To: R. Tyler Ballance; +Cc: git [-- Attachment #1: Type: text/plain, Size: 1443 bytes --] On Tuesday 2009 January 13 16:18:52 R. Tyler Ballance wrote: >On Tue, 2009-01-13 at 16:06 -0600, Boyd Stephen Smith Jr. wrote: >> receive.denyNonFastForwards >> If set to true, git-receive-pack will deny a ref update which >> is not a fast forward. Use this to prevent such an update via a >> push, even if that push is forced. > >Looks good, thanks; sorry I missed it, didn't even think to look at the >git-config(1) page for such an option. I didn't really know about it until earlier this week. I was expecting to be able to do a non-ff push to one of my repositories and it didn't work because this was set "behind my back". (I'm not sure when it got added, but I don't think the shared repositories I set up with git 1.4.4.4 had it, so I wasn't expecting it.) >I'm assuming this will actually cover the rebase -i case as well? I don't know exactly what you mean. It prevents fast-forwards, so once a commit is "visible" on one of your central branches, it won't ever go away. (You can, of course, use git revert to undo it's changes.) As others mentioned, now would be a good time to look at receive.denyDeletes and/or a custom hook as well. -- Boyd Stephen Smith Jr. ,= ,-_-. =. bss@iguanasuicide.net ((_/)o o(\_)) ICQ: 514984 YM/AIM: DaTwinkDaddy `-'(. .)`-' http://iguanasuicide.net/ \_/ [-- Attachment #2: This is a digitally signed message part. --] [-- Type: application/pgp-signature, Size: 197 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2009-01-13 22:49 UTC | newest] Thread overview: 12+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2009-01-13 21:43 Removing options from build R. Tyler Ballance 2009-01-13 21:53 ` Thomas Rast 2009-01-13 21:56 ` Thomas Rast 2009-01-13 22:00 ` R. Tyler Ballance 2009-01-13 22:07 ` Björn Steinbrink 2009-01-13 22:10 ` Boyd Stephen Smith Jr. 2009-01-13 22:47 ` Daniel Barkalow 2009-01-13 21:55 ` Björn Steinbrink 2009-01-13 22:05 ` Jakub Narebski 2009-01-13 22:06 ` Boyd Stephen Smith Jr. 2009-01-13 22:18 ` R. Tyler Ballance 2009-01-13 22:34 ` Boyd Stephen Smith Jr.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox