@zenstackhq/cli 3.0.0-beta.21 → 3.0.0-beta.23

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.
@@ -1,5 +1,5 @@
1
1
 
2
- > @zenstackhq/cli@3.0.0-beta.21 build /home/runner/work/zenstack-v3/zenstack-v3/packages/cli
2
+ > @zenstackhq/cli@3.0.0-beta.23 build /home/runner/work/zenstack-v3/zenstack-v3/packages/cli
3
3
  > tsc --noEmit && tsup-node
4
4
 
5
5
  CLI Building entry: {"index":"src/index.ts"}
@@ -10,13 +10,31 @@
10
10
  CLI Cleaning output folder
11
11
  ESM Build start
12
12
  CJS Build start
13
- CJS dist/index.cjs 36.83 KB
14
- CJS dist/index.cjs.map 69.67 KB
15
- CJS ⚡️ Build success in 176ms
16
- ESM dist/index.js 32.75 KB
17
- ESM dist/index.js.map 69.17 KB
18
- ESM ⚡️ Build success in 183ms
13
+ [warn] ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta]
14
+
15
+ src/utils/exec-utils.ts:28:15:
16
+  28 │ if (typeof import.meta.resolve === 'function') {
17
+ ~~~~~~~~~~~
18
+
19
+ You need to set the output format to "esm" for "import.meta" to work correctly.
20
+
21
+
22
+ [warn] ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta]
23
+
24
+ src/utils/exec-utils.ts:30:35:
25
+  30 │ ...rismaPath = fileURLToPath(import.meta.resolve('prisma/build/ind...
26
+ ╵ ~~~~~~~~~~~
27
+
28
+ You need to set the output format to "esm" for "import.meta" to work correctly.
29
+
30
+
31
+ ESM dist/index.js 33.49 KB
32
+ ESM dist/index.js.map 70.32 KB
33
+ ESM ⚡️ Build success in 195ms
34
+ CJS dist/index.cjs 37.29 KB
35
+ CJS dist/index.cjs.map 70.85 KB
36
+ CJS ⚡️ Build success in 196ms
19
37
  DTS Build start
20
- DTS ⚡️ Build success in 3601ms
38
+ DTS ⚡️ Build success in 3661ms
21
39
  DTS dist/index.d.ts 13.00 B
22
40
  DTS dist/index.d.cts 13.00 B
package/dist/index.cjs CHANGED
@@ -37,6 +37,8 @@ var import_node_fs2 = __toESM(require("fs"), 1);
37
37
 
38
38
  // src/utils/exec-utils.ts
39
39
  var import_child_process = require("child_process");
40
+ var import_url = require("url");
41
+ var import_meta = {};
40
42
  function execSync(cmd, options) {
41
43
  const { env: env2, ...restOptions } = options ?? {};
42
44
  const mergedEnv = env2 ? {
@@ -51,11 +53,16 @@ function execSync(cmd, options) {
51
53
  });
52
54
  }
53
55
  __name(execSync, "execSync");
54
- function execPackage(cmd, options) {
55
- const packageManager = process?.versions?.["bun"] ? "bunx" : "npx";
56
- execSync(`${packageManager} ${cmd}`, options);
56
+ function execPrisma(args, options) {
57
+ let prismaPath;
58
+ if (typeof import_meta.resolve === "function") {
59
+ prismaPath = (0, import_url.fileURLToPath)(import_meta.resolve("prisma/build/index.js"));
60
+ } else {
61
+ prismaPath = require.resolve("prisma/build/index.js");
62
+ }
63
+ execSync(`node ${prismaPath} ${args}`, options);
57
64
  }
58
- __name(execPackage, "execPackage");
65
+ __name(execPrisma, "execPrisma");
59
66
 
60
67
  // src/actions/action-utils.ts
61
68
  var import_language = require("@zenstackhq/language");
@@ -85,7 +92,15 @@ function getSchemaFile(file) {
85
92
  if (!import_node_fs.default.existsSync(pkgJsonConfig.schema)) {
86
93
  throw new CliError(`Schema file not found: ${pkgJsonConfig.schema}`);
87
94
  }
88
- return pkgJsonConfig.schema;
95
+ if (import_node_fs.default.statSync(pkgJsonConfig.schema).isDirectory()) {
96
+ const schemaPath = import_node_path.default.join(pkgJsonConfig.schema, "schema.zmodel");
97
+ if (!import_node_fs.default.existsSync(schemaPath)) {
98
+ throw new CliError(`Schema file not found: ${schemaPath}`);
99
+ }
100
+ return schemaPath;
101
+ } else {
102
+ return pkgJsonConfig.schema;
103
+ }
89
104
  }
90
105
  if (import_node_fs.default.existsSync("./zenstack/schema.zmodel")) {
91
106
  return "./zenstack/schema.zmodel";
@@ -189,14 +204,14 @@ async function runPush(options) {
189
204
  const prismaSchemaFile = await generateTempPrismaSchema(schemaFile);
190
205
  try {
191
206
  const cmd = [
192
- "prisma db push",
207
+ "db push",
193
208
  ` --schema "${prismaSchemaFile}"`,
194
209
  options.acceptDataLoss ? " --accept-data-loss" : "",
195
210
  options.forceReset ? " --force-reset" : "",
196
211
  " --skip-generate"
197
212
  ].join("");
198
213
  try {
199
- await execPackage(cmd);
214
+ execPrisma(cmd);
200
215
  } catch (err) {
201
216
  handleSubProcessError(err);
202
217
  }
@@ -588,67 +603,67 @@ async function run5(command, options) {
588
603
  }
589
604
  }
590
605
  __name(run5, "run");
591
- async function runDev(prismaSchemaFile, options) {
606
+ function runDev(prismaSchemaFile, options) {
592
607
  try {
593
608
  const cmd = [
594
- "prisma migrate dev",
609
+ "migrate dev",
595
610
  ` --schema "${prismaSchemaFile}"`,
596
611
  " --skip-generate",
597
- options.name ? ` --name ${options.name}` : "",
612
+ options.name ? ` --name "${options.name}"` : "",
598
613
  options.createOnly ? " --create-only" : ""
599
614
  ].join("");
600
- await execPackage(cmd);
615
+ execPrisma(cmd);
601
616
  } catch (err) {
602
617
  handleSubProcessError2(err);
603
618
  }
604
619
  }
605
620
  __name(runDev, "runDev");
606
- async function runReset(prismaSchemaFile, options) {
621
+ function runReset(prismaSchemaFile, options) {
607
622
  try {
608
623
  const cmd = [
609
- "prisma migrate reset",
624
+ "migrate reset",
610
625
  ` --schema "${prismaSchemaFile}"`,
611
626
  " --skip-generate",
612
627
  options.force ? " --force" : ""
613
628
  ].join("");
614
- await execPackage(cmd);
629
+ execPrisma(cmd);
615
630
  } catch (err) {
616
631
  handleSubProcessError2(err);
617
632
  }
618
633
  }
619
634
  __name(runReset, "runReset");
620
- async function runDeploy(prismaSchemaFile, _options) {
635
+ function runDeploy(prismaSchemaFile, _options) {
621
636
  try {
622
637
  const cmd = [
623
- "prisma migrate deploy",
638
+ "migrate deploy",
624
639
  ` --schema "${prismaSchemaFile}"`
625
640
  ].join("");
626
- await execPackage(cmd);
641
+ execPrisma(cmd);
627
642
  } catch (err) {
628
643
  handleSubProcessError2(err);
629
644
  }
630
645
  }
631
646
  __name(runDeploy, "runDeploy");
632
- async function runStatus(prismaSchemaFile, _options) {
647
+ function runStatus(prismaSchemaFile, _options) {
633
648
  try {
634
- await execPackage(`prisma migrate status --schema "${prismaSchemaFile}"`);
649
+ execPrisma(`migrate status --schema "${prismaSchemaFile}"`);
635
650
  } catch (err) {
636
651
  handleSubProcessError2(err);
637
652
  }
638
653
  }
639
654
  __name(runStatus, "runStatus");
640
- async function runResolve(prismaSchemaFile, options) {
655
+ function runResolve(prismaSchemaFile, options) {
641
656
  if (!options.applied && !options.rolledBack) {
642
657
  throw new CliError("Either --applied or --rolled-back option must be provided");
643
658
  }
644
659
  try {
645
660
  const cmd = [
646
- "prisma migrate resolve",
661
+ "migrate resolve",
647
662
  ` --schema "${prismaSchemaFile}"`,
648
- options.applied ? ` --applied ${options.applied}` : "",
649
- options.rolledBack ? ` --rolled-back ${options.rolledBack}` : ""
663
+ options.applied ? ` --applied "${options.applied}"` : "",
664
+ options.rolledBack ? ` --rolled-back "${options.rolledBack}"` : ""
650
665
  ].join("");
651
- await execPackage(cmd);
666
+ execPrisma(cmd);
652
667
  } catch (err) {
653
668
  handleSubProcessError2(err);
654
669
  }
@@ -820,12 +835,12 @@ var import_node_fs10 = __toESM(require("fs"), 1);
820
835
  var import_node_path8 = __toESM(require("path"), 1);
821
836
  var import_node_url = require("url");
822
837
  var import_semver = __toESM(require("semver"), 1);
823
- var import_meta = {};
838
+ var import_meta2 = {};
824
839
  var CHECK_VERSION_TIMEOUT = 2e3;
825
840
  var VERSION_CHECK_TAG = "next";
826
841
  function getVersion() {
827
842
  try {
828
- const _dirname = typeof __dirname !== "undefined" ? __dirname : import_node_path8.default.dirname((0, import_node_url.fileURLToPath)(import_meta.url));
843
+ const _dirname = typeof __dirname !== "undefined" ? __dirname : import_node_path8.default.dirname((0, import_node_url.fileURLToPath)(import_meta2.url));
829
844
  return JSON.parse(import_node_fs10.default.readFileSync(import_node_path8.default.join(_dirname, "../package.json"), "utf8")).version;
830
845
  } catch {
831
846
  return void 0;
@@ -864,7 +879,7 @@ async function getLatestVersion() {
864
879
  __name(getLatestVersion, "getLatestVersion");
865
880
 
866
881
  // src/telemetry.ts
867
- var import_meta2 = {};
882
+ var import_meta3 = {};
868
883
  var Telemetry = class {
869
884
  static {
870
885
  __name(this, "Telemetry");
@@ -955,7 +970,7 @@ var Telemetry = class {
955
970
  }
956
971
  getPrismaVersion() {
957
972
  try {
958
- const packageJsonPath = import_meta2.resolve("prisma/package.json");
973
+ const packageJsonPath = import_meta3.resolve("prisma/package.json");
959
974
  const packageJsonUrl = new URL(packageJsonPath);
960
975
  const packageJson = JSON.parse(import_node_fs11.default.readFileSync(packageJsonUrl, "utf8"));
961
976
  return packageJson.version;
@@ -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/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/check.ts","../src/telemetry.ts","../src/constants.ts","../src/utils/is-ci.ts","../src/utils/is-container.ts","../src/utils/is-docker.ts","../src/utils/is-wsl.ts","../src/utils/machine-id-utils.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 { telemetry } from './telemetry';\nimport { checkNewVersion, getVersion } from './utils/version-utils';\n\nconst generateAction = async (options: Parameters<typeof actions.generate>[0]): Promise<void> => {\n await telemetry.trackCommand('generate', () => actions.generate(options));\n};\n\nconst migrateAction = async (subCommand: string, options: any): Promise<void> => {\n await telemetry.trackCommand(`migrate ${subCommand}`, () => actions.migrate(subCommand, options));\n};\n\nconst dbAction = async (subCommand: string, options: any): Promise<void> => {\n await telemetry.trackCommand(`db ${subCommand}`, () => actions.db(subCommand, options));\n};\n\nconst infoAction = async (projectPath: string): Promise<void> => {\n await telemetry.trackCommand('info', () => actions.info(projectPath));\n};\n\nconst initAction = async (projectPath: string): Promise<void> => {\n await telemetry.trackCommand('init', () => actions.init(projectPath));\n};\n\nconst checkAction = async (options: Parameters<typeof actions.check>[0]): Promise<void> => {\n await telemetry.trackCommand('check', () => actions.check(options));\n};\n\nfunction createProgram() {\n const program = new Command('zen');\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 the data layer for modern TypeScript apps.\\n\\nDocumentation: https://zenstack.dev/docs/3.x`,\n )\n .showHelpAfterError()\n .showSuggestionAfterError();\n\n const schemaOption = new Option(\n '--schema <file>',\n `schema file (with extension ${schemaExtensions}). Defaults to \"zenstack/schema.zmodel\" unless specified in package.json.`,\n );\n\n const noVersionCheckOption = new Option('--no-version-check', 'do not check for new version');\n\n program\n .command('generate')\n .description('Run code generation plugins.')\n .addOption(schemaOption)\n .addOption(noVersionCheckOption)\n .addOption(new Option('-o, --output <path>', 'default output directory for code generation'))\n .addOption(new Option('--lite', 'also generate a lite version of schema without attributes').default(false))\n .addOption(new Option('--lite-only', 'only generate lite version of schema without attributes').default(false))\n .addOption(new Option('--silent', 'suppress all output except errors').default(false))\n .action(generateAction);\n\n const migrateCommand = program.command('migrate').description('Run database schema migration related tasks.');\n const migrationsOption = new Option('--migrations <path>', 'path that contains the \"migrations\" directory');\n\n migrateCommand\n .command('dev')\n .addOption(schemaOption)\n .addOption(noVersionCheckOption)\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 .addOption(noVersionCheckOption)\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(noVersionCheckOption)\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(noVersionCheckOption)\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(noVersionCheckOption)\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(noVersionCheckOption)\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 packages.')\n .argument('[path]', 'project path', '.')\n .addOption(noVersionCheckOption)\n .action(infoAction);\n\n program\n .command('init')\n .description('Initialize an existing project for ZenStack.')\n .argument('[path]', 'project path', '.')\n .addOption(noVersionCheckOption)\n .action(initAction);\n\n program\n .command('check')\n .description('Check a ZModel schema for syntax or semantic errors.')\n .addOption(schemaOption)\n .addOption(noVersionCheckOption)\n .action(checkAction);\n\n program.hook('preAction', async (_thisCommand, actionCommand) => {\n if (actionCommand.getOptionValue('versionCheck') !== false) {\n await checkNewVersion();\n }\n });\n\n return program;\n}\n\nasync function main() {\n let exitCode = 0;\n\n const program = createProgram();\n program.exitOverride();\n\n try {\n await telemetry.trackCli(async () => {\n await program.parseAsync();\n });\n } catch (e) {\n if (e instanceof CommanderError) {\n // ignore\n exitCode = e.exitCode;\n } else if (e instanceof CliError) {\n // log\n console.error(colors.red(e.message));\n exitCode = 1;\n } else {\n console.error(colors.red(`Unhandled error: ${e}`));\n exitCode = 1;\n }\n }\n\n if (telemetry.isTracking) {\n // give telemetry a chance to send events before exit\n setTimeout(() => {\n process.exit(exitCode);\n }, 200);\n } else {\n process.exit(exitCode);\n }\n}\n\nmain();\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, { type 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 lite: boolean;\n liteOnly: 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, options);\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/orm';\nimport { schema } from '${outputPath}/schema';\n\nconst client = new ZenStackClient(schema, {\n dialect: { ... }\n});\n\\`\\`\\`\n\nCheck documentation: https://zenstack.dev/docs/3.x`);\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, options: Options) {\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 | undefined;\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 {\n // plugin may not export a generator so we simply ignore the error here\n }\n }\n\n if (cliPlugin) {\n processedPlugins.push({ cliPlugin, pluginOptions: getPluginOptions(plugin) });\n }\n }\n\n const defaultPlugins = [\n {\n plugin: corePlugins['typescript'],\n options: { lite: options.lite, liteOnly: options.liteOnly },\n },\n ];\n defaultPlugins.forEach(({ plugin, options }) => {\n if (!processedPlugins.some((p) => p.cliPlugin === plugin)) {\n processedPlugins.push({ cliPlugin: plugin, pluginOptions: options });\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 let spinner: Ora | undefined;\n\n if (!options.silent) {\n spinner = ora(cliPlugin.statusText ?? `Running plugin ${cliPlugin.name}`).start();\n }\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 outFile = path.join(defaultOutputPath, 'schema.prisma');\n if (typeof pluginOptions['output'] === 'string') {\n outFile = path.resolve(defaultOutputPath, pluginOptions['output']);\n if (!fs.existsSync(path.dirname(outFile))) {\n fs.mkdirSync(path.dirname(outFile), { recursive: true });\n }\n }\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n fs.writeFileSync(outFile, 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 // output path\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\n // lite mode\n const lite = pluginOptions['lite'] === true;\n\n // liteOnly mode\n const liteOnly = pluginOptions['liteOnly'] === true;\n\n await new TsSchemaGenerator().generate(model, { outDir, lite, liteOnly });\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 if (depPkgJson.private) {\n return undefined;\n }\n return { pkg, version: depPkgJson.version as string };\n } catch {\n return { pkg, version: undefined };\n }\n }),\n );\n\n return result.filter((p) => !!p);\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/orm@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/orm';\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 = [\n 'prisma migrate reset',\n ` --schema \"${prismaSchemaFile}\"`,\n ' --skip-generate',\n options.force ? ' --force' : '',\n ].join('');\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 checking a schema's validity.\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 { init, type Mixpanel } from 'mixpanel';\nimport { randomUUID } from 'node:crypto';\nimport fs from 'node:fs';\nimport * as os from 'os';\nimport { TELEMETRY_TRACKING_TOKEN } from './constants';\nimport { isInCi } from './utils/is-ci';\nimport { isInContainer } from './utils/is-container';\nimport isDocker from './utils/is-docker';\nimport { isWsl } from './utils/is-wsl';\nimport { getMachineId } from './utils/machine-id-utils';\nimport { getVersion } from './utils/version-utils';\n\n/**\n * Telemetry events\n */\nexport type TelemetryEvents =\n | 'cli:start'\n | 'cli:complete'\n | 'cli:error'\n | 'cli:command:start'\n | 'cli:command:complete'\n | 'cli:command:error'\n | 'cli:plugin:start'\n | 'cli:plugin:complete'\n | 'cli:plugin:error';\n\n/**\n * Utility class for sending telemetry\n */\nexport class Telemetry {\n private readonly mixpanel: Mixpanel | undefined;\n private readonly hostId = getMachineId();\n private readonly sessionid = randomUUID();\n private readonly _os_type = os.type();\n private readonly _os_release = os.release();\n private readonly _os_arch = os.arch();\n private readonly _os_version = os.version();\n private readonly _os_platform = os.platform();\n private readonly version = getVersion();\n private readonly prismaVersion = this.getPrismaVersion();\n private readonly isDocker = isDocker();\n private readonly isWsl = isWsl();\n private readonly isContainer = isInContainer();\n private readonly isCi = isInCi;\n\n constructor() {\n if (process.env['DO_NOT_TRACK'] !== '1' && TELEMETRY_TRACKING_TOKEN) {\n this.mixpanel = init(TELEMETRY_TRACKING_TOKEN, {\n geolocate: true,\n });\n }\n }\n\n get isTracking() {\n return !!this.mixpanel;\n }\n\n track(event: TelemetryEvents, properties: Record<string, unknown> = {}) {\n if (this.mixpanel) {\n const payload = {\n distinct_id: this.hostId,\n session: this.sessionid,\n time: new Date(),\n $os: this._os_type,\n osType: this._os_type,\n osRelease: this._os_release,\n osPlatform: this._os_platform,\n osArch: this._os_arch,\n osVersion: this._os_version,\n nodeVersion: process.version,\n version: this.version,\n prismaVersion: this.prismaVersion,\n isDocker: this.isDocker,\n isWsl: this.isWsl,\n isContainer: this.isContainer,\n isCi: this.isCi,\n ...properties,\n };\n this.mixpanel.track(event, payload);\n }\n }\n\n trackError(err: Error) {\n this.track('cli:error', {\n message: err.message,\n stack: err.stack,\n });\n }\n\n async trackSpan<T>(\n startEvent: TelemetryEvents,\n completeEvent: TelemetryEvents,\n errorEvent: TelemetryEvents,\n properties: Record<string, unknown>,\n action: () => Promise<T> | T,\n ) {\n this.track(startEvent, properties);\n const start = Date.now();\n let success = true;\n try {\n return await action();\n } catch (err: any) {\n this.track(errorEvent, {\n message: err.message,\n stack: err.stack,\n ...properties,\n });\n success = false;\n throw err;\n } finally {\n this.track(completeEvent, {\n duration: Date.now() - start,\n success,\n ...properties,\n });\n }\n }\n\n async trackCommand(command: string, action: () => Promise<void> | void) {\n await this.trackSpan('cli:command:start', 'cli:command:complete', 'cli:command:error', { command }, action);\n }\n\n async trackCli(action: () => Promise<void> | void) {\n await this.trackSpan('cli:start', 'cli:complete', 'cli:error', {}, action);\n }\n\n getPrismaVersion() {\n try {\n const packageJsonPath = import.meta.resolve('prisma/package.json');\n const packageJsonUrl = new URL(packageJsonPath);\n const packageJson = JSON.parse(fs.readFileSync(packageJsonUrl, 'utf8'));\n return packageJson.version;\n } catch {\n return undefined;\n }\n }\n}\n\nexport const telemetry = new Telemetry();\n","// replaced at build time\nexport const TELEMETRY_TRACKING_TOKEN = '<TELEMETRY_TRACKING_TOKEN>';\n\n// plugin-contributed model file name\nexport const PLUGIN_MODULE_NAME = 'plugin.zmodel';\n","import { env } from 'node:process';\nexport const isInCi =\n env['CI'] !== '0' &&\n env['CI'] !== 'false' &&\n ('CI' in env || 'CONTINUOUS_INTEGRATION' in env || Object.keys(env).some((key) => key.startsWith('CI_')));\n","import fs from 'node:fs';\nimport isDocker from './is-docker';\n\nlet cachedResult: boolean | undefined;\n\n// Podman detection\nconst hasContainerEnv = () => {\n try {\n fs.statSync('/run/.containerenv');\n return true;\n } catch {\n return false;\n }\n};\n\nexport function isInContainer() {\n // TODO: Use `??=` when targeting Node.js 16.\n if (cachedResult === undefined) {\n cachedResult = hasContainerEnv() || isDocker();\n }\n\n return cachedResult;\n}\n","// Copied over from https://github.com/sindresorhus/is-docker for CJS compatibility\n\nimport fs from 'node:fs';\n\nlet isDockerCached: boolean | undefined;\n\nfunction hasDockerEnv() {\n try {\n fs.statSync('/.dockerenv');\n return true;\n } catch {\n return false;\n }\n}\n\nfunction hasDockerCGroup() {\n try {\n return fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker');\n } catch {\n return false;\n }\n}\n\nexport default function isDocker() {\n // TODO: Use `??=` when targeting Node.js 16.\n if (isDockerCached === undefined) {\n isDockerCached = hasDockerEnv() || hasDockerCGroup();\n }\n\n return isDockerCached;\n}\n","import process from 'node:process';\nimport os from 'node:os';\nimport fs from 'node:fs';\nexport const isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n\n if (os.release().toLowerCase().includes('microsoft')) {\n return true;\n }\n\n try {\n return fs.readFileSync('/proc/version', 'utf8').toLowerCase().includes('microsoft');\n } catch {\n return false;\n }\n};\n","// modified from https://github.com/automation-stack/node-machine-id\n\nimport { execSync } from 'child_process';\nimport { createHash, randomUUID } from 'node:crypto';\n\nconst { platform } = process;\nconst win32RegBinPath = {\n native: '%windir%\\\\System32',\n mixed: '%windir%\\\\sysnative\\\\cmd.exe /c %windir%\\\\System32',\n};\nconst guid = {\n darwin: 'ioreg -rd1 -c IOPlatformExpertDevice',\n win32:\n `${win32RegBinPath[isWindowsProcessMixedOrNativeArchitecture()]}\\\\REG.exe ` +\n 'QUERY HKEY_LOCAL_MACHINE\\\\SOFTWARE\\\\Microsoft\\\\Cryptography ' +\n '/v MachineGuid',\n linux: '( cat /var/lib/dbus/machine-id /etc/machine-id 2> /dev/null || hostname 2> /dev/null) | head -n 1 || :',\n freebsd: 'kenv -q smbios.system.uuid || sysctl -n kern.hostuuid',\n};\n\nfunction isWindowsProcessMixedOrNativeArchitecture() {\n // eslint-disable-next-line no-prototype-builtins\n if (process.arch === 'ia32' && process.env.hasOwnProperty('PROCESSOR_ARCHITEW6432')) {\n return 'mixed';\n }\n return 'native';\n}\n\nfunction hash(guid: string): string {\n return createHash('sha256').update(guid).digest('hex');\n}\n\nfunction expose(result: string): string | undefined {\n switch (platform) {\n case 'darwin':\n return result\n .split('IOPlatformUUID')[1]\n ?.split('\\n')[0]\n ?.replace(/=|\\s+|\"/gi, '')\n .toLowerCase();\n case 'win32':\n return result\n .toString()\n .split('REG_SZ')[1]\n ?.replace(/\\r+|\\n+|\\s+/gi, '')\n .toLowerCase();\n case 'linux':\n return result\n .toString()\n .replace(/\\r+|\\n+|\\s+/gi, '')\n .toLowerCase();\n case 'freebsd':\n return result\n .toString()\n .replace(/\\r+|\\n+|\\s+/gi, '')\n .toLowerCase();\n default:\n throw new Error(`Unsupported platform: ${process.platform}`);\n }\n}\n\nexport function getMachineId() {\n if (!(platform in guid)) {\n return randomUUID();\n }\n try {\n const value = execSync(guid[platform as keyof typeof guid]);\n const id = expose(value.toString());\n if (!id) {\n return randomUUID();\n }\n return hash(id);\n } catch {\n return randomUUID();\n }\n}\n","import colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport semver from 'semver';\n\nconst CHECK_VERSION_TIMEOUT = 2000;\nconst VERSION_CHECK_TAG = 'next';\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\nexport async function checkNewVersion() {\n const currVersion = getVersion();\n let latestVersion: string;\n try {\n latestVersion = await getLatestVersion();\n } catch {\n // noop\n return;\n }\n\n if (latestVersion && currVersion && semver.gt(latestVersion, currVersion)) {\n console.log(`A newer version ${colors.cyan(latestVersion)} is available.`);\n }\n}\n\nexport async function getLatestVersion() {\n const fetchResult = await fetch(`https://registry.npmjs.org/@zenstackhq/cli/${VERSION_CHECK_TAG}`, {\n headers: { accept: 'application/vnd.npm.install-v1+json; q=1.0, application/json; q=0.8, */*' },\n signal: AbortSignal.timeout(CHECK_VERSION_TIMEOUT),\n });\n\n if (fetchResult.ok) {\n const data: any = await fetchResult.json();\n const latestVersion = data?.version;\n if (typeof latestVersion === 'string' && semver.valid(latestVersion)) {\n return latestVersion;\n }\n }\n\n throw new Error('invalid npm registry response');\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_colors","import_node_path","import_sdk","import_node_fs","import_node_path","plugin","name","statusText","generate","model","defaultOutputPath","pluginOptions","outFile","path","join","resolve","fs","existsSync","dirname","mkdirSync","recursive","prismaSchema","PrismaSchemaGenerator","writeFileSync","import_sdk","import_node_fs","import_node_path","plugin","name","statusText","generate","model","defaultOutputPath","pluginOptions","outDir","path","resolve","fs","existsSync","mkdirSync","recursive","lite","liteOnly","TsSchemaGenerator","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","push","pluginOptions","getPluginOptions","defaultPlugins","lite","liteOnly","forEach","some","p","invariant","generate","name","spinner","ora","statusText","defaultOutputPath","succeed","err","fail","error","providerField","fields","find","f","value","result","field","getLiteral","getLiteralArray","undefined","warn","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","private","undefined","import_colors","import_node_fs","import_node_path","import_ora","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_crypto","import_node_fs","os","TELEMETRY_TRACKING_TOKEN","isInCi","env","Object","keys","some","key","startsWith","import_node_fs","import_node_fs","isDockerCached","hasDockerEnv","fs","statSync","hasDockerCGroup","readFileSync","includes","isDocker","undefined","cachedResult","hasContainerEnv","fs","statSync","isInContainer","undefined","isDocker","import_node_process","import_node_fs","isWsl","process","platform","os","release","toLowerCase","includes","fs","readFileSync","import_child_process","platform","process","win32RegBinPath","native","mixed","guid","darwin","win32","isWindowsProcessMixedOrNativeArchitecture","linux","freebsd","arch","env","hasOwnProperty","hash","createHash","update","digest","expose","result","split","replace","toLowerCase","toString","Error","getMachineId","randomUUID","value","execSync","id","import_colors","import_node_fs","import_node_path","CHECK_VERSION_TIMEOUT","VERSION_CHECK_TAG","getVersion","_dirname","__dirname","path","dirname","fileURLToPath","url","JSON","parse","fs","readFileSync","join","version","undefined","checkNewVersion","currVersion","latestVersion","getLatestVersion","semver","gt","console","log","colors","cyan","fetchResult","fetch","headers","accept","signal","AbortSignal","timeout","ok","data","json","valid","Error","import_meta","Telemetry","mixpanel","hostId","getMachineId","sessionid","randomUUID","_os_type","type","_os_release","release","_os_arch","arch","_os_version","version","_os_platform","platform","getVersion","prismaVersion","getPrismaVersion","isDocker","isWsl","isContainer","isInContainer","isCi","isInCi","process","env","TELEMETRY_TRACKING_TOKEN","init","geolocate","isTracking","track","event","properties","payload","distinct_id","session","time","Date","$os","osType","osRelease","osPlatform","osArch","osVersion","nodeVersion","trackError","err","message","stack","trackSpan","startEvent","completeEvent","errorEvent","action","start","now","success","duration","trackCommand","command","trackCli","packageJsonPath","import_meta","resolve","packageJsonUrl","URL","packageJson","JSON","parse","fs","readFileSync","undefined","telemetry","generateAction","options","telemetry","trackCommand","generate","migrateAction","subCommand","migrate","dbAction","db","infoAction","projectPath","info","initAction","init","checkAction","check","createProgram","program","Command","version","getVersion","schemaExtensions","ZModelLanguageMetaData","fileExtensions","join","description","colors","bold","blue","showHelpAfterError","showSuggestionAfterError","schemaOption","Option","noVersionCheckOption","command","addOption","default","action","migrateCommand","migrationsOption","dbCommand","argument","hook","_thisCommand","actionCommand","getOptionValue","checkNewVersion","main","exitCode","exitOverride","trackCli","parseAsync","e","CommanderError","CliError","console","error","red","message","isTracking","setTimeout","process","exit"]}
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/check.ts","../src/telemetry.ts","../src/constants.ts","../src/utils/is-ci.ts","../src/utils/is-container.ts","../src/utils/is-docker.ts","../src/utils/is-wsl.ts","../src/utils/machine-id-utils.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 { telemetry } from './telemetry';\nimport { checkNewVersion, getVersion } from './utils/version-utils';\n\nconst generateAction = async (options: Parameters<typeof actions.generate>[0]): Promise<void> => {\n await telemetry.trackCommand('generate', () => actions.generate(options));\n};\n\nconst migrateAction = async (subCommand: string, options: any): Promise<void> => {\n await telemetry.trackCommand(`migrate ${subCommand}`, () => actions.migrate(subCommand, options));\n};\n\nconst dbAction = async (subCommand: string, options: any): Promise<void> => {\n await telemetry.trackCommand(`db ${subCommand}`, () => actions.db(subCommand, options));\n};\n\nconst infoAction = async (projectPath: string): Promise<void> => {\n await telemetry.trackCommand('info', () => actions.info(projectPath));\n};\n\nconst initAction = async (projectPath: string): Promise<void> => {\n await telemetry.trackCommand('init', () => actions.init(projectPath));\n};\n\nconst checkAction = async (options: Parameters<typeof actions.check>[0]): Promise<void> => {\n await telemetry.trackCommand('check', () => actions.check(options));\n};\n\nfunction createProgram() {\n const program = new Command('zen');\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 the data layer for modern TypeScript apps.\\n\\nDocumentation: https://zenstack.dev/docs/3.x`,\n )\n .showHelpAfterError()\n .showSuggestionAfterError();\n\n const schemaOption = new Option(\n '--schema <file>',\n `schema file (with extension ${schemaExtensions}). Defaults to \"zenstack/schema.zmodel\" unless specified in package.json.`,\n );\n\n const noVersionCheckOption = new Option('--no-version-check', 'do not check for new version');\n\n program\n .command('generate')\n .description('Run code generation plugins.')\n .addOption(schemaOption)\n .addOption(noVersionCheckOption)\n .addOption(new Option('-o, --output <path>', 'default output directory for code generation'))\n .addOption(new Option('--lite', 'also generate a lite version of schema without attributes').default(false))\n .addOption(new Option('--lite-only', 'only generate lite version of schema without attributes').default(false))\n .addOption(new Option('--silent', 'suppress all output except errors').default(false))\n .action(generateAction);\n\n const migrateCommand = program.command('migrate').description('Run database schema migration related tasks.');\n const migrationsOption = new Option('--migrations <path>', 'path that contains the \"migrations\" directory');\n\n migrateCommand\n .command('dev')\n .addOption(schemaOption)\n .addOption(noVersionCheckOption)\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 .addOption(noVersionCheckOption)\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(noVersionCheckOption)\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(noVersionCheckOption)\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(noVersionCheckOption)\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(noVersionCheckOption)\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 packages.')\n .argument('[path]', 'project path', '.')\n .addOption(noVersionCheckOption)\n .action(infoAction);\n\n program\n .command('init')\n .description('Initialize an existing project for ZenStack.')\n .argument('[path]', 'project path', '.')\n .addOption(noVersionCheckOption)\n .action(initAction);\n\n program\n .command('check')\n .description('Check a ZModel schema for syntax or semantic errors.')\n .addOption(schemaOption)\n .addOption(noVersionCheckOption)\n .action(checkAction);\n\n program.hook('preAction', async (_thisCommand, actionCommand) => {\n if (actionCommand.getOptionValue('versionCheck') !== false) {\n await checkNewVersion();\n }\n });\n\n return program;\n}\n\nasync function main() {\n let exitCode = 0;\n\n const program = createProgram();\n program.exitOverride();\n\n try {\n await telemetry.trackCli(async () => {\n await program.parseAsync();\n });\n } catch (e) {\n if (e instanceof CommanderError) {\n // ignore\n exitCode = e.exitCode;\n } else if (e instanceof CliError) {\n // log\n console.error(colors.red(e.message));\n exitCode = 1;\n } else {\n console.error(colors.red(`Unhandled error: ${e}`));\n exitCode = 1;\n }\n }\n\n if (telemetry.isTracking) {\n // give telemetry a chance to send events before exit\n setTimeout(() => {\n process.exit(exitCode);\n }, 200);\n } else {\n process.exit(exitCode);\n }\n}\n\nmain();\n","import fs from 'node:fs';\nimport { execPrisma } 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 '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 execPrisma(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';\nimport { fileURLToPath } from 'url';\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\n/**\n * Utility for running prisma commands\n */\nexport function execPrisma(args: string, options?: Omit<ExecSyncOptions, 'env'> & { env?: Record<string, string> }) {\n let prismaPath: string;\n if (typeof import.meta.resolve === 'function') {\n // esm\n prismaPath = fileURLToPath(import.meta.resolve('prisma/build/index.js'));\n } else {\n // cjs\n prismaPath = require.resolve('prisma/build/index.js');\n }\n execSync(`node ${prismaPath} ${args}`, 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 if (fs.statSync(pkgJsonConfig.schema).isDirectory()) {\n const schemaPath = path.join(pkgJsonConfig.schema, 'schema.zmodel');\n if (!fs.existsSync(schemaPath)) {\n throw new CliError(`Schema file not found: ${schemaPath}`);\n }\n return schemaPath;\n } else {\n return pkgJsonConfig.schema;\n }\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, { type 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 lite: boolean;\n liteOnly: 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, options);\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/orm';\nimport { schema } from '${outputPath}/schema';\n\nconst client = new ZenStackClient(schema, {\n dialect: { ... }\n});\n\\`\\`\\`\n\nCheck documentation: https://zenstack.dev/docs/3.x`);\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, options: Options) {\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 | undefined;\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 {\n // plugin may not export a generator so we simply ignore the error here\n }\n }\n\n if (cliPlugin) {\n processedPlugins.push({ cliPlugin, pluginOptions: getPluginOptions(plugin) });\n }\n }\n\n const defaultPlugins = [\n {\n plugin: corePlugins['typescript'],\n options: { lite: options.lite, liteOnly: options.liteOnly },\n },\n ];\n defaultPlugins.forEach(({ plugin, options }) => {\n if (!processedPlugins.some((p) => p.cliPlugin === plugin)) {\n processedPlugins.push({ cliPlugin: plugin, pluginOptions: options });\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 let spinner: Ora | undefined;\n\n if (!options.silent) {\n spinner = ora(cliPlugin.statusText ?? `Running plugin ${cliPlugin.name}`).start();\n }\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 outFile = path.join(defaultOutputPath, 'schema.prisma');\n if (typeof pluginOptions['output'] === 'string') {\n outFile = path.resolve(defaultOutputPath, pluginOptions['output']);\n if (!fs.existsSync(path.dirname(outFile))) {\n fs.mkdirSync(path.dirname(outFile), { recursive: true });\n }\n }\n const prismaSchema = await new PrismaSchemaGenerator(model).generate();\n fs.writeFileSync(outFile, 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 // output path\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\n // lite mode\n const lite = pluginOptions['lite'] === true;\n\n // liteOnly mode\n const liteOnly = pluginOptions['liteOnly'] === true;\n\n await new TsSchemaGenerator().generate(model, { outDir, lite, liteOnly });\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 if (depPkgJson.private) {\n return undefined;\n }\n return { pkg, version: depPkgJson.version as string };\n } catch {\n return { pkg, version: undefined };\n }\n }),\n );\n\n return result.filter((p) => !!p);\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/orm@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/orm';\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 { execPrisma } 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\nfunction runDev(prismaSchemaFile: string, options: DevOptions) {\n try {\n const cmd = [\n 'migrate dev',\n ` --schema \"${prismaSchemaFile}\"`,\n ' --skip-generate',\n options.name ? ` --name \"${options.name}\"` : '',\n options.createOnly ? ' --create-only' : '',\n ].join('');\n execPrisma(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction runReset(prismaSchemaFile: string, options: ResetOptions) {\n try {\n const cmd = [\n 'migrate reset',\n ` --schema \"${prismaSchemaFile}\"`,\n ' --skip-generate',\n options.force ? ' --force' : '',\n ].join('');\n execPrisma(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction runDeploy(prismaSchemaFile: string, _options: DeployOptions) {\n try {\n const cmd = ['migrate deploy', ` --schema \"${prismaSchemaFile}\"`].join('');\n execPrisma(cmd);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction runStatus(prismaSchemaFile: string, _options: StatusOptions) {\n try {\n execPrisma(`migrate status --schema \"${prismaSchemaFile}\"`);\n } catch (err) {\n handleSubProcessError(err);\n }\n}\n\nfunction 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 'migrate resolve',\n ` --schema \"${prismaSchemaFile}\"`,\n options.applied ? ` --applied \"${options.applied}\"` : '',\n options.rolledBack ? ` --rolled-back \"${options.rolledBack}\"` : '',\n ].join('');\n execPrisma(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 checking a schema's validity.\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 { init, type Mixpanel } from 'mixpanel';\nimport { randomUUID } from 'node:crypto';\nimport fs from 'node:fs';\nimport * as os from 'os';\nimport { TELEMETRY_TRACKING_TOKEN } from './constants';\nimport { isInCi } from './utils/is-ci';\nimport { isInContainer } from './utils/is-container';\nimport isDocker from './utils/is-docker';\nimport { isWsl } from './utils/is-wsl';\nimport { getMachineId } from './utils/machine-id-utils';\nimport { getVersion } from './utils/version-utils';\n\n/**\n * Telemetry events\n */\nexport type TelemetryEvents =\n | 'cli:start'\n | 'cli:complete'\n | 'cli:error'\n | 'cli:command:start'\n | 'cli:command:complete'\n | 'cli:command:error'\n | 'cli:plugin:start'\n | 'cli:plugin:complete'\n | 'cli:plugin:error';\n\n/**\n * Utility class for sending telemetry\n */\nexport class Telemetry {\n private readonly mixpanel: Mixpanel | undefined;\n private readonly hostId = getMachineId();\n private readonly sessionid = randomUUID();\n private readonly _os_type = os.type();\n private readonly _os_release = os.release();\n private readonly _os_arch = os.arch();\n private readonly _os_version = os.version();\n private readonly _os_platform = os.platform();\n private readonly version = getVersion();\n private readonly prismaVersion = this.getPrismaVersion();\n private readonly isDocker = isDocker();\n private readonly isWsl = isWsl();\n private readonly isContainer = isInContainer();\n private readonly isCi = isInCi;\n\n constructor() {\n if (process.env['DO_NOT_TRACK'] !== '1' && TELEMETRY_TRACKING_TOKEN) {\n this.mixpanel = init(TELEMETRY_TRACKING_TOKEN, {\n geolocate: true,\n });\n }\n }\n\n get isTracking() {\n return !!this.mixpanel;\n }\n\n track(event: TelemetryEvents, properties: Record<string, unknown> = {}) {\n if (this.mixpanel) {\n const payload = {\n distinct_id: this.hostId,\n session: this.sessionid,\n time: new Date(),\n $os: this._os_type,\n osType: this._os_type,\n osRelease: this._os_release,\n osPlatform: this._os_platform,\n osArch: this._os_arch,\n osVersion: this._os_version,\n nodeVersion: process.version,\n version: this.version,\n prismaVersion: this.prismaVersion,\n isDocker: this.isDocker,\n isWsl: this.isWsl,\n isContainer: this.isContainer,\n isCi: this.isCi,\n ...properties,\n };\n this.mixpanel.track(event, payload);\n }\n }\n\n trackError(err: Error) {\n this.track('cli:error', {\n message: err.message,\n stack: err.stack,\n });\n }\n\n async trackSpan<T>(\n startEvent: TelemetryEvents,\n completeEvent: TelemetryEvents,\n errorEvent: TelemetryEvents,\n properties: Record<string, unknown>,\n action: () => Promise<T> | T,\n ) {\n this.track(startEvent, properties);\n const start = Date.now();\n let success = true;\n try {\n return await action();\n } catch (err: any) {\n this.track(errorEvent, {\n message: err.message,\n stack: err.stack,\n ...properties,\n });\n success = false;\n throw err;\n } finally {\n this.track(completeEvent, {\n duration: Date.now() - start,\n success,\n ...properties,\n });\n }\n }\n\n async trackCommand(command: string, action: () => Promise<void> | void) {\n await this.trackSpan('cli:command:start', 'cli:command:complete', 'cli:command:error', { command }, action);\n }\n\n async trackCli(action: () => Promise<void> | void) {\n await this.trackSpan('cli:start', 'cli:complete', 'cli:error', {}, action);\n }\n\n getPrismaVersion() {\n try {\n const packageJsonPath = import.meta.resolve('prisma/package.json');\n const packageJsonUrl = new URL(packageJsonPath);\n const packageJson = JSON.parse(fs.readFileSync(packageJsonUrl, 'utf8'));\n return packageJson.version;\n } catch {\n return undefined;\n }\n }\n}\n\nexport const telemetry = new Telemetry();\n","// replaced at build time\nexport const TELEMETRY_TRACKING_TOKEN = '<TELEMETRY_TRACKING_TOKEN>';\n\n// plugin-contributed model file name\nexport const PLUGIN_MODULE_NAME = 'plugin.zmodel';\n","import { env } from 'node:process';\nexport const isInCi =\n env['CI'] !== '0' &&\n env['CI'] !== 'false' &&\n ('CI' in env || 'CONTINUOUS_INTEGRATION' in env || Object.keys(env).some((key) => key.startsWith('CI_')));\n","import fs from 'node:fs';\nimport isDocker from './is-docker';\n\nlet cachedResult: boolean | undefined;\n\n// Podman detection\nconst hasContainerEnv = () => {\n try {\n fs.statSync('/run/.containerenv');\n return true;\n } catch {\n return false;\n }\n};\n\nexport function isInContainer() {\n // TODO: Use `??=` when targeting Node.js 16.\n if (cachedResult === undefined) {\n cachedResult = hasContainerEnv() || isDocker();\n }\n\n return cachedResult;\n}\n","// Copied over from https://github.com/sindresorhus/is-docker for CJS compatibility\n\nimport fs from 'node:fs';\n\nlet isDockerCached: boolean | undefined;\n\nfunction hasDockerEnv() {\n try {\n fs.statSync('/.dockerenv');\n return true;\n } catch {\n return false;\n }\n}\n\nfunction hasDockerCGroup() {\n try {\n return fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker');\n } catch {\n return false;\n }\n}\n\nexport default function isDocker() {\n // TODO: Use `??=` when targeting Node.js 16.\n if (isDockerCached === undefined) {\n isDockerCached = hasDockerEnv() || hasDockerCGroup();\n }\n\n return isDockerCached;\n}\n","import process from 'node:process';\nimport os from 'node:os';\nimport fs from 'node:fs';\nexport const isWsl = () => {\n if (process.platform !== 'linux') {\n return false;\n }\n\n if (os.release().toLowerCase().includes('microsoft')) {\n return true;\n }\n\n try {\n return fs.readFileSync('/proc/version', 'utf8').toLowerCase().includes('microsoft');\n } catch {\n return false;\n }\n};\n","// modified from https://github.com/automation-stack/node-machine-id\n\nimport { execSync } from 'child_process';\nimport { createHash, randomUUID } from 'node:crypto';\n\nconst { platform } = process;\nconst win32RegBinPath = {\n native: '%windir%\\\\System32',\n mixed: '%windir%\\\\sysnative\\\\cmd.exe /c %windir%\\\\System32',\n};\nconst guid = {\n darwin: 'ioreg -rd1 -c IOPlatformExpertDevice',\n win32:\n `${win32RegBinPath[isWindowsProcessMixedOrNativeArchitecture()]}\\\\REG.exe ` +\n 'QUERY HKEY_LOCAL_MACHINE\\\\SOFTWARE\\\\Microsoft\\\\Cryptography ' +\n '/v MachineGuid',\n linux: '( cat /var/lib/dbus/machine-id /etc/machine-id 2> /dev/null || hostname 2> /dev/null) | head -n 1 || :',\n freebsd: 'kenv -q smbios.system.uuid || sysctl -n kern.hostuuid',\n};\n\nfunction isWindowsProcessMixedOrNativeArchitecture() {\n // eslint-disable-next-line no-prototype-builtins\n if (process.arch === 'ia32' && process.env.hasOwnProperty('PROCESSOR_ARCHITEW6432')) {\n return 'mixed';\n }\n return 'native';\n}\n\nfunction hash(guid: string): string {\n return createHash('sha256').update(guid).digest('hex');\n}\n\nfunction expose(result: string): string | undefined {\n switch (platform) {\n case 'darwin':\n return result\n .split('IOPlatformUUID')[1]\n ?.split('\\n')[0]\n ?.replace(/=|\\s+|\"/gi, '')\n .toLowerCase();\n case 'win32':\n return result\n .toString()\n .split('REG_SZ')[1]\n ?.replace(/\\r+|\\n+|\\s+/gi, '')\n .toLowerCase();\n case 'linux':\n return result\n .toString()\n .replace(/\\r+|\\n+|\\s+/gi, '')\n .toLowerCase();\n case 'freebsd':\n return result\n .toString()\n .replace(/\\r+|\\n+|\\s+/gi, '')\n .toLowerCase();\n default:\n throw new Error(`Unsupported platform: ${process.platform}`);\n }\n}\n\nexport function getMachineId() {\n if (!(platform in guid)) {\n return randomUUID();\n }\n try {\n const value = execSync(guid[platform as keyof typeof guid]);\n const id = expose(value.toString());\n if (!id) {\n return randomUUID();\n }\n return hash(id);\n } catch {\n return randomUUID();\n }\n}\n","import colors from 'colors';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport semver from 'semver';\n\nconst CHECK_VERSION_TIMEOUT = 2000;\nconst VERSION_CHECK_TAG = 'next';\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\nexport async function checkNewVersion() {\n const currVersion = getVersion();\n let latestVersion: string;\n try {\n latestVersion = await getLatestVersion();\n } catch {\n // noop\n return;\n }\n\n if (latestVersion && currVersion && semver.gt(latestVersion, currVersion)) {\n console.log(`A newer version ${colors.cyan(latestVersion)} is available.`);\n }\n}\n\nexport async function getLatestVersion() {\n const fetchResult = await fetch(`https://registry.npmjs.org/@zenstackhq/cli/${VERSION_CHECK_TAG}`, {\n headers: { accept: 'application/vnd.npm.install-v1+json; q=1.0, application/json; q=0.8, */*' },\n signal: AbortSignal.timeout(CHECK_VERSION_TIMEOUT),\n });\n\n if (fetchResult.ok) {\n const data: any = await fetchResult.json();\n const latestVersion = data?.version;\n if (typeof latestVersion === 'string' && semver.valid(latestVersion)) {\n return latestVersion;\n }\n }\n\n throw new Error('invalid npm registry response');\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","execPrisma","args","options","prismaPath","resolve","fileURLToPath","require","execSync","CliError","Error","getSchemaFile","file","fs","existsSync","CliError","pkgJsonConfig","getPkgJsonConfig","process","cwd","schema","statSync","isDirectory","schemaPath","path","join","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","dirname","prismaSchemaFile","resolve","writeFileSync","startPath","result","undefined","output","pkgJsonFile","findUp","pkgJson","JSON","parse","readFileSync","zenstack","names","multiple","name","target","find","push","up","length","run","command","options","runPush","schemaFile","getSchemaFile","schema","prismaSchemaFile","generateTempPrismaSchema","cmd","acceptDataLoss","forceReset","join","execPrisma","err","handleSubProcessError","fs","existsSync","unlinkSync","import_ast","import_colors","import_node_path","import_sdk","import_node_fs","import_node_path","plugin","name","statusText","generate","model","defaultOutputPath","pluginOptions","outFile","path","join","resolve","fs","existsSync","dirname","mkdirSync","recursive","prismaSchema","PrismaSchemaGenerator","writeFileSync","import_sdk","import_node_fs","import_node_path","plugin","name","statusText","generate","model","defaultOutputPath","pluginOptions","outDir","path","resolve","fs","existsSync","mkdirSync","recursive","lite","liteOnly","TsSchemaGenerator","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","push","pluginOptions","getPluginOptions","defaultPlugins","lite","liteOnly","forEach","some","p","invariant","generate","name","spinner","ora","statusText","defaultOutputPath","succeed","err","fail","error","providerField","fields","find","f","value","result","field","getLiteral","getLiteralArray","undefined","warn","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","private","undefined","import_colors","import_node_fs","import_node_path","import_ora","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","execPrisma","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_crypto","import_node_fs","os","TELEMETRY_TRACKING_TOKEN","isInCi","env","Object","keys","some","key","startsWith","import_node_fs","import_node_fs","isDockerCached","hasDockerEnv","fs","statSync","hasDockerCGroup","readFileSync","includes","isDocker","undefined","cachedResult","hasContainerEnv","fs","statSync","isInContainer","undefined","isDocker","import_node_process","import_node_fs","isWsl","process","platform","os","release","toLowerCase","includes","fs","readFileSync","import_child_process","platform","process","win32RegBinPath","native","mixed","guid","darwin","win32","isWindowsProcessMixedOrNativeArchitecture","linux","freebsd","arch","env","hasOwnProperty","hash","createHash","update","digest","expose","result","split","replace","toLowerCase","toString","Error","getMachineId","randomUUID","value","execSync","id","import_colors","import_node_fs","import_node_path","import_meta","CHECK_VERSION_TIMEOUT","VERSION_CHECK_TAG","getVersion","_dirname","__dirname","path","dirname","fileURLToPath","import_meta","url","JSON","parse","fs","readFileSync","join","version","undefined","checkNewVersion","currVersion","latestVersion","getLatestVersion","semver","gt","console","log","colors","cyan","fetchResult","fetch","headers","accept","signal","AbortSignal","timeout","ok","data","json","valid","Error","import_meta","Telemetry","mixpanel","hostId","getMachineId","sessionid","randomUUID","_os_type","type","_os_release","release","_os_arch","arch","_os_version","version","_os_platform","platform","getVersion","prismaVersion","getPrismaVersion","isDocker","isWsl","isContainer","isInContainer","isCi","isInCi","process","env","TELEMETRY_TRACKING_TOKEN","init","geolocate","isTracking","track","event","properties","payload","distinct_id","session","time","Date","$os","osType","osRelease","osPlatform","osArch","osVersion","nodeVersion","trackError","err","message","stack","trackSpan","startEvent","completeEvent","errorEvent","action","start","now","success","duration","trackCommand","command","trackCli","packageJsonPath","import_meta","resolve","packageJsonUrl","URL","packageJson","JSON","parse","fs","readFileSync","undefined","telemetry","generateAction","options","telemetry","trackCommand","generate","migrateAction","subCommand","migrate","dbAction","db","infoAction","projectPath","info","initAction","init","checkAction","check","createProgram","program","Command","version","getVersion","schemaExtensions","ZModelLanguageMetaData","fileExtensions","join","description","colors","bold","blue","showHelpAfterError","showSuggestionAfterError","schemaOption","Option","noVersionCheckOption","command","addOption","default","action","migrateCommand","migrationsOption","dbCommand","argument","hook","_thisCommand","actionCommand","getOptionValue","checkNewVersion","main","exitCode","exitOverride","trackCli","parseAsync","e","CommanderError","CliError","console","error","red","message","isTracking","setTimeout","process","exit"]}