@coderich/autograph 0.9.0 → 0.9.4
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
CHANGED
package/src/core/Resolver.js
CHANGED
|
@@ -10,7 +10,7 @@ module.exports = class Resolver {
|
|
|
10
10
|
this.models = schema.getModels();
|
|
11
11
|
this.schema = schema;
|
|
12
12
|
this.context = context;
|
|
13
|
-
this.loaders = this.models.reduce((prev, model) => prev.set(model
|
|
13
|
+
this.loaders = this.models.reduce((prev, model) => prev.set(`${model}`, new DataLoader(this, model)), new Map());
|
|
14
14
|
|
|
15
15
|
//
|
|
16
16
|
this.getSchema = () => this.schema;
|
|
@@ -62,7 +62,7 @@ module.exports = class Resolver {
|
|
|
62
62
|
if (Object.prototype.hasOwnProperty.call(where, key) && where[key] == null) return Promise.resolve(null);
|
|
63
63
|
|
|
64
64
|
//
|
|
65
|
-
return this.loaders.get(model).load(query);
|
|
65
|
+
return this.loaders.get(`${model}`).load(query);
|
|
66
66
|
}
|
|
67
67
|
}
|
|
68
68
|
}
|
|
@@ -92,7 +92,7 @@ module.exports = class Resolver {
|
|
|
92
92
|
|
|
93
93
|
// DataLoader Proxy Methods
|
|
94
94
|
clear(model) {
|
|
95
|
-
this.loaders.get(
|
|
95
|
+
this.loaders.get(`${model}`).clearAll();
|
|
96
96
|
return this;
|
|
97
97
|
}
|
|
98
98
|
|
package/src/core/Schema.js
CHANGED
|
@@ -50,8 +50,8 @@ module.exports = class extends Schema {
|
|
|
50
50
|
this.modelsByKey = this.models.reduce((prev, model) => Object.assign(prev, { [model.getKey()]: model }), {});
|
|
51
51
|
}
|
|
52
52
|
|
|
53
|
-
loadDir(dir) {
|
|
54
|
-
super.loadDir(dir);
|
|
53
|
+
loadDir(dir, options) {
|
|
54
|
+
super.loadDir(dir, options);
|
|
55
55
|
this.createModels();
|
|
56
56
|
return this;
|
|
57
57
|
}
|
|
@@ -106,12 +106,12 @@ module.exports = class Schema extends Node {
|
|
|
106
106
|
return this.schema.context;
|
|
107
107
|
}
|
|
108
108
|
|
|
109
|
-
loadDir(dir) {
|
|
109
|
+
loadDir(dir, options) {
|
|
110
110
|
// Typedefs
|
|
111
|
-
const typeDefs = Glob.sync(`${dir}/**/*.{gql,graphql}
|
|
111
|
+
const typeDefs = Glob.sync(`${dir}/**/*.{gql,graphql}`, options).map(file => loadFile(file)).join('\n\n');
|
|
112
112
|
|
|
113
113
|
// Possibly full schema definitions
|
|
114
|
-
const schema = Glob.sync(`${dir}/**/*.js
|
|
114
|
+
const schema = Glob.sync(`${dir}/**/*.js`, options).map(file => reqFile(file)).reduce((prev, data) => {
|
|
115
115
|
return Merge(prev, data);
|
|
116
116
|
}, {
|
|
117
117
|
typeDefs: typeDefs.length ? typeDefs : undefined,
|
|
@@ -69,13 +69,19 @@ module.exports = (schema) => {
|
|
|
69
69
|
}
|
|
70
70
|
`),
|
|
71
71
|
|
|
72
|
-
...entityModels.map(model => `
|
|
72
|
+
...entityModels.filter(model => model.hasGQLScope('s')).map(model => `
|
|
73
|
+
input ${model.getName()}SubscriptionInputFilter {
|
|
74
|
+
when: [SubscriptionWhenEnum!]! = [preEvent, postEvent]
|
|
75
|
+
where: ${model.getName()}SubscriptionInputWhere! = {}
|
|
76
|
+
}
|
|
77
|
+
|
|
73
78
|
input ${model.getName()}SubscriptionInputWhere {
|
|
74
|
-
${getGQLWhereFields(model).
|
|
79
|
+
${getGQLWhereFields(model).map(field => `${field.getName()}: ${field.getModelRef() && !field.isFKReference() ? `${ucFirst(field.getDataRef())}InputWhere` : 'AutoGraphMixed'}`)}
|
|
75
80
|
}
|
|
76
81
|
|
|
77
|
-
type ${model.getName()}
|
|
78
|
-
${
|
|
82
|
+
type ${model.getName()}SubscriptionPayload {
|
|
83
|
+
event: ${model.getName()}SubscriptionPayloadEvent
|
|
84
|
+
query: ${model.getName()}SubscriptionQuery
|
|
79
85
|
}
|
|
80
86
|
|
|
81
87
|
type ${model.getName()}SubscriptionPayloadEvent {
|
|
@@ -83,13 +89,20 @@ module.exports = (schema) => {
|
|
|
83
89
|
data: ${model.getName()}SubscriptionPayloadEventData!
|
|
84
90
|
}
|
|
85
91
|
|
|
86
|
-
type ${model.getName()}
|
|
87
|
-
|
|
92
|
+
type ${model.getName()}SubscriptionPayloadEventData {
|
|
93
|
+
${getGQLWhereFields(model).map(field => `${field.getName()}: ${field.isFKReference() ? 'ID' : field.getGQLType()}`)}
|
|
88
94
|
}
|
|
89
95
|
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
96
|
+
interface ${model.getName()}SubscriptionQuery {
|
|
97
|
+
${model.getFields().filter(field => field.hasGQLScope('r')).map(field => `${field.getName()}: ${field.getPayloadType()}`)}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
type ${model.getName()}Create implements ${model.getName()}SubscriptionQuery {
|
|
101
|
+
${model.getFields().filter(field => field.hasGQLScope('r')).map(field => `${field.getName()}: ${field.getPayloadType()}`)}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
type ${model.getName()}Update implements ${model.getName()}SubscriptionQuery {
|
|
105
|
+
${model.getFields().filter(field => field.hasGQLScope('r')).map(field => `${field.getName()}: ${field.getPayloadType()}`)}
|
|
93
106
|
}
|
|
94
107
|
`),
|
|
95
108
|
|
|
@@ -110,6 +123,8 @@ module.exports = (schema) => {
|
|
|
110
123
|
`type Query {
|
|
111
124
|
node(id: ID!): Node
|
|
112
125
|
${entityModels.map(model => makeReadAPI(model.getName(), model))}
|
|
126
|
+
${entityModels.map(model => makeReadAPI(`${model.getName()}Create`, model))}
|
|
127
|
+
${entityModels.map(model => makeReadAPI(`${model.getName()}Update`, model))}
|
|
113
128
|
}`,
|
|
114
129
|
|
|
115
130
|
`type Mutation {
|
|
@@ -152,6 +167,15 @@ module.exports = (schema) => {
|
|
|
152
167
|
});
|
|
153
168
|
}, {});
|
|
154
169
|
|
|
170
|
+
if (model.isEntity() && model.hasGQLScope('s')) {
|
|
171
|
+
prev[`${model.getName()}SubscriptionQuery`] = {
|
|
172
|
+
__resolveType: root => root.__typename, // eslint-disable-line no-underscore-dangle
|
|
173
|
+
...fieldResolvers,
|
|
174
|
+
};
|
|
175
|
+
prev[`${model.getName()}Create`] = fieldResolvers;
|
|
176
|
+
prev[`${model.getName()}Update`] = fieldResolvers;
|
|
177
|
+
}
|
|
178
|
+
|
|
155
179
|
return Object.assign(prev, {
|
|
156
180
|
[modelName]: fieldResolvers,
|
|
157
181
|
[`${modelName}Connection`]: {
|
|
@@ -9,9 +9,13 @@ module.exports = (schema) => {
|
|
|
9
9
|
const createdAt = model.getDirectiveArg('model', 'createdAt', 'createdAt');
|
|
10
10
|
const updatedAt = model.getDirectiveArg('model', 'updatedAt', 'updatedAt');
|
|
11
11
|
|
|
12
|
-
if (model.getKind() === 'ObjectTypeDefinition') {
|
|
12
|
+
if (model.getKind() === 'ObjectTypeDefinition' && (id || createdAt || updatedAt)) {
|
|
13
|
+
const interfaces = [];
|
|
14
|
+
if (id) interfaces.push('Node');
|
|
15
|
+
const interfacesGQL = interfaces.length ? ' implements'.concat(' ', interfaces.join(' & ')) : '';
|
|
16
|
+
|
|
13
17
|
return `
|
|
14
|
-
extend type ${modelName}
|
|
18
|
+
extend type ${modelName}${interfacesGQL} {
|
|
15
19
|
${id ? `id: ID! @field(key: "${id}", gqlScope: r)` : ''}
|
|
16
20
|
${createdAt ? `createdAt: AutoGraphDateTime @field(key: "${createdAt}", gqlScope: r)` : ''}
|
|
17
21
|
${updatedAt ? `updatedAt: AutoGraphDateTime @field(key: "${updatedAt}", gqlScope: r)` : ''}
|
|
@@ -24,7 +28,7 @@ module.exports = (schema) => {
|
|
|
24
28
|
interface Node { id: ID! }
|
|
25
29
|
enum SortOrderEnum { asc desc }
|
|
26
30
|
enum SubscriptionCrudEnum { create update delete } # Not going to support "read"
|
|
27
|
-
enum SubscriptionWhenEnum {
|
|
31
|
+
enum SubscriptionWhenEnum { preEvent postEvent }
|
|
28
32
|
`),
|
|
29
33
|
});
|
|
30
34
|
};
|
|
@@ -13,11 +13,11 @@ const systemEvent = new EventEmitter().setMaxListeners(100).on('system', async (
|
|
|
13
13
|
|
|
14
14
|
//
|
|
15
15
|
exports.createSystemEvent = (name, mixed = {}, thunk = () => {}) => {
|
|
16
|
-
let event;
|
|
17
|
-
let middleware;
|
|
16
|
+
let event = mixed;
|
|
17
|
+
let middleware = () => Promise.resolve();
|
|
18
18
|
const type = ucFirst(name);
|
|
19
19
|
|
|
20
|
-
if (name !== 'Setup') {
|
|
20
|
+
if (name !== 'Setup' && name !== 'Response') {
|
|
21
21
|
const { method, query } = mixed;
|
|
22
22
|
const { resolver, model, meta, doc, id, input, sort, merged, native, root, crud } = query.toObject();
|
|
23
23
|
|
|
@@ -49,18 +49,18 @@ exports.createSystemEvent = (name, mixed = {}, thunk = () => {}) => {
|
|
|
49
49
|
|
|
50
50
|
resolve();
|
|
51
51
|
});
|
|
52
|
-
} else {
|
|
53
|
-
middleware = () => Promise.resolve();
|
|
54
|
-
event = mixed;
|
|
55
52
|
}
|
|
56
53
|
|
|
57
54
|
return systemEvent.emit('system', { type: `pre${type}`, data: event }).then((result) => {
|
|
58
55
|
if (result !== undefined) return result; // Allowing middleware to dictate result
|
|
59
56
|
return middleware().then(thunk);
|
|
60
57
|
}).then((result) => {
|
|
61
|
-
// event.doc = result; // You do actually need this...
|
|
62
58
|
event.result = result;
|
|
63
|
-
return systemEvent.emit('system', { type: `post${type}`, data: event }).then(
|
|
59
|
+
return systemEvent.emit('system', { type: `post${type}`, data: event }).then((postResult = result) => postResult);
|
|
60
|
+
}).then((result) => {
|
|
61
|
+
if (name === 'Response') return result;
|
|
62
|
+
event.result = result;
|
|
63
|
+
return exports.createSystemEvent('Response', event, (finalResult = result) => finalResult);
|
|
64
64
|
});
|
|
65
65
|
};
|
|
66
66
|
|