orez 0.0.46 → 0.0.48

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 (65) hide show
  1. package/README.md +4 -8
  2. package/dist/admin/http-proxy.d.ts +31 -0
  3. package/dist/admin/http-proxy.d.ts.map +1 -0
  4. package/dist/admin/http-proxy.js +140 -0
  5. package/dist/admin/http-proxy.js.map +1 -0
  6. package/dist/admin/log-store.d.ts +22 -0
  7. package/dist/admin/log-store.d.ts.map +1 -0
  8. package/dist/admin/log-store.js +86 -0
  9. package/dist/admin/log-store.js.map +1 -0
  10. package/dist/admin/server.d.ts +19 -0
  11. package/dist/admin/server.d.ts.map +1 -0
  12. package/dist/admin/server.js +110 -0
  13. package/dist/admin/server.js.map +1 -0
  14. package/dist/admin/ui.d.ts +2 -0
  15. package/dist/admin/ui.d.ts.map +1 -0
  16. package/dist/admin/ui.js +683 -0
  17. package/dist/admin/ui.js.map +1 -0
  18. package/dist/cli.js +48 -1
  19. package/dist/cli.js.map +1 -1
  20. package/dist/config.d.ts +4 -0
  21. package/dist/config.d.ts.map +1 -1
  22. package/dist/config.js +4 -0
  23. package/dist/config.js.map +1 -1
  24. package/dist/index.d.ts +9 -0
  25. package/dist/index.d.ts.map +1 -1
  26. package/dist/index.js +211 -20
  27. package/dist/index.js.map +1 -1
  28. package/dist/log.d.ts +9 -0
  29. package/dist/log.d.ts.map +1 -1
  30. package/dist/log.js +24 -1
  31. package/dist/log.js.map +1 -1
  32. package/dist/pg-proxy.d.ts.map +1 -1
  33. package/dist/pg-proxy.js +19 -4
  34. package/dist/pg-proxy.js.map +1 -1
  35. package/dist/pglite-manager.d.ts +1 -0
  36. package/dist/pglite-manager.d.ts.map +1 -1
  37. package/dist/pglite-manager.js +8 -2
  38. package/dist/pglite-manager.js.map +1 -1
  39. package/dist/replication/change-tracker.d.ts.map +1 -1
  40. package/dist/replication/change-tracker.js +16 -29
  41. package/dist/replication/change-tracker.js.map +1 -1
  42. package/dist/replication/handler.d.ts.map +1 -1
  43. package/dist/replication/handler.js +42 -7
  44. package/dist/replication/handler.js.map +1 -1
  45. package/dist/vite-plugin.d.ts +3 -0
  46. package/dist/vite-plugin.d.ts.map +1 -1
  47. package/dist/vite-plugin.js +24 -0
  48. package/dist/vite-plugin.js.map +1 -1
  49. package/package.json +4 -2
  50. package/src/admin/http-proxy.ts +190 -0
  51. package/src/admin/log-store.ts +114 -0
  52. package/src/admin/server.ts +152 -0
  53. package/src/admin/ui.ts +684 -0
  54. package/src/cli.ts +62 -13
  55. package/src/config.ts +8 -0
  56. package/src/index.ts +239 -20
  57. package/src/log.ts +25 -1
  58. package/src/pg-proxy.ts +27 -5
  59. package/src/pglite-manager.ts +9 -2
  60. package/src/replication/change-tracker.ts +20 -30
  61. package/src/replication/handler.ts +54 -8
  62. package/src/replication/pgoutput-encoder.test.ts +217 -0
  63. package/src/replication/zero-compat.test.ts +232 -1
  64. package/src/shim/hooks.mjs +33 -0
  65. package/src/vite-plugin.ts +28 -0
@@ -20,6 +20,13 @@ export function load(url, context, nextLoad) {
20
20
  format: 'module',
21
21
  shortCircuit: true,
22
22
  source: `
23
+ // catch uncaught exceptions from bedrock-sqlite wasm clearly
24
+ process.on('uncaughtException', (err) => {
25
+ console.error('[orez-shim] UNCAUGHT EXCEPTION:', err?.message || err);
26
+ console.error('[orez-shim] code:', err?.code, 'name:', err?.name);
27
+ console.error('[orez-shim] stack:', err?.stack?.split('\\n').slice(0, 5).join('\\n'));
28
+ process.exit(1);
29
+ });
23
30
  import { createRequire } from 'node:module';
24
31
  const require = createRequire('${BEDROCK_PATH}');
25
32
  const mod = require('${BEDROCK_PATH}');
@@ -34,6 +41,32 @@ Database.prototype = OrigDatabase.prototype;
34
41
  Database.prototype.constructor = Database;
35
42
  Object.keys(OrigDatabase).forEach(k => { Database[k] = OrigDatabase[k]; });
36
43
  Database.prototype.unsafeMode = function() { return this; };
44
+ // wrap pragma to skip optimize (corrupts wasm vfs) and swallow sqlite errors
45
+ const origPragma = OrigDatabase.prototype.pragma;
46
+ Database.prototype.pragma = function(str, opts) {
47
+ if (str && str.trim().toLowerCase().startsWith('optimize')) return [];
48
+ try { return origPragma.call(this, str, opts); }
49
+ catch(e) { if (e && (e.code === 'SQLITE_CORRUPT' || e.code === 'SQLITE_IOERR')) return []; throw e; }
50
+ };
51
+ // wrap close to swallow wasm errors during shutdown
52
+ const origClose = OrigDatabase.prototype.close;
53
+ Database.prototype.close = function() {
54
+ try { return origClose.call(this); }
55
+ catch(e) { console.error('[orez-shim] close error (swallowed):', e?.message || e); }
56
+ };
57
+ // trace writes to _zero.changeLog and _zero.replicationState to debug view-syncer
58
+ const origRun = OrigDatabase.prototype.run;
59
+ Database.prototype.run = function(sql, ...args) {
60
+ if (typeof sql === 'string') {
61
+ if (sql.includes('_zero.changeLog')) {
62
+ console.info('[orez-shim] changeLog write:', sql.slice(0, 120), args.length ? JSON.stringify(args[0]).slice(0, 80) : '');
63
+ }
64
+ if (sql.includes('_zero.replicationState') && (sql.includes('UPDATE') || sql.includes('INSERT'))) {
65
+ console.info('[orez-shim] replicationState update:', sql.slice(0, 120), args.length ? JSON.stringify(args[0]).slice(0, 80) : '');
66
+ }
67
+ }
68
+ return origRun.call(this, sql, ...args);
69
+ };
37
70
  if (!Database.prototype.defaultSafeIntegers) Database.prototype.defaultSafeIntegers = function() { return this; };
38
71
  if (!Database.prototype.serialize) Database.prototype.serialize = function() { throw new Error('not supported in wasm'); };
39
72
  if (!Database.prototype.backup) Database.prototype.backup = function() { throw new Error('not supported in wasm'); };
@@ -7,16 +7,21 @@ import type { Plugin } from 'vite'
7
7
  export interface OrezPluginOptions extends Partial<ZeroLiteConfig> {
8
8
  s3?: boolean
9
9
  s3Port?: number
10
+ admin?: boolean
11
+ adminPort?: number
12
+ adminLogs?: boolean
10
13
  }
11
14
 
12
15
  export default function orez(options?: OrezPluginOptions): Plugin {
13
16
  let stop: (() => Promise<void>) | null = null
14
17
  let s3Server: Server | null = null
18
+ let adminServer: Server | null = null
15
19
 
16
20
  return {
17
21
  name: 'orez',
18
22
 
19
23
  async configureServer(server) {
24
+ const startTime = Date.now()
20
25
  const result = await startZeroLite(options)
21
26
  stop = result.stop
22
27
 
@@ -28,7 +33,30 @@ export default function orez(options?: OrezPluginOptions): Plugin {
28
33
  })
29
34
  }
30
35
 
36
+ if (options?.admin && result.logStore) {
37
+ const { findPort } = await import('./port.js')
38
+ const { log } = await import('./log.js')
39
+ const adminPort = options.adminPort || result.config.zeroPort + 2
40
+ const resolvedPort = await findPort(adminPort)
41
+ const { startAdminServer } = await import('./admin/server.js')
42
+ adminServer = await startAdminServer({
43
+ port: resolvedPort,
44
+ logStore: result.logStore,
45
+ config: result.config,
46
+ zeroEnv: result.zeroEnv,
47
+ actions: result.actions,
48
+ startTime,
49
+ httpLog: result.httpLogStore || undefined,
50
+ })
51
+ log.orez(`admin: http://127.0.0.1:${resolvedPort}`)
52
+ if (result.config.adminLogs) {
53
+ const { resolve } = await import('node:path')
54
+ log.orez(`logs: ${resolve(result.config.dataDir, 'logs', 'orez.log')}`)
55
+ }
56
+ }
57
+
31
58
  server.httpServer?.on('close', async () => {
59
+ adminServer?.close()
32
60
  s3Server?.close()
33
61
  if (stop) {
34
62
  await stop()