Doobie
Install
libraryDependencies += "dev.hnaderi" %% "edomata-doobie" % "0.12.3"
or for integrated modules:
libraryDependencies += "dev.hnaderi" %% "edomata-doobie-circe" % "0.12.3"
libraryDependencies += "dev.hnaderi" %% "edomata-doobie-upickle" % "0.12.3"
Note that doobie is built on top of JDBC which can't be used in javascript obviously, and this packages are available for JVM only.
Imports
import edomata.doobie.*
Defining codecs
when event sourcing:
given BackendCodec[Event] = CirceCodec.jsonb // or .json
given BackendCodec[Notification] = CirceCodec.jsonb
when using cqrs style:
given BackendCodec[State] = CirceCodec.jsonb
Persisted snapshots (event sourcing only)
if you want to use persisted snapshots, you need to provide codec for your state model too.
given BackendCodec[State] = CirceCodec.jsonb
Compiling application to a service
You need to use a driver to build your backend, there are two doobie drivers available:
DoobieDriver
event sourcing driverDoobieCQRSDriver
cqrs driver
val app = ??? // your application from previous chapter
val trx : Transactor[IO] = ??? // create your Transactor
val buildBackend = Backend
.builder(AccountService) // 1
.use(DoobieDriver("domainname", trx)) // 2
// .persistedSnapshot(maxInMem = 200) // 3
.inMemSnapshot(200)
.withRetryConfig(retryInitialDelay = 2.seconds)
.build
val application = buildBackend.use { backend =>
val service = backend.compile(app)
// compiling your application will give you a function
// that takes a messages and does everything required,
// and returns result.
service(
CommandMessage("abc", Instant.now, "a", "receive")
).flatMap(IO.println)
}
- use your domain as described in previous chapter.
domainname
is used as schema name in postgres.- feel free to navigate available options in backend builder.