aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKseniya Tomskikh <ktomskih@datamonsters.co>2017-10-27 12:02:49 +0700
committerKseniya Tomskikh <ktomskih@datamonsters.co>2017-10-27 12:10:50 +0700
commitb27ba47906e48e9fc59d65893c71309303f73fc8 (patch)
tree6b18ea803640792c8e0aa4e96eebd3060811ffb5
parente3b8e6ce8f659bff81b9a4bc3a79e3d2c3dd734f (diff)
downloadrest-query-b27ba47906e48e9fc59d65893c71309303f73fc8.tar.gz
rest-query-b27ba47906e48e9fc59d65893c71309303f73fc8.tar.bz2
rest-query-b27ba47906e48e9fc59d65893c71309303f73fc8.zip
Restore base repository
-rw-r--r--src/main/scala/xyz/driver/pdsuicommon/db/repositories/Repository.scala3
-rw-r--r--src/main/scala/xyz/driver/pdsuicommon/db/repositories/RepositoryLogging.scala62
2 files changed, 65 insertions, 0 deletions
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
+ }
+
+}