Skip to content

Releases: apollographql/apollo-kotlin

v2.2.1

22 Jun 09:34
Compare
Choose a tag to compare

Summary

This version is a maintainance release to add the STORE_PARTIAL_RESPONSES cache header. Version 2.1.0 changed the caching behaviour to not store partial response if there are errors. This is the expected behaviour in the large majority of cases but some use cases might rely on this old behaviour. If you are in this case, you can now opt-in the previous behaviour with STORE_PARTIAL_RESPONSES. See #2363 for more details.

New

  • [Cache] Add opt-in to cache responses with errors (#2363)

Bugfixes

  • [Multiplatform] do not escape the variables json (#2377)
  • [Compiler] Don't merge inline fragment with directives (conditions) (#2352)
  • [Subscriptions] make the error message if subscriptions are not configured more actionable (#2373)

Misc

  • The documentation now contains a tutorial and different "getting started" pages for Jav/Kotlin/Multiplatform
  • The artifacts hosted on JCenter are now signed with an apollographql GPG key (key ID 5A446C80C27E095353CF3969F165A96372E61948) instead of the default Bintray key before.

v2.2.0

11 Jun 09:58
Compare
Choose a tag to compare

Summary

This version, amongst other things, contains RxJava3 support, a new way to register ApolloInterceptor with factories and makes it easier to download your schema.json from the command line. Starting with this version, releases are published on Maven Central in addition to Jcenter.

RxJava3 support (#2304)

Version 2.2.0 includes support for RxJava3. To use it, add the dependency to your Gradle file:

// RxJava3 support
implementation("com.apollographql.apollo:apollo-rx3-support:x.y.z")

The dependency contains static and extension methods to convert ApolloCall, ApolloSubscriptionCall, etc... to their RxJava3 counterparts.

For an exemple, to convert an ApolloCall to an Observable:

Java:

// Create a query object
EpisodeHeroName query = EpisodeHeroName.builder().episode(Episode.EMPIRE).build();

// Create an ApolloCall object
ApolloCall<EpisodeHeroName.Data> apolloCall = apolloClient.query(query);

// RxJava3 Observable
Observable<Response<EpisodeHeroName.Data>> observable3 = Rx3Apollo.from(apolloCall);

Kotlin:

// Create a query object
val query = EpisodeHeroNameQuery(episode = Episode.EMPIRE.toInput())

// Directly create Observable with Kotlin extension
val observable = apolloClient.rxQuery(query)

You can read more in the dedicated section of the documentation.

ApolloClient.applicationInterceptorFactories() (#2302)

ApolloInterceptors added with ApolloClient.applicationInterceptor() were only created once for the lifetime of the ApolloClient so the same interceptor was always disposed. If you need your interceptor to start with a new state for each call, you can use ApolloInterceptorFactory that will create a new interceptor for each new call.

Simplified downloadApolloSchema task usage from the command line (#2321)

Using the downloadApolloSchema task from the command line is now easier:

# Instead of using properties:
./gradlew downloadApolloSchema -Pcom.apollographql.apollo.endpoint=https://your.graphql.endpoint \
-Pcom.apollographql.apollo.schema=src/main/graphql/com/example/schema.json

# You can now use `--endpoint` and `--schema`:
./gradlew downloadApolloSchema --endpoint=https://your.graphql.endpoint --schema=app/src/main/graphql/com/example/schema.json

Fixes

  • Change constructor visibility for WebSocketSubscribtionTransport (#2348)
  • [Runtime] fix AbstractMethodError due to @JvmSynthetic (#2349)
  • Fix issue with query root level fragment support. (#2344)
  • Add check for missing selection set for object types. (#2344)
  • [Subscriptions] make a copy of the list to avoid ConcurrentModificationException (#2332)
  • [Gradle Plugin] Use relative strings for the rootFolder input property so as not to break cacheability (#2294)
  • [Build] release artifacts on maven central (#1130)

Internal changes

  • Provide base websocket abstraction (#2311)
  • [Kotlin Runtime] Add BearerTokenInterceptor (#2298)
  • [Tooling] enable checkstyle again (#2296)
  • Fix a small issue in sample (#2308)

v2.1.0

21 May 22:39
Compare
Choose a tag to compare

Important changes

The normalized cache will not store partial response data anymore if the response contains errors (#2281). This is to avoid storing inconsistent data. Make sure that your code doesn't rely on this behaviour before upgrading.

New features

  • It is now possible to generate GraphQL enum types as sealed classes to retain their rawValue. (#2279)

For this, use the sealedClassesForEnumsMatching gradle option:

// build.gradle.kts
apollo {
    sealedClassesForEnumsMatching.set(listOf("SomeEnum", "OtherEnum"))
}

Fixes

  • [Runtime] ApolloStore.write fragment crash on execute (#2289)
  • [Plugin] Create the directory for the user if needed during the schemaDownload (#2283)
  • [Cache] Prevent incorrect caching of partial responses with errors (#2281)
  • [Runtime] Revert okhttp to 3.12 to continue supporting Android 4.4 (#2269)
  • [Codegen] Improve performance of the codegen (#2257)
  • [Plugin] Also take into account the root project when enforcing versions (#2254)

Internal changes

  • [Tooling] enable checkstyle again (#2296)
  • [Documentation] Reorganize docset (#2292)
  • [Runtime] Fix wrong error message in CallState (#2290)
  • [Codegen] Update codegen tests (#2260)
  • [Multiplatform] Make Execution context more Kotlin coroutine context idiomatic (#2258)
  • [Multiplatform] Kotlin runtime initial structure (#2256)
  • [Multiplatform] Introduce GraphQL execution context (#2248)

v2.0.3

14 May 13:16
Compare
Choose a tag to compare

Technical release to revert multiplatform apollo-normalized-cache-sqlite until we figure out how to handle #2253

v2.0.2

05 May 19:40
Compare
Choose a tag to compare

Important Fixes

Since version 2.0.0, the normalized cache could behave unpredictably when trying to update a CacheKey:

  • Fix issue with sql cache not updated for the same CacheKey (#2245)

Internal changes

  • Fix issues with Kotlin Multiplatform setup (#2238)
  • Make sqlite module multiplatform Component: Kotlin MPP (#2234)
  • Migrate Transaction and EvictionPolicy to Kotlin (#2144)

New features

There's now a shiny Swift UI demo app using Kotlin multiplatform models:

  • Swift UI funtimes for iOS Sample App on KMP (#2223)
  • Generate synthetic accessor for optional list properties (#2232)

80329982-8bd07880-8809-11ea-8ad6-48e5b55f6f4c

v2.0.1

29 Apr 22:15
Compare
Choose a tag to compare

New features

You can now add comments to your .graphql queries.

For an example:

# This is a sample query to fetch hero name
# that demonstrates Java / Kotlin docs generations
# for query data model
query TestQuery {
 ...
}

Will produce somthing like:

/**
 *  This is a sample query to fetch hero name
 *  that demonstrates Java / Kotlin docs generations
 *  for query data model
 */
@Suppress("NAME_SHADOWING", "UNUSED_ANONYMOUS_PARAMETER", "LocalVariableName",
    "RemoveExplicitTypeArguments", "NestedLambdaShadowedImplicitParameter")
class TestQuery : Query<TestQuery.Data, TestQuery.Data, Operation.Variables> {

Bug Fixes

  • Make sure generated code do not produce warnings (#2219)
  • Migrate Transaction and EvictionPolicy to Kotlin (#2144)
  • Fix eager asFlow() completion (#2214)
  • Take nullity into account to generate correct code (#2213)
  • Add missing Java/Kotlin Docs generation for generated classes (#2210)

Internal Changes

  • Convert ApolloStore to kotlin (#2144)
  • Update OkHttp for important fixes (#2215)

v2.0.0

21 Apr 20:42
Compare
Choose a tag to compare

Important Changes

Kotlin Multiplatform

We are really excited to announce that with this release it is possible to build Kotlin Multiplatform apps with Apollo. The supported targets are Android / iOS / JVM. Currently only apollo-api module supports Kotlin Multiplatform. It is enough to use the generated code for preparing request body for Http calls and parse the response body.

This is a backward compatible change for existing users. Please keep in mind that it will bring Kotlin standard library as a transitive dependency.

Side effect changes of Kotlin migration:

  • Some primitive types like Booleans may be unboxed where appropriate
  • Classes and functions are final unless they are intentionally marked as open
  • Kotlin-stdlib is added as a transitive dependency
  • Jvm target version is now 1.8
  • Gradle 6.x recommended. In 5.x, Gradle Metadata needs to be enabled by putting this into settings.gradle enableFeaturePreview("GRADLE_METADATA")

Okio and OkHttp migration

During Kotlin Multiplatform integration, Okio and OkHttp are migrated to their latest major versions to make use of their Kotlin support.
Okio is upgraded to 2.4.3 and OkHttp is upgraded to 4.4.0

Note: If you explicitly depend on these libraries, it would be recommended to do major version upgrade of this libraries first before upgrading Apollo.

Both of them are binary compatible for Java users. There are some source incompatible changes for Kotlin users. Please use Code Cleanup feature of IntelliJ / Android Studio to automatically handle the migration. More info can be found here: https://square.github.io/okhttp/upgrading_to_okhttp_4/

Update Okio and Okhttp (#2054)

New Normalized Cache Modules

For in-memory LruNormalizedCache users, no change required since apollo-runtime brings it as transitive dependency. It is still recommended adding the following dependency explicitly: implementation("com.apollographql.apollo:apollo-normalized-cache:x.y.z")

Apollo normalized cache module (#2142)

SqlNormalizedCache is moved to its own module. If you added apollo-android-support for disk cache, replace it with new dependency.

// Replace:
implementation("com.apollographql.apollo:apollo-android-support:x.y.z")

// With:
implementation("com.apollographql.apollo:apollo-normalized-cache-sqlite:2.0.0")

ApolloSqlHelper is deprecated. Instantiate SqlNormalizedCacheFactory class with same arguments instead.

// Replace:
val apolloSqlHelper = ApolloSqlHelper.create(context, "db_name")
val cacheFactory = SqlNormalizedCacheFactory(apolloSqlHelper)

// With:
val cacheFactory = SqlNormalizedCacheFactory(context, name = "db_name")

Replace legacy Android SQL with SqlDelight (#2158)

Deprecated Gradle Plugin is removed

The deprecated Gradle Plugin is now removed. Please refer to migration guide from previous releases before upgrading to 2.0
https://www.apollographql.com/docs/android/essentials/migration/#gradle-plugin-changes

Bug-fixes

  • Suppress raw type warning in generated code (#2149)
  • Fix issue with long query name generates bad formatted kotlin code (#2153)
  • Fix an issue where removing graphql files does not remove the generated files (#2170)
  • Fix asFlow() leak (#2175)
  • Put special KotlinPoet character to avoid broken wrapped code (#2190)

Kotlin Multiplatform Support

  • Migrate Http cache api module to kotlin (#2051)
  • Migrate Utils to kotlin (#2052)
  • Refactor ScalarType (#2063)
  • Add iOS targets to API module (#2070)
  • fix KMP artifacts (#2084)
  • Convert top level api classes to Kotlin (#2021)
  • Convert bunch of internal classes to Kotlin (#2028)
  • Convert generic reader / writer Json classes to Kotlin (#2042)
  • Convert OperationDataJsonSerializer to Kotlin by keeping existing Java api compatible. (#2050)
  • Migrate logger to Kotlin (#2047)
  • Convert next portion of api module files to Kotlin (#2044)
  • Remove redundant supplier class and use Kotlin Function0 (#2059)
  • Introduce Kotlin Multiplatform into apollo-api module (#2062)
  • Fix publish task to cover Kotlin MPP (#2067)
  • Some Kotlin MPP publication fixes (#2072)
  • [Gradle Plugin] Support Kotlin multiplatform (#2120)
  • Kotlin Multiplatform Sample (#2136)
  • More Kotlin in normalized-cache (#2151)
  • Migrate some normalized cache classes (#2148)
  • Generate 'composeRequestBody' to encode GraphQL POST request payload (#2150)
  • Add overloaded constructors for SqlNormalizedCacheFactory (#2189)
  • Fix some of the dependency issues (#2168)
  • Enable support for generics Objective-C interop (#2174)
  • KMP sample: coroutines in common code (#2160)
  • Generate overloaded parse method for ByteString (#2178)
  • Fix compat issues on iOS target (#2177)
  • Replace DetachedObjectGraph wrapper with stable ref. (#2198)

Clean up / Maintenance

  • Remove apollo-gradle-plugin-deprecated (#2015)
  • Fix deeplink to plugin config (#2056)
  • bump gradle version to 6.2.2 (#2085)
  • Update agp to 3.6 (#2088)
  • Move to GitHub actions (#2091)
  • Avoid doc duplication by using README.md on gatsby as well (#2053)
  • Expose per repo publishing tasks (#2094)
  • update Releasing.md (#2101)
  • Updated Coroutines documentation with new extensions, removed depreciated extensions. (#2105)
  • Silence sdkmanager (#2113)
  • Move migration guide (#2114)
  • Move getting started to top level (#2118)
  • Add contribution instructions to README (#2110)
  • Skip CI checks if the changes are only for documentations (#2115)
  • fix tag detection (#2123)
  • Move test class back into test sources (#2147)
  • Add full exceptions for better error output on CI (#2155)
  • Update docs for 2.0.0 release (#2169)
  • Remove some deprecated declarations and usages for 2.0 (#2161)
  • Update maven publishing (#2172)
  • bump the plugin-publish version. (#2195)
  • Make kotlin-sample project use generated Kotlin models (#2196

External Contributions

Thanks @ralphie9224 @zachburt05 @odlund @zhuhaow @lwasyl @SubhrajyotiSen for contributions

v1.4.5

18 Apr 08:49
Compare
Choose a tag to compare

Bug Fixes

  • Suppress raw type warning in generated code (#2149)
  • Fix issue with long query name generates bad formatted kotlin code (#2153)
  • Fix an issue where removing graphql files does not remove the generated files (#2170)
  • Fix asFlow() leak (#2175)
  • Put special KotlinPoet character to avoid broken wrapped code (#2190)

v1.4.4

06 Apr 19:07
Compare
Choose a tag to compare

Bug Fixes

  • Fix issue with fragment field type conditions (#2125)
  • Generate Mapper function for Kotlin models (#2130)

v1.4.3

31 Mar 08:20
Compare
Choose a tag to compare

Bug Fixes

  • Fix query watcher not calling status events (#2102)
  • Fix duplicate class generation in test folders (#2106)
  • Fix issue with HttpCache causes HttpParseException (#2107)
  • Fix IdlingResources issue with Watcher (#2108)
  • Scope fields in operation variables (#2122)