@graphql-tools/executor-urql-exchange
Version:
81 lines (80 loc) • 3.51 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.executorExchange = void 0;
const wonka_1 = require("wonka");
const utils_1 = require("@graphql-tools/utils");
const core_1 = require("@urql/core");
function executorExchange(executor) {
function makeYogaSource(operation) {
const extraFetchOptions = typeof operation.context.fetchOptions === 'function'
? operation.context.fetchOptions()
: operation.context.fetchOptions;
const executionRequest = {
document: operation.query,
operationType: operation.kind,
variables: operation.variables,
context: operation.context,
extensions: {
endpoint: operation.context.url,
fetch: operation.context.fetch,
useGETForQueries: operation.context.preferGetMethod,
headers: extraFetchOptions?.headers,
method: extraFetchOptions?.method,
},
};
return (0, wonka_1.make)(observer => {
let ended = false;
Promise.resolve(executor(executionRequest))
.then(async (result) => {
if (ended || !result) {
return;
}
if (!(0, utils_1.isAsyncIterable)(result)) {
observer.next((0, core_1.makeResult)(operation, result));
}
else {
let prevResult = null;
for await (const value of result) {
if (value) {
if (prevResult && value.incremental) {
prevResult = (0, core_1.mergeResultPatch)(prevResult, value);
}
else {
prevResult = (0, core_1.makeResult)(operation, value);
}
observer.next(prevResult);
}
if (ended) {
break;
}
}
}
observer.complete();
})
.catch(error => {
observer.next((0, core_1.makeErrorResult)(operation, error));
})
.finally(() => {
ended = true;
observer.complete();
});
return () => {
ended = true;
};
});
}
return function executorExchangeFn({ forward }) {
return function executorExchangeIO(ops$) {
const sharedOps$ = (0, wonka_1.share)(ops$);
const executedOps$ = (0, wonka_1.pipe)(sharedOps$, (0, wonka_1.filter)((operation) => operation.kind === 'query' ||
operation.kind === 'mutation' ||
operation.kind === 'subscription'), (0, wonka_1.mergeMap)((operation) => {
const teardown$ = (0, wonka_1.pipe)(sharedOps$, (0, wonka_1.filter)((op) => op.kind === 'teardown' && op.key === operation.key));
return (0, wonka_1.pipe)(makeYogaSource(operation), (0, wonka_1.takeUntil)(teardown$));
}));
const forwardedOps$ = (0, wonka_1.pipe)(sharedOps$, (0, wonka_1.filter)((operation) => operation.kind === 'teardown'), forward);
return (0, wonka_1.merge)([executedOps$, forwardedOps$]);
};
};
}
exports.executorExchange = executorExchange;
;