fix init reversion when core.sharedRepository = group

init: Fix misbehavior when core.sharedRepository = group that caused it to
enter an adjusted branch. (Reversion in version 8.20210630)

Commit 4b1b9d7a83 made init call
freezeContent in case there was a hook that could prevent writing in
situations where perms don't. But with the above git config, freezeContent
does not prevent write at all. So init needs to do what freezeContent does
with a non-shared git config.

Or init could check for that config, and skip the probing, since it
won't actually be preventing write to any files. But that would make init
too aware if details of Annex.Perms, and also would break if the git config
were changed after init.

Sponsored-by: Dartmouth College's Datalad project
This commit is contained in:
Joey Hess 2021-07-12 10:15:49 -04:00
parent 215aee105d
commit 6a581f8b8b
No known key found for this signature in database
GPG key ID: DB12DB0FF05F8F38
4 changed files with 25 additions and 5 deletions

View file

@ -25,6 +25,7 @@ import qualified Git
import qualified Git.Config import qualified Git.Config
import qualified Git.Objects import qualified Git.Objects
import Git.Types (fromConfigValue) import Git.Types (fromConfigValue)
import Git.ConfigTypes (SharedRepository(..))
import qualified Annex.Branch import qualified Annex.Branch
import Logs.UUID import Logs.UUID
import Logs.Trust.Basic import Logs.Trust.Basic
@ -243,8 +244,8 @@ isInitialized = maybe Annex.Branch.hasSibling (const $ return True) =<< getVersi
probeCrippledFileSystem :: Annex Bool probeCrippledFileSystem :: Annex Bool
probeCrippledFileSystem = withEventuallyCleanedOtherTmp $ \tmp -> do probeCrippledFileSystem = withEventuallyCleanedOtherTmp $ \tmp -> do
(r, warnings) <- probeCrippledFileSystem' tmp (r, warnings) <- probeCrippledFileSystem' tmp
(Just freezeContent) (Just (freezeContent' UnShared))
(Just thawContent) (Just (thawContent' UnShared))
mapM_ warning warnings mapM_ warning warnings
return r return r

View file

@ -15,8 +15,10 @@ module Annex.Perms (
createWorkTreeDirectory, createWorkTreeDirectory,
noUmask, noUmask,
freezeContent, freezeContent,
freezeContent',
isContentWritePermOk, isContentWritePermOk,
thawContent, thawContent,
thawContent',
createContentDir, createContentDir,
freezeContentDir, freezeContentDir,
thawContentDir, thawContentDir,
@ -131,8 +133,12 @@ createWorkTreeDirectory dir = do
- owned by another user, so failure to set this mode is ignored. - owned by another user, so failure to set this mode is ignored.
-} -}
freezeContent :: RawFilePath -> Annex () freezeContent :: RawFilePath -> Annex ()
freezeContent file = unlessM crippledFileSystem $ do freezeContent file = unlessM crippledFileSystem $
withShared go withShared $ \sr -> freezeContent' sr file
freezeContent' :: SharedRepository -> RawFilePath -> Annex ()
freezeContent' sr file = do
go sr
freezeHook file freezeHook file
where where
go GroupShared = liftIO $ void $ tryIO $ modifyFileMode file $ go GroupShared = liftIO $ void $ tryIO $ modifyFileMode file $
@ -160,7 +166,10 @@ isContentWritePermOk file = ifM crippledFileSystem
{- Allows writing to an annexed file that freezeContent was called on {- Allows writing to an annexed file that freezeContent was called on
- before. -} - before. -}
thawContent :: RawFilePath -> Annex () thawContent :: RawFilePath -> Annex ()
thawContent file = thawPerms (withShared go) (thawHook file) thawContent file = withShared $ \sr -> thawContent' sr file
thawContent' :: SharedRepository -> RawFilePath -> Annex ()
thawContent' sr file = thawPerms (go sr) (thawHook file)
where where
go GroupShared = liftIO $ void $ tryIO $ groupWriteRead file go GroupShared = liftIO $ void $ tryIO $ groupWriteRead file
go AllShared = liftIO $ void $ tryIO $ groupWriteRead file go AllShared = liftIO $ void $ tryIO $ groupWriteRead file

View file

@ -5,6 +5,9 @@ git-annex (8.20210631) UNRELEASED; urgency=medium
* addurl: Avoid crashing when used on beegfs. * addurl: Avoid crashing when used on beegfs.
* --debug output goes to stderr again, not stdout. * --debug output goes to stderr again, not stdout.
(Reversion in version 8.20210428) (Reversion in version 8.20210428)
* init: Fix misbehavior when core.sharedRepository = group that
caused it to enter an adjusted branch.
(Reversion in version 8.20210630)
-- Joey Hess <id@joeyh.name> Wed, 30 Jun 2021 17:55:10 -0400 -- Joey Hess <id@joeyh.name> Wed, 30 Jun 2021 17:55:10 -0400

View file

@ -0,0 +1,7 @@
[[!comment format=mdwn
username="joey"
subject="""comment 3"""
date="2021-07-12T14:09:19Z"
content="""
(Fixed the problem with git-annex init's probing.)
"""]]