Safe Haskell | None |
---|---|
Language | Haskell98 |
- type Domain = String
- data IPAddr
- newtype AliasesInfo = AliasesInfo (Set HostName)
- toAliasesInfo :: [HostName] -> AliasesInfo
- fromAliasesInfo :: AliasesInfo -> [HostName]
- newtype DnsInfo = DnsInfo {
- fromDnsInfo :: Set Record
- toDnsInfo :: Set Record -> DnsInfo
- data NamedConf = NamedConf {
- confDomain :: Domain
- confDnsServerType :: DnsServerType
- confFile :: FilePath
- confMasters :: [IPAddr]
- confAllowTransfer :: [IPAddr]
- confLines :: [String]
- data DnsServerType
- data Zone = Zone {}
- data SOA = SOA {}
- data Record
- type ReverseIP = String
- reverseIP :: IPAddr -> ReverseIP
- canonicalIP :: IPAddr -> IPAddr
- getIPAddr :: Record -> Maybe IPAddr
- getCNAME :: Record -> Maybe BindDomain
- getNS :: Record -> Maybe BindDomain
- type SerialNumber = Word32
- data BindDomain
- domainHostName :: BindDomain -> Maybe HostName
- newtype NamedConfMap = NamedConfMap (Map Domain NamedConf)
- fromNamedConfMap :: NamedConfMap -> Map Domain NamedConf
Documentation
newtype AliasesInfo Source #
toAliasesInfo :: [HostName] -> AliasesInfo Source #
fromAliasesInfo :: AliasesInfo -> [HostName] Source #
Represents a bind 9 named.conf file.
NamedConf | |
|
data DnsServerType Source #
Represents a bind 9 zone file.
Every domain has a SOA record, which is big and complicated.
SOA | |
|
Types of DNS records.
This is not a complete list, more can be added.
canonicalIP :: IPAddr -> IPAddr Source #
Converts an IP address (particularly IPv6) to canonical, fully expanded form.
type SerialNumber = Word32 Source #
Bind serial numbers are unsigned, 32 bit integers.
data BindDomain Source #
Domains in the zone file must end with a period if they are absolute.
Let's use a type to keep absolute domains straight from relative domains.
The RootDomain refers to the top level of the domain, so can be used to add nameservers, MX's, etc to a domain.
domainHostName :: BindDomain -> Maybe HostName Source #
newtype NamedConfMap Source #
Eq NamedConfMap Source # | |
Ord NamedConfMap Source # | |
Show NamedConfMap Source # | |
Monoid NamedConfMap Source # | Adding a Master NamedConf stanza for a particulr domain always overrides an existing Secondary stanza for that domain, while a Secondary stanza is only added when there is no existing Master stanza. |
IsInfo NamedConfMap Source # | |
Empty NamedConfMap Source # | |