| Safe Haskell | None | 
|---|
Propellor.Property.Dns
- module Propellor.Types.Dns
- primary :: [Host] -> Domain -> SOA -> [(BindDomain, Record)] -> RevertableProperty
- secondary :: [Host] -> Domain -> RevertableProperty
- secondaryFor :: [HostName] -> [Host] -> Domain -> RevertableProperty
- mkSOA :: Domain -> SerialNumber -> SOA
- writeZoneFile :: Zone -> FilePath -> IO ()
- nextSerialNumber :: Zone -> SerialNumber -> Zone
- adjustSerialNumber :: Zone -> (SerialNumber -> SerialNumber) -> Zone
- serialNumberOffset :: IO SerialNumber
- type WarningMessage = String
- genZone :: [Host] -> Domain -> SOA -> (Zone, [WarningMessage])
Documentation
module Propellor.Types.Dns
primary :: [Host] -> Domain -> SOA -> [(BindDomain, Record)] -> RevertablePropertySource
Primary dns server for a domain.
Most of the content of the zone file is configured by setting properties of hosts. For example,
host "foo.example.com" & ipv4 "192.168.1.1" & alias "mail.exmaple.com"
Will cause that hostmame and its alias to appear in the zone file, with the configured IP address.
The [(BindDomain, Record)] list can be used for additional records that cannot be configured elsewhere. This often includes NS records, TXT records and perhaps CNAMEs pointing at hosts that propellor does not control.
secondary :: [Host] -> Domain -> RevertablePropertySource
Secondary dns server for a domain.
The primary server is determined by looking at the properties of other hosts to find which one is configured as the primary.
Note that if a host is declared to be a primary and a secondary dns server for the same domain, the primary server config always wins.
secondaryFor :: [HostName] -> [Host] -> Domain -> RevertablePropertySource
This variant is useful if the primary server does not have its DNS configured via propellor.
mkSOA :: Domain -> SerialNumber -> SOASource
Generates a SOA with some fairly sane numbers in it.
The Domain is the domain to use in the SOA record. Typically something like ns1.example.com. So, not the domain that this is the SOA record for.
The SerialNumber can be whatever serial number was used by the domain before propellor started managing it. Or 0 if the domain has only ever been managed by propellor.
You do not need to increment the SerialNumber when making changes! Propellor will automatically add the number of commits in the git repository to the SerialNumber.
writeZoneFile :: Zone -> FilePath -> IO ()Source
Write a Zone out to a to a file.
The serial number in the Zone automatically has the serialNumberOffset added to it. Also, just in case, the old serial number used in the zone file is checked, and if it is somehow larger, its succ is used.
nextSerialNumber :: Zone -> SerialNumber -> ZoneSource
Adjusts the serial number of the zone to always be larger than the serial number in the Zone record, and always be larger than the passed SerialNumber.
adjustSerialNumber :: Zone -> (SerialNumber -> SerialNumber) -> ZoneSource
serialNumberOffset :: IO SerialNumberSource
Count the number of git commits made to the current branch.
type WarningMessage = StringSource