Trait/Object

org.scanamo

DynamoFormat

Related Docs: object DynamoFormat | package scanamo

Permalink

trait DynamoFormat[T] extends AnyRef

Type class for defining serialisation to and from DynamoDB's AttributeValue

>>> val listOptionFormat = DynamoFormat[List[Option[Int]]]
>>> listOptionFormat.read(listOptionFormat.write(List(Some(1), None, Some(3))))
Right(List(Some(1), None, Some(3)))

Also supports automatic and semi-automatic derivation for case classes
>>> import org.scanamo.auto._
>>>
>>> case class Farm(animals: List[String])
>>> case class Farmer(name: String, age: Long, farm: Farm)
>>> val farmerF = DynamoFormat[Farmer]
>>> farmerF.read(farmerF.write(Farmer("McDonald", 156L, Farm(List("sheep", "cow")))))
Right(Farmer(McDonald,156,Farm(List(sheep, cow))))

and for sealed trait + case object hierarchies

>>> sealed trait Animal
>>> case object Aardvark extends Animal
>>> case object Zebra extends Animal
>>> case class Pet(name: String, animal: Animal)
>>> val petF = DynamoFormat[Pet]
>>> petF.read(petF.write(Pet("Amy", Aardvark)))
Right(Pet(Amy,Aardvark))

>>> petF.read(petF.write(Pet("Zebediah", Zebra)))
Right(Pet(Zebediah,Zebra))

Problems reading a value are detailed

>>> import cats.syntax.either._

>>> case class Developer(name: String, age: String, problems: Int)
>>> val invalid = DynamoFormat[Farmer].read(DynamoFormat[Developer].write(Developer("Alice", "none of your business", 99)))
>>> invalid
Left(InvalidPropertiesError(NonEmptyList((age,NoPropertyOfType(N,DynString(none of your business))), (farm,MissingProperty))))

>>> invalid.leftMap(cats.Show[error.DynamoReadError].show)
Left('age': not of type: 'N' was 'DynString(none of your business)', 'farm': missing)

Custom formats can often be most easily defined using DynamoFormat.coercedXmap, DynamoFormat.xmap or DynamoFormat.iso

Linear Supertypes
Known Subclasses
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. DynamoFormat
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Abstract Value Members

  1. abstract def read(av: DynamoValue): Either[DynamoReadError, T]

    Permalink
  2. abstract def write(t: T): DynamoValue

    Permalink

Concrete Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  5. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  6. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  7. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  8. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  9. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  10. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  11. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  12. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  13. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  14. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  15. def read(av: AttributeValue): Either[DynamoReadError, T]

    Permalink
  16. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  17. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  18. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  19. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  20. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped