From cd1b635b2ae90d9ac2d8b1779183a1fbd8c5fd5c Mon Sep 17 00:00:00 2001 From: vlad Date: Tue, 13 Jun 2017 16:12:20 -0700 Subject: Adding domain entities --- .../driver/pdsuicommon/utils/ServiceUtils.scala | 32 ++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 src/main/scala/xyz/driver/pdsuicommon/utils/ServiceUtils.scala (limited to 'src/main/scala/xyz/driver/pdsuicommon/utils/ServiceUtils.scala') diff --git a/src/main/scala/xyz/driver/pdsuicommon/utils/ServiceUtils.scala b/src/main/scala/xyz/driver/pdsuicommon/utils/ServiceUtils.scala new file mode 100644 index 0000000..979c483 --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuicommon/utils/ServiceUtils.scala @@ -0,0 +1,32 @@ +package xyz.driver.pdsuicommon.utils + +import xyz.driver.pdsuicommon.db.SearchFilterBinaryOperation.Eq +import xyz.driver.pdsuicommon.db.SearchFilterExpr +import xyz.driver.pdsuicommon.db.SearchFilterExpr.{Atom, Dimension} +import xyz.driver.pdsuicommon.logging._ + +import scala.util.{Failure, Success, Try} + +object ServiceUtils extends PhiLogging { + + def findEqFilter(filter: SearchFilterExpr, fieldName: String): Option[SearchFilterExpr] = { + findEqFilter(filter, Dimension(None, fieldName)) + } + + def findEqFilter(filter: SearchFilterExpr, dimension: Dimension): Option[SearchFilterExpr] = { + filter.find { + case Atom.Binary(dimension, Eq, _) => true + case _ => false + } + } + + def convertIdInFilterToLong(value: AnyRef): Option[Long] = { + Try(value.toString.toLong) match { + case Success(id) => + Option(id) + case Failure(e) => + logger.error(phi"Incorrect id format in filter $e") + None + } + } +} -- cgit v1.2.3