diff options
author | Paul Oliver <contact@pauloliver.dev> | 2024-12-29 17:05:34 +0000 |
---|---|---|
committer | Paul Oliver <contact@pauloliver.dev> | 2025-01-16 18:30:09 -0800 |
commit | cc639b06c7126fac7b445d8f778455620d7f8f50 (patch) | |
tree | a4c5c7c0b0a9cdb5bea0891e198003035065e57d /hsm-dummy-poller |
Initial
Diffstat (limited to 'hsm-dummy-poller')
-rw-r--r-- | hsm-dummy-poller/Main.hs | 56 | ||||
-rw-r--r-- | hsm-dummy-poller/hsm-dummy-poller.cabal | 25 |
2 files changed, 81 insertions, 0 deletions
diff --git a/hsm-dummy-poller/Main.hs b/hsm-dummy-poller/Main.hs new file mode 100644 index 0000000..7a35230 --- /dev/null +++ b/hsm-dummy-poller/Main.hs @@ -0,0 +1,56 @@ +{-# LANGUAGE OverloadedRecordDot #-} +{-# LANGUAGE OverloadedStrings #-} +{-# LANGUAGE TemplateHaskell #-} + +import Control.Monad (forM_) +import Data.Function ((&)) +import Data.Text (Text, pack) +import Effectful (Eff, (:>), runEff) +import Effectful.Concurrent (Concurrent, runConcurrent, threadDelay) +import Effectful.Log (Log, localDomain, logInfo_, runLog) +import Effectful.Reader.Static (Reader, asks, runReader) +import Effectful.Resource (runResource) +import Hsm.Core.App (launch) +import Hsm.Core.Env (deriveFromYaml) +import Hsm.Core.Zmq.Client (poll, runClient) +import Streamly.Data.Fold qualified as S (drain) +import Streamly.Data.Stream qualified as S (Stream, fold, mapM) +import System.IO.Echo (withoutInputEcho) + +data Env = Env + { name :: Text + , subEps :: [Text] + , topics :: [Text] + , period :: Int + } + +$(deriveFromYaml ''Env) + +handle :: + forall es. (Concurrent :> es, Log :> es, Reader Env :> es) + => S.Stream (Eff es) [Int] + -> Eff es () +handle = + S.fold S.drain . S.mapM (\p -> asks period >>= threadDelay >> handler p) + where + receiverDomain :: Text + receiverDomain = "receiver" + -- + handler :: [Int] -> Eff es () + handler [] = localDomain receiverDomain $ logInfo_ "No pulse received yet" + handler ps = + forM_ ps $ \p -> + localDomain receiverDomain + $ logInfo_ + $ "Received pulse #" <> pack (show p) + +main :: IO () +main = + launch @Env "dummy-poller" withoutInputEcho $ \env logger level -> + (poll & handle) + & runClient @Env + & runConcurrent + & runLog env.name logger level + & runReader env + & runResource + & runEff diff --git a/hsm-dummy-poller/hsm-dummy-poller.cabal b/hsm-dummy-poller/hsm-dummy-poller.cabal new file mode 100644 index 0000000..801cf68 --- /dev/null +++ b/hsm-dummy-poller/hsm-dummy-poller.cabal @@ -0,0 +1,25 @@ +cabal-version: 3.4 +author: Paul Oliver +build-type: Simple +maintainer: contact@pauloliver.dev +name: hsm-dummy-poller +version: 0.1.0.0 + +executable dummy-poller + build-depends: + , base + , echo + , effectful + , hsm-core + , log-effectful + , resourcet-effectful + , streamly-core + , text + + main-is: Main.hs + ghc-options: -Wall -Wunused-packages + + if !arch(x86_64) + ghc-options: -optl=-mno-fix-cortex-a53-835769 + + default-language: GHC2021 |