better hasPrivContentExposed

Avoid locking down and then lossening the file mode; just use the
default/current mode from the beginning.
This commit is contained in:
Joey Hess 2014-07-17 22:35:59 -04:00
parent 91d148215a
commit cfb758d655
1 changed files with 15 additions and 9 deletions

View File

@ -18,18 +18,24 @@ f `hasContent` newcontent = fileProperty ("replace " ++ f)
-- The file's permissions are preserved if the file already existed. -- The file's permissions are preserved if the file already existed.
-- Otherwise, they're set to 600. -- Otherwise, they're set to 600.
hasPrivContent :: FilePath -> Context -> Property hasPrivContent :: FilePath -> Context -> Property
hasPrivContent f context = withPrivData (PrivFile f) context $ \getcontent -> hasPrivContent = hasPrivContent' writeFileProtected
property desc $ getcontent $ \privcontent ->
ensureProperty $ fileProperty' writeFileProtected desc -- | Leaves the file at its default or current mode,
(\_oldcontent -> lines privcontent) f -- allowing "private" data to be read.
--
-- Use with caution!
hasPrivContentExposed :: FilePath -> Context -> Property
hasPrivContentExposed = hasPrivContent' writeFile
hasPrivContent' :: (String -> FilePath -> IO ()) -> FilePath -> Context -> Property
hasPrivContent' writer f context =
withPrivData (PrivFile f) context $ \getcontent ->
property desc $ getcontent $ \privcontent ->
ensureProperty $ fileProperty' writer desc
(\_oldcontent -> lines privcontent) f
where where
desc = "privcontent " ++ f desc = "privcontent " ++ f
-- | Leaves the file world-readable.
hasPrivContentExposed :: FilePath -> Context -> Property
hasPrivContentExposed f context = hasPrivContent f context `onChange`
mode f (combineModes (ownerWriteMode:readModes))
-- | Ensures that a line is present in a file, adding it to the end if not. -- | Ensures that a line is present in a file, adding it to the end if not.
containsLine :: FilePath -> Line -> Property containsLine :: FilePath -> Line -> Property
f `containsLine` l = f `containsLines` [l] f `containsLine` l = f `containsLines` [l]