@urql/core
August 11, 2025 · View on GitHub
6.0.1
Patch Changes
- Use nullish coalescing for
preferGetMethodandpreferGetForPersistedQueriesso thatfalseis kept if set Submitted by @dargmuesli (See #3812)
6.0.0
Major Changes
- By default leverage GET for queries where the query-string + variables comes down to less than 2048 characters.
When upgrading it's important to see whether your server supports
GET, if it doesn't ideally adding support for it or alternatively settingpreferGetMethodin thecreateClientmethod as well aspreferGetForPersistedQueriesfor the persisted exchange tofalseSubmitted by @JoviDeCroock (See #3789)
Minor Changes
- Fix type definition for
GraphQLRequestParamsto makevariablesfield optional if and only if all fields are optional or nullish Submitted by @arkandias (See #3807)
5.2.0
Minor Changes
- export the getOperationName utility function Submitted by @giacomocerquone (See #3785)
5.1.2
Patch Changes
- Correct typo in cacheHit debug message of the
debugExchangeSubmitted by @jorrit (See #3773) - ⚠️ Fix
fetchSourcenot text-decoding response chunks as streams, which could cause UTF-8 decoding to break Submitted by @i110 (See #3767) - ⚠️ Fix compatibility with Typescript >5.5 (See: https://github.com/0no-co/graphql.web/pull/49) Submitted by @andreisergiu98 (See #3730)
- Change debug log verbosity to
console.debugrather thanconsole.logSubmitted by @kitten (See #3770)
5.1.1
Patch Changes
- Omit minified files and sourcemaps'
sourcesContentin published packages Submitted by @kitten (See #3755)
5.1.0
Minor Changes
- Remove
addMetadatatransform where we'd strip out metadata for production environments, this particularly affectsOperationResult.context.metadata.cacheOutcomeSubmitted by @alpavlove (See #3714)
5.0.8
Patch Changes
- ⚠️ Fix
deepMergeregression on array values Submitted by @JoviDeCroock (See #3696)
5.0.7
Patch Changes
- Remove
for-ofsyntax from@urql/corehelpers for JSC memory reduction Submitted by @kitten (See #3690)
5.0.6
Patch Changes
- Allow empty error messages when re-hydrating GraphQL errors Submitted by @JoviDeCroock (See #3650)
5.0.5
Patch Changes
5.0.4
Patch Changes
- Change how we calculate the
OperationKeyto take files into account, before we would encode them tonullresulting in every mutation with the same variables (excluding the files) to have the same key. This resulted in mutations that upload different files at the same time to share a result in GraphCache Submitted by @JoviDeCroock (See #3601)
5.0.3
Patch Changes
- Use
documentIdfrom persisted documents for document keys, when it's available Submitted by @kitten (See #3575)
5.0.2
Patch Changes
- ⚠️ Fix issue where a reexecute on an in-flight operation would lead to multiple network-requests. For example, this issue presents itself when Graphcache is concurrently updating multiple, inter-dependent queries with shared entities. One query completing while others are still in-flight may lead to duplicate operations being issued Submitted by @JoviDeCroock (See #3573)
5.0.1
Patch Changes
- ⚠️ Fix
@ts-ignoreon TypeScript peer dependency import in typings not being applied due to a leading!character Submitted by @kitten (See #3567)
5.0.0
Major Changes
- Remove deprecated
dedupExchangeSubmitted by @JoviDeCroock (See #3520) - Remove deprecated
maskTypenameSubmitted by @JoviDeCroock (See #3520)
Patch Changes
4.3.0
Minor Changes
- Support Apollo Federation's format for subscription results in
multipart/mixedresponses (result properties essentially are namespaced on apayloadkey) Submitted by @JoviDeCroock (See #3499) - Add support for sending persisted documents. Any
DocumentNodewith no/empty definitions and adocumentIdproperty is considered a persisted document. When this is detected adocumentIdparameter rather than aquerystring is sent to the GraphQL API, similar to Automatic Persisted Queries (APQs). However, APQs are only supported via@urql/exchange-persisted, while support fordocumentIdis now built-in Submitted by @kitten (See #3515)
Patch Changes
- Allow
urlto be a plain, non-URL pathname (i.e./api/graphql) to be used withpreferGetMethodSubmitted by @akrantz01 (See #3514) - Correctly support the
Headersclass being used infetchOptionsSubmitted by @JoviDeCroock (See #3505)
4.2.3
Patch Changes
- Add back our cache-outcome on the document-cache, this was behind a development flag however in our normalized cache we always add it already Submitted by @JoviDeCroock (See #3464)
4.2.2
Patch Changes
- ⚠️ Fix the default
cacheExchangecrashing oncache-onlyrequest policies with cache misses due toundefinedresults Submitted by @JoviDeCroock (See #3459)
4.2.1
Patch Changes
- ⚠️ Fix incorrect JSON stringification of objects from different JS contexts. This could lead to invalid variables being generated in the Vercel Edge runtime specifically Submitted by @SoraKumo001 (See #3453)
4.2.0
Minor Changes
- Try to parse
text/plaincontent-type as JSON before bailing out with an error Submitted by @JoviDeCroock (See #3430)
4.1.4
Patch Changes
- Implement new
@defer/@streamtransport protocol spec changes Submitted by @JoviDeCroock (See #3389) - Support non spec-compliant error bodies, i.e. the Shopify API does return
errorsbut as an object. Adding a check whether we are really dealing with an Array of errors enables this Submitted by @JoviDeCroock (See #3395) - ⚠️ Fix
preferGetMethod: 'force' | 'within-url-limit'not being applied correctly by theClientSubmitted by @Burbenog (See #3403)
4.1.3
Patch Changes
- ⚠️ Fix missing
teardownoperation handling in thessrExchange. This could lead to duplicate network operations being executed Submitted by @kitten (See #3386)
4.1.2
Patch Changes
- Explicitly unblock
client.reexecuteOperationcalls to allow stalled operations from continuing and re-executing. Previously, this could cause@urql/exchange-graphcacheto stall if an optimistic mutation led to a cache miss Submitted by @kitten (See #3363)
4.1.1
Patch Changes
- Add case for
subscriptionExchangeto handleGraphQLError[]received in theerrorobserver callback. Note: This doesn't strictly check for theGraphQLErrorshape and only checks for arrays and receiving errors in theExecutionResulton thenextobserver callback is preferred and recommended for transports Submitted by @kitten (See #3346)
4.1.0
Minor Changes
- Update
formatDocumentto outputFormattedNodetype mapping. The formatter will now annotate added__typenamefields with_generated: true, place selection nodes' directives onto a_directivesdictionary, and will filter directives to not include"_"underscore prefixed directives in the final query. This prepares us for a feature that allows enhanced client-side directives in Graphcache Submitted by @kitten (See #3317)
Patch Changes
- Add
OperationContext.optimisticflag as an internal indication on whether a mutation triggered an optimistic update in@urql/exchange-graphcache'scacheExchangeSubmitted by @kitten (See #3308)
4.0.11
Patch Changes
- Re-order
maskTypenameto apply masking earlier in the chain Submitted by @kitten (See #3298) - ⚠️ Fix
ssrExchangenot formatting query documents usingformatDocument. Without this call we'd run the risk of not having__typenameavailable on the client-side when rehydrating Submitted by @kitten (See #3288) - Add deprecation notice for
maskTypenameoption. Masking typenames in a result is no longer recommended. It’s only useful when multiple pre-conditions are applied and inferior to mapping to an input object manually Submitted by @kitten (See #3299)
4.0.10
Patch Changes
- Add missing
fetchSubscriptionsentry toOperationContext. The Client’sfetchSubscriptionsnow works properly and can be used to execute subscriptions as multipart/event-stream requests Submitted by @kitten (See #3244) - ⚠️ Fix
fetchSourcenot working for subscriptions sincehasNextisn’t necessarily set Submitted by @kitten (See #3244)
4.0.9
Patch Changes
- Return
AbortControllerinvocation to previous behaviour where it used to be more forceful. It will now properly abort outside of when our generator yields results, and hence now also cancels requests again that have already delivered headers but are currently awaiting a response body Submitted by @kitten (See #3239)
4.0.8
Patch Changes
- Respect
additionalTypenameson subscriptions and re-execute queries for them as well, as one would intuitively expect Submitted by @kitten (See #3230) - Update build process to generate correct source maps Submitted by @kitten (See #3201)
- Don't allow
isSubscriptionOperationoption insubscriptionExchangeto includeteardownoperations, to avoid confusion Submitted by @kitten (See #3206)
4.0.7
Patch Changes
4.0.6
Patch Changes
- Handle
multipart/mixedvariations starting with boundary rather than CRLF and a boundary Submitted by @kitten (See #3172) - ⚠️ Fix regression which would disallow
network-onlyoperations aftercache-and-networkcompleted Submitted by @kitten (See #3174)
4.0.5
Patch Changes
- Replace
FileandBlobobjects withnullin variables if multipart request will be started Submitted by @kitten (See #3169) - Strictly deduplicate
cache-and-networkandnetwork-onlyoperations, while a non-stale response is being waited for Submitted by @kitten (See #3157) - ⚠️ Fix boundary stopping
multipart/mixedstreams when it randomly occurs in response payloads Submitted by @kitten (See #3155) - Improve dispatching of arbitrary operations using
reexecuteOperationSubmitted by @kitten (See #3159)
4.0.4
Patch Changes
- ⚠️ Fix
hasNextbeing defaulted tofalsewhen a new subscription event is received on thesubscriptionExchangethat doesn't havehasNextset Submitted by @kitten (See #3137)
4.0.3
Patch Changes
- Handle
fetchrejections inmakeFetchSourceand properly hand them over toCombinedErrors Submitted by @kitten (See #3131)
4.0.2
Patch Changes
- ⚠️ Fix incremental delivery payloads not merging data correctly, or not handling patches on root results Submitted by @kitten (See #3124)
4.0.1
Patch Changes
- ⚠️ Fix format of
mapform data field on multipart upload requests. This was erroneously set to a string rather than a string tuple Submitted by @kitten (See #3118)
4.0.0
Major Changes
-
Remove
defaultExchangesfrom@urql/coreand makeexchangesa required property onClientconstruction. In doing so we make theurqlpackage more tree-shakeable as the three default exchanges are in no code paths meaning they can be removed if not used. A migration would look as follows if you are currently creating a client without exchangesimport { createClient, cacheExchange, fetchExchange } from '@urql/core'; const client = createClient({ url: '', exchanges: [cacheExchange, fetchExchange], });Submitted by @JoviDeCroock (See #3033)
-
Update
subscriptionExchangeto receiveFetchBodyinstead. In the usual usage ofsubscriptionExchange(for instance withgraphql-ws) you can expect no breaking changes. However, thekeyandextensionsfield has been removed and instead theforwardSubscriptionfunction receives the fullOperationas a second argument Submitted by @kitten (See #3054) -
Remove dependence on
graphqlpackage and replace it with@0no-co/graphql.web, which reduces the default bundlesize impact ofurqlpackages to a minimum. All types should remain compatible, even if you usegraphqlelsewhere in your app, and if other dependencies are usinggraphqlyou may alias it tographql-web-liteSubmitted by @kitten (See #3097) -
Update
OperationResult.hasNextandOperationResult.staleto be required fields. If you have a custom exchange creating results, you'll have to add these fields or use themakeResult,mergeResultPatch, ormakeErrorResulthelpers Submitted by @kitten (See #3061) -
Remove
getOperationNameexport from@urql/coreSubmitted by @kitten (See #3062)
Minor Changes
- Return a new
OperationResultSourcefrom allClientmethods (which replacesPromisifiedSourceon shortcut methods). This allows not onlytoPromise()to be called, but it can also be used as an awaitablePromiseLikeand has a.subscribe(onResult)method aliasing the subscribe utility fromwonkaSubmitted by @kitten (See #3060) - Update
subscriptionExchangeto support incremental results out of the box. If a subscription proactively completes, results are also now updated withhasNext: falseSubmitted by @kitten (See #3055) - Implement
text/event-streamresponse support. This generally adheres to the GraphQL SSE protocol and GraphQL Yoga push responses, and is an alternative tomultipart/mixedSubmitted by @kitten (See #3050) - Implement GraphQL Multipart Request support in
@urql/core. This adds the File/Blob upload support to@urql/core, which effectively deprecates@urql/exchange-multipart-fetchSubmitted by @kitten (See #3051) - Support
GraphQLRequest.extensionsas spec-extensions input to GraphQL requests Submitted by @kitten (See #3054) - Allow subscriptions to be handled by the
fetchExchangewhenfetchSubscriptionsis turned on Submitted by @kitten (See #3106) - Deprecate the
dedupExchange. The functionality of deduplicating queries and subscriptions has now been moved into and absorbed by theClient. Previously, theClientalready started doing some work to share results between queries, and to avoid dispatching operations as needed. It now only dispatches operations strictly when thededupExchangewould allow so as well, moving its logic into theClientSubmitted by @kitten (See #3058)
Patch Changes
- Deduplicate operations as the
dedupExchangedid; by filtering out duplicate operations until either the original operation has been cancelled (teardown) or a first result (withouthasNext: true) has come in Submitted by @kitten (See #3101) - ⚠️ Fix source maps included with recently published packages, which lost their
sourcesContent, including additional source files, and had incorrect paths in some of them Submitted by @kitten (See #3053) - Allow
makeOperationto be called with a partialOperationContextwhen it’s called to copy an operation. When it receives anOperationas a second argument now, the third argument, the context, will be spread into the prioroperation.contextSubmitted by @kitten (See #3081) - Move
multipart/mixedto end ofAcceptheader to avoid cauing Yoga to unnecessarily use it Submitted by @JoviDeCroock (See #3039) - Upgrade to
wonka@^6.3.0Submitted by @kitten (See #3104) - Update
Exchangecontract andcomposeExchangesutility to remove the need to manually callshareon either incomingSource<Operation>orforward()’sSource<OperationResult>. This is now taken care of internally incomposeExchangesand should make it easier for you to create custom exchanges and for us to explain them Submitted by @kitten (See #3082) - Add support for
graphql’s built-inTypedQueryDocumentNodetypings for type inference Submitted by @kitten (See #3085) - Add missing type exports of SSR-related types (
SerializedResult,SSRExchangeParams,SSRExchange, andSSRData) to@urql/core's type exports Submitted by @kitten (See #3079) - Allow any object fitting the
GraphQLErrorshape to rehydrate without passing through aGraphQLErrorconstructor inCombinedErrorSubmitted by @kitten (See #3087) - Add missing
hasNextandstalepassthroughs on caching exchanges Submitted by @kitten (See #3059) - ⚠️ Fix incremental results not merging
errorsfrom subsequent non-incremental results Submitted by @kitten (See #3055) - Add logic for
request.extensions.persistedQueryto@urql/coreto omit sendingqueryas needed Submitted by @kitten (See #3057) - ⚠️ Fix incorrect operation name being picked from queries that contain multiple operations Submitted by @kitten (See #3062)
- Replace fetch source implementation with async generator implementation, based on Wonka's
fromAsyncIterable. This also further hardens our support for the "Incremental Delivery" specification and refactors its implementation and covers more edge cases Submitted by @kitten (See #3043) - Ensure network errors are always issued with
CombinedErrors, while downstream errors are re-thrown Submitted by @kitten (See #3063) - Refactor
Clientresult source construction code and allow multiple mutation results, ifresult.hasNexton a mutation result is set totrue, indicating deferred or streamed results Submitted by @kitten (See #3102) - Remove dependence on
import { visit } from 'graphql';with smaller but functionally equivalent alternative Submitted by @kitten (See #3097)
3.2.2
Patch Changes
- ⚠️ Fix generated empty
Variablestype as passed to generics, that outputs a type of{ [var: string]: never; }. A legacy/unsupported version oftypescript-urql, which wrapsurql's React hooks, generates empty variables types as the following code snippet, which is not detected:
Submitted by @kitten (See #3029)type Exact<T extends { [key: string]: unknown }> = { [K in keyof T]: T[K] }; type Variables = Exact<{ [key: string]: never }>;
3.2.1
Patch Changes
3.2.0
Minor Changes
- Update support for the "Incremental Delivery" payload specification, accepting the new
incrementalproperty on execution results, as per the specification. This will expand support for newer APIs implementing the more up-to-date specification Submitted by @kitten (See #3007) - Update default
Acceptheader to includemultipart/mixedandapplication/graphql-response+json. The former seems to now be a defactor standard-accepted indication for support of the "Incremental Delivery" GraphQL over HTTP spec addition/RFC, and the latter is an updated form of the olderContent-Typeof GraphQL responses, so both the old and new one should now be included Submitted by @kitten (See #3007)
Patch Changes
- Add TSDoc annotations to all external
@urql/coreAPIs Submitted by @kitten (See #2962) - ⚠️ Fix subscriptions not being duplicated when
hasNextisn't set. ThehasNextfield is an upcoming "Incremental Delivery" field. When a subscription result doesn't set it we now set it totruemanually. This indicates to thededupExchangethat no duplicate subscription operations should be started Submitted by @kitten (See #3015) - Expose consistent
GraphQLRequestParamsutility type from whichGraphQLRequests are created in all bindings Submitted by @kitten (See #3022)
3.1.1
Patch Changes
- Correctly mark cache-hits from the ssr-exchange, by @JoviDeCroock (See #2872)
- ⚠️ Fix type-generation, with a change in TS/Rollup the type generation took the paths as src and resolved them into the types dir, by @JoviDeCroock (See #2870)
- ⚠️ Fix regression in
@urql/core'sstringifyDocumentthat caused some formatted documents to not be reprinted, by @JoviDeCroock (See #2871)
3.1.0
Minor Changes
- Implement
mapExchange, which replaceserrorExchange, allowingonOperationandonResultto be called to either react to or replace operations and results. For backwards compatibility, this exchange is also exported aserrorExchangeand supportsonError, by @kitten (See #2846)
Patch Changes
- Move remaining
Variablesgenerics over fromobjectdefault toVariables extends AnyVariables = AnyVariables. This has been introduced previously in #2607 but some missing ports have been missed due to TypeScript not catching them previously. Depending on your TypeScript version theobjectdefault is incompatible withAnyVariables, by @kitten (See #2843) - Reuse output of
stringifyDocumentin place of repeatedprint. This will mean that we now prevent callingprintrepeatedly for identical operations and are instead only reusing the result once. This change has a subtle consequence of our internals. Operation keys will change due to this refactor and we will no longer sanitise strip newlines from queries that@urql/corehas printed, by @kitten (See #2847) - Update to
wonka@^6.1.2to fix memory leak infetchcaused in Node.js by a lack of clean up after initiating a request, by @kitten (See #2850)
3.0.5
Patch Changes
- Update typings of the client to encompass the changes of https://github.com/FormidableLabs/urql/pull/2692, by @c-schwan (See #2758)
- ⚠️ Fix case where our transform-debug-target babel plugin would override the root dispatchDebug in
compose.tswith the latest found exchange, in this casefetchExchange, by @JoviDeCroock (See #2762)
3.0.4
Patch Changes
- ⚠️ Fix
ssrExchangebug which preventedstaleWhileRevalidatefrom sending off requests as network-only requests, and caused unrelatednetwork-onlyoperations to be dropped, by @kitten (See #2691) - Allow URL limit for GET requests to be bypassed using
preferGetMethod: 'force'rather than the defaulttrueor'within-url-limit'value, by @kitten (See #2692) - ⚠️ Fix operation identities preventing users from deeply cloning operation contexts. Instead, we now use a client-wide counter (rolling over as needed).
While this changes an internal data structure in
@urql/coreonly, this change also affects theofflineExchangein@urql/exchange-graphcachedue to it relying on the identity being previously an object rather than an integer, by @kitten (See #2732)
3.0.3
Patch Changes
- ⚠️ Fix variable types in core makeOperation, by @JoviDeCroock (See #2665)
3.0.2
Patch Changes
- ⚠️ Fix case where
maskTypenamewould not traverse down when the root query-field does not contain a__typename, by @mlecoq (See #2643)
3.0.1
Patch Changes
- ⚠️ fix setting a client default requestPolicy, we set
context.requestPolicy: undefinedfrom our bindings which makes a spread override the client-set default, by @JoviDeCroock (See #2634)
3.0.0
Major Changes
- Goodbye IE11! 👋 This major release removes support for IE11. All code that is shipped will be transpiled much less and will not be ES5-compatible anymore, by @kitten (See #2504)
- Remove support for options on the
ClientandClient.createOperationContext. We've noticed that there's no real need forcreateOperationContextor the options on theClientand that it actually encourages modifying properties on theClientthat are really meant to be modified dynamically via exchanges, by @kitten (See #2619) - Implement stricter variables types, which require variables to always be passed and match TypeScript types when the generic is set or inferred. This is a breaking change for TypeScript users potentially, unless all types are adhered to, by @kitten (See #2607)
- Upgrade to Wonka v6 (
wonka@^6.0.0), which has no breaking changes but is built to target ES2015 and comes with other minor improvements. The library has fully been migrated to TypeScript which will hopefully help with making contributions easier!, by @kitten (See #2504)
Minor Changes
- Remove the
babel-plugin-modular-graphqlhelper, this because the graphql package hasn't converted to ESM yet which gives issues in node environments, by @JoviDeCroock (See #2551)
2.6.1
Patch Changes
- ⚠️ Fix missing React updates after an incoming response that schedules a mount. We now prevent dispatched operations from continuing to flush synchronously when the original source that runs the queue has terminated. This is important for the React bindings, because an update (e.g.
setState) may recursively schedule a mount, which then disabled othersetStateupdates from being processed. Previously we assumed that React used a trampoline scheduler for updates, however it appears thatsetStatecan recursively start more React work, by @kitten (See #2556)
2.6.0
Minor Changes
2.5.0
Minor Changes
- Add
Acceptheader to GraphQL HTTP requests. This complies to the specification but doesn't go as far as sendingContent-Typewhich would throw a lot of APIs off. Instead, we'll now be sending an accept header forapplication/graphql+json, application/jsonto indicate that we comply with the GraphQL over HTTP protocol. This also fixes headers merging to allow overridingAcceptandContent-Typeregardless of the user options' casing, by @kitten (See #2457)
Patch Changes
- Support aborting in
withPromisecases, by @JoviDeCroock (See #2446) - Passthrough responses with content type of
text/*as error messages, by @kitten (See #2456)
2.4.4
Patch Changes
- cut off
urlwhen using the GET method at 2048 characters (lowest url-size coming from chromium), by @JoviDeCroock (See #2384) - ⚠️ Fix issue where a synchronous
toPromise()return would not result in the stream tearing down, by @JoviDeCroock (See #2386)
2.4.3
Patch Changes
- Prevent ignored characters in GraphQL queries from being replaced inside strings and block strings. Previously we accepted sanitizing strings via regular expressions causing duplicate hashes as acceptable, since it'd only be caused when a string wasn't extracted into variables. This is fixed now however, by @kitten (See #2295)
2.4.2
Patch Changes
- Undo logic to catch errors from incremental fetching and forking the response stream, introduce logic to detect results, by @JoviDeCroock (See #2287)
2.4.1
Patch Changes
- ⚠️ Fix mutation operation being used as compared identity and instead add a stand-in comparison, by @kitten (See #2228)
2.4.0
Minor Changes
- Allow for repeated mutations that have similar inputs which results in the same key, this is for instance the case with file uploads, by @JoviDeCroock (See #2189)
Patch Changes
- Bump
@graphql-typed-document-node/coreto 3.1.1 forgraphql@16support, by @JoviDeCroock (See #2153) - ⚠️ Fix error bubbling, when an error happened in the exchange-pipeline we would treat it as a GraphQL-error, by @JoviDeCroock (See #2210)
- Filter
network-onlyrequests from thessrExchange, this is to enablestaleWhileRevalidatedqueries to successfully dispatch their queries, by @JoviDeCroock (See #2198)
2.3.6
Patch Changes
- Extend peer dependency range of
graphqlto include^16.0.0. As always when upgrading across many packages ofurql, especially including@urql/corewe recommend you to deduplicate dependencies after upgrading, usingnpm dedupeornpx yarn-deduplicate, by @kitten (See #2133)
2.3.5
Patch Changes
- ⚠️ Fix issue where
maskTypenamewould ignore array shapes, by @JoviDeCroock (See #2074)
2.3.4
Patch Changes
- Prevent
Bufferfrom being polyfilled by an automatic detection in Webpack. Instead of referencing theBufferglobal we now simply check the constructor name, by @kitten (See #2027) - ⚠️ Fix error-type of an
ExecutionResultto line up with subscription-libs, by @JoviDeCroock (See #1998)
2.3.3
Patch Changes
- Adding option to
ssrExchangeto include theextensionsfield of operation results in the cache, by @dios-david (See #1985)
2.3.2
Patch Changes
- ⚠️ Fix issue where the ssr-exchange would loop due to checking network-only revalidations, by @JoviDeCroock (See #1944)
2.3.1
Patch Changes
- ⚠️ Fix mark
query.__keyas non-enumerable soformatDocumentdoes not restore previous invocations when cloning the gql-ast, by @JoviDeCroock (See #1870) - ⚠️ Fix: update toPromise to exclude
hasNextresults. This change ensures that when we call toPromise() on a query we wont serve an incomplete result, the user will expect to receive a non-stale full-result when using toPromise(), by @JoviDeCroock (See #1880)
2.3.0
Minor Changes
- Add experimental support for
@deferand@streamresponses for GraphQL. This implements the "GraphQL Defer and Stream Directives" and "Incremental Delivery over HTTP" specifications. If a GraphQL API supportsmultipart/mixedresponses for deferred and streamed delivery of GraphQL results,@urql/core(and all its derived fetch implementations) will attempt to stream results. This is only supported on browsers supporting streamed fetch responses, which excludes IE11. The implementation of streamed multipart responses is derived frommerosby@maraisr, and is subject to change if the RFCs end up changing, by @kitten (See #1854)
2.2.0
Minor Changes
- Add a
staleWhileRevalidateoption to thessrExchange, which allows the client to immediately refetch a new result on hydration, which may be used for cached / stale SSR or SSG pages. This is different from usingcache-and-networkby default (which isn't recommended) as thessrExchangetypically acts like a "replacement fetch request", by @kitten (See #1852)
Patch Changes
- ⚠️ Fix prevent mangling embedded strings in queries sent using the
GETmethod, by @JoviDeCroock (See #1851) - The single-source behavior previously wasn't effective for implementations like React, where the issue presents itself when the state of an operation is first polled. This led to the operation being torn down erroneously. We now ensure that operations started at the same time still use a shared single-source, by @JoviDeCroock (See #1850)
2.1.6
Patch Changes
- Warn for invalid operation passed to query/subscription/mutation, by @JoviDeCroock (See #1829)
2.1.5
Patch Changes
- Prevent
ssrExchange().restoreData()from adding results to the exchange that have already been invalidated. This may happen whenrestoreData()is called repeatedly, e.g. per page. When a prior run has already invalidated an SSR result then the result is 'migrated' to the user'scacheExchange, which means thatrestoreData()should never attempt to re-add it again, by @kitten (See #1776) - ⚠️ Fix accidental change in passive
stale: true, where acache-firstoperation issued by Graphcache wouldn't yield an affected query and update its result to reflect the loading state withstale: true. This is a regression fromv2.1.0and mostly becomes unexpected whencache.invalidate(...)is used, by @kitten (See #1755)
2.1.4
Patch Changes
- Prevent stale results from being emitted by promisified query sources, e.g.
client.query(...).toPromise()yielding a partial result withstale: trueset. Instead,.toPromise()will now filter out stale results, by @kitten (See #1709)
2.1.3
Patch Changes
- Treat empty variables the same as no variables in
@urql/core'screateRequest, by @kitten (See #1695)
2.1.2
Patch Changes
- ⚠️ Fix a condition under which the
Clientwould hang when a query is started and consumed withtoPromise(), by @kitten (See #1634) - Refactor
Clientto hide some implementation details and to reduce size, by @kitten (See #1638)
2.1.1
Patch Changes
- ⚠️ Fix a regression in
@urql/core@2.1.1that prevented concurrent operations from being dispatched with differing request policies, which for instance prevented the explicitexecuteQuerycalls on bindings to fail, by @kitten (See #1626)
2.1.0
Minor Changes
- With the "single-source behavior" the
Clientwill now also avoid executing an operation if it's already active, has a previous result available, and is either run with thecache-firstorcache-onlyrequest policies. This is similar to a "short circuiting" behavior, where unnecessary work is avoided by not issuing more operations into the exchange pipeline than expected, by @kitten (See #1600) - Add consistent "single-source behavior" which makes the
Clientmore forgiving when duplicate sources are used, which previously made it difficult to use the same operation across an app together withcache-and-network; This was a rare use-case, and it isn't recommended to overfetch data across an app, however, the newClientimplementation of shared sources ensures that when an operation is active that theClientdistributes the last known result for the active operation to any new usages of it (which is called “replaying stale results”) (See #1515)
Patch Changes
- Remove closure-compiler from the build step (See #1570)
- ⚠️ Fix inconsistency in generating keys for
DocumentNodes, especially when using GraphQL Code Generator, which could cause SSR serialization to fail, by @zenflow (See #1509)
2.0.0
Major Changes
- Breaking: Remove
pollIntervalfeature fromOperationContext. Instead consider using a source that usesWonka.intervalandWonka.switchMapoverclient.query()'s source, by @kitten (See #1374) - Remove deprecated
operationNameproperty fromOperations. The newOperation.kindproperty is now preferred. If you're creating new operations you may also use themakeOperationutility instead. When upgrading@urql/coreplease ensure that your package manager didn't install any duplicates of it. You may deduplicate it manually usingnpx yarn-deduplicate(for Yarn) ornpm dedupe(for npm), by @kitten (See #1357)
Minor Changes
- Reemit an
OperationResultasstale: trueif it's being reexecuted asnetwork-onlyoperation to give bindings immediate feedback on background refetches, by @kitten (See #1375)
1.16.2
Patch Changes
- Add a workaround for
graphql-tag/loader, which provides filtered query documents (where the original document contains multiple operations) without updating or providing a correctdocument.loc.source.bodystring, by @kitten (See #1315)
1.16.1
Patch Changes
- Add fragment deduplication to
gqltag. Identical fragments can now be interpolated multiple times without a warning being triggered or them being duplicated ingql's output, by @kitten (See #1225)
1.16.0
Minor Changes
- Add a built-in
gqltag function helper to@urql/core. This behaves similarly tographql-tagbut only warns about locally duplicated fragment names rather than globally. It also primes@urql/core's key cache with the parsedDocumentNode, by @kitten (See #1187)
Patch Changes
- ⚠️ Fix edge case in
formatDocument, which fails to add a__typenamefield if it has been aliased to a different name, by @kitten (See #1186) - Cache results of
formatDocumentby the input document's key, by @kitten (See #1186)
1.15.2
Patch Changes
- Don't add
undefinedto any property of thessrExchange's serialized results, as this would crash in Next.js, by @JoviDeCroock (See #1168)
1.15.1
Patch Changes
- Export
getOperationNamefrom@urql/coreand use it in@urql/exchange-execute, fixing several imports, by @JoviDeCroock (See #1135)
1.15.0
Minor Changes
- Improve the Suspense implementation, which fixes edge-cases when Suspense is used with subscriptions, partially disabled, or used on the client-side. It has now been ensured that client-side suspense functions without the deprecated
suspenseExchangeand uncached results are loaded consistently. As part of this work, theClientitself does now never throw Suspense promises anymore, which is functionality that either way has no place outside of the React/Preact bindings, by @kitten (See #1123)
Patch Changes
- Use
Recordoverobjecttype for subscription operation variables. Theobjecttype is currently hard to use (see this issue), by @enisdenjo (See #1119) - Add support for
TypedDocumentNodeto infer the type of theOperationResultandOperationfor all methods, functions, and hooks that either directly or indirectly accept aDocumentNode. Seegraphql-typed-document-nodeand the corresponding blog post for more information., by @kitten (See #1113) - Refactor
useSourcehooks which powersuseQueryanduseSubscriptionto improve various edge case behaviour. This will not change the behaviour of these hooks dramatically but avoid unnecessary state updates when any updates are obviously equivalent and the hook will furthermore improve continuation from mount to effects, which will fix cases where the state between the mounting and effect phase may slightly change, by @kitten (See #1104)
1.14.1
Patch Changes
- ⚠️ Fix the production build overwriting the development build. Specifically in the previous release we mistakenly replaced all development bundles with production bundles. This doesn't have any direct influence on how these packages work, but prevented development warnings from being logged or full errors from being thrown, by @kitten (See #1097)
1.14.0
This version of @urql/core renames Operation.operationName to Operation.kind. For now the old
property is merely deprecated and will issue a warning if it's used directly. That said, all
exchanges that are released today also need this new version of @urql/core@>=1.14.0, so if you
upgrade to any of the following packages, you will also need to upgrade @urql/core. If you upgrade
and see the deprecation warning, check whether all following exchanges have been upgraded:
@urql/exchange-auth@0.1.2@urql/exchange-execute@1.0.2@urql/exchange-graphcache@3.1.8@urql/exchange-multipart-fetch@0.1.10@urql/exchange-persisted-fetch@1.2.2@urql/exchange-populate@0.2.1@urql/exchange-refocus@0.2.1@urql/exchange-retry@0.1.9@urql/exchange-suspense@1.9.2
Once you've upgraded @urql/core please also ensure that your package manager hasn't accidentally
duplicated the @urql/core package. If you're using npm you can do so by running npm dedupe,
and if you use yarn you can do so by running yarn-deduplicate.
If you have a custom exchange, you can mute the deprecation warning by using Operation.kind rather
than Operation.operationName. If these exchanges are copying or altering operations by spreading
them this will also trigger the warning, which you can fix by using the new makeOperation helper
function.
Minor Changes
- Deprecate the
Operation.operationNameproperty in favor ofOperation.kind. This name was previously confusing asoperationNamewas effectively referring to two different things. You can safely upgrade to this new version, however to mute all deprecation warnings you will have to upgrade allurqlpackages you use. If you have custom exchanges that spread operations, please use the newmakeOperationhelper function instead, by @bkonkle (See #1045)
Patch Changes
- Add missing
.mjsextension to all imports fromgraphqlto fix Webpack 5 builds, which require extension-specific import paths for ESM bundles and packages. This change allows you to safely upgrade to Webpack 5., by @kitten (See #1094)
1.13.1
Patch Changes
- Allow
client.reexecuteOperationto be called with mutations which skip the active operation minimums, by @kitten (See #1011)
1.13.0
Please note that this release changes the data structure of the ssrExchange's
output. We don't treat this as a breaking change, since this data is considered
a private structure, but if your tests or other code relies on this, please check
the type changes and update it.
Minor Changes
- Adds an error exchange to urql-core. This allows tapping into all graphql errors within the urql client. Useful for logging, debugging, handling authentication errors etc, by @kadikraman (See #947)
Patch Changes
- ⚠️ Fix condition where mutated result data would be picked up by the
ssrExchange, for instance as a result of mutations by Graphcache. Instead thessrExchangenow serializes data early, by @kitten (See #962) - Omit the
Content-Type: application/jsonHTTP header when using GET in thefetchExchange,persistedFetchExchange, ormultipartFetchExchange, by @JoviDeCroock (See #957)
1.12.3
Patch Changes
- Remove whitespace and comments from string-queries, by @JoviDeCroock (See #911)
- Remove redundant whitespaces when using GET for graphql queries, by @JoviDeCroock (See #908)
1.12.2
Patch Changes
- ⚠️ Fix
formatDocumentmutating parts of theDocumentNodewhich may be shared by other documents and queries. Also ensure that a formatted document will always generate the same key increateRequestas the original document, by @kitten (See #880) - ⚠️ Fix
ssrExchangeinvalidating results on the client-side too eagerly, by delaying invalidation by a tick, by @kitten (See #885)
1.12.1
Patch Changes
- ⚠️ Fix timing for out-of-band
client.reexecuteOperationcalls. This would surface in asynchronous caching scenarios, where no result would be delivered by the cache synchronously, while it still callsclient.reexecuteOperationfor e.g. anetwork-onlyrequest, which happens forcache-and-network. This issue becomes especially obvious in highly synchronous frameworks like Svelte, by @kitten (See #860) - Replace unnecessary
scheduleTaskpolyfill with inlinePromise.resolve().then(fn)calls, by @kitten (See #861)
1.12.0
As always, please ensure that you deduplicate @urql/core when upgrading. Additionally
deduplicating the versions of wonka that you have installed may also reduce your bundlesize.
Minor Changes
- Expose a
client.subscriptionshortcut method, similar toclient.queryandclient.mutation, by @FredyC (See #838)
Patch Changes
- Upgrade to a minimum version of wonka@^4.0.14 to work around issues with React Native's minification builds, which use uglify-es and could lead to broken bundles, by @kitten (See #842)
1.11.8
Patch Changes
- Add operationName to GET queries, by @jakubriedl (See #798)
1.11.7
Patch Changes
- Add
sourcedebug name to alldispatchDebugcalls during build time to identify events by which exchange dispatched them, by @JoviDeCroock (See #780)
1.11.6
Patch Changes
- Add a
"./package.json"entry to thepackage.json's"exports"field for Node 14. This seems to be required by packages likerollup-plugin-svelteto function properly, by @JoviDeCroock (See #771)
1.11.5
Patch Changes
- Hoist variables in unminified build output for Metro Bundler builds which otherwise fails for
process.env.NODE_ENVif-clauses, by @kitten (See #737) - Add a babel-plugin that removes empty imports from the final build output, by @JoviDeCroock (See #735)
1.11.4
Patch Changes
Sorry for the many updates; Please only upgrade to >=1.11.4 and don't use the deprecated 1.11.3
and 1.11.2 release.
- ⚠️ Fix nested package path for @urql/core/internal and @urql/exchange-graphcache/extras, by @kitten (See #734)
1.11.3
Patch Changes
- Make the extension of the main export unknown, which fixes a Webpack issue where the resolver won't pick
modulefields inpackage.jsonfiles once it's importing from another.mjsfile, by @JoviDeCroock (See #733)
1.11.1
Patch Changes
- ⚠️ Fix missing
@urql/core/internalentrypoint in the npm-release, which was previously not included, by @JoviDeCroock (See #731)
1.11.0
Minor Changes
- Add debugging events to exchanges that add more detailed information on what is happening internally, which will be displayed by devtools like the urql Chrome / Firefox extension, by @andyrichardson (See #608)
- Add @urql/core/internal entrypoint for internally shared utilities and start sharing fetchExchange-related code, by @kitten (See #722)
Patch Changes
1.10.9
Patch Changes
- Pick modules from graphql package, instead of importing from graphql/index.mjs, by @kitten (See #700)
1.10.8
Patch Changes
- Add graphql@^15.0.0 to peer dependency range, by @kitten (See #688)
- ⚠️ Fix non-2xx results never being parsed as GraphQL results. This can result in valid GraphQLErrors being hidden, which should take precedence over generic HTTP NetworkErrors, by @kitten (See #678)
1.10.7
Patch Changes
- ⚠️ Fix oversight in edge case for #662. The operation queue wasn't marked as being active which caused
staleresults andcache-and-networkoperations from reissuing operations immediately (unqueued essentially) which would then be filtered out by thededupExchange, by @kitten (See #669)
1.10.6
Patch Changes
- ⚠️ Fix critical bug in operation queueing that can lead to unexpected teardowns and swallowed operations. This would happen when a teardown operation kicks off the queue, by @kitten (See #662)
1.10.5
Patch Changes
- Refactor a couple of core helpers for minor bundlesize savings, by @kitten (See #658)
- Add support for variables that contain non-plain objects without any enumerable keys, e.g.
FileorBlob. In this casestringifyVariableswill now use a stable (but random) key, which means that mutations containingFiles — or other objects like this — will now be distinct, as they should be, by @kitten (See #650)
1.10.4
Patch Changes
- ⚠️ Fix node resolution when using Webpack, which experiences a bug where it only resolves
package.json:maininstead ofmodulewhen an.mjsfile imports a package, by @JoviDeCroock (See #642)
1.10.3
Patch Changes
- ⚠️ Fix Node.js Module support for v13 (experimental-modules) and v14. If your bundler doesn't support
.mjsfiles and fails to resolve the new version, please double check your configuration for Webpack, or similar tools, by @JoviDeCroock (See #637)
1.10.2
Patch Changes
- Add a guard to "maskTypenames" so a null value isn't considered an object, by @JoviDeCroock (See #621)
1.10.1
Patch Changes
1.10.0
Minor Changes
- Add
additionalTypenamesto theOperationContext, which allows the document cache to invalidate efficiently when the__typenameis unknown at the initial fetch, by @JoviDeCroock (See #601) You can learn more about this change in our docs.
Patch Changes
- Add missing GraphQLError serialization for extensions and path field to ssrExchange, by @kitten (See #607)
1.9.2
Patch Changes
1.9.1
Patch Changes
- ⚠️ Fix
cache-onlyoperations being forwarded and triggering fetch requests, by @JoviDeCroock (See #551) - Adds a one-tick delay to the subscriptionExchange to prevent unnecessary early tear downs, by @JoviDeCroock (See #542)
- Add enableAllOperations option to subscriptionExchange to let it handle queries and mutations as well, by @kitten (See #544)
1.9.0
Minor Changes
- Adds the
maskTypenameexport to urql-core, this deeply masks typenames from the given payload. Masking__typenameproperties is also available as amaskTypenameoption on theClient. Setting this to true will strip typenames from results, by @JoviDeCroock (See #533) - Add support for sending queries using GET instead of POST method (See #519)
- Add client.readQuery method (See #518)