aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--server/src/Thermoprint/Server/Database/Instances.hs22
-rw-r--r--server/thermoprint-server.cabal2
-rw-r--r--server/thermoprint-server.nix14
3 files changed, 8 insertions, 30 deletions
diff --git a/server/src/Thermoprint/Server/Database/Instances.hs b/server/src/Thermoprint/Server/Database/Instances.hs
index f5c22fd..e54f90e 100644
--- a/server/src/Thermoprint/Server/Database/Instances.hs
+++ b/server/src/Thermoprint/Server/Database/Instances.hs
@@ -6,28 +6,8 @@ module Thermoprint.Server.Database.Instances where
6 6
7import Thermoprint.API (Printout, JobStatus, PrintingError) 7import Thermoprint.API (Printout, JobStatus, PrintingError)
8 8
9import Database.Persist (PersistField(..))
10import Database.Persist.Sql (PersistFieldSql(..))
11import Database.Persist.TH 9import Database.Persist.TH
12 10
13import Control.Monad ((<=<)) 11derivePersistFieldJSON "Printout"
14import Data.Bifunctor
15
16import qualified Data.Aeson as JSON (encode, eitherDecodeStrict')
17
18import Data.ByteString (ByteString)
19import qualified Data.ByteString.Lazy as LBS (toStrict)
20import qualified Data.Text as T (pack)
21
22import 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
25instance PersistField Printout where
26 toPersistValue = toPersistValue . LBS.toStrict . JSON.encode
27 fromPersistValue = first T.pack . JSON.eitherDecodeStrict' <=< fromPersistValue
28
29instance PersistFieldSql Printout where
30 sqlType _ = sqlType (Proxy :: Proxy ByteString)
31
32derivePersistField "PrintingError" 12derivePersistField "PrintingError"
33derivePersistField "JobStatus" 13derivePersistField "JobStatus"
diff --git a/server/thermoprint-server.cabal b/server/thermoprint-server.cabal
index bd22482..8862255 100644
--- a/server/thermoprint-server.cabal
+++ b/server/thermoprint-server.cabal
@@ -40,8 +40,6 @@ library
40 , either >=4.4.1 && <5 40 , either >=4.4.1 && <5
41 , text >=1.2.1 && <2 41 , text >=1.2.1 && <2
42 , stm >=2.4.4 && <3 42 , stm >=2.4.4 && <3
43 , aeson >=0.9.0 && <1
44 , bytestring >=0.10.6 && <1
45 hs-source-dirs: src 43 hs-source-dirs: src
46 default-language: Haskell2010 44 default-language: Haskell2010
47 45
diff --git a/server/thermoprint-server.nix b/server/thermoprint-server.nix
index 0f85c9d..57e94a3 100644
--- a/server/thermoprint-server.nix
+++ b/server/thermoprint-server.nix
@@ -1,7 +1,7 @@
1{ mkDerivation, aeson, base, bytestring, containers 1{ mkDerivation, base, containers, data-default-class, dyre, either
2, data-default-class, dyre, either, monad-logger, mtl, persistent 2, monad-logger, mtl, persistent, persistent-sqlite
3, persistent-sqlite, persistent-template, resourcet, servant-server 3, persistent-template, resourcet, servant-server, stdenv, stm, text
4, stdenv, stm, text, thermoprint-spec, transformers, wai, warp 4, thermoprint-spec, transformers, wai, warp
5}: 5}:
6mkDerivation { 6mkDerivation {
7 pname = "thermoprint-server"; 7 pname = "thermoprint-server";
@@ -10,9 +10,9 @@ mkDerivation {
10 isLibrary = true; 10 isLibrary = true;
11 isExecutable = true; 11 isExecutable = true;
12 libraryHaskellDepends = [ 12 libraryHaskellDepends = [
13 aeson base bytestring containers data-default-class dyre either 13 base containers data-default-class dyre either monad-logger mtl
14 monad-logger mtl persistent persistent-template resourcet 14 persistent persistent-template resourcet servant-server stm text
15 servant-server stm text thermoprint-spec transformers wai warp 15 thermoprint-spec transformers wai warp
16 ]; 16 ];
17 executableHaskellDepends = [ 17 executableHaskellDepends = [
18 base monad-logger mtl persistent-sqlite resourcet 18 base monad-logger mtl persistent-sqlite resourcet