module Puppet.NativeTypes.File (nativeFile) where
import Puppet.NativeTypes.Helpers
import Control.Monad.Error
import Puppet.Interpreter.Types
import qualified Data.Map as Map
import qualified Data.Set as Set
import Data.Char (isDigit)
import qualified Data.Text as T
nativeFile :: (PuppetTypeName, PuppetTypeMethods)
nativeFile = ("file", PuppetTypeMethods validateFile parameterset)
parameterset = Set.fromList $ map fst parameterfunctions
parameterfunctions =
[("backup" , [string])
,("checksum" , [values ["md5", "md5lite", "mtime", "ctime", "none"]])
,("content" , [string])
,("ensure" , [defaultvalue "present", string])
,("force" , [string, values ["true","false"]])
,("group" , [defaultvalue "root", string])
,("ignore" , [string])
,("links" , [string])
,("mode" , [defaultvalue "0644", string])
,("owner" , [string])
,("path" , [nameval, fullyQualified, noTrailingSlash])
,("provider" , [values ["posix","windows"]])
,("purge" , [string, values ["true","false"]])
,("recurse" , [string, values ["inf","true","false","remote"]])
,("recurselimit", [integer])
,("replace" , [string, values ["true","false"]])
,("sourceselect", [values ["first","all"]])
,("target" , [string])
,("source" , [])
]
validateFile :: PuppetTypeValidate
validateFile = defaultValidate parameterset >=> parameterFunctions parameterfunctions >=> validateSourceOrContent >=> validateMode
validateMode :: PuppetTypeValidate
validateMode res = let
modestr = case ((rrparams res) Map.! "mode") of
ResolvedString s -> s
_ -> "0644"
in do
when ((T.length modestr /= 3) && (T.length modestr /= 4)) (throwError "Invalid mode size")
when (not (T.all isDigit modestr)) (throwError "The mode should only be made of digits")
if T.length modestr == 3
then return $ insertparam res "mode" (ResolvedString (T.cons '0' modestr))
else return res
validateSourceOrContent :: PuppetTypeValidate
validateSourceOrContent res = let
parammap = rrparams res
source = Map.member "source" parammap
content = Map.member "content" parammap
in if source && content
then Left "Source and content can't be specified at the same time"
else Right res