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

spray.httpx.unmarshalling.Deserializer.scala Maven / Gradle / Ivy

/*
 * Copyright © 2011-2015 the spray project 
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package spray.httpx.unmarshalling

import scala.util.control.NonFatal

trait Deserializer[A, B] extends (A ⇒ Deserialized[B]) { self ⇒

  def withDefaultValue(defaultValue: B): Deserializer[A, B] =
    new Deserializer[A, B] {
      def apply(value: A) = self(value).left.flatMap {
        case ContentExpected ⇒ Right(defaultValue)
        case error           ⇒ Left(error)
      }
    }
}

object Deserializer extends DeserializerLowerPriorityImplicits
    with BasicUnmarshallers
    with UnmarshallerLifting
    with FromStringDeserializers
    with FormDataUnmarshallers {

  implicit def fromFunction2Converter[A, B](implicit f: A ⇒ B) =
    new Deserializer[A, B] {
      def apply(a: A) = {
        try Right(f(a))
        catch {
          case NonFatal(ex) ⇒ Left(MalformedContent(ex.toString, ex))
        }
      }
    }

  implicit def liftToTargetOption[A, B](implicit converter: Deserializer[A, B]) =
    new Deserializer[A, Option[B]] {
      def apply(value: A) = converter(value) match {
        case Right(a)              ⇒ Right(Some(a))
        case Left(ContentExpected) ⇒ Right(None)
        case Left(error)           ⇒ Left(error)
      }
    }
}

private[unmarshalling] abstract class DeserializerLowerPriorityImplicits {
  implicit def lift2SourceOption[A, B](converter: Deserializer[A, B]) = liftToSourceOption(converter)
  implicit def liftToSourceOption[A, B](implicit converter: Deserializer[A, B]) = {
    new Deserializer[Option[A], B] {
      def apply(value: Option[A]) = value match {
        case Some(a) ⇒ converter(a)
        case None    ⇒ Left(ContentExpected)
      }
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy