Skip to content

Commit

Permalink
add transaction utilities
Browse files Browse the repository at this point in the history
  • Loading branch information
chris-martin committed Jan 10, 2025
1 parent 2d22fee commit 83b8847
Show file tree
Hide file tree
Showing 8 changed files with 56 additions and 23 deletions.
1 change: 0 additions & 1 deletion .envrc

This file was deleted.

1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,4 @@
stack-*.lock
stack.*.lock
.direnv
.envrc
13 changes: 9 additions & 4 deletions persistent-sql-lifted/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
## [_Unreleased_](https://github.com/freckle/persistent-sql-lifted/compare/persistent-sql-lifted-v0.1.0.0...main)
## [_Unreleased_](https://github.com/freckle/persistent-sql-lifted/compare/persistent-sql-lifted-v0.1.1.0...main)

## [v0.0.0.1](https://github.com/freckle/freckle-app/compare/persistent-sql-lifted-v0.0.0.0...persistent-sql-lifted-v0.1.0.0)
## [v0.1.1.0](https://github.com/freckle/persistent-sql-lifted/compare/persistent-sql-lifted-v0.1.0.0...persistent-sql-lifted-v0.1.1.0)

Major expansion, adding query runners for Persistent and Esqueleto.
New:

## [v0.0.0.0](https://github.com/freckle/freckle-app/tree/persistent-sql-lifted-v0.0.0.0/persistent-sql-lifted)
- `transactionSave`
- `transactionSaveWithIsolation`
- `transactionUndo`
- `transactionUndoWithIsolation`

## [v0.1.0.0](https://github.com/freckle/persistent-sql-lifted/tree/persistent-sql-lifted-v0.0.0.0/persistent-sql-lifted)

First release, sprouted from `freckle-app-1.20.3.0`.
12 changes: 7 additions & 5 deletions persistent-sql-lifted/library/Database/Persist/Sql/Lifted.hs
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
{-# LANGUAGE CPP #-}

-- |
--
-- Re-exports from:
Expand Down Expand Up @@ -85,6 +83,12 @@ module Database.Persist.Sql.Lifted
, deleteWhere
, deleteCount

-- * Transactions
, transactionSave
, transactionSaveWithIsolation
, transactionUndo
, transactionUndoWithIsolation

-- * Rendering queries to text
, renderQueryDelete
, renderQueryInsertInto
Expand All @@ -93,9 +97,7 @@ module Database.Persist.Sql.Lifted
, renderQueryUpdate
) where

#if MIN_VERSION_base(4,17,0)
import Data.Type.Equality (type (~))
#endif
import Data.Type.Equality.Compat
import Database.Persist (Key, PersistEntity (PersistEntityBackend), Update)
import Database.Persist.Sql.Lifted.Core
import Database.Persist.Sql.Lifted.Esqueleto
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
{-# LANGUAGE CPP #-}

-- | Wrappers that apply 'liftSql' to Esqueleto utilities of the same name.
module Database.Persist.Sql.Lifted.Esqueleto
( delete
Expand All @@ -22,9 +20,7 @@ import Data.Function (($))
import Data.Int (Int64)
import Data.Maybe (Maybe)
import Data.Text (Text)
#if MIN_VERSION_base(4,17,0)
import Data.Type.Equality (type (~))
#endif
import Data.Type.Equality.Compat
import Database.Esqueleto.Experimental
( Entity
, PersistEntity (Key, PersistEntityBackend)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
{-# LANGUAGE CPP #-}

-- | Wrappers that apply 'liftSql' to Persistent utilities of the same name.
module Database.Persist.Sql.Lifted.Persistent
( checkUnique
Expand Down Expand Up @@ -37,6 +35,10 @@ module Database.Persist.Sql.Lifted.Persistent
, selectKeys
, selectKeysList
, selectList
, transactionSave
, transactionSaveWithIsolation
, transactionUndo
, transactionUndoWithIsolation
, update
, updateGet
, updateWhere
Expand All @@ -52,9 +54,7 @@ import Data.Function (($))
import Data.Int (Int)
import Data.Map.Strict (Map)
import Data.Maybe (Maybe)
#if MIN_VERSION_base(4,17,0)
import Data.Type.Equality (type (~))
#endif
import Data.Type.Equality.Compat
import Database.Persist
( AtLeastOneUniqueKey
, Entity
Expand All @@ -66,6 +66,8 @@ import Database.Persist
)
import Database.Persist.Class qualified as P
import Database.Persist.Class.PersistEntity (SafeToInsert)
import Database.Persist.Sql (IsolationLevel)
import Database.Persist.Sql qualified as P
import Database.Persist.Sql.Lifted.Core (MonadSqlBackend, SqlBackend, liftSql)
import GHC.Stack (HasCallStack)

Expand Down Expand Up @@ -557,6 +559,32 @@ selectList
-- ^ Entities corresponding to the filters and options provided
selectList fs os = liftSql $ P.selectList fs os

-- | Commit the current transaction and begin a new one
transactionSave :: forall m. (MonadSqlBackend m, HasCallStack) => m ()
transactionSave = liftSql P.transactionSave

-- | Commit the current transaction and begin a new one
transactionSaveWithIsolation
:: forall m
. (MonadSqlBackend m, HasCallStack)
=> IsolationLevel
-- ^ Isolation level
-> m ()
transactionSaveWithIsolation il = liftSql $ transactionSaveWithIsolation il

-- | Roll back the current transaction and begin a new one
transactionUndo :: forall m. (MonadSqlBackend m, HasCallStack) => m ()
transactionUndo = liftSql transactionUndo

-- | Roll back the current transaction and begin a new one
transactionUndoWithIsolation
:: forall m
. (MonadSqlBackend m, HasCallStack)
=> IsolationLevel
-- ^ Isolation level
-> m ()
transactionUndoWithIsolation il = liftSql $ transactionUndoWithIsolation il

-- | Update individual fields on a specific record
update
:: forall a m
Expand Down
3 changes: 2 additions & 1 deletion persistent-sql-lifted/package.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
name: persistent-sql-lifted
version: 0.1.0.0
version: 0.1.1.0

maintainer: Freckle Education
category: Database
Expand Down Expand Up @@ -59,6 +59,7 @@ library:
source-dirs: library
dependencies:
- annotated-exception
- base-compat
- conduit
- containers
- esqueleto
Expand Down
5 changes: 3 additions & 2 deletions persistent-sql-lifted/persistent-sql-lifted.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,10 @@ cabal-version: 1.18
-- see: https://github.com/sol/hpack

name: persistent-sql-lifted
version: 0.1.0.0
version: 0.1.1.0
synopsis: Monad classes for running queries with Persistent and Esqueleto
description: This package introduces two classes: MonadSqlBackend for monadic contexts in
which a SqlBackend is available, and MonadSqlBackend for contexts in which we
which a SqlBackend is available, and MonadSqlTx for contexts in which we
can execute a SQL transaction.
.
Additionally, this package provides variants of query-running utilities from
Expand Down Expand Up @@ -55,6 +55,7 @@ library
build-depends:
annotated-exception
, base <5
, base-compat
, conduit
, containers
, esqueleto
Expand Down

0 comments on commit 83b8847

Please sign in to comment.