Scalars

As defined by specification, scalar represents a primitive value in GraphQL. In KGraphQL, besides built-in scalar types, client code can declare custom scalar type, which can coerce to String, Boolean, Int, Long or Float (Kotlin Double).

KGraphQL provides a group of DSL methods: stringScalar { }, booleanScalar { }, intScalar{ }, longScalar{ }, floatScalar{ }. They differ only by the Kotlin primitive type they coerce to.

Scalar has to define its coercion functions deserialize and serialize or coercion object which implements correct subtype of com.apurebase.kgraphql.schema.scalar.ScalarCoercion.

Example of direct coercion functions declaration

stringScalar<UUID> {
  deserialize = { uuid: String -> UUID.fromString(uuid) }
  serialize = UUID::toString
}

Example of coercion object declaration

stringScalar<UUID> {
  coercion = object : StringScalarCoercion<UUID> {
    override fun serialize(instance: UUID): String = instance.toString()
    override fun deserialize(raw: String, valueNode: ValueNode?): UUID = UUID.fromString(raw)
  }
}