ZIO Schema is a ZIO-based library for modeling the schema of data structures as first-class values.
With schema descriptions that can be automatically derived for case classes and sealed traits, ZIO Schema provide powerful features for free:
- Codecs for any supported protocol (JSON, protobuf, etc.), so data structures can be serialized and deserialized in a principled way
- Diffing, patching, merging, and other generic-data-based operations
- Migration of data structures from one schema to another compatible schema
- Derivation of arbitrary type classes (
Ord, etc.) from the structure of the data
When your data structures need to be serialized, deserialized, persisted, or transported across the wire, then ZIO Schema lets you focus on data modeling and automatically tackle all the low-level, messy details for you.
ZIO Schema is used by a growing number of ZIO libraries, including ZIO Flow, ZIO Redis, ZIO Web, ZIO SQL and ZIO DynamoDB.
Add in your
libraryDependencies ++= Seq( "dev.zio" %% "zio-schema" % "<version>", // Required for automatic generic derivation of schemas "dev.zio" %% "zio-schema-derivation" % "<version>", "org.scala-lang" % "scala-reflect" % scalaVersion.value % "provided" )
For the general guidelines, see ZIO contributor's guide.
Before you submit a PR, make sure your tests are passing, and that the code is properly formatted
sbt prepare sbt test