diff options
Diffstat (limited to 'src/main/scala')
-rw-r--r-- | src/main/scala/xyz/driver/restquery/db/SlickQueryBuilder.scala | 10 | ||||
-rw-r--r-- | src/main/scala/xyz/driver/restquery/rest/parsers/SearchFilterParser.scala | 13 |
2 files changed, 17 insertions, 6 deletions
diff --git a/src/main/scala/xyz/driver/restquery/db/SlickQueryBuilder.scala b/src/main/scala/xyz/driver/restquery/db/SlickQueryBuilder.scala index 2947b3c..f7b5a7f 100644 --- a/src/main/scala/xyz/driver/restquery/db/SlickQueryBuilder.scala +++ b/src/main/scala/xyz/driver/restquery/db/SlickQueryBuilder.scala @@ -60,10 +60,12 @@ final case class SlickPostgresQueryBuilderParameters( def limitToSql()(implicit profile: JdbcProfile): SQLActionBuilder = { import profile.api._ - pagination.map { pagination => - val startFrom = (pagination.pageNumber - 1) * pagination.pageSize - sql"limit #${pagination.pageSize} OFFSET #$startFrom" - } getOrElse (sql"") + pagination + .map { pagination => + val startFrom = (pagination.pageNumber - 1) * pagination.pageSize + sql"limit #${pagination.pageSize} OFFSET #$startFrom" + } + .getOrElse(sql"") } val qs = """"""" diff --git a/src/main/scala/xyz/driver/restquery/rest/parsers/SearchFilterParser.scala b/src/main/scala/xyz/driver/restquery/rest/parsers/SearchFilterParser.scala index 23cb2f0..0d351e9 100644 --- a/src/main/scala/xyz/driver/restquery/rest/parsers/SearchFilterParser.scala +++ b/src/main/scala/xyz/driver/restquery/rest/parsers/SearchFilterParser.scala @@ -1,5 +1,6 @@ package xyz.driver.restquery.rest.parsers +import java.time.LocalDate import java.util.UUID import fastparse.all._ @@ -121,9 +122,16 @@ object SearchFilterParser { UUID.fromString(s"$group1-$group2-$group3-$group4-$group5") } + private val dateParser: Parser[LocalDate] = + P(CharIn('0' to '9').rep(min = 4).! ~ "-" ~ CharIn('0' to '9').rep(1).! ~ "-" ~ CharIn('0' to '9').rep(1).!) + .map { + case (year, month, day) => + LocalDate.of(year.toInt, month.toInt, day.toInt) + } + private val binaryAtomParser: Parser[SearchFilterExpr.Atom.Binary] = P( dimensionParser ~ whitespaceParser ~ - ((numericOperatorParser.! ~ whitespaceParser ~ (longParser | numberParser.!) ~ End) | + ((numericOperatorParser.! ~ whitespaceParser ~ (dateParser | longParser | numberParser.!) ~ End) | (commonOperatorParser.! ~ whitespaceParser ~ (uuidParser | booleanParser | AnyChar .rep(min = 1) .!) ~ End)) @@ -134,7 +142,8 @@ object SearchFilterParser { private val nAryAtomParser: Parser[SearchFilterExpr.Atom.NAry] = P( dimensionParser ~ whitespaceParser ~ ( naryOperatorParser ~ whitespaceParser ~ - ((uuidParser.rep(min = 1, sep = ",") ~ End) | + ((dateParser.rep(min = 1, sep = ",") ~ End) | + (uuidParser.rep(min = 1, sep = ",") ~ End) | (longParser.rep(min = 1, sep = ",") ~ End) | (booleanParser.rep(min = 1, sep = ",") ~ End) | (nAryValueParser.!.rep(min = 1, sep = ",") ~ End)) |