 7f992ef59c
			
		
	
	
	
	
	7f992ef59cRemaining things needing converted are in the assistant, and Annex.Ssh. Every other remaining call to createDirectoryIfMissing True has been audited and is not relevant. The ones in Build/ of course don't get included in the program. Others included eg, Remote.Tahoe and Config.Files which both write to dotfiles under the home directory.
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			1.8 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			1.8 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
| {- Persistent sqlite database initialization
 | |
|  -
 | |
|  - Copyright 2015-2020 Joey Hess <id@joeyh.name>
 | |
|  -
 | |
|  - Licensed under the GNU AGPL version 3 or higher.
 | |
|  -}
 | |
| 
 | |
| module Database.Init where
 | |
| 
 | |
| import Annex.Common
 | |
| import Annex.Perms
 | |
| import Utility.FileMode
 | |
| 
 | |
| import Database.Persist.Sqlite
 | |
| import Control.Monad.IO.Class (liftIO)
 | |
| import qualified Data.Text as T
 | |
| import Lens.Micro
 | |
| 
 | |
| {- Ensures that the database is freshly initialized. Deletes any
 | |
|  - existing database. Pass the migration action for the database.
 | |
|  -
 | |
|  - The permissions of the database are set based on the
 | |
|  - core.sharedRepository setting. Setting these permissions on the main db
 | |
|  - file causes Sqlite to always use the same permissions for additional
 | |
|  - files it writes later on
 | |
|  -}
 | |
| initDb :: FilePath -> SqlPersistM () -> Annex ()
 | |
| initDb db migration = do
 | |
| 	let dbdir = takeDirectory db
 | |
| 	let tmpdbdir = dbdir ++ ".tmp"
 | |
| 	let tmpdb = tmpdbdir </> "db"
 | |
| 	let tdb = T.pack tmpdb
 | |
| 	top <- parentDir . fromRawFilePath <$> fromRepo gitAnnexDir
 | |
| 	liftIO $ do
 | |
| 		createDirectoryUnder top tmpdbdir
 | |
| 		runSqliteInfo (enableWAL tdb) migration
 | |
| 	setAnnexDirPerm tmpdbdir
 | |
| 	-- Work around sqlite bug that prevents it from honoring
 | |
| 	-- less restrictive umasks.
 | |
| 	liftIO $ setFileMode tmpdb =<< defaultFileMode
 | |
| 	setAnnexFilePerm tmpdb
 | |
| 	liftIO $ do
 | |
| 		void $ tryIO $ removeDirectoryRecursive dbdir
 | |
| 		rename tmpdbdir dbdir
 | |
| 
 | |
| {- Make sure that the database uses WAL mode, to prevent readers
 | |
|  - from blocking writers, and prevent a writer from blocking readers.
 | |
|  -
 | |
|  - This is the default in recent persistent-sqlite versions, but 
 | |
|  - force it on just in case. 
 | |
|  -
 | |
|  - Note that once WAL mode is enabled, it will persist whenever the
 | |
|  - database is opened. -}
 | |
| enableWAL :: T.Text -> SqliteConnectionInfo
 | |
| enableWAL db = over walEnabled (const True) $ 
 | |
| 	mkSqliteConnectionInfo db
 |