@coderich/autograph 0.9.2 → 0.9.3

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.2",
4
+ "version": "0.9.3",
5
5
  "description": "AutoGraph",
6
6
  "keywords": [
7
7
  "graphql",
@@ -70,12 +70,27 @@ module.exports = (schema) => {
70
70
  `),
71
71
 
72
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'}`)}
80
+ }
81
+
82
+ type ${model.getName()}SubscriptionPayload {
83
+ event: ${model.getName()}SubscriptionPayloadEvent
84
+ query: ${model.getName()}SubscriptionQuery
85
+ }
86
+
87
+ type ${model.getName()}SubscriptionPayloadEvent {
88
+ crud: SubscriptionCrudEnum!
89
+ data: ${model.getName()}SubscriptionPayloadEventData!
75
90
  }
76
91
 
77
92
  type ${model.getName()}SubscriptionPayloadEventData {
78
- ${getGQLWhereFields(model).filter(field => field.isBasicType() || field.isEmbedded()).map(field => `${field.getName()}: ${field.getGQLType()}`)}
93
+ ${getGQLWhereFields(model).map(field => `${field.getName()}: ${field.isFKReference() ? 'ID' : field.getGQLType()}`)}
79
94
  }
80
95
 
81
96
  interface ${model.getName()}SubscriptionQuery {
@@ -89,21 +104,6 @@ module.exports = (schema) => {
89
104
  type ${model.getName()}Update implements ${model.getName()}SubscriptionQuery {
90
105
  ${model.getFields().filter(field => field.hasGQLScope('r')).map(field => `${field.getName()}: ${field.getPayloadType()}`)}
91
106
  }
92
-
93
- type ${model.getName()}SubscriptionPayloadEvent {
94
- crud: SubscriptionCrudEnum!
95
- data: ${model.getName()}SubscriptionPayloadEventData!
96
- }
97
-
98
- type ${model.getName()}SubscriptionPayload {
99
- event: ${model.getName()}SubscriptionPayloadEvent
100
- query: ${model.getName()}SubscriptionQuery
101
- }
102
-
103
- input ${model.getName()}SubscriptionInputFilter {
104
- when: [SubscriptionWhenEnum!]! = [preEvent, postEvent]
105
- where: ${model.getName()}SubscriptionInputWhere! = {}
106
- }
107
107
  `),
108
108
 
109
109
  ...spliceModels.map(model => `
@@ -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