@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
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@coderich/autograph",
3
3
  "author": "Richard Livolsi (coderich)",
4
- "version": "0.9.0",
4
+ "version": "0.9.4",
5
5
  "description": "AutoGraph",
6
6
  "keywords": [
7
7
  "graphql",
@@ -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, new DataLoader(this, model)), new WeakMap());
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(this.toModel(model)).clearAll();
95
+ this.loaders.get(`${model}`).clearAll();
96
96
  return this;
97
97
  }
98
98
 
@@ -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}`).map(file => loadFile(file)).join('\n\n');
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`).map(file => reqFile(file)).reduce((prev, data) => {
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).filter(field => field.isBasicType() || field.isEmbedded()).map(field => `${field.getName()}: ${field.getModelRef() ? `${ucFirst(field.getDataRef())}InputWhere` : 'AutoGraphMixed'}`)}
79
+ ${getGQLWhereFields(model).map(field => `${field.getName()}: ${field.getModelRef() && !field.isFKReference() ? `${ucFirst(field.getDataRef())}InputWhere` : 'AutoGraphMixed'}`)}
75
80
  }
76
81
 
77
- type ${model.getName()}SubscriptionPayloadEventData {
78
- ${getGQLWhereFields(model).filter(field => field.isBasicType() || field.isEmbedded()).map(field => `${field.getName()}: ${field.getGQLType()}`)}
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()}SubscriptionPayload {
87
- event: ${model.getName()}SubscriptionPayloadEvent
92
+ type ${model.getName()}SubscriptionPayloadEventData {
93
+ ${getGQLWhereFields(model).map(field => `${field.getName()}: ${field.isFKReference() ? 'ID' : field.getGQLType()}`)}
88
94
  }
89
95
 
90
- input ${model.getName()}SubscriptionInputFilter {
91
- when: SubscriptionWhenEnum! = anytime
92
- where: ${model.getName()}SubscriptionInputWhere! = {}
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} ${id ? 'implements Node' : ''} {
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 { anytime preEvent postEvent }
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(finalResult => finalResult || result);
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