diff options
| author | Joey Hess <joey@kitenet.net> | 2014-05-31 16:48:14 -0400 |
|---|---|---|
| committer | Joey Hess <joey@kitenet.net> | 2014-05-31 16:48:14 -0400 |
| commit | 6383d8c38893c160382eb9bf69e0315c5e87269e (patch) | |
| tree | 63b3cf0c907df738fb227dc88d1dea5ea08a3c61 /src/Propellor/Attr.hs | |
| parent | 1a83bf26300a225f044205e2208783e664377e25 (diff) | |
propellor spin
Diffstat (limited to 'src/Propellor/Attr.hs')
| -rw-r--r-- | src/Propellor/Attr.hs | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/src/Propellor/Attr.hs b/src/Propellor/Attr.hs index 98cfc64d..e2b64bf0 100644 --- a/src/Propellor/Attr.hs +++ b/src/Propellor/Attr.hs @@ -33,21 +33,31 @@ getOS = asks _os -- TODO check at run time if the host really has this address. -- (Can't change the host's address, but as a sanity check.) ipv4 :: String -> Property -ipv4 addr = pureAttrProperty ("ipv4 " ++ addr) - (addDNS $ Address $ IPv4 addr) +ipv4 = addDNS . Address . IPv4 -- | Indidate that a host has an AAAA record in the DNS. ipv6 :: String -> Property -ipv6 addr = pureAttrProperty ("ipv6 " ++ addr) - (addDNS $ Address $ IPv6 addr) +ipv6 = addDNS . Address . IPv6 -- | Indicates another name for the host in the DNS. alias :: Domain -> Property -alias domain = pureAttrProperty ("alias " ++ domain) - (addDNS $ CNAME $ AbsDomain domain) +alias = addDNS . CNAME . AbsDomain -addDNS :: Record -> SetAttr -addDNS record d = d { _dns = S.insert record (_dns d) } +addDNS :: Record -> Property +addDNS r = pureAttrProperty (rdesc r) $ + \d -> d { _dns = S.insert r (_dns d) } + where + rdesc (CNAME d) = unwords ["alias", ddesc d] + rdesc (Address (IPv4 addr)) = unwords ["ipv4", addr] + rdesc (Address (IPv6 addr)) = unwords ["ipv6", addr] + rdesc (MX n d) = unwords ["MX", show n, ddesc d] + rdesc (NS d) = unwords ["NS", ddesc d] + rdesc (TXT s) = unwords ["TXT", s] + rdesc (SRV x y z d) = unwords ["SRV", show x, show y, show z, ddesc d] + + ddesc (AbsDomain domain) = domain + ddesc (RelDomain domain) = domain + ddesc RootDomain = "@" -- | Adds a DNS NamedConf stanza. -- |
