aboutsummaryrefslogtreecommitdiff
path: root/server/src/Thermoprint
diff options
context:
space:
mode:
Diffstat (limited to 'server/src/Thermoprint')
-rw-r--r--server/src/Thermoprint/Server/API.hs22
-rw-r--r--server/src/Thermoprint/Server/Database.hs15
2 files changed, 20 insertions, 17 deletions
diff --git a/server/src/Thermoprint/Server/API.hs b/server/src/Thermoprint/Server/API.hs
index 9e28d58..66a594b 100644
--- a/server/src/Thermoprint/Server/API.hs
+++ b/server/src/Thermoprint/Server/API.hs
@@ -106,14 +106,10 @@ queue' = fmap force . liftIO . readTVarIO . queue
106 106
107extractJobs :: (PrinterId, Queue) -> Seq (API.JobId, JobStatus) 107extractJobs :: (PrinterId, Queue) -> Seq (API.JobId, JobStatus)
108-- ^ Get an API-compatible list of all jobs from a 'Printer' 'Queue' 108-- ^ Get an API-compatible list of all jobs from a 'Printer' 'Queue'
109extractJobs (pId, Queue pending current history) = mconcat [ fmap (, Queued pId) pending' 109extractJobs (pId, Queue pending current history) = mconcat [ fmap ((, Queued pId) . castId) pending
110 , maybe Seq.empty Seq.singleton (fmap (, Printing pId) current') 110 , maybe Seq.empty Seq.singleton $ fmap ((, Printing pId) . castId) current
111 , fmap (second $ maybe Done Failed) history' 111 , fmap (bimap castId $ maybe Done Failed) history
112 ] 112 ]
113 where
114 pending' = fmap (castId' . unJobKey) pending
115 current' = fmap (castId' . unJobKey) current
116 history' = fmap (first $ castId' . unJobKey) history
117 113
118listPrinters :: Handler (Map PrinterId PrinterStatus) 114listPrinters :: Handler (Map PrinterId PrinterStatus)
119listPrinters = fmap toStatus <$> (mapM (liftIO . readTVarIO . queue) . printers =<< ask) 115listPrinters = fmap toStatus <$> (mapM (liftIO . readTVarIO . queue) . printers =<< ask)
@@ -122,13 +118,13 @@ listPrinters = fmap toStatus <$> (mapM (liftIO . readTVarIO . queue) . printers
122 toStatus (Queue _ (Just id) _) = Busy . castId $ fromSqlKey id 118 toStatus (Queue _ (Just id) _) = Busy . castId $ fromSqlKey id
123 119
124queueJob :: Maybe PrinterId -> Printout -> Handler API.JobId 120queueJob :: Maybe PrinterId -> Printout -> Handler API.JobId
125queueJob pId printout = lift . fmap (castId' . unJobKey) . withReaderT sqlPool . addToQueue printout . snd =<< lookupPrinter pId 121queueJob pId printout = lift . fmap castId . withReaderT sqlPool . addToQueue printout . snd =<< lookupPrinter pId
126 122
127printerStatus :: PrinterId -> Handler PrinterStatus 123printerStatus :: PrinterId -> Handler PrinterStatus
128printerStatus = fmap queueToStatus . queue' . snd <=< lookupPrinter . Just 124printerStatus = fmap queueToStatus . queue' . snd <=< lookupPrinter . Just
129 where 125 where
130 queueToStatus (Queue _ Nothing _) = Available 126 queueToStatus (Queue _ Nothing _) = Available
131 queueToStatus (Queue _ (Just id) _) = Busy . castId' $ unJobKey id 127 queueToStatus (Queue _ (Just id) _) = Busy $ castId id
132 128
133listJobs :: Maybe PrinterId -> Maybe API.JobId -> Maybe API.JobId -> Handler (Seq (API.JobId, JobStatus)) 129listJobs :: Maybe PrinterId -> Maybe API.JobId -> Maybe API.JobId -> Handler (Seq (API.JobId, JobStatus))
134listJobs Nothing minId maxId = fmap mconcat . mapM (\pId -> listJobs (Just pId) minId maxId) =<< asks (Map.keys . printers) 130listJobs Nothing minId maxId = fmap mconcat . mapM (\pId -> listJobs (Just pId) minId maxId) =<< asks (Map.keys . printers)
@@ -137,7 +133,7 @@ listJobs pId minId maxId = fmap (filterJobs . extractJobs) . (\(a, b) -> (,)
137 filterJobs = Seq.filter (\(id, _) -> maybe True (< id) minId && maybe True (> id) maxId) 133 filterJobs = Seq.filter (\(id, _) -> maybe True (< id) minId && maybe True (> id) maxId)
138 134
139getJob :: API.JobId -> Handler Printout 135getJob :: API.JobId -> Handler Printout
140getJob jobId = fmap jobContent . maybe (left err404) return =<< runSqlPool (get . JobKey . SqlBackendKey $ castId jobId) =<< asks sqlPool 136getJob jobId = fmap jobContent . maybe (left err404) return =<< runSqlPool (get $ castId jobId) =<< asks sqlPool
141 137
142jobStatus :: API.JobId -> Handler JobStatus 138jobStatus :: API.JobId -> Handler JobStatus
143jobStatus jobId = maybe (left err404) return . lookup jobId . toList =<< listJobs Nothing Nothing Nothing 139jobStatus jobId = maybe (left err404) return . lookup jobId . toList =<< listJobs Nothing Nothing Nothing
@@ -147,10 +143,10 @@ deleteJob jobId = do
147 printerIds <- asks (Map.keys . printers) 143 printerIds <- asks (Map.keys . printers)
148 forM_ printerIds $ \pId -> do 144 forM_ printerIds $ \pId -> do
149 (pId', p) <- lookupPrinter $ Just pId 145 (pId', p) <- lookupPrinter $ Just pId
150 -- liftIO . atomically . modifyTVar' (queue p) $ force . removeNeedle 146 found <- liftIO . atomically $ do
147 current <- readTVar $ queue p
148 modifyTVar' (queue p) $ force . (\q@(Queue pending _ _) -> q { pending = Seq.filter (/= castId jobId) pending })
151 undefined 149 undefined
152 where
153 needle = JobKey . SqlBackendKey $ castId jobId
154 150
155listDrafts :: Handler (Map API.DraftId (Maybe DraftTitle)) 151listDrafts :: Handler (Map API.DraftId (Maybe DraftTitle))
156listDrafts = return undefined 152listDrafts = return undefined
diff --git a/server/src/Thermoprint/Server/Database.hs b/server/src/Thermoprint/Server/Database.hs
index 1e01680..5bd4512 100644
--- a/server/src/Thermoprint/Server/Database.hs
+++ b/server/src/Thermoprint/Server/Database.hs
@@ -4,6 +4,7 @@
4{-# LANGUAGE TypeFamilies #-} 4{-# LANGUAGE TypeFamilies #-}
5{-# LANGUAGE ExistentialQuantification #-} 5{-# LANGUAGE ExistentialQuantification #-}
6{-# LANGUAGE GeneralizedNewtypeDeriving #-} 6{-# LANGUAGE GeneralizedNewtypeDeriving #-}
7{-# LANGUAGE StandaloneDeriving #-}
7{-# LANGUAGE FlexibleInstances #-} 8{-# LANGUAGE FlexibleInstances #-}
8 9
9module Thermoprint.Server.Database 10module Thermoprint.Server.Database
@@ -11,7 +12,6 @@ module Thermoprint.Server.Database
11 , Draft(..), DraftId 12 , Draft(..), DraftId
12 , Key(..) 13 , Key(..)
13 , migrateAll 14 , migrateAll
14 , castId'
15 ) where 15 ) where
16 16
17import Control.DeepSeq 17import Control.DeepSeq
@@ -32,8 +32,15 @@ Draft
32 content Printout 32 content Printout
33|] 33|]
34 34
35deriving instance Enum (Key Job)
36deriving instance Num (Key Job)
37deriving instance Real (Key Job)
38deriving instance Integral (Key Job)
39
40deriving instance Enum (Key Draft)
41deriving instance Num (Key Draft)
42deriving instance Real (Key Draft)
43deriving instance Integral (Key Draft)
44
35instance NFData (Key Job) where 45instance NFData (Key Job) where
36 rnf = rnf . unSqlBackendKey . unJobKey 46 rnf = rnf . unSqlBackendKey . unJobKey
37
38castId' :: Enum b => BackendKey SqlBackend -> b
39castId' = castId . unSqlBackendKey