orez 0.2.10 → 0.2.11

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/src/cli.ts CHANGED
@@ -1107,6 +1107,7 @@ const main = defineCommand({
1107
1107
  const {
1108
1108
  config,
1109
1109
  stop,
1110
+ instances,
1110
1111
  zeroEnv,
1111
1112
  logStore,
1112
1113
  httpLog,
@@ -1162,6 +1163,7 @@ const main = defineCommand({
1162
1163
  zeroEnv,
1163
1164
  actions: { restartZero, stopZero, resetZero, resetZeroFull },
1164
1165
  startTime: Date.now(),
1166
+ db: instances,
1165
1167
  })
1166
1168
  log.orez(`admin: ${url(`http://localhost:${config.adminPort}`)}`)
1167
1169
  }
@@ -42,6 +42,7 @@ export function orezPlugin(options?: OrezPluginOptions): Plugin {
42
42
  resetZeroFull: result.resetZeroFull,
43
43
  },
44
44
  startTime: Date.now(),
45
+ db: result.instances,
45
46
  })
46
47
  }
47
48
 
@@ -100,8 +100,32 @@ export function messagePortToWs(port: MessagePort): WsCompatible {
100
100
  }
101
101
 
102
102
  // forward port messages → ws 'message' events
103
+ // filter out control messages from sync-ws-patch.js (__close, __open)
103
104
  port.onmessage = (event: MessageEvent) => {
104
- emit('message', { data: event.data })
105
+ const data = event.data
106
+ // control messages from sync-ws-patch.js — handle as close/open events
107
+ if (
108
+ data &&
109
+ typeof data === 'object' &&
110
+ !ArrayBuffer.isView(data) &&
111
+ !(data instanceof ArrayBuffer)
112
+ ) {
113
+ if (data.__close) {
114
+ closed = true
115
+ port.close()
116
+ emit('close', {
117
+ code: data.code ?? 1000,
118
+ reason: data.reason ?? '',
119
+ wasClean: true,
120
+ })
121
+ return
122
+ }
123
+ if (data.__open) {
124
+ // already open, ignore
125
+ return
126
+ }
127
+ }
128
+ emit('message', { data })
105
129
  }
106
130
 
107
131
  port.onmessageerror = (event: MessageEvent) => {