New
-
First-party converters now support deferring serialization to happen when the request body is written (i.e., during HTTP execution) rather than when the HTTP request is created. In some cases this moves conversion from a calling thread to a background thread, such as in the case when using
Call.enqueue
directly.The following converters support this feature through a new
createStreaming()
factory:- Wire
Changed
- Nothing yet!
Fixed
- Nothing yet!
2.11.0 - 2024-03-28
New
- The built-in
OptionalConverterFactory
is now public to allow installing it before other converters which consume all types (e.g., Moshi, Gson, Jackson, etc.).
Fixed
- Ensure that exceptions thrown from failure to parse method annotations can be observed by multiple threads/callers. Previously only the first caller would see the actual parsing exception and other callers would get a cryptic
ClassCastException
.
2.10.0 - 2024-03-18
New
-
Support using
Unit
as a response type. This can be used for non-body HTTP methods likeHEAD
or body-containing HTTP methods likeGET
where the body will be discarded without deserialization. -
kotlinx.serialization converter!
This was imported from github.com/JakeWharton/retrofit2-kotlinx-serialization-converter/ and remains unchanged from its 1.0.0 release.
The Maven coordinates are
com.squareup.retrofit2:converter-kotlinx-serialization
. -
JAXB 3 converter!
The Maven coordinates are
com.squareup.retrofit2:converter-jaxb3
. -
@Header
,@Headers
, and@HeaderMap
can now set non-ASCII values through theallowUnsafeNonAsciiValues
annotation property. These are not technically compliant with the HTTP specification, but are often supported or required by services. -
Publish a BOM of all modules. The Maven coordinates are
com.squareup.retrofit2:retrofit-bom
. -
Invocation
now exposes the serviceClass<?>
and the instance on which the method was invoked. This disambiguates the source when service inheritence is used. -
A response type keeper annotation processor is now available for generating shrinker rules for all referenced types in your service interface. In some cases, it's impossible for static shrinker rules to keep the entirety of what Retrofit needs at runtime. This annotation processor generates those additional rules. For more info see its README.
Changed
- Add shrinker rules to retain the generic signatures of built-in types (
Call
,Response
, etc.) which are used via reflection at runtime. - Remove backpressure support from RxJava 2 and 3 adapters. Since we only deliver a single value and the Reactive Streams specification states that callers must request a non-zero subscription value, we never need to honor backpressure.
- Kotlin
Retrofit.create
function now has a non-null lower bound. Even if you specified a nullable type before this function would never return null. - Suspend functions now capture and defer all
Throwable
subtypes (not justException
subtypes) to avoid Java'sUndeclaredThrowableException
when thrown synchronously. - Eagerly reject
suspend fun
functions that returnCall<Body>
. These are never correct, and should declare a return type ofBody
directly. - Support for Java 14-specific and Java 16-specific reflection needed to invoke default methods on interfaces have been moved to separate versions of a class through a multi-release jar. This should have no observable impact other than the jar now contains classes which target Java 14 and Java 16 bytecode that might trip up some static analysis tools which are not aware of multi-release jars.
- Parameter names are now displayed in exception messages when available in the underlying Java bytecode.
- Jackson converter now supports binary formats by using byte streams rather than character streams in its implementation. Use the
create(ObjectMapper, MediaType)
overload to supply the value of theContent-Type
header for your format.
Fixed
- Do not include synthetic methods when doing eager validation.
- Use per-method rather than per-class locking when parsing annotations. This eliminates contention when multiple calls are made in quick succession at the beginning of the process lifetime.
2.9.0 - 2020-05-20
-
New: RxJava 3 adapter!
The Maven coordinates are
com.squareup.retrofit2:adapter-rxjava3
.Unlike the RxJava 1 and RxJava 2 adapters, the RxJava 3 adapter's
create()
method will produce asynchronous HTTP requests by default. For synchronous requests usecreateSynchronous()
and for synchronous on a scheduler usecreateWithScheduler(..)
.
2.8.2 - 2020-05-18
- Fix: Detect running on the Android platform by using system property rather than the presence of classes. This ensures that even when you're running on the JVM with Android classes present on the classpath you get JVM semantics.
- Fix: Update to OkHttp 3.14.9 which contains an associated Android platform detection fix.
2.8.1 - 2020-03-25
- Fix: Do not access
MethodHandles.Lookup
on Android API 24 and 25. The class is only available on Android API 26 and higher.
2.8.0 - 2020-03-23
- New: Add
Call.timeout()
which returns theokio.Timeout
of the full call. - Fix: Change
Call.awaitResponse()
to accept a nullable response type. - Fix: Support default methods on Java 14+. We had been working around a bug in earlier versions of Java. That bug was fixed in Java 14, and the fix broke our workaround.
2.7.2 - 2020-02-24
- Fix: Update to OkHttp 3.14.7 for compatibility with Android R (API 30).
2.7.1 - 2020-01-02
- Fix: Support 'suspend' functions in services interfaces when using 'retrofit-mock' artifact.
2.7.0 - 2019-12-09
This release changes the minimum requirements to Java 8+ or Android 5+. See this blog post for more information on the change.
- New: Upgrade to OkHttp 3.14.4. Please see its changelog for 3.x.
- Fix: Allow service interfaces to extend other interfaces.
- Fix: Ensure a non-null body is returned by
Response.error
.
2.6.4 - 2020-01-02
- Fix: Support 'suspend' functions in services interfaces when using 'retrofit-mock' artifact.
2.6.3 - 2019-12-09
- Fix: Change mechanism for avoiding
UndeclaredThrowableException
in rare cases from usingyield
an explicit dispatch which ensures that it will work even on dispatchers which do not support yielding.
2.6.2 - 2019-09-23
- Fix: Avoid
IOException
s being wrapped inUndeclaredThrowableException
in rare cases when usingResponse<..>
as a return type for Kotlin 'suspend' functions.
2.6.1 - 2019-07-31
- Fix: Avoid
IOException
s being wrapped inUndeclaredThrowableException
in rare cases. - Fix: Include no-content
ResponseBody
for responses created byResponse.error
. - Fix: Update embedded R8/ProGuard rules to not warn about nested classes used for Kotlin extensions.
2.6.0 - 2019-06-05
-
New: Support
suspend
modifier on functions for Kotlin! This allows you to express the asynchrony of HTTP requests in an idiomatic fashion for the language.@GET("users/{id}") suspend fun user(@Path("id") id: Long): User
Behind the scenes this behaves as if defined as
fun user(...): Call<User>
and then invoked withCall.enqueue
. You can also returnResponse<User>
for access to the response metadata.Currently this integration only supports non-null response body types. Follow issue 3075 for nullable type support.
-
New:
@Tag
parameter annotation for setting tags on the underlying OkHttpRequest
object. These can be read inCallAdapter
s or OkHttpInterceptor
s for tracing, analytics, varying behavior, and more. -
New:
@SkipCallbackExecutor
method annotation will result in yourCall
invoking itsCallback
on the background thread on which the HTTP call was made. -
New: Support OkHttp's
Headers
type for@HeaderMap
parameters. -
New: Add
Retrofit.Builder.baseUrl(URL)
overload. -
Fix: Add embedded R8/ProGuard rule which retains Retrofit interfaces (while still allowing obfuscation). This is needed because R8 running in 'full mode' (i.e., not in ProGuard-compatibility mode) will see that there are no subtypes of these interfaces and rewrite any code which references instances to null.
-
Fix: Mark
HttpException.response()
as@Nullable
as serializing the exception does not retain this instance. -
Fix: Fatal errors (such as stack overflows, out of memory, etc.) now propagate to the OkHttp
Dispatcher
thread on which they are running. -
Fix: Ensure JAX-B converter closes the response body when an exception is thrown during deserialization.
-
Fix: Ignore static methods when performing eager validation of interface methods.
-
Fix: Ensure that calling
source()
twice on theResponseBody
passed to aConverter
always returns the same instance. Prior to the fix, intermediate buffering would cause response data to be lost.
2.5.0 - 2018-11-18
- New: Built-in support for Kotlin's
Unit
type. This behaves the same as Java'sVoid
where the body content is ignored and immediately discarded. - New: Built-in support for Java 8's
Optional
andCompletableFuture
types. Previously the 'converter-java8' and 'adapter-java8' dependencies were needed and explicitly addingJava8OptionalConverterFactory
and/orJava8CallAdapterFactory
to yourRetrofit.Builder
in order to use these types. Support is now built-in and those types and their artifacts are marked as deprecated. - New:
Invocation
class provides a reference to the invoked method and argument list as a tag on the underlying OkHttpCall
. This can be accessed from an OkHttp interceptor for things like logging, analytics, or metrics aggregation. - New: Kotlin extension for
Retrofit
which allows you callcreate
passing the interface type only as a generic parameter (e.g.,retrofit.create<MyService>()
). - New: Added
Response.success
overload which allows specifying a custom 2xx status code. - New: Added
Calls.failure
overload which allows passing anyThrowable
subtype. - New: Minimal R8 rules now ship inside the jar requiring no client configuration in the common case.
- Fix: Do not propagate fatal errors to the callback. They are sent to the thread's uncaught exception handler.
- Fix: Do not enqueue/execute an otherwise useless call when the RxJava type is disposed by
onSubscribe
. - Fix: Call
RxJavaPlugins
assembly hook when creating an RxJava 2 type. - Fix: Ensure both the Guava and Java 8
Optional
converters delegate properly. This ensures that converters registered prior to the optional converter can be used for deserializing the body type. - Fix: Prevent
@Path
values from participating in path-traversal. This ensures untrusted input passed as a path value cannot cause you to make a request to an un-intended relative URL. - Fix: Simple XML converter (which is deprecated) no longer wraps subtypes of
RuntimeException
orIOException
when it fails. - Fix: Prevent JAXB converter from loading remote entities and DTDs.
- Fix: Correctly detect default methods in interfaces on Android (API 24+). These still do not work, but now a correct exception will be thrown when detected.
- Fix: Report more accurate exceptions when a
@QueryName
or@QueryMap
precedes a@Url
parameter. - Update OkHttp dependency to 3.12.
2.4.0 - 2018-03-14
- New:
Retrofit.Builder
exposes mutable lists of the added converter and call adapter factories. - New: Call adapter added for Scala's
Future
. - New: Converter for JAXB replaces the now-deprecated converter for Simple XML Framework.
- New: Add Java 9 automatic module names for each artifact corresponding to their root package.
- Fix: Do not swallow
Error
s from callbacks (usuallyOutOfMemoryError
). - Fix: Moshi and Gson converters now assert that the full response was consumed. This prevents hiding bugs in faulty adapters which might not have consumed the full JSON input which would then cause failures on the next request over that connection.
- Fix: Do not conflate OkHttp
Call
cancelation with RxJava unsubscription/disposal. Prior to this change, canceling of aCall
would prevent a cancelation exception from propagating down the Rx stream.
2.3.0 - 2017-05-13
-
Retrofit now uses
@Nullable
to annotate all possibly-null values. We've added a compile-time dependency on the JSR 305 annotations. This is a provided dependency and does not need to be included in your build configuration,.jar
file, or.apk
. We use@ParametersAreNonnullByDefault
and all parameters and return types are never null unless explicitly annotated@Nullable
.Warning: this release is source-incompatible for Kotlin users. Nullability was previously ambiguous and lenient but now the compiler will enforce strict null checks.
-
New: Converters added for Java 8's and Guava's
Optional
which wrap a potentially-nullable response body. These converters still rely on normal serialization library converters for parsing the response bytes into an object. -
New: String converters that return
null
for an@Query
or@Field
parameter are now skipped. -
New: The mock module's
NetworkBehavior
now throws a custom subclass ofIOException
to more clearly indicate the exception's source. -
RxJava 1.x converter updated to 1.3.0 which stabilizes the use of
Completable
. -
Fix: Add explicit handling for
OnCompleteFailedException
,OnErrorFailedException
, andOnErrorNotImplementedException
for RxJava 1.x to ensure they're correct delivered to the plugins/hooks for handling. -
Fix:
NoSuchElementException
thrown when unsubscribing from an RxJava 1.xSingle
.
2.2.0 - 2017-02-21
- RxJava 2.x is now supported with a first-party 'adapter-rxjava2' artifact.
- New:
@QueryName
annotation allows creating a query parameter with no '=' separator or value. - New: Support for messages generated by Protobuf 3.0 or newer when using the converter for Google's protobuf.
- New: RxJava 1.x call adapter now correctly handles broken subscribers whose methods throw exceptions.
- New: Add
toString()
implementations forResponse
andResult
. - New: The Moshi converter factory now offers methods for enabling null serialization and lenient parsing.
- New: Add
createAsync()
to RxJava 1.x call adapter factory which executes requests usingCall.enqueue()
using the underlying HTTP client's asynchronous support. - New:
NetworkBehavior
now allows setting an error percentage and returns HTTP errors when triggered. HttpException
has been moved into the main artifact and should be used instead of the versions embedded in each adapter (which have been deprecated).- Promote the response body generic type on
CallAdapter
from theadapt
method to the enclosing class. This is a source-incompatible but binary-compatible change which is only relevant if you are implementing your ownCallAdapter
s. - Remove explicit handling of the now-defunct RoboVM platform.
- Fix: Close response on HTTP 204 and 205 to avoid resource leak.
- Fix: Reflect the canceled state of the HTTP client's
Call
in Retrofit'sCall
. - Fix: Use supplied string converters for the
String
type on non-body parameters. This allows user converters to handle cases such as when annotating string parameters instead of them always using the raw string. - Fix: Skip a UTF-8 BOM (if present) when using the converter for Moshi.
2.1.0 - 2016-06-15
- New:
@HeaderMap
annotation and support for supplying an arbitrary number of headers to an endpoint. - New:
@JsonAdapter
annotations on the@Body
parameter and on the method will be propagated to Moshi for creating the request and response adapters, respectively. - Fix: Honor the
Content-Type
encoding of XML responses when deserializing response bodies. - Fix: Remove the stacktrace from fake network exceptions created from retrofit-mock's
NetworkBehavior
. They had the potential to be misleading and look like a library issue. - Fix: Eagerly catch malformed
Content-Type
headers supplied via@Header
or@Headers
.
2.0.2 - 2016-04-14
- New:
ProtoConverterFactory.createWithRegistry()
method accepts an extension registry to be used when deserializing protos. - Fix: Pass the correct
Call
instance toCallback
'sonResponse
andonFailure
methods such that callingclone()
retains the correct threading behavior. - Fix: Reduce the per-request allocation overhead for the RxJava call adapter.
2.0.1 - 2016-03-30
- New: Support OkHttp's
HttpUrl
as a@Url
parameter type. - New: Support iterable and array
@Part
parameters using OkHttp'sMultipartBody.Part
. - Fix: Honor backpressure in
Observable
s created from the RxJavaCallAdapterFactory.
2.0.0 - 2016-03-11
Retrofit 2 is a major release focused on extensibility. The API changes are numerous but solve shortcomings of the previous version and provide a path for future enhancement.
Because the release includes breaking API changes, we're changing the project's package name from
retrofit
to retrofit2
. This should make it possible for large applications and libraries to
migrate incrementally. The Maven group ID is now com.squareup.retrofit2
. For an explanation of
this strategy, see Jake Wharton's post, Java Interoperability Policy for Major Version
Updates.
-
Service methods return
Call<T>
. This allows them to be executed synchronously or asynchronously using the same method definition. ACall
instance represents a single request/response pair so it can only be used once, but you canclone()
it for re-use. Invokingcancel()
will cancel in-flight requests or prevent the request from even being performed if it has not already. -
Multiple converters for multiple serialization formats. API calls returning different formats (like JSON, protocol buffers, and plain text) no longer need to be separated into separate service interfaces. Combine them together and add multiple converters. Converters are chosen based on the response type you declare. Gson is no longer included by default, so you will always need to add a converter for any serialization support. OkHttp's
RequestBody
andResponseBody
types can always be used without adding one, however. -
Call adapters allow different execution mechanisms. While
Call
is the built-in mechanism, support for additional ones can be added similar to how different converters can be added. RxJava'sObservable
support has moved into a separate artifact as a result, and support for Java 8'sCompletableFuture
and Guava'sListenableFuture
are also provided as additional artifacts. -
Generic response type includes HTTP information and deserialized body. You no longer have to choose between the deserialized body and reading HTTP information. Every
Call
automatically receives both via theResponse<T>
type and the RxJava, Guava, and Java 8 call adapters also support it. -
@Url for hypermedia-like APIs. When your API returns links for pagination, additional resources, or updated content they can now be used with a service method whose first parameter is annotated with
@Url
.
Changes from beta 4:
- New:
RxJavaCallAdapterFactory
now supports service methods which returnCompletable
which ignores and discards response bodies, if any. - New:
RxJavaCallAdapterFactory
supports supplying a defaultScheduler
which will be used forsubscribeOn
on returnedObservable
,Single
, andCompletable
instances. - New:
MoshiConverterFactory
supports creating an instance which uses lenient parsing. - New:
@Part
can omit the part name and use OkHttp'sMultipartBody.Part
type for supplying parts. This lets you customize the headers, name, and filename and provide the part body in a single argument. - The
BaseUrl
interface and support for changeable base URLs was removed. This functionality can be done using an OkHttp interceptor and a sample showcasing it was added. Response.isSuccess()
was renamed toResponse.isSuccessful()
for parity with the name of OkHttp's version of that method.- Fix: Throw a more appropriate exception with a message when a resolved url (base URL + relative URL) is malformed.
- Fix:
GsonConverterFactory
now honors settings on theGson
instance (like leniency). - Fix:
ScalarsConverterFactory
now supports primitive scalar types in addition to boxed for response body parsing. - Fix:
Retrofit.callbackExecutor()
may now return an executor even when one was not explicitly provided. This allows customCallAdapter.Factory
implementations to use it when triggering callbacks to ensure they happen on the appropriate thread for the platform (e.g., Android).
2.0.0-beta4 - 2016-02-04
- New:
Call
instance is now passed to bothonResponse
andonFailure
methods ofCallback
. This aids in detecting whenonFailure
is called as a result ofCall.cancel()
by checkingCall.isCanceled()
. - New:
Call.request()
returns (optionally creating) theRequest
object for the call. Note: If this is called beforeCall.execute()
orCall.enqueue()
this will do relatively expensive work synchronously. Doing so in performance-critical sections (like on the Android main thread) should be avoided. - New: Support for the release version of OkHttp 3.0 and newer.
- New:
adapter-guava
module provides aCallAdapter.Factory
for Guava'sListenableFuture
. - New:
adapter-java8
module provides aCallAdapter.Factory
for Java 8'sCompleteableFuture
. - New:
ScalarsConverterFactory
(fromconverter-scalars
module) now supports parsing response bodies into eitherString
, the 8 primitive types, or the 8 boxed primitive types. - New: Automatic support for sending callbacks to the iOS main thread when running via RoboVM.
- New: Method annotations are now passed to the factory for request body converters. This allows converters to alter the structure of both request bodies and response bodies with a single method-level annotation.
- Each converter has been moved to its own package under
retrofit2.converter.<name>
. This prevents type collisions when many converters are simultaneously in use. - Fix: Exceptions thrown when unable to locate a
CallAdapter.Factory
for a method return type now correctly list theCallAdapter.Factory
instances checked. - Fix: Ensure default methods on service interfaces can be invoked.
- Fix: Correctly resolve the generic parameter types of collection interfaces when subclasses of those collections are used as method parameters.
- Fix: Do not encode
/
characters in@Path
replacements whenencoded = true
.
2.0.0-beta3 - 2016-01-05
- New: All classes have been migrated to the
retrofit2.*
package name. The Maven groupId is nowcom.squareup.retrofit2
. This is in accordance with the Java Interoperability Policy for Major Version Updates. With this change Retrofit 2.x can coexiest with Retrofit 1.x in the same project. - New: Update to use the OkHttp 3 API and OkHttp 3.0.0-RC1 or newer is now required. Similar to the previous
point, OkHttp has a new package name (
okhttp3.*
) and Maven groupId (com.squareup.okhttp3
) which allow it to coexist with OkHttp 2.x in the same project. - New: String converters allow for custom serialization of parameters that end up as strings (such as
@Path
,@Query
,@Header
, etc.).Converter.Factory
has a newstringConverter
method which receives the parameter type and annotations and can return a converter for that type. This allows providing custom rendering of types likeDate
,User
, etc. to a string before being used for its purpose. A default converter will calltoString()
for any type which retains the mimics the previous behavior. - New: OkHttp's
Call.Factory
type is now used as the HTTP client rather than using theOkHttpClient
type directly (OkHttpClient
does implementCall.Factory
). AcallFactory
method has been added to bothRetrofit.Builder
andRetrofit
to allow supplying alternate implementations of an HTTP client. Theclient(OkHttpClient)
method onRetrofit.Builder
still exists as a convenience. - New:
isExecuted()
method returns whether aCall
has been synchronously or asynchronously executed. - New:
isCanceled()
method returns whether aCall
has been canceled. Use this inonFailure
to determine whether the callback was invoked from cancellation or actual transport failure. - New:
converter-scalars
module provides aConverter.Factory
for convertingString
, the 8 primitive types, and the 8 boxed primitive types astext/plain
bodies. Install this before your normal converter to avoid passing these simple scalars through, for example, a JSON converter. - New:
Converter.Factory
methods now receive aRetrofit
instance which also now has methods for querying the next converter for a given type. This allows implementations to delegate to others and provide additional behavior without complete reimplementation. - New:
@OPTIONS
annotation more easily allows for making OPTIONS requests. - New:
@Part
annotation now supportsList
and array types. - New: The
@Url
annotation now allows usingjava.net.URI
orandroid.net.Uri
(in addition toString
) as parameter types for providing relative or absolute endpoint URLs dynamically. - New: The
retrofit-mock
module has been rewritten with a newBehaviorDelegate
class for implementing fake network behavior in a local mock implementation of your service endpoints. Documentation and more tests are forthcoming, but theSimpleMockService
demonstrates its use for now. - Fix: Forbid Retrofit's
Response
type and OkHttp'sResponse
type as the response body type given to aCall
(i.e.,Call<Response>
). OkHttp'sResponseBody
type is the correct one to use when the raw body contents are desired. - Fix: The Gson converter now respects settings on the supplied
Gson
instance (such asserializeNulls
). This requires Gson 2.4 or newer. - The Wire converter has been updated to the Wire 2.0 API.
- The change in 2.0.0-beta2 which provided the
Retrofit
instance to theonResponse
callback ofCallback
has been reverted. There are too many edge cases around providing theRetrofit
object in order to allow deserialization of the error body. To accommodate this use case, pass around theRetrofit
response manually or implement a customCallAdapter.Factory
does so automatically.
2.0.0-beta2 - 2015-09-28
- New: Using a response type of
Void
(e.g.,Call<Void>
) will ignore and discard the response body. This can be used when there will be no response body (such as in a 201 response) or whenever the body is not needed.@Head
requests are now forced to use this as their response type. - New:
validateEagerly()
method onRetrofit.Builder
will verify the correctness of all service methods on calls tocreate()
instead of lazily validating on first use. - New:
Converter
is now parameterized over both 'from' and 'to' types with a singleconvert
method.Converter.Factory
is now an abstract class and has factory methods for both request body and response body. - New:
Converter.Factory
andCallAdapter.Factory
now receive the method annotations when being created for a return/response type and the parameter annotations when being created for a parameter type. - New:
callAdapter()
method onRetrofit
allows querying aCallAdapter
for a given type. ThenextCallAdapter()
method allows delegating to anotherCallAdapter
from within aCallAdapter.Factory
. This is useful for composing call adapters to incrementally build up behavior. - New:
requestConverter()
andresponseConverter()
methods onRetrofit
allow querying aConverter
for a given type. - New:
onResponse
method inCallback
now receives theRetrofit
instance. Combined with theresponseConverter()
method onRetrofit
, this provides a way of deserializing an error body onResponse
. See theDeserializeErrorBody
sample for an example. - New: The
MoshiConverterFactory
has been updated for its v1.0.0. - Fix: Using
ResponseBody
for the response type orRequestBody
for a parameter type is now correctly identified. Previously these types would erroneously be passed to the supplied converter. - Fix: The encoding of
@Path
values has been corrected to conform to OkHttp'sHttpUrl
. - Fix: Use form-data content disposition subtype for
@Multipart
. - Fix:
Observable
andSingle
-based execution of requests now behave synchronously (and thus requiressubscribeOn()
for running in the background). - Fix: Correct
GsonConverterFactory
to honor the configuration of theGson
instances (such as not serializing null values, the default).
2.0.0-beta1 - 2015-08-27
- New:
Call
encapsulates a single request/response HTTP call. A call can by run synchronously viaexecute()
or asynchronously viaenqueue()
and can be canceled withcancel()
. - New:
Response
is now parameterized and includes the deserialized body object. - New:
@Url
parameter annotation allows passing a complete URL for an endpoint. - New: OkHttp is now required as a dependency. Types like
TypedInput
andTypedOutput
(and its implementations),Request
, andHeader
have been replaced with OkHttp types likeRequestBody
,ResponseBody
, andHeaders
. - New:
CallAdapter
(andFactory
) provides extension point for supporting multiple execution mechanisms. An RxJava implementation is provided by a sibling module. - New:
Converter
(andFactory
) provides extension point for supporting multiple serialization mechanisms. Gson, Jackson, Moshi, Protobuf, Wire, and SimpleXml implementations are provided by sibling modules. - Fix: A lot of things.
- Hello Droidcon NYC 2015!
1.9.0 - 2015-01-07
- Update to OkHttp 2.x's native API. If you are using OkHttp you must use version 2.0 or newer (the latest
is 2.2 at time of writing) and you no longer need to use the
okhttp-urlconnection
shim. - New: Allow disabling Simple XML Framework's strict parsing.
- New:
@Header
now accepts aList
or array for a type. - New:
@Field
and@FieldMap
now have options for enabling or disabling URL encoding of names and values. - Fix: Remove query parameters from thread name when running background requests for asynchronous use.
1.8.0 - 2014-11-18
- Update to RxJava 1.0. This comes with the project's 'groupId' change from
com.netflix.rxjava
toio.reactivex
which is why the minor version was bumped.
1.7.1 - 2014-10-23
- Fix: Correctly log
null
request arguments forHEADERS_AND_ARGS
log level.
1.7.0 - 2014-10-08
- New:
RetrofitError
'sgetKind()
now disambiguates the type of error represented. - New:
HEADERS_AND_ARGS
log level displays parameters passed to method invocation along with normal header list. - New:
@Part
and@PartMap
now support specifying theContent-Transfer-Encoding
of their respective values. - New:
@Path
,@Query
, and@QueryMap
now have options for enabling or disabling URL encoding on names (where appropriate) and values. @Header
now accepts all object types, invokingString.valueOf
when neccesary.- Attempting to use a
@Path
replacement block ({name}
) in a query parameter now suggested@Query
in the exception message. - Fix: Correct NPE when
Content-Type
override is specified on requests without a body. - Fix:
WireConverter
now correctly throwsConversionException
on incorrect MIME types for parity withProtoConverter
. - Fix: Include
Content-Type
on AppEngine requests. - Fix: Account for NPE on AppEngine when the response URL was not automatically populated in certain cases.
- Fix:
MockRestAdapter
's RxJava support now correctly schedules work on the HTTP executor, specifically when chaining multiple requests together. - Experimental RxJava support updated for v0.20.
1.6.1 - 2014-07-02
- Fix: Add any explicitly-specified 'Content-Type' header (via annotation or param) to the request even if there is no request body (e.g., DELETE).
- Fix: Include trailing CRLF in multi-part uploads to work around a bug in .NET MVC 4 parsing.
- Fix: Allow
null
mock exception bodies and use the success type from the declared service interface.
1.6.0 - 2014-06-06
- New:
@Streaming
on aResponse
type will skip buffering the body to abyte[]
before delivering. - When using OkHttp, version 1.6.0 or newer (including 2.0.0+) is now required.
- The absence of a response body and an empty body are now differentiated in the log messages.
- Fix: If set, the
RequestInterceptor
is now applied at the time ofObservable
subscription rather than at the time of its creation. - Fix:
Callback
subtypes are now supported when usingMockRestAdapter
. - Fix:
RetrofitError
now contains a useful message indicating the reason for the failure. - Fix: Exceptions thrown when parsing the response type of the interface are now properly propagated.
- Fix: Calling
Response#getBody
whennull
body now correctly returns instead of throwing an NPE. - Experimental RxJava support updated for v0.19.
- The
Content-Type
andContent-Length
headers are no longer automatically added to the header list on theRequest
object. This reverts erroneous behavior added in v1.5.0. CustomClient
implementations should revert to adding these headers based on theTypedInput
body of theRequest
.
1.5.1 - 2014-05-08
- New:
@PartMap
annotation accepts aMap
of key/value pairs for multi-part. - Fix:
MockRestAdpater
uses theErrorHandler
from its parentRestAdapter
. - Experimental RxJava support updated for v0.18 and is now lazily initialized.
1.5.0 - 2014-03-20
- New: Support for AppEngine's URL Fetch HTTP client.
- New: Multipart requests of unknown length are now supported.
- New: HTTP
Content-Type
can be overridden with a method-level or paramter header annotation. - New: Exceptions from malformed interface methods now include detailed information.
- Fix: Support empty HTTP response status reason.
- If an
ErrorHandler
is supplied it will be invoked forCallback
andObservable
methods. - HTTP
PATCH
method usingHttpUrlConnection
is no longer supported. Add the OkHttp jar to your project if you need this behavior. - Custom
Client
implementations should no longer setContent-Type
orContent-Length
headers based on theTypedInput
body of theRequest
. These headers will now be added automatically as part of the standardRequest
header list.
1.4.1 - 2014-02-01
- Fix:
@QueryMap
,@EncodedFieldMap
, and@FieldMap
now correctly detectMap
-based parameter types.
1.4.0 - 2014-01-31
- New:
@Query
and@EncodedQuery
now acceptList
or arrays for multiple values. - New:
@QueryMap
and@EncodedQueryMap
accept aMap
of key/value pairs for query parameters. - New:
@Field
now acceptsList
or arrays for multiple values. - New:
@FieldMap
accepts aMap
of name/value pairs for form URL-encoded request bodies. - New:
Endpoint
replacesServer
as the representation of the remote API root. TheEndpoints
utility class contains factories methods for creating instances.Server
andChangeableServer
are now deprecated. SimpleXmlConverter
andJacksonConverter
now have a default constructor.Response
now includes the URL.- Fix: Hide references to optional classes to prevent over-eager class verifiers from complaining (e.g., Dalvik).
- Fix: Properly detect and reject interfaces which extend from other interfaces.
1.3.0 - 2013-11-25
- New: Converter module for SimpleXML.
- New: Mock module which allows simulating real network behavior for local service interface implementations. See 'mock-github-client' example for a demo.
- New: RxJava
Observable
support! Declare a return type ofObservable<Foo>
on your service interfaces to automatically get an observable for that request. (Experimental API) - Fix: Use
ObjectMapper
's type factory when deserializing (Jackson converter). - Multipart POST requests now stream their individual part bodies.
- Log chunking to 4000 characters now only happens on the Android platform.
1.2.2 - 2013-09-12
- Fix: Respect connection and read timeouts on supplied
OkHttpClient
instances. - Fix: Ensure connection is closed on non-200 responses.
1.2.1 - 2013-08-30
- New: Converter for Wire protocol buffers!
1.2.0 - 2013-08-23
- New: Additional first-party converters for Jackson and Protocol Buffers! These are provided
as separate modules that you can include and pass to
RestAdapter.Builder
'ssetConverter
. - New:
@EncodedPath
and@EncodedQuery
annotations allow provided path and query params that are already URL-encoded. - New:
@PATCH
HTTP method annotation. - Fix: Properly support custom HTTP method annotations in
UrlConnectionClient
. - Fix: Apply
RequestInterceptor
during method invocation rather than at request execution time. - Change
setDebug
tosetLogLevel
onRestAdapter
andRestAdapter.Builder
and provide two levels of logging viaLogLevel
. - Query parameters can now be added in a request interceptor.
1.1.1 - 2013-06-25
- Fix: Ensure
@Headers
-defined headers are correctly added to requests. - Fix: Supply reasonable connection and read timeouts for default clients.
- Fix: Allow passing
null
for a@Part
-annotated argument to remove it from the multipart request body.
1.1.0 - 2013-06-20
- Introduce
RequestInterceptor
to replaceRequestHeaders
. An interceptor provided to theRestAdapter.Builder
will be called for every request and allow setting both headers and additional path parameter replacements. - Add
ErrorHandler
for customizing the exceptions which are thrown when synchronous methods return non-200 error codes. - Properly parse responses which erroneously omit the "Content-Type" header.
1.0.2 - 2013-05-23
- Allow uppercase letters in path replacement identifiers.
- Fix: Static query parameters in the URL are now correctly appended with a separating '?'.
- Fix: Explicitly allow or forbid
null
as a value for method parameters.@Path
- Forbidden@Query
- Allowed@Field
- Allowed@Part
- Forbidden@Body
- Forbidden@Header
- Allowed
1.0.1 - 2013-05-13
- Fix: Correct bad regex behavior on Android.
1.0.0 - 2013-05-13
Initial release.