over-zero 0.0.62 → 0.0.63
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/dist/cjs/cli.cjs +405 -0
- package/dist/cjs/cli.js +397 -0
- package/dist/cjs/cli.js.map +6 -0
- package/dist/cjs/cli.native.js +505 -0
- package/dist/cjs/cli.native.js.map +1 -0
- package/dist/cjs/constants.cjs +28 -0
- package/dist/cjs/constants.js +22 -0
- package/dist/cjs/constants.js.map +6 -0
- package/dist/cjs/constants.native.js +31 -0
- package/dist/cjs/constants.native.js.map +1 -0
- package/dist/cjs/createPermissions.cjs +82 -0
- package/dist/cjs/createPermissions.js +77 -0
- package/dist/cjs/createPermissions.js.map +6 -0
- package/dist/cjs/createPermissions.native.js +107 -0
- package/dist/cjs/createPermissions.native.js.map +1 -0
- package/dist/cjs/createUseQuery.cjs +59 -0
- package/dist/cjs/createUseQuery.js +34 -0
- package/dist/cjs/createUseQuery.js.map +6 -0
- package/dist/cjs/createUseQuery.native.js +70 -0
- package/dist/cjs/createUseQuery.native.js.map +1 -0
- package/dist/cjs/createZeroClient.cjs +162 -0
- package/dist/cjs/createZeroClient.js +126 -0
- package/dist/cjs/createZeroClient.js.map +6 -0
- package/dist/cjs/createZeroClient.native.js +214 -0
- package/dist/cjs/createZeroClient.native.js.map +1 -0
- package/dist/cjs/createZeroServer.cjs +148 -0
- package/dist/cjs/createZeroServer.js +126 -0
- package/dist/cjs/createZeroServer.js.map +6 -0
- package/dist/cjs/createZeroServer.native.js +170 -0
- package/dist/cjs/createZeroServer.native.js.map +1 -0
- package/dist/cjs/helpers/batchQuery.cjs +49 -0
- package/dist/cjs/helpers/batchQuery.js +38 -0
- package/dist/cjs/helpers/batchQuery.js.map +6 -0
- package/dist/cjs/helpers/batchQuery.native.js +49 -0
- package/dist/cjs/helpers/batchQuery.native.js.map +1 -0
- package/dist/cjs/helpers/createMutators.cjs +90 -0
- package/dist/cjs/helpers/createMutators.js +85 -0
- package/dist/cjs/helpers/createMutators.js.map +6 -0
- package/dist/cjs/helpers/createMutators.native.js +132 -0
- package/dist/cjs/helpers/createMutators.native.js.map +1 -0
- package/dist/cjs/helpers/didRunPermissionCheck.cjs +30 -0
- package/dist/cjs/helpers/didRunPermissionCheck.js +26 -0
- package/dist/cjs/helpers/didRunPermissionCheck.js.map +6 -0
- package/dist/cjs/helpers/didRunPermissionCheck.native.js +39 -0
- package/dist/cjs/helpers/didRunPermissionCheck.native.js.map +1 -0
- package/dist/cjs/helpers/ensureLoggedIn.cjs +33 -0
- package/dist/cjs/helpers/ensureLoggedIn.js +25 -0
- package/dist/cjs/helpers/ensureLoggedIn.js.map +6 -0
- package/dist/cjs/helpers/ensureLoggedIn.native.js +36 -0
- package/dist/cjs/helpers/ensureLoggedIn.native.js.map +1 -0
- package/dist/cjs/helpers/getQueryOrMutatorAuthData.cjs +30 -0
- package/dist/cjs/helpers/getQueryOrMutatorAuthData.js +24 -0
- package/dist/cjs/helpers/getQueryOrMutatorAuthData.js.map +6 -0
- package/dist/cjs/helpers/getQueryOrMutatorAuthData.native.js +33 -0
- package/dist/cjs/helpers/getQueryOrMutatorAuthData.native.js.map +1 -0
- package/dist/cjs/helpers/mutatorContext.cjs +40 -0
- package/dist/cjs/helpers/mutatorContext.js +36 -0
- package/dist/cjs/helpers/mutatorContext.js.map +6 -0
- package/dist/cjs/helpers/mutatorContext.native.js +43 -0
- package/dist/cjs/helpers/mutatorContext.native.js.map +1 -0
- package/dist/cjs/helpers/prettyFormatZeroQuery.cjs +107 -0
- package/dist/cjs/helpers/prettyFormatZeroQuery.js +92 -0
- package/dist/cjs/helpers/prettyFormatZeroQuery.js.map +6 -0
- package/dist/cjs/helpers/prettyFormatZeroQuery.native.js +119 -0
- package/dist/cjs/helpers/prettyFormatZeroQuery.native.js.map +1 -0
- package/dist/cjs/helpers/useZeroDebug.cjs +68 -0
- package/dist/cjs/helpers/useZeroDebug.js +49 -0
- package/dist/cjs/helpers/useZeroDebug.js.map +6 -0
- package/dist/cjs/helpers/useZeroDebug.native.js +81 -0
- package/dist/cjs/helpers/useZeroDebug.native.js.map +1 -0
- package/dist/cjs/index.cjs +34 -876
- package/dist/cjs/index.js +35 -0
- package/dist/cjs/index.js.map +6 -0
- package/dist/cjs/index.native.js +45 -0
- package/dist/cjs/index.native.js.map +1 -0
- package/dist/cjs/mutations.cjs +51 -0
- package/dist/cjs/mutations.js +44 -0
- package/dist/cjs/mutations.js.map +6 -0
- package/dist/cjs/mutations.native.js +56 -0
- package/dist/cjs/mutations.native.js.map +1 -0
- package/dist/cjs/queryRegistry.cjs +33 -0
- package/dist/cjs/queryRegistry.js +28 -0
- package/dist/cjs/queryRegistry.js.map +6 -0
- package/dist/cjs/queryRegistry.native.js +36 -0
- package/dist/cjs/queryRegistry.native.js.map +1 -0
- package/dist/cjs/resolveQuery.cjs +41 -0
- package/dist/cjs/resolveQuery.js +40 -0
- package/dist/cjs/resolveQuery.js.map +6 -0
- package/dist/cjs/resolveQuery.native.js +46 -0
- package/dist/cjs/resolveQuery.native.js.map +1 -0
- package/dist/cjs/run.cjs +48 -0
- package/dist/cjs/run.js +37 -0
- package/dist/cjs/run.js.map +6 -0
- package/dist/cjs/run.native.js +52 -0
- package/dist/cjs/run.native.js.map +1 -0
- package/dist/cjs/server.cjs +11 -531
- package/dist/cjs/server.js +15 -0
- package/dist/cjs/server.js.map +6 -0
- package/dist/cjs/server.native.js +21 -0
- package/dist/cjs/server.native.js.map +1 -0
- package/dist/cjs/serverWhere.cjs +29 -0
- package/dist/cjs/serverWhere.js +24 -0
- package/dist/cjs/serverWhere.js.map +6 -0
- package/dist/cjs/serverWhere.native.js +32 -0
- package/dist/cjs/serverWhere.native.js.map +1 -0
- package/dist/cjs/state.cjs +49 -0
- package/dist/cjs/state.js +37 -0
- package/dist/cjs/state.js.map +6 -0
- package/dist/cjs/state.native.js +54 -0
- package/dist/cjs/state.native.js.map +1 -0
- package/dist/cjs/types.cjs +16 -0
- package/dist/cjs/types.js +14 -0
- package/dist/cjs/types.js.map +6 -0
- package/dist/cjs/types.native.js +19 -0
- package/dist/cjs/types.native.js.map +1 -0
- package/dist/cjs/where.cjs +41 -0
- package/dist/cjs/where.js +35 -0
- package/dist/cjs/where.js.map +6 -0
- package/dist/cjs/where.native.js +46 -0
- package/dist/cjs/where.native.js.map +1 -0
- package/dist/cjs/zeroRunner.cjs +34 -0
- package/dist/cjs/zeroRunner.js +32 -0
- package/dist/cjs/zeroRunner.js.map +6 -0
- package/dist/cjs/zeroRunner.native.js +37 -0
- package/dist/cjs/zeroRunner.native.js.map +1 -0
- package/dist/cjs/zql.cjs +31 -0
- package/dist/cjs/zql.js +26 -0
- package/dist/cjs/zql.js.map +6 -0
- package/dist/cjs/zql.native.js +35 -0
- package/dist/cjs/zql.native.js.map +1 -0
- package/dist/esm/cli.js +383 -0
- package/dist/esm/cli.js.map +6 -0
- package/dist/esm/cli.mjs +384 -0
- package/dist/esm/cli.mjs.map +1 -0
- package/dist/esm/cli.native.js +481 -0
- package/dist/esm/cli.native.js.map +1 -0
- package/dist/esm/constants.js +6 -0
- package/dist/esm/constants.js.map +6 -0
- package/dist/esm/constants.mjs +4 -0
- package/dist/esm/constants.mjs.map +1 -0
- package/dist/esm/constants.native.js +4 -0
- package/dist/esm/constants.native.js.map +1 -0
- package/dist/esm/createPermissions.js +66 -0
- package/dist/esm/createPermissions.js.map +6 -0
- package/dist/esm/createPermissions.mjs +59 -0
- package/dist/esm/createPermissions.mjs.map +1 -0
- package/dist/esm/createPermissions.native.js +81 -0
- package/dist/esm/createPermissions.native.js.map +1 -0
- package/dist/esm/createUseQuery.js +21 -0
- package/dist/esm/createUseQuery.js.map +6 -0
- package/dist/esm/createUseQuery.mjs +36 -0
- package/dist/esm/createUseQuery.mjs.map +1 -0
- package/dist/esm/createUseQuery.native.js +44 -0
- package/dist/esm/createUseQuery.native.js.map +1 -0
- package/dist/esm/createZeroClient.js +135 -0
- package/dist/esm/createZeroClient.js.map +6 -0
- package/dist/esm/createZeroClient.mjs +139 -0
- package/dist/esm/createZeroClient.mjs.map +1 -0
- package/dist/esm/createZeroClient.native.js +188 -0
- package/dist/esm/createZeroClient.native.js.map +1 -0
- package/dist/esm/createZeroServer.js +121 -0
- package/dist/esm/createZeroServer.js.map +6 -0
- package/dist/esm/createZeroServer.mjs +125 -0
- package/dist/esm/createZeroServer.mjs.map +1 -0
- package/dist/esm/createZeroServer.native.js +144 -0
- package/dist/esm/createZeroServer.native.js.map +1 -0
- package/dist/esm/helpers/batchQuery.js +22 -0
- package/dist/esm/helpers/batchQuery.js.map +6 -0
- package/dist/esm/helpers/batchQuery.mjs +26 -0
- package/dist/esm/helpers/batchQuery.mjs.map +1 -0
- package/dist/esm/helpers/batchQuery.native.js +23 -0
- package/dist/esm/helpers/batchQuery.native.js.map +1 -0
- package/dist/esm/helpers/createMutators.js +71 -0
- package/dist/esm/helpers/createMutators.js.map +6 -0
- package/dist/esm/helpers/createMutators.mjs +67 -0
- package/dist/esm/helpers/createMutators.mjs.map +1 -0
- package/dist/esm/helpers/createMutators.native.js +106 -0
- package/dist/esm/helpers/createMutators.native.js.map +1 -0
- package/dist/esm/helpers/didRunPermissionCheck.js +10 -0
- package/dist/esm/helpers/didRunPermissionCheck.js.map +6 -0
- package/dist/esm/helpers/didRunPermissionCheck.mjs +6 -0
- package/dist/esm/helpers/didRunPermissionCheck.mjs.map +1 -0
- package/dist/esm/helpers/didRunPermissionCheck.native.js +12 -0
- package/dist/esm/helpers/didRunPermissionCheck.native.js.map +1 -0
- package/dist/esm/helpers/ensureLoggedIn.js +10 -0
- package/dist/esm/helpers/ensureLoggedIn.js.map +6 -0
- package/dist/esm/helpers/ensureLoggedIn.mjs +10 -0
- package/dist/esm/helpers/ensureLoggedIn.mjs.map +1 -0
- package/dist/esm/helpers/ensureLoggedIn.native.js +10 -0
- package/dist/esm/helpers/ensureLoggedIn.native.js.map +1 -0
- package/dist/esm/helpers/getQueryOrMutatorAuthData.js +9 -0
- package/dist/esm/helpers/getQueryOrMutatorAuthData.js.map +6 -0
- package/dist/esm/helpers/getQueryOrMutatorAuthData.mjs +7 -0
- package/dist/esm/helpers/getQueryOrMutatorAuthData.mjs.map +1 -0
- package/dist/esm/helpers/getQueryOrMutatorAuthData.native.js +7 -0
- package/dist/esm/helpers/getQueryOrMutatorAuthData.native.js.map +1 -0
- package/dist/esm/helpers/mutatorContext.js +20 -0
- package/dist/esm/helpers/mutatorContext.js.map +6 -0
- package/dist/esm/helpers/mutatorContext.mjs +15 -0
- package/dist/esm/helpers/mutatorContext.mjs.map +1 -0
- package/dist/esm/helpers/mutatorContext.native.js +15 -0
- package/dist/esm/helpers/mutatorContext.native.js.map +1 -0
- package/dist/esm/helpers/prettyFormatZeroQuery.js +76 -0
- package/dist/esm/helpers/prettyFormatZeroQuery.js.map +6 -0
- package/dist/esm/helpers/prettyFormatZeroQuery.mjs +84 -0
- package/dist/esm/helpers/prettyFormatZeroQuery.mjs.map +1 -0
- package/dist/esm/helpers/prettyFormatZeroQuery.native.js +93 -0
- package/dist/esm/helpers/prettyFormatZeroQuery.native.js.map +1 -0
- package/dist/esm/helpers/useZeroDebug.js +35 -0
- package/dist/esm/helpers/useZeroDebug.js.map +6 -0
- package/dist/esm/helpers/useZeroDebug.mjs +45 -0
- package/dist/esm/helpers/useZeroDebug.mjs.map +1 -0
- package/dist/esm/helpers/useZeroDebug.native.js +55 -0
- package/dist/esm/helpers/useZeroDebug.native.js.map +1 -0
- package/dist/esm/index.js +20 -0
- package/dist/esm/index.js.map +6 -0
- package/dist/esm/index.mjs +17 -43
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/index.native.js +17 -0
- package/dist/esm/index.native.js.map +1 -0
- package/dist/esm/mutations.js +28 -0
- package/dist/esm/mutations.js.map +6 -0
- package/dist/esm/mutations.mjs +28 -0
- package/dist/esm/mutations.mjs.map +1 -0
- package/dist/esm/mutations.native.js +30 -0
- package/dist/esm/mutations.native.js.map +1 -0
- package/dist/esm/queryRegistry.js +12 -0
- package/dist/esm/queryRegistry.js.map +6 -0
- package/dist/esm/queryRegistry.mjs +9 -0
- package/dist/esm/queryRegistry.mjs.map +1 -0
- package/dist/esm/queryRegistry.native.js +9 -0
- package/dist/esm/queryRegistry.native.js.map +1 -0
- package/dist/esm/resolveQuery.js +24 -0
- package/dist/esm/resolveQuery.js.map +6 -0
- package/dist/esm/resolveQuery.mjs +18 -0
- package/dist/esm/resolveQuery.mjs.map +1 -0
- package/dist/esm/resolveQuery.native.js +20 -0
- package/dist/esm/resolveQuery.native.js.map +1 -0
- package/dist/esm/run.js +22 -0
- package/dist/esm/run.js.map +6 -0
- package/dist/esm/run.mjs +24 -0
- package/dist/esm/run.mjs.map +1 -0
- package/dist/esm/run.native.js +25 -0
- package/dist/esm/run.native.js.map +1 -0
- package/dist/esm/server.js +2 -0
- package/dist/esm/server.js.map +6 -0
- package/dist/esm/server.mjs +2 -511
- package/dist/esm/server.mjs.map +1 -1
- package/dist/esm/server.native.js +2 -0
- package/dist/esm/server.native.js.map +1 -0
- package/dist/esm/serverWhere.js +8 -0
- package/dist/esm/serverWhere.js.map +6 -0
- package/dist/esm/serverWhere.mjs +6 -0
- package/dist/esm/serverWhere.mjs.map +1 -0
- package/dist/esm/serverWhere.native.js +6 -0
- package/dist/esm/serverWhere.native.js.map +1 -0
- package/dist/esm/state.js +21 -0
- package/dist/esm/state.js.map +6 -0
- package/dist/esm/state.mjs +22 -0
- package/dist/esm/state.mjs.map +1 -0
- package/dist/esm/state.native.js +24 -0
- package/dist/esm/state.native.js.map +1 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm/types.js.map +6 -0
- package/dist/esm/types.mjs +2 -0
- package/dist/esm/types.mjs.map +1 -0
- package/dist/esm/types.native.js +2 -0
- package/dist/esm/types.native.js.map +1 -0
- package/dist/esm/where.js +20 -0
- package/dist/esm/where.js.map +6 -0
- package/dist/esm/where.mjs +17 -0
- package/dist/esm/where.mjs.map +1 -0
- package/dist/esm/where.native.js +19 -0
- package/dist/esm/where.native.js.map +1 -0
- package/dist/esm/zeroRunner.js +16 -0
- package/dist/esm/zeroRunner.js.map +6 -0
- package/dist/esm/zeroRunner.mjs +10 -0
- package/dist/esm/zeroRunner.mjs.map +1 -0
- package/dist/esm/zeroRunner.native.js +10 -0
- package/dist/esm/zeroRunner.native.js.map +1 -0
- package/dist/esm/zql.js +10 -0
- package/dist/esm/zql.js.map +6 -0
- package/dist/esm/zql.mjs +8 -0
- package/dist/esm/zql.mjs.map +1 -0
- package/dist/esm/zql.native.js +9 -0
- package/dist/esm/zql.native.js.map +1 -0
- package/package.json +31 -23
- package/readme.md +14 -43
- package/src/constants.native.ts +3 -0
- package/src/constants.ts +3 -0
- package/src/helpers/createMutators.ts +1 -1
- package/src/where.ts +3 -7
- package/types/cli.d.ts +3 -0
- package/types/cli.d.ts.map +1 -0
- package/types/constants.d.ts +3 -0
- package/types/constants.d.ts.map +1 -0
- package/types/constants.native.d.ts +3 -0
- package/types/constants.native.d.ts.map +1 -0
- package/types/createPermissions.d.ts +10 -0
- package/types/createPermissions.d.ts.map +1 -0
- package/types/createUseQuery.d.ts +20 -0
- package/types/createUseQuery.d.ts.map +1 -0
- package/types/createZeroClient.d.ts +35 -0
- package/types/createZeroClient.d.ts.map +1 -0
- package/{dist/esm/server.d.ts → types/createZeroServer.d.ts} +16 -83
- package/types/createZeroServer.d.ts.map +1 -0
- package/types/helpers/batchQuery.d.ts +7 -0
- package/types/helpers/batchQuery.d.ts.map +1 -0
- package/types/helpers/createMutators.d.ts +10 -0
- package/types/helpers/createMutators.d.ts.map +1 -0
- package/types/helpers/didRunPermissionCheck.d.ts +4 -0
- package/types/helpers/didRunPermissionCheck.d.ts.map +1 -0
- package/types/helpers/ensureLoggedIn.d.ts +3 -0
- package/types/helpers/ensureLoggedIn.d.ts.map +1 -0
- package/types/helpers/getQueryOrMutatorAuthData.d.ts +3 -0
- package/types/helpers/getQueryOrMutatorAuthData.d.ts.map +1 -0
- package/types/helpers/mutatorContext.d.ts +5 -0
- package/types/helpers/mutatorContext.d.ts.map +1 -0
- package/types/helpers/prettyFormatZeroQuery.d.ts +3 -0
- package/types/helpers/prettyFormatZeroQuery.d.ts.map +1 -0
- package/types/helpers/useZeroDebug.d.ts +3 -0
- package/types/helpers/useZeroDebug.d.ts.map +1 -0
- package/types/index.d.ts +17 -0
- package/types/index.d.ts.map +1 -0
- package/types/mutations.d.ts +20 -0
- package/types/mutations.d.ts.map +1 -0
- package/types/queryRegistry.d.ts +3 -0
- package/types/queryRegistry.d.ts.map +1 -0
- package/types/resolveQuery.d.ts +11 -0
- package/types/resolveQuery.d.ts.map +1 -0
- package/types/run.d.ts +7 -0
- package/types/run.d.ts.map +1 -0
- package/types/server.d.ts +2 -0
- package/types/server.d.ts.map +1 -0
- package/types/serverWhere.d.ts +5 -0
- package/types/serverWhere.d.ts.map +1 -0
- package/types/state.d.ts +8 -0
- package/types/state.d.ts.map +1 -0
- package/types/types.d.ts +78 -0
- package/types/types.d.ts.map +1 -0
- package/types/where.d.ts +6 -0
- package/types/where.d.ts.map +1 -0
- package/types/zeroRunner.d.ts +6 -0
- package/types/zeroRunner.d.ts.map +1 -0
- package/types/zql.d.ts +3 -0
- package/types/zql.d.ts.map +1 -0
- package/dist/cjs/index.cjs.map +0 -1
- package/dist/cjs/index.native.cjs +0 -884
- package/dist/cjs/index.native.cjs.map +0 -1
- package/dist/cjs/server.cjs.map +0 -1
- package/dist/esm/chunk-H7ZB7VXX.mjs +0 -852
- package/dist/esm/chunk-H7ZB7VXX.mjs.map +0 -1
- package/dist/esm/index.cjs +0 -884
- package/dist/esm/index.cjs.map +0 -1
- package/dist/esm/index.d.cts +0 -205
- package/dist/esm/index.d.ts +0 -205
- package/dist/esm/index.native.cjs +0 -884
- package/dist/esm/index.native.cjs.map +0 -1
- package/dist/esm/index.native.d.cts +0 -6
- package/dist/esm/index.native.d.ts +0 -6
- package/dist/esm/index.native.mjs +0 -43
- package/dist/esm/index.native.mjs.map +0 -1
package/dist/cjs/cli.cjs
ADDED
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf,
|
|
7
|
+
__hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __copyProps = (to, from, except, desc) => {
|
|
9
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
10
|
+
get: () => from[key],
|
|
11
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
12
|
+
});
|
|
13
|
+
return to;
|
|
14
|
+
};
|
|
15
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
16
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
17
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
18
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
19
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
21
|
+
value: mod,
|
|
22
|
+
enumerable: !0
|
|
23
|
+
}) : target, mod));
|
|
24
|
+
var import_node_fs = require("node:fs"),
|
|
25
|
+
import_node_path = require("node:path"),
|
|
26
|
+
import_model = require("@sinclair/typebox-codegen/model"),
|
|
27
|
+
import_typescript = require("@sinclair/typebox-codegen/typescript"),
|
|
28
|
+
import_citty = require("citty"),
|
|
29
|
+
ts = __toESM(require("typescript"), 1);
|
|
30
|
+
function writeFileIfChanged(filePath, content) {
|
|
31
|
+
try {
|
|
32
|
+
if ((0, import_node_fs.existsSync)(filePath) && (0, import_node_fs.readFileSync)(filePath, "utf-8") === content) return !1;
|
|
33
|
+
} catch {}
|
|
34
|
+
return (0, import_node_fs.writeFileSync)(filePath, content, "utf-8"), !0;
|
|
35
|
+
}
|
|
36
|
+
const generateQueries = (0, import_citty.defineCommand)({
|
|
37
|
+
meta: {
|
|
38
|
+
name: "generate-queries",
|
|
39
|
+
description: "Generate server-side query validators from TypeScript query functions"
|
|
40
|
+
},
|
|
41
|
+
args: {
|
|
42
|
+
dir: {
|
|
43
|
+
type: "positional",
|
|
44
|
+
description: "Directory containing query files",
|
|
45
|
+
required: !1,
|
|
46
|
+
default: "."
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
async run({
|
|
50
|
+
args
|
|
51
|
+
}) {
|
|
52
|
+
const dir = (0, import_node_path.resolve)(args.dir),
|
|
53
|
+
{
|
|
54
|
+
readdirSync: readdirSync2
|
|
55
|
+
} = await import("node:fs"),
|
|
56
|
+
files = readdirSync2(dir).filter(f => f.endsWith(".ts")),
|
|
57
|
+
allQueries = [],
|
|
58
|
+
results = await Promise.all(files.map(async file => {
|
|
59
|
+
const filePath = (0, import_node_path.resolve)(dir, file),
|
|
60
|
+
queries = [];
|
|
61
|
+
try {
|
|
62
|
+
const content = (0, import_node_fs.readFileSync)(filePath, "utf-8"),
|
|
63
|
+
sourceFile = ts.createSourceFile(filePath, content, ts.ScriptTarget.Latest, !0);
|
|
64
|
+
ts.forEachChild(sourceFile, node => {
|
|
65
|
+
if (ts.isVariableStatement(node)) {
|
|
66
|
+
if (!node.modifiers?.find(m => m.kind === ts.SyntaxKind.ExportKeyword)) return;
|
|
67
|
+
const declaration = node.declarationList.declarations[0];
|
|
68
|
+
if (!declaration || !ts.isVariableDeclaration(declaration)) return;
|
|
69
|
+
const name = declaration.name.getText(sourceFile);
|
|
70
|
+
if (declaration.initializer && ts.isArrowFunction(declaration.initializer)) {
|
|
71
|
+
const params = declaration.initializer.parameters;
|
|
72
|
+
let paramType = "void";
|
|
73
|
+
params.length > 0 && (paramType = params[0].type?.getText(sourceFile) || "unknown");
|
|
74
|
+
try {
|
|
75
|
+
const typeString = `type QueryParams = ${paramType}`,
|
|
76
|
+
model = import_typescript.TypeScriptToModel.Generate(typeString),
|
|
77
|
+
valibotCode = import_model.ModelToValibot.Generate(model);
|
|
78
|
+
queries.push({
|
|
79
|
+
name,
|
|
80
|
+
params: paramType,
|
|
81
|
+
valibotCode
|
|
82
|
+
});
|
|
83
|
+
} catch (err) {
|
|
84
|
+
console.error(`\u2717 ${name}: ${err}`);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
} catch (err) {
|
|
90
|
+
console.error(`Error processing ${file}:`, err);
|
|
91
|
+
}
|
|
92
|
+
return queries;
|
|
93
|
+
}));
|
|
94
|
+
allQueries.push(...results.flat()), console.info(`\u2713 ${allQueries.length} query validators`);
|
|
95
|
+
}
|
|
96
|
+
}),
|
|
97
|
+
generate = (0, import_citty.defineCommand)({
|
|
98
|
+
meta: {
|
|
99
|
+
name: "generate",
|
|
100
|
+
description: "Generate models, types, tables, and query validators"
|
|
101
|
+
},
|
|
102
|
+
args: {
|
|
103
|
+
dir: {
|
|
104
|
+
type: "positional",
|
|
105
|
+
description: "Base directory (defaults to src/data)",
|
|
106
|
+
required: !1,
|
|
107
|
+
default: "src/data"
|
|
108
|
+
},
|
|
109
|
+
watch: {
|
|
110
|
+
type: "boolean",
|
|
111
|
+
description: "Watch for changes and regenerate",
|
|
112
|
+
required: !1,
|
|
113
|
+
default: !1
|
|
114
|
+
},
|
|
115
|
+
after: {
|
|
116
|
+
type: "string",
|
|
117
|
+
description: "Command to run after generation completes",
|
|
118
|
+
required: !1
|
|
119
|
+
}
|
|
120
|
+
},
|
|
121
|
+
async run({
|
|
122
|
+
args
|
|
123
|
+
}) {
|
|
124
|
+
const baseDir = (0, import_node_path.resolve)(args.dir),
|
|
125
|
+
modelsDir = (0, import_node_path.resolve)(baseDir, "models"),
|
|
126
|
+
generatedDir = (0, import_node_path.resolve)(baseDir, "generated"),
|
|
127
|
+
queriesDir = (0, import_node_path.resolve)(baseDir, "queries"),
|
|
128
|
+
runGenerate = async options => {
|
|
129
|
+
const silent = options?.silent ?? !1;
|
|
130
|
+
(0, import_node_fs.existsSync)(generatedDir) || (0, import_node_fs.mkdirSync)(generatedDir, {
|
|
131
|
+
recursive: !0
|
|
132
|
+
});
|
|
133
|
+
const allModelFiles = (0, import_node_fs.readdirSync)(modelsDir).filter(f => f.endsWith(".ts")).sort(),
|
|
134
|
+
filesWithSchema = (await Promise.all(allModelFiles.map(async f => ({
|
|
135
|
+
file: f,
|
|
136
|
+
hasSchema: (0, import_node_fs.readFileSync)((0, import_node_path.resolve)(modelsDir, f), "utf-8").includes("export const schema = table(")
|
|
137
|
+
})))).filter(c => c.hasSchema).map(c => c.file),
|
|
138
|
+
[modelsOutput, typesOutput, tablesOutput, readmeOutput] = await Promise.all([Promise.resolve(generateModelsFile(allModelFiles)), Promise.resolve(generateTypesFile(filesWithSchema)), Promise.resolve(generateTablesFile(filesWithSchema)), Promise.resolve(generateReadmeFile())]),
|
|
139
|
+
filesChanged = (await Promise.all([Promise.resolve(writeFileIfChanged((0, import_node_path.resolve)(generatedDir, "models.ts"), modelsOutput)), Promise.resolve(writeFileIfChanged((0, import_node_path.resolve)(generatedDir, "types.ts"), typesOutput)), Promise.resolve(writeFileIfChanged((0, import_node_path.resolve)(generatedDir, "tables.ts"), tablesOutput)), Promise.resolve(writeFileIfChanged((0, import_node_path.resolve)(generatedDir, "README.md"), readmeOutput))])).filter(Boolean).length;
|
|
140
|
+
if (filesChanged > 0 && !silent && console.info(` \u{1F4DD} Updated ${filesChanged} file(s)`), (0, import_node_fs.existsSync)(queriesDir)) {
|
|
141
|
+
const queryFiles = (0, import_node_fs.readdirSync)(queriesDir).filter(f => f.endsWith(".ts")),
|
|
142
|
+
allQueries = (await Promise.all(queryFiles.map(async file => {
|
|
143
|
+
const filePath = (0, import_node_path.resolve)(queriesDir, file),
|
|
144
|
+
fileBaseName = (0, import_node_path.basename)(file, ".ts"),
|
|
145
|
+
queries = [];
|
|
146
|
+
try {
|
|
147
|
+
const content = (0, import_node_fs.readFileSync)(filePath, "utf-8"),
|
|
148
|
+
sourceFile = ts.createSourceFile(filePath, content, ts.ScriptTarget.Latest, !0);
|
|
149
|
+
ts.forEachChild(sourceFile, node => {
|
|
150
|
+
if (ts.isVariableStatement(node)) {
|
|
151
|
+
if (!node.modifiers?.find(m => m.kind === ts.SyntaxKind.ExportKeyword)) return;
|
|
152
|
+
const declaration = node.declarationList.declarations[0];
|
|
153
|
+
if (!declaration || !ts.isVariableDeclaration(declaration)) return;
|
|
154
|
+
const name = declaration.name.getText(sourceFile);
|
|
155
|
+
if (name === "permission") return;
|
|
156
|
+
if (declaration.initializer && ts.isArrowFunction(declaration.initializer)) {
|
|
157
|
+
const params = declaration.initializer.parameters;
|
|
158
|
+
let paramType = "void";
|
|
159
|
+
params.length > 0 && (paramType = params[0].type?.getText(sourceFile) || "unknown");
|
|
160
|
+
try {
|
|
161
|
+
const typeString = `type QueryParams = ${paramType}`,
|
|
162
|
+
model = import_typescript.TypeScriptToModel.Generate(typeString),
|
|
163
|
+
valibotCode = import_model.ModelToValibot.Generate(model);
|
|
164
|
+
queries.push({
|
|
165
|
+
name,
|
|
166
|
+
params: paramType,
|
|
167
|
+
valibotCode,
|
|
168
|
+
sourceFile: fileBaseName
|
|
169
|
+
});
|
|
170
|
+
} catch (err) {
|
|
171
|
+
console.error(`\u2717 ${name}: ${err}`);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
} catch (err) {
|
|
177
|
+
console.error(`Error processing ${file}:`, err);
|
|
178
|
+
}
|
|
179
|
+
return queries;
|
|
180
|
+
}))).flat(),
|
|
181
|
+
groupedQueriesOutput = generateGroupedQueriesFile(allQueries),
|
|
182
|
+
syncedQueriesOutput = generateSyncedQueriesFile(allQueries),
|
|
183
|
+
groupedChanged = writeFileIfChanged((0, import_node_path.resolve)(generatedDir, "groupedQueries.ts"), groupedQueriesOutput),
|
|
184
|
+
syncedChanged = writeFileIfChanged((0, import_node_path.resolve)(generatedDir, "syncedQueries.ts"), syncedQueriesOutput),
|
|
185
|
+
queryFilesChanged = (groupedChanged ? 1 : 0) + (syncedChanged ? 1 : 0),
|
|
186
|
+
totalFilesChanged = filesChanged + queryFilesChanged;
|
|
187
|
+
if (totalFilesChanged > 0 && !silent && (groupedChanged && console.info(" \u{1F4DD} Updated groupedQueries.ts"), syncedChanged && console.info(" \u{1F4DD} Updated syncedQueries.ts"), console.info(`\u2713 ${allModelFiles.length} models (${filesWithSchema.length} schemas), ${allQueries.length} queries`)), totalFilesChanged > 0 && !silent && args.after) try {
|
|
188
|
+
const {
|
|
189
|
+
execSync
|
|
190
|
+
} = await import("node:child_process");
|
|
191
|
+
execSync(args.after, {
|
|
192
|
+
stdio: "inherit"
|
|
193
|
+
});
|
|
194
|
+
} catch (err) {
|
|
195
|
+
console.error(`Error running after command: ${err}`);
|
|
196
|
+
}
|
|
197
|
+
} else if (filesChanged > 0 && !silent && console.info(`\u2713 ${allModelFiles.length} models (${filesWithSchema.length} schemas)`), filesChanged > 0 && !silent && args.after) try {
|
|
198
|
+
const {
|
|
199
|
+
execSync
|
|
200
|
+
} = await import("node:child_process");
|
|
201
|
+
execSync(args.after, {
|
|
202
|
+
stdio: "inherit"
|
|
203
|
+
});
|
|
204
|
+
} catch (err) {
|
|
205
|
+
console.error(`Error running after command: ${err}`);
|
|
206
|
+
}
|
|
207
|
+
};
|
|
208
|
+
if (await runGenerate({
|
|
209
|
+
silent: args.watch
|
|
210
|
+
}), args.watch) {
|
|
211
|
+
console.info(`\u{1F440} watching...
|
|
212
|
+
`);
|
|
213
|
+
const chokidar = await import("chokidar");
|
|
214
|
+
let debounceTimer = null;
|
|
215
|
+
const debouncedRegenerate = (path, event) => {
|
|
216
|
+
debounceTimer && clearTimeout(debounceTimer), console.info(`
|
|
217
|
+
${event} ${path}`), debounceTimer = setTimeout(() => {
|
|
218
|
+
runGenerate();
|
|
219
|
+
}, 1e3);
|
|
220
|
+
},
|
|
221
|
+
watcher = chokidar.watch([modelsDir, queriesDir], {
|
|
222
|
+
persistent: !0,
|
|
223
|
+
ignoreInitial: !0
|
|
224
|
+
});
|
|
225
|
+
watcher.on("change", path => debouncedRegenerate(path, "\u{1F4DD}")), watcher.on("add", path => debouncedRegenerate(path, "\u2795")), watcher.on("unlink", path => debouncedRegenerate(path, "\u{1F5D1}\uFE0F ")), await new Promise(() => {});
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
});
|
|
229
|
+
function generateModelsFile(modelFiles) {
|
|
230
|
+
const modelNames = modelFiles.map(f => (0, import_node_path.basename)(f, ".ts")).sort(),
|
|
231
|
+
getImportName = name => name === "user" ? "userPublic" : name,
|
|
232
|
+
imports = modelNames.map(name => `import * as ${getImportName(name)} from '../models/${name}'`).join(`
|
|
233
|
+
`),
|
|
234
|
+
modelsObj = `export const models = {
|
|
235
|
+
${[...modelNames].sort((a, b) => getImportName(a).localeCompare(getImportName(b))).map(name => ` ${getImportName(name)},`).join(`
|
|
236
|
+
`)}
|
|
237
|
+
}`;
|
|
238
|
+
return `// auto-generated by: over-zero generate
|
|
239
|
+
${imports}
|
|
240
|
+
|
|
241
|
+
${modelsObj}
|
|
242
|
+
`;
|
|
243
|
+
}
|
|
244
|
+
function generateTypesFile(modelFiles) {
|
|
245
|
+
const modelNames = modelFiles.map(f => (0, import_node_path.basename)(f, ".ts")).sort(),
|
|
246
|
+
getSchemaName = name => name === "user" ? "userPublic" : name;
|
|
247
|
+
return `import type { TableInsertRow, TableUpdateRow } from 'over-zero'
|
|
248
|
+
import type * as schema from './tables'
|
|
249
|
+
|
|
250
|
+
${modelNames.map(name => {
|
|
251
|
+
const pascalName = name.charAt(0).toUpperCase() + name.slice(1),
|
|
252
|
+
schemaName = getSchemaName(name);
|
|
253
|
+
return `export type ${pascalName} = TableInsertRow<typeof schema.${schemaName}>
|
|
254
|
+
export type ${pascalName}Update = TableUpdateRow<typeof schema.${schemaName}>`;
|
|
255
|
+
}).join(`
|
|
256
|
+
|
|
257
|
+
`)}
|
|
258
|
+
`;
|
|
259
|
+
}
|
|
260
|
+
function generateTablesFile(modelFiles) {
|
|
261
|
+
const modelNames = modelFiles.map(f => (0, import_node_path.basename)(f, ".ts")).sort(),
|
|
262
|
+
getExportName = name => name === "user" ? "userPublic" : name;
|
|
263
|
+
return `// auto-generated by: over-zero generate
|
|
264
|
+
// this is separate from models as otherwise you end up with circular types :/
|
|
265
|
+
|
|
266
|
+
${modelNames.map(name => `export { schema as ${getExportName(name)} } from '../models/${name}'`).join(`
|
|
267
|
+
`)}
|
|
268
|
+
`;
|
|
269
|
+
}
|
|
270
|
+
function generateGroupedQueriesFile(queries) {
|
|
271
|
+
return `/**
|
|
272
|
+
* auto-generated by: over-zero generate
|
|
273
|
+
*
|
|
274
|
+
* grouped query re-exports for minification-safe query identity.
|
|
275
|
+
* this file re-exports all query modules - while this breaks tree-shaking,
|
|
276
|
+
* queries are typically small and few in number even in larger apps.
|
|
277
|
+
*/
|
|
278
|
+
${[...new Set(queries.map(q => q.sourceFile))].sort().map(file => `export * as ${file} from '../queries/${file}'`).join(`
|
|
279
|
+
`)}
|
|
280
|
+
`;
|
|
281
|
+
}
|
|
282
|
+
function generateSyncedQueriesFile(queries) {
|
|
283
|
+
const queryByFile = /* @__PURE__ */new Map();
|
|
284
|
+
for (const q of queries) queryByFile.has(q.sourceFile) || queryByFile.set(q.sourceFile, []), queryByFile.get(q.sourceFile).push(q);
|
|
285
|
+
const sortedFiles = Array.from(queryByFile.keys()).sort(),
|
|
286
|
+
imports = `// auto-generated by: over-zero generate
|
|
287
|
+
// server-side query definitions with validators
|
|
288
|
+
import { defineQuery, defineQueries } from '@rocicorp/zero'
|
|
289
|
+
import * as v from 'valibot'
|
|
290
|
+
import * as Queries from './groupedQueries'
|
|
291
|
+
`,
|
|
292
|
+
namespaceDefs = sortedFiles.map(file => {
|
|
293
|
+
const queryDefs = queryByFile.get(file).sort((a, b) => a.name.localeCompare(b.name)).map(q => {
|
|
294
|
+
const lines = q.valibotCode.split(`
|
|
295
|
+
`).filter(l => l.trim()),
|
|
296
|
+
schemaLineIndex = lines.findIndex(l => l.startsWith("export const QueryParams"));
|
|
297
|
+
let validatorDef = "";
|
|
298
|
+
if (schemaLineIndex !== -1) {
|
|
299
|
+
const schemaLines = [];
|
|
300
|
+
let openBraces = 0,
|
|
301
|
+
started = !1;
|
|
302
|
+
for (let i = schemaLineIndex; i < lines.length; i++) {
|
|
303
|
+
const line = lines[i],
|
|
304
|
+
cleaned = started ? line : line.replace("export const QueryParams = ", "");
|
|
305
|
+
if (schemaLines.push(cleaned), started = !0, openBraces += (cleaned.match(/\{/g) || []).length, openBraces -= (cleaned.match(/\}/g) || []).length, openBraces += (cleaned.match(/\(/g) || []).length, openBraces -= (cleaned.match(/\)/g) || []).length, openBraces === 0 && schemaLines.length > 0) break;
|
|
306
|
+
}
|
|
307
|
+
validatorDef = schemaLines.join(`
|
|
308
|
+
`);
|
|
309
|
+
}
|
|
310
|
+
if (q.params === "void" || !validatorDef) return ` ${q.name}: defineQuery(() => Queries.${file}.${q.name}()),`;
|
|
311
|
+
const indentedValidator = validatorDef.split(`
|
|
312
|
+
`).map((line, i) => i === 0 ? line : ` ${line}`).join(`
|
|
313
|
+
`);
|
|
314
|
+
return ` ${q.name}: defineQuery(
|
|
315
|
+
${indentedValidator},
|
|
316
|
+
({ args }) => Queries.${file}.${q.name}(args)
|
|
317
|
+
),`;
|
|
318
|
+
}).join(`
|
|
319
|
+
`);
|
|
320
|
+
return `const ${file} = {
|
|
321
|
+
${queryDefs}
|
|
322
|
+
}`;
|
|
323
|
+
}).join(`
|
|
324
|
+
|
|
325
|
+
`),
|
|
326
|
+
queriesObject = sortedFiles.map(file => ` ${file},`).join(`
|
|
327
|
+
`);
|
|
328
|
+
return `${imports}
|
|
329
|
+
${namespaceDefs}
|
|
330
|
+
|
|
331
|
+
export const queries = defineQueries({
|
|
332
|
+
${queriesObject}
|
|
333
|
+
})
|
|
334
|
+
`;
|
|
335
|
+
}
|
|
336
|
+
function generateReadmeFile() {
|
|
337
|
+
return `# generated
|
|
338
|
+
|
|
339
|
+
this folder is auto-generated by over-zero. do not edit files here directly.
|
|
340
|
+
|
|
341
|
+
## what's generated
|
|
342
|
+
|
|
343
|
+
- \`models.ts\` - exports all models from ../models
|
|
344
|
+
- \`types.ts\` - typescript types derived from table schemas
|
|
345
|
+
- \`tables.ts\` - exports table schemas for type inference
|
|
346
|
+
- \`groupedQueries.ts\` - namespaced query re-exports for client setup
|
|
347
|
+
- \`syncedQueries.ts\` - namespaced syncedQuery wrappers for server setup
|
|
348
|
+
|
|
349
|
+
## usage guidelines
|
|
350
|
+
|
|
351
|
+
**do not import generated files outside of the data folder.**
|
|
352
|
+
|
|
353
|
+
### queries
|
|
354
|
+
|
|
355
|
+
write your queries as plain functions in \`../queries/\` and import them directly:
|
|
356
|
+
|
|
357
|
+
\`\`\`ts
|
|
358
|
+
// \u2705 good - import from queries
|
|
359
|
+
import { channelMessages } from '~/data/queries/message'
|
|
360
|
+
\`\`\`
|
|
361
|
+
|
|
362
|
+
the generated query files are only used internally by zero client/server setup.
|
|
363
|
+
|
|
364
|
+
### types
|
|
365
|
+
|
|
366
|
+
you can import types from this folder, but prefer re-exporting from \`../types.ts\`:
|
|
367
|
+
|
|
368
|
+
\`\`\`ts
|
|
369
|
+
// \u274C okay but not preferred
|
|
370
|
+
import type { Message } from '~/data/generated/types'
|
|
371
|
+
|
|
372
|
+
// \u2705 better - re-export from types.ts
|
|
373
|
+
import type { Message } from '~/data/types'
|
|
374
|
+
\`\`\`
|
|
375
|
+
|
|
376
|
+
## regeneration
|
|
377
|
+
|
|
378
|
+
files are regenerated when you run:
|
|
379
|
+
|
|
380
|
+
\`\`\`bash
|
|
381
|
+
bun over-zero generate
|
|
382
|
+
\`\`\`
|
|
383
|
+
|
|
384
|
+
or in watch mode:
|
|
385
|
+
|
|
386
|
+
\`\`\`bash
|
|
387
|
+
bun over-zero generate --watch
|
|
388
|
+
\`\`\`
|
|
389
|
+
|
|
390
|
+
## more info
|
|
391
|
+
|
|
392
|
+
see the [over-zero readme](./node_modules/over-zero/README.md) for full documentation.
|
|
393
|
+
`;
|
|
394
|
+
}
|
|
395
|
+
const main = (0, import_citty.defineCommand)({
|
|
396
|
+
meta: {
|
|
397
|
+
name: "over-zero",
|
|
398
|
+
description: "Over-zero CLI tools"
|
|
399
|
+
},
|
|
400
|
+
subCommands: {
|
|
401
|
+
generate,
|
|
402
|
+
"generate-queries": generateQueries
|
|
403
|
+
}
|
|
404
|
+
});
|
|
405
|
+
(0, import_citty.runMain)(main);
|