Releases: disneystreaming/smithy4s
v0.15.0 : Smithy 2.0 support, custom type refinements
The 0.15.0 release breaks both source and binary compatibility
This is a very exciting release for us, as it makes Smithy4s compatible with Smithy 2.0
Highlights
Adds support for smithy 2.0, which brings a number of very interesting features. In particular :
- mixins, which allow to drastically DRY your specifications when multiple shapes share a number of elements
- defaults, which allow to specify default values for the fields of your structure types
- enums/int enums, which make enumerations a lot nicer to write/read in smithy
Adds support for custom refinements
This provides a mechanism for the user to plug some datatypes of their own in the generated code. These can be validated against
user-defined rules, via an implicit instance provided by the user (or a third party). Smithy4s forces this customisation to be driven by smithy traits, which allow specifications to retain a formally-indicative nature of the behaviour of APIs. These refinements are wired in all decoding logic exercised by smithy4s, which means they are taken into account whether the data is found in headers, query parameters, path parameters, or bodies of the http requests/responses.
See the documentation for more details.
Better collision avoidance in the rendered code
Some care has been put in the generated code to facilitate collision avoidance between what exists and what is generated, without relying on fully-qualified-names by default. Although there may still be edge cases, this approach means the generated code retains a reasonably pleasant-to-read nature, which we have found to be important to users.
Fixes
- When the
@jsonName
trait is used on structure members, potential error messages should expose the correct expectations - Fixes an issue that would lead clients to decode error payloads as the wrong error type
What's Changed
- Add type annotation to list of endpoints by @kubukoz in #323
- adds doc search by @yisraelU in #326
- Update smithy-aws-traits, smithy-build, ... to 1.22.0 by @scala-steward in #325
- Reduce CPU usage on access to java.util.HashTable by @plokhotnyuk in #327
- Update cats-effect to 3.3.14 by @scala-steward in #324
- Update 02-unions.md by @yisraelU in #335
@errorMessage
trait by @kubukoz in #320- Update jsoniter-scala-core to 2.13.37 by @scala-steward in #334
- Update jsoniter-scala-core to 2.13.38 by @scala-steward in #342
- Update weaver-cats, weaver-scalacheck to 0.6.14 by @scala-steward in #340
- Update http4s-circe, http4s-client, ... to 0.23.14 by @scala-steward in #344
- Update scala-collection-compat to 2.8.1 by @scala-steward in #345
- Update fs2-core to 3.2.11 by @scala-steward in #339
- add middleware example docs by @lewisjkl in #343
- Revise bijection surjection by @lewisjkl in #351
- Update jsoniter-scala-core to 2.13.39 by @scala-steward in #349
- Update to smithy 2.0; add int enum support by @lewisjkl in #352
- Update jsoniter-scala-core to 2.14.0 by @scala-steward in #353
- Update swagger-ui-dist to 4.13.2 by @scala-steward in #350
- Update jsoniter-scala-core to 2.14.1 by @scala-steward in #356
- first pass at using mixins to create traits by @lewisjkl in #355
- Best-effort error-decoding fix by @Baccata in #357
- Update weaver-cats, weaver-scalacheck to 0.7.15 by @scala-steward in #362
- Update jsoniter-scala-core to 2.14.2 by @scala-steward in #360
- Update fs2-core to 3.2.12 by @scala-steward in #359
- Smithy 2.0 syntax is released in the 1.23.0 artifact by @Baccata in #364
- Update jsoniter-scala-core to 2.15.0 by @scala-steward in #367
- Collision detection by @yisraelU in #366
- DocumentKeyDecoder and DocumentKeyEncoder by @daddykotex in #311
- Use jsonName on Missing required field error by @daddykotex in #371
- Build checkpoint for mergify by @daddykotex in #373
- Add the logic to render default parameters by @Baccata in #374
- Backported jsonName fixes by @daddykotex in #375
- Change checks conditions and command by @Baccata in #378
- add default support in several locations by @lewisjkl in #358
- Series 0.15.0 mega PR by @Baccata in #379
Full Changelog: v0.14.2...v0.15.0
v0.14.2: more efficient parsing of json objects/arrays
Highlights :
- More efficient parsing of json objects/arrays. As usual, kudos to @plokhotnyuk for his amazing work on optimising the json parsing.
- It's now easier to set up smithy4s in other SBT configurations than
Compile
. See here
What's Changed
- Make it easier to enable codegen in configurations other than Compile by @kubukoz in #310
- Update decline to 2.3.0 by @scala-steward in #312
- Update sbt-scalajs, scalajs-compiler, ... to 1.10.1 by @scala-steward in #315
- Update http4s-circe, http4s-client, ... to 0.22.14 by @scala-steward in #313
- Update scala-collection-compat to 2.8.0 by @scala-steward in #318
- Update sbt, sbt-dependency-tree to 1.7.1 by @scala-steward in #319
- Update scala-library, scala-reflect to 2.12.16 by @scala-steward in #316
- More efficient parsing of JSON arrays and objects by @plokhotnyuk in #322
Full Changelog: v0.14.1...v0.14.2
v0.14.1: bug fix (swagger-ui)
Fixes a bug that would lead callers to get 404'd on the default swagger-ui path.
What's Changed
Full Changelog: v0.14.0...v0.14.1
v0.14.0: Scala-native support, improvements across the board
The 0.14.0 release breaks binary compatibility, as well as source compatibility (in a few places) with the previous versions.
It does however achieves a number of significant improvements across the boards, in terms of user experience, performance and maintainability.
Special thanks to @plokhotnyuk, @schmeedy, @yisraelU, @daddykotex
Highlights
- The core/json/dynamic modules are now published for scala-native (scala 3 only for the time being)
- The http4s-swagger-ui module has received an overhaul, in order to avoid relying on a javascript function that presented a security issue, but also to allow for users to easily serve several specifications at the same time.
- Having union members target the
Unit
shape now leads to the corresponding type be rendered as a case object in Scala. - A mechanism was added for users to be able to opt-in
Vector
andIndexedSeq
Scala types when using smithylist
shape. - The
Timestamp
construct was overhauled to unify its modelling across the different platforms, and received a massive performance improvement for parsing/serialising. - Modified the SBT plugin to have SBT pre-fetch the artifacts before calling the Smithy4s code-generation, making it more respectful to other settings (such as repository credentials)
- The
smithy4s.schema.Schema
construct was reworked to unify the collections under a common abstraction, and thesmithy4s.schema.SchemaVisitor
construct was also changed to reduce the likelihood of a common mistake related to memoisation of union encoders .
What's Changed
- Add a first iteration containing documentation of design. by @Baccata in #257
- Remove smithy files from package by @yisraelU in #285
- Refactoring of Timestamp by @plokhotnyuk in #283
- Couple ShapeTag with Schema by @Baccata in #271
- Change the Field and Alt model to not hold schemas anymore by @Baccata in #279
- Fix path url decoding by @kubukoz in #284
- Use internal sbt dependency resolution in codegen-plugin by @schmeedy in #288
- Improve swagger docs support by @daddykotex in #287
- Update copyright notices by @daddykotex in #292
- Document library dependency feature by @Baccata in #291
- Document the design of the Service and Endpoint interfaces by @Baccata in #282
- Rework of the concept of collection in the Schema abstraction by @daddykotex in #290
- Scala native support by @Baccata in #289
- Optimize serialization for ArraySeq by @plokhotnyuk in #297
- Render Unit in unions as case objects by @Baccata in #294
- Update fs2-core to 3.2.10 by @scala-steward in #299
- Update weaver-cats, weaver-scalacheck to 0.7.13 by @scala-steward in #301
- Update sbt-scalafix to 0.10.1 by @scala-steward in #298
- Update weaver-cats, weaver-scalacheck to 0.6.13 by @scala-steward in #300
- Implement a simple SchemaDescription visitor by @daddykotex in #295
- Revises the "union" method in SchemaVisitor ... by @Baccata in #302
- Replace schematic implementation by schema visitor by @daddykotex in #296
- Add enum value names by @kubukoz in #304
- Update jsoniter-scala-core to 2.13.36 by @plokhotnyuk in #305
- Add
@vector
and@indexedSeq
by @daddykotex in #303
New Contributors
Full Changelog: v0.13.7...v0.14.0
v0.13.7 : fix unused import
Highlights :
- Fix an issue that would lead to unused imports being rendered when the input of an operation has a collection member from another namespace.
- Fix a potential resource leak in the EC2/ECS AWS credentials provider
What's Changed
- Switch weaver to munit in core Module. by @Baccata in #277
- Fix resource leak in AWS refresh loop by @kubukoz in #278
- fix imports for newtypes from other packages by @lewisjkl in #280
Full Changelog: v0.13.6...v0.13.7
v0.13.6
Even though this is a patch release, its packed with goodies. Thanks to @plokhotnyuk, we've got a lot of performance improvements for our json module. There are a few bug fixes on top of that.
What's Changed
- More efficient reading and writing of JSON documents by @plokhotnyuk in #251
- More efficient serialization discriminated ADTs by @plokhotnyuk in #259
- Clean up tests for Timestamp by @plokhotnyuk in #261
- Fix streamed schema rendering by @kubukoz in #265
- Fix map rendering in traits (non-toplevel values) by @Baccata in #268
- Unify ShapeTag across Scala versions by @Baccata in #269
- sets UseIntegerType to True to fix issue with AWS not handling number by @yisraelU in #272
- Implement SchemaVisitorJCodec by @daddykotex in #270
- Fix errors not respecting http bindings semantics by @daddykotex in #275
Full Changelog: v0.13.5...v0.13.6
v0.13.5 - fixing a dynamic schema regression, padding base64 strings
What's Changed
- Do padding of base64 encoded strings by @plokhotnyuk in #246
- update copyright header by @mcanlas in #248
- Do not publish protocol tests by @daddykotex in #249
- Add smithy4s.meta to the reserved namespaces by @Baccata in #250
- Fix dynamic compiler applying field/alt hints at the wrong level by @Baccata in #247
New Contributors
Full Changelog: v0.13.4...v0.13.5
v0.13.4: more performance improvements, better recursion handling
What's Changed
- More efficient parsing of documents by @plokhotnyuk in #239
- adds SchemaVisitor implementation of MetadataWriter and MetadataReader by @yisraelU in #225
- More efficient parsing of lists, sets, maps, and unions by @plokhotnyuk in #240
- Fixes #181 by @Baccata in #243
- Improve recursion handling in dynamic schemas by @Baccata in #241
Full Changelog: v0.13.3...v0.13.4
v0.13.3: more efficient serialization of documents with ASCII key
What's Changed
- More efficient serialization of documents with ASCII keys by @plokhotnyuk in #237
Full Changelog: v0.13.2...v0.13.3
v0.13.2: improve performance of document encoder
Highlights :
- Fixes a bug that would lead document encoders to be partially recompiled on each serialisation, decreasing performance
- Correctly translate
@untaggedUnion
annotated shapes to openapi
What's Changed
- Update circe-generic to 0.14.2 by @scala-steward in #223
- Update http4s-circe, http4s-client, ... to 0.22.13 by @scala-steward in #224
- Update cats-effect to 3.3.12 by @scala-steward in #227
- Update jsoniter-scala-core to 2.13.25 by @scala-steward in #228
- Update weaver-cats, weaver-scalacheck to 0.7.12 by @scala-steward in #230
- Update weaver-cats, weaver-scalacheck to 0.6.12 by @scala-steward in #229
- clarify @adtMember docs by @lewisjkl in #226
- Update jsoniter-scala-core to 2.13.26 by @scala-steward in #231
- Update sbt-sonatype to 3.9.13 by @scala-steward in #233
- Update http4s-circe, http4s-client, ... to 0.23.12 by @scala-steward in #232
- Implement UntaggedUnion support in OpenApi extension by @daddykotex in #235
- Memorize document encoders by @plokhotnyuk in #236
New Contributors
- @plokhotnyuk made their first contribution in #236
Full Changelog: v0.13.1...v0.13.2