X-Git-Url: http://www.average.org/gitweb/?p=pdns-pipe-nmc.git;a=blobdiff_plain;f=pdns-pipe-nmc.hs;h=ab3e410de5951ed572dd20fdda70a0956a0b9f0e;hp=1786376112854000b368be6a410432a9875db356;hb=ea30e0fbb979aba2ca9e9380a8455e0ed31be075;hpb=db22eaa53c505149f42cb3a7e3df9ea1fa9e1350 diff --git a/pdns-pipe-nmc.hs b/pdns-pipe-nmc.hs index 1786376..ab3e410 100644 --- a/pdns-pipe-nmc.hs +++ b/pdns-pipe-nmc.hs @@ -54,8 +54,8 @@ qRsp rsp = case parseJsonRpc (responseBody rsp) :: Either JsonRpcError NmcRes of Left jerr -> case (jrpcErrCode jerr) of - -4 -> Right "{}" -- this is how non-existent entry is returned - _ -> Left $ "JsonRpc error response: " ++ (show jerr) + (-4) -> Right "{}" -- this is how non-existent entry is returned + _ -> Left $ "JsonRpc error response: " ++ (show jerr) Right jrsp -> Right $ resValue jrsp -- NMC interface @@ -118,7 +118,7 @@ mainPdnsNmc = do case preq of PdnsRequestQ qname qtype id _ _ _ -> do io $ queryDom (queryOpNmc cfg mgr id) qname - >>= putStr . (pdnsOut ver count qname qtype) + >>= putStr . (pdnsOutQ ver count qname qtype) -- debug io $ putStrLn $ "LOG\tRequest number " ++ (show count) ++ " id: " ++ (show id) @@ -139,28 +139,35 @@ mainPdnsNmc = do runStateT mainloop (0, empty) >> return () +-- helper for command-line tools + +pdnsOut key qt dom = + case qt of + "AXFR" -> pdnsOutXfr 1 (-1) key dom + _ -> pdnsOutQ 1 (-1) key (rrType qt) dom + -- query by key from Namecoin -mainOne key = do +mainOne key qt = do cfg <- readConfig confFile mgr <- newManager def dom <- queryDom (queryOpNmc cfg mgr (-1)) key putStrLn $ ppShow dom - putStr $ pdnsOut 1 (-1) key RRTypeANY dom + putStr $ pdnsOut key qt dom -- using file backend for testing json domain data -mainFile key = do +mainFile key qt = do dom <- queryDom queryOpFile key putStrLn $ ppShow dom - putStr $ pdnsOut 1 (-1) key RRTypeANY dom + putStr $ pdnsOut key qt dom -- Entry point main = do args <- getArgs case args of - [] -> mainPdnsNmc - [key] -> mainOne key - ["-f",key] -> mainFile key - _ -> error $ "usage: empty args, or \"[-f] \"" + [] -> mainPdnsNmc + [key, qtype] -> mainOne key qtype + ["-f" ,key, qtype] -> mainFile key qtype + _ -> error $ "usage: empty args, or \"[-f] {|ANY|AXFR}\" (type in caps)"