aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--server/src/Thermoprint/Server.hs14
1 files changed, 7 insertions, 7 deletions
diff --git a/server/src/Thermoprint/Server.hs b/server/src/Thermoprint/Server.hs
index 3d0e97e..7767c12 100644
--- a/server/src/Thermoprint/Server.hs
+++ b/server/src/Thermoprint/Server.hs
@@ -64,6 +64,13 @@ instance Default Config where
64 , printers = Map.empty 64 , printers = Map.empty
65 } 65 }
66 66
67withPrinters :: MonadResource m => Config -> [m PrinterMethod] -> m Config
68-- ^ Add a list of printers to a 'Config'
69withPrinters cfg pss = (\map -> cfg { printers = map }) <$> foldlM (\map spec -> Map.insert (nextKey map) <$> printer spec <*> pure map) Map.empty pss
70 where
71 nextKey map
72 | Map.null map = 0
73 | otherwise = succ . fst $ Map.findMin map
67 74
68thermoprintServer :: ( MonadLoggerIO m 75thermoprintServer :: ( MonadLoggerIO m
69 , MonadReader ConnectionPool m 76 , MonadReader ConnectionPool m
@@ -83,10 +90,3 @@ thermoprintServer io = Dyre.wrapMain $ Dyre.defaultParams
83 mapM_ ($(logWarnS) "DB") =<< runSqlPool (runMigrationSilent migrateAll) =<< ask 90 mapM_ ($(logWarnS) "DB") =<< runSqlPool (runMigrationSilent migrateAll) =<< ask
84 forM_ printers $ resourceForkIO . runPrinter 91 forM_ printers $ resourceForkIO . runPrinter
85 liftIO . Warp.runSettings warpSettings . serve thermoprintAPI . flip enter API.thermoprintServer =<< handlerNat printers 92 liftIO . Warp.runSettings warpSettings . serve thermoprintAPI . flip enter API.thermoprintServer =<< handlerNat printers
86
87withPrinters :: MonadResource m => Config -> [m PrinterMethod] -> m Config
88withPrinters cfg pss = (\map -> cfg { printers = map }) <$> foldlM (\map spec -> Map.insert (nextKey map) <$> printer spec <*> pure map) Map.empty pss
89 where
90 nextKey map
91 | Map.null map = 0
92 | otherwise = succ . fst $ Map.findMin map