aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/core/database/Dal.scala
diff options
context:
space:
mode:
authorVlad Uspensky <v.uspenskiy@icloud.com>2017-04-11 16:21:33 -0700
committerGitHub <noreply@github.com>2017-04-11 16:21:33 -0700
commitc890011c2dba22f52b007848d6d41e8acde6d38d (patch)
treeaccdaf6c1450745bdbac97a7ba69d46130ad00cc /src/main/scala/xyz/driver/core/database/Dal.scala
parent686d4e2845bd6335d998dbc33f6a7d1ae49191a2 (diff)
parentf92036251d778a6c7a0445a46c1fdda930e19cfc (diff)
downloaddriver-core-c890011c2dba22f52b007848d6d41e8acde6d38d.tar.gz
driver-core-c890011c2dba22f52b007848d6d41e8acde6d38d.tar.bz2
driver-core-c890011c2dba22f52b007848d6d41e8acde6d38d.zip
Merge pull request #32 from drivergroup/SCALA-2v0.11.1
Custom Swagger Json Converter for SCALA-2
Diffstat (limited to 'src/main/scala/xyz/driver/core/database/Dal.scala')
-rw-r--r--src/main/scala/xyz/driver/core/database/Dal.scala8
1 files changed, 7 insertions, 1 deletions
diff --git a/src/main/scala/xyz/driver/core/database/Dal.scala b/src/main/scala/xyz/driver/core/database/Dal.scala
index d863e50..1bc3827 100644
--- a/src/main/scala/xyz/driver/core/database/Dal.scala
+++ b/src/main/scala/xyz/driver/core/database/Dal.scala
@@ -3,7 +3,7 @@ package xyz.driver.core.database
import slick.lifted.AbstractTable
import scala.concurrent.{ExecutionContext, Future}
-import scalaz.{ListT, Monad}
+import scalaz.{ListT, Monad, OptionT}
import scalaz.std.scalaFuture._
trait Dal {
@@ -13,6 +13,12 @@ trait Dal {
def execute[D](operations: T[D]): Future[D]
def noAction[V](v: V): T[V]
def customAction[R](action: => Future[R]): T[R]
+
+ def execute[D](action: => OptionT[T, D]): OptionT[Future, D] =
+ action.mapT(execute[Option[D]])
+
+ def customAction[R](action: => OptionT[Future, R]): OptionT[T, R] =
+ OptionT[T, R](customAction(action.run))
}
class FutureDal(executionContext: ExecutionContext) extends Dal {