@zenstackhq/cli 3.0.0-alpha.25 → 3.0.0-alpha.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,5 +1,9 @@
1
1
  var __defProp = Object.defineProperty;
2
2
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+ var __export = (target, all) => {
4
+ for (var name in all)
5
+ __defProp(target, name, { get: all[name], enumerable: true });
6
+ };
3
7
 
4
8
  // src/index.ts
5
9
  import { ZModelLanguageMetaData } from "@zenstackhq/language";
@@ -185,31 +189,73 @@ __name(runPush, "runPush");
185
189
  // src/actions/generate.ts
186
190
  import { invariant } from "@zenstackhq/common-helpers";
187
191
  import { isPlugin } from "@zenstackhq/language/ast";
188
- import { PrismaSchemaGenerator as PrismaSchemaGenerator2, TsSchemaGenerator } from "@zenstackhq/sdk";
192
+ import { getLiteral, getLiteralArray } from "@zenstackhq/language/utils";
189
193
  import colors2 from "colors";
194
+ import path4 from "path";
195
+ import ora from "ora";
196
+
197
+ // src/plugins/index.ts
198
+ var plugins_exports = {};
199
+ __export(plugins_exports, {
200
+ prisma: () => prisma_default,
201
+ typescript: () => typescript_default
202
+ });
203
+
204
+ // src/plugins/prisma.ts
205
+ import { PrismaSchemaGenerator as PrismaSchemaGenerator2 } from "@zenstackhq/sdk";
190
206
  import fs3 from "fs";
191
207
  import path2 from "path";
208
+ var plugin = {
209
+ name: "Prisma Schema Generator",
210
+ statusText: "Generating Prisma schema",
211
+ async generate({ model, defaultOutputPath, pluginOptions }) {
212
+ let outDir = defaultOutputPath;
213
+ if (typeof pluginOptions["output"] === "string") {
214
+ outDir = path2.resolve(defaultOutputPath, pluginOptions["output"]);
215
+ if (!fs3.existsSync(outDir)) {
216
+ fs3.mkdirSync(outDir, {
217
+ recursive: true
218
+ });
219
+ }
220
+ }
221
+ const prismaSchema = await new PrismaSchemaGenerator2(model).generate();
222
+ fs3.writeFileSync(path2.join(outDir, "schema.prisma"), prismaSchema);
223
+ }
224
+ };
225
+ var prisma_default = plugin;
226
+
227
+ // src/plugins/typescript.ts
228
+ import { TsSchemaGenerator } from "@zenstackhq/sdk";
229
+ import fs4 from "fs";
230
+ import path3 from "path";
231
+ var plugin2 = {
232
+ name: "TypeScript Schema Generator",
233
+ statusText: "Generating TypeScript schema",
234
+ async generate({ model, defaultOutputPath, pluginOptions }) {
235
+ let outDir = defaultOutputPath;
236
+ if (typeof pluginOptions["output"] === "string") {
237
+ outDir = path3.resolve(defaultOutputPath, pluginOptions["output"]);
238
+ if (!fs4.existsSync(outDir)) {
239
+ fs4.mkdirSync(outDir, {
240
+ recursive: true
241
+ });
242
+ }
243
+ }
244
+ await new TsSchemaGenerator().generate(model, outDir);
245
+ }
246
+ };
247
+ var typescript_default = plugin2;
248
+
249
+ // src/actions/generate.ts
192
250
  async function run2(options) {
193
251
  const start = Date.now();
194
252
  const schemaFile = getSchemaFile(options.schema);
195
253
  const model = await loadSchemaDocument(schemaFile);
196
254
  const outputPath = getOutputPath(options, schemaFile);
197
- const tsSchemaFile = path2.join(outputPath, "schema.ts");
198
- await new TsSchemaGenerator().generate(schemaFile, [], outputPath);
199
- await runPlugins(model, outputPath, tsSchemaFile);
200
- if (options.savePrismaSchema) {
201
- const prismaSchema = await new PrismaSchemaGenerator2(model).generate();
202
- let prismaSchemaFile = path2.join(outputPath, "schema.prisma");
203
- if (typeof options.savePrismaSchema === "string") {
204
- prismaSchemaFile = path2.resolve(outputPath, options.savePrismaSchema);
205
- fs3.mkdirSync(path2.dirname(prismaSchemaFile), {
206
- recursive: true
207
- });
208
- }
209
- fs3.writeFileSync(prismaSchemaFile, prismaSchema);
210
- }
255
+ await runPlugins(schemaFile, model, outputPath);
211
256
  if (!options.silent) {
212
- console.log(colors2.green(`Generation completed successfully in ${Date.now() - start}ms.`));
257
+ console.log(colors2.green(`Generation completed successfully in ${Date.now() - start}ms.
258
+ `));
213
259
  console.log(`You can now create a ZenStack client with it.
214
260
 
215
261
  \`\`\`ts
@@ -231,34 +277,93 @@ function getOutputPath(options, schemaFile) {
231
277
  if (pkgJsonConfig.output) {
232
278
  return pkgJsonConfig.output;
233
279
  } else {
234
- return path2.dirname(schemaFile);
280
+ return path4.dirname(schemaFile);
235
281
  }
236
282
  }
237
283
  __name(getOutputPath, "getOutputPath");
238
- async function runPlugins(model, outputPath, tsSchemaFile) {
284
+ async function runPlugins(schemaFile, model, outputPath) {
239
285
  const plugins = model.declarations.filter(isPlugin);
240
- for (const plugin of plugins) {
241
- const providerField = plugin.fields.find((f) => f.name === "provider");
242
- invariant(providerField, `Plugin ${plugin.name} does not have a provider field`);
243
- const provider = providerField.value.value;
244
- let useProvider = provider;
245
- if (useProvider.startsWith("@core/")) {
246
- useProvider = `@zenstackhq/runtime/plugins/${useProvider.slice(6)}`;
286
+ const processedPlugins = [];
287
+ for (const plugin3 of plugins) {
288
+ const provider = getPluginProvider(plugin3);
289
+ let cliPlugin;
290
+ if (provider.startsWith("@core/")) {
291
+ cliPlugin = plugins_exports[provider.slice("@core/".length)];
292
+ if (!cliPlugin) {
293
+ throw new CliError(`Unknown core plugin: ${provider}`);
294
+ }
295
+ } else {
296
+ let moduleSpec = provider;
297
+ if (moduleSpec.startsWith(".")) {
298
+ moduleSpec = path4.resolve(path4.dirname(schemaFile), moduleSpec);
299
+ }
300
+ try {
301
+ cliPlugin = (await import(moduleSpec)).default;
302
+ } catch (error) {
303
+ throw new CliError(`Failed to load plugin ${provider}: ${error}`);
304
+ }
247
305
  }
248
- const generator = (await import(useProvider)).default;
249
- console.log("Running generator:", provider);
250
- await generator({
251
- model,
252
- outputPath,
253
- tsSchemaFile
306
+ processedPlugins.push({
307
+ cliPlugin,
308
+ pluginOptions: getPluginOptions(plugin3)
254
309
  });
255
310
  }
311
+ const defaultPlugins = [
312
+ typescript_default
313
+ ].reverse();
314
+ defaultPlugins.forEach((d) => {
315
+ if (!processedPlugins.some((p) => p.cliPlugin === d)) {
316
+ processedPlugins.push({
317
+ cliPlugin: d,
318
+ pluginOptions: {}
319
+ });
320
+ }
321
+ });
322
+ for (const { cliPlugin, pluginOptions } of processedPlugins) {
323
+ invariant(typeof cliPlugin.generate === "function", `Plugin ${cliPlugin.name} does not have a generate function`);
324
+ const spinner = ora(cliPlugin.statusText ?? `Running plugin ${cliPlugin.name}`).start();
325
+ try {
326
+ await cliPlugin.generate({
327
+ schemaFile,
328
+ model,
329
+ defaultOutputPath: outputPath,
330
+ pluginOptions
331
+ });
332
+ spinner.succeed();
333
+ } catch (err) {
334
+ spinner.fail();
335
+ console.error(err);
336
+ }
337
+ }
256
338
  }
257
339
  __name(runPlugins, "runPlugins");
340
+ function getPluginProvider(plugin3) {
341
+ const providerField = plugin3.fields.find((f) => f.name === "provider");
342
+ invariant(providerField, `Plugin ${plugin3.name} does not have a provider field`);
343
+ const provider = providerField.value.value;
344
+ return provider;
345
+ }
346
+ __name(getPluginProvider, "getPluginProvider");
347
+ function getPluginOptions(plugin3) {
348
+ const result = {};
349
+ for (const field of plugin3.fields) {
350
+ if (field.name === "provider") {
351
+ continue;
352
+ }
353
+ const value = getLiteral(field.value) ?? getLiteralArray(field.value);
354
+ if (value === void 0) {
355
+ console.warn(`Plugin "${plugin3.name}" option "${field.name}" has unsupported value, skipping`);
356
+ continue;
357
+ }
358
+ result[field.name] = value;
359
+ }
360
+ return result;
361
+ }
362
+ __name(getPluginOptions, "getPluginOptions");
258
363
 
259
364
  // src/actions/info.ts
260
365
  import colors3 from "colors";
261
- import path3 from "path";
366
+ import path5 from "path";
262
367
  async function run3(projectPath) {
263
368
  const packages = await getZenStackPackages(projectPath);
264
369
  if (!packages) {
@@ -280,9 +385,9 @@ async function run3(projectPath) {
280
385
  __name(run3, "run");
281
386
  async function getZenStackPackages(projectPath) {
282
387
  let pkgJson;
283
- const resolvedPath = path3.resolve(projectPath);
388
+ const resolvedPath = path5.resolve(projectPath);
284
389
  try {
285
- pkgJson = (await import(path3.join(resolvedPath, "package.json"), {
390
+ pkgJson = (await import(path5.join(resolvedPath, "package.json"), {
286
391
  with: {
287
392
  type: "json"
288
393
  }
@@ -318,9 +423,9 @@ __name(getZenStackPackages, "getZenStackPackages");
318
423
 
319
424
  // src/actions/init.ts
320
425
  import colors4 from "colors";
321
- import fs4 from "fs";
322
- import path4 from "path";
323
- import ora from "ora";
426
+ import fs5 from "fs";
427
+ import path6 from "path";
428
+ import ora2 from "ora";
324
429
  import { detect, resolveCommand } from "package-manager-detector";
325
430
 
326
431
  // src/actions/templates.ts
@@ -382,7 +487,7 @@ async function run4(projectPath) {
382
487
  if (!resolved) {
383
488
  throw new CliError(`Unable to determine how to install package "${pkg.name}". Please install it manually.`);
384
489
  }
385
- const spinner = ora(`Installing "${pkg.name}"`).start();
490
+ const spinner = ora2(`Installing "${pkg.name}"`).start();
386
491
  try {
387
492
  execSync(`${resolved.command} ${resolved.args.join(" ")}`, {
388
493
  cwd: projectPath
@@ -394,11 +499,11 @@ async function run4(projectPath) {
394
499
  }
395
500
  }
396
501
  const generationFolder = "zenstack";
397
- if (!fs4.existsSync(path4.join(projectPath, generationFolder))) {
398
- fs4.mkdirSync(path4.join(projectPath, generationFolder));
502
+ if (!fs5.existsSync(path6.join(projectPath, generationFolder))) {
503
+ fs5.mkdirSync(path6.join(projectPath, generationFolder));
399
504
  }
400
- if (!fs4.existsSync(path4.join(projectPath, generationFolder, "schema.zmodel"))) {
401
- fs4.writeFileSync(path4.join(projectPath, generationFolder, "schema.zmodel"), STARTER_ZMODEL);
505
+ if (!fs5.existsSync(path6.join(projectPath, generationFolder, "schema.zmodel"))) {
506
+ fs5.writeFileSync(path6.join(projectPath, generationFolder, "schema.zmodel"), STARTER_ZMODEL);
402
507
  } else {
403
508
  console.log(colors4.yellow("Schema file already exists. Skipping generation of sample."));
404
509
  }
@@ -409,11 +514,11 @@ async function run4(projectPath) {
409
514
  __name(run4, "run");
410
515
 
411
516
  // src/actions/migrate.ts
412
- import fs5 from "fs";
413
- import path5 from "path";
517
+ import fs6 from "fs";
518
+ import path7 from "path";
414
519
  async function run5(command, options) {
415
520
  const schemaFile = getSchemaFile(options.schema);
416
- const prismaSchemaDir = options.migrations ? path5.dirname(options.migrations) : void 0;
521
+ const prismaSchemaDir = options.migrations ? path7.dirname(options.migrations) : void 0;
417
522
  const prismaSchemaFile = await generateTempPrismaSchema(schemaFile, prismaSchemaDir);
418
523
  try {
419
524
  switch (command) {
@@ -434,8 +539,8 @@ async function run5(command, options) {
434
539
  break;
435
540
  }
436
541
  } finally {
437
- if (fs5.existsSync(prismaSchemaFile)) {
438
- fs5.unlinkSync(prismaSchemaFile);
542
+ if (fs6.existsSync(prismaSchemaFile)) {
543
+ fs6.unlinkSync(prismaSchemaFile);
439
544
  }
440
545
  }
441
546
  }
@@ -529,13 +634,13 @@ async function run6(options) {
529
634
  __name(run6, "run");
530
635
 
531
636
  // src/utils/version-utils.ts
532
- import fs6 from "fs";
533
- import path6 from "path";
637
+ import fs7 from "fs";
638
+ import path8 from "path";
534
639
  import { fileURLToPath } from "url";
535
640
  function getVersion() {
536
641
  try {
537
- const _dirname = typeof __dirname !== "undefined" ? __dirname : path6.dirname(fileURLToPath(import.meta.url));
538
- return JSON.parse(fs6.readFileSync(path6.join(_dirname, "../package.json"), "utf8")).version;
642
+ const _dirname = typeof __dirname !== "undefined" ? __dirname : path8.dirname(fileURLToPath(import.meta.url));
643
+ return JSON.parse(fs7.readFileSync(path8.join(_dirname, "../package.json"), "utf8")).version;
539
644
  } catch {
540
645
  return void 0;
541
646
  }
@@ -569,7 +674,7 @@ function createProgram() {
569
674
 
570
675
  Documentation: https://zenstack.dev.`).showHelpAfterError().showSuggestionAfterError();
571
676
  const schemaOption = new Option("--schema <file>", `schema file (with extension ${schemaExtensions}). Defaults to "schema.zmodel" unless specified in package.json.`);
572
- program2.command("generate").description("Run code generation.").addOption(schemaOption).addOption(new Option("--silent", "do not print any output")).addOption(new Option("--save-prisma-schema [path]", "save a Prisma schema file, by default into the output directory")).addOption(new Option("-o, --output <path>", "default output directory for core plugins")).action(generateAction);
677
+ program2.command("generate").description("Run code generation.").addOption(schemaOption).addOption(new Option("--silent", "do not print any output")).addOption(new Option("-o, --output <path>", "default output directory for core plugins")).action(generateAction);
573
678
  const migrateCommand = program2.command("migrate").description("Update the database schema with migrations.");
574
679
  const migrationsOption = new Option("--migrations <path>", "path for migrations");
575
680
  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));
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 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":";;;;AAAA,SAASA,8BAA8B;AACvC,OAAOC,aAAY;AACnB,SAASC,SAASC,gBAAgBC,cAAc;;;ACFhD,OAAOC,SAAQ;;;ACAf,SAASC,YAAYC,aAAmC;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,QAAMP,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,SAASG,oBAAoB;AAC7B,SAASC,oBAAoB;AAC7B,SAASC,6BAA6B;AACtC,OAAOC,YAAY;AACnB,OAAOC,QAAQ;AACf,OAAOC,UAAU;;;ACFV,IAAMC,WAAN,cAAuBC,MAAAA;EAH9B,OAG8BA;;;AAAO;;;ADK9B,SAASC,cAAcC,MAAa;AACvC,MAAIA,MAAM;AACN,QAAI,CAACC,GAAGC,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,GAAGC,WAAWE,cAAcI,MAAM,GAAG;AACtC,YAAM,IAAIL,SAAS,0BAA0BC,cAAcI,MAAM,EAAE;IACvE;AACA,WAAOJ,cAAcI;EACzB;AAEA,MAAIP,GAAGC,WAAW,0BAAA,GAA6B;AAC3C,WAAO;EACX,WAAWD,GAAGC,WAAW,iBAAA,GAAoB;AACzC,WAAO;EACX,OAAO;AACH,UAAM,IAAIC,SACN,+FAAA;EAER;AACJ;AAzBgBJ;AA2BhB,eAAsBU,mBAAmBC,YAAkB;AACvD,QAAMC,aAAa,MAAMC,aAAaF,UAAAA;AACtC,MAAI,CAACC,WAAWE,SAAS;AACrBF,eAAWG,OAAOC,QAAQ,CAACC,QAAAA;AACvBC,cAAQC,MAAMC,OAAOC,IAAIJ,GAAAA,CAAAA;IAC7B,CAAA;AACA,UAAM,IAAIb,SAAS,gDAAA;EACvB;AACAQ,aAAWU,SAASN,QAAQ,CAACO,SAAAA;AACzBL,YAAQK,KAAKH,OAAOI,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,YAAAA,GAAe;AACxC,UAAM,IAAI/B,SAAS,iCAAA;EACvB;AACA,QAAMgC,eAAe,MAAM,IAAIC,sBAAsBZ,KAAAA,EAAOa,SAAQ;AACpE,MAAI,CAACN,QAAQ;AACTA,aAASO,KAAKC,QAAQT,UAAAA;EAC1B;AACA,QAAMU,mBAAmBF,KAAKG,QAAQV,QAAQ,gBAAA;AAC9C9B,KAAGyC,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,GAAGmD,aAAaL,aAAa,MAAA,CAAA;EACtD,QAAQ;AACJ,WAAOH;EACX;AAEA,MAAIK,QAAQI,YAAY,OAAOJ,QAAQI,aAAa,UAAU;AAC1DT,WAAOpC,SAASyC,QAAQI,SAAS7C,UAAU8B,KAAKG,QAAQH,KAAKC,QAAQQ,WAAAA,GAAcE,QAAQI,SAAS7C,MAAM;AAC1GoC,WAAOE,SAASG,QAAQI,SAASP,UAAUR,KAAKG,QAAQH,KAAKC,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,GAAGC,WAAWoC,KAAKqB,KAAKpD,KAAKiD,IAAAA,CAAAA,CAAAA;AACjE,MAAID,aAAa,SAASE,QAAQ;AAC9B,WAAOnB,KAAKqB,KAAKpD,KAAKkD,MAAAA;EAC1B;AACA,MAAIA,QAAQ;AACRb,WAAOgB,KAAKtB,KAAKqB,KAAKpD,KAAKkD,MAAAA,CAAAA;EAC/B;AACA,QAAMI,KAAKvB,KAAKG,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,IAAGC,WAAWV,gBAAAA,GAAmB;AACjCS,MAAAA,IAAGE,WAAWX,gBAAAA;IAClB;EACJ;AACJ;AAzBeJ;;;AIrBf,SAASgB,iBAAiB;AAC1B,SAASC,gBAAyC;AAClD,SAASC,yBAAAA,wBAAuBC,yBAA4C;AAC5E,OAAOC,aAAY;AACnB,OAAOC,SAAQ;AACf,OAAOC,WAAU;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,MAAKC,KAAKJ,YAAY,WAAA;AAC3C,QAAM,IAAIK,kBAAAA,EAAoBC,SAASX,YAAY,CAAA,GAAIK,UAAAA;AAEvD,QAAMO,WAAWT,OAAOE,YAAYE,YAAAA;AAGpC,MAAIX,QAAQiB,kBAAkB;AAC1B,UAAMC,eAAe,MAAM,IAAIC,uBAAsBZ,KAAAA,EAAOQ,SAAQ;AACpE,QAAIK,mBAAmBR,MAAKC,KAAKJ,YAAY,eAAA;AAC7C,QAAI,OAAOT,QAAQiB,qBAAqB,UAAU;AAC9CG,yBAAmBR,MAAKS,QAAQZ,YAAYT,QAAQiB,gBAAgB;AACpEK,MAAAA,IAAGC,UAAUX,MAAKY,QAAQJ,gBAAAA,GAAmB;QAAEK,WAAW;MAAK,CAAA;IACnE;AACAH,IAAAA,IAAGI,cAAcN,kBAAkBF,YAAAA;EACvC;AAEA,MAAI,CAAClB,QAAQ2B,QAAQ;AACjBC,YAAQC,IAAIC,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,MAAKY,QAAQpB,UAAAA;EACxB;AACJ;AAVSM;AAYT,eAAeM,WAAWT,OAAcE,YAAoBE,cAAoB;AAC5E,QAAM0B,UAAU9B,MAAM+B,aAAaC,OAAOC,QAAAA;AAC1C,aAAWC,UAAUJ,SAAS;AAC1B,UAAMK,gBAAgBD,OAAOE,OAAOC,KAAK,CAACC,MAAMA,EAAEC,SAAS,UAAA;AAC3DC,cAAUL,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,OAAOuC,aAAY;AACnB,OAAOC,WAAU;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,QAAOC,MAAMJ,IAAIK,OAAO,EAAA,CAAA,CAAA,IAASJ,OAAAA,EAAS;EACjE;AAEA,MAAIH,SAASQ,OAAO,GAAG;AACnBX,YAAQY,KAAKJ,QAAOK,OAAO,kFAAA,CAAA;EAC/B;AACJ;AAnBsBjB,OAAAA,MAAAA;AAqBtB,eAAeG,oBAAoBF,aAAmB;AAClD,MAAIiB;AAIJ,QAAMC,eAAeC,MAAKC,QAAQpB,WAAAA;AAClC,MAAI;AACAiB,eACI,MAAM,OAAOE,MAAKE,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,OAAOuC,aAAY;AACnB,OAAOC,SAAQ;AACf,OAAOC,WAAU;AACjB,OAAOC,SAAS;AAChB,SAASC,QAAQC,sBAAsB;;;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,MAAMC,OAAAA;AACf,MAAI,CAACD,IAAI;AACLA,SAAK;MAAEE,OAAO;MAAOJ,MAAM;IAAM;EACrC;AAEAK,UAAQC,IAAIC,QAAOC,KAAK,0BAA0BN,GAAGE,KAAK,EAAE,CAAA;AAE5D,aAAWK,OAAOV,UAAU;AACxB,UAAMW,WAAWC,eAAeT,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,UAAUC,IAAI,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,IAAGC,WAAWC,MAAKR,KAAKrB,aAAa0B,gBAAAA,CAAAA,GAAoB;AAC1DC,IAAAA,IAAGG,UAAUD,MAAKR,KAAKrB,aAAa0B,gBAAAA,CAAAA;EACxC;AAEA,MAAI,CAACC,IAAGC,WAAWC,MAAKR,KAAKrB,aAAa0B,kBAAkB,eAAA,CAAA,GAAmB;AAC3EC,IAAAA,IAAGI,cAAcF,MAAKR,KAAKrB,aAAa0B,kBAAkB,eAAA,GAAkBM,cAAAA;EAChF,OAAO;AACHzB,YAAQC,IAAIC,QAAOwB,OAAO,4DAAA,CAAA;EAC9B;AAEA1B,UAAQC,IAAIC,QAAOyB,MAAM,4CAAA,CAAA;AACzB3B,UAAQC,IAAIC,QAAOC,KAAK,QAAQgB,gBAAAA,2CAA2D,CAAA;AAC3FnB,UAAQC,IAAIC,QAAOC,KAAK,2EAAA,CAAA;AAC5B;AAhDsBX,OAAAA,MAAAA;;;AEZtB,OAAOoC,SAAQ;AACf,OAAOC,WAAU;AA+BjB,eAAsBC,KAAIC,SAAiBC,SAAsB;AAC7D,QAAMC,aAAaC,cAAcF,QAAQG,MAAM;AAC/C,QAAMC,kBAAkBJ,QAAQK,aAAaC,MAAKC,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;MAEJ,KAAK;AACD,cAAMe,WAAWN,kBAAkBT,OAAAA;AACnC;IACR;EACJ,UAAA;AACI,QAAIgB,IAAGC,WAAWR,gBAAAA,GAAmB;AACjCO,MAAAA,IAAGE,WAAWT,gBAAAA;IAClB;EACJ;AACJ;AAhCsBX,OAAAA,MAAAA;AAkCtB,eAAea,OAAOF,kBAA0BT,SAAmB;AAC/D,MAAI;AACA,UAAMmB,MAAM;MACR;MACA,cAAcV,gBAAAA;MACd;MACAT,QAAQoB,OAAO,WAAWpB,QAAQoB,IAAI,KAAK;MAC3CpB,QAAQqB,aAAa,mBAAmB;MAC1CC,KAAK,EAAA;AAEP,UAAMC,YAAYJ,GAAAA;EACtB,SAASK,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AAdeb;AAgBf,eAAeC,SAASH,kBAA0BT,SAAqB;AACnE,MAAI;AACA,UAAMmB,MAAM;MAAC;MAAwB,cAAcV,gBAAAA;MAAqBT,QAAQ0B,QAAQ,aAAa;MAAIJ,KACrG,EAAA;AAGJ,UAAMC,YAAYJ,GAAAA;EACtB,SAASK,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AAVeZ;AAYf,eAAeC,UAAUJ,kBAA0BkB,UAAuB;AACtE,MAAI;AACA,UAAMR,MAAM;MAAC;MAAyB,cAAcV,gBAAAA;MAAqBa,KAAK,EAAA;AAE9E,UAAMC,YAAYJ,GAAAA;EACtB,SAASK,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AAReX;AAUf,eAAeC,UAAUL,kBAA0BkB,UAAuB;AACtE,MAAI;AACA,UAAMJ,YAAY,mCAAmCd,gBAAAA,GAAmB;EAC5E,SAASe,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AANeV;AAQf,eAAeC,WAAWN,kBAA0BT,SAAuB;AACvE,MAAI,CAACA,QAAQ4B,WAAW,CAAC5B,QAAQ6B,YAAY;AACzC,UAAM,IAAIC,SAAS,2DAAA;EACvB;AAEA,MAAI;AACA,UAAMX,MAAM;MACR;MACA,cAAcV,gBAAAA;MACdT,QAAQ4B,UAAU,cAAc5B,QAAQ4B,OAAO,KAAK;MACpD5B,QAAQ6B,aAAa,kBAAkB7B,QAAQ6B,UAAU,KAAK;MAChEP,KAAK,EAAA;AAEP,UAAMC,YAAYJ,GAAAA;EACtB,SAASK,KAAK;AACVC,IAAAA,uBAAsBD,GAAAA;EAC1B;AACJ;AAjBeT;AAmBf,SAASU,uBAAsBD,KAAY;AACvC,MAAIA,eAAeO,SAAS,YAAYP,OAAO,OAAOA,IAAIQ,WAAW,UAAU;AAC3EC,YAAQC,KAAKV,IAAIQ,MAAM;EAC3B,OAAO;AACHC,YAAQC,KAAK,CAAA;EACjB;AACJ;AANST,OAAAA,wBAAAA;;;ACnIT,OAAOU,aAAY;AAUnB,eAAsBC,KAAIC,SAAgB;AACtC,QAAMC,aAAaC,cAAcF,QAAQG,MAAM;AAE/C,MAAI;AACA,UAAMC,mBAAmBH,UAAAA;AACzBI,YAAQC,IAAIC,QAAOC,MAAM,kDAAA,CAAA;EAC7B,SAASC,OAAO;AACZJ,YAAQI,MAAMF,QAAOG,IAAI,kCAAA,CAAA;AAEzB,UAAMD;EACV;AACJ;AAXsBV,OAAAA,MAAAA;;;ACVtB,OAAOY,SAAQ;AACf,OAAOC,WAAU;AACjB,SAASC,qBAAqB;AAEvB,SAASC,aAAAA;AACZ,MAAI;AAEA,UAAMC,WAAW,OAAOC,cAAc,cAAcA,YAAYC,MAAKC,QAAQC,cAAc,YAAYC,GAAG,CAAA;AAC1G,WAAOC,KAAKC,MAAMC,IAAGC,aAAaP,MAAKQ,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,QAAQ,UAAA;AAE5BD,EAAAA,SAAQE,QAAQC,WAAAA,GAAe,gBAAgB,qBAAA;AAE/C,QAAMC,mBAAmBC,uBAAuBC,eAAeC,KAAK,IAAA;AAEpEP,EAAAA,SACKQ,YACG,GAAGC,QAAOC,KAAKC,KACX,QAAA,CAAA;;qCACkG,EAEzGC,mBAAkB,EAClBC,yBAAwB;AAE7B,QAAMC,eAAe,IAAIC,OACrB,mBACA,+BAA+BX,gBAAAA,kEAAkF;AAGrHJ,EAAAA,SACKZ,QAAQ,UAAA,EACRoB,YAAY,sBAAA,EACZQ,UAAUF,YAAAA,EACVE,UAAU,IAAID,OAAO,YAAY,yBAAA,CAAA,EACjCC,UACG,IAAID,OACA,+BACA,iEAAA,CAAA,EAGPC,UAAU,IAAID,OAAO,uBAAuB,2CAAA,CAAA,EAC5CE,OAAOjC,cAAAA;AAEZ,QAAMkC,iBAAiBlB,SAAQZ,QAAQ,SAAA,EAAWoB,YAAY,6CAAA;AAC9D,QAAMW,mBAAmB,IAAIJ,OAAO,uBAAuB,qBAAA;AAE3DG,iBACK9B,QAAQ,KAAA,EACR4B,UAAUF,YAAAA,EACVE,UAAU,IAAID,OAAO,qBAAqB,gBAAA,CAAA,EAC1CC,UAAU,IAAID,OAAO,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,OAAO,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;AAEjDiC,iBACK9B,QAAQ,SAAA,EACR4B,UAAUF,YAAAA,EACVE,UAAUG,gBAAAA,EACVH,UAAU,IAAID,OAAO,yBAAyB,wCAAA,CAAA,EAC9CC,UAAU,IAAID,OAAO,6BAA6B,4CAAA,CAAA,EAClDP,YAAY,iEAAA,EACZS,OAAO,CAAChC,YAAYE,cAAc,WAAWF,OAAAA,CAAAA;AAElD,QAAMmC,YAAYpB,SAAQZ,QAAQ,IAAA,EAAMoB,YAAY,iDAAA;AAEpDY,YACKhC,QAAQ,MAAA,EACRoB,YAAY,kDAAA,EACZQ,UAAUF,YAAAA,EACVE,UAAU,IAAID,OAAO,sBAAsB,2BAAA,CAAA,EAC3CC,UAAU,IAAID,OAAO,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;AAvGgBD;AAyGhB,IAAMC,UAAUD,cAAAA;AAEhBC,QAAQsB,WAAU,EAAGC,MAAM,CAACC,QAAAA;AACxB,MAAIA,eAAeC,UAAU;AACzBC,YAAQC,MAAMlB,QAAOmB,IAAIJ,IAAIK,OAAO,CAAA;AACpCC,YAAQC,KAAK,CAAA;EACjB,WAAWP,eAAeQ,gBAAgB;AAEtCF,YAAQC,KAAKP,IAAIS,QAAQ;EAC7B,OAAO;AACHP,YAAQC,MAAMlB,QAAOmB,IAAI,+BAAA,CAAA;AACzBF,YAAQC,MAAMH,GAAAA;AACdM,YAAQC,KAAK,CAAA;EACjB;AACJ,CAAA;","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"]}
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/plugins/index.ts","../src/plugins/prisma.ts","../src/plugins/typescript.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(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, Plugin, type Model } from '@zenstackhq/language/ast';\nimport { getLiteral, getLiteralArray } from '@zenstackhq/language/utils';\nimport { type CliPlugin } from '@zenstackhq/sdk';\nimport colors from 'colors';\nimport path from 'node:path';\nimport ora from 'ora';\nimport { CliError } from '../cli-error';\nimport * as corePlugins from '../plugins';\nimport { getPkgJsonConfig, getSchemaFile, loadSchemaDocument } from './action-utils';\n\ntype Options = {\n schema?: string;\n output?: string;\n silent?: 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 await runPlugins(schemaFile, model, outputPath);\n\n if (!options.silent) {\n console.log(colors.green(`Generation completed successfully in ${Date.now() - start}ms.\\n`));\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(schemaFile: string, model: Model, outputPath: string) {\n const plugins = model.declarations.filter(isPlugin);\n const processedPlugins: { cliPlugin: CliPlugin; pluginOptions: Record<string, unknown> }[] = [];\n\n for (const plugin of plugins) {\n const provider = getPluginProvider(plugin);\n\n let cliPlugin: CliPlugin;\n if (provider.startsWith('@core/')) {\n cliPlugin = (corePlugins as any)[provider.slice('@core/'.length)];\n if (!cliPlugin) {\n throw new CliError(`Unknown core plugin: ${provider}`);\n }\n } else {\n let moduleSpec = provider;\n if (moduleSpec.startsWith('.')) {\n // relative to schema's path\n moduleSpec = path.resolve(path.dirname(schemaFile), moduleSpec);\n }\n try {\n cliPlugin = (await import(moduleSpec)).default as CliPlugin;\n } catch (error) {\n throw new CliError(`Failed to load plugin ${provider}: ${error}`);\n }\n }\n\n processedPlugins.push({ cliPlugin, pluginOptions: getPluginOptions(plugin) });\n }\n\n const defaultPlugins = [corePlugins['typescript']].reverse();\n defaultPlugins.forEach((d) => {\n if (!processedPlugins.some((p) => p.cliPlugin === d)) {\n processedPlugins.push({ cliPlugin: d, pluginOptions: {} });\n }\n });\n\n for (const { cliPlugin, pluginOptions } of processedPlugins) {\n invariant(\n typeof cliPlugin.generate === 'function',\n `Plugin ${cliPlugin.name} does not have a generate function`,\n );\n\n // run plugin generator\n const spinner = ora(cliPlugin.statusText ?? `Running plugin ${cliPlugin.name}`).start();\n try {\n await cliPlugin.generate({\n schemaFile,\n model,\n defaultOutputPath: outputPath,\n pluginOptions,\n });\n spinner.succeed();\n } catch (err) {\n spinner.fail();\n console.error(err);\n }\n }\n}\n\nfunction getPluginProvider(plugin: Plugin) {\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 return provider;\n}\n\nfunction getPluginOptions(plugin: Plugin): Record<string, unknown> {\n const result: Record<string, unknown> = {};\n for (const field of plugin.fields) {\n if (field.name === 'provider') {\n continue; // skip provider\n }\n const value = getLiteral(field.value) ?? getLiteralArray(field.value);\n if (value === undefined) {\n console.warn(`Plugin \"${plugin.name}\" option \"${field.name}\" has unsupported value, skipping`);\n continue;\n }\n result[field.name] = value;\n }\n return result;\n}\n","export { default as prisma } from './prisma';\nexport { default as typescript } from './typescript';\n","import { PrismaSchemaGenerator, type CliPlugin } from '@zenstackhq/sdk';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nconst plugin: CliPlugin = {\n name: 'Prisma Schema Generator',\n statusText: 'Generating Prisma schema',\n async generate({ model, defaultOutputPath, pluginOptions }) {\n let outDir = defaultOutputPath;\n if (typeof pluginOptions['output'] === 'string') {\n outDir = path.resolve(defaultOutputPath, pluginOptions['output']);\n if (!fs.existsSync(outDir)) {\n fs.mkdirSync(outDir, { recursive: true });\n }\n }\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n fs.writeFileSync(path.join(outDir, 'schema.prisma'), prismaSchema);\n },\n};\n\nexport default plugin;\n","import type { CliPlugin } from '@zenstackhq/sdk';\nimport { TsSchemaGenerator } from '@zenstackhq/sdk';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nconst plugin: CliPlugin = {\n name: 'TypeScript Schema Generator',\n statusText: 'Generating TypeScript schema',\n async generate({ model, defaultOutputPath, pluginOptions }) {\n let outDir = defaultOutputPath;\n if (typeof pluginOptions['output'] === 'string') {\n outDir = path.resolve(defaultOutputPath, pluginOptions['output']);\n if (!fs.existsSync(outDir)) {\n fs.mkdirSync(outDir, { recursive: true });\n }\n }\n await new TsSchemaGenerator().generate(model, outDir);\n },\n};\n\nexport default plugin;\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","getLiteral","getLiteralArray","colors","path","ora","PrismaSchemaGenerator","fs","path","plugin","name","statusText","generate","model","defaultOutputPath","pluginOptions","outDir","resolve","existsSync","mkdirSync","recursive","prismaSchema","writeFileSync","join","TsSchemaGenerator","fs","path","plugin","name","statusText","generate","model","defaultOutputPath","pluginOptions","outDir","resolve","existsSync","mkdirSync","recursive","run","options","start","Date","now","schemaFile","getSchemaFile","schema","model","loadSchemaDocument","outputPath","getOutputPath","runPlugins","silent","console","log","colors","green","output","pkgJsonConfig","getPkgJsonConfig","process","cwd","path","dirname","plugins","declarations","filter","isPlugin","processedPlugins","plugin","provider","getPluginProvider","cliPlugin","startsWith","corePlugins","slice","length","CliError","moduleSpec","resolve","default","error","push","pluginOptions","getPluginOptions","defaultPlugins","reverse","forEach","d","some","p","invariant","generate","name","spinner","ora","statusText","defaultOutputPath","succeed","err","fail","providerField","fields","find","f","value","result","field","getLiteral","getLiteralArray","undefined","warn","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.25",
6
+ "version": "3.0.0-alpha.27",
7
7
  "type": "module",
8
8
  "author": {
9
9
  "name": "ZenStack Team"
@@ -28,23 +28,23 @@
28
28
  "ora": "^5.4.1",
29
29
  "package-manager-detector": "^1.3.0",
30
30
  "ts-pattern": "^5.7.1",
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"
31
+ "@zenstackhq/language": "3.0.0-alpha.27",
32
+ "@zenstackhq/common-helpers": "3.0.0-alpha.27",
33
+ "@zenstackhq/sdk": "3.0.0-alpha.27"
34
34
  },
35
35
  "peerDependencies": {
36
- "prisma": "^6.0.0"
36
+ "prisma": "^6.14.0"
37
37
  },
38
38
  "devDependencies": {
39
39
  "@types/better-sqlite3": "^7.6.13",
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.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"
43
+ "@zenstackhq/eslint-config": "3.0.0-alpha.27",
44
+ "@zenstackhq/runtime": "3.0.0-alpha.27",
45
+ "@zenstackhq/testtools": "3.0.0-alpha.27",
46
+ "@zenstackhq/typescript-config": "3.0.0-alpha.27",
47
+ "@zenstackhq/vitest-config": "3.0.0-alpha.27"
48
48
  },
49
49
  "scripts": {
50
50
  "build": "tsc --noEmit && tsup-node",