@zenstackhq/cli 3.0.0-alpha.23 → 3.0.0-alpha.25
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 +9 -9
- package/dist/index.cjs +22 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +22 -1
- package/dist/index.js.map +1 -1
- package/package.json +10 -10
- package/src/actions/migrate.ts +29 -0
- package/src/index.ts +10 -1
- package/test/migrate.test.ts +31 -0
- package/tsconfig.json +1 -1
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
|
|
2
|
-
> @zenstackhq/cli@3.0.0-alpha.
|
|
3
|
-
> tsup-node
|
|
2
|
+
> @zenstackhq/cli@3.0.0-alpha.25 build /home/runner/work/zenstack-v3/zenstack-v3/packages/cli
|
|
3
|
+
> tsc --noEmit && tsup-node
|
|
4
4
|
|
|
5
5
|
[34mCLI[39m Building entry: {"index":"src/index.ts"}
|
|
6
6
|
[34mCLI[39m Using tsconfig: tsconfig.json
|
|
@@ -10,13 +10,13 @@
|
|
|
10
10
|
[34mCLI[39m Cleaning output folder
|
|
11
11
|
[34mESM[39m Build start
|
|
12
12
|
[34mCJS[39m Build start
|
|
13
|
-
[32mESM[39m [1mdist/index.js [22m[
|
|
14
|
-
[32mESM[39m [1mdist/index.js.map [22m[
|
|
15
|
-
[32mESM[39m ⚡️ Build success in
|
|
16
|
-
[32mCJS[39m [1mdist/index.cjs [22m[
|
|
17
|
-
[32mCJS[39m [1mdist/index.cjs.map [22m[
|
|
18
|
-
[32mCJS[39m ⚡️ Build success in
|
|
13
|
+
[32mESM[39m [1mdist/index.js [22m[32m20.49 KB[39m
|
|
14
|
+
[32mESM[39m [1mdist/index.js.map [22m[32m43.09 KB[39m
|
|
15
|
+
[32mESM[39m ⚡️ Build success in 110ms
|
|
16
|
+
[32mCJS[39m [1mdist/index.cjs [22m[32m23.97 KB[39m
|
|
17
|
+
[32mCJS[39m [1mdist/index.cjs.map [22m[32m43.35 KB[39m
|
|
18
|
+
[32mCJS[39m ⚡️ Build success in 111ms
|
|
19
19
|
[34mDTS[39m Build start
|
|
20
|
-
[32mDTS[39m ⚡️ Build success in
|
|
20
|
+
[32mDTS[39m ⚡️ Build success in 3561ms
|
|
21
21
|
[32mDTS[39m [1mdist/index.d.ts [22m[32m108.00 B[39m
|
|
22
22
|
[32mDTS[39m [1mdist/index.d.cts [22m[32m108.00 B[39m
|
package/dist/index.cjs
CHANGED
|
@@ -461,6 +461,9 @@ async function run5(command, options) {
|
|
|
461
461
|
case "status":
|
|
462
462
|
await runStatus(prismaSchemaFile, options);
|
|
463
463
|
break;
|
|
464
|
+
case "resolve":
|
|
465
|
+
await runResolve(prismaSchemaFile, options);
|
|
466
|
+
break;
|
|
464
467
|
}
|
|
465
468
|
} finally {
|
|
466
469
|
if (import_node_fs5.default.existsSync(prismaSchemaFile)) {
|
|
@@ -517,6 +520,23 @@ async function runStatus(prismaSchemaFile, _options) {
|
|
|
517
520
|
}
|
|
518
521
|
}
|
|
519
522
|
__name(runStatus, "runStatus");
|
|
523
|
+
async function runResolve(prismaSchemaFile, options) {
|
|
524
|
+
if (!options.applied && !options.rolledBack) {
|
|
525
|
+
throw new CliError("Either --applied or --rolled-back option must be provided");
|
|
526
|
+
}
|
|
527
|
+
try {
|
|
528
|
+
const cmd = [
|
|
529
|
+
"prisma migrate resolve",
|
|
530
|
+
` --schema "${prismaSchemaFile}"`,
|
|
531
|
+
options.applied ? ` --applied ${options.applied}` : "",
|
|
532
|
+
options.rolledBack ? ` --rolled-back ${options.rolledBack}` : ""
|
|
533
|
+
].join("");
|
|
534
|
+
await execPackage(cmd);
|
|
535
|
+
} catch (err) {
|
|
536
|
+
handleSubProcessError2(err);
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
__name(runResolve, "runResolve");
|
|
520
540
|
function handleSubProcessError2(err) {
|
|
521
541
|
if (err instanceof Error && "status" in err && typeof err.status === "number") {
|
|
522
542
|
process.exit(err.status);
|
|
@@ -588,7 +608,8 @@ Documentation: https://zenstack.dev.`).showHelpAfterError().showSuggestionAfterE
|
|
|
588
608
|
migrateCommand.command("dev").addOption(schemaOption).addOption(new import_commander.Option("-n, --name <name>", "migration name")).addOption(new import_commander.Option("--create-only", "only create migration, do not apply")).addOption(migrationsOption).description("Create a migration from changes in schema and apply it to the database.").action((options) => migrateAction("dev", options));
|
|
589
609
|
migrateCommand.command("reset").addOption(schemaOption).addOption(new import_commander.Option("--force", "skip the confirmation prompt")).addOption(migrationsOption).description("Reset your database and apply all migrations, all data will be lost.").action((options) => migrateAction("reset", options));
|
|
590
610
|
migrateCommand.command("deploy").addOption(schemaOption).addOption(migrationsOption).description("Deploy your pending migrations to your production/staging database.").action((options) => migrateAction("deploy", options));
|
|
591
|
-
migrateCommand.command("status").addOption(schemaOption).addOption(migrationsOption).description("
|
|
611
|
+
migrateCommand.command("status").addOption(schemaOption).addOption(migrationsOption).description("Check the status of your database migrations.").action((options) => migrateAction("status", options));
|
|
612
|
+
migrateCommand.command("resolve").addOption(schemaOption).addOption(migrationsOption).addOption(new import_commander.Option("--applied <migration>", "record a specific migration as applied")).addOption(new import_commander.Option("--rolled-back <migration>", "record a specific migration as rolled back")).description("Resolve issues with database migrations in deployment databases").action((options) => migrateAction("resolve", options));
|
|
592
613
|
const dbCommand = program2.command("db").description("Manage your database schema during development.");
|
|
593
614
|
dbCommand.command("push").description("Push the state from your schema to your database").addOption(schemaOption).addOption(new import_commander.Option("--accept-data-loss", "ignore data loss warnings")).addOption(new import_commander.Option("--force-reset", "force a reset of the database before push")).action((options) => dbAction("push", options));
|
|
594
615
|
program2.command("info").description("Get information of installed ZenStack and related packages.").argument("[path]", "project path", ".").action(infoAction);
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/actions/db.ts","../src/utils/exec-utils.ts","../src/actions/action-utils.ts","../src/cli-error.ts","../src/actions/generate.ts","../src/actions/info.ts","../src/actions/init.ts","../src/actions/templates.ts","../src/actions/migrate.ts","../src/actions/validate.ts","../src/utils/version-utils.ts"],"sourcesContent":["import { ZModelLanguageMetaData } from '@zenstackhq/language';\nimport colors from 'colors';\nimport { Command, CommanderError, Option } from 'commander';\nimport * as actions from './actions';\nimport { CliError } from './cli-error';\nimport { getVersion } from './utils/version-utils';\n\nconst generateAction = async (options: Parameters<typeof actions.generate>[0]): Promise<void> => {\n await actions.generate(options);\n};\n\nconst migrateAction = async (command: string, options: any): Promise<void> => {\n await actions.migrate(command, options);\n};\n\nconst dbAction = async (command: string, options: any): Promise<void> => {\n await actions.db(command, options);\n};\n\nconst infoAction = async (projectPath: string): Promise<void> => {\n await actions.info(projectPath);\n};\n\nconst initAction = async (projectPath: string): Promise<void> => {\n await actions.init(projectPath);\n};\n\nconst validateAction = async (options: Parameters<typeof actions.validate>[0]): Promise<void> => {\n await actions.validate(options);\n};\n\nexport function createProgram() {\n const program = new Command('zenstack');\n\n program.version(getVersion()!, '-v --version', 'display CLI version');\n\n const schemaExtensions = ZModelLanguageMetaData.fileExtensions.join(', ');\n\n program\n .description(\n `${colors.bold.blue(\n 'ζ',\n )} ZenStack is a database access toolkit for TypeScript apps.\\n\\nDocumentation: https://zenstack.dev.`,\n )\n .showHelpAfterError()\n .showSuggestionAfterError();\n\n const schemaOption = new Option(\n '--schema <file>',\n `schema file (with extension ${schemaExtensions}). Defaults to \"schema.zmodel\" unless specified in package.json.`,\n );\n\n program\n .command('generate')\n .description('Run code generation.')\n .addOption(schemaOption)\n .addOption(new Option('--silent', 'do not print any output'))\n .addOption(\n new Option(\n '--save-prisma-schema [path]',\n 'save a Prisma schema file, by default into the output directory',\n ),\n )\n .addOption(new Option('-o, --output <path>', 'default output directory for core plugins'))\n .action(generateAction);\n\n const migrateCommand = program.command('migrate').description('Update the database schema with migrations.');\n const migrationsOption = new Option('--migrations <path>', 'path for migrations');\n\n migrateCommand\n .command('dev')\n .addOption(schemaOption)\n .addOption(new Option('-n, --name <name>', 'migration name'))\n .addOption(new Option('--create-only', 'only create migration, do not apply'))\n .addOption(migrationsOption)\n .description('Create a migration from changes in schema and apply it to the database.')\n .action((options) => migrateAction('dev', options));\n\n migrateCommand\n .command('reset')\n .addOption(schemaOption)\n .addOption(new Option('--force', 'skip the confirmation prompt'))\n .addOption(migrationsOption)\n .description('Reset your database and apply all migrations, all data will be lost.')\n .action((options) => migrateAction('reset', options));\n\n migrateCommand\n .command('deploy')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('Deploy your pending migrations to your production/staging database.')\n .action((options) => migrateAction('deploy', options));\n\n migrateCommand\n .command('status')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('check the status of your database migrations.')\n .action((options) => migrateAction('status', options));\n\n const dbCommand = program.command('db').description('Manage your database schema during development.');\n\n dbCommand\n .command('push')\n .description('Push the state from your schema to your database')\n .addOption(schemaOption)\n .addOption(new Option('--accept-data-loss', 'ignore data loss warnings'))\n .addOption(new Option('--force-reset', 'force a reset of the database before push'))\n .action((options) => dbAction('push', options));\n\n program\n .command('info')\n .description('Get information of installed ZenStack and related packages.')\n .argument('[path]', 'project path', '.')\n .action(infoAction);\n\n program\n .command('init')\n .description('Initialize an existing project for ZenStack.')\n .argument('[path]', 'project path', '.')\n .action(initAction);\n\n program.command('validate').description('Validate a ZModel schema.').addOption(schemaOption).action(validateAction);\n\n return program;\n}\n\nconst program = createProgram();\n\nprogram.parseAsync().catch((err) => {\n if (err instanceof CliError) {\n console.error(colors.red(err.message));\n process.exit(1);\n } else if (err instanceof CommanderError) {\n // errors are already reported, just exit\n process.exit(err.exitCode);\n } else {\n console.error(colors.red('An unexpected error occurred:'));\n console.error(err);\n process.exit(1);\n }\n});\n","import fs from 'node:fs';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile, handleSubProcessError } from './action-utils';\n\ntype Options = {\n schema?: string;\n acceptDataLoss?: boolean;\n forceReset?: boolean;\n};\n\n/**\n * CLI action for db related commands\n */\nexport async function run(command: string, options: Options) {\n switch (command) {\n case 'push':\n await runPush(options);\n break;\n }\n}\n\nasync function runPush(options: Options) {\n // generate a temp prisma schema file\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile);\n\n try {\n // run prisma db push\n const cmd = [\n 'prisma db push',\n ` --schema \"${prismaSchemaFile}\"`,\n options.acceptDataLoss ? ' --accept-data-loss' : '',\n options.forceReset ? ' --force-reset' : '',\n ' --skip-generate',\n ].join('');\n\n try {\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n","import { execSync as _exec, type ExecSyncOptions } from 'child_process';\n\n/**\n * Utility for executing command synchronously and prints outputs on current console\n */\nexport function execSync(cmd: string, options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> }): void {\n const { env, ...restOptions } = options ?? {};\n const mergedEnv = env ? { ...process.env, ...env } : undefined;\n _exec(cmd, {\n encoding: 'utf-8',\n stdio: options?.stdio ?? 'inherit',\n env: mergedEnv,\n ...restOptions,\n });\n}\n\n/**\n * Utility for running package commands through npx/bunx\n */\nexport function execPackage(\n cmd: string,\n options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> },\n): void {\n const packageManager = process?.versions?.['bun'] ? 'bunx' : 'npx';\n execSync(`${packageManager} ${cmd}`, options);\n}\n","import { loadDocument } from '@zenstackhq/language';\nimport { isDataSource } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { CliError } from '../cli-error';\n\nexport function getSchemaFile(file?: string) {\n if (file) {\n if (!fs.existsSync(file)) {\n throw new CliError(`Schema file not found: ${file}`);\n }\n return file;\n }\n\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.schema) {\n if (!fs.existsSync(pkgJsonConfig.schema)) {\n throw new CliError(`Schema file not found: ${pkgJsonConfig.schema}`);\n }\n return pkgJsonConfig.schema;\n }\n\n if (fs.existsSync('./zenstack/schema.zmodel')) {\n return './zenstack/schema.zmodel';\n } else if (fs.existsSync('./schema.zmodel')) {\n return './schema.zmodel';\n } else {\n throw new CliError(\n 'Schema file not found in default locations (\"./zenstack/schema.zmodel\" or \"./schema.zmodel\").',\n );\n }\n}\n\nexport async function loadSchemaDocument(schemaFile: string) {\n const loadResult = await loadDocument(schemaFile);\n if (!loadResult.success) {\n loadResult.errors.forEach((err) => {\n console.error(colors.red(err));\n });\n throw new CliError('Schema contains errors. See above for details.');\n }\n loadResult.warnings.forEach((warn) => {\n console.warn(colors.yellow(warn));\n });\n return loadResult.model;\n}\n\nexport function handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n\nexport async function generateTempPrismaSchema(zmodelPath: string, folder?: string) {\n const model = await loadSchemaDocument(zmodelPath);\n if (!model.declarations.some(isDataSource)) {\n throw new CliError('Schema must define a datasource');\n }\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n if (!folder) {\n folder = path.dirname(zmodelPath);\n }\n const prismaSchemaFile = path.resolve(folder, '~schema.prisma');\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n return prismaSchemaFile;\n}\n\nexport function getPkgJsonConfig(startPath: string) {\n const result: { schema: string | undefined; output: string | undefined } = { schema: undefined, output: undefined };\n const pkgJsonFile = findUp(['package.json'], startPath, false);\n\n if (!pkgJsonFile) {\n return result;\n }\n\n let pkgJson: any = undefined;\n try {\n pkgJson = JSON.parse(fs.readFileSync(pkgJsonFile, 'utf8'));\n } catch {\n return result;\n }\n\n if (pkgJson.zenstack && typeof pkgJson.zenstack === 'object') {\n result.schema = pkgJson.zenstack.schema && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.schema);\n result.output = pkgJson.zenstack.output && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.output);\n }\n\n return result;\n}\n\ntype FindUpResult<Multiple extends boolean> = Multiple extends true ? string[] | undefined : string | undefined;\n\nfunction findUp<Multiple extends boolean = false>(\n names: string[],\n cwd: string = process.cwd(),\n multiple: Multiple = false as Multiple,\n result: string[] = [],\n): FindUpResult<Multiple> {\n if (!names.some((name) => !!name)) {\n return undefined;\n }\n const target = names.find((name) => fs.existsSync(path.join(cwd, name)));\n if (multiple === false && target) {\n return path.join(cwd, target) as FindUpResult<Multiple>;\n }\n if (target) {\n result.push(path.join(cwd, target));\n }\n const up = path.resolve(cwd, '..');\n if (up === cwd) {\n return (multiple && result.length > 0 ? result : undefined) as FindUpResult<Multiple>;\n }\n return findUp(names, up, multiple, result);\n}\n","/**\n * Indicating an error during CLI execution\n */\nexport class CliError extends Error {}\n","import { invariant } from '@zenstackhq/common-helpers';\nimport { isPlugin, LiteralExpr, type Model } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator, TsSchemaGenerator, type CliGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { getPkgJsonConfig, getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n output?: string;\n silent?: boolean;\n savePrismaSchema?: string | boolean;\n};\n\n/**\n * CLI action for generating code from schema\n */\nexport async function run(options: Options) {\n const start = Date.now();\n\n const schemaFile = getSchemaFile(options.schema);\n\n const model = await loadSchemaDocument(schemaFile);\n const outputPath = getOutputPath(options, schemaFile);\n\n // generate TS schema\n const tsSchemaFile = path.join(outputPath, 'schema.ts');\n await new TsSchemaGenerator().generate(schemaFile, [], outputPath);\n\n await runPlugins(model, outputPath, tsSchemaFile);\n\n // generate Prisma schema\n if (options.savePrismaSchema) {\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n let prismaSchemaFile = path.join(outputPath, 'schema.prisma');\n if (typeof options.savePrismaSchema === 'string') {\n prismaSchemaFile = path.resolve(outputPath, options.savePrismaSchema);\n fs.mkdirSync(path.dirname(prismaSchemaFile), { recursive: true });\n }\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n }\n\n if (!options.silent) {\n console.log(colors.green(`Generation completed successfully in ${Date.now() - start}ms.`));\n console.log(`You can now create a ZenStack client with it.\n\n\\`\\`\\`ts\nimport { ZenStackClient } from '@zenstackhq/runtime';\nimport { schema } from '${outputPath}/schema';\n\nconst client = new ZenStackClient(schema, {\n dialect: { ... }\n});\n\\`\\`\\``);\n }\n}\n\nfunction getOutputPath(options: Options, schemaFile: string) {\n if (options.output) {\n return options.output;\n }\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.output) {\n return pkgJsonConfig.output;\n } else {\n return path.dirname(schemaFile);\n }\n}\n\nasync function runPlugins(model: Model, outputPath: string, tsSchemaFile: string) {\n const plugins = model.declarations.filter(isPlugin);\n for (const plugin of plugins) {\n const providerField = plugin.fields.find((f) => f.name === 'provider');\n invariant(providerField, `Plugin ${plugin.name} does not have a provider field`);\n const provider = (providerField.value as LiteralExpr).value as string;\n let useProvider = provider;\n if (useProvider.startsWith('@core/')) {\n useProvider = `@zenstackhq/runtime/plugins/${useProvider.slice(6)}`;\n }\n const generator = (await import(useProvider)).default as CliGenerator;\n console.log('Running generator:', provider);\n await generator({ model, outputPath, tsSchemaFile });\n }\n}\n","import colors from 'colors';\nimport path from 'node:path';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = await getZenStackPackages(projectPath);\n if (!packages) {\n console.error('Unable to locate package.json. Are you in a valid project directory?');\n return;\n }\n\n console.log('Installed ZenStack Packages:');\n const versions = new Set<string>();\n for (const { pkg, version } of packages) {\n if (version) {\n versions.add(version);\n }\n console.log(` ${colors.green(pkg.padEnd(20))}\\t${version}`);\n }\n\n if (versions.size > 1) {\n console.warn(colors.yellow('WARNING: Multiple versions of Zenstack packages detected. This may cause issues.'));\n }\n}\n\nasync function getZenStackPackages(projectPath: string): Promise<Array<{ pkg: string; version: string | undefined }>> {\n let pkgJson: {\n dependencies: Record<string, unknown>;\n devDependencies: Record<string, unknown>;\n };\n const resolvedPath = path.resolve(projectPath);\n try {\n pkgJson = (\n await import(path.join(resolvedPath, 'package.json'), {\n with: { type: 'json' },\n })\n ).default;\n } catch {\n return [];\n }\n\n const packages = Array.from(\n new Set(\n [...Object.keys(pkgJson.dependencies ?? {}), ...Object.keys(pkgJson.devDependencies ?? {})].filter(\n (p) => p.startsWith('@zenstackhq/') || p === 'zenstack',\n ),\n ),\n ).sort();\n\n const result = await Promise.all(\n packages.map(async (pkg) => {\n try {\n const depPkgJson = (\n await import(`${pkg}/package.json`, {\n with: { type: 'json' },\n })\n ).default;\n return { pkg, version: depPkgJson.version as string };\n } catch {\n return { pkg, version: undefined };\n }\n }),\n );\n\n return result;\n}\n","import colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport ora from 'ora';\nimport { detect, resolveCommand } from 'package-manager-detector';\nimport { CliError } from '../cli-error';\nimport { execSync } from '../utils/exec-utils';\nimport { STARTER_ZMODEL } from './templates';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = [\n { name: '@zenstackhq/cli@next', dev: true },\n { name: '@zenstackhq/runtime@next', dev: false },\n ];\n let pm = await detect();\n if (!pm) {\n pm = { agent: 'npm', name: 'npm' };\n }\n\n console.log(colors.gray(`Using package manager: ${pm.agent}`));\n\n for (const pkg of packages) {\n const resolved = resolveCommand(pm.agent, 'install', [\n pkg.name,\n ...(pkg.dev ? [pm.agent === 'yarn' ? '--dev' : '--save-dev'] : []),\n ]);\n if (!resolved) {\n throw new CliError(`Unable to determine how to install package \"${pkg.name}\". Please install it manually.`);\n }\n\n const spinner = ora(`Installing \"${pkg.name}\"`).start();\n try {\n execSync(`${resolved.command} ${resolved.args.join(' ')}`, {\n cwd: projectPath,\n });\n spinner.succeed();\n } catch (e) {\n spinner.fail();\n throw e;\n }\n }\n\n const generationFolder = 'zenstack';\n\n if (!fs.existsSync(path.join(projectPath, generationFolder))) {\n fs.mkdirSync(path.join(projectPath, generationFolder));\n }\n\n if (!fs.existsSync(path.join(projectPath, generationFolder, 'schema.zmodel'))) {\n fs.writeFileSync(path.join(projectPath, generationFolder, 'schema.zmodel'), STARTER_ZMODEL);\n } else {\n console.log(colors.yellow('Schema file already exists. Skipping generation of sample.'));\n }\n\n console.log(colors.green('ZenStack project initialized successfully!'));\n console.log(colors.gray(`See \"${generationFolder}/schema.zmodel\" for your database schema.`));\n console.log(colors.gray('Run `zenstack generate` to compile the the schema into a TypeScript file.'));\n}\n","export const STARTER_ZMODEL = `// This is a sample model to get you started.\n\n/// A sample data source using local sqlite db.\ndatasource db {\n provider = 'sqlite'\n url = 'file:./dev.db'\n}\n\n/// User model\nmodel User {\n id String @id @default(cuid())\n email String @unique @email @length(6, 32)\n posts Post[]\n}\n\n/// Post model\nmodel Post {\n id String @id @default(cuid())\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n title String @length(1, 256)\n content String\n published Boolean @default(false)\n author User @relation(fields: [authorId], references: [id])\n authorId String\n}\n`;\n\nexport const STARTER_MAIN_TS = `import { ZenStackClient } from '@zenstackhq/runtime';\nimport SQLite from 'better-sqlite3';\nimport { SqliteDialect } from 'kysely';\nimport { schema } from './zenstack/schema';\n\nasync function main() {\n const client = new ZenStackClient(schema, {\n dialect: new SqliteDialect({\n database: new SQLite('./zenstack/dev.db'),\n }),\n });\n const user = await client.user.create({\n data: {\n email: 'test@zenstack.dev',\n posts: {\n create: [\n {\n title: 'Hello World',\n content: 'This is a test post',\n },\n ],\n },\n },\n include: { posts: true }\n });\n console.log('User created:', user);\n}\n\nmain();\n`;\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile } from './action-utils';\n\ntype CommonOptions = {\n schema?: string;\n migrations?: string;\n};\n\ntype DevOptions = CommonOptions & {\n name?: string;\n createOnly?: boolean;\n};\n\ntype ResetOptions = CommonOptions & {\n force?: boolean;\n};\n\ntype DeployOptions = CommonOptions;\n\ntype StatusOptions = CommonOptions;\n\n/**\n * CLI action for migration-related commands\n */\nexport async function run(command: string, options: CommonOptions) {\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaDir = options.migrations ? path.dirname(options.migrations) : undefined;\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile, prismaSchemaDir);\n\n try {\n switch (command) {\n case 'dev':\n await runDev(prismaSchemaFile, options as DevOptions);\n break;\n\n case 'reset':\n await runReset(prismaSchemaFile, options as ResetOptions);\n break;\n\n case 'deploy':\n await runDeploy(prismaSchemaFile, options as DeployOptions);\n break;\n\n case 'status':\n await runStatus(prismaSchemaFile, options as StatusOptions);\n break;\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n\nasync function runDev(prismaSchemaFile: string, options: DevOptions) {\n try {\n const cmd = [\n 'prisma migrate dev',\n ` --schema \"${prismaSchemaFile}\"`,\n ' --skip-generate',\n options.name ? ` --name ${options.name}` : '',\n options.createOnly ? ' --create-only' : '',\n ].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runReset(prismaSchemaFile: string, options: ResetOptions) {\n try {\n const cmd = ['prisma migrate reset', ` --schema \"${prismaSchemaFile}\"`, options.force ? ' --force' : ''].join(\n '',\n );\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runDeploy(prismaSchemaFile: string, _options: DeployOptions) {\n try {\n const cmd = ['prisma migrate deploy', ` --schema \"${prismaSchemaFile}\"`].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runStatus(prismaSchemaFile: string, _options: StatusOptions) {\n try {\n await execPackage(`prisma migrate status --schema \"${prismaSchemaFile}\"`);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n","import colors from 'colors';\nimport { getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n};\n\n/**\n * CLI action for validating schema without generation\n */\nexport async function run(options: Options) {\n const schemaFile = getSchemaFile(options.schema);\n\n try {\n await loadSchemaDocument(schemaFile);\n console.log(colors.green('✓ Schema validation completed successfully.'));\n } catch (error) {\n console.error(colors.red('✗ Schema validation failed.'));\n // Re-throw to maintain CLI exit code behavior\n throw error;\n }\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\nexport function getVersion() {\n try {\n // isomorphic __dirname\n const _dirname = typeof __dirname !== 'undefined' ? __dirname : path.dirname(fileURLToPath(import.meta.url));\n return JSON.parse(fs.readFileSync(path.join(_dirname, '../package.json'), 'utf8')).version;\n } catch {\n return undefined;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;IAAAA,mBAAuC;AACvC,IAAAC,iBAAmB;AACnB,uBAAgD;;;ACFhD,IAAAC,kBAAe;;;ACAf,2BAAwD;AAKjD,SAASC,SAASC,KAAaC,SAAyE;AAC3G,QAAM,EAAEC,KAAK,GAAGC,YAAAA,IAAgBF,WAAW,CAAC;AAC5C,QAAMG,YAAYF,MAAM;IAAE,GAAGG,QAAQH;IAAK,GAAGA;EAAI,IAAII;AACrDC,2BAAAA,UAAMP,KAAK;IACPQ,UAAU;IACVC,OAAOR,SAASQ,SAAS;IACzBP,KAAKE;IACL,GAAGD;EACP,CAAA;AACJ;AATgBJ;AAcT,SAASW,YACZV,KACAC,SAAyE;AAEzE,QAAMU,iBAAiBN,SAASO,WAAW,KAAA,IAAS,SAAS;AAC7Db,WAAS,GAAGY,cAAAA,IAAkBX,GAAAA,IAAOC,OAAAA;AACzC;AANgBS;;;ACnBhB,sBAA6B;AAC7B,iBAA6B;AAC7B,iBAAsC;AACtC,oBAAmB;AACnB,qBAAe;AACf,uBAAiB;;;ACFV,IAAMG,WAAN,cAAuBC,MAAAA;EAH9B,OAG8BA;;;AAAO;;;ADK9B,SAASC,cAAcC,MAAa;AACvC,MAAIA,MAAM;AACN,QAAI,CAACC,eAAAA,QAAGC,WAAWF,IAAAA,GAAO;AACtB,YAAM,IAAIG,SAAS,0BAA0BH,IAAAA,EAAM;IACvD;AACA,WAAOA;EACX;AAEA,QAAMI,gBAAgBC,iBAAiBC,QAAQC,IAAG,CAAA;AAClD,MAAIH,cAAcI,QAAQ;AACtB,QAAI,CAACP,eAAAA,QAAGC,WAAWE,cAAcI,MAAM,GAAG;AACtC,YAAM,IAAIL,SAAS,0BAA0BC,cAAcI,MAAM,EAAE;IACvE;AACA,WAAOJ,cAAcI;EACzB;AAEA,MAAIP,eAAAA,QAAGC,WAAW,0BAAA,GAA6B;AAC3C,WAAO;EACX,WAAWD,eAAAA,QAAGC,WAAW,iBAAA,GAAoB;AACzC,WAAO;EACX,OAAO;AACH,UAAM,IAAIC,SACN,+FAAA;EAER;AACJ;AAzBgBJ;AA2BhB,eAAsBU,mBAAmBC,YAAkB;AACvD,QAAMC,aAAa,UAAMC,8BAAaF,UAAAA;AACtC,MAAI,CAACC,WAAWE,SAAS;AACrBF,eAAWG,OAAOC,QAAQ,CAACC,QAAAA;AACvBC,cAAQC,MAAMC,cAAAA,QAAOC,IAAIJ,GAAAA,CAAAA;IAC7B,CAAA;AACA,UAAM,IAAIb,SAAS,gDAAA;EACvB;AACAQ,aAAWU,SAASN,QAAQ,CAACO,SAAAA;AACzBL,YAAQK,KAAKH,cAAAA,QAAOI,OAAOD,IAAAA,CAAAA;EAC/B,CAAA;AACA,SAAOX,WAAWa;AACtB;AAZsBf;AAcf,SAASgB,sBAAsBT,KAAY;AAC9C,MAAIA,eAAeU,SAAS,YAAYV,OAAO,OAAOA,IAAIW,WAAW,UAAU;AAC3ErB,YAAQsB,KAAKZ,IAAIW,MAAM;EAC3B,OAAO;AACHrB,YAAQsB,KAAK,CAAA;EACjB;AACJ;AANgBH;AAQhB,eAAsBI,yBAAyBC,YAAoBC,QAAe;AAC9E,QAAMP,QAAQ,MAAMf,mBAAmBqB,UAAAA;AACvC,MAAI,CAACN,MAAMQ,aAAaC,KAAKC,uBAAAA,GAAe;AACxC,UAAM,IAAI/B,SAAS,iCAAA;EACvB;AACA,QAAMgC,eAAe,MAAM,IAAIC,iCAAsBZ,KAAAA,EAAOa,SAAQ;AACpE,MAAI,CAACN,QAAQ;AACTA,aAASO,iBAAAA,QAAKC,QAAQT,UAAAA;EAC1B;AACA,QAAMU,mBAAmBF,iBAAAA,QAAKG,QAAQV,QAAQ,gBAAA;AAC9C9B,iBAAAA,QAAGyC,cAAcF,kBAAkBL,YAAAA;AACnC,SAAOK;AACX;AAZsBX;AAcf,SAASxB,iBAAiBsC,WAAiB;AAC9C,QAAMC,SAAqE;IAAEpC,QAAQqC;IAAWC,QAAQD;EAAU;AAClH,QAAME,cAAcC,OAAO;IAAC;KAAiBL,WAAW,KAAA;AAExD,MAAI,CAACI,aAAa;AACd,WAAOH;EACX;AAEA,MAAIK,UAAeJ;AACnB,MAAI;AACAI,cAAUC,KAAKC,MAAMlD,eAAAA,QAAGmD,aAAaL,aAAa,MAAA,CAAA;EACtD,QAAQ;AACJ,WAAOH;EACX;AAEA,MAAIK,QAAQI,YAAY,OAAOJ,QAAQI,aAAa,UAAU;AAC1DT,WAAOpC,SAASyC,QAAQI,SAAS7C,UAAU8B,iBAAAA,QAAKG,QAAQH,iBAAAA,QAAKC,QAAQQ,WAAAA,GAAcE,QAAQI,SAAS7C,MAAM;AAC1GoC,WAAOE,SAASG,QAAQI,SAASP,UAAUR,iBAAAA,QAAKG,QAAQH,iBAAAA,QAAKC,QAAQQ,WAAAA,GAAcE,QAAQI,SAASP,MAAM;EAC9G;AAEA,SAAOF;AACX;AArBgBvC;AAyBhB,SAAS2C,OACLM,OACA/C,MAAcD,QAAQC,IAAG,GACzBgD,WAAqB,OACrBX,SAAmB,CAAA,GAAE;AAErB,MAAI,CAACU,MAAMrB,KAAK,CAACuB,SAAS,CAAC,CAACA,IAAAA,GAAO;AAC/B,WAAOX;EACX;AACA,QAAMY,SAASH,MAAMI,KAAK,CAACF,SAASvD,eAAAA,QAAGC,WAAWoC,iBAAAA,QAAKqB,KAAKpD,KAAKiD,IAAAA,CAAAA,CAAAA;AACjE,MAAID,aAAa,SAASE,QAAQ;AAC9B,WAAOnB,iBAAAA,QAAKqB,KAAKpD,KAAKkD,MAAAA;EAC1B;AACA,MAAIA,QAAQ;AACRb,WAAOgB,KAAKtB,iBAAAA,QAAKqB,KAAKpD,KAAKkD,MAAAA,CAAAA;EAC/B;AACA,QAAMI,KAAKvB,iBAAAA,QAAKG,QAAQlC,KAAK,IAAA;AAC7B,MAAIsD,OAAOtD,KAAK;AACZ,WAAQgD,YAAYX,OAAOkB,SAAS,IAAIlB,SAASC;EACrD;AACA,SAAOG,OAAOM,OAAOO,IAAIN,UAAUX,MAAAA;AACvC;AArBSI;;;AFnFT,eAAsBe,IAAIC,SAAiBC,SAAgB;AACvD,UAAQD,SAAAA;IACJ,KAAK;AACD,YAAME,QAAQD,OAAAA;AACd;EACR;AACJ;AANsBF;AAQtB,eAAeG,QAAQD,SAAgB;AAEnC,QAAME,aAAaC,cAAcH,QAAQI,MAAM;AAC/C,QAAMC,mBAAmB,MAAMC,yBAAyBJ,UAAAA;AAExD,MAAI;AAEA,UAAMK,MAAM;MACR;MACA,cAAcF,gBAAAA;MACdL,QAAQQ,iBAAiB,wBAAwB;MACjDR,QAAQS,aAAa,mBAAmB;MACxC;MACFC,KAAK,EAAA;AAEP,QAAI;AACA,YAAMC,YAAYJ,GAAAA;IACtB,SAASK,KAAK;AACVC,4BAAsBD,GAAAA;IAC1B;EACJ,UAAA;AACI,QAAIE,gBAAAA,QAAGC,WAAWV,gBAAAA,GAAmB;AACjCS,sBAAAA,QAAGE,WAAWX,gBAAAA;IAClB;EACJ;AACJ;AAzBeJ;;;AIrBf,4BAA0B;AAC1B,IAAAgB,cAAkD;AAClD,IAAAC,cAA4E;AAC5E,IAAAC,iBAAmB;AACnB,IAAAC,kBAAe;AACf,IAAAC,oBAAiB;AAajB,eAAsBC,KAAIC,SAAgB;AACtC,QAAMC,QAAQC,KAAKC,IAAG;AAEtB,QAAMC,aAAaC,cAAcL,QAAQM,MAAM;AAE/C,QAAMC,QAAQ,MAAMC,mBAAmBJ,UAAAA;AACvC,QAAMK,aAAaC,cAAcV,SAASI,UAAAA;AAG1C,QAAMO,eAAeC,kBAAAA,QAAKC,KAAKJ,YAAY,WAAA;AAC3C,QAAM,IAAIK,8BAAAA,EAAoBC,SAASX,YAAY,CAAA,GAAIK,UAAAA;AAEvD,QAAMO,WAAWT,OAAOE,YAAYE,YAAAA;AAGpC,MAAIX,QAAQiB,kBAAkB;AAC1B,UAAMC,eAAe,MAAM,IAAIC,kCAAsBZ,KAAAA,EAAOQ,SAAQ;AACpE,QAAIK,mBAAmBR,kBAAAA,QAAKC,KAAKJ,YAAY,eAAA;AAC7C,QAAI,OAAOT,QAAQiB,qBAAqB,UAAU;AAC9CG,yBAAmBR,kBAAAA,QAAKS,QAAQZ,YAAYT,QAAQiB,gBAAgB;AACpEK,sBAAAA,QAAGC,UAAUX,kBAAAA,QAAKY,QAAQJ,gBAAAA,GAAmB;QAAEK,WAAW;MAAK,CAAA;IACnE;AACAH,oBAAAA,QAAGI,cAAcN,kBAAkBF,YAAAA;EACvC;AAEA,MAAI,CAAClB,QAAQ2B,QAAQ;AACjBC,YAAQC,IAAIC,eAAAA,QAAOC,MAAM,wCAAwC7B,KAAKC,IAAG,IAAKF,KAAAA,KAAU,CAAA;AACxF2B,YAAQC,IAAI;;;;0BAIMpB,UAAAA;;;;;OAKnB;EACH;AACJ;AAtCsBV,OAAAA,MAAAA;AAwCtB,SAASW,cAAcV,SAAkBI,YAAkB;AACvD,MAAIJ,QAAQgC,QAAQ;AAChB,WAAOhC,QAAQgC;EACnB;AACA,QAAMC,gBAAgBC,iBAAiBC,QAAQC,IAAG,CAAA;AAClD,MAAIH,cAAcD,QAAQ;AACtB,WAAOC,cAAcD;EACzB,OAAO;AACH,WAAOpB,kBAAAA,QAAKY,QAAQpB,UAAAA;EACxB;AACJ;AAVSM;AAYT,eAAeM,WAAWT,OAAcE,YAAoBE,cAAoB;AAC5E,QAAM0B,UAAU9B,MAAM+B,aAAaC,OAAOC,oBAAAA;AAC1C,aAAWC,UAAUJ,SAAS;AAC1B,UAAMK,gBAAgBD,OAAOE,OAAOC,KAAK,CAACC,MAAMA,EAAEC,SAAS,UAAA;AAC3DC,yCAAUL,eAAe,UAAUD,OAAOK,IAAI,iCAAiC;AAC/E,UAAME,WAAYN,cAAcO,MAAsBA;AACtD,QAAIC,cAAcF;AAClB,QAAIE,YAAYC,WAAW,QAAA,GAAW;AAClCD,oBAAc,+BAA+BA,YAAYE,MAAM,CAAA,CAAA;IACnE;AACA,UAAMC,aAAa,MAAM,OAAOH,cAAcI;AAC9C1B,YAAQC,IAAI,sBAAsBmB,QAAAA;AAClC,UAAMK,UAAU;MAAE9C;MAAOE;MAAYE;IAAa,CAAA;EACtD;AACJ;AAdeK;;;ACtEf,IAAAuC,iBAAmB;AACnB,IAAAC,oBAAiB;AAKjB,eAAsBC,KAAIC,aAAmB;AACzC,QAAMC,WAAW,MAAMC,oBAAoBF,WAAAA;AAC3C,MAAI,CAACC,UAAU;AACXE,YAAQC,MAAM,sEAAA;AACd;EACJ;AAEAD,UAAQE,IAAI,8BAAA;AACZ,QAAMC,WAAW,oBAAIC,IAAAA;AACrB,aAAW,EAAEC,KAAKC,QAAO,KAAMR,UAAU;AACrC,QAAIQ,SAAS;AACTH,eAASI,IAAID,OAAAA;IACjB;AACAN,YAAQE,IAAI,OAAOM,eAAAA,QAAOC,MAAMJ,IAAIK,OAAO,EAAA,CAAA,CAAA,IAASJ,OAAAA,EAAS;EACjE;AAEA,MAAIH,SAASQ,OAAO,GAAG;AACnBX,YAAQY,KAAKJ,eAAAA,QAAOK,OAAO,kFAAA,CAAA;EAC/B;AACJ;AAnBsBjB,OAAAA,MAAAA;AAqBtB,eAAeG,oBAAoBF,aAAmB;AAClD,MAAIiB;AAIJ,QAAMC,eAAeC,kBAAAA,QAAKC,QAAQpB,WAAAA;AAClC,MAAI;AACAiB,eACI,MAAM,OAAOE,kBAAAA,QAAKE,KAAKH,cAAc,cAAA,GAAiB;MAClDI,MAAM;QAAEC,MAAM;MAAO;IACzB,IACFC;EACN,QAAQ;AACJ,WAAO,CAAA;EACX;AAEA,QAAMvB,WAAWwB,MAAMC,KACnB,IAAInB,IACA;OAAIoB,OAAOC,KAAKX,QAAQY,gBAAgB,CAAC,CAAA;OAAOF,OAAOC,KAAKX,QAAQa,mBAAmB,CAAC,CAAA;IAAIC,OACxF,CAACC,MAAMA,EAAEC,WAAW,cAAA,KAAmBD,MAAM,UAAA,CAAA,CAAA,EAGvDE,KAAI;AAEN,QAAMC,SAAS,MAAMC,QAAQC,IACzBpC,SAASqC,IAAI,OAAO9B,QAAAA;AAChB,QAAI;AACA,YAAM+B,cACF,MAAM,OAAO,GAAG/B,GAAAA,iBAAoB;QAChCc,MAAM;UAAEC,MAAM;QAAO;MACzB,IACFC;AACF,aAAO;QAAEhB;QAAKC,SAAS8B,WAAW9B;MAAkB;IACxD,QAAQ;AACJ,aAAO;QAAED;QAAKC,SAAS+B;MAAU;IACrC;EACJ,CAAA,CAAA;AAGJ,SAAOL;AACX;AAxCejC;;;AC3Bf,IAAAuC,iBAAmB;AACnB,IAAAC,kBAAe;AACf,IAAAC,oBAAiB;AACjB,iBAAgB;AAChB,sCAAuC;;;ACJhC,IAAMC,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ADY9B,eAAsBC,KAAIC,aAAmB;AACzC,QAAMC,WAAW;IACb;MAAEC,MAAM;MAAwBC,KAAK;IAAK;IAC1C;MAAED,MAAM;MAA4BC,KAAK;IAAM;;AAEnD,MAAIC,KAAK,UAAMC,wCAAAA;AACf,MAAI,CAACD,IAAI;AACLA,SAAK;MAAEE,OAAO;MAAOJ,MAAM;IAAM;EACrC;AAEAK,UAAQC,IAAIC,eAAAA,QAAOC,KAAK,0BAA0BN,GAAGE,KAAK,EAAE,CAAA;AAE5D,aAAWK,OAAOV,UAAU;AACxB,UAAMW,eAAWC,gDAAeT,GAAGE,OAAO,WAAW;MACjDK,IAAIT;SACAS,IAAIR,MAAM;QAACC,GAAGE,UAAU,SAAS,UAAU;UAAgB,CAAA;KAClE;AACD,QAAI,CAACM,UAAU;AACX,YAAM,IAAIE,SAAS,+CAA+CH,IAAIT,IAAI,gCAAgC;IAC9G;AAEA,UAAMa,cAAUC,WAAAA,SAAI,eAAeL,IAAIT,IAAI,GAAG,EAAEe,MAAK;AACrD,QAAI;AACAC,eAAS,GAAGN,SAASO,OAAO,IAAIP,SAASQ,KAAKC,KAAK,GAAA,CAAA,IAAQ;QACvDC,KAAKtB;MACT,CAAA;AACAe,cAAQQ,QAAO;IACnB,SAASC,GAAG;AACRT,cAAQU,KAAI;AACZ,YAAMD;IACV;EACJ;AAEA,QAAME,mBAAmB;AAEzB,MAAI,CAACC,gBAAAA,QAAGC,WAAWC,kBAAAA,QAAKR,KAAKrB,aAAa0B,gBAAAA,CAAAA,GAAoB;AAC1DC,oBAAAA,QAAGG,UAAUD,kBAAAA,QAAKR,KAAKrB,aAAa0B,gBAAAA,CAAAA;EACxC;AAEA,MAAI,CAACC,gBAAAA,QAAGC,WAAWC,kBAAAA,QAAKR,KAAKrB,aAAa0B,kBAAkB,eAAA,CAAA,GAAmB;AAC3EC,oBAAAA,QAAGI,cAAcF,kBAAAA,QAAKR,KAAKrB,aAAa0B,kBAAkB,eAAA,GAAkBM,cAAAA;EAChF,OAAO;AACHzB,YAAQC,IAAIC,eAAAA,QAAOwB,OAAO,4DAAA,CAAA;EAC9B;AAEA1B,UAAQC,IAAIC,eAAAA,QAAOyB,MAAM,4CAAA,CAAA;AACzB3B,UAAQC,IAAIC,eAAAA,QAAOC,KAAK,QAAQgB,gBAAAA,2CAA2D,CAAA;AAC3FnB,UAAQC,IAAIC,eAAAA,QAAOC,KAAK,2EAAA,CAAA;AAC5B;AAhDsBX,OAAAA,MAAAA;;;AEZtB,IAAAoC,kBAAe;AACf,IAAAC,oBAAiB;AAyBjB,eAAsBC,KAAIC,SAAiBC,SAAsB;AAC7D,QAAMC,aAAaC,cAAcF,QAAQG,MAAM;AAC/C,QAAMC,kBAAkBJ,QAAQK,aAAaC,kBAAAA,QAAKC,QAAQP,QAAQK,UAAU,IAAIG;AAChF,QAAMC,mBAAmB,MAAMC,yBAAyBT,YAAYG,eAAAA;AAEpE,MAAI;AACA,YAAQL,SAAAA;MACJ,KAAK;AACD,cAAMY,OAAOF,kBAAkBT,OAAAA;AAC/B;MAEJ,KAAK;AACD,cAAMY,SAASH,kBAAkBT,OAAAA;AACjC;MAEJ,KAAK;AACD,cAAMa,UAAUJ,kBAAkBT,OAAAA;AAClC;MAEJ,KAAK;AACD,cAAMc,UAAUL,kBAAkBT,OAAAA;AAClC;IACR;EACJ,UAAA;AACI,QAAIe,gBAAAA,QAAGC,WAAWP,gBAAAA,GAAmB;AACjCM,sBAAAA,QAAGE,WAAWR,gBAAAA;IAClB;EACJ;AACJ;AA5BsBX,OAAAA,MAAAA;AA8BtB,eAAea,OAAOF,kBAA0BT,SAAmB;AAC/D,MAAI;AACA,UAAMkB,MAAM;MACR;MACA,cAAcT,gBAAAA;MACd;MACAT,QAAQmB,OAAO,WAAWnB,QAAQmB,IAAI,KAAK;MAC3CnB,QAAQoB,aAAa,mBAAmB;MAC1CC,KAAK,EAAA;AAEP,UAAMC,YAAYJ,GAAAA;EACtB,SAASK,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AAdeZ;AAgBf,eAAeC,SAASH,kBAA0BT,SAAqB;AACnE,MAAI;AACA,UAAMkB,MAAM;MAAC;MAAwB,cAAcT,gBAAAA;MAAqBT,QAAQyB,QAAQ,aAAa;MAAIJ,KACrG,EAAA;AAGJ,UAAMC,YAAYJ,GAAAA;EACtB,SAASK,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AAVeX;AAYf,eAAeC,UAAUJ,kBAA0BiB,UAAuB;AACtE,MAAI;AACA,UAAMR,MAAM;MAAC;MAAyB,cAAcT,gBAAAA;MAAqBY,KAAK,EAAA;AAE9E,UAAMC,YAAYJ,GAAAA;EACtB,SAASK,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AAReV;AAUf,eAAeC,UAAUL,kBAA0BiB,UAAuB;AACtE,MAAI;AACA,UAAMJ,YAAY,mCAAmCb,gBAAAA,GAAmB;EAC5E,SAASc,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AANeT;AAQf,SAASU,uBAAsBD,KAAY;AACvC,MAAIA,eAAeI,SAAS,YAAYJ,OAAO,OAAOA,IAAIK,WAAW,UAAU;AAC3EC,YAAQC,KAAKP,IAAIK,MAAM;EAC3B,OAAO;AACHC,YAAQC,KAAK,CAAA;EACjB;AACJ;AANSN,OAAAA,wBAAAA;;;ACtGT,IAAAO,iBAAmB;AAUnB,eAAsBC,KAAIC,SAAgB;AACtC,QAAMC,aAAaC,cAAcF,QAAQG,MAAM;AAE/C,MAAI;AACA,UAAMC,mBAAmBH,UAAAA;AACzBI,YAAQC,IAAIC,eAAAA,QAAOC,MAAM,kDAAA,CAAA;EAC7B,SAASC,OAAO;AACZJ,YAAQI,MAAMF,eAAAA,QAAOG,IAAI,kCAAA,CAAA;AAEzB,UAAMD;EACV;AACJ;AAXsBV,OAAAA,MAAAA;;;ACVtB,IAAAY,kBAAe;AACf,IAAAC,oBAAiB;AACjB,sBAA8B;AAF9B;AAIO,SAASC,aAAAA;AACZ,MAAI;AAEA,UAAMC,WAAW,OAAOC,cAAc,cAAcA,YAAYC,kBAAAA,QAAKC,YAAQC,+BAAc,YAAYC,GAAG,CAAA;AAC1G,WAAOC,KAAKC,MAAMC,gBAAAA,QAAGC,aAAaP,kBAAAA,QAAKQ,KAAKV,UAAU,iBAAA,GAAoB,MAAA,CAAA,EAASW;EACvF,QAAQ;AACJ,WAAOC;EACX;AACJ;AARgBb;;;AXGhB,IAAMc,iBAAiB,8BAAOC,YAAAA;AAC1B,QAAcC,KAASD,OAAAA;AAC3B,GAFuB;AAIvB,IAAME,gBAAgB,8BAAOC,SAAiBH,YAAAA;AAC1C,QAAcI,KAAQD,SAASH,OAAAA;AACnC,GAFsB;AAItB,IAAMK,WAAW,8BAAOF,SAAiBH,YAAAA;AACrC,QAAcM,IAAGH,SAASH,OAAAA;AAC9B,GAFiB;AAIjB,IAAMO,aAAa,8BAAOC,gBAAAA;AACtB,QAAcC,KAAKD,WAAAA;AACvB,GAFmB;AAInB,IAAME,aAAa,8BAAOF,gBAAAA;AACtB,QAAcG,KAAKH,WAAAA;AACvB,GAFmB;AAInB,IAAMI,iBAAiB,8BAAOZ,YAAAA;AAC1B,QAAca,KAASb,OAAAA;AAC3B,GAFuB;AAIhB,SAASc,gBAAAA;AACZ,QAAMC,WAAU,IAAIC,yBAAQ,UAAA;AAE5BD,EAAAA,SAAQE,QAAQC,WAAAA,GAAe,gBAAgB,qBAAA;AAE/C,QAAMC,mBAAmBC,wCAAuBC,eAAeC,KAAK,IAAA;AAEpEP,EAAAA,SACKQ,YACG,GAAGC,eAAAA,QAAOC,KAAKC,KACX,QAAA,CAAA;;qCACkG,EAEzGC,mBAAkB,EAClBC,yBAAwB;AAE7B,QAAMC,eAAe,IAAIC,wBACrB,mBACA,+BAA+BX,gBAAAA,kEAAkF;AAGrHJ,EAAAA,SACKZ,QAAQ,UAAA,EACRoB,YAAY,sBAAA,EACZQ,UAAUF,YAAAA,EACVE,UAAU,IAAID,wBAAO,YAAY,yBAAA,CAAA,EACjCC,UACG,IAAID,wBACA,+BACA,iEAAA,CAAA,EAGPC,UAAU,IAAID,wBAAO,uBAAuB,2CAAA,CAAA,EAC5CE,OAAOjC,cAAAA;AAEZ,QAAMkC,iBAAiBlB,SAAQZ,QAAQ,SAAA,EAAWoB,YAAY,6CAAA;AAC9D,QAAMW,mBAAmB,IAAIJ,wBAAO,uBAAuB,qBAAA;AAE3DG,iBACK9B,QAAQ,KAAA,EACR4B,UAAUF,YAAAA,EACVE,UAAU,IAAID,wBAAO,qBAAqB,gBAAA,CAAA,EAC1CC,UAAU,IAAID,wBAAO,iBAAiB,qCAAA,CAAA,EACtCC,UAAUG,gBAAAA,EACVX,YAAY,yEAAA,EACZS,OAAO,CAAChC,YAAYE,cAAc,OAAOF,OAAAA,CAAAA;AAE9CiC,iBACK9B,QAAQ,OAAA,EACR4B,UAAUF,YAAAA,EACVE,UAAU,IAAID,wBAAO,WAAW,8BAAA,CAAA,EAChCC,UAAUG,gBAAAA,EACVX,YAAY,sEAAA,EACZS,OAAO,CAAChC,YAAYE,cAAc,SAASF,OAAAA,CAAAA;AAEhDiC,iBACK9B,QAAQ,QAAA,EACR4B,UAAUF,YAAAA,EACVE,UAAUG,gBAAAA,EACVX,YAAY,qEAAA,EACZS,OAAO,CAAChC,YAAYE,cAAc,UAAUF,OAAAA,CAAAA;AAEjDiC,iBACK9B,QAAQ,QAAA,EACR4B,UAAUF,YAAAA,EACVE,UAAUG,gBAAAA,EACVX,YAAY,+CAAA,EACZS,OAAO,CAAChC,YAAYE,cAAc,UAAUF,OAAAA,CAAAA;AAEjD,QAAMmC,YAAYpB,SAAQZ,QAAQ,IAAA,EAAMoB,YAAY,iDAAA;AAEpDY,YACKhC,QAAQ,MAAA,EACRoB,YAAY,kDAAA,EACZQ,UAAUF,YAAAA,EACVE,UAAU,IAAID,wBAAO,sBAAsB,2BAAA,CAAA,EAC3CC,UAAU,IAAID,wBAAO,iBAAiB,2CAAA,CAAA,EACtCE,OAAO,CAAChC,YAAYK,SAAS,QAAQL,OAAAA,CAAAA;AAE1Ce,EAAAA,SACKZ,QAAQ,MAAA,EACRoB,YAAY,6DAAA,EACZa,SAAS,UAAU,gBAAgB,GAAA,EACnCJ,OAAOzB,UAAAA;AAEZQ,EAAAA,SACKZ,QAAQ,MAAA,EACRoB,YAAY,8CAAA,EACZa,SAAS,UAAU,gBAAgB,GAAA,EACnCJ,OAAOtB,UAAAA;AAEZK,EAAAA,SAAQZ,QAAQ,UAAA,EAAYoB,YAAY,2BAAA,EAA6BQ,UAAUF,YAAAA,EAAcG,OAAOpB,cAAAA;AAEpG,SAAOG;AACX;AA9FgBD;AAgGhB,IAAMC,UAAUD,cAAAA;AAEhBC,QAAQsB,WAAU,EAAGC,MAAM,CAACC,QAAAA;AACxB,MAAIA,eAAeC,UAAU;AACzBC,YAAQC,MAAMlB,eAAAA,QAAOmB,IAAIJ,IAAIK,OAAO,CAAA;AACpCC,YAAQC,KAAK,CAAA;EACjB,WAAWP,eAAeQ,iCAAgB;AAEtCF,YAAQC,KAAKP,IAAIS,QAAQ;EAC7B,OAAO;AACHP,YAAQC,MAAMlB,eAAAA,QAAOmB,IAAI,+BAAA,CAAA;AACzBF,YAAQC,MAAMH,GAAAA;AACdM,YAAQC,KAAK,CAAA;EACjB;AACJ,CAAA;","names":["import_language","import_colors","import_node_fs","execSync","cmd","options","env","restOptions","mergedEnv","process","undefined","_exec","encoding","stdio","execPackage","packageManager","versions","CliError","Error","getSchemaFile","file","fs","existsSync","CliError","pkgJsonConfig","getPkgJsonConfig","process","cwd","schema","loadSchemaDocument","schemaFile","loadResult","loadDocument","success","errors","forEach","err","console","error","colors","red","warnings","warn","yellow","model","handleSubProcessError","Error","status","exit","generateTempPrismaSchema","zmodelPath","folder","declarations","some","isDataSource","prismaSchema","PrismaSchemaGenerator","generate","path","dirname","prismaSchemaFile","resolve","writeFileSync","startPath","result","undefined","output","pkgJsonFile","findUp","pkgJson","JSON","parse","readFileSync","zenstack","names","multiple","name","target","find","join","push","up","length","run","command","options","runPush","schemaFile","getSchemaFile","schema","prismaSchemaFile","generateTempPrismaSchema","cmd","acceptDataLoss","forceReset","join","execPackage","err","handleSubProcessError","fs","existsSync","unlinkSync","import_ast","import_sdk","import_colors","import_node_fs","import_node_path","run","options","start","Date","now","schemaFile","getSchemaFile","schema","model","loadSchemaDocument","outputPath","getOutputPath","tsSchemaFile","path","join","TsSchemaGenerator","generate","runPlugins","savePrismaSchema","prismaSchema","PrismaSchemaGenerator","prismaSchemaFile","resolve","fs","mkdirSync","dirname","recursive","writeFileSync","silent","console","log","colors","green","output","pkgJsonConfig","getPkgJsonConfig","process","cwd","plugins","declarations","filter","isPlugin","plugin","providerField","fields","find","f","name","invariant","provider","value","useProvider","startsWith","slice","generator","default","import_colors","import_node_path","run","projectPath","packages","getZenStackPackages","console","error","log","versions","Set","pkg","version","add","colors","green","padEnd","size","warn","yellow","pkgJson","resolvedPath","path","resolve","join","with","type","default","Array","from","Object","keys","dependencies","devDependencies","filter","p","startsWith","sort","result","Promise","all","map","depPkgJson","undefined","import_colors","import_node_fs","import_node_path","STARTER_ZMODEL","run","projectPath","packages","name","dev","pm","detect","agent","console","log","colors","gray","pkg","resolved","resolveCommand","CliError","spinner","ora","start","execSync","command","args","join","cwd","succeed","e","fail","generationFolder","fs","existsSync","path","mkdirSync","writeFileSync","STARTER_ZMODEL","yellow","green","import_node_fs","import_node_path","run","command","options","schemaFile","getSchemaFile","schema","prismaSchemaDir","migrations","path","dirname","undefined","prismaSchemaFile","generateTempPrismaSchema","runDev","runReset","runDeploy","runStatus","fs","existsSync","unlinkSync","cmd","name","createOnly","join","execPackage","err","handleSubProcessError","force","_options","Error","status","process","exit","import_colors","run","options","schemaFile","getSchemaFile","schema","loadSchemaDocument","console","log","colors","green","error","red","import_node_fs","import_node_path","getVersion","_dirname","__dirname","path","dirname","fileURLToPath","url","JSON","parse","fs","readFileSync","join","version","undefined","generateAction","options","generate","migrateAction","command","migrate","dbAction","db","infoAction","projectPath","info","initAction","init","validateAction","validate","createProgram","program","Command","version","getVersion","schemaExtensions","ZModelLanguageMetaData","fileExtensions","join","description","colors","bold","blue","showHelpAfterError","showSuggestionAfterError","schemaOption","Option","addOption","action","migrateCommand","migrationsOption","dbCommand","argument","parseAsync","catch","err","CliError","console","error","red","message","process","exit","CommanderError","exitCode"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/actions/db.ts","../src/utils/exec-utils.ts","../src/actions/action-utils.ts","../src/cli-error.ts","../src/actions/generate.ts","../src/actions/info.ts","../src/actions/init.ts","../src/actions/templates.ts","../src/actions/migrate.ts","../src/actions/validate.ts","../src/utils/version-utils.ts"],"sourcesContent":["import { ZModelLanguageMetaData } from '@zenstackhq/language';\nimport colors from 'colors';\nimport { Command, CommanderError, Option } from 'commander';\nimport * as actions from './actions';\nimport { CliError } from './cli-error';\nimport { getVersion } from './utils/version-utils';\n\nconst generateAction = async (options: Parameters<typeof actions.generate>[0]): Promise<void> => {\n await actions.generate(options);\n};\n\nconst migrateAction = async (command: string, options: any): Promise<void> => {\n await actions.migrate(command, options);\n};\n\nconst dbAction = async (command: string, options: any): Promise<void> => {\n await actions.db(command, options);\n};\n\nconst infoAction = async (projectPath: string): Promise<void> => {\n await actions.info(projectPath);\n};\n\nconst initAction = async (projectPath: string): Promise<void> => {\n await actions.init(projectPath);\n};\n\nconst validateAction = async (options: Parameters<typeof actions.validate>[0]): Promise<void> => {\n await actions.validate(options);\n};\n\nexport function createProgram() {\n const program = new Command('zenstack');\n\n program.version(getVersion()!, '-v --version', 'display CLI version');\n\n const schemaExtensions = ZModelLanguageMetaData.fileExtensions.join(', ');\n\n program\n .description(\n `${colors.bold.blue(\n 'ζ',\n )} ZenStack is a database access toolkit for TypeScript apps.\\n\\nDocumentation: https://zenstack.dev.`,\n )\n .showHelpAfterError()\n .showSuggestionAfterError();\n\n const schemaOption = new Option(\n '--schema <file>',\n `schema file (with extension ${schemaExtensions}). Defaults to \"schema.zmodel\" unless specified in package.json.`,\n );\n\n program\n .command('generate')\n .description('Run code generation.')\n .addOption(schemaOption)\n .addOption(new Option('--silent', 'do not print any output'))\n .addOption(\n new Option(\n '--save-prisma-schema [path]',\n 'save a Prisma schema file, by default into the output directory',\n ),\n )\n .addOption(new Option('-o, --output <path>', 'default output directory for core plugins'))\n .action(generateAction);\n\n const migrateCommand = program.command('migrate').description('Update the database schema with migrations.');\n const migrationsOption = new Option('--migrations <path>', 'path for migrations');\n\n migrateCommand\n .command('dev')\n .addOption(schemaOption)\n .addOption(new Option('-n, --name <name>', 'migration name'))\n .addOption(new Option('--create-only', 'only create migration, do not apply'))\n .addOption(migrationsOption)\n .description('Create a migration from changes in schema and apply it to the database.')\n .action((options) => migrateAction('dev', options));\n\n migrateCommand\n .command('reset')\n .addOption(schemaOption)\n .addOption(new Option('--force', 'skip the confirmation prompt'))\n .addOption(migrationsOption)\n .description('Reset your database and apply all migrations, all data will be lost.')\n .action((options) => migrateAction('reset', options));\n\n migrateCommand\n .command('deploy')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('Deploy your pending migrations to your production/staging database.')\n .action((options) => migrateAction('deploy', options));\n\n migrateCommand\n .command('status')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('Check the status of your database migrations.')\n .action((options) => migrateAction('status', options));\n\n migrateCommand\n .command('resolve')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .addOption(new Option('--applied <migration>', 'record a specific migration as applied'))\n .addOption(new Option('--rolled-back <migration>', 'record a specific migration as rolled back'))\n .description('Resolve issues with database migrations in deployment databases')\n .action((options) => migrateAction('resolve', options));\n\n const dbCommand = program.command('db').description('Manage your database schema during development.');\n\n dbCommand\n .command('push')\n .description('Push the state from your schema to your database')\n .addOption(schemaOption)\n .addOption(new Option('--accept-data-loss', 'ignore data loss warnings'))\n .addOption(new Option('--force-reset', 'force a reset of the database before push'))\n .action((options) => dbAction('push', options));\n\n program\n .command('info')\n .description('Get information of installed ZenStack and related packages.')\n .argument('[path]', 'project path', '.')\n .action(infoAction);\n\n program\n .command('init')\n .description('Initialize an existing project for ZenStack.')\n .argument('[path]', 'project path', '.')\n .action(initAction);\n\n program.command('validate').description('Validate a ZModel schema.').addOption(schemaOption).action(validateAction);\n\n return program;\n}\n\nconst program = createProgram();\n\nprogram.parseAsync().catch((err) => {\n if (err instanceof CliError) {\n console.error(colors.red(err.message));\n process.exit(1);\n } else if (err instanceof CommanderError) {\n // errors are already reported, just exit\n process.exit(err.exitCode);\n } else {\n console.error(colors.red('An unexpected error occurred:'));\n console.error(err);\n process.exit(1);\n }\n});\n","import fs from 'node:fs';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile, handleSubProcessError } from './action-utils';\n\ntype Options = {\n schema?: string;\n acceptDataLoss?: boolean;\n forceReset?: boolean;\n};\n\n/**\n * CLI action for db related commands\n */\nexport async function run(command: string, options: Options) {\n switch (command) {\n case 'push':\n await runPush(options);\n break;\n }\n}\n\nasync function runPush(options: Options) {\n // generate a temp prisma schema file\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile);\n\n try {\n // run prisma db push\n const cmd = [\n 'prisma db push',\n ` --schema \"${prismaSchemaFile}\"`,\n options.acceptDataLoss ? ' --accept-data-loss' : '',\n options.forceReset ? ' --force-reset' : '',\n ' --skip-generate',\n ].join('');\n\n try {\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n","import { execSync as _exec, type ExecSyncOptions } from 'child_process';\n\n/**\n * Utility for executing command synchronously and prints outputs on current console\n */\nexport function execSync(cmd: string, options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> }): void {\n const { env, ...restOptions } = options ?? {};\n const mergedEnv = env ? { ...process.env, ...env } : undefined;\n _exec(cmd, {\n encoding: 'utf-8',\n stdio: options?.stdio ?? 'inherit',\n env: mergedEnv,\n ...restOptions,\n });\n}\n\n/**\n * Utility for running package commands through npx/bunx\n */\nexport function execPackage(\n cmd: string,\n options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> },\n): void {\n const packageManager = process?.versions?.['bun'] ? 'bunx' : 'npx';\n execSync(`${packageManager} ${cmd}`, options);\n}\n","import { loadDocument } from '@zenstackhq/language';\nimport { isDataSource } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { CliError } from '../cli-error';\n\nexport function getSchemaFile(file?: string) {\n if (file) {\n if (!fs.existsSync(file)) {\n throw new CliError(`Schema file not found: ${file}`);\n }\n return file;\n }\n\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.schema) {\n if (!fs.existsSync(pkgJsonConfig.schema)) {\n throw new CliError(`Schema file not found: ${pkgJsonConfig.schema}`);\n }\n return pkgJsonConfig.schema;\n }\n\n if (fs.existsSync('./zenstack/schema.zmodel')) {\n return './zenstack/schema.zmodel';\n } else if (fs.existsSync('./schema.zmodel')) {\n return './schema.zmodel';\n } else {\n throw new CliError(\n 'Schema file not found in default locations (\"./zenstack/schema.zmodel\" or \"./schema.zmodel\").',\n );\n }\n}\n\nexport async function loadSchemaDocument(schemaFile: string) {\n const loadResult = await loadDocument(schemaFile);\n if (!loadResult.success) {\n loadResult.errors.forEach((err) => {\n console.error(colors.red(err));\n });\n throw new CliError('Schema contains errors. See above for details.');\n }\n loadResult.warnings.forEach((warn) => {\n console.warn(colors.yellow(warn));\n });\n return loadResult.model;\n}\n\nexport function handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n\nexport async function generateTempPrismaSchema(zmodelPath: string, folder?: string) {\n const model = await loadSchemaDocument(zmodelPath);\n if (!model.declarations.some(isDataSource)) {\n throw new CliError('Schema must define a datasource');\n }\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n if (!folder) {\n folder = path.dirname(zmodelPath);\n }\n const prismaSchemaFile = path.resolve(folder, '~schema.prisma');\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n return prismaSchemaFile;\n}\n\nexport function getPkgJsonConfig(startPath: string) {\n const result: { schema: string | undefined; output: string | undefined } = { schema: undefined, output: undefined };\n const pkgJsonFile = findUp(['package.json'], startPath, false);\n\n if (!pkgJsonFile) {\n return result;\n }\n\n let pkgJson: any = undefined;\n try {\n pkgJson = JSON.parse(fs.readFileSync(pkgJsonFile, 'utf8'));\n } catch {\n return result;\n }\n\n if (pkgJson.zenstack && typeof pkgJson.zenstack === 'object') {\n result.schema = pkgJson.zenstack.schema && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.schema);\n result.output = pkgJson.zenstack.output && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.output);\n }\n\n return result;\n}\n\ntype FindUpResult<Multiple extends boolean> = Multiple extends true ? string[] | undefined : string | undefined;\n\nfunction findUp<Multiple extends boolean = false>(\n names: string[],\n cwd: string = process.cwd(),\n multiple: Multiple = false as Multiple,\n result: string[] = [],\n): FindUpResult<Multiple> {\n if (!names.some((name) => !!name)) {\n return undefined;\n }\n const target = names.find((name) => fs.existsSync(path.join(cwd, name)));\n if (multiple === false && target) {\n return path.join(cwd, target) as FindUpResult<Multiple>;\n }\n if (target) {\n result.push(path.join(cwd, target));\n }\n const up = path.resolve(cwd, '..');\n if (up === cwd) {\n return (multiple && result.length > 0 ? result : undefined) as FindUpResult<Multiple>;\n }\n return findUp(names, up, multiple, result);\n}\n","/**\n * Indicating an error during CLI execution\n */\nexport class CliError extends Error {}\n","import { invariant } from '@zenstackhq/common-helpers';\nimport { isPlugin, LiteralExpr, type Model } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator, TsSchemaGenerator, type CliGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { getPkgJsonConfig, getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n output?: string;\n silent?: boolean;\n savePrismaSchema?: string | boolean;\n};\n\n/**\n * CLI action for generating code from schema\n */\nexport async function run(options: Options) {\n const start = Date.now();\n\n const schemaFile = getSchemaFile(options.schema);\n\n const model = await loadSchemaDocument(schemaFile);\n const outputPath = getOutputPath(options, schemaFile);\n\n // generate TS schema\n const tsSchemaFile = path.join(outputPath, 'schema.ts');\n await new TsSchemaGenerator().generate(schemaFile, [], outputPath);\n\n await runPlugins(model, outputPath, tsSchemaFile);\n\n // generate Prisma schema\n if (options.savePrismaSchema) {\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n let prismaSchemaFile = path.join(outputPath, 'schema.prisma');\n if (typeof options.savePrismaSchema === 'string') {\n prismaSchemaFile = path.resolve(outputPath, options.savePrismaSchema);\n fs.mkdirSync(path.dirname(prismaSchemaFile), { recursive: true });\n }\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n }\n\n if (!options.silent) {\n console.log(colors.green(`Generation completed successfully in ${Date.now() - start}ms.`));\n console.log(`You can now create a ZenStack client with it.\n\n\\`\\`\\`ts\nimport { ZenStackClient } from '@zenstackhq/runtime';\nimport { schema } from '${outputPath}/schema';\n\nconst client = new ZenStackClient(schema, {\n dialect: { ... }\n});\n\\`\\`\\``);\n }\n}\n\nfunction getOutputPath(options: Options, schemaFile: string) {\n if (options.output) {\n return options.output;\n }\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.output) {\n return pkgJsonConfig.output;\n } else {\n return path.dirname(schemaFile);\n }\n}\n\nasync function runPlugins(model: Model, outputPath: string, tsSchemaFile: string) {\n const plugins = model.declarations.filter(isPlugin);\n for (const plugin of plugins) {\n const providerField = plugin.fields.find((f) => f.name === 'provider');\n invariant(providerField, `Plugin ${plugin.name} does not have a provider field`);\n const provider = (providerField.value as LiteralExpr).value as string;\n let useProvider = provider;\n if (useProvider.startsWith('@core/')) {\n useProvider = `@zenstackhq/runtime/plugins/${useProvider.slice(6)}`;\n }\n const generator = (await import(useProvider)).default as CliGenerator;\n console.log('Running generator:', provider);\n await generator({ model, outputPath, tsSchemaFile });\n }\n}\n","import colors from 'colors';\nimport path from 'node:path';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = await getZenStackPackages(projectPath);\n if (!packages) {\n console.error('Unable to locate package.json. Are you in a valid project directory?');\n return;\n }\n\n console.log('Installed ZenStack Packages:');\n const versions = new Set<string>();\n for (const { pkg, version } of packages) {\n if (version) {\n versions.add(version);\n }\n console.log(` ${colors.green(pkg.padEnd(20))}\\t${version}`);\n }\n\n if (versions.size > 1) {\n console.warn(colors.yellow('WARNING: Multiple versions of Zenstack packages detected. This may cause issues.'));\n }\n}\n\nasync function getZenStackPackages(projectPath: string): Promise<Array<{ pkg: string; version: string | undefined }>> {\n let pkgJson: {\n dependencies: Record<string, unknown>;\n devDependencies: Record<string, unknown>;\n };\n const resolvedPath = path.resolve(projectPath);\n try {\n pkgJson = (\n await import(path.join(resolvedPath, 'package.json'), {\n with: { type: 'json' },\n })\n ).default;\n } catch {\n return [];\n }\n\n const packages = Array.from(\n new Set(\n [...Object.keys(pkgJson.dependencies ?? {}), ...Object.keys(pkgJson.devDependencies ?? {})].filter(\n (p) => p.startsWith('@zenstackhq/') || p === 'zenstack',\n ),\n ),\n ).sort();\n\n const result = await Promise.all(\n packages.map(async (pkg) => {\n try {\n const depPkgJson = (\n await import(`${pkg}/package.json`, {\n with: { type: 'json' },\n })\n ).default;\n return { pkg, version: depPkgJson.version as string };\n } catch {\n return { pkg, version: undefined };\n }\n }),\n );\n\n return result;\n}\n","import colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport ora from 'ora';\nimport { detect, resolveCommand } from 'package-manager-detector';\nimport { CliError } from '../cli-error';\nimport { execSync } from '../utils/exec-utils';\nimport { STARTER_ZMODEL } from './templates';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = [\n { name: '@zenstackhq/cli@next', dev: true },\n { name: '@zenstackhq/runtime@next', dev: false },\n ];\n let pm = await detect();\n if (!pm) {\n pm = { agent: 'npm', name: 'npm' };\n }\n\n console.log(colors.gray(`Using package manager: ${pm.agent}`));\n\n for (const pkg of packages) {\n const resolved = resolveCommand(pm.agent, 'install', [\n pkg.name,\n ...(pkg.dev ? [pm.agent === 'yarn' ? '--dev' : '--save-dev'] : []),\n ]);\n if (!resolved) {\n throw new CliError(`Unable to determine how to install package \"${pkg.name}\". Please install it manually.`);\n }\n\n const spinner = ora(`Installing \"${pkg.name}\"`).start();\n try {\n execSync(`${resolved.command} ${resolved.args.join(' ')}`, {\n cwd: projectPath,\n });\n spinner.succeed();\n } catch (e) {\n spinner.fail();\n throw e;\n }\n }\n\n const generationFolder = 'zenstack';\n\n if (!fs.existsSync(path.join(projectPath, generationFolder))) {\n fs.mkdirSync(path.join(projectPath, generationFolder));\n }\n\n if (!fs.existsSync(path.join(projectPath, generationFolder, 'schema.zmodel'))) {\n fs.writeFileSync(path.join(projectPath, generationFolder, 'schema.zmodel'), STARTER_ZMODEL);\n } else {\n console.log(colors.yellow('Schema file already exists. Skipping generation of sample.'));\n }\n\n console.log(colors.green('ZenStack project initialized successfully!'));\n console.log(colors.gray(`See \"${generationFolder}/schema.zmodel\" for your database schema.`));\n console.log(colors.gray('Run `zenstack generate` to compile the the schema into a TypeScript file.'));\n}\n","export const STARTER_ZMODEL = `// This is a sample model to get you started.\n\n/// A sample data source using local sqlite db.\ndatasource db {\n provider = 'sqlite'\n url = 'file:./dev.db'\n}\n\n/// User model\nmodel User {\n id String @id @default(cuid())\n email String @unique @email @length(6, 32)\n posts Post[]\n}\n\n/// Post model\nmodel Post {\n id String @id @default(cuid())\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n title String @length(1, 256)\n content String\n published Boolean @default(false)\n author User @relation(fields: [authorId], references: [id])\n authorId String\n}\n`;\n\nexport const STARTER_MAIN_TS = `import { ZenStackClient } from '@zenstackhq/runtime';\nimport SQLite from 'better-sqlite3';\nimport { SqliteDialect } from 'kysely';\nimport { schema } from './zenstack/schema';\n\nasync function main() {\n const client = new ZenStackClient(schema, {\n dialect: new SqliteDialect({\n database: new SQLite('./zenstack/dev.db'),\n }),\n });\n const user = await client.user.create({\n data: {\n email: 'test@zenstack.dev',\n posts: {\n create: [\n {\n title: 'Hello World',\n content: 'This is a test post',\n },\n ],\n },\n },\n include: { posts: true }\n });\n console.log('User created:', user);\n}\n\nmain();\n`;\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { CliError } from '../cli-error';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile } from './action-utils';\n\ntype CommonOptions = {\n schema?: string;\n migrations?: string;\n};\n\ntype DevOptions = CommonOptions & {\n name?: string;\n createOnly?: boolean;\n};\n\ntype ResetOptions = CommonOptions & {\n force?: boolean;\n};\n\ntype DeployOptions = CommonOptions;\n\ntype StatusOptions = CommonOptions;\n\ntype ResolveOptions = CommonOptions & {\n applied?: string;\n rolledBack?: string;\n};\n\n/**\n * CLI action for migration-related commands\n */\nexport async function run(command: string, options: CommonOptions) {\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaDir = options.migrations ? path.dirname(options.migrations) : undefined;\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile, prismaSchemaDir);\n\n try {\n switch (command) {\n case 'dev':\n await runDev(prismaSchemaFile, options as DevOptions);\n break;\n\n case 'reset':\n await runReset(prismaSchemaFile, options as ResetOptions);\n break;\n\n case 'deploy':\n await runDeploy(prismaSchemaFile, options as DeployOptions);\n break;\n\n case 'status':\n await runStatus(prismaSchemaFile, options as StatusOptions);\n break;\n\n case 'resolve':\n await runResolve(prismaSchemaFile, options as ResolveOptions);\n break;\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n\nasync function runDev(prismaSchemaFile: string, options: DevOptions) {\n try {\n const cmd = [\n 'prisma migrate dev',\n ` --schema \"${prismaSchemaFile}\"`,\n ' --skip-generate',\n options.name ? ` --name ${options.name}` : '',\n options.createOnly ? ' --create-only' : '',\n ].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runReset(prismaSchemaFile: string, options: ResetOptions) {\n try {\n const cmd = ['prisma migrate reset', ` --schema \"${prismaSchemaFile}\"`, options.force ? ' --force' : ''].join(\n '',\n );\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runDeploy(prismaSchemaFile: string, _options: DeployOptions) {\n try {\n const cmd = ['prisma migrate deploy', ` --schema \"${prismaSchemaFile}\"`].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runStatus(prismaSchemaFile: string, _options: StatusOptions) {\n try {\n await execPackage(`prisma migrate status --schema \"${prismaSchemaFile}\"`);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runResolve(prismaSchemaFile: string, options: ResolveOptions) {\n if (!options.applied && !options.rolledBack) {\n throw new CliError('Either --applied or --rolled-back option must be provided');\n }\n\n try {\n const cmd = [\n 'prisma migrate resolve',\n ` --schema \"${prismaSchemaFile}\"`,\n options.applied ? ` --applied ${options.applied}` : '',\n options.rolledBack ? ` --rolled-back ${options.rolledBack}` : '',\n ].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n","import colors from 'colors';\nimport { getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n};\n\n/**\n * CLI action for validating schema without generation\n */\nexport async function run(options: Options) {\n const schemaFile = getSchemaFile(options.schema);\n\n try {\n await loadSchemaDocument(schemaFile);\n console.log(colors.green('✓ Schema validation completed successfully.'));\n } catch (error) {\n console.error(colors.red('✗ Schema validation failed.'));\n // Re-throw to maintain CLI exit code behavior\n throw error;\n }\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\nexport function getVersion() {\n try {\n // isomorphic __dirname\n const _dirname = typeof __dirname !== 'undefined' ? __dirname : path.dirname(fileURLToPath(import.meta.url));\n return JSON.parse(fs.readFileSync(path.join(_dirname, '../package.json'), 'utf8')).version;\n } catch {\n return undefined;\n }\n}\n"],"mappings":"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","names":["import_language","import_colors","import_node_fs","execSync","cmd","options","env","restOptions","mergedEnv","process","undefined","_exec","encoding","stdio","execPackage","packageManager","versions","CliError","Error","getSchemaFile","file","fs","existsSync","CliError","pkgJsonConfig","getPkgJsonConfig","process","cwd","schema","loadSchemaDocument","schemaFile","loadResult","loadDocument","success","errors","forEach","err","console","error","colors","red","warnings","warn","yellow","model","handleSubProcessError","Error","status","exit","generateTempPrismaSchema","zmodelPath","folder","declarations","some","isDataSource","prismaSchema","PrismaSchemaGenerator","generate","path","dirname","prismaSchemaFile","resolve","writeFileSync","startPath","result","undefined","output","pkgJsonFile","findUp","pkgJson","JSON","parse","readFileSync","zenstack","names","multiple","name","target","find","join","push","up","length","run","command","options","runPush","schemaFile","getSchemaFile","schema","prismaSchemaFile","generateTempPrismaSchema","cmd","acceptDataLoss","forceReset","join","execPackage","err","handleSubProcessError","fs","existsSync","unlinkSync","import_ast","import_sdk","import_colors","import_node_fs","import_node_path","run","options","start","Date","now","schemaFile","getSchemaFile","schema","model","loadSchemaDocument","outputPath","getOutputPath","tsSchemaFile","path","join","TsSchemaGenerator","generate","runPlugins","savePrismaSchema","prismaSchema","PrismaSchemaGenerator","prismaSchemaFile","resolve","fs","mkdirSync","dirname","recursive","writeFileSync","silent","console","log","colors","green","output","pkgJsonConfig","getPkgJsonConfig","process","cwd","plugins","declarations","filter","isPlugin","plugin","providerField","fields","find","f","name","invariant","provider","value","useProvider","startsWith","slice","generator","default","import_colors","import_node_path","run","projectPath","packages","getZenStackPackages","console","error","log","versions","Set","pkg","version","add","colors","green","padEnd","size","warn","yellow","pkgJson","resolvedPath","path","resolve","join","with","type","default","Array","from","Object","keys","dependencies","devDependencies","filter","p","startsWith","sort","result","Promise","all","map","depPkgJson","undefined","import_colors","import_node_fs","import_node_path","STARTER_ZMODEL","run","projectPath","packages","name","dev","pm","detect","agent","console","log","colors","gray","pkg","resolved","resolveCommand","CliError","spinner","ora","start","execSync","command","args","join","cwd","succeed","e","fail","generationFolder","fs","existsSync","path","mkdirSync","writeFileSync","STARTER_ZMODEL","yellow","green","import_node_fs","import_node_path","run","command","options","schemaFile","getSchemaFile","schema","prismaSchemaDir","migrations","path","dirname","undefined","prismaSchemaFile","generateTempPrismaSchema","runDev","runReset","runDeploy","runStatus","runResolve","fs","existsSync","unlinkSync","cmd","name","createOnly","join","execPackage","err","handleSubProcessError","force","_options","applied","rolledBack","CliError","Error","status","process","exit","import_colors","run","options","schemaFile","getSchemaFile","schema","loadSchemaDocument","console","log","colors","green","error","red","import_node_fs","import_node_path","getVersion","_dirname","__dirname","path","dirname","fileURLToPath","url","JSON","parse","fs","readFileSync","join","version","undefined","generateAction","options","generate","migrateAction","command","migrate","dbAction","db","infoAction","projectPath","info","initAction","init","validateAction","validate","createProgram","program","Command","version","getVersion","schemaExtensions","ZModelLanguageMetaData","fileExtensions","join","description","colors","bold","blue","showHelpAfterError","showSuggestionAfterError","schemaOption","Option","addOption","action","migrateCommand","migrationsOption","dbCommand","argument","parseAsync","catch","err","CliError","console","error","red","message","process","exit","CommanderError","exitCode"]}
|
package/dist/index.js
CHANGED
|
@@ -429,6 +429,9 @@ async function run5(command, options) {
|
|
|
429
429
|
case "status":
|
|
430
430
|
await runStatus(prismaSchemaFile, options);
|
|
431
431
|
break;
|
|
432
|
+
case "resolve":
|
|
433
|
+
await runResolve(prismaSchemaFile, options);
|
|
434
|
+
break;
|
|
432
435
|
}
|
|
433
436
|
} finally {
|
|
434
437
|
if (fs5.existsSync(prismaSchemaFile)) {
|
|
@@ -485,6 +488,23 @@ async function runStatus(prismaSchemaFile, _options) {
|
|
|
485
488
|
}
|
|
486
489
|
}
|
|
487
490
|
__name(runStatus, "runStatus");
|
|
491
|
+
async function runResolve(prismaSchemaFile, options) {
|
|
492
|
+
if (!options.applied && !options.rolledBack) {
|
|
493
|
+
throw new CliError("Either --applied or --rolled-back option must be provided");
|
|
494
|
+
}
|
|
495
|
+
try {
|
|
496
|
+
const cmd = [
|
|
497
|
+
"prisma migrate resolve",
|
|
498
|
+
` --schema "${prismaSchemaFile}"`,
|
|
499
|
+
options.applied ? ` --applied ${options.applied}` : "",
|
|
500
|
+
options.rolledBack ? ` --rolled-back ${options.rolledBack}` : ""
|
|
501
|
+
].join("");
|
|
502
|
+
await execPackage(cmd);
|
|
503
|
+
} catch (err) {
|
|
504
|
+
handleSubProcessError2(err);
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
__name(runResolve, "runResolve");
|
|
488
508
|
function handleSubProcessError2(err) {
|
|
489
509
|
if (err instanceof Error && "status" in err && typeof err.status === "number") {
|
|
490
510
|
process.exit(err.status);
|
|
@@ -555,7 +575,8 @@ Documentation: https://zenstack.dev.`).showHelpAfterError().showSuggestionAfterE
|
|
|
555
575
|
migrateCommand.command("dev").addOption(schemaOption).addOption(new Option("-n, --name <name>", "migration name")).addOption(new Option("--create-only", "only create migration, do not apply")).addOption(migrationsOption).description("Create a migration from changes in schema and apply it to the database.").action((options) => migrateAction("dev", options));
|
|
556
576
|
migrateCommand.command("reset").addOption(schemaOption).addOption(new Option("--force", "skip the confirmation prompt")).addOption(migrationsOption).description("Reset your database and apply all migrations, all data will be lost.").action((options) => migrateAction("reset", options));
|
|
557
577
|
migrateCommand.command("deploy").addOption(schemaOption).addOption(migrationsOption).description("Deploy your pending migrations to your production/staging database.").action((options) => migrateAction("deploy", options));
|
|
558
|
-
migrateCommand.command("status").addOption(schemaOption).addOption(migrationsOption).description("
|
|
578
|
+
migrateCommand.command("status").addOption(schemaOption).addOption(migrationsOption).description("Check the status of your database migrations.").action((options) => migrateAction("status", options));
|
|
579
|
+
migrateCommand.command("resolve").addOption(schemaOption).addOption(migrationsOption).addOption(new Option("--applied <migration>", "record a specific migration as applied")).addOption(new Option("--rolled-back <migration>", "record a specific migration as rolled back")).description("Resolve issues with database migrations in deployment databases").action((options) => migrateAction("resolve", options));
|
|
559
580
|
const dbCommand = program2.command("db").description("Manage your database schema during development.");
|
|
560
581
|
dbCommand.command("push").description("Push the state from your schema to your database").addOption(schemaOption).addOption(new Option("--accept-data-loss", "ignore data loss warnings")).addOption(new Option("--force-reset", "force a reset of the database before push")).action((options) => dbAction("push", options));
|
|
561
582
|
program2.command("info").description("Get information of installed ZenStack and related packages.").argument("[path]", "project path", ".").action(infoAction);
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/actions/db.ts","../src/utils/exec-utils.ts","../src/actions/action-utils.ts","../src/cli-error.ts","../src/actions/generate.ts","../src/actions/info.ts","../src/actions/init.ts","../src/actions/templates.ts","../src/actions/migrate.ts","../src/actions/validate.ts","../src/utils/version-utils.ts"],"sourcesContent":["import { ZModelLanguageMetaData } from '@zenstackhq/language';\nimport colors from 'colors';\nimport { Command, CommanderError, Option } from 'commander';\nimport * as actions from './actions';\nimport { CliError } from './cli-error';\nimport { getVersion } from './utils/version-utils';\n\nconst generateAction = async (options: Parameters<typeof actions.generate>[0]): Promise<void> => {\n await actions.generate(options);\n};\n\nconst migrateAction = async (command: string, options: any): Promise<void> => {\n await actions.migrate(command, options);\n};\n\nconst dbAction = async (command: string, options: any): Promise<void> => {\n await actions.db(command, options);\n};\n\nconst infoAction = async (projectPath: string): Promise<void> => {\n await actions.info(projectPath);\n};\n\nconst initAction = async (projectPath: string): Promise<void> => {\n await actions.init(projectPath);\n};\n\nconst validateAction = async (options: Parameters<typeof actions.validate>[0]): Promise<void> => {\n await actions.validate(options);\n};\n\nexport function createProgram() {\n const program = new Command('zenstack');\n\n program.version(getVersion()!, '-v --version', 'display CLI version');\n\n const schemaExtensions = ZModelLanguageMetaData.fileExtensions.join(', ');\n\n program\n .description(\n `${colors.bold.blue(\n 'ζ',\n )} ZenStack is a database access toolkit for TypeScript apps.\\n\\nDocumentation: https://zenstack.dev.`,\n )\n .showHelpAfterError()\n .showSuggestionAfterError();\n\n const schemaOption = new Option(\n '--schema <file>',\n `schema file (with extension ${schemaExtensions}). Defaults to \"schema.zmodel\" unless specified in package.json.`,\n );\n\n program\n .command('generate')\n .description('Run code generation.')\n .addOption(schemaOption)\n .addOption(new Option('--silent', 'do not print any output'))\n .addOption(\n new Option(\n '--save-prisma-schema [path]',\n 'save a Prisma schema file, by default into the output directory',\n ),\n )\n .addOption(new Option('-o, --output <path>', 'default output directory for core plugins'))\n .action(generateAction);\n\n const migrateCommand = program.command('migrate').description('Update the database schema with migrations.');\n const migrationsOption = new Option('--migrations <path>', 'path for migrations');\n\n migrateCommand\n .command('dev')\n .addOption(schemaOption)\n .addOption(new Option('-n, --name <name>', 'migration name'))\n .addOption(new Option('--create-only', 'only create migration, do not apply'))\n .addOption(migrationsOption)\n .description('Create a migration from changes in schema and apply it to the database.')\n .action((options) => migrateAction('dev', options));\n\n migrateCommand\n .command('reset')\n .addOption(schemaOption)\n .addOption(new Option('--force', 'skip the confirmation prompt'))\n .addOption(migrationsOption)\n .description('Reset your database and apply all migrations, all data will be lost.')\n .action((options) => migrateAction('reset', options));\n\n migrateCommand\n .command('deploy')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('Deploy your pending migrations to your production/staging database.')\n .action((options) => migrateAction('deploy', options));\n\n migrateCommand\n .command('status')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('check the status of your database migrations.')\n .action((options) => migrateAction('status', options));\n\n const dbCommand = program.command('db').description('Manage your database schema during development.');\n\n dbCommand\n .command('push')\n .description('Push the state from your schema to your database')\n .addOption(schemaOption)\n .addOption(new Option('--accept-data-loss', 'ignore data loss warnings'))\n .addOption(new Option('--force-reset', 'force a reset of the database before push'))\n .action((options) => dbAction('push', options));\n\n program\n .command('info')\n .description('Get information of installed ZenStack and related packages.')\n .argument('[path]', 'project path', '.')\n .action(infoAction);\n\n program\n .command('init')\n .description('Initialize an existing project for ZenStack.')\n .argument('[path]', 'project path', '.')\n .action(initAction);\n\n program.command('validate').description('Validate a ZModel schema.').addOption(schemaOption).action(validateAction);\n\n return program;\n}\n\nconst program = createProgram();\n\nprogram.parseAsync().catch((err) => {\n if (err instanceof CliError) {\n console.error(colors.red(err.message));\n process.exit(1);\n } else if (err instanceof CommanderError) {\n // errors are already reported, just exit\n process.exit(err.exitCode);\n } else {\n console.error(colors.red('An unexpected error occurred:'));\n console.error(err);\n process.exit(1);\n }\n});\n","import fs from 'node:fs';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile, handleSubProcessError } from './action-utils';\n\ntype Options = {\n schema?: string;\n acceptDataLoss?: boolean;\n forceReset?: boolean;\n};\n\n/**\n * CLI action for db related commands\n */\nexport async function run(command: string, options: Options) {\n switch (command) {\n case 'push':\n await runPush(options);\n break;\n }\n}\n\nasync function runPush(options: Options) {\n // generate a temp prisma schema file\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile);\n\n try {\n // run prisma db push\n const cmd = [\n 'prisma db push',\n ` --schema \"${prismaSchemaFile}\"`,\n options.acceptDataLoss ? ' --accept-data-loss' : '',\n options.forceReset ? ' --force-reset' : '',\n ' --skip-generate',\n ].join('');\n\n try {\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n","import { execSync as _exec, type ExecSyncOptions } from 'child_process';\n\n/**\n * Utility for executing command synchronously and prints outputs on current console\n */\nexport function execSync(cmd: string, options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> }): void {\n const { env, ...restOptions } = options ?? {};\n const mergedEnv = env ? { ...process.env, ...env } : undefined;\n _exec(cmd, {\n encoding: 'utf-8',\n stdio: options?.stdio ?? 'inherit',\n env: mergedEnv,\n ...restOptions,\n });\n}\n\n/**\n * Utility for running package commands through npx/bunx\n */\nexport function execPackage(\n cmd: string,\n options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> },\n): void {\n const packageManager = process?.versions?.['bun'] ? 'bunx' : 'npx';\n execSync(`${packageManager} ${cmd}`, options);\n}\n","import { loadDocument } from '@zenstackhq/language';\nimport { isDataSource } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { CliError } from '../cli-error';\n\nexport function getSchemaFile(file?: string) {\n if (file) {\n if (!fs.existsSync(file)) {\n throw new CliError(`Schema file not found: ${file}`);\n }\n return file;\n }\n\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.schema) {\n if (!fs.existsSync(pkgJsonConfig.schema)) {\n throw new CliError(`Schema file not found: ${pkgJsonConfig.schema}`);\n }\n return pkgJsonConfig.schema;\n }\n\n if (fs.existsSync('./zenstack/schema.zmodel')) {\n return './zenstack/schema.zmodel';\n } else if (fs.existsSync('./schema.zmodel')) {\n return './schema.zmodel';\n } else {\n throw new CliError(\n 'Schema file not found in default locations (\"./zenstack/schema.zmodel\" or \"./schema.zmodel\").',\n );\n }\n}\n\nexport async function loadSchemaDocument(schemaFile: string) {\n const loadResult = await loadDocument(schemaFile);\n if (!loadResult.success) {\n loadResult.errors.forEach((err) => {\n console.error(colors.red(err));\n });\n throw new CliError('Schema contains errors. See above for details.');\n }\n loadResult.warnings.forEach((warn) => {\n console.warn(colors.yellow(warn));\n });\n return loadResult.model;\n}\n\nexport function handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n\nexport async function generateTempPrismaSchema(zmodelPath: string, folder?: string) {\n const model = await loadSchemaDocument(zmodelPath);\n if (!model.declarations.some(isDataSource)) {\n throw new CliError('Schema must define a datasource');\n }\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n if (!folder) {\n folder = path.dirname(zmodelPath);\n }\n const prismaSchemaFile = path.resolve(folder, '~schema.prisma');\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n return prismaSchemaFile;\n}\n\nexport function getPkgJsonConfig(startPath: string) {\n const result: { schema: string | undefined; output: string | undefined } = { schema: undefined, output: undefined };\n const pkgJsonFile = findUp(['package.json'], startPath, false);\n\n if (!pkgJsonFile) {\n return result;\n }\n\n let pkgJson: any = undefined;\n try {\n pkgJson = JSON.parse(fs.readFileSync(pkgJsonFile, 'utf8'));\n } catch {\n return result;\n }\n\n if (pkgJson.zenstack && typeof pkgJson.zenstack === 'object') {\n result.schema = pkgJson.zenstack.schema && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.schema);\n result.output = pkgJson.zenstack.output && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.output);\n }\n\n return result;\n}\n\ntype FindUpResult<Multiple extends boolean> = Multiple extends true ? string[] | undefined : string | undefined;\n\nfunction findUp<Multiple extends boolean = false>(\n names: string[],\n cwd: string = process.cwd(),\n multiple: Multiple = false as Multiple,\n result: string[] = [],\n): FindUpResult<Multiple> {\n if (!names.some((name) => !!name)) {\n return undefined;\n }\n const target = names.find((name) => fs.existsSync(path.join(cwd, name)));\n if (multiple === false && target) {\n return path.join(cwd, target) as FindUpResult<Multiple>;\n }\n if (target) {\n result.push(path.join(cwd, target));\n }\n const up = path.resolve(cwd, '..');\n if (up === cwd) {\n return (multiple && result.length > 0 ? result : undefined) as FindUpResult<Multiple>;\n }\n return findUp(names, up, multiple, result);\n}\n","/**\n * Indicating an error during CLI execution\n */\nexport class CliError extends Error {}\n","import { invariant } from '@zenstackhq/common-helpers';\nimport { isPlugin, LiteralExpr, type Model } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator, TsSchemaGenerator, type CliGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { getPkgJsonConfig, getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n output?: string;\n silent?: boolean;\n savePrismaSchema?: string | boolean;\n};\n\n/**\n * CLI action for generating code from schema\n */\nexport async function run(options: Options) {\n const start = Date.now();\n\n const schemaFile = getSchemaFile(options.schema);\n\n const model = await loadSchemaDocument(schemaFile);\n const outputPath = getOutputPath(options, schemaFile);\n\n // generate TS schema\n const tsSchemaFile = path.join(outputPath, 'schema.ts');\n await new TsSchemaGenerator().generate(schemaFile, [], outputPath);\n\n await runPlugins(model, outputPath, tsSchemaFile);\n\n // generate Prisma schema\n if (options.savePrismaSchema) {\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n let prismaSchemaFile = path.join(outputPath, 'schema.prisma');\n if (typeof options.savePrismaSchema === 'string') {\n prismaSchemaFile = path.resolve(outputPath, options.savePrismaSchema);\n fs.mkdirSync(path.dirname(prismaSchemaFile), { recursive: true });\n }\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n }\n\n if (!options.silent) {\n console.log(colors.green(`Generation completed successfully in ${Date.now() - start}ms.`));\n console.log(`You can now create a ZenStack client with it.\n\n\\`\\`\\`ts\nimport { ZenStackClient } from '@zenstackhq/runtime';\nimport { schema } from '${outputPath}/schema';\n\nconst client = new ZenStackClient(schema, {\n dialect: { ... }\n});\n\\`\\`\\``);\n }\n}\n\nfunction getOutputPath(options: Options, schemaFile: string) {\n if (options.output) {\n return options.output;\n }\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.output) {\n return pkgJsonConfig.output;\n } else {\n return path.dirname(schemaFile);\n }\n}\n\nasync function runPlugins(model: Model, outputPath: string, tsSchemaFile: string) {\n const plugins = model.declarations.filter(isPlugin);\n for (const plugin of plugins) {\n const providerField = plugin.fields.find((f) => f.name === 'provider');\n invariant(providerField, `Plugin ${plugin.name} does not have a provider field`);\n const provider = (providerField.value as LiteralExpr).value as string;\n let useProvider = provider;\n if (useProvider.startsWith('@core/')) {\n useProvider = `@zenstackhq/runtime/plugins/${useProvider.slice(6)}`;\n }\n const generator = (await import(useProvider)).default as CliGenerator;\n console.log('Running generator:', provider);\n await generator({ model, outputPath, tsSchemaFile });\n }\n}\n","import colors from 'colors';\nimport path from 'node:path';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = await getZenStackPackages(projectPath);\n if (!packages) {\n console.error('Unable to locate package.json. Are you in a valid project directory?');\n return;\n }\n\n console.log('Installed ZenStack Packages:');\n const versions = new Set<string>();\n for (const { pkg, version } of packages) {\n if (version) {\n versions.add(version);\n }\n console.log(` ${colors.green(pkg.padEnd(20))}\\t${version}`);\n }\n\n if (versions.size > 1) {\n console.warn(colors.yellow('WARNING: Multiple versions of Zenstack packages detected. This may cause issues.'));\n }\n}\n\nasync function getZenStackPackages(projectPath: string): Promise<Array<{ pkg: string; version: string | undefined }>> {\n let pkgJson: {\n dependencies: Record<string, unknown>;\n devDependencies: Record<string, unknown>;\n };\n const resolvedPath = path.resolve(projectPath);\n try {\n pkgJson = (\n await import(path.join(resolvedPath, 'package.json'), {\n with: { type: 'json' },\n })\n ).default;\n } catch {\n return [];\n }\n\n const packages = Array.from(\n new Set(\n [...Object.keys(pkgJson.dependencies ?? {}), ...Object.keys(pkgJson.devDependencies ?? {})].filter(\n (p) => p.startsWith('@zenstackhq/') || p === 'zenstack',\n ),\n ),\n ).sort();\n\n const result = await Promise.all(\n packages.map(async (pkg) => {\n try {\n const depPkgJson = (\n await import(`${pkg}/package.json`, {\n with: { type: 'json' },\n })\n ).default;\n return { pkg, version: depPkgJson.version as string };\n } catch {\n return { pkg, version: undefined };\n }\n }),\n );\n\n return result;\n}\n","import colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport ora from 'ora';\nimport { detect, resolveCommand } from 'package-manager-detector';\nimport { CliError } from '../cli-error';\nimport { execSync } from '../utils/exec-utils';\nimport { STARTER_ZMODEL } from './templates';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = [\n { name: '@zenstackhq/cli@next', dev: true },\n { name: '@zenstackhq/runtime@next', dev: false },\n ];\n let pm = await detect();\n if (!pm) {\n pm = { agent: 'npm', name: 'npm' };\n }\n\n console.log(colors.gray(`Using package manager: ${pm.agent}`));\n\n for (const pkg of packages) {\n const resolved = resolveCommand(pm.agent, 'install', [\n pkg.name,\n ...(pkg.dev ? [pm.agent === 'yarn' ? '--dev' : '--save-dev'] : []),\n ]);\n if (!resolved) {\n throw new CliError(`Unable to determine how to install package \"${pkg.name}\". Please install it manually.`);\n }\n\n const spinner = ora(`Installing \"${pkg.name}\"`).start();\n try {\n execSync(`${resolved.command} ${resolved.args.join(' ')}`, {\n cwd: projectPath,\n });\n spinner.succeed();\n } catch (e) {\n spinner.fail();\n throw e;\n }\n }\n\n const generationFolder = 'zenstack';\n\n if (!fs.existsSync(path.join(projectPath, generationFolder))) {\n fs.mkdirSync(path.join(projectPath, generationFolder));\n }\n\n if (!fs.existsSync(path.join(projectPath, generationFolder, 'schema.zmodel'))) {\n fs.writeFileSync(path.join(projectPath, generationFolder, 'schema.zmodel'), STARTER_ZMODEL);\n } else {\n console.log(colors.yellow('Schema file already exists. Skipping generation of sample.'));\n }\n\n console.log(colors.green('ZenStack project initialized successfully!'));\n console.log(colors.gray(`See \"${generationFolder}/schema.zmodel\" for your database schema.`));\n console.log(colors.gray('Run `zenstack generate` to compile the the schema into a TypeScript file.'));\n}\n","export const STARTER_ZMODEL = `// This is a sample model to get you started.\n\n/// A sample data source using local sqlite db.\ndatasource db {\n provider = 'sqlite'\n url = 'file:./dev.db'\n}\n\n/// User model\nmodel User {\n id String @id @default(cuid())\n email String @unique @email @length(6, 32)\n posts Post[]\n}\n\n/// Post model\nmodel Post {\n id String @id @default(cuid())\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n title String @length(1, 256)\n content String\n published Boolean @default(false)\n author User @relation(fields: [authorId], references: [id])\n authorId String\n}\n`;\n\nexport const STARTER_MAIN_TS = `import { ZenStackClient } from '@zenstackhq/runtime';\nimport SQLite from 'better-sqlite3';\nimport { SqliteDialect } from 'kysely';\nimport { schema } from './zenstack/schema';\n\nasync function main() {\n const client = new ZenStackClient(schema, {\n dialect: new SqliteDialect({\n database: new SQLite('./zenstack/dev.db'),\n }),\n });\n const user = await client.user.create({\n data: {\n email: 'test@zenstack.dev',\n posts: {\n create: [\n {\n title: 'Hello World',\n content: 'This is a test post',\n },\n ],\n },\n },\n include: { posts: true }\n });\n console.log('User created:', user);\n}\n\nmain();\n`;\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile } from './action-utils';\n\ntype CommonOptions = {\n schema?: string;\n migrations?: string;\n};\n\ntype DevOptions = CommonOptions & {\n name?: string;\n createOnly?: boolean;\n};\n\ntype ResetOptions = CommonOptions & {\n force?: boolean;\n};\n\ntype DeployOptions = CommonOptions;\n\ntype StatusOptions = CommonOptions;\n\n/**\n * CLI action for migration-related commands\n */\nexport async function run(command: string, options: CommonOptions) {\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaDir = options.migrations ? path.dirname(options.migrations) : undefined;\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile, prismaSchemaDir);\n\n try {\n switch (command) {\n case 'dev':\n await runDev(prismaSchemaFile, options as DevOptions);\n break;\n\n case 'reset':\n await runReset(prismaSchemaFile, options as ResetOptions);\n break;\n\n case 'deploy':\n await runDeploy(prismaSchemaFile, options as DeployOptions);\n break;\n\n case 'status':\n await runStatus(prismaSchemaFile, options as StatusOptions);\n break;\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n\nasync function runDev(prismaSchemaFile: string, options: DevOptions) {\n try {\n const cmd = [\n 'prisma migrate dev',\n ` --schema \"${prismaSchemaFile}\"`,\n ' --skip-generate',\n options.name ? ` --name ${options.name}` : '',\n options.createOnly ? ' --create-only' : '',\n ].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runReset(prismaSchemaFile: string, options: ResetOptions) {\n try {\n const cmd = ['prisma migrate reset', ` --schema \"${prismaSchemaFile}\"`, options.force ? ' --force' : ''].join(\n '',\n );\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runDeploy(prismaSchemaFile: string, _options: DeployOptions) {\n try {\n const cmd = ['prisma migrate deploy', ` --schema \"${prismaSchemaFile}\"`].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runStatus(prismaSchemaFile: string, _options: StatusOptions) {\n try {\n await execPackage(`prisma migrate status --schema \"${prismaSchemaFile}\"`);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n","import colors from 'colors';\nimport { getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n};\n\n/**\n * CLI action for validating schema without generation\n */\nexport async function run(options: Options) {\n const schemaFile = getSchemaFile(options.schema);\n\n try {\n await loadSchemaDocument(schemaFile);\n console.log(colors.green('✓ Schema validation completed successfully.'));\n } catch (error) {\n console.error(colors.red('✗ Schema validation failed.'));\n // Re-throw to maintain CLI exit code behavior\n throw error;\n }\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\nexport function getVersion() {\n try {\n // isomorphic __dirname\n const _dirname = typeof __dirname !== 'undefined' ? __dirname : path.dirname(fileURLToPath(import.meta.url));\n return JSON.parse(fs.readFileSync(path.join(_dirname, '../package.json'), 'utf8')).version;\n } catch {\n return undefined;\n }\n}\n"],"mappings":"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","names":["ZModelLanguageMetaData","colors","Command","CommanderError","Option","fs","execSync","_exec","execSync","cmd","options","env","restOptions","mergedEnv","process","undefined","_exec","encoding","stdio","execPackage","packageManager","versions","loadDocument","isDataSource","PrismaSchemaGenerator","colors","fs","path","CliError","Error","getSchemaFile","file","fs","existsSync","CliError","pkgJsonConfig","getPkgJsonConfig","process","cwd","schema","loadSchemaDocument","schemaFile","loadResult","loadDocument","success","errors","forEach","err","console","error","colors","red","warnings","warn","yellow","model","handleSubProcessError","Error","status","exit","generateTempPrismaSchema","zmodelPath","folder","declarations","some","isDataSource","prismaSchema","PrismaSchemaGenerator","generate","path","dirname","prismaSchemaFile","resolve","writeFileSync","startPath","result","undefined","output","pkgJsonFile","findUp","pkgJson","JSON","parse","readFileSync","zenstack","names","multiple","name","target","find","join","push","up","length","run","command","options","runPush","schemaFile","getSchemaFile","schema","prismaSchemaFile","generateTempPrismaSchema","cmd","acceptDataLoss","forceReset","join","execPackage","err","handleSubProcessError","fs","existsSync","unlinkSync","invariant","isPlugin","PrismaSchemaGenerator","TsSchemaGenerator","colors","fs","path","run","options","start","Date","now","schemaFile","getSchemaFile","schema","model","loadSchemaDocument","outputPath","getOutputPath","tsSchemaFile","path","join","TsSchemaGenerator","generate","runPlugins","savePrismaSchema","prismaSchema","PrismaSchemaGenerator","prismaSchemaFile","resolve","fs","mkdirSync","dirname","recursive","writeFileSync","silent","console","log","colors","green","output","pkgJsonConfig","getPkgJsonConfig","process","cwd","plugins","declarations","filter","isPlugin","plugin","providerField","fields","find","f","name","invariant","provider","value","useProvider","startsWith","slice","generator","default","colors","path","run","projectPath","packages","getZenStackPackages","console","error","log","versions","Set","pkg","version","add","colors","green","padEnd","size","warn","yellow","pkgJson","resolvedPath","path","resolve","join","with","type","default","Array","from","Object","keys","dependencies","devDependencies","filter","p","startsWith","sort","result","Promise","all","map","depPkgJson","undefined","colors","fs","path","ora","detect","resolveCommand","STARTER_ZMODEL","run","projectPath","packages","name","dev","pm","detect","agent","console","log","colors","gray","pkg","resolved","resolveCommand","CliError","spinner","ora","start","execSync","command","args","join","cwd","succeed","e","fail","generationFolder","fs","existsSync","path","mkdirSync","writeFileSync","STARTER_ZMODEL","yellow","green","fs","path","run","command","options","schemaFile","getSchemaFile","schema","prismaSchemaDir","migrations","path","dirname","undefined","prismaSchemaFile","generateTempPrismaSchema","runDev","runReset","runDeploy","runStatus","fs","existsSync","unlinkSync","cmd","name","createOnly","join","execPackage","err","handleSubProcessError","force","_options","Error","status","process","exit","colors","run","options","schemaFile","getSchemaFile","schema","loadSchemaDocument","console","log","colors","green","error","red","fs","path","fileURLToPath","getVersion","_dirname","__dirname","path","dirname","fileURLToPath","url","JSON","parse","fs","readFileSync","join","version","undefined","generateAction","options","generate","migrateAction","command","migrate","dbAction","db","infoAction","projectPath","info","initAction","init","validateAction","validate","createProgram","program","Command","version","getVersion","schemaExtensions","ZModelLanguageMetaData","fileExtensions","join","description","colors","bold","blue","showHelpAfterError","showSuggestionAfterError","schemaOption","Option","addOption","action","migrateCommand","migrationsOption","dbCommand","argument","parseAsync","catch","err","CliError","console","error","red","message","process","exit","CommanderError","exitCode"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/actions/db.ts","../src/utils/exec-utils.ts","../src/actions/action-utils.ts","../src/cli-error.ts","../src/actions/generate.ts","../src/actions/info.ts","../src/actions/init.ts","../src/actions/templates.ts","../src/actions/migrate.ts","../src/actions/validate.ts","../src/utils/version-utils.ts"],"sourcesContent":["import { ZModelLanguageMetaData } from '@zenstackhq/language';\nimport colors from 'colors';\nimport { Command, CommanderError, Option } from 'commander';\nimport * as actions from './actions';\nimport { CliError } from './cli-error';\nimport { getVersion } from './utils/version-utils';\n\nconst generateAction = async (options: Parameters<typeof actions.generate>[0]): Promise<void> => {\n await actions.generate(options);\n};\n\nconst migrateAction = async (command: string, options: any): Promise<void> => {\n await actions.migrate(command, options);\n};\n\nconst dbAction = async (command: string, options: any): Promise<void> => {\n await actions.db(command, options);\n};\n\nconst infoAction = async (projectPath: string): Promise<void> => {\n await actions.info(projectPath);\n};\n\nconst initAction = async (projectPath: string): Promise<void> => {\n await actions.init(projectPath);\n};\n\nconst validateAction = async (options: Parameters<typeof actions.validate>[0]): Promise<void> => {\n await actions.validate(options);\n};\n\nexport function createProgram() {\n const program = new Command('zenstack');\n\n program.version(getVersion()!, '-v --version', 'display CLI version');\n\n const schemaExtensions = ZModelLanguageMetaData.fileExtensions.join(', ');\n\n program\n .description(\n `${colors.bold.blue(\n 'ζ',\n )} ZenStack is a database access toolkit for TypeScript apps.\\n\\nDocumentation: https://zenstack.dev.`,\n )\n .showHelpAfterError()\n .showSuggestionAfterError();\n\n const schemaOption = new Option(\n '--schema <file>',\n `schema file (with extension ${schemaExtensions}). Defaults to \"schema.zmodel\" unless specified in package.json.`,\n );\n\n program\n .command('generate')\n .description('Run code generation.')\n .addOption(schemaOption)\n .addOption(new Option('--silent', 'do not print any output'))\n .addOption(\n new Option(\n '--save-prisma-schema [path]',\n 'save a Prisma schema file, by default into the output directory',\n ),\n )\n .addOption(new Option('-o, --output <path>', 'default output directory for core plugins'))\n .action(generateAction);\n\n const migrateCommand = program.command('migrate').description('Update the database schema with migrations.');\n const migrationsOption = new Option('--migrations <path>', 'path for migrations');\n\n migrateCommand\n .command('dev')\n .addOption(schemaOption)\n .addOption(new Option('-n, --name <name>', 'migration name'))\n .addOption(new Option('--create-only', 'only create migration, do not apply'))\n .addOption(migrationsOption)\n .description('Create a migration from changes in schema and apply it to the database.')\n .action((options) => migrateAction('dev', options));\n\n migrateCommand\n .command('reset')\n .addOption(schemaOption)\n .addOption(new Option('--force', 'skip the confirmation prompt'))\n .addOption(migrationsOption)\n .description('Reset your database and apply all migrations, all data will be lost.')\n .action((options) => migrateAction('reset', options));\n\n migrateCommand\n .command('deploy')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('Deploy your pending migrations to your production/staging database.')\n .action((options) => migrateAction('deploy', options));\n\n migrateCommand\n .command('status')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .description('Check the status of your database migrations.')\n .action((options) => migrateAction('status', options));\n\n migrateCommand\n .command('resolve')\n .addOption(schemaOption)\n .addOption(migrationsOption)\n .addOption(new Option('--applied <migration>', 'record a specific migration as applied'))\n .addOption(new Option('--rolled-back <migration>', 'record a specific migration as rolled back'))\n .description('Resolve issues with database migrations in deployment databases')\n .action((options) => migrateAction('resolve', options));\n\n const dbCommand = program.command('db').description('Manage your database schema during development.');\n\n dbCommand\n .command('push')\n .description('Push the state from your schema to your database')\n .addOption(schemaOption)\n .addOption(new Option('--accept-data-loss', 'ignore data loss warnings'))\n .addOption(new Option('--force-reset', 'force a reset of the database before push'))\n .action((options) => dbAction('push', options));\n\n program\n .command('info')\n .description('Get information of installed ZenStack and related packages.')\n .argument('[path]', 'project path', '.')\n .action(infoAction);\n\n program\n .command('init')\n .description('Initialize an existing project for ZenStack.')\n .argument('[path]', 'project path', '.')\n .action(initAction);\n\n program.command('validate').description('Validate a ZModel schema.').addOption(schemaOption).action(validateAction);\n\n return program;\n}\n\nconst program = createProgram();\n\nprogram.parseAsync().catch((err) => {\n if (err instanceof CliError) {\n console.error(colors.red(err.message));\n process.exit(1);\n } else if (err instanceof CommanderError) {\n // errors are already reported, just exit\n process.exit(err.exitCode);\n } else {\n console.error(colors.red('An unexpected error occurred:'));\n console.error(err);\n process.exit(1);\n }\n});\n","import fs from 'node:fs';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile, handleSubProcessError } from './action-utils';\n\ntype Options = {\n schema?: string;\n acceptDataLoss?: boolean;\n forceReset?: boolean;\n};\n\n/**\n * CLI action for db related commands\n */\nexport async function run(command: string, options: Options) {\n switch (command) {\n case 'push':\n await runPush(options);\n break;\n }\n}\n\nasync function runPush(options: Options) {\n // generate a temp prisma schema file\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile);\n\n try {\n // run prisma db push\n const cmd = [\n 'prisma db push',\n ` --schema \"${prismaSchemaFile}\"`,\n options.acceptDataLoss ? ' --accept-data-loss' : '',\n options.forceReset ? ' --force-reset' : '',\n ' --skip-generate',\n ].join('');\n\n try {\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n","import { execSync as _exec, type ExecSyncOptions } from 'child_process';\n\n/**\n * Utility for executing command synchronously and prints outputs on current console\n */\nexport function execSync(cmd: string, options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> }): void {\n const { env, ...restOptions } = options ?? {};\n const mergedEnv = env ? { ...process.env, ...env } : undefined;\n _exec(cmd, {\n encoding: 'utf-8',\n stdio: options?.stdio ?? 'inherit',\n env: mergedEnv,\n ...restOptions,\n });\n}\n\n/**\n * Utility for running package commands through npx/bunx\n */\nexport function execPackage(\n cmd: string,\n options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> },\n): void {\n const packageManager = process?.versions?.['bun'] ? 'bunx' : 'npx';\n execSync(`${packageManager} ${cmd}`, options);\n}\n","import { loadDocument } from '@zenstackhq/language';\nimport { isDataSource } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { CliError } from '../cli-error';\n\nexport function getSchemaFile(file?: string) {\n if (file) {\n if (!fs.existsSync(file)) {\n throw new CliError(`Schema file not found: ${file}`);\n }\n return file;\n }\n\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.schema) {\n if (!fs.existsSync(pkgJsonConfig.schema)) {\n throw new CliError(`Schema file not found: ${pkgJsonConfig.schema}`);\n }\n return pkgJsonConfig.schema;\n }\n\n if (fs.existsSync('./zenstack/schema.zmodel')) {\n return './zenstack/schema.zmodel';\n } else if (fs.existsSync('./schema.zmodel')) {\n return './schema.zmodel';\n } else {\n throw new CliError(\n 'Schema file not found in default locations (\"./zenstack/schema.zmodel\" or \"./schema.zmodel\").',\n );\n }\n}\n\nexport async function loadSchemaDocument(schemaFile: string) {\n const loadResult = await loadDocument(schemaFile);\n if (!loadResult.success) {\n loadResult.errors.forEach((err) => {\n console.error(colors.red(err));\n });\n throw new CliError('Schema contains errors. See above for details.');\n }\n loadResult.warnings.forEach((warn) => {\n console.warn(colors.yellow(warn));\n });\n return loadResult.model;\n}\n\nexport function handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n\nexport async function generateTempPrismaSchema(zmodelPath: string, folder?: string) {\n const model = await loadSchemaDocument(zmodelPath);\n if (!model.declarations.some(isDataSource)) {\n throw new CliError('Schema must define a datasource');\n }\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n if (!folder) {\n folder = path.dirname(zmodelPath);\n }\n const prismaSchemaFile = path.resolve(folder, '~schema.prisma');\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n return prismaSchemaFile;\n}\n\nexport function getPkgJsonConfig(startPath: string) {\n const result: { schema: string | undefined; output: string | undefined } = { schema: undefined, output: undefined };\n const pkgJsonFile = findUp(['package.json'], startPath, false);\n\n if (!pkgJsonFile) {\n return result;\n }\n\n let pkgJson: any = undefined;\n try {\n pkgJson = JSON.parse(fs.readFileSync(pkgJsonFile, 'utf8'));\n } catch {\n return result;\n }\n\n if (pkgJson.zenstack && typeof pkgJson.zenstack === 'object') {\n result.schema = pkgJson.zenstack.schema && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.schema);\n result.output = pkgJson.zenstack.output && path.resolve(path.dirname(pkgJsonFile), pkgJson.zenstack.output);\n }\n\n return result;\n}\n\ntype FindUpResult<Multiple extends boolean> = Multiple extends true ? string[] | undefined : string | undefined;\n\nfunction findUp<Multiple extends boolean = false>(\n names: string[],\n cwd: string = process.cwd(),\n multiple: Multiple = false as Multiple,\n result: string[] = [],\n): FindUpResult<Multiple> {\n if (!names.some((name) => !!name)) {\n return undefined;\n }\n const target = names.find((name) => fs.existsSync(path.join(cwd, name)));\n if (multiple === false && target) {\n return path.join(cwd, target) as FindUpResult<Multiple>;\n }\n if (target) {\n result.push(path.join(cwd, target));\n }\n const up = path.resolve(cwd, '..');\n if (up === cwd) {\n return (multiple && result.length > 0 ? result : undefined) as FindUpResult<Multiple>;\n }\n return findUp(names, up, multiple, result);\n}\n","/**\n * Indicating an error during CLI execution\n */\nexport class CliError extends Error {}\n","import { invariant } from '@zenstackhq/common-helpers';\nimport { isPlugin, LiteralExpr, type Model } from '@zenstackhq/language/ast';\nimport { PrismaSchemaGenerator, TsSchemaGenerator, type CliGenerator } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { getPkgJsonConfig, getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n output?: string;\n silent?: boolean;\n savePrismaSchema?: string | boolean;\n};\n\n/**\n * CLI action for generating code from schema\n */\nexport async function run(options: Options) {\n const start = Date.now();\n\n const schemaFile = getSchemaFile(options.schema);\n\n const model = await loadSchemaDocument(schemaFile);\n const outputPath = getOutputPath(options, schemaFile);\n\n // generate TS schema\n const tsSchemaFile = path.join(outputPath, 'schema.ts');\n await new TsSchemaGenerator().generate(schemaFile, [], outputPath);\n\n await runPlugins(model, outputPath, tsSchemaFile);\n\n // generate Prisma schema\n if (options.savePrismaSchema) {\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n let prismaSchemaFile = path.join(outputPath, 'schema.prisma');\n if (typeof options.savePrismaSchema === 'string') {\n prismaSchemaFile = path.resolve(outputPath, options.savePrismaSchema);\n fs.mkdirSync(path.dirname(prismaSchemaFile), { recursive: true });\n }\n fs.writeFileSync(prismaSchemaFile, prismaSchema);\n }\n\n if (!options.silent) {\n console.log(colors.green(`Generation completed successfully in ${Date.now() - start}ms.`));\n console.log(`You can now create a ZenStack client with it.\n\n\\`\\`\\`ts\nimport { ZenStackClient } from '@zenstackhq/runtime';\nimport { schema } from '${outputPath}/schema';\n\nconst client = new ZenStackClient(schema, {\n dialect: { ... }\n});\n\\`\\`\\``);\n }\n}\n\nfunction getOutputPath(options: Options, schemaFile: string) {\n if (options.output) {\n return options.output;\n }\n const pkgJsonConfig = getPkgJsonConfig(process.cwd());\n if (pkgJsonConfig.output) {\n return pkgJsonConfig.output;\n } else {\n return path.dirname(schemaFile);\n }\n}\n\nasync function runPlugins(model: Model, outputPath: string, tsSchemaFile: string) {\n const plugins = model.declarations.filter(isPlugin);\n for (const plugin of plugins) {\n const providerField = plugin.fields.find((f) => f.name === 'provider');\n invariant(providerField, `Plugin ${plugin.name} does not have a provider field`);\n const provider = (providerField.value as LiteralExpr).value as string;\n let useProvider = provider;\n if (useProvider.startsWith('@core/')) {\n useProvider = `@zenstackhq/runtime/plugins/${useProvider.slice(6)}`;\n }\n const generator = (await import(useProvider)).default as CliGenerator;\n console.log('Running generator:', provider);\n await generator({ model, outputPath, tsSchemaFile });\n }\n}\n","import colors from 'colors';\nimport path from 'node:path';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = await getZenStackPackages(projectPath);\n if (!packages) {\n console.error('Unable to locate package.json. Are you in a valid project directory?');\n return;\n }\n\n console.log('Installed ZenStack Packages:');\n const versions = new Set<string>();\n for (const { pkg, version } of packages) {\n if (version) {\n versions.add(version);\n }\n console.log(` ${colors.green(pkg.padEnd(20))}\\t${version}`);\n }\n\n if (versions.size > 1) {\n console.warn(colors.yellow('WARNING: Multiple versions of Zenstack packages detected. This may cause issues.'));\n }\n}\n\nasync function getZenStackPackages(projectPath: string): Promise<Array<{ pkg: string; version: string | undefined }>> {\n let pkgJson: {\n dependencies: Record<string, unknown>;\n devDependencies: Record<string, unknown>;\n };\n const resolvedPath = path.resolve(projectPath);\n try {\n pkgJson = (\n await import(path.join(resolvedPath, 'package.json'), {\n with: { type: 'json' },\n })\n ).default;\n } catch {\n return [];\n }\n\n const packages = Array.from(\n new Set(\n [...Object.keys(pkgJson.dependencies ?? {}), ...Object.keys(pkgJson.devDependencies ?? {})].filter(\n (p) => p.startsWith('@zenstackhq/') || p === 'zenstack',\n ),\n ),\n ).sort();\n\n const result = await Promise.all(\n packages.map(async (pkg) => {\n try {\n const depPkgJson = (\n await import(`${pkg}/package.json`, {\n with: { type: 'json' },\n })\n ).default;\n return { pkg, version: depPkgJson.version as string };\n } catch {\n return { pkg, version: undefined };\n }\n }),\n );\n\n return result;\n}\n","import colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport ora from 'ora';\nimport { detect, resolveCommand } from 'package-manager-detector';\nimport { CliError } from '../cli-error';\nimport { execSync } from '../utils/exec-utils';\nimport { STARTER_ZMODEL } from './templates';\n\n/**\n * CLI action for getting information about installed ZenStack packages\n */\nexport async function run(projectPath: string) {\n const packages = [\n { name: '@zenstackhq/cli@next', dev: true },\n { name: '@zenstackhq/runtime@next', dev: false },\n ];\n let pm = await detect();\n if (!pm) {\n pm = { agent: 'npm', name: 'npm' };\n }\n\n console.log(colors.gray(`Using package manager: ${pm.agent}`));\n\n for (const pkg of packages) {\n const resolved = resolveCommand(pm.agent, 'install', [\n pkg.name,\n ...(pkg.dev ? [pm.agent === 'yarn' ? '--dev' : '--save-dev'] : []),\n ]);\n if (!resolved) {\n throw new CliError(`Unable to determine how to install package \"${pkg.name}\". Please install it manually.`);\n }\n\n const spinner = ora(`Installing \"${pkg.name}\"`).start();\n try {\n execSync(`${resolved.command} ${resolved.args.join(' ')}`, {\n cwd: projectPath,\n });\n spinner.succeed();\n } catch (e) {\n spinner.fail();\n throw e;\n }\n }\n\n const generationFolder = 'zenstack';\n\n if (!fs.existsSync(path.join(projectPath, generationFolder))) {\n fs.mkdirSync(path.join(projectPath, generationFolder));\n }\n\n if (!fs.existsSync(path.join(projectPath, generationFolder, 'schema.zmodel'))) {\n fs.writeFileSync(path.join(projectPath, generationFolder, 'schema.zmodel'), STARTER_ZMODEL);\n } else {\n console.log(colors.yellow('Schema file already exists. Skipping generation of sample.'));\n }\n\n console.log(colors.green('ZenStack project initialized successfully!'));\n console.log(colors.gray(`See \"${generationFolder}/schema.zmodel\" for your database schema.`));\n console.log(colors.gray('Run `zenstack generate` to compile the the schema into a TypeScript file.'));\n}\n","export const STARTER_ZMODEL = `// This is a sample model to get you started.\n\n/// A sample data source using local sqlite db.\ndatasource db {\n provider = 'sqlite'\n url = 'file:./dev.db'\n}\n\n/// User model\nmodel User {\n id String @id @default(cuid())\n email String @unique @email @length(6, 32)\n posts Post[]\n}\n\n/// Post model\nmodel Post {\n id String @id @default(cuid())\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n title String @length(1, 256)\n content String\n published Boolean @default(false)\n author User @relation(fields: [authorId], references: [id])\n authorId String\n}\n`;\n\nexport const STARTER_MAIN_TS = `import { ZenStackClient } from '@zenstackhq/runtime';\nimport SQLite from 'better-sqlite3';\nimport { SqliteDialect } from 'kysely';\nimport { schema } from './zenstack/schema';\n\nasync function main() {\n const client = new ZenStackClient(schema, {\n dialect: new SqliteDialect({\n database: new SQLite('./zenstack/dev.db'),\n }),\n });\n const user = await client.user.create({\n data: {\n email: 'test@zenstack.dev',\n posts: {\n create: [\n {\n title: 'Hello World',\n content: 'This is a test post',\n },\n ],\n },\n },\n include: { posts: true }\n });\n console.log('User created:', user);\n}\n\nmain();\n`;\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { CliError } from '../cli-error';\nimport { execPackage } from '../utils/exec-utils';\nimport { generateTempPrismaSchema, getSchemaFile } from './action-utils';\n\ntype CommonOptions = {\n schema?: string;\n migrations?: string;\n};\n\ntype DevOptions = CommonOptions & {\n name?: string;\n createOnly?: boolean;\n};\n\ntype ResetOptions = CommonOptions & {\n force?: boolean;\n};\n\ntype DeployOptions = CommonOptions;\n\ntype StatusOptions = CommonOptions;\n\ntype ResolveOptions = CommonOptions & {\n applied?: string;\n rolledBack?: string;\n};\n\n/**\n * CLI action for migration-related commands\n */\nexport async function run(command: string, options: CommonOptions) {\n const schemaFile = getSchemaFile(options.schema);\n const prismaSchemaDir = options.migrations ? path.dirname(options.migrations) : undefined;\n const prismaSchemaFile = await generateTempPrismaSchema(schemaFile, prismaSchemaDir);\n\n try {\n switch (command) {\n case 'dev':\n await runDev(prismaSchemaFile, options as DevOptions);\n break;\n\n case 'reset':\n await runReset(prismaSchemaFile, options as ResetOptions);\n break;\n\n case 'deploy':\n await runDeploy(prismaSchemaFile, options as DeployOptions);\n break;\n\n case 'status':\n await runStatus(prismaSchemaFile, options as StatusOptions);\n break;\n\n case 'resolve':\n await runResolve(prismaSchemaFile, options as ResolveOptions);\n break;\n }\n } finally {\n if (fs.existsSync(prismaSchemaFile)) {\n fs.unlinkSync(prismaSchemaFile);\n }\n }\n}\n\nasync function runDev(prismaSchemaFile: string, options: DevOptions) {\n try {\n const cmd = [\n 'prisma migrate dev',\n ` --schema \"${prismaSchemaFile}\"`,\n ' --skip-generate',\n options.name ? ` --name ${options.name}` : '',\n options.createOnly ? ' --create-only' : '',\n ].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runReset(prismaSchemaFile: string, options: ResetOptions) {\n try {\n const cmd = ['prisma migrate reset', ` --schema \"${prismaSchemaFile}\"`, options.force ? ' --force' : ''].join(\n '',\n );\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runDeploy(prismaSchemaFile: string, _options: DeployOptions) {\n try {\n const cmd = ['prisma migrate deploy', ` --schema \"${prismaSchemaFile}\"`].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runStatus(prismaSchemaFile: string, _options: StatusOptions) {\n try {\n await execPackage(`prisma migrate status --schema \"${prismaSchemaFile}\"`);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nasync function runResolve(prismaSchemaFile: string, options: ResolveOptions) {\n if (!options.applied && !options.rolledBack) {\n throw new CliError('Either --applied or --rolled-back option must be provided');\n }\n\n try {\n const cmd = [\n 'prisma migrate resolve',\n ` --schema \"${prismaSchemaFile}\"`,\n options.applied ? ` --applied ${options.applied}` : '',\n options.rolledBack ? ` --rolled-back ${options.rolledBack}` : '',\n ].join('');\n\n await execPackage(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction handleSubProcessError(err: unknown) {\n if (err instanceof Error && 'status' in err && typeof err.status === 'number') {\n process.exit(err.status);\n } else {\n process.exit(1);\n }\n}\n","import colors from 'colors';\nimport { getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n};\n\n/**\n * CLI action for validating schema without generation\n */\nexport async function run(options: Options) {\n const schemaFile = getSchemaFile(options.schema);\n\n try {\n await loadSchemaDocument(schemaFile);\n console.log(colors.green('✓ Schema validation completed successfully.'));\n } catch (error) {\n console.error(colors.red('✗ Schema validation failed.'));\n // Re-throw to maintain CLI exit code behavior\n throw error;\n }\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\nexport function getVersion() {\n try {\n // isomorphic __dirname\n const _dirname = typeof __dirname !== 'undefined' ? __dirname : path.dirname(fileURLToPath(import.meta.url));\n return JSON.parse(fs.readFileSync(path.join(_dirname, '../package.json'), 'utf8')).version;\n } catch {\n return undefined;\n }\n}\n"],"mappings":"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","names":["ZModelLanguageMetaData","colors","Command","CommanderError","Option","fs","execSync","_exec","execSync","cmd","options","env","restOptions","mergedEnv","process","undefined","_exec","encoding","stdio","execPackage","packageManager","versions","loadDocument","isDataSource","PrismaSchemaGenerator","colors","fs","path","CliError","Error","getSchemaFile","file","fs","existsSync","CliError","pkgJsonConfig","getPkgJsonConfig","process","cwd","schema","loadSchemaDocument","schemaFile","loadResult","loadDocument","success","errors","forEach","err","console","error","colors","red","warnings","warn","yellow","model","handleSubProcessError","Error","status","exit","generateTempPrismaSchema","zmodelPath","folder","declarations","some","isDataSource","prismaSchema","PrismaSchemaGenerator","generate","path","dirname","prismaSchemaFile","resolve","writeFileSync","startPath","result","undefined","output","pkgJsonFile","findUp","pkgJson","JSON","parse","readFileSync","zenstack","names","multiple","name","target","find","join","push","up","length","run","command","options","runPush","schemaFile","getSchemaFile","schema","prismaSchemaFile","generateTempPrismaSchema","cmd","acceptDataLoss","forceReset","join","execPackage","err","handleSubProcessError","fs","existsSync","unlinkSync","invariant","isPlugin","PrismaSchemaGenerator","TsSchemaGenerator","colors","fs","path","run","options","start","Date","now","schemaFile","getSchemaFile","schema","model","loadSchemaDocument","outputPath","getOutputPath","tsSchemaFile","path","join","TsSchemaGenerator","generate","runPlugins","savePrismaSchema","prismaSchema","PrismaSchemaGenerator","prismaSchemaFile","resolve","fs","mkdirSync","dirname","recursive","writeFileSync","silent","console","log","colors","green","output","pkgJsonConfig","getPkgJsonConfig","process","cwd","plugins","declarations","filter","isPlugin","plugin","providerField","fields","find","f","name","invariant","provider","value","useProvider","startsWith","slice","generator","default","colors","path","run","projectPath","packages","getZenStackPackages","console","error","log","versions","Set","pkg","version","add","colors","green","padEnd","size","warn","yellow","pkgJson","resolvedPath","path","resolve","join","with","type","default","Array","from","Object","keys","dependencies","devDependencies","filter","p","startsWith","sort","result","Promise","all","map","depPkgJson","undefined","colors","fs","path","ora","detect","resolveCommand","STARTER_ZMODEL","run","projectPath","packages","name","dev","pm","detect","agent","console","log","colors","gray","pkg","resolved","resolveCommand","CliError","spinner","ora","start","execSync","command","args","join","cwd","succeed","e","fail","generationFolder","fs","existsSync","path","mkdirSync","writeFileSync","STARTER_ZMODEL","yellow","green","fs","path","run","command","options","schemaFile","getSchemaFile","schema","prismaSchemaDir","migrations","path","dirname","undefined","prismaSchemaFile","generateTempPrismaSchema","runDev","runReset","runDeploy","runStatus","runResolve","fs","existsSync","unlinkSync","cmd","name","createOnly","join","execPackage","err","handleSubProcessError","force","_options","applied","rolledBack","CliError","Error","status","process","exit","colors","run","options","schemaFile","getSchemaFile","schema","loadSchemaDocument","console","log","colors","green","error","red","fs","path","fileURLToPath","getVersion","_dirname","__dirname","path","dirname","fileURLToPath","url","JSON","parse","fs","readFileSync","join","version","undefined","generateAction","options","generate","migrateAction","command","migrate","dbAction","db","infoAction","projectPath","info","initAction","init","validateAction","validate","createProgram","program","Command","version","getVersion","schemaExtensions","ZModelLanguageMetaData","fileExtensions","join","description","colors","bold","blue","showHelpAfterError","showSuggestionAfterError","schemaOption","Option","addOption","action","migrateCommand","migrationsOption","dbCommand","argument","parseAsync","catch","err","CliError","console","error","red","message","process","exit","CommanderError","exitCode"]}
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"publisher": "zenstack",
|
|
4
4
|
"displayName": "ZenStack CLI",
|
|
5
5
|
"description": "FullStack database toolkit with built-in access control and automatic API generation.",
|
|
6
|
-
"version": "3.0.0-alpha.
|
|
6
|
+
"version": "3.0.0-alpha.25",
|
|
7
7
|
"type": "module",
|
|
8
8
|
"author": {
|
|
9
9
|
"name": "ZenStack Team"
|
|
@@ -28,9 +28,9 @@
|
|
|
28
28
|
"ora": "^5.4.1",
|
|
29
29
|
"package-manager-detector": "^1.3.0",
|
|
30
30
|
"ts-pattern": "^5.7.1",
|
|
31
|
-
"@zenstackhq/
|
|
32
|
-
"@zenstackhq/language": "3.0.0-alpha.
|
|
33
|
-
"@zenstackhq/
|
|
31
|
+
"@zenstackhq/common-helpers": "3.0.0-alpha.25",
|
|
32
|
+
"@zenstackhq/language": "3.0.0-alpha.25",
|
|
33
|
+
"@zenstackhq/sdk": "3.0.0-alpha.25"
|
|
34
34
|
},
|
|
35
35
|
"peerDependencies": {
|
|
36
36
|
"prisma": "^6.0.0"
|
|
@@ -40,14 +40,14 @@
|
|
|
40
40
|
"@types/tmp": "^0.2.6",
|
|
41
41
|
"better-sqlite3": "^12.2.0",
|
|
42
42
|
"tmp": "^0.2.3",
|
|
43
|
-
"@zenstackhq/runtime": "3.0.0-alpha.
|
|
44
|
-
"@zenstackhq/
|
|
45
|
-
"@zenstackhq/
|
|
46
|
-
"@zenstackhq/vitest-config": "3.0.0-alpha.
|
|
47
|
-
"@zenstackhq/
|
|
43
|
+
"@zenstackhq/runtime": "3.0.0-alpha.25",
|
|
44
|
+
"@zenstackhq/eslint-config": "3.0.0-alpha.25",
|
|
45
|
+
"@zenstackhq/testtools": "3.0.0-alpha.25",
|
|
46
|
+
"@zenstackhq/vitest-config": "3.0.0-alpha.25",
|
|
47
|
+
"@zenstackhq/typescript-config": "3.0.0-alpha.25"
|
|
48
48
|
},
|
|
49
49
|
"scripts": {
|
|
50
|
-
"build": "tsup-node",
|
|
50
|
+
"build": "tsc --noEmit && tsup-node",
|
|
51
51
|
"watch": "tsup-node --watch",
|
|
52
52
|
"lint": "eslint src --ext ts",
|
|
53
53
|
"test": "vitest run",
|
package/src/actions/migrate.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import fs from 'node:fs';
|
|
2
2
|
import path from 'node:path';
|
|
3
|
+
import { CliError } from '../cli-error';
|
|
3
4
|
import { execPackage } from '../utils/exec-utils';
|
|
4
5
|
import { generateTempPrismaSchema, getSchemaFile } from './action-utils';
|
|
5
6
|
|
|
@@ -21,6 +22,11 @@ type DeployOptions = CommonOptions;
|
|
|
21
22
|
|
|
22
23
|
type StatusOptions = CommonOptions;
|
|
23
24
|
|
|
25
|
+
type ResolveOptions = CommonOptions & {
|
|
26
|
+
applied?: string;
|
|
27
|
+
rolledBack?: string;
|
|
28
|
+
};
|
|
29
|
+
|
|
24
30
|
/**
|
|
25
31
|
* CLI action for migration-related commands
|
|
26
32
|
*/
|
|
@@ -46,6 +52,10 @@ export async function run(command: string, options: CommonOptions) {
|
|
|
46
52
|
case 'status':
|
|
47
53
|
await runStatus(prismaSchemaFile, options as StatusOptions);
|
|
48
54
|
break;
|
|
55
|
+
|
|
56
|
+
case 'resolve':
|
|
57
|
+
await runResolve(prismaSchemaFile, options as ResolveOptions);
|
|
58
|
+
break;
|
|
49
59
|
}
|
|
50
60
|
} finally {
|
|
51
61
|
if (fs.existsSync(prismaSchemaFile)) {
|
|
@@ -100,6 +110,25 @@ async function runStatus(prismaSchemaFile: string, _options: StatusOptions) {
|
|
|
100
110
|
}
|
|
101
111
|
}
|
|
102
112
|
|
|
113
|
+
async function runResolve(prismaSchemaFile: string, options: ResolveOptions) {
|
|
114
|
+
if (!options.applied && !options.rolledBack) {
|
|
115
|
+
throw new CliError('Either --applied or --rolled-back option must be provided');
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
try {
|
|
119
|
+
const cmd = [
|
|
120
|
+
'prisma migrate resolve',
|
|
121
|
+
` --schema "${prismaSchemaFile}"`,
|
|
122
|
+
options.applied ? ` --applied ${options.applied}` : '',
|
|
123
|
+
options.rolledBack ? ` --rolled-back ${options.rolledBack}` : '',
|
|
124
|
+
].join('');
|
|
125
|
+
|
|
126
|
+
await execPackage(cmd);
|
|
127
|
+
} catch (err) {
|
|
128
|
+
handleSubProcessError(err);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
103
132
|
function handleSubProcessError(err: unknown) {
|
|
104
133
|
if (err instanceof Error && 'status' in err && typeof err.status === 'number') {
|
|
105
134
|
process.exit(err.status);
|
package/src/index.ts
CHANGED
|
@@ -95,9 +95,18 @@ export function createProgram() {
|
|
|
95
95
|
.command('status')
|
|
96
96
|
.addOption(schemaOption)
|
|
97
97
|
.addOption(migrationsOption)
|
|
98
|
-
.description('
|
|
98
|
+
.description('Check the status of your database migrations.')
|
|
99
99
|
.action((options) => migrateAction('status', options));
|
|
100
100
|
|
|
101
|
+
migrateCommand
|
|
102
|
+
.command('resolve')
|
|
103
|
+
.addOption(schemaOption)
|
|
104
|
+
.addOption(migrationsOption)
|
|
105
|
+
.addOption(new Option('--applied <migration>', 'record a specific migration as applied'))
|
|
106
|
+
.addOption(new Option('--rolled-back <migration>', 'record a specific migration as rolled back'))
|
|
107
|
+
.description('Resolve issues with database migrations in deployment databases')
|
|
108
|
+
.action((options) => migrateAction('resolve', options));
|
|
109
|
+
|
|
101
110
|
const dbCommand = program.command('db').description('Manage your database schema during development.');
|
|
102
111
|
|
|
103
112
|
dbCommand
|
package/test/migrate.test.ts
CHANGED
|
@@ -38,4 +38,35 @@ describe('CLI migrate commands test', () => {
|
|
|
38
38
|
runCli('migrate dev --name init', workDir);
|
|
39
39
|
runCli('migrate status', workDir);
|
|
40
40
|
});
|
|
41
|
+
|
|
42
|
+
it('supports migrate resolve', () => {
|
|
43
|
+
const workDir = createProject(model);
|
|
44
|
+
runCli('migrate dev --name init', workDir);
|
|
45
|
+
|
|
46
|
+
// find the migration record "timestamp_init"
|
|
47
|
+
const migrationRecords = fs.readdirSync(path.join(workDir, 'zenstack/migrations'));
|
|
48
|
+
const migration = migrationRecords.find((f) => f.endsWith('_init'));
|
|
49
|
+
|
|
50
|
+
// force a migration failure
|
|
51
|
+
fs.writeFileSync(path.join(workDir, 'zenstack/migrations', migration!, 'migration.sql'), 'invalid content');
|
|
52
|
+
|
|
53
|
+
// redeploy the migration, which will fail
|
|
54
|
+
fs.rmSync(path.join(workDir, 'zenstack/dev.db'), { force: true });
|
|
55
|
+
try {
|
|
56
|
+
runCli('migrate deploy', workDir);
|
|
57
|
+
} catch {
|
|
58
|
+
// noop
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// --rolled-back
|
|
62
|
+
runCli(`migrate resolve --rolled-back ${migration}`, workDir);
|
|
63
|
+
|
|
64
|
+
// --applied
|
|
65
|
+
runCli(`migrate resolve --applied ${migration}`, workDir);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it('should throw error when neither applied nor rolled-back is provided', () => {
|
|
69
|
+
const workDir = createProject(model);
|
|
70
|
+
expect(() => runCli('migrate resolve', workDir)).toThrow();
|
|
71
|
+
});
|
|
41
72
|
});
|