diff --git a/README.md b/README.md index 69b5cb5605..bcb71252e4 100755 --- a/README.md +++ b/README.md @@ -41,14 +41,14 @@ sttp (v2) documentation is available at [sttp.softwaremill.com](http://sttp.soft sttp (v1) documentation is available at [sttp.softwaremill.com/en/v1](https://sttp.softwaremill.com/en/v1). -scaladoc is available at [https://www.javadoc.io](https://www.javadoc.io/doc/com.softwaremill.sttp.client/core_2.12/3.0.0-RC1) +scaladoc is available at [https://www.javadoc.io](https://www.javadoc.io/doc/com.softwaremill.sttp.client/core_2.12/3.0.0-RC2) ## Quickstart with Ammonite If you are an [Ammonite](http://ammonite.io) user, you can quickly start experimenting with sttp by copy-pasting the following: ```scala -import $ivy.`com.softwaremill.sttp.client::core:3.0.0-RC1` +import $ivy.`com.softwaremill.sttp.client::core:3.0.0-RC2` import sttp.client.quick._ quickRequest.get(uri"http://httpbin.org/ip").send(backend) ``` @@ -60,7 +60,7 @@ This brings in the sttp API and an implicit, synchronous backend. Add the following dependency: ```scala -"com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2" ``` Then, import: diff --git a/generated-docs/out/backends/akka.md b/generated-docs/out/backends/akka.md index a70d7f89f1..aee5f0c8e6 100644 --- a/generated-docs/out/backends/akka.md +++ b/generated-docs/out/backends/akka.md @@ -3,7 +3,7 @@ This backend is based on [akka-http](http://doc.akka.io/docs/akka-http/current/scala/http/). To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "akka-http-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "akka-http-backend" % "3.0.0-RC2" ``` A fully **asynchronous** backend. Uses the `Future` effect to return responses. There are also [other `Future`-based backends](future.md), which don't depend on Akka. diff --git a/generated-docs/out/backends/catseffect.md b/generated-docs/out/backends/catseffect.md index 2a24c821e1..51378c44dd 100644 --- a/generated-docs/out/backends/catseffect.md +++ b/generated-docs/out/backends/catseffect.md @@ -5,7 +5,7 @@ The [Cats Effect](https://github.com/typelevel/cats-effect) backend is **asynchr To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "async-http-client-backend-cats" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "async-http-client-backend-cats" % "3.0.0-RC2" ``` You'll need the following imports and implicits to create the backend: diff --git a/generated-docs/out/backends/finagle.md b/generated-docs/out/backends/finagle.md index 0881fde128..2097f0b527 100644 --- a/generated-docs/out/backends/finagle.md +++ b/generated-docs/out/backends/finagle.md @@ -3,7 +3,7 @@ To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "finagle-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "finagle-backend" % "3.0.0-RC2" ``` Next you'll need to add an implicit value: diff --git a/generated-docs/out/backends/fs2.md b/generated-docs/out/backends/fs2.md index e72cbf6687..0936b7439d 100644 --- a/generated-docs/out/backends/fs2.md +++ b/generated-docs/out/backends/fs2.md @@ -7,7 +7,7 @@ The [fs2](https://github.com/functional-streams-for-scala/fs2) backend is **asyn To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "async-http-client-backend-fs2" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "async-http-client-backend-fs2" % "3.0.0-RC2" ``` And some imports: @@ -76,7 +76,7 @@ val backend = AsyncHttpClientFs2Backend.usingClient[IO](asyncHttpClient, blocker To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "httpclient-backend-fs2" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "httpclient-backend-fs2" % "3.0.0-RC2" ``` And some imports: diff --git a/generated-docs/out/backends/future.md b/generated-docs/out/backends/future.md index 389f1c7790..64b02f22aa 100644 --- a/generated-docs/out/backends/future.md +++ b/generated-docs/out/backends/future.md @@ -20,7 +20,7 @@ Class Supported stream type To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "async-http-client-backend-future" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "async-http-client-backend-future" % "3.0.0-RC2" ``` And some imports: @@ -71,7 +71,7 @@ val backend = AsyncHttpClientFutureBackend.usingClient(asyncHttpClient) To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "okhttp-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "okhttp-backend" % "3.0.0-RC2" ``` and some imports: @@ -103,7 +103,7 @@ This backend depends on [OkHttp](http://square.github.io/okhttp/) and fully supp To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "httpclient-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "httpclient-backend" % "3.0.0-RC2" ``` and some imports: diff --git a/generated-docs/out/backends/http4s.md b/generated-docs/out/backends/http4s.md index e81c7dec33..920e43a5f9 100644 --- a/generated-docs/out/backends/http4s.md +++ b/generated-docs/out/backends/http4s.md @@ -3,7 +3,7 @@ This backend is based on [http4s](https://http4s.org) (blaze client) and is **asynchronous**. To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "http4s-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "http4s-backend" % "3.0.0-RC2" ``` Add some imports as well: diff --git a/generated-docs/out/backends/javascript/fetch.md b/generated-docs/out/backends/javascript/fetch.md index a4de2377e4..cb8fcce033 100644 --- a/generated-docs/out/backends/javascript/fetch.md +++ b/generated-docs/out/backends/javascript/fetch.md @@ -5,7 +5,7 @@ A JavaScript backend implemented using the [Fetch API](https://developer.mozilla This is the default backend, available in the main jar for JS. To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %%% "core" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %%% "core" % "3.0.0-RC2" ``` And create the backend instance: @@ -48,7 +48,7 @@ Streaming support is provided via `FetchMonixBackend`. Note that streaming suppo To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %%% "monix" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %%% "monix" % "3.0.0-RC2" ``` An example of streaming a response: diff --git a/generated-docs/out/backends/monix.md b/generated-docs/out/backends/monix.md index 7a03c7c962..106b0f5c97 100644 --- a/generated-docs/out/backends/monix.md +++ b/generated-docs/out/backends/monix.md @@ -7,7 +7,7 @@ There are several backend implementations which are `monix.eval.Task`-based. The To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC2" ``` This backend depends on [async-http-client](https://github.com/AsyncHttpClient/async-http-client), uses [Netty](http://netty.io) behind the scenes and supports effect cancellation. @@ -50,7 +50,7 @@ val backend = AsyncHttpClientMonixBackend.usingClient(asyncHttpClient) To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "okhttp-backend-monix" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "okhttp-backend-monix" % "3.0.0-RC2" ``` Create the backend using: @@ -76,7 +76,7 @@ This backend depends on [OkHttp](http://square.github.io/okhttp/) and fully supp To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "httpclient-backend-monix" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "httpclient-backend-monix" % "3.0.0-RC2" ``` Create the backend using: diff --git a/generated-docs/out/backends/native/curl.md b/generated-docs/out/backends/native/curl.md index e10758717f..d9b25ef8e5 100644 --- a/generated-docs/out/backends/native/curl.md +++ b/generated-docs/out/backends/native/curl.md @@ -5,7 +5,7 @@ A Scala Native backend implemented using [Curl](https://github.com/curl/curl/blo To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %%% "core" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %%% "core" % "3.0.0-RC2" ``` and initialize one of the backends: diff --git a/generated-docs/out/backends/scalaz.md b/generated-docs/out/backends/scalaz.md index 82b4c85d5a..bb23c9261f 100644 --- a/generated-docs/out/backends/scalaz.md +++ b/generated-docs/out/backends/scalaz.md @@ -5,7 +5,7 @@ The [Scalaz](https://github.com/scalaz/scalaz) backend is **asynchronous**. Send To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "async-http-client-backend-scalaz" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "async-http-client-backend-scalaz" % "3.0.0-RC2" ``` This backend depends on [async-http-client](https://github.com/AsyncHttpClient/async-http-client) and uses [Netty](http://netty.io) behind the scenes. diff --git a/generated-docs/out/backends/synchronous.md b/generated-docs/out/backends/synchronous.md index 8725c4c2a7..408d560c17 100644 --- a/generated-docs/out/backends/synchronous.md +++ b/generated-docs/out/backends/synchronous.md @@ -20,7 +20,7 @@ This backend works with all Scala versions. A Dotty build is available as well. To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "okhttp-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "okhttp-backend" % "3.0.0-RC2" ``` Create the backend using: @@ -48,7 +48,7 @@ This backend depends on [OkHttp](http://square.github.io/okhttp/) and fully supp To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "httpclient-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "httpclient-backend" % "3.0.0-RC2" ``` Create the backend using: diff --git a/generated-docs/out/backends/wrappers/custom.md b/generated-docs/out/backends/wrappers/custom.md index 8a34a9b623..a046f11b7b 100644 --- a/generated-docs/out/backends/wrappers/custom.md +++ b/generated-docs/out/backends/wrappers/custom.md @@ -285,7 +285,7 @@ object RateLimitingSttpBackend { Implementing a new backend is made easy as the tests are published in the `core` jar file under the `tests` classifier. Simply add the follow dependencies to your `build.sbt`: ``` -"com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1" % Test classifier "tests" +"com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2" % Test classifier "tests" ``` Implement your backend and extend the `HttpTest` class: diff --git a/generated-docs/out/backends/wrappers/logging.md b/generated-docs/out/backends/wrappers/logging.md new file mode 100644 index 0000000000..8eae85e602 --- /dev/null +++ b/generated-docs/out/backends/wrappers/logging.md @@ -0,0 +1,49 @@ +# Logging + +The `sttp.client.logging.LoggingBackend` can log requests and responses which end successfully or with an exception. It can be created given: + +* a `sttp.client.logging.Logger`, which is an integration point with logging libraries. Two such integration that are available with sttp-client is slf4j and scribe (see below), but custom ones can be easily added. +* a `sttp.client.logging.Log`, which constructs messages and performs logging actions. A custom implementation can be provided to change default log levels or log message content. + +By default, the following options are exposed: + +* `includeTiming` - should the duration of the request be included in the log message +* `beforeCurlInsteadOfShow` - before sending a request, instead of a summary of the request to be sent, log the curl command which corresponds to the request +* `logRequestBody` - should the request body be logged before sending the request (if the request body can be logged) +* `logResponseBody` - should the response body be logged after receiving a response to the request (if the response body can be replayed) + +The messages are by default logged on these levels: + +* `DEBUG` before the request is sent +* `DEBUG` when a request completes successfully +* `ERROR` when there's an exception when sending a request + +## Using slf4j + +To use the [slf4j](http://www.slf4j.org) logging backend wrapper, add the following dependency to your project: + +``` +"com.softwaremill.sttp.client" %% "slf4j-backend" % "3.0.0-RC2" +``` + +There are three backend wrappers available, which log request & response information using a slf4j `Logger`. To see the logs, you'll need to use an slf4j-compatible logger implementation, e.g. [logback](http://logback.qos.ch), or use a binding, e.g. [log4j-slf4j](https://logging.apache.org/log4j/2.0/log4j-slf4j-impl/index.html). + +Example usage: + +```scala +import sttp.client._ +import sttp.client.logging.slf4j.Slf4jLoggingBackend + +val backend = Slf4jLoggingBackend(HttpURLConnectionBackend()) +basicRequest.get(uri"https://httpbin.org/get").send(backend) +``` + +To create a customised logging backend, see the section on [custom backends](custom.md). + +## Using scribe + +To use the [scribe](https://github.com/outr/scribe) logging backend wrapper, add the following dependency to your project: + +``` +"com.softwaremill.sttp.client" %% "scribe-backend" % "3.0.0-RC2" +``` \ No newline at end of file diff --git a/generated-docs/out/backends/wrappers/opentracing.md b/generated-docs/out/backends/wrappers/opentracing.md index dcb2f3c252..f9bae55f2f 100644 --- a/generated-docs/out/backends/wrappers/opentracing.md +++ b/generated-docs/out/backends/wrappers/opentracing.md @@ -3,7 +3,7 @@ To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "opentracing-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "opentracing-backend" % "3.0.0-RC2" ``` This backend depends on [opentracing](https://github.com/opentracing/opentracing-java), a standardized set of api for distributed tracing. @@ -47,7 +47,7 @@ Using with [jaeger](https://www.jaegertracing.io/) tracing Add following dependency: ``` -libraryDependencies += "io.jaegertracing" % "jaeger-client" % "1.3.2" +libraryDependencies += "io.jaegertracing" % "jaeger-client" % "1.4.0" ``` Create an instance of tracer: diff --git a/generated-docs/out/backends/wrappers/prometheus.md b/generated-docs/out/backends/wrappers/prometheus.md index 49d15fb8d4..3ef03b51cb 100644 --- a/generated-docs/out/backends/wrappers/prometheus.md +++ b/generated-docs/out/backends/wrappers/prometheus.md @@ -3,7 +3,7 @@ To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "prometheus-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "prometheus-backend" % "3.0.0-RC2" ``` and some imports: diff --git a/generated-docs/out/backends/wrappers/zio-opentracing.md b/generated-docs/out/backends/wrappers/zio-opentracing.md index 33d4e65b43..7778465045 100644 --- a/generated-docs/out/backends/wrappers/zio-opentracing.md +++ b/generated-docs/out/backends/wrappers/zio-opentracing.md @@ -3,7 +3,7 @@ To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "zio-telemetry-opentracing-backend" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "zio-telemetry-opentracing-backend" % "3.0.0-RC2" ``` This backend depends on [zio-opentracing](https://github.com/zio/zio-telemetry). diff --git a/generated-docs/out/backends/zio.md b/generated-docs/out/backends/zio.md index 843ad87f9f..13dcf5ef01 100644 --- a/generated-docs/out/backends/zio.md +++ b/generated-docs/out/backends/zio.md @@ -7,7 +7,7 @@ The [ZIO](https://github.com/zio/zio) backends are **asynchronous**. Sending a r To use, add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC2" ``` This backend depends on [async-http-client](https://github.com/AsyncHttpClient/async-http-client), uses [Netty](http://netty.io) behind the scenes and supports effect cancellation. This backend works with all Scala versions. A Dotty build is available as well. @@ -53,7 +53,7 @@ val backend = AsyncHttpClientZioBackend.usingClient(runtime, asyncHttpClient) To use, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "httpclient-backend-zio" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "httpclient-backend-zio" % "3.0.0-RC2" ``` Create the backend using: diff --git a/generated-docs/out/examples.md b/generated-docs/out/examples.md index 7015df1fb7..d8fea776b8 100644 --- a/generated-docs/out/examples.md +++ b/generated-docs/out/examples.md @@ -7,7 +7,7 @@ All of the examples are available [in the sources](https://github.com/softwaremi Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2") ``` Example code: @@ -23,8 +23,8 @@ Required dependencies: ```scala libraryDependencies ++= List( - "com.softwaremill.sttp.client" %% "akka-http-backend" % "3.0.0-RC1", - "com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC1", + "com.softwaremill.sttp.client" %% "akka-http-backend" % "3.0.0-RC2", + "com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC2", "org.json4s" %% "json4s-native" % "3.6.0" ) ``` @@ -42,8 +42,8 @@ Required dependencies: ```scala libraryDependencies ++= List( - "com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC1", - "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC1", + "com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC2", + "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC2", "io.circe" %% "circe-generic" % "0.13.0" ) ``` @@ -61,8 +61,8 @@ Required dependencies: ```scala libraryDependencies ++= List( - "com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC1", - "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC1", + "com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC2", + "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC2", "io.circe" %% "circe-generic" % "0.13.0" ) ``` @@ -80,8 +80,8 @@ Required dependencies: ```scala libraryDependencies ++= List( - "com.softwaremill.sttp.client" %% "slf4j-backend" % "3.0.0-RC1", - "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC1", + "com.softwaremill.sttp.client" %% "slf4j-backend" % "3.0.0-RC2", + "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC2", "io.circe" %% "circe-generic" % "0.13.0" ) ``` @@ -99,8 +99,8 @@ Required dependencies: ```scala libraryDependencies ++= List( - "com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC1", - "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC1", + "com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC2", + "com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC2", "io.circe" %% "circe-generic" % "0.13.0" ) ``` @@ -117,7 +117,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2") ``` Example code: @@ -132,7 +132,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC2") ``` Example code: @@ -147,7 +147,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-fs2 % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-fs2 % "3.0.0-RC2") ``` Example code: @@ -162,7 +162,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-monix % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-monix % "3.0.0-RC2") ``` Example code: @@ -177,7 +177,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "akka-http-backend" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "akka-http-backend" % "3.0.0-RC2") ``` Example code: @@ -192,7 +192,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-monix" % "3.0.0-RC2") ``` Example code: @@ -207,7 +207,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-fs2" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-fs2" % "3.0.0-RC2") ``` Example code: @@ -222,7 +222,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC2") ``` Example code: @@ -237,7 +237,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "async-http-client-backend-zio" % "3.0.0-RC2") ``` Example code: @@ -252,7 +252,7 @@ Example code: Required dependencies: ```scala -libraryDependencies ++= List("com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1") +libraryDependencies ++= List("com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2") ``` Example code: diff --git a/generated-docs/out/json.md b/generated-docs/out/json.md index 6a5d52bb3b..0764471abf 100644 --- a/generated-docs/out/json.md +++ b/generated-docs/out/json.md @@ -34,7 +34,7 @@ case class ResponsePayload(data: String) JSON encoding of bodies and decoding of responses can be handled using [Circe](https://circe.github.io/circe/) by the `circe` module. To use add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "circe" % "3.0.0-RC2" ``` This module adds a body serialized, so that json payloads can be sent as request bodies. To send a payload of type `T` as json, a `io.circe.Encoder[T]` implicit value must be available in scope. @@ -66,7 +66,7 @@ Arbitrary JSON structures can be traversed by parsing the result as `io.circe.Js To encode and decode json using json4s, add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC2" "org.json4s" %% "json4s-native" % "3.6.0" ``` @@ -100,7 +100,7 @@ val response: Identity[Response[Either[ResponseException[String, Exception], Res To encode and decode JSON using [spray-json](https://github.com/spray/spray-json), add the following dependency to your project: ``` -"com.softwaremill.sttp.client" %% "spray-json" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "spray-json" % "3.0.0-RC2" ``` Using this module it is possible to set request bodies and read response bodies as your custom types, using the implicitly available instances of `spray.json.JsonWriter` / `spray.json.JsonReader` or `spray.json.JsonFormat`. @@ -132,7 +132,7 @@ val response: Identity[Response[Either[ResponseException[String, Exception], Res To encode and decode JSON using [play-json](https://www.playframework.com), add the following dependency to your project: ```scala -"com.softwaremill.sttp.client" %% "play-json" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "play-json" % "3.0.0-RC2" ``` To use, add an import: `import sttp.client.playJson._`. diff --git a/generated-docs/out/openapi.md b/generated-docs/out/openapi.md index 75769bba34..4ff3cd2d5a 100644 --- a/generated-docs/out/openapi.md +++ b/generated-docs/out/openapi.md @@ -36,8 +36,8 @@ lazy val petstoreApi: Project = project openApiGeneratorName := "scala-sttp", openApiOutputDir := baseDirectory.value.name, libraryDependencies ++= Seq( - "com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1", - "com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC1", + "com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2", + "com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC2", "org.json4s" %% "json4s-jackson" % "3.6.8" ) ) @@ -87,8 +87,8 @@ lazy val petstoreApi: Project = project openApiOutputDir := baseDirectory.value.name, openApiIgnoreFileOverride := s"${baseDirectory.in(ThisBuild).value.getPath}/openapi-ignore-file", libraryDependencies ++= Seq( - "com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1", - "com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC1", + "com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2", + "com.softwaremill.sttp.client" %% "json4s" % "3.0.0-RC2", "org.json4s" %% "json4s-jackson" % "3.6.8" ), (compile in Compile) := ((compile in Compile) dependsOn openApiGenerate).value, diff --git a/generated-docs/out/quickstart.md b/generated-docs/out/quickstart.md index d755c9ccc2..84fa17662a 100644 --- a/generated-docs/out/quickstart.md +++ b/generated-docs/out/quickstart.md @@ -9,7 +9,7 @@ To integrate with other parts of your application, you'll often need to use an a The basic dependency which provides the API and the default synchronous backend is: ```scala -"com.softwaremill.sttp.client" %% "core" % "3.0.0-RC1" +"com.softwaremill.sttp.client" %% "core" % "3.0.0-RC2" ``` `sttp client` is available for Scala 2.11, 2.12 and 2.13, and requires Java 8, as well as for Dotty (Scala 3) 0.23. @@ -21,7 +21,7 @@ The basic dependency which provides the API and the default synchronous backend If you are an [Ammonite](https://ammonite.io) user, you can quickly start experimenting with sttp by copy-pasting the following: ```scala -import $ivy.`com.softwaremill.sttp.client::core:3.0.0-RC1` +import $ivy.`com.softwaremill.sttp.client::core:3.0.0-RC2` import sttp.client.quick._ quickRequest.get(uri"http://httpbin.org/ip").send(backend) ``` @@ -31,7 +31,7 @@ Importing the `quick` object has the same effect as importing `sttp.client._`, p If the default `HttpURLConnectionBackend` for some reason is insufficient, you can also use one based on OkHttp: ```scala -import $ivy.`com.softwaremill.sttp.client::okhttp-backend:3.0.0-RC1` +import $ivy.`com.softwaremill.sttp.client::okhttp-backend:3.0.0-RC2` import sttp.client.okhttp.quick._ quickRequest.get(uri"http://httpbin.org/ip").send(backend) ``` diff --git a/version.sbt b/version.sbt index b4332167a9..bbf00929cb 100644 --- a/version.sbt +++ b/version.sbt @@ -1 +1 @@ -version in ThisBuild := "3.0.0-RC1" +version in ThisBuild := "3.0.0-RC2"