All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.scalatra.json.JsonValueReader.scala Maven / Gradle / Ivy

package org.scalatra
package json

import org.json4s._
import org.scalatra.util.RicherString._
import org.scalatra.util.ValueReader

import scala.util.control.Exception.allCatch

object JsonValueReader {
  private val separatorBeginning = "."
  private val separatorEnd = ""
}

class JsonValueReader(val data: JValue) extends ValueReader[JValue, JValue] {
  //  type I = T
  import JsonValueReader._

  def read(key: String): Either[String, Option[JValue]] =
    allCatch.withApply(t => Left(t.getMessage)) { Right(readPath(key)) }

  protected def readPath(path: String, subj: JValue = data): Option[JValue] = {
    val partIndex = path.indexOf(separatorBeginning)
    val (part, rest) = if (path.indexOf(separatorBeginning) > -1) path.splitAt(partIndex) else (path, "")
    val realRest = if (rest.nonEmpty) {
      if (separatorEnd.nonBlank) {
        if (rest.size > 1) rest.substring(2) else rest.substring(1)
      } else rest.substring(1)
    } else rest
    if (realRest.isEmpty) {
      get(part, subj)
    } else {
      get(part, subj) flatMap (readPath(realRest, _))
    }
  }

  protected def get(path: String, subj: JValue): Option[JValue] = {
    val jv = subj \ path
    jv match {
      case JNothing => None
      case o => Some(o)
    }
  }
}
trait JsonValueReaderProperty[T] { self: JsonMethods[T] =>

  implicit protected def jsonFormats: Formats
  protected implicit def jsonValueReader(d: JValue): JsonValueReader = new JsonValueReader(d)
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy