namecoin-update/Main.hs

47 lines
1.3 KiB
Haskell
Raw Normal View History

2015-05-12 23:09:23 +02:00
{-# Language TemplateHaskell, RecordWildCards #-}
2015-04-19 23:36:44 +02:00
import System.Process
import System.Exit
import Data.Aeson
2015-05-12 23:09:23 +02:00
import Data.Aeson.TH
2015-04-19 23:36:44 +02:00
import Data.ByteString.Lazy.Char8 (pack)
2016-08-29 06:07:56 +02:00
import Control.Exception (try)
2015-04-19 23:36:44 +02:00
2016-08-29 06:07:56 +02:00
data Name = Name
{ name :: String
, value :: String
, expires_in :: Int
}
2015-04-19 23:36:44 +02:00
2015-05-12 23:09:23 +02:00
deriveJSON defaultOptions ''Name
2015-04-19 23:36:44 +02:00
2016-08-29 06:07:56 +02:00
namecoin :: [String] -> CreateProcess
2017-01-26 21:56:15 +01:00
namecoin args = shell ("namecoind -conf=$HOME/.config/namecoin " ++ unwords args)
2016-08-29 06:07:56 +02:00
readCommand = readCreateProcess (namecoin ["name_list"]) ""
updateCommand n v = readCreateProcessWithExitCode (namecoin ["name_update", n, v]) ""
2015-04-19 23:36:44 +02:00
updateName :: Name -> IO Int
updateName Name{..}
| expires_in < 100 = do
(code, out, err) <- updateCommand name value
if code == ExitSuccess
then putStrLn (name ++ " updated: " ++ out) >> return 0
else putStrLn (name ++ " update failed: " ++ err) >> return 1
| otherwise = putStrLn ("No need to update " ++ name) >> return 0
2016-08-29 06:07:56 +02:00
2015-04-19 23:36:44 +02:00
main :: IO ()
main = do
out <- pack <$> readCommand
case eitherDecode out of
Right names -> do
errs <- sum <$> mapM updateName (names :: [Name])
if errs > 0
then putStrLn (show errs ++ " updates failed")
2016-08-29 06:07:56 +02:00
else putStrLn "All ok"
Left err -> putStrLn ("Error communicating with namecoin: " ++ err)