@coderich/autograph 0.13.41 → 0.13.43
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/data/DataLoader.js +5 -0
- package/src/data/Pipeline.js +1 -0
- package/src/data/Resolver.js +16 -1
- package/src/schema/Schema.js +8 -3
package/package.json
CHANGED
package/src/data/DataLoader.js
CHANGED
|
@@ -50,6 +50,11 @@ module.exports = class Loader {
|
|
|
50
50
|
const values = Array.from(new Set(batches.map(batch => batch.values).flat()));
|
|
51
51
|
const $query = { ...batches[0].$query, op: 'findMany', where: { [key]: values } };
|
|
52
52
|
|
|
53
|
+
//
|
|
54
|
+
if (values.length < 3) {
|
|
55
|
+
return batches.map(batch => this.#model.source.client.resolve(batch.$query).then(data => ({ data, ...batch })));
|
|
56
|
+
}
|
|
57
|
+
|
|
53
58
|
// Collect all the $values (Regular Expressions) to match doc (result) data by
|
|
54
59
|
const $values = Array.from(new Set(batches.map(batch => batch.$values).flat()));
|
|
55
60
|
const docsByRegExpKey = $values.reduce((map, re) => map.set(re, []), new Map());
|
package/src/data/Pipeline.js
CHANGED
|
@@ -62,6 +62,7 @@ module.exports = class Pipeline {
|
|
|
62
62
|
Pipeline.define('$construct', params => Pipeline.resolve(params, 'construct'), { ignoreNull: false });
|
|
63
63
|
Pipeline.define('$restruct', params => Pipeline.resolve(params, 'restruct'), { ignoreNull: false });
|
|
64
64
|
Pipeline.define('$serialize', params => Pipeline.resolve(params, 'serialize'), { ignoreNull: false });
|
|
65
|
+
Pipeline.define('$deserialize', params => Pipeline.resolve(params, 'deserialize'), { ignoreNull: false });
|
|
65
66
|
Pipeline.define('$validate', params => Pipeline.resolve(params, 'validate'), { ignoreNull: false });
|
|
66
67
|
|
|
67
68
|
//
|
package/src/data/Resolver.js
CHANGED
|
@@ -205,7 +205,22 @@ module.exports = class Resolver {
|
|
|
205
205
|
return this.toResultSet(model, results);
|
|
206
206
|
});
|
|
207
207
|
} else {
|
|
208
|
-
thunk = tquery =>
|
|
208
|
+
thunk = (tquery) => {
|
|
209
|
+
const { where, op } = query.toObject();
|
|
210
|
+
const values = Object.values(where);
|
|
211
|
+
const $values = values.flat();
|
|
212
|
+
const skipQuery = values.length && (!$values.length || $values.includes(undefined));
|
|
213
|
+
|
|
214
|
+
if (skipQuery) {
|
|
215
|
+
switch (op) {
|
|
216
|
+
case 'count': return Promise.resolve(0);
|
|
217
|
+
case 'findMany': return Promise.resolve([]);
|
|
218
|
+
default: return Promise.resolve(null);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
return this.#dataLoaders[model].resolve(tquery);
|
|
223
|
+
};
|
|
209
224
|
}
|
|
210
225
|
|
|
211
226
|
return this.#createSystemEvent(query, (tquery) => {
|
package/src/schema/Schema.js
CHANGED
|
@@ -16,7 +16,7 @@ const scalarKinds = [Kind.SCALAR_TYPE_DEFINITION, Kind.SCALAR_TYPE_EXTENSION];
|
|
|
16
16
|
const fieldKinds = [Kind.FIELD_DEFINITION];
|
|
17
17
|
const modelKinds = [Kind.OBJECT_TYPE_DEFINITION, Kind.OBJECT_TYPE_EXTENSION].concat(interfaceKinds);
|
|
18
18
|
const allowedKinds = modelKinds.concat(fieldKinds).concat(Kind.DOCUMENT, Kind.NON_NULL_TYPE, Kind.NAMED_TYPE, Kind.LIST_TYPE, Kind.DIRECTIVE).concat(scalarKinds).concat(enumKinds);
|
|
19
|
-
const pipelines = ['validate', 'construct', 'restruct', 'instruct', 'normalize', 'serialize'];
|
|
19
|
+
const pipelines = ['validate', 'construct', 'restruct', 'instruct', 'normalize', 'serialize', 'deserialize'];
|
|
20
20
|
const inputPipelines = ['validate', 'construct', 'instruct', 'normalize', 'serialize'];
|
|
21
21
|
const scalars = ['ID', 'String', 'Float', 'Int', 'Boolean'];
|
|
22
22
|
|
|
@@ -418,7 +418,12 @@ module.exports = class Schema {
|
|
|
418
418
|
|
|
419
419
|
$model.transformers.doc.config({
|
|
420
420
|
shape: Object.values($model.fields).reduce((prev, curr) => {
|
|
421
|
-
const
|
|
421
|
+
const args = { model: $model, field: curr };
|
|
422
|
+
|
|
423
|
+
const rules = [
|
|
424
|
+
curr.name, // Rename key
|
|
425
|
+
a => Pipeline.$deserialize({ ...a, ...args, path: a.path.concat(curr.name) }),
|
|
426
|
+
];
|
|
422
427
|
if (curr.isArray) rules.unshift(({ value }) => (value == null ? value : Util.ensureArray(value)));
|
|
423
428
|
if (curr.isEmbedded) rules.unshift(({ value }) => Util.map(value, v => curr.model.transformers.doc.transform(v)));
|
|
424
429
|
return Object.assign(prev, { [curr.key]: rules });
|
|
@@ -623,6 +628,7 @@ module.exports = class Schema {
|
|
|
623
628
|
construct: [AutoGraphPipelineEnum!]
|
|
624
629
|
restruct: [AutoGraphPipelineEnum!]
|
|
625
630
|
serialize: [AutoGraphPipelineEnum!]
|
|
631
|
+
deserialize: [AutoGraphPipelineEnum!]
|
|
626
632
|
validate: [AutoGraphPipelineEnum!]
|
|
627
633
|
|
|
628
634
|
# TEMP TO APPEASE TRANSITION
|
|
@@ -630,7 +636,6 @@ module.exports = class Schema {
|
|
|
630
636
|
gqlScope: AutoGraphMixed # Dictate how GraphQL API behaves
|
|
631
637
|
dalScope: AutoGraphMixed # Dictate how the DAL behaves
|
|
632
638
|
transform: [AutoGraphPipelineEnum!]
|
|
633
|
-
deserialize: [AutoGraphPipelineEnum!]
|
|
634
639
|
) on FIELD_DEFINITION | INPUT_FIELD_DEFINITION | SCALAR
|
|
635
640
|
|
|
636
641
|
directive @${link}(
|