smithy.api.HttpPrefixHeaders.scala Maven / Gradle / Ivy
package smithy.api
import smithy4s.Hints
import smithy4s.Newtype
import smithy4s.Schema
import smithy4s.ShapeId
import smithy4s.schema.Schema.bijection
import smithy4s.schema.Schema.recursive
import smithy4s.schema.Schema.string
/** Binds a map of key-value pairs to prefixed HTTP headers. */
object HttpPrefixHeaders extends Newtype[String] {
val id: ShapeId = ShapeId("smithy.api", "httpPrefixHeaders")
val hints: Hints = Hints(
smithy.api.Documentation("Binds a map of key-value pairs to prefixed HTTP headers."),
smithy.api.Trait(selector = Some("structure > member\n:test(> map :not([trait|sparse]) > member[id|member=value] > string)"), structurallyExclusive = Some(smithy.api.StructurallyExclusive.MEMBER.widen), conflicts = Some(List(smithy.api.NonEmptyString("smithy.api#httpLabel"), smithy.api.NonEmptyString("smithy.api#httpQuery"), smithy.api.NonEmptyString("smithy.api#httpHeader"), smithy.api.NonEmptyString("smithy.api#httpPayload"), smithy.api.NonEmptyString("smithy.api#httpResponseCode"), smithy.api.NonEmptyString("smithy.api#httpQueryParams"))), breakingChanges = Some(List(smithy.api.TraitDiffRule(change = smithy.api.TraitChangeType.ANY.widen, severity = smithy.api.Severity.ERROR.widen, path = None, message = None)))),
).lazily
val underlyingSchema: Schema[String] = string.withId(id).addHints(hints)
implicit val schema: Schema[HttpPrefixHeaders] = recursive(bijection(underlyingSchema, asBijection))
}