@kapeta/local-cluster-service 0.54.11 → 0.54.12

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/CHANGELOG.md CHANGED
@@ -1,3 +1,10 @@
1
+ ## [0.54.12](https://github.com/kapetacom/local-cluster-service/compare/v0.54.11...v0.54.12) (2024-07-10)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * throttle plan events and catch event errors ([#190](https://github.com/kapetacom/local-cluster-service/issues/190)) ([9a04b1e](https://github.com/kapetacom/local-cluster-service/commit/9a04b1eefba7f94558c1fd08441584dace9ae7e9))
7
+
1
8
  ## [0.54.11](https://github.com/kapetacom/local-cluster-service/compare/v0.54.10...v0.54.11) (2024-07-10)
2
9
 
3
10
 
@@ -17,6 +17,7 @@ const event_parser_1 = require("./event-parser");
17
17
  const codegen_1 = require("./codegen");
18
18
  const assetManager_1 = require("../assetManager");
19
19
  const path_1 = __importDefault(require("path"));
20
+ const lodash_1 = __importDefault(require("lodash"));
20
21
  const router = (0, express_promise_router_1.default)();
21
22
  router.use('/', cors_1.corsHandler);
22
23
  router.use('/', stringBody_1.stringBody);
@@ -35,21 +36,28 @@ router.post('/:handle/all', async (req, res) => {
35
36
  res.set('Access-Control-Expose-Headers', stormClient_1.ConversationIdHeader);
36
37
  res.set(stormClient_1.ConversationIdHeader, metaStream.getConversationId());
37
38
  let currentPhase = events_1.StormEventPhaseType.META;
39
+ // Helper to avoid sending the plan multiple times in a row
40
+ const sendUpdatedPlan = lodash_1.default.debounce(sendDefinitions, 50, { maxWait: 200 });
38
41
  metaStream.on('data', (data) => {
39
- const result = eventParser.processEvent(req.params.handle, data);
40
- switch (data.type) {
41
- case 'CREATE_API':
42
- case 'CREATE_MODEL':
43
- case 'CREATE_TYPE':
44
- if (currentPhase !== events_1.StormEventPhaseType.DEFINITIONS) {
45
- sendEvent(res, (0, event_parser_1.createPhaseEndEvent)(events_1.StormEventPhaseType.META));
46
- currentPhase = events_1.StormEventPhaseType.DEFINITIONS;
47
- sendEvent(res, (0, event_parser_1.createPhaseStartEvent)(events_1.StormEventPhaseType.DEFINITIONS));
48
- }
49
- break;
42
+ try {
43
+ const result = eventParser.processEvent(handle, data);
44
+ switch (data.type) {
45
+ case 'CREATE_API':
46
+ case 'CREATE_MODEL':
47
+ case 'CREATE_TYPE':
48
+ if (currentPhase !== events_1.StormEventPhaseType.DEFINITIONS) {
49
+ sendEvent(res, (0, event_parser_1.createPhaseEndEvent)(events_1.StormEventPhaseType.META));
50
+ currentPhase = events_1.StormEventPhaseType.DEFINITIONS;
51
+ sendEvent(res, (0, event_parser_1.createPhaseStartEvent)(events_1.StormEventPhaseType.DEFINITIONS));
52
+ }
53
+ break;
54
+ }
55
+ sendEvent(res, data);
56
+ sendUpdatedPlan(res, result);
57
+ }
58
+ catch (e) {
59
+ console.error('Failed to process event', e);
50
60
  }
51
- sendEvent(res, data);
52
- sendDefinitions(res, result);
53
61
  });
54
62
  try {
55
63
  sendEvent(res, (0, event_parser_1.createPhaseStartEvent)(events_1.StormEventPhaseType.META));
@@ -17,6 +17,7 @@ const event_parser_1 = require("./event-parser");
17
17
  const codegen_1 = require("./codegen");
18
18
  const assetManager_1 = require("../assetManager");
19
19
  const path_1 = __importDefault(require("path"));
20
+ const lodash_1 = __importDefault(require("lodash"));
20
21
  const router = (0, express_promise_router_1.default)();
21
22
  router.use('/', cors_1.corsHandler);
22
23
  router.use('/', stringBody_1.stringBody);
@@ -35,21 +36,28 @@ router.post('/:handle/all', async (req, res) => {
35
36
  res.set('Access-Control-Expose-Headers', stormClient_1.ConversationIdHeader);
36
37
  res.set(stormClient_1.ConversationIdHeader, metaStream.getConversationId());
37
38
  let currentPhase = events_1.StormEventPhaseType.META;
39
+ // Helper to avoid sending the plan multiple times in a row
40
+ const sendUpdatedPlan = lodash_1.default.debounce(sendDefinitions, 50, { maxWait: 200 });
38
41
  metaStream.on('data', (data) => {
39
- const result = eventParser.processEvent(req.params.handle, data);
40
- switch (data.type) {
41
- case 'CREATE_API':
42
- case 'CREATE_MODEL':
43
- case 'CREATE_TYPE':
44
- if (currentPhase !== events_1.StormEventPhaseType.DEFINITIONS) {
45
- sendEvent(res, (0, event_parser_1.createPhaseEndEvent)(events_1.StormEventPhaseType.META));
46
- currentPhase = events_1.StormEventPhaseType.DEFINITIONS;
47
- sendEvent(res, (0, event_parser_1.createPhaseStartEvent)(events_1.StormEventPhaseType.DEFINITIONS));
48
- }
49
- break;
42
+ try {
43
+ const result = eventParser.processEvent(handle, data);
44
+ switch (data.type) {
45
+ case 'CREATE_API':
46
+ case 'CREATE_MODEL':
47
+ case 'CREATE_TYPE':
48
+ if (currentPhase !== events_1.StormEventPhaseType.DEFINITIONS) {
49
+ sendEvent(res, (0, event_parser_1.createPhaseEndEvent)(events_1.StormEventPhaseType.META));
50
+ currentPhase = events_1.StormEventPhaseType.DEFINITIONS;
51
+ sendEvent(res, (0, event_parser_1.createPhaseStartEvent)(events_1.StormEventPhaseType.DEFINITIONS));
52
+ }
53
+ break;
54
+ }
55
+ sendEvent(res, data);
56
+ sendUpdatedPlan(res, result);
57
+ }
58
+ catch (e) {
59
+ console.error('Failed to process event', e);
50
60
  }
51
- sendEvent(res, data);
52
- sendDefinitions(res, result);
53
61
  });
54
62
  try {
55
63
  sendEvent(res, (0, event_parser_1.createPhaseStartEvent)(events_1.StormEventPhaseType.META));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kapeta/local-cluster-service",
3
- "version": "0.54.11",
3
+ "version": "0.54.12",
4
4
  "description": "Manages configuration, ports and service discovery for locally running Kapeta systems",
5
5
  "type": "commonjs",
6
6
  "exports": {
@@ -22,6 +22,7 @@ import {
22
22
  import { StormCodegen } from './codegen';
23
23
  import { assetManager } from '../assetManager';
24
24
  import Path from 'path';
25
+ import _ from 'lodash';
25
26
 
26
27
  const router = Router();
27
28
 
@@ -29,7 +30,7 @@ router.use('/', corsHandler);
29
30
  router.use('/', stringBody);
30
31
 
31
32
  router.post('/:handle/all', async (req: KapetaBodyRequest, res: Response) => {
32
- const handle = req.params.handle;
33
+ const handle = req.params.handle as string;
33
34
 
34
35
  try {
35
36
  const stormOptions = await resolveOptions();
@@ -51,23 +52,29 @@ router.post('/:handle/all', async (req: KapetaBodyRequest, res: Response) => {
51
52
 
52
53
  let currentPhase = StormEventPhaseType.META;
53
54
 
55
+ // Helper to avoid sending the plan multiple times in a row
56
+ const sendUpdatedPlan = _.debounce(sendDefinitions, 50, { maxWait: 200 });
54
57
  metaStream.on('data', (data: StormEvent) => {
55
- const result = eventParser.processEvent(req.params.handle, data);
56
-
57
- switch (data.type) {
58
- case 'CREATE_API':
59
- case 'CREATE_MODEL':
60
- case 'CREATE_TYPE':
61
- if (currentPhase !== StormEventPhaseType.DEFINITIONS) {
62
- sendEvent(res, createPhaseEndEvent(StormEventPhaseType.META));
63
- currentPhase = StormEventPhaseType.DEFINITIONS;
64
- sendEvent(res, createPhaseStartEvent(StormEventPhaseType.DEFINITIONS));
65
- }
66
- break;
67
- }
58
+ try {
59
+ const result = eventParser.processEvent(handle, data);
60
+
61
+ switch (data.type) {
62
+ case 'CREATE_API':
63
+ case 'CREATE_MODEL':
64
+ case 'CREATE_TYPE':
65
+ if (currentPhase !== StormEventPhaseType.DEFINITIONS) {
66
+ sendEvent(res, createPhaseEndEvent(StormEventPhaseType.META));
67
+ currentPhase = StormEventPhaseType.DEFINITIONS;
68
+ sendEvent(res, createPhaseStartEvent(StormEventPhaseType.DEFINITIONS));
69
+ }
70
+ break;
71
+ }
68
72
 
69
- sendEvent(res, data);
70
- sendDefinitions(res, result);
73
+ sendEvent(res, data);
74
+ sendUpdatedPlan(res, result);
75
+ } catch (e) {
76
+ console.error('Failed to process event', e);
77
+ }
71
78
  });
72
79
 
73
80
  try {