-
-
Notifications
You must be signed in to change notification settings - Fork 461
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
RFC: Add a way to minify query before sending it #3073
Comments
You can already do this yourself by authoring an exchange that would sit in front of the EDIT: oh, no it looks like our |
So possibly going from this Could easily fix the issue since that's the last point where the query string gets manipulated? Maybe this could be an easy fix for a yarn patch until you guys discuss the idea at a broader level |
From my point of view this isn't really something I would want to put into urql, I would be open to finding a way where |
I understand, and agree with it. For anyone encountering this issue, before it gets resolved at a @JoviDeCroock if you need any help on how to preserve minification on stringifyDocument let me know. Also, as a random thought: what if the query gets minified by default? Wouldn't it be better from a performance standpoint? My query dropped from 8Kb to 4Kb, it seems a little but sizeable improvement tbh. Thanks again for your kind help! |
I'm not sure this is something that belongs in For context, internally a GraphQL query document is always parsed, and it's a "transports" responsibility to stringify it back to a GraphQL query document string. In fact, I'm very surprised that Contentful imposes a length limit, rather than a field limit. I think their length limit isn't unreasonable, but I'm surprised it's this low. For context, it's only twice as long as our rather low default GET URL length limit. You can create a custom import { filter, merge, mergeMap, pipe, share, takeUntil } from 'wonka';
import { Exchange } from '@urql/core';
import {
makeFetchBody,
makeFetchURL,
makeFetchOptions,
makeFetchSource,
} from '@urql/core/internal';
import compress from 'graphql-query-compress'
export const fetchExchange: Exchange = ({ forward }) => {
return ops$ => {
const sharedOps$ = share(ops$);
const fetchResults$ = pipe(
sharedOps$,
filter(operation => {
return operation.kind === 'query' || operation.kind === 'mutation';
}),
mergeMap(operation => {
const body = makeFetchBody(operation);
if (body.query)
body.query = compress(body.query);
return pipe(
makeFetchSource(
operation,
makeFetchURL(operation, body),
makeFetchOptions(operation, body)
),
takeUntil(
pipe(
sharedOps$,
filter(op => op.kind === 'teardown' && op.key === operation.key)
)
)
);
})
);
const forward$ = pipe(
sharedOps$,
filter(operation => {
return operation.kind !== 'query' && operation.kind !== 'mutation';
}),
forward
);
return merge([fetchResults$, forward$]);
};
}; |
Thank you @JoviDeCroock and @kitten! One question tho, where should I create this custom |
Marking this as |
Summary
I'm trying to send a query to Contentful GraphQL API, which has a query limit of 8Kb.
The query in question is slightly above the limit.
I've tried to minify it by using https://www.npmjs.com/package/graphql-query-compress this package, and by compressing the query string I've managed to get it to around 4Kb.
After feeding the Urql client the query, it seems like it decompresses it somehow before sending it to the API, since I still see that error in the response.
Is it possible to add a compressQuery option before sending it?
Not sure if this counts as an issue or a question or an RFC, be free to scold me if it's not an RFC :)
Thanks for your time reading this.
Proposed Solution
Add an option to compress/minify the query string before sending it
The text was updated successfully, but these errors were encountered: