@ibgib/core-gib 0.1.58 → 0.1.60

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.
Files changed (96) hide show
  1. package/CHANGELOG.md +9 -1
  2. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.d.mts.map +1 -1
  3. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.mjs +6 -2
  4. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.mjs.map +1 -1
  5. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-types.d.mts +1 -1
  6. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.d.mts +1 -1
  7. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.d.mts.map +1 -1
  8. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mjs +7 -11
  9. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mjs.map +1 -1
  10. package/dist/sync/sync-peer/sync-peer-types.d.mts +24 -1
  11. package/dist/sync/sync-peer/sync-peer-types.d.mts.map +1 -1
  12. package/dist/sync/sync-peer/sync-peer-v1.d.mts +15 -4
  13. package/dist/sync/sync-peer/sync-peer-v1.d.mts.map +1 -1
  14. package/dist/sync/sync-peer/sync-peer-v1.mjs +120 -25
  15. package/dist/sync/sync-peer/sync-peer-v1.mjs.map +1 -1
  16. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-constants.d.mts +46 -0
  17. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-constants.d.mts.map +1 -0
  18. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-constants.mjs +45 -0
  19. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-constants.mjs.map +1 -0
  20. package/dist/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-peer-websocket-receiver-types.d.mts +2 -2
  21. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-receiver/sync-peer-websocket-receiver-types.d.mts.map +1 -0
  22. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-receiver/sync-peer-websocket-receiver-types.mjs.map +1 -0
  23. package/dist/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-peer-websocket-receiver-v1.d.mts +11 -8
  24. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-receiver/sync-peer-websocket-receiver-v1.d.mts.map +1 -0
  25. package/dist/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-peer-websocket-receiver-v1.mjs +115 -61
  26. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-receiver/sync-peer-websocket-receiver-v1.mjs.map +1 -0
  27. package/dist/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-websocket-peer-helpers.d.mts +3 -3
  28. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-receiver/sync-websocket-peer-helpers.d.mts.map +1 -0
  29. package/dist/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-websocket-peer-helpers.mjs +6 -6
  30. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-receiver/sync-websocket-peer-helpers.mjs.map +1 -0
  31. package/dist/sync/sync-peer/{sync-peer-websocket-sender → sync-peer-websocket/sync-peer-websocket-sender}/sync-peer-websocket-sender-types.d.mts +1 -1
  32. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-sender/sync-peer-websocket-sender-types.d.mts.map +1 -0
  33. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-sender/sync-peer-websocket-sender-types.mjs.map +1 -0
  34. package/dist/sync/sync-peer/{sync-peer-websocket-sender → sync-peer-websocket/sync-peer-websocket-sender}/sync-peer-websocket-sender-v1.d.mts +22 -4
  35. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.d.mts.map +1 -0
  36. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.mjs +447 -0
  37. package/dist/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.mjs.map +1 -0
  38. package/dist/sync/sync-saga-context/sync-saga-context-helpers.d.mts +22 -5
  39. package/dist/sync/sync-saga-context/sync-saga-context-helpers.d.mts.map +1 -1
  40. package/dist/sync/sync-saga-context/sync-saga-context-helpers.mjs +263 -28
  41. package/dist/sync/sync-saga-context/sync-saga-context-helpers.mjs.map +1 -1
  42. package/dist/sync/sync-saga-context/sync-saga-context-types.d.mts +13 -0
  43. package/dist/sync/sync-saga-context/sync-saga-context-types.d.mts.map +1 -1
  44. package/dist/sync/sync-saga-coordinator.d.mts +12 -1
  45. package/dist/sync/sync-saga-coordinator.d.mts.map +1 -1
  46. package/dist/sync/sync-saga-coordinator.mjs +106 -12
  47. package/dist/sync/sync-saga-coordinator.mjs.map +1 -1
  48. package/dist/sync/sync-types.d.mts +24 -0
  49. package/dist/sync/sync-types.d.mts.map +1 -1
  50. package/dist/sync/sync-types.mjs +0 -1
  51. package/dist/sync/sync-types.mjs.map +1 -1
  52. package/dist/sync/sync-withid.connect.respec.mjs +3 -3
  53. package/dist/sync/sync-withid.connect.respec.mjs.map +1 -1
  54. package/dist/sync/sync-withid.pingpong.respec.d.mts +11 -0
  55. package/dist/sync/sync-withid.pingpong.respec.d.mts.map +1 -0
  56. package/dist/sync/sync-withid.pingpong.respec.mjs +199 -0
  57. package/dist/sync/sync-withid.pingpong.respec.mjs.map +1 -0
  58. package/dist/witness/space/inner-space/inner-space-v1.d.mts.map +1 -1
  59. package/dist/witness/space/inner-space/inner-space-v1.mjs +1 -1
  60. package/dist/witness/space/inner-space/inner-space-v1.mjs.map +1 -1
  61. package/package.json +1 -1
  62. package/src/sync/docs/security-3b.md +92 -0
  63. package/src/sync/docs/security.md +107 -39
  64. package/src/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.mts +6 -2
  65. package/src/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-types.mts +1 -1
  66. package/src/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mts +11 -14
  67. package/src/sync/sync-peer/sync-peer-types.mts +28 -1
  68. package/src/sync/sync-peer/sync-peer-v1.mts +127 -35
  69. package/src/sync/sync-peer/sync-peer-websocket/README.md +42 -0
  70. package/src/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-constants.mts +68 -0
  71. package/src/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-peer-websocket-receiver-types.mts +2 -2
  72. package/src/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-peer-websocket-receiver-v1.mts +128 -71
  73. package/src/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-websocket-peer-helpers.mts +8 -8
  74. package/src/sync/sync-peer/{sync-peer-websocket-sender → sync-peer-websocket/sync-peer-websocket-sender}/sync-peer-websocket-sender-types.mts +1 -1
  75. package/src/sync/sync-peer/sync-peer-websocket/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.mts +509 -0
  76. package/src/sync/sync-saga-context/sync-saga-context-helpers.mts +267 -36
  77. package/src/sync/sync-saga-context/sync-saga-context-types.mts +14 -0
  78. package/src/sync/sync-saga-coordinator.mts +148 -8
  79. package/src/sync/sync-types.mts +28 -4
  80. package/src/sync/sync-withid.connect.respec.mts +3 -3
  81. package/src/sync/sync-withid.pingpong.respec.mts +234 -0
  82. package/src/witness/space/inner-space/inner-space-v1.mts +4 -5
  83. package/dist/sync/sync-peer/sync-peer-websocket-receiver/sync-peer-websocket-receiver-types.d.mts.map +0 -1
  84. package/dist/sync/sync-peer/sync-peer-websocket-receiver/sync-peer-websocket-receiver-types.mjs.map +0 -1
  85. package/dist/sync/sync-peer/sync-peer-websocket-receiver/sync-peer-websocket-receiver-v1.d.mts.map +0 -1
  86. package/dist/sync/sync-peer/sync-peer-websocket-receiver/sync-peer-websocket-receiver-v1.mjs.map +0 -1
  87. package/dist/sync/sync-peer/sync-peer-websocket-receiver/sync-websocket-peer-helpers.d.mts.map +0 -1
  88. package/dist/sync/sync-peer/sync-peer-websocket-receiver/sync-websocket-peer-helpers.mjs.map +0 -1
  89. package/dist/sync/sync-peer/sync-peer-websocket-sender/sync-peer-websocket-sender-types.d.mts.map +0 -1
  90. package/dist/sync/sync-peer/sync-peer-websocket-sender/sync-peer-websocket-sender-types.mjs.map +0 -1
  91. package/dist/sync/sync-peer/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.d.mts.map +0 -1
  92. package/dist/sync/sync-peer/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.mjs +0 -282
  93. package/dist/sync/sync-peer/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.mjs.map +0 -1
  94. package/src/sync/sync-peer/sync-peer-websocket-sender/sync-peer-websocket-sender-v1.mts +0 -321
  95. /package/dist/sync/sync-peer/{sync-peer-websocket-receiver → sync-peer-websocket/sync-peer-websocket-receiver}/sync-peer-websocket-receiver-types.mjs +0 -0
  96. /package/dist/sync/sync-peer/{sync-peer-websocket-sender → sync-peer-websocket/sync-peer-websocket-sender}/sync-peer-websocket-sender-types.mjs +0 -0
@@ -1,321 +0,0 @@
1
- /**
2
- * @module sync-peer-websocket-sender-v1
3
- */
4
-
5
- import { extractErrorMsg } from '@ibgib/helper-gib/dist/helpers/utils-helper.mjs';
6
- import { getIbGibAddr } from '@ibgib/ts-gib/dist/helper.mjs';
7
- import { IbGib_V1 } from '@ibgib/ts-gib/dist/V1/types.mjs';
8
- import { KeystoneIbGib_V1 } from '../../../keystone/keystone-types.mjs';
9
- import { KeystoneService_V1 } from '../../../keystone/keystone-service-v1.mjs';
10
- import { KeystoneStrategyFactory } from '../../../keystone/strategy/keystone-strategy-factory.mjs';
11
- import { deriveSessionSecret } from '../../sync-helpers.mjs';
12
- import { SyncPeer_V1 } from '../sync-peer-v1.mjs';
13
- import { SyncSagaContextIbGib_V1 } from '../../sync-saga-context/sync-saga-context-types.mjs';
14
- import { GLOBAL_LOG_A_LOT } from '../../../core-constants.mjs';
15
- import {
16
- ConnectSyncPeerWebSocketSenderOpts,
17
- InitializeSyncPeerWebSocketSenderOpts,
18
- SyncPeerWebSocketSenderData_V1,
19
- SyncPeerWebSocketSenderRel8ns_V1,
20
- SyncPeerWebSocketSenderIbGib_V1
21
- } from './sync-peer-websocket-sender-types.mjs';
22
- import {
23
- SESSION_KEYSTONE_POLICY,
24
- getConnectChallenge
25
- } from '../sync-peer-websocket-receiver/sync-websocket-peer-helpers.mjs';
26
-
27
- const logalot = GLOBAL_LOG_A_LOT || true;
28
-
29
- /**
30
- * WebSocket Sender Peer implementation running in browser/native environment.
31
- */
32
- export class SyncPeerWebSocketSender_V1
33
- extends SyncPeer_V1<ConnectSyncPeerWebSocketSenderOpts, InitializeSyncPeerWebSocketSenderOpts>
34
- implements SyncPeerWebSocketSenderIbGib_V1 {
35
-
36
- protected override lc: string = `[${SyncPeerWebSocketSender_V1.name}]`;
37
-
38
- override get classname(): string {
39
- return SyncPeerWebSocketSender_V1.name;
40
- }
41
-
42
- public get isSocketOpen(): boolean {
43
- return this.ws !== undefined && this.ws.readyState === WebSocket.OPEN;
44
- }
45
-
46
- declare data: SyncPeerWebSocketSenderData_V1 | undefined;
47
- declare rel8ns: SyncPeerWebSocketSenderRel8ns_V1 | undefined;
48
-
49
- protected ws?: WebSocket;
50
- protected activeResolve?: (value: SyncSagaContextIbGib_V1 | undefined) => void;
51
- protected activeReject?: (reason: any) => void;
52
-
53
- constructor(
54
- initialData: SyncPeerWebSocketSenderData_V1,
55
- initialRel8ns?: SyncPeerWebSocketSenderRel8ns_V1,
56
- ) {
57
- super(initialData, initialRel8ns);
58
- }
59
-
60
- protected override async preConnectCheck(opts: ConnectSyncPeerWebSocketSenderOpts): Promise<void> {
61
- const lc = `${this.lc}[${this.preConnectCheck.name}]`;
62
- if (!this.data?.wsUrl) {
63
- throw new Error(`Missing wsUrl in peer data (E: a3b2c1d0e9f8e7d6c5b4a3f2e1d0c910)`);
64
- }
65
- if (!this.data?.httpEvolveUrl) {
66
- throw new Error(`Missing httpEvolveUrl in peer data (E: a3b2c1d0e9f8e7d6c5b4a3f2e1d0c911)`);
67
- }
68
- }
69
-
70
- /**
71
- * Submits the evolved master identity (I1) and new session keystone (S) to the server's HTTP registry.
72
- */
73
- protected override async postEstablishToReceiver({
74
- newSenderIdentity,
75
- sessionIdentity,
76
- }: {
77
- newSenderIdentity: KeystoneIbGib_V1;
78
- sessionIdentity: KeystoneIbGib_V1;
79
- }): Promise<void> {
80
- const lc = `${this.lc}[${this.postEstablishToReceiver.name}]`;
81
- try {
82
- if (logalot) { console.log(`${lc} posting evolved keystones to ${this.data!.httpEvolveUrl}...`); }
83
- if (!this.data) { throw new Error(`(UNEXPECTED) this.data falsy? (E: d642e8a9af18b532c87c6f581aa53b26)`); }
84
-
85
- if (!this.data.httpEvolveUrl) { throw new Error(`(UNEXPECTED) this.data.httpEvolveUrl falsy? (E: 8589ddbb155914d85c09658881da2c26)`); }
86
-
87
- const response = await fetch(this.data.httpEvolveUrl, {
88
- method: 'PUT',
89
- headers: {
90
- 'Content-Type': 'application/json',
91
- },
92
- body: JSON.stringify({
93
- keystoneIbGib: newSenderIdentity,
94
- relatedIbGibs: [sessionIdentity]
95
- }),
96
- });
97
-
98
- if (!response.ok) {
99
- const data = await response.json().catch(() => ({}));
100
- const errorMsg = data.message || data.error || 'Unknown error';
101
- throw new Error(`HTTP ${response.status} evolution post rejected. errorMsg: ${errorMsg} (E: e8a478291b88d05c68cf6b385684b826)`);
102
- }
103
-
104
- if (logalot) { console.log(`${lc} evolve post accepted by server.`); }
105
- } catch (error) {
106
- console.error(`${lc} establish post failed: ${extractErrorMsg(error)}`);
107
- throw error;
108
- }
109
- }
110
-
111
- /**
112
- * Establishes the stateful WebSocket connection and performs the multi-turn cryptographic challenge connect.
113
- */
114
- protected override async connectImpl(opts: ConnectSyncPeerWebSocketSenderOpts): Promise<void> {
115
- const lc = `${this.lc}[${this.connectImpl.name}]`;
116
- try {
117
- if (logalot) { console.log(`${lc} starting...`); }
118
-
119
- const { senderIdentity, fnSenderSecret, sagaId, localMetaspace, localSpace } = this.opts!;
120
- if (!senderIdentity || !fnSenderSecret || !sagaId) {
121
- throw new Error(`Missing identity parameters in peer options (E: ed49b6711ac82efcdb42b8a28c5b6826)`);
122
- }
123
-
124
- // 1. Solve upfront pre-filter solution
125
- const senderSecret = await fnSenderSecret();
126
- const sessionSecret = await deriveSessionSecret({ senderSecret, sagaId });
127
-
128
- // Fetch session identity S that establishSessionIdentity just created
129
- const sAddr_tjp = getIbGibAddr({ ibGib: senderIdentity }); // wait, S's past contains I
130
- // Actually, we can get the S keystone that was returned by establishSessionIdentity.
131
- // Let's resolve S from the sender localSpace using its target claim or the targetAddrs
132
- const sAddr = getIbGibAddr({ ibGib: senderIdentity.rel8ns?.past ? senderIdentity : senderIdentity }); // stub: get the actual generated S
133
-
134
- // To make sure we have the exact session identity S, we can query localSpace.
135
- // Since we know the sagaId, we can walk or locate it.
136
- // But wait, the coordinator calls establishSessionIdentity first, which returns the created S keystone!
137
- // Let's store a reference to the sessionIdentity S on this class during establish, or lookup from localSpace.
138
- // Wait, does the coordinator let the peer store S? No, but let's query the latest keystone in localSpace.
139
- const senderIdentityLatestAddr =
140
- await localMetaspace.getLatestAddr({ ibGib: senderIdentity, space: localSpace });
141
- if (!senderIdentityLatestAddr) { throw new Error(`senderIdentityLatestAddr falsy. we should have a latest addr that is different than the sender identity at this point (done in the peer establish phase) (E: 225607318bef485d7821f82de97b6826)`); }
142
-
143
- const resGet = await localMetaspace.get({ addrs: [senderIdentityLatestAddr], space: localSpace });
144
- const I_tip = resGet.ibGibs?.[0] as KeystoneIbGib_V1;
145
-
146
- // const targetSAddr = I_tip?.rel8ns?.past?.[0] ?? I_tip?.data?.proofs?.[0]?.claim?.target;
147
- const targetSAddr = I_tip.data.proofs.at(0)?.claim.target;
148
- if (!targetSAddr) {
149
- throw new Error(`Could not locate session keystone target from identity (E: 5ec4882f7e5e4c33fbd00ab8b3166726)`);
150
- }
151
-
152
- const resGetS = await localMetaspace.get({ addrs: [targetSAddr], space: localSpace });
153
- const sessionS = resGetS.ibGibs?.[0] as KeystoneIbGib_V1;
154
- if (!sessionS) {
155
- throw new Error(`Session keystone not found in local space: ${targetSAddr} (E: 9ba818e6622808bb4ae749be31f80b26)`);
156
- }
157
-
158
- // Solve dynamic upfront picket-fence challenge
159
- const connectPool =
160
- (sessionS.data?.challengePools ?? [])
161
- .find(p => p.id === SESSION_KEYSTONE_POLICY.CONNECT_POOL.ID);
162
- if (!connectPool) {
163
- throw new Error(`Session keystone missing connect pool (E: f50968afca04b6d38ec19824ea201826)`);
164
- }
165
-
166
- const { challengeId } = getConnectChallenge(sessionS);
167
- const strategy = KeystoneStrategyFactory.create({ config: connectPool.config });
168
- const poolSecret = await strategy.derivePoolSecret({ masterSecret: sessionSecret });
169
- const solution = await strategy.generateSolution({
170
- poolSecret,
171
- poolId: SESSION_KEYSTONE_POLICY.CONNECT_POOL.ID,
172
- challengeId
173
- });
174
-
175
- // 2. Open WebSocket connection
176
- const wsUrl = `${this.data!.wsUrl}?sAddr=${encodeURIComponent(targetSAddr)}&solution=${encodeURIComponent(solution.value)}`;
177
- if (logalot) { console.log(`${lc} connecting to WebSocket: ${wsUrl}`); }
178
-
179
- const ws = new WebSocket(wsUrl);
180
- this.ws = ws;
181
-
182
- return new Promise<void>((resolve, reject) => {
183
- let isResolved = false;
184
-
185
- ws.addEventListener('open', () => {
186
- if (logalot) { console.log(`${lc} WebSocket opened. Awaiting challenge...`); }
187
- });
188
-
189
- ws.addEventListener('message', async (ev) => {
190
- try {
191
- const msg = JSON.parse(ev.data);
192
- if (logalot) { console.log(`${lc} received frame: ${msg.type}`); }
193
-
194
- if (msg.type === 'auth-challenge-init') {
195
- ws.send(JSON.stringify({
196
- type: 'auth-init',
197
- sAddr: targetSAddr
198
- }));
199
- } else if (msg.type === 'auth-challenge') {
200
- const { challengeUuid, demandedIds } = msg;
201
- if (logalot) { console.log(`${lc} solving demanded challenges: ${demandedIds.join(', ')}`); }
202
-
203
- const keystoneService = new KeystoneService_V1();
204
- const proofFrame = await keystoneService.sign({
205
- latestKeystone: sessionS,
206
- masterSecret: sessionSecret,
207
- poolId: SESSION_KEYSTONE_POLICY.CONNECT_POOL.ID,
208
- requiredChallengeIds: demandedIds,
209
- claim: {
210
- verb: SESSION_KEYSTONE_POLICY.CONNECT_POOL.VERB,
211
- target: challengeUuid
212
- },
213
- metaspace: localMetaspace,
214
- space: localSpace
215
- });
216
-
217
- ws.send(JSON.stringify({
218
- type: 'auth-proof',
219
- proofFrame
220
- }));
221
- } else if (msg.type === 'auth-ok') {
222
- if (logalot) { console.log(`${lc} WebSocket connect SUCCESS!`); }
223
- isResolved = true;
224
-
225
- // Setup persistent runtime listeners
226
- ws.removeEventListener('message', (() => { }) as any);
227
- ws.addEventListener('message', (event) => this.handleRuntimeMessage(event));
228
-
229
- resolve();
230
- } else if (msg.type === 'auth-fail') {
231
- reject(new Error(`Connect failed: ${msg.message}`));
232
- }
233
- } catch (error) {
234
- reject(error);
235
- }
236
- });
237
-
238
- ws.addEventListener('close', (event) => {
239
- if (!isResolved) {
240
- reject(new Error(`WebSocket closed before connect completed (code: ${event.code})`));
241
- }
242
- });
243
-
244
- ws.addEventListener('error', (err) => {
245
- if (!isResolved) {
246
- reject(new Error(`WebSocket connection error`));
247
- }
248
- });
249
- });
250
-
251
- } catch (error) {
252
- console.error(`${lc} connect failed: ${extractErrorMsg(error)}`);
253
- throw error;
254
- }
255
- }
256
-
257
- /**
258
- * Handles synchronizing messages and evolved context frames during active transaction turns.
259
- */
260
- protected handleRuntimeMessage(event: MessageEvent): void {
261
- const lc = `${this.lc}[${this.handleRuntimeMessage.name}]`;
262
- try {
263
- const msg = JSON.parse(event.data);
264
- if (logalot) { console.log(`${lc} received runtime frame: ${msg.type}`); }
265
-
266
- if (msg.type === 'sync-frame-response') {
267
- if (this.activeResolve) {
268
- const responseContext = msg.context as SyncSagaContextIbGib_V1;
269
- const resolve = this.activeResolve;
270
- this.activeResolve = undefined;
271
- this.activeReject = undefined;
272
- resolve(responseContext);
273
- }
274
- } else if (msg.type === 'domain-payload') {
275
- const payload = msg.ibGib as IbGib_V1;
276
- this.payloadIbGibsDomainReceived$.next(payload);
277
- }
278
- } catch (error) {
279
- console.error(`${lc} failed parsing runtime frame: ${extractErrorMsg(error)}`);
280
- if (this.activeReject) {
281
- this.activeReject(error);
282
- }
283
- }
284
- }
285
-
286
- /**
287
- * Serializes the transaction context and payload down the active WebSocket connection.
288
- */
289
- protected override async sendContextRequest(context: SyncSagaContextIbGib_V1): Promise<SyncSagaContextIbGib_V1 | undefined> {
290
- const lc = `${this.lc}[${this.sendContextRequest.name}]`;
291
- try {
292
- if (!this.ws || this.ws.readyState !== WebSocket.OPEN) {
293
- throw new Error(`WebSocket is not connected or open (E: a3b2c1d0e9f8e7d6c5b4a3f2e1d0c915)`);
294
- }
295
-
296
- // 1. Push any outgoing payload domain ibgibs down the pipe
297
- const domainPayloads = context.payloadIbGibsDomain ?? [];
298
- for (const ibGib of domainPayloads) {
299
- this.ws.send(JSON.stringify({
300
- type: 'domain-payload',
301
- ibGib
302
- }));
303
- }
304
-
305
- // 2. Transmit the synchronizing transaction context
306
- return new Promise<SyncSagaContextIbGib_V1 | undefined>((resolve, reject) => {
307
- this.activeResolve = resolve;
308
- this.activeReject = reject;
309
-
310
- this.ws!.send(JSON.stringify({
311
- type: 'sync-frame',
312
- context
313
- }));
314
- });
315
-
316
- } catch (error) {
317
- console.error(`${lc} sendContextRequest failed: ${extractErrorMsg(error)}`);
318
- throw error;
319
- }
320
- }
321
- }