From b27ba47906e48e9fc59d65893c71309303f73fc8 Mon Sep 17 00:00:00 2001 From: Kseniya Tomskikh Date: Fri, 27 Oct 2017 12:02:49 +0700 Subject: Restore base repository --- .../pdsuicommon/db/repositories/Repository.scala | 3 ++ .../db/repositories/RepositoryLogging.scala | 62 ++++++++++++++++++++++ 2 files changed, 65 insertions(+) create mode 100644 src/main/scala/xyz/driver/pdsuicommon/db/repositories/Repository.scala create mode 100644 src/main/scala/xyz/driver/pdsuicommon/db/repositories/RepositoryLogging.scala (limited to 'src') diff --git a/src/main/scala/xyz/driver/pdsuicommon/db/repositories/Repository.scala b/src/main/scala/xyz/driver/pdsuicommon/db/repositories/Repository.scala new file mode 100644 index 0000000..e62238e --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuicommon/db/repositories/Repository.scala @@ -0,0 +1,3 @@ +package xyz.driver.pdsuicommon.db.repositories + +trait Repository extends RepositoryLogging diff --git a/src/main/scala/xyz/driver/pdsuicommon/db/repositories/RepositoryLogging.scala b/src/main/scala/xyz/driver/pdsuicommon/db/repositories/RepositoryLogging.scala new file mode 100644 index 0000000..d1ec1da --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuicommon/db/repositories/RepositoryLogging.scala @@ -0,0 +1,62 @@ +package xyz.driver.pdsuicommon.db.repositories + +import xyz.driver.pdsuicommon.logging._ + +trait RepositoryLogging extends PhiLogging { + + protected def logCreatedOne[T](x: T)(implicit toPhiString: T => PhiString): T = { + logger.info(phi"An entity was created: $x") + x + } + + protected def logCreatedMultiple[T <: Iterable[_]](xs: T)(implicit toPhiString: T => PhiString): T = { + if (xs.nonEmpty) { + logger.info(phi"Entities were created: $xs") + } + xs + } + + protected def logUpdatedOne(rowsAffected: Long): Long = { + rowsAffected match { + case 0 => logger.trace(phi"The entity is up to date") + case 1 => logger.info(phi"The entity was updated") + case x => logger.warn(phi"The ${Unsafe(x)} entities were updated") + } + rowsAffected + } + + protected def logUpdatedOneUnimportant(rowsAffected: Long): Long = { + rowsAffected match { + case 0 => logger.trace(phi"The entity is up to date") + case 1 => logger.trace(phi"The entity was updated") + case x => logger.warn(phi"The ${Unsafe(x)} entities were updated") + } + rowsAffected + } + + protected def logUpdatedMultiple(rowsAffected: Long): Long = { + rowsAffected match { + case 0 => logger.trace(phi"All entities are up to date") + case x => logger.info(phi"The ${Unsafe(x)} entities were updated") + } + rowsAffected + } + + protected def logDeletedOne(rowsAffected: Long): Long = { + rowsAffected match { + case 0 => logger.trace(phi"The entity does not exist") + case 1 => logger.info(phi"The entity was deleted") + case x => logger.warn(phi"Deleted ${Unsafe(x)} entities, expected one") + } + rowsAffected + } + + protected def logDeletedMultiple(rowsAffected: Long): Long = { + rowsAffected match { + case 0 => logger.trace(phi"Entities do not exist") + case x => logger.info(phi"Deleted ${Unsafe(x)} entities") + } + rowsAffected + } + +} -- cgit v1.2.3