X-Git-Url: http://git.cielonegro.org/gitweb.cgi?a=blobdiff_plain;f=ExampleDNSServer.hs;h=75b261aa9effb9349a6f4e7d9a0f75fd557b5803;hb=845dca95afa7e073e62520ef3c4840b3b078bdad;hp=f590caab054b7d58240b9ae1c0e9d208682c42fc;hpb=d24a461f09bd10e3fe148e3b6b86c8e861b09a43;p=haskell-dns.git diff --git a/ExampleDNSServer.hs b/ExampleDNSServer.hs index f590caa..75b261a 100644 --- a/ExampleDNSServer.hs +++ b/ExampleDNSServer.hs @@ -1,46 +1,85 @@ import Network.DNS.Message import Network.DNS.Named import Network.DNS.Named.Config -import Network.DNS.Named.Responder import Network.DNS.Named.Zone -import Network.Socket -import System.IO.Unsafe +import Network.Socket.IsString () main :: IO () -main = runNamed cnf zoneFor +main = runNamed cnf (return . findZone) where cnf :: Config cnf = Config { - cnfServerAddress = SockAddrInet 9090 iNADDR_ANY + cnfServerPort = "9090" + , cnfAllowTransfer = True } - zoneFor :: DomainName -> Maybe Zone - zoneFor name + findZone :: DomainName -> Maybe Zone + findZone name | name `isInZone` zone = Just zone | otherwise = Nothing zone :: Zone zone = Zone { - zoneName = mkDN "cielonegro.org." - , zoneResponders = [ wrapResponder' $ - do name <- getQueryName - if name == mkDN "ns.cielonegro.org." then - respond ResourceRecord { - rrName = name - , rrType = A - , rrClass = IN - , rrTTL = 9600 - , rrData = inetAddr "127.0.0.1" - } - else - fail "FIXME: we want to throw NameError but we can't for now" - ] - , zoneIsAuthoritative = True + zoneName = "cielonegro.org." + , zoneSOA = Just SOAFields { + soaMasterNameServer = "ns.cielonegro.org." + , soaResponsibleMailbox = "root.ns.cielonegro.org." + , soaSerialNumber = 2008022148 + , soaRefreshInterval = 3600 + , soaRetryInterval = 900 + , soaExpirationLimit = 3600000 + , soaMinimumTTL = 3600 + } + , zoneRecordNames = return [ "ns.cielonegro.org." + , "www.cielonegro.org." + , "git.cielonegro.org." + ] + , zoneResponder = return . responder } - wrapResponder' :: Responder A IN () -> SomeResponder - wrapResponder' = wrapResponder + responder :: DomainName -> [SomeRR] + responder name + | name == "ns.cielonegro.org." + = [ wrapRecord ResourceRecord { + rrName = name + , rrType = A + , rrClass = IN + , rrTTL = 9600 + , rrData = "127.0.0.1" + } + , wrapRecord ResourceRecord { + rrName = name + , rrType = AAAA + , rrClass = IN + , rrTTL = 9600 + , rrData = "::1" + } + ] + | name == "www.cielonegro.org." + = [ wrapRecord ResourceRecord { + rrName = name + , rrType = A + , rrClass = IN + , rrTTL = 9600 + , rrData = "127.0.0.2" + } + , wrapRecord ResourceRecord { + rrName = name + , rrType = AAAA + , rrClass = IN + , rrTTL = 9600 + , rrData = "fe80::216:cbff:fe39:56a4" + } + ] + | name == "git.cielonegro.org." + = [ wrapRecord ResourceRecord { + rrName = name + , rrType = CNAME + , rrClass = IN + , rrTTL = 9600 + , rrData = "www.cielonegro.org." + } + ] + | otherwise + = [] -- This means NXDOMAIN. - -inetAddr :: String -> HostAddress -inetAddr = unsafePerformIO . inet_addr