@supatype/cli 0.1.0-alpha.10
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/.turbo/turbo-build.log +4 -0
- package/.turbo/turbo-test.log +221 -0
- package/.turbo/turbo-typecheck.log +4 -0
- package/assets/supatype-logo-wordmark.ascii.txt +6 -0
- package/bin/dev-entry.ts +2 -0
- package/bin/supatype.js +5 -0
- package/dist/app/framework.d.ts +44 -0
- package/dist/app/framework.d.ts.map +1 -0
- package/dist/app/framework.js +200 -0
- package/dist/app/framework.js.map +1 -0
- package/dist/app/proxy-dev-app.d.ts +13 -0
- package/dist/app/proxy-dev-app.d.ts.map +1 -0
- package/dist/app/proxy-dev-app.js +54 -0
- package/dist/app/proxy-dev-app.js.map +1 -0
- package/dist/app-config.d.ts +7 -0
- package/dist/app-config.d.ts.map +1 -0
- package/dist/app-config.js +113 -0
- package/dist/app-config.js.map +1 -0
- package/dist/assets/supatype-logo-wordmark.ascii.txt +6 -0
- package/dist/augmentation-generator.d.ts +2 -0
- package/dist/augmentation-generator.d.ts.map +1 -0
- package/dist/augmentation-generator.js +111 -0
- package/dist/augmentation-generator.js.map +1 -0
- package/dist/binary-cache.d.ts +98 -0
- package/dist/binary-cache.d.ts.map +1 -0
- package/dist/binary-cache.js +687 -0
- package/dist/binary-cache.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +61 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/admin.d.ts +4 -0
- package/dist/commands/admin.d.ts.map +1 -0
- package/dist/commands/admin.js +271 -0
- package/dist/commands/admin.js.map +1 -0
- package/dist/commands/app.d.ts +3 -0
- package/dist/commands/app.d.ts.map +1 -0
- package/dist/commands/app.js +82 -0
- package/dist/commands/app.js.map +1 -0
- package/dist/commands/cache.d.ts +6 -0
- package/dist/commands/cache.d.ts.map +1 -0
- package/dist/commands/cache.js +105 -0
- package/dist/commands/cache.js.map +1 -0
- package/dist/commands/cloud.d.ts +23 -0
- package/dist/commands/cloud.d.ts.map +1 -0
- package/dist/commands/cloud.js +254 -0
- package/dist/commands/cloud.js.map +1 -0
- package/dist/commands/db.d.ts +8 -0
- package/dist/commands/db.d.ts.map +1 -0
- package/dist/commands/db.js +116 -0
- package/dist/commands/db.js.map +1 -0
- package/dist/commands/deploy-types.d.ts +14 -0
- package/dist/commands/deploy-types.d.ts.map +1 -0
- package/dist/commands/deploy-types.js +38 -0
- package/dist/commands/deploy-types.js.map +1 -0
- package/dist/commands/deploy.d.ts +15 -0
- package/dist/commands/deploy.d.ts.map +1 -0
- package/dist/commands/deploy.js +322 -0
- package/dist/commands/deploy.js.map +1 -0
- package/dist/commands/dev.d.ts +14 -0
- package/dist/commands/dev.d.ts.map +1 -0
- package/dist/commands/dev.js +806 -0
- package/dist/commands/dev.js.map +1 -0
- package/dist/commands/diff.d.ts +3 -0
- package/dist/commands/diff.d.ts.map +1 -0
- package/dist/commands/diff.js +54 -0
- package/dist/commands/diff.js.map +1 -0
- package/dist/commands/engine.d.ts +7 -0
- package/dist/commands/engine.d.ts.map +1 -0
- package/dist/commands/engine.js +27 -0
- package/dist/commands/engine.js.map +1 -0
- package/dist/commands/functions.d.ts +3 -0
- package/dist/commands/functions.d.ts.map +1 -0
- package/dist/commands/functions.js +749 -0
- package/dist/commands/functions.js.map +1 -0
- package/dist/commands/generate.d.ts +3 -0
- package/dist/commands/generate.d.ts.map +1 -0
- package/dist/commands/generate.js +38 -0
- package/dist/commands/generate.js.map +1 -0
- package/dist/commands/init.d.ts +7 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +228 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/keys.d.ts +4 -0
- package/dist/commands/keys.d.ts.map +1 -0
- package/dist/commands/keys.js +57 -0
- package/dist/commands/keys.js.map +1 -0
- package/dist/commands/logs.d.ts +6 -0
- package/dist/commands/logs.d.ts.map +1 -0
- package/dist/commands/logs.js +52 -0
- package/dist/commands/logs.js.map +1 -0
- package/dist/commands/migrate-from-v1.d.ts +5 -0
- package/dist/commands/migrate-from-v1.d.ts.map +1 -0
- package/dist/commands/migrate-from-v1.js +125 -0
- package/dist/commands/migrate-from-v1.js.map +1 -0
- package/dist/commands/migrate.d.ts +3 -0
- package/dist/commands/migrate.d.ts.map +1 -0
- package/dist/commands/migrate.js +75 -0
- package/dist/commands/migrate.js.map +1 -0
- package/dist/commands/pg.d.ts +8 -0
- package/dist/commands/pg.d.ts.map +1 -0
- package/dist/commands/pg.js +102 -0
- package/dist/commands/pg.js.map +1 -0
- package/dist/commands/plugins.d.ts +3 -0
- package/dist/commands/plugins.d.ts.map +1 -0
- package/dist/commands/plugins.js +431 -0
- package/dist/commands/plugins.js.map +1 -0
- package/dist/commands/pull.d.ts +3 -0
- package/dist/commands/pull.d.ts.map +1 -0
- package/dist/commands/pull.js +12 -0
- package/dist/commands/pull.js.map +1 -0
- package/dist/commands/push.d.ts +3 -0
- package/dist/commands/push.d.ts.map +1 -0
- package/dist/commands/push.js +179 -0
- package/dist/commands/push.js.map +1 -0
- package/dist/commands/seed.d.ts +5 -0
- package/dist/commands/seed.d.ts.map +1 -0
- package/dist/commands/seed.js +55 -0
- package/dist/commands/seed.js.map +1 -0
- package/dist/commands/self-host.d.ts +9 -0
- package/dist/commands/self-host.d.ts.map +1 -0
- package/dist/commands/self-host.js +310 -0
- package/dist/commands/self-host.js.map +1 -0
- package/dist/commands/self-update.d.ts +9 -0
- package/dist/commands/self-update.d.ts.map +1 -0
- package/dist/commands/self-update.js +33 -0
- package/dist/commands/self-update.js.map +1 -0
- package/dist/commands/status.d.ts +6 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +70 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/types.d.ts +3 -0
- package/dist/commands/types.d.ts.map +1 -0
- package/dist/commands/types.js +62 -0
- package/dist/commands/types.js.map +1 -0
- package/dist/commands/update.d.ts +7 -0
- package/dist/commands/update.d.ts.map +1 -0
- package/dist/commands/update.js +118 -0
- package/dist/commands/update.js.map +1 -0
- package/dist/components.d.ts +5 -0
- package/dist/components.d.ts.map +1 -0
- package/dist/components.js +3 -0
- package/dist/components.js.map +1 -0
- package/dist/config.d.ts +65 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +134 -0
- package/dist/config.js.map +1 -0
- package/dist/dev-compose.d.ts +19 -0
- package/dist/dev-compose.d.ts.map +1 -0
- package/dist/dev-compose.js +468 -0
- package/dist/dev-compose.js.map +1 -0
- package/dist/dev-log-bus.d.ts +30 -0
- package/dist/dev-log-bus.d.ts.map +1 -0
- package/dist/dev-log-bus.js +87 -0
- package/dist/dev-log-bus.js.map +1 -0
- package/dist/dev-log-filter.d.ts +10 -0
- package/dist/dev-log-filter.d.ts.map +1 -0
- package/dist/dev-log-filter.js +36 -0
- package/dist/dev-log-filter.js.map +1 -0
- package/dist/dev-logo.d.ts +12 -0
- package/dist/dev-logo.d.ts.map +1 -0
- package/dist/dev-logo.js +57 -0
- package/dist/dev-logo.js.map +1 -0
- package/dist/dev-session.d.ts +26 -0
- package/dist/dev-session.d.ts.map +1 -0
- package/dist/dev-session.js +106 -0
- package/dist/dev-session.js.map +1 -0
- package/dist/dev-shutdown.d.ts +9 -0
- package/dist/dev-shutdown.d.ts.map +1 -0
- package/dist/dev-shutdown.js +50 -0
- package/dist/dev-shutdown.js.map +1 -0
- package/dist/dev-task-colors.d.ts +14 -0
- package/dist/dev-task-colors.d.ts.map +1 -0
- package/dist/dev-task-colors.js +44 -0
- package/dist/dev-task-colors.js.map +1 -0
- package/dist/dev-tui.d.ts +24 -0
- package/dist/dev-tui.d.ts.map +1 -0
- package/dist/dev-tui.js +188 -0
- package/dist/dev-tui.js.map +1 -0
- package/dist/diff-output.d.ts +4 -0
- package/dist/diff-output.d.ts.map +1 -0
- package/dist/diff-output.js +12 -0
- package/dist/diff-output.js.map +1 -0
- package/dist/docker-postgres.d.ts +57 -0
- package/dist/docker-postgres.d.ts.map +1 -0
- package/dist/docker-postgres.js +208 -0
- package/dist/docker-postgres.js.map +1 -0
- package/dist/engine-client.d.ts +69 -0
- package/dist/engine-client.d.ts.map +1 -0
- package/dist/engine-client.js +157 -0
- package/dist/engine-client.js.map +1 -0
- package/dist/engine-push-output.d.ts +16 -0
- package/dist/engine-push-output.d.ts.map +1 -0
- package/dist/engine-push-output.js +61 -0
- package/dist/engine-push-output.js.map +1 -0
- package/dist/ensure-binary.d.ts +7 -0
- package/dist/ensure-binary.d.ts.map +1 -0
- package/dist/ensure-binary.js +17 -0
- package/dist/ensure-binary.js.map +1 -0
- package/dist/functions-router-gen.d.ts +14 -0
- package/dist/functions-router-gen.d.ts.map +1 -0
- package/dist/functions-router-gen.js +199 -0
- package/dist/functions-router-gen.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/jwt.d.ts +3 -0
- package/dist/jwt.d.ts.map +1 -0
- package/dist/jwt.js +13 -0
- package/dist/jwt.js.map +1 -0
- package/dist/kong-config.d.ts +25 -0
- package/dist/kong-config.d.ts.map +1 -0
- package/dist/kong-config.js +71 -0
- package/dist/kong-config.js.map +1 -0
- package/dist/local-gateway.d.ts +7 -0
- package/dist/local-gateway.d.ts.map +1 -0
- package/dist/local-gateway.js +9 -0
- package/dist/local-gateway.js.map +1 -0
- package/dist/local-storage.d.ts +8 -0
- package/dist/local-storage.d.ts.map +1 -0
- package/dist/local-storage.js +14 -0
- package/dist/local-storage.js.map +1 -0
- package/dist/pgbouncer-userlist.d.ts +5 -0
- package/dist/pgbouncer-userlist.d.ts.map +1 -0
- package/dist/pgbouncer-userlist.js +14 -0
- package/dist/pgbouncer-userlist.js.map +1 -0
- package/dist/postgres-ctl.d.ts +44 -0
- package/dist/postgres-ctl.d.ts.map +1 -0
- package/dist/postgres-ctl.js +137 -0
- package/dist/postgres-ctl.js.map +1 -0
- package/dist/process-manager.d.ts +49 -0
- package/dist/process-manager.d.ts.map +1 -0
- package/dist/process-manager.js +177 -0
- package/dist/process-manager.js.map +1 -0
- package/dist/project-config.d.ts +238 -0
- package/dist/project-config.d.ts.map +1 -0
- package/dist/project-config.js +159 -0
- package/dist/project-config.js.map +1 -0
- package/dist/pull-utils.d.ts +31 -0
- package/dist/pull-utils.d.ts.map +1 -0
- package/dist/pull-utils.js +77 -0
- package/dist/pull-utils.js.map +1 -0
- package/dist/release-pins.d.ts +7 -0
- package/dist/release-pins.d.ts.map +1 -0
- package/dist/release-pins.js +27 -0
- package/dist/release-pins.js.map +1 -0
- package/dist/release-public-key.d.ts +8 -0
- package/dist/release-public-key.d.ts.map +1 -0
- package/dist/release-public-key.js +13 -0
- package/dist/release-public-key.js.map +1 -0
- package/dist/restore-system-relation-targets.d.ts +3 -0
- package/dist/restore-system-relation-targets.d.ts.map +1 -0
- package/dist/restore-system-relation-targets.js +45 -0
- package/dist/restore-system-relation-targets.js.map +1 -0
- package/dist/runtime-routes.d.ts +34 -0
- package/dist/runtime-routes.d.ts.map +1 -0
- package/dist/runtime-routes.js +252 -0
- package/dist/runtime-routes.js.map +1 -0
- package/dist/schema-ast-v2.d.ts +127 -0
- package/dist/schema-ast-v2.d.ts.map +1 -0
- package/dist/schema-ast-v2.js +226 -0
- package/dist/schema-ast-v2.js.map +1 -0
- package/dist/scripts/postinstall.d.ts +11 -0
- package/dist/scripts/postinstall.d.ts.map +1 -0
- package/dist/scripts/postinstall.js +47 -0
- package/dist/scripts/postinstall.js.map +1 -0
- package/dist/seed.d.ts +8 -0
- package/dist/seed.d.ts.map +1 -0
- package/dist/seed.js +32 -0
- package/dist/seed.js.map +1 -0
- package/dist/self-host-compose.d.ts +43 -0
- package/dist/self-host-compose.d.ts.map +1 -0
- package/dist/self-host-compose.js +400 -0
- package/dist/self-host-compose.js.map +1 -0
- package/dist/storage-provision.d.ts +24 -0
- package/dist/storage-provision.d.ts.map +1 -0
- package/dist/storage-provision.js +44 -0
- package/dist/storage-provision.js.map +1 -0
- package/dist/studio-admin-roles.d.ts +7 -0
- package/dist/studio-admin-roles.d.ts.map +1 -0
- package/dist/studio-admin-roles.js +14 -0
- package/dist/studio-admin-roles.js.map +1 -0
- package/dist/studio-dev-server.d.ts +22 -0
- package/dist/studio-dev-server.d.ts.map +1 -0
- package/dist/studio-dev-server.js +28 -0
- package/dist/studio-dev-server.js.map +1 -0
- package/dist/supatype-eval-1781522769253.d.mts +2 -0
- package/dist/supatype-eval-1781522769253.d.mts.map +1 -0
- package/dist/supatype-eval-1781522769253.mjs +3 -0
- package/dist/supatype-eval-1781522769253.mjs.map +1 -0
- package/dist/systemd.d.ts +26 -0
- package/dist/systemd.d.ts.map +1 -0
- package/dist/systemd.js +102 -0
- package/dist/systemd.js.map +1 -0
- package/dist/tsx-runner.d.ts +18 -0
- package/dist/tsx-runner.d.ts.map +1 -0
- package/dist/tsx-runner.js +69 -0
- package/dist/tsx-runner.js.map +1 -0
- package/dist/type-extractor.d.ts +4 -0
- package/dist/type-extractor.d.ts.map +1 -0
- package/dist/type-extractor.js +1213 -0
- package/dist/type-extractor.js.map +1 -0
- package/dist/type-resolver.d.ts +33 -0
- package/dist/type-resolver.d.ts.map +1 -0
- package/dist/type-resolver.js +338 -0
- package/dist/type-resolver.js.map +1 -0
- package/package.json +41 -0
- package/releases/deno/VERSION +1 -0
- package/scripts/mirror-deno-release.sh +76 -0
- package/src/TYPE-RESOLUTION.md +294 -0
- package/src/app/framework.ts +249 -0
- package/src/app/proxy-dev-app.ts +68 -0
- package/src/app-config.ts +128 -0
- package/src/augmentation-generator.ts +126 -0
- package/src/binary-cache.ts +845 -0
- package/src/cli.ts +63 -0
- package/src/commands/admin.ts +372 -0
- package/src/commands/app.ts +97 -0
- package/src/commands/cache.ts +117 -0
- package/src/commands/cloud.ts +325 -0
- package/src/commands/db.ts +136 -0
- package/src/commands/deploy-types.ts +49 -0
- package/src/commands/deploy.ts +400 -0
- package/src/commands/dev.ts +1009 -0
- package/src/commands/diff.ts +63 -0
- package/src/commands/engine.ts +30 -0
- package/src/commands/functions.ts +901 -0
- package/src/commands/generate.ts +44 -0
- package/src/commands/init.ts +253 -0
- package/src/commands/keys.ts +66 -0
- package/src/commands/logs.ts +58 -0
- package/src/commands/migrate-from-v1.ts +131 -0
- package/src/commands/migrate.ts +87 -0
- package/src/commands/pg.ts +133 -0
- package/src/commands/plugins.ts +508 -0
- package/src/commands/pull.ts +17 -0
- package/src/commands/push.ts +226 -0
- package/src/commands/seed.ts +68 -0
- package/src/commands/self-host.ts +364 -0
- package/src/commands/self-update.ts +45 -0
- package/src/commands/status.ts +84 -0
- package/src/commands/types.ts +76 -0
- package/src/commands/update.ts +136 -0
- package/src/components.ts +6 -0
- package/src/config.ts +223 -0
- package/src/dev-compose.ts +583 -0
- package/src/dev-log-bus.ts +101 -0
- package/src/dev-log-filter.ts +32 -0
- package/src/dev-logo.ts +62 -0
- package/src/dev-session.ts +130 -0
- package/src/dev-shutdown.ts +54 -0
- package/src/dev-task-colors.ts +47 -0
- package/src/dev-tui.ts +232 -0
- package/src/diff-output.ts +12 -0
- package/src/docker-postgres.ts +295 -0
- package/src/engine-client.ts +236 -0
- package/src/engine-push-output.ts +71 -0
- package/src/ensure-binary.ts +28 -0
- package/src/functions-router-gen.ts +224 -0
- package/src/index.ts +11 -0
- package/src/jwt.ts +14 -0
- package/src/kong-config.ts +93 -0
- package/src/local-gateway.ts +9 -0
- package/src/local-storage.ts +14 -0
- package/src/pgbouncer-userlist.ts +15 -0
- package/src/postgres-ctl.ts +171 -0
- package/src/process-manager.ts +220 -0
- package/src/project-config.ts +388 -0
- package/src/pull-utils.ts +81 -0
- package/src/release-pins.ts +31 -0
- package/src/release-public-key.ts +12 -0
- package/src/restore-system-relation-targets.ts +45 -0
- package/src/runtime-routes.ts +291 -0
- package/src/schema-ast-v2.ts +324 -0
- package/src/scripts/postinstall.ts +51 -0
- package/src/seed.ts +43 -0
- package/src/self-host-compose.ts +452 -0
- package/src/storage-provision.ts +58 -0
- package/src/studio-admin-roles.ts +16 -0
- package/src/studio-dev-server.ts +53 -0
- package/src/supatype-eval-1781522769253.mts +1 -0
- package/src/systemd.ts +137 -0
- package/src/tsx-runner.ts +89 -0
- package/src/type-extractor.ts +1479 -0
- package/src/type-resolver.ts +457 -0
- package/tests/app-command.test.ts +54 -0
- package/tests/augmentation-generator.test.ts +59 -0
- package/tests/binary-cache-cloud-overrides.test.ts +123 -0
- package/tests/cached-artifact-format.test.ts +84 -0
- package/tests/cli-help.test.ts +133 -0
- package/tests/config.test.ts +252 -0
- package/tests/dev-ui.test.ts +139 -0
- package/tests/docker-postgres.test.ts +39 -0
- package/tests/engine-distribution.test.ts +418 -0
- package/tests/engine-push-output.test.ts +67 -0
- package/tests/ensure-binary.test.ts +59 -0
- package/tests/init.test.ts +127 -0
- package/tests/keys.test.ts +160 -0
- package/tests/migrate-from-v1.test.ts +29 -0
- package/tests/normalize-admin-config.test.ts +48 -0
- package/tests/pg-spawn-env.test.ts +18 -0
- package/tests/postgres-archive-tag.test.ts +9 -0
- package/tests/proxy-dev-app.test.ts +33 -0
- package/tests/pull-utils.test.ts +150 -0
- package/tests/release-pins.test.ts +28 -0
- package/tests/runtime-contract.test.ts +370 -0
- package/tests/seed-discover.test.ts +31 -0
- package/tests/studio-admin-roles.test.ts +27 -0
- package/tests/tsconfig.json +9 -0
- package/tests/tsx-runner.test.ts +66 -0
- package/tests/type-extractor.test.ts +985 -0
- package/tests/type-resolver.test.ts +59 -0
- package/tsconfig.json +10 -0
- package/tsconfig.tsbuildinfo +1 -0
- package/vitest.config.ts +12 -0
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { readFileSync, writeFileSync, existsSync } from "node:fs"
|
|
2
|
+
import { resolve } from "node:path"
|
|
3
|
+
import { Node, Project, QuoteKind, SyntaxKind, type ObjectLiteralExpression, type SourceFile } from "ts-morph"
|
|
4
|
+
|
|
5
|
+
export interface UpdateAppConfigInput {
|
|
6
|
+
mode: "none" | "static" | "proxy"
|
|
7
|
+
staticDir?: string
|
|
8
|
+
upstream?: string
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export function updateAppConfigInProject(cwd: string, input: UpdateAppConfigInput): string {
|
|
12
|
+
const configPath = resolve(cwd, "supatype.config.ts")
|
|
13
|
+
if (!existsSync(configPath)) {
|
|
14
|
+
throw new Error("supatype.config.ts not found. Run: supatype init")
|
|
15
|
+
}
|
|
16
|
+
const next = updateAppConfigAst(configPath, input)
|
|
17
|
+
writeFileSync(configPath, next, "utf8")
|
|
18
|
+
return configPath
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function updateAppConfigAst(configPath: string, input: UpdateAppConfigInput): string {
|
|
22
|
+
const project = new Project({
|
|
23
|
+
useInMemoryFileSystem: false,
|
|
24
|
+
skipAddingFilesFromTsConfig: true,
|
|
25
|
+
manipulationSettings: {
|
|
26
|
+
quoteKind: QuoteKind.Double,
|
|
27
|
+
},
|
|
28
|
+
})
|
|
29
|
+
const srcText = readFileSync(configPath, "utf8")
|
|
30
|
+
const sourceFile = project.createSourceFile(configPath, srcText, { overwrite: true })
|
|
31
|
+
const rootObject = getRootConfigObject(sourceFile)
|
|
32
|
+
|
|
33
|
+
const appProperty = rootObject.getProperty("app")
|
|
34
|
+
|
|
35
|
+
if (appProperty === undefined) {
|
|
36
|
+
rootObject.addPropertyAssignment({
|
|
37
|
+
name: "app",
|
|
38
|
+
initializer: renderAppInitializer(input),
|
|
39
|
+
})
|
|
40
|
+
} else if (Node.isPropertyAssignment(appProperty)) {
|
|
41
|
+
const init = appProperty.getInitializer()
|
|
42
|
+
if (init && Node.isObjectLiteralExpression(init)) {
|
|
43
|
+
patchAppObject(init, input)
|
|
44
|
+
} else {
|
|
45
|
+
appProperty.setInitializer(renderAppInitializer(input))
|
|
46
|
+
}
|
|
47
|
+
} else {
|
|
48
|
+
appProperty.remove()
|
|
49
|
+
rootObject.addPropertyAssignment({
|
|
50
|
+
name: "app",
|
|
51
|
+
initializer: renderAppInitializer(input),
|
|
52
|
+
})
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
return sourceFile.getFullText()
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function getRootConfigObject(sourceFile: SourceFile): ObjectLiteralExpression {
|
|
59
|
+
const exportAssignment = sourceFile.getFirstDescendantByKind(SyntaxKind.ExportAssignment)
|
|
60
|
+
if (!exportAssignment) {
|
|
61
|
+
throw new Error("Could not find default export in supatype.config.ts.")
|
|
62
|
+
}
|
|
63
|
+
const expr = exportAssignment.getExpression()
|
|
64
|
+
if (Node.isObjectLiteralExpression(expr)) {
|
|
65
|
+
return expr
|
|
66
|
+
}
|
|
67
|
+
if (Node.isCallExpression(expr)) {
|
|
68
|
+
const [firstArg] = expr.getArguments()
|
|
69
|
+
if (firstArg && Node.isObjectLiteralExpression(firstArg)) {
|
|
70
|
+
return firstArg
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
throw new Error(
|
|
74
|
+
"supatype.config.ts must export an object literal or defineConfig({...}).",
|
|
75
|
+
)
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
function renderAppInitializer(input: UpdateAppConfigInput): string {
|
|
79
|
+
if (input.mode === "proxy") {
|
|
80
|
+
return `{
|
|
81
|
+
mode: "proxy",
|
|
82
|
+
upstream: "${input.upstream ?? "http://localhost:3000"}",
|
|
83
|
+
}`
|
|
84
|
+
}
|
|
85
|
+
if (input.mode === "static") {
|
|
86
|
+
return `{
|
|
87
|
+
mode: "static",
|
|
88
|
+
static_dir: "${input.staticDir ?? "./dist"}",
|
|
89
|
+
}`
|
|
90
|
+
}
|
|
91
|
+
return `{
|
|
92
|
+
mode: "none",
|
|
93
|
+
}`
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
function patchAppObject(appObj: ObjectLiteralExpression, input: UpdateAppConfigInput): void {
|
|
97
|
+
upsertStringProperty(appObj, "mode", input.mode)
|
|
98
|
+
|
|
99
|
+
if (input.mode === "proxy") {
|
|
100
|
+
upsertStringProperty(appObj, "upstream", input.upstream ?? "http://localhost:3000")
|
|
101
|
+
removePropertyIfPresent(appObj, "static_dir")
|
|
102
|
+
return
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
if (input.mode === "static") {
|
|
106
|
+
upsertStringProperty(appObj, "static_dir", input.staticDir ?? "./dist")
|
|
107
|
+
removePropertyIfPresent(appObj, "upstream")
|
|
108
|
+
return
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
removePropertyIfPresent(appObj, "upstream")
|
|
112
|
+
removePropertyIfPresent(appObj, "static_dir")
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
function upsertStringProperty(obj: ObjectLiteralExpression, key: string, value: string): void {
|
|
116
|
+
const existing = obj.getProperty(key)
|
|
117
|
+
if (existing && Node.isPropertyAssignment(existing)) {
|
|
118
|
+
existing.setInitializer(`"${value}"`)
|
|
119
|
+
return
|
|
120
|
+
}
|
|
121
|
+
if (existing) existing.remove()
|
|
122
|
+
obj.addPropertyAssignment({ name: key, initializer: `"${value}"` })
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
function removePropertyIfPresent(obj: ObjectLiteralExpression, key: string): void {
|
|
126
|
+
const prop = obj.getProperty(key)
|
|
127
|
+
if (prop) prop.remove()
|
|
128
|
+
}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
interface AstModel {
|
|
2
|
+
tableName: string
|
|
3
|
+
fields: Record<string, Record<string, unknown>>
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
interface AstShape {
|
|
7
|
+
models?: AstModel[]
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export function generateClientAugmentation(ast: unknown): string {
|
|
11
|
+
const parsed = ast as AstShape
|
|
12
|
+
const models = [...(parsed.models ?? [])].sort((a, b) => a.tableName.localeCompare(b.tableName))
|
|
13
|
+
|
|
14
|
+
const lines: string[] = []
|
|
15
|
+
lines.push("// Generated by supatype CLI — do not edit manually.")
|
|
16
|
+
lines.push("")
|
|
17
|
+
lines.push("declare module \"@supatype/client\" {")
|
|
18
|
+
lines.push(" interface SupatypeModels {")
|
|
19
|
+
|
|
20
|
+
for (const model of models) {
|
|
21
|
+
lines.push(` ${quoteKey(model.tableName)}: {`)
|
|
22
|
+
lines.push(` Row: ${generateRowType(model.fields)}`)
|
|
23
|
+
lines.push(` Insert: ${generateInsertType(model.fields)}`)
|
|
24
|
+
lines.push(` Update: ${generateUpdateType(model.fields)}`)
|
|
25
|
+
lines.push(" }")
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
lines.push(" }")
|
|
29
|
+
lines.push("}")
|
|
30
|
+
lines.push("")
|
|
31
|
+
lines.push("export {}")
|
|
32
|
+
lines.push("")
|
|
33
|
+
|
|
34
|
+
return lines.join("\n")
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
function generateRowType(fields: Record<string, Record<string, unknown>>): string {
|
|
38
|
+
const entries = Object.entries(fields).sort(([a], [b]) => a.localeCompare(b))
|
|
39
|
+
if (entries.length === 0) return "Record<string, unknown>"
|
|
40
|
+
const body = entries
|
|
41
|
+
.map(([name, meta]) => ` ${quoteKey(name)}: ${toTsType(meta)}`)
|
|
42
|
+
.join("\n")
|
|
43
|
+
return `{\n${body}\n}`
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function insertColumnOptionalOnInsert(meta: Record<string, unknown>): boolean {
|
|
47
|
+
return meta["default"] !== undefined || meta["serverGenerated"] === true
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function generateInsertType(fields: Record<string, Record<string, unknown>>): string {
|
|
51
|
+
const entries = Object.entries(fields).sort(([a], [b]) => a.localeCompare(b))
|
|
52
|
+
if (entries.length === 0) return "Record<string, unknown>"
|
|
53
|
+
const body = entries
|
|
54
|
+
.map(([name, meta]) => {
|
|
55
|
+
const required = meta["required"] === true && !insertColumnOptionalOnInsert(meta)
|
|
56
|
+
return ` ${quoteKey(name)}${required ? "" : "?"}: ${toTsType(meta)}`
|
|
57
|
+
})
|
|
58
|
+
.join("\n")
|
|
59
|
+
return `{\n${body}\n}`
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function generateUpdateType(fields: Record<string, Record<string, unknown>>): string {
|
|
63
|
+
const entries = Object.entries(fields).sort(([a], [b]) => a.localeCompare(b))
|
|
64
|
+
if (entries.length === 0) return "Record<string, unknown>"
|
|
65
|
+
const body = entries
|
|
66
|
+
.map(([name, meta]) => ` ${quoteKey(name)}?: ${toTsType(meta)}`)
|
|
67
|
+
.join("\n")
|
|
68
|
+
return `{\n${body}\n}`
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function toTsType(meta: Record<string, unknown>): string {
|
|
72
|
+
const kind = typeof meta["kind"] === "string" ? meta["kind"] : "json"
|
|
73
|
+
const required = meta["required"] === true
|
|
74
|
+
const base = (() => {
|
|
75
|
+
switch (kind) {
|
|
76
|
+
case "uuid":
|
|
77
|
+
case "slug":
|
|
78
|
+
case "text":
|
|
79
|
+
case "email":
|
|
80
|
+
case "url":
|
|
81
|
+
case "date":
|
|
82
|
+
case "timestamp":
|
|
83
|
+
case "datetime":
|
|
84
|
+
case "money":
|
|
85
|
+
case "xml":
|
|
86
|
+
case "interval":
|
|
87
|
+
return "string"
|
|
88
|
+
case "integer":
|
|
89
|
+
case "smallInt":
|
|
90
|
+
case "serial":
|
|
91
|
+
case "float":
|
|
92
|
+
case "decimal":
|
|
93
|
+
return "number"
|
|
94
|
+
case "bigSerial":
|
|
95
|
+
case "bigInt":
|
|
96
|
+
return "bigint"
|
|
97
|
+
case "boolean":
|
|
98
|
+
return "boolean"
|
|
99
|
+
case "json":
|
|
100
|
+
case "blocks":
|
|
101
|
+
case "geo":
|
|
102
|
+
case "vector":
|
|
103
|
+
case "relation":
|
|
104
|
+
case "array":
|
|
105
|
+
case "image":
|
|
106
|
+
case "file":
|
|
107
|
+
return "Record<string, unknown>"
|
|
108
|
+
case "richText":
|
|
109
|
+
return "(import(\"@supatype/types/lexical\").SerializedEditorState | string)"
|
|
110
|
+
case "enum": {
|
|
111
|
+
const values = Array.isArray(meta["values"]) ? meta["values"] as unknown[] : []
|
|
112
|
+
const quoted = values
|
|
113
|
+
.filter((v): v is string => typeof v === "string")
|
|
114
|
+
.map((v) => JSON.stringify(v))
|
|
115
|
+
return quoted.length > 0 ? quoted.join(" | ") : "string"
|
|
116
|
+
}
|
|
117
|
+
default:
|
|
118
|
+
return "unknown"
|
|
119
|
+
}
|
|
120
|
+
})()
|
|
121
|
+
return required ? base : `${base} | null`
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
function quoteKey(key: string): string {
|
|
125
|
+
return /^[A-Za-z_$][A-Za-z0-9_$]*$/.test(key) ? key : JSON.stringify(key)
|
|
126
|
+
}
|