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.
- package/README.md +4 -8
- package/dist/admin/http-proxy.d.ts +31 -0
- package/dist/admin/http-proxy.d.ts.map +1 -0
- package/dist/admin/http-proxy.js +140 -0
- package/dist/admin/http-proxy.js.map +1 -0
- package/dist/admin/log-store.d.ts +22 -0
- package/dist/admin/log-store.d.ts.map +1 -0
- package/dist/admin/log-store.js +86 -0
- package/dist/admin/log-store.js.map +1 -0
- package/dist/admin/server.d.ts +19 -0
- package/dist/admin/server.d.ts.map +1 -0
- package/dist/admin/server.js +110 -0
- package/dist/admin/server.js.map +1 -0
- package/dist/admin/ui.d.ts +2 -0
- package/dist/admin/ui.d.ts.map +1 -0
- package/dist/admin/ui.js +683 -0
- package/dist/admin/ui.js.map +1 -0
- package/dist/cli.js +48 -1
- package/dist/cli.js.map +1 -1
- package/dist/config.d.ts +4 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +4 -0
- package/dist/config.js.map +1 -1
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +211 -20
- package/dist/index.js.map +1 -1
- package/dist/log.d.ts +9 -0
- package/dist/log.d.ts.map +1 -1
- package/dist/log.js +24 -1
- package/dist/log.js.map +1 -1
- package/dist/pg-proxy.d.ts.map +1 -1
- package/dist/pg-proxy.js +19 -4
- package/dist/pg-proxy.js.map +1 -1
- package/dist/pglite-manager.d.ts +1 -0
- package/dist/pglite-manager.d.ts.map +1 -1
- package/dist/pglite-manager.js +8 -2
- package/dist/pglite-manager.js.map +1 -1
- package/dist/replication/change-tracker.d.ts.map +1 -1
- package/dist/replication/change-tracker.js +16 -29
- package/dist/replication/change-tracker.js.map +1 -1
- package/dist/replication/handler.d.ts.map +1 -1
- package/dist/replication/handler.js +42 -7
- package/dist/replication/handler.js.map +1 -1
- package/dist/vite-plugin.d.ts +3 -0
- package/dist/vite-plugin.d.ts.map +1 -1
- package/dist/vite-plugin.js +24 -0
- package/dist/vite-plugin.js.map +1 -1
- package/package.json +4 -2
- package/src/admin/http-proxy.ts +190 -0
- package/src/admin/log-store.ts +114 -0
- package/src/admin/server.ts +152 -0
- package/src/admin/ui.ts +684 -0
- package/src/cli.ts +62 -13
- package/src/config.ts +8 -0
- package/src/index.ts +239 -20
- package/src/log.ts +25 -1
- package/src/pg-proxy.ts +27 -5
- package/src/pglite-manager.ts +9 -2
- package/src/replication/change-tracker.ts +20 -30
- package/src/replication/handler.ts +54 -8
- package/src/replication/pgoutput-encoder.test.ts +217 -0
- package/src/replication/zero-compat.test.ts +232 -1
- package/src/shim/hooks.mjs +33 -0
- package/src/vite-plugin.ts +28 -0
package/src/shim/hooks.mjs
CHANGED
|
@@ -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'); };
|
package/src/vite-plugin.ts
CHANGED
|
@@ -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()
|