aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuicommon/parsers/PaginationParser.scala
blob: b59b1a5f0e4a51cfd2776ab7bcf312a19a87a0ef (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
package xyz.driver.pdsuicommon.parsers

import xyz.driver.pdsuicommon.db._
import scala.util._

object PaginationParser {

  @deprecated("play-akka transition", "0")
  def parse(query: Map[String, Seq[String]]): Try[Pagination] =
    parse(query.toSeq.flatMap {
      case (key, values) =>
        values.map(value => key -> value)
    })

  def parse(query: Seq[(String, String)]): Try[Pagination] = {
    val IntString = """(\d+)""".r
    def validate(field: String, default: Int) = query.collectFirst { case (`field`, size) => size } match {
      case Some(IntString(x)) if x.toInt > 0 => x.toInt
      case Some(IntString(x))                => throw new ParseQueryArgException((field, s"must greater than zero (found $x)"))
      case Some(str)                         => throw new ParseQueryArgException((field, s"must be an integer (found $str)"))
      case None                              => default
    }

    Try {
      Pagination(validate("pageSize", Pagination.Default.pageSize),
                 validate("pageNumber", Pagination.Default.pageNumber))
    }
  }
}