diff options
author | Gregor Kleen <gkleen@yggdrasil.li> | 2016-01-23 12:52:15 +0000 |
---|---|---|
committer | Gregor Kleen <gkleen@yggdrasil.li> | 2016-01-23 12:52:15 +0000 |
commit | b508a6bd35d28260f307acf8ffde8b7acf843a09 (patch) | |
tree | f3f18a35cf66fa897d93c874a6fc05672239d7ab /server/src/Thermoprint/Server/Database | |
parent | a8e274ee830bb6f72609295803d8ee37a36ea481 (diff) | |
download | thermoprint-b508a6bd35d28260f307acf8ffde8b7acf843a09.tar thermoprint-b508a6bd35d28260f307acf8ffde8b7acf843a09.tar.gz thermoprint-b508a6bd35d28260f307acf8ffde8b7acf843a09.tar.bz2 thermoprint-b508a6bd35d28260f307acf8ffde8b7acf843a09.tar.xz thermoprint-b508a6bd35d28260f307acf8ffde8b7acf843a09.zip |
Db layout, persistent-inst. & printer framework
Diffstat (limited to 'server/src/Thermoprint/Server/Database')
-rw-r--r-- | server/src/Thermoprint/Server/Database/Instances.hs | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/server/src/Thermoprint/Server/Database/Instances.hs b/server/src/Thermoprint/Server/Database/Instances.hs new file mode 100644 index 0000000..f5c22fd --- /dev/null +++ b/server/src/Thermoprint/Server/Database/Instances.hs | |||
@@ -0,0 +1,33 @@ | |||
1 | {-# LANGUAGE TemplateHaskell #-} | ||
2 | {-# LANGUAGE TypeSynonymInstances #-} | ||
3 | {-# LANGUAGE FlexibleInstances #-} | ||
4 | |||
5 | module Thermoprint.Server.Database.Instances where | ||
6 | |||
7 | import Thermoprint.API (Printout, JobStatus, PrintingError) | ||
8 | |||
9 | import Database.Persist (PersistField(..)) | ||
10 | import Database.Persist.Sql (PersistFieldSql(..)) | ||
11 | import Database.Persist.TH | ||
12 | |||
13 | import Control.Monad ((<=<)) | ||
14 | import Data.Bifunctor | ||
15 | |||
16 | import qualified Data.Aeson as JSON (encode, eitherDecodeStrict') | ||
17 | |||
18 | import Data.ByteString (ByteString) | ||
19 | import qualified Data.ByteString.Lazy as LBS (toStrict) | ||
20 | import qualified Data.Text as T (pack) | ||
21 | |||
22 | import Data.Proxy | ||
23 | |||
24 | -- | Instead of deriving an instance using 'derivePersistField', which would use 'show' and 'read', we write our own by hand in order to use json | ||
25 | instance PersistField Printout where | ||
26 | toPersistValue = toPersistValue . LBS.toStrict . JSON.encode | ||
27 | fromPersistValue = first T.pack . JSON.eitherDecodeStrict' <=< fromPersistValue | ||
28 | |||
29 | instance PersistFieldSql Printout where | ||
30 | sqlType _ = sqlType (Proxy :: Proxy ByteString) | ||
31 | |||
32 | derivePersistField "PrintingError" | ||
33 | derivePersistField "JobStatus" | ||