@sanity/cli 6.0.0-alpha.6 → 6.0.0-alpha.8

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.
Files changed (209) hide show
  1. package/README.md +2907 -109
  2. package/dist/actions/build/renderDocumentWorker/tryLoadDocumentComponent.js +2 -1
  3. package/dist/actions/build/renderDocumentWorker/tryLoadDocumentComponent.js.map +1 -1
  4. package/dist/actions/init/bootstrapLocalTemplate.d.ts +13 -0
  5. package/dist/actions/init/bootstrapLocalTemplate.js +136 -0
  6. package/dist/actions/init/bootstrapLocalTemplate.js.map +1 -0
  7. package/dist/actions/init/bootstrapRemoteTemplate.d.ts +12 -0
  8. package/dist/actions/init/bootstrapRemoteTemplate.js +109 -0
  9. package/dist/actions/init/bootstrapRemoteTemplate.js.map +1 -0
  10. package/dist/actions/init/bootstrapTemplate.d.ts +18 -0
  11. package/dist/actions/init/bootstrapTemplate.js +32 -0
  12. package/dist/actions/init/bootstrapTemplate.js.map +1 -0
  13. package/dist/actions/init/checkNextJsReactCompatibility.d.ts +9 -0
  14. package/dist/actions/init/checkNextJsReactCompatibility.js +21 -0
  15. package/dist/actions/init/checkNextJsReactCompatibility.js.map +1 -0
  16. package/dist/actions/init/countNestedFolders.d.ts +1 -0
  17. package/dist/actions/init/countNestedFolders.js +6 -0
  18. package/dist/actions/init/countNestedFolders.js.map +1 -0
  19. package/dist/actions/init/createAppCliConfig.d.ts +5 -0
  20. package/dist/actions/init/createAppCliConfig.js +19 -0
  21. package/dist/actions/init/createAppCliConfig.js.map +1 -0
  22. package/dist/actions/init/createCliConfig.d.ts +6 -0
  23. package/dist/actions/init/createCliConfig.js +27 -0
  24. package/dist/actions/init/createCliConfig.js.map +1 -0
  25. package/dist/actions/init/createPackageManifest.d.ts +6 -0
  26. package/dist/actions/init/createPackageManifest.js +86 -0
  27. package/dist/actions/init/createPackageManifest.js.map +1 -0
  28. package/dist/actions/init/createStudioConfig.d.ts +13 -0
  29. package/dist/actions/init/createStudioConfig.js +41 -0
  30. package/dist/actions/init/createStudioConfig.js.map +1 -0
  31. package/dist/actions/init/env/createOrAppendEnvVars.d.ts +12 -0
  32. package/dist/actions/init/env/createOrAppendEnvVars.js +25 -0
  33. package/dist/actions/init/env/createOrAppendEnvVars.js.map +1 -0
  34. package/dist/actions/init/env/parseAndUpdateEnvVars.d.ts +9 -0
  35. package/dist/actions/init/env/parseAndUpdateEnvVars.js +42 -0
  36. package/dist/actions/init/env/parseAndUpdateEnvVars.js.map +1 -0
  37. package/dist/actions/init/env/writeEnvVarsToFile.d.ts +12 -0
  38. package/dist/actions/init/env/writeEnvVarsToFile.js +49 -0
  39. package/dist/actions/init/env/writeEnvVarsToFile.js.map +1 -0
  40. package/dist/actions/init/fetchPostInitPrompt.d.ts +6 -0
  41. package/dist/actions/init/fetchPostInitPrompt.js +30 -0
  42. package/dist/actions/init/fetchPostInitPrompt.js.map +1 -0
  43. package/dist/actions/init/git.d.ts +1 -0
  44. package/dist/actions/init/git.js +65 -0
  45. package/dist/actions/init/git.js.map +1 -0
  46. package/dist/actions/init/processTemplate.d.ts +7 -0
  47. package/dist/actions/init/processTemplate.js +56 -0
  48. package/dist/actions/init/processTemplate.js.map +1 -0
  49. package/dist/actions/init/remoteTemplate.d.ts +0 -3
  50. package/dist/actions/init/remoteTemplate.js +2 -40
  51. package/dist/actions/init/remoteTemplate.js.map +1 -1
  52. package/dist/actions/init/resolvePackageManager.d.ts +10 -0
  53. package/dist/actions/init/resolvePackageManager.js +20 -0
  54. package/dist/actions/init/resolvePackageManager.js.map +1 -0
  55. package/dist/actions/init/setupMCP.d.ts +21 -0
  56. package/dist/actions/init/setupMCP.js +258 -0
  57. package/dist/actions/init/setupMCP.js.map +1 -0
  58. package/dist/actions/init/templates/appQuickstart.d.ts +3 -0
  59. package/dist/actions/init/templates/appQuickstart.js +28 -0
  60. package/dist/actions/init/templates/appQuickstart.js.map +1 -0
  61. package/dist/actions/init/templates/appSanityUi.d.ts +3 -0
  62. package/dist/actions/init/templates/appSanityUi.js +30 -0
  63. package/dist/actions/init/templates/appSanityUi.js.map +1 -0
  64. package/dist/actions/init/templates/blog.d.ts +3 -0
  65. package/dist/actions/init/templates/blog.js +4 -0
  66. package/dist/actions/init/templates/blog.js.map +1 -0
  67. package/dist/actions/init/templates/clean.d.ts +3 -0
  68. package/dist/actions/init/templates/clean.js +4 -0
  69. package/dist/actions/init/templates/clean.js.map +1 -0
  70. package/dist/actions/init/templates/getStarted.d.ts +3 -0
  71. package/dist/actions/init/templates/getStarted.js +35 -0
  72. package/dist/actions/init/templates/getStarted.js.map +1 -0
  73. package/dist/actions/init/templates/index.d.ts +3 -0
  74. package/dist/actions/init/templates/index.js +23 -0
  75. package/dist/actions/init/templates/index.js.map +1 -0
  76. package/dist/actions/init/templates/moviedb.d.ts +3 -0
  77. package/dist/actions/init/templates/moviedb.js +34 -0
  78. package/dist/actions/init/templates/moviedb.js.map +1 -0
  79. package/dist/actions/init/templates/nextjs/index.d.ts +6 -0
  80. package/dist/actions/init/templates/nextjs/index.js +213 -0
  81. package/dist/actions/init/templates/nextjs/index.js.map +1 -0
  82. package/dist/actions/init/templates/nextjs/schemaTypes/blog.d.ts +3 -0
  83. package/dist/actions/init/templates/nextjs/schemaTypes/blog.js +247 -0
  84. package/dist/actions/init/templates/nextjs/schemaTypes/blog.js.map +1 -0
  85. package/dist/actions/init/templates/quickstart.d.ts +3 -0
  86. package/dist/actions/init/templates/quickstart.js +4 -0
  87. package/dist/actions/init/templates/quickstart.js.map +1 -0
  88. package/dist/actions/init/templates/shopify.d.ts +3 -0
  89. package/dist/actions/init/templates/shopify.js +77 -0
  90. package/dist/actions/init/templates/shopify.js.map +1 -0
  91. package/dist/actions/init/templates/shopifyOnline.d.ts +3 -0
  92. package/dist/actions/init/templates/shopifyOnline.js +49 -0
  93. package/dist/actions/init/templates/shopifyOnline.js.map +1 -0
  94. package/dist/actions/init/types.d.ts +15 -0
  95. package/dist/actions/init/types.js +3 -0
  96. package/dist/actions/init/types.js.map +1 -0
  97. package/dist/actions/init/updateInitialTemplateMetadata.d.ts +1 -0
  98. package/dist/actions/init/updateInitialTemplateMetadata.js +17 -0
  99. package/dist/actions/init/updateInitialTemplateMetadata.js.map +1 -0
  100. package/dist/actions/telemetry/resolveConsent.d.ts +1 -9
  101. package/dist/actions/telemetry/resolveConsent.js +2 -2
  102. package/dist/actions/telemetry/resolveConsent.js.map +1 -1
  103. package/dist/actions/telemetry/setConsent.d.ts +1 -4
  104. package/dist/actions/telemetry/setConsent.js +4 -8
  105. package/dist/actions/telemetry/setConsent.js.map +1 -1
  106. package/dist/commands/init.d.ts +24 -14
  107. package/dist/commands/init.js +544 -26
  108. package/dist/commands/init.js.map +1 -1
  109. package/dist/commands/telemetry/disable.js +0 -1
  110. package/dist/commands/telemetry/disable.js.map +1 -1
  111. package/dist/commands/telemetry/enable.js +0 -1
  112. package/dist/commands/telemetry/enable.js.map +1 -1
  113. package/dist/commands/telemetry/status.js +1 -3
  114. package/dist/commands/telemetry/status.js.map +1 -1
  115. package/dist/hooks/prerun/flushTelemetry.worker.d.ts +2 -0
  116. package/dist/hooks/prerun/flushTelemetry.worker.js +22 -0
  117. package/dist/hooks/prerun/flushTelemetry.worker.js.map +1 -0
  118. package/dist/hooks/prerun/setupTelemetry.js +65 -1
  119. package/dist/hooks/prerun/setupTelemetry.js.map +1 -1
  120. package/dist/prompts/init/nextjs.d.ts +5 -0
  121. package/dist/prompts/init/nextjs.js +56 -0
  122. package/dist/prompts/init/nextjs.js.map +1 -0
  123. package/dist/prompts/init/promptForTypescript.d.ts +0 -1
  124. package/dist/prompts/init/promptForTypescript.js +0 -6
  125. package/dist/prompts/init/promptForTypescript.js.map +1 -1
  126. package/dist/services/mcp.d.ts +10 -0
  127. package/dist/services/mcp.js +16 -0
  128. package/dist/services/mcp.js.map +1 -1
  129. package/dist/services/projects.d.ts +5 -2
  130. package/dist/services/projects.js +37 -0
  131. package/dist/services/projects.js.map +1 -1
  132. package/dist/services/telemetry.d.ts +2 -0
  133. package/dist/services/telemetry.js +20 -0
  134. package/dist/services/telemetry.js.map +1 -0
  135. package/dist/studioDependencies.d.ts +16 -0
  136. package/dist/studioDependencies.js +24 -0
  137. package/dist/studioDependencies.js.map +1 -0
  138. package/dist/telemetry/cli.telemetry.d.ts +20 -0
  139. package/dist/telemetry/cli.telemetry.js +8 -0
  140. package/dist/telemetry/cli.telemetry.js.map +1 -0
  141. package/dist/telemetry/store/cleanupOldTelemetryFiles.d.ts +5 -0
  142. package/dist/telemetry/store/cleanupOldTelemetryFiles.js +30 -0
  143. package/dist/telemetry/store/cleanupOldTelemetryFiles.js.map +1 -0
  144. package/dist/telemetry/store/createTelemetryStore.d.ts +39 -0
  145. package/dist/telemetry/store/createTelemetryStore.js +95 -0
  146. package/dist/telemetry/store/createTelemetryStore.js.map +1 -0
  147. package/dist/telemetry/store/createTraceId.d.ts +10 -0
  148. package/dist/telemetry/store/createTraceId.js +10 -0
  149. package/dist/telemetry/store/createTraceId.js.map +1 -0
  150. package/dist/telemetry/store/debug.d.ts +5 -0
  151. package/dist/telemetry/store/debug.js +7 -0
  152. package/dist/telemetry/store/debug.js.map +1 -0
  153. package/dist/telemetry/store/findTelemetryFiles.d.ts +13 -0
  154. package/dist/telemetry/store/findTelemetryFiles.js +34 -0
  155. package/dist/telemetry/store/findTelemetryFiles.js.map +1 -0
  156. package/dist/telemetry/store/flushTelemetryFiles.d.ts +20 -0
  157. package/dist/telemetry/store/flushTelemetryFiles.js +107 -0
  158. package/dist/telemetry/store/flushTelemetryFiles.js.map +1 -0
  159. package/dist/telemetry/store/generateTelemetryFilePath.d.ts +17 -0
  160. package/dist/telemetry/store/generateTelemetryFilePath.js +30 -0
  161. package/dist/telemetry/store/generateTelemetryFilePath.js.map +1 -0
  162. package/dist/telemetry/store/getTelemetryBaseInfo.d.ts +27 -0
  163. package/dist/telemetry/store/getTelemetryBaseInfo.js +34 -0
  164. package/dist/telemetry/store/getTelemetryBaseInfo.js.map +1 -0
  165. package/dist/telemetry/store/logger.d.ts +6 -0
  166. package/dist/telemetry/store/logger.js +54 -0
  167. package/dist/telemetry/store/logger.js.map +1 -0
  168. package/dist/telemetry/store/trace.d.ts +6 -0
  169. package/dist/telemetry/store/trace.js +150 -0
  170. package/dist/telemetry/store/trace.js.map +1 -0
  171. package/dist/telemetry/utils/readNDJSON.d.ts +10 -0
  172. package/dist/telemetry/utils/readNDJSON.js +18 -0
  173. package/dist/telemetry/utils/readNDJSON.js.map +1 -0
  174. package/dist/types.d.ts +33 -0
  175. package/dist/types.js.map +1 -1
  176. package/dist/typings/deepSortObject.d.js +2 -0
  177. package/dist/typings/deepSortObject.d.js.map +1 -0
  178. package/dist/util/copy.d.ts +5 -0
  179. package/dist/util/copy.js +37 -0
  180. package/dist/util/copy.js.map +1 -0
  181. package/dist/util/detectRuntime.d.ts +8 -0
  182. package/dist/util/detectRuntime.js +20 -0
  183. package/dist/util/detectRuntime.js.map +1 -0
  184. package/dist/util/frameworkPort.d.ts +12 -0
  185. package/dist/util/frameworkPort.js +61 -0
  186. package/dist/util/frameworkPort.js.map +1 -0
  187. package/dist/util/fsUtils.d.ts +2 -0
  188. package/dist/util/fsUtils.js +34 -0
  189. package/dist/util/fsUtils.js.map +1 -0
  190. package/dist/util/getProjectDefaults.d.ts +11 -0
  191. package/dist/util/getProjectDefaults.js +77 -0
  192. package/dist/util/getProjectDefaults.js.map +1 -0
  193. package/dist/util/isStaging.d.ts +7 -0
  194. package/dist/util/isStaging.js +10 -0
  195. package/dist/util/isStaging.js.map +1 -0
  196. package/dist/util/packageManager/packageManagerChoice.d.ts +2 -0
  197. package/dist/util/packageManager/packageManagerChoice.js +8 -0
  198. package/dist/util/packageManager/packageManagerChoice.js.map +1 -1
  199. package/dist/util/parseArguments.d.ts +35 -0
  200. package/dist/util/parseArguments.js +42 -0
  201. package/dist/util/parseArguments.js.map +1 -0
  202. package/dist/util/readdirRecursive.d.ts +5 -0
  203. package/dist/util/readdirRecursive.js +24 -0
  204. package/dist/util/readdirRecursive.js.map +1 -0
  205. package/dist/util/resolveLatestVersions.d.ts +7 -0
  206. package/dist/util/resolveLatestVersions.js +21 -0
  207. package/dist/util/resolveLatestVersions.js.map +1 -0
  208. package/oclif.manifest.json +154 -141
  209. package/package.json +26 -14
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/commands/init.ts"],"sourcesContent":["// @Todo will remove by time migration of this command is complete\n/* eslint-disable @typescript-eslint/no-unused-vars */\nimport {Args, Command, Flags} from '@oclif/core'\nimport {CLIError} from '@oclif/core/errors'\nimport {type FlagInput} from '@oclif/core/interfaces'\nimport {getCliToken, SanityCommand, type SanityOrgUser, subdebug} from '@sanity/cli-core'\nimport {chalk, confirm, input, logSymbols, select, Separator, spinner} from '@sanity/cli-core/ux'\nimport {type DatasetAclMode, isHttpError} from '@sanity/client'\nimport {type Framework, frameworks} from '@vercel/frameworks'\nimport {detectFrameworkRecord, LocalFileSystemDetector} from '@vercel/fs-detectors'\n\nimport {getProviderName} from '../actions/auth/getProviderName.js'\nimport {login} from '../actions/auth/login/login.js'\nimport {createDataset} from '../actions/dataset/create.js'\nimport {determineAppTemplate} from '../actions/init/determineAppTemplate.js'\nimport {\n checkIsRemoteTemplate,\n getGitHubRepoInfo,\n type RepoInfo,\n} from '../actions/init/remoteTemplate.js'\nimport {getOrganizationChoices} from '../actions/organizations/getOrganizationChoices.js'\nimport {getOrganizationsWithAttachGrantInfo} from '../actions/organizations/getOrganizationsWithAttachGrantInfo.js'\nimport {hasProjectAttachGrant} from '../actions/organizations/hasProjectAttachGrant.js'\nimport {promptForDatasetName} from '../prompts/promptForDatasetName.js'\nimport {createDataset as createDatasetService, listDatasets} from '../services/datasets.js'\nimport {getProjectFeatures} from '../services/getProjectFeatures.js'\nimport {\n createOrganization,\n listOrganizations,\n type OrganizationCreateResponse,\n type ProjectOrganization,\n} from '../services/organizations.js'\nimport {getPlanId, getPlanIdFromCoupon} from '../services/plans.js'\nimport {createProject, listProjects} from '../services/projects.js'\nimport {getCliUser} from '../services/user.js'\n\nconst debug = subdebug('init')\n\nexport class InitCommand extends SanityCommand<typeof InitCommand> {\n static override args = {type: Args.string({hidden: true})}\n static override description = 'Initialize a new Sanity Studio, project and/or app'\n static override enableJsonFlag = true\n\n static override examples = [\n '<%= config.bin %> <%= command.id %>',\n {\n command: '<%= config.bin %> <%= command.id %> --dataset-default',\n description: 'Initialize a new project with a public dataset named \"production\"',\n },\n {\n command:\n '<%= config.bin %> <%= command.id %> -y --project abc123 --dataset production --output-path ~/myproj',\n description: 'Initialize a project with the given project ID and dataset to the given path',\n },\n {\n command:\n '<%= config.bin %> <%= command.id %> -y --project abc123 --dataset staging --template moviedb --output-path .',\n description:\n 'Initialize a project with the given project ID and dataset using the moviedb template to the given path',\n },\n {\n command:\n '<%= config.bin %> <%= command.id %> -y --create-project \"Movies Unlimited\" --dataset moviedb --visibility private --template moviedb --output-path /Users/espenh/movies-unlimited',\n description: 'Create a brand new project with name \"Movies Unlimited\"',\n },\n ] satisfies Array<Command.Example>\n\n static override flags = {\n 'auto-updates': Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Enable auto updates of studio versions',\n exclusive: ['bare'],\n }),\n bare: Flags.boolean({\n description:\n 'Skip the Studio initialization and only print the selected project ID and dataset name to stdout',\n }),\n coupon: Flags.string({\n description:\n 'Optionally select a coupon for a new project (cannot be used with --project-plan)',\n exclusive: ['project-plan'],\n helpValue: '<code>',\n }),\n 'create-project': Flags.string({\n description: 'Create a new project with the given name',\n helpValue: '<name>',\n }),\n dataset: Flags.string({\n description: 'Dataset name for the studio',\n exclusive: ['dataset-default'],\n helpValue: '<name>',\n }),\n 'dataset-default': Flags.boolean({\n description: 'Set up a project with a public dataset named \"production\"',\n }),\n env: Flags.string({\n description: 'Write environment variables to file',\n exclusive: ['bare'],\n helpValue: '<filename>',\n parse: async (input) => {\n if (!input.startsWith('.env')) {\n throw new CLIError('Env filename (`--env`) must start with `.env`')\n }\n return input\n },\n }),\n 'from-create': Flags.boolean({\n description: 'Internal flag to indicate that the command is run from create-sanity',\n hidden: true,\n }),\n git: Flags.string({\n default: undefined,\n description: 'Specify a commit message for initial commit, or disable git init',\n exclusive: ['bare'],\n // oclif doesn't indent correctly with custom help labels, thus leading space :/\n helpLabel: ' --[no-]git',\n helpValue: '<message>',\n }),\n mcp: Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Enable AI editor integration (MCP) setup',\n }),\n 'nextjs-add-config-files': Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Add config files to Next.js project',\n helpGroup: 'Next.js',\n }),\n 'nextjs-append-env': Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Append project ID and dataset to .env file',\n helpGroup: 'Next.js',\n }),\n 'nextjs-embed-studio': Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Embed the Studio in Next.js application',\n helpGroup: 'Next.js',\n }),\n // oclif doesn't support a boolean/string flag combination, but listing both a\n // `--git` and a `--no-git` flag in help breaks conventions, so we hide this one,\n // but use it to \"combine\" the two in the actual logic.\n 'no-git': Flags.boolean({\n description: 'Disable git initialization',\n exclusive: ['git'],\n hidden: true,\n }),\n organization: Flags.string({\n description: 'Organization ID to use for the project',\n helpValue: '<id>',\n }),\n 'output-path': Flags.string({\n description: 'Path to write studio project to',\n exclusive: ['bare'],\n helpValue: '<path>',\n }),\n 'overwrite-files': Flags.boolean({\n default: false,\n description: 'Overwrite existing files',\n }),\n 'package-manager': Flags.string({\n description: 'Specify which package manager to use [allowed: npm, yarn, pnpm]',\n exclusive: ['bare'],\n helpValue: '<manager>',\n options: ['npm', 'yarn', 'pnpm'],\n }),\n project: Flags.string({\n aliases: ['project-id'],\n description: 'Project ID to use for the studio',\n exclusive: ['create-project'],\n helpValue: '<id>',\n }),\n 'project-plan': Flags.string({\n description: 'Optionally select a plan for a new project',\n helpValue: '<name>',\n }),\n provider: Flags.string({\n description: 'Login provider to use',\n helpValue: '<provider>',\n }),\n reconfigure: Flags.boolean({\n deprecated: {message: 'This flag is no longer supported', version: '3.0.0'},\n description: 'Reconfigure an existing project',\n hidden: true,\n }),\n template: Flags.string({\n default: 'clean',\n description: 'Project template to use [default: \"clean\"]',\n exclusive: ['bare'],\n helpValue: '<template>',\n }),\n // Porting over a beta flag\n // Oclif doesn't seem to support something in beta so hiding for now\n 'template-token': Flags.string({\n description: 'Used for accessing private GitHub repo templates',\n hidden: true,\n }),\n typescript: Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Enable TypeScript support',\n exclusive: ['bare'],\n }),\n visibility: Flags.string({\n description: 'Visibility mode for dataset',\n helpValue: '<mode>',\n options: ['public', 'private'],\n }),\n yes: Flags.boolean({\n char: 'y',\n default: false,\n description:\n 'Unattended mode, answers \"yes\" to any \"yes/no\" prompt and otherwise uses defaults',\n }),\n } satisfies FlagInput\n\n public async run(): Promise<void> {\n const {args, flags} = await this.parse(InitCommand)\n const createProjectName = this.flags['create-project']\n // For backwards \"compatibility\" - we used to allow `sanity init plugin`,\n // and no longer do - but instead of printing an error about an unknown\n // _command_, we want to acknowledge that the user is trying to do something\n // that no longer exists but might have at some point in the past.\n if (args.type) {\n this.error(\n args.type === 'plugin'\n ? 'Initializing plugins through the CLI is no longer supported'\n : `Unknown init type \"${args.type}\"`,\n {exit: 1},\n )\n }\n\n // @todo\n //const trace = telemetry.trace(CLIInitStepCompleted)\n\n // Slightly more helpful message for removed flags rather than just saying the flag\n // does not exist.\n if (this.flags.reconfigure) {\n this.error('--reconfigure is deprecated - manual configuration is now required', {exit: 1})\n }\n\n // Oclif doesn't support custom exclusive error messaging\n if (this.flags.project && this.flags.organization) {\n this.error(\n 'You have specified both a project and an organization. To move a project to an organization please visit https://www.sanity.io/manage',\n {exit: 1},\n )\n }\n\n const defaultConfig = this.flags['dataset-default']\n let showDefaultConfigPrompt = !defaultConfig\n if (\n this.flags.dataset ||\n this.flags.visibility ||\n this.flags['dataset-default'] ||\n this.isUnattended()\n ) {\n showDefaultConfigPrompt = false\n }\n\n const detectedFramework: Framework | null = await detectFrameworkRecord({\n frameworkList: frameworks as readonly Framework[],\n fs: new LocalFileSystemDetector(process.cwd()),\n })\n const isNextJs = detectedFramework?.slug === 'nextjs'\n\n let remoteTemplateInfo: RepoInfo | undefined\n if (flags.template && checkIsRemoteTemplate(flags.template)) {\n remoteTemplateInfo = await getGitHubRepoInfo(flags.template, flags['template-token'])\n }\n\n if (detectedFramework && detectedFramework.slug !== 'sanity' && remoteTemplateInfo) {\n this.error(\n `A remote template cannot be used with a detected framework. Detected: ${detectedFramework.name}`,\n {exit: 1},\n )\n }\n\n // Checks flags are present when in unattended mode\n if (this.isUnattended()) {\n this.checkFlagsInUnattendedMode({createProjectName, isNextJs})\n }\n\n // @todo\n // trace.start()\n // trace.log({\n // step: 'start',\n // flags: {\n // defaultConfig,\n // unattended,\n // plan: intendedPlan,\n // coupon: intendedCoupon,\n // reconfigure,\n // git: commitMessage,\n // bare: bareOutput,\n // env,\n // },\n // })\n\n // Plan can be set through `--project-plan`, or implied through `--coupon`.\n // As coupons can expire and project plans might change/be removed, we need to\n // verify that the passed flags are valid. The complexity of this is hidden in the\n // below plan methods, eventually returning a plan ID or undefined if we are told to\n // use the default plan.\n\n const planId = await this.getPlan()\n\n let envFilenameDefault = '.env'\n if (detectedFramework && detectedFramework.slug === 'nextjs') {\n envFilenameDefault = '.env.local'\n }\n const _envFilename = typeof flags.env === 'string' ? flags.env : envFilenameDefault\n\n // If the user isn't already autenticated, make it so\n const {user} = await this.ensureAuthenticated()\n\n // skip project / dataset prompting\n const template = this.flags.template\n const isAppTemplate = template ? determineAppTemplate(template) : false // Default to false\n if (!isAppTemplate) {\n this.log(`${logSymbols.success} Fetching existing projects`)\n this.log('')\n }\n\n const _newProjectId =\n createProjectName && (await this.createProjectFromName({createProjectName, planId, user}))\n\n const {datasetName, projectId} = await this.getProjectDetails({\n isAppTemplate,\n planId,\n showDefaultConfigPrompt,\n user,\n })\n\n // If user doesn't want to output any template code\n if (this.flags.bare) {\n this.log(`${logSymbols.success} Below are your project details`)\n this.log('')\n this.log(`Project ID: ${chalk.cyan(projectId)}`)\n this.log(`Dataset: ${chalk.cyan(datasetName)}`)\n this.log(\n `\\nYou can find your project on Sanity Manage — https://www.sanity.io/manage/project/${projectId}\\n`,\n )\n return\n }\n }\n\n private checkFlagsInUnattendedMode({\n createProjectName,\n isNextJs,\n }: {\n createProjectName: string | undefined\n isNextJs: boolean\n }) {\n debug('Unattended mode, validating required options')\n\n if (!this.flags['dataset']) {\n this.error(`\\`--dataset\\` must be specified in unattended mode`, {exit: 1})\n }\n\n // output-path is required in unattended mode when not using nextjs\n if (!isNextJs && !this.flags['output-path']) {\n this.error(`\\`--output-path\\` must be specified in unattended mode`, {exit: 1})\n }\n\n if (!this.flags.project && !createProjectName) {\n this.error(\n '`--project <id>` or `--create-project <name>` must be specified in unattended mode',\n {exit: 1},\n )\n }\n\n if (createProjectName && !this.flags.organization) {\n this.error(\n '--create-project is not supported in unattended mode without an organization, please specify an organization with `--organization <id>`',\n {exit: 1},\n )\n }\n }\n\n private async createProjectFromName({\n createProjectName,\n planId,\n user,\n }: {\n createProjectName: string\n planId: string | undefined\n user: SanityOrgUser\n }): Promise<string> {\n debug('--create-project specified, creating a new project')\n\n let orgForCreateProjectFlag = this.flags.organization\n\n if (!orgForCreateProjectFlag) {\n debug('no organization specified, selecting one')\n const organizations = await listOrganizations()\n orgForCreateProjectFlag = await this.promptUserForOrganization({organizations, user})\n }\n\n debug('creating a new project')\n const createdProject = await createProject({\n displayName: createProjectName.trim(),\n metadata: {coupon: this.flags.coupon},\n organizationId: orgForCreateProjectFlag,\n subscription: planId ? {planId} : undefined,\n })\n\n debug('Project with ID %s created', createdProject.projectId)\n if (this.flags.dataset) {\n debug('--dataset specified, creating dataset (%s)', this.flags.dataset)\n const spin = spinner('Creating dataset').start()\n await createDatasetService({\n aclMode: this.flags.visibility as DatasetAclMode,\n datasetName: this.flags.dataset,\n projectId: createdProject.projectId,\n })\n spin.succeed()\n }\n\n return createdProject.projectId\n }\n\n // @todo do we actually need to be authenticated for init? check flags and determine.\n private async ensureAuthenticated(): Promise<{user: SanityOrgUser}> {\n let isAuthenticated = (await getCliToken()) !== undefined\n debug(isAuthenticated ? 'User already has a token' : 'User has no token')\n\n let user: SanityOrgUser | undefined\n if (isAuthenticated) {\n // It _appears_ we are authenticated, but the token might be invalid/expired,\n // so we need to verify that we can actually make an authenticated request.\n try {\n user = await getCliUser()\n } catch {\n // assume that any error means that the token is invalid\n isAuthenticated = false\n }\n }\n\n if (isAuthenticated) {\n // @todo telemetry\n // trace.log({ step: 'login', alreadyLoggedIn: true })\n } else {\n if (this.isUnattended()) {\n this.error('Must be logged in to run this command in unattended mode, run `sanity login`', {\n exit: 1,\n })\n }\n\n // @todo telemetry\n //trace.log({step: 'login'})\n\n // @todo trigger login action, then get and return user info\n await login({output: this.output})\n }\n\n user = await getCliUser()\n\n this.log(\n `${logSymbols.success} You are logged in as ${user.email} using ${getProviderName(user.provider)}`,\n )\n return {user}\n }\n\n private async getOrCreateDataset(opts: {\n displayName: string\n projectId: string\n showDefaultConfigPrompt: boolean\n }): Promise<{datasetName: string; userAction: 'create' | 'none' | 'select'}> {\n const visibility = this.flags.visibility\n const dataset = this.flags.dataset\n let defaultConfig = this.flags['dataset-default']\n\n if (dataset && this.isUnattended()) {\n return {datasetName: dataset, userAction: 'none'}\n }\n\n const [datasets, projectFeatures] = await Promise.all([\n listDatasets(opts.projectId),\n getProjectFeatures(opts.projectId),\n ])\n\n if (dataset) {\n debug('User has specified dataset through a flag (%s)', dataset)\n const existing = datasets.find((ds) => ds.name === dataset)\n if (!existing) {\n debug('Specified dataset not found, creating it')\n await createDataset({\n datasetName: dataset,\n forcePublic: defaultConfig,\n output: this.output,\n projectFeatures,\n projectId: opts.projectId,\n visibility,\n })\n }\n\n return {datasetName: dataset, userAction: 'none'}\n }\n\n const datasetInfo =\n 'Your content will be stored in a dataset that can be public or private, depending on\\nwhether you want to query your content with or without authentication.\\nThe default dataset configuration has a public dataset named \"production\".'\n\n if (datasets.length === 0) {\n debug('No datasets found for project, prompting for name')\n if (opts.showDefaultConfigPrompt) {\n this.log(datasetInfo)\n defaultConfig = await this.promptForDefaultConfig()\n }\n const name = defaultConfig\n ? 'production'\n : await promptForDatasetName({\n message: 'Name of your first dataset:',\n })\n await createDataset({\n datasetName: name,\n forcePublic: defaultConfig,\n output: this.output,\n projectFeatures,\n projectId: opts.projectId,\n visibility,\n })\n return {datasetName: name, userAction: 'create'}\n }\n\n debug(`User has ${datasets.length} dataset(s) already, showing list of choices`)\n const datasetChoices = datasets.map((dataset) => ({value: dataset.name}))\n\n const selected = await select({\n choices: [{name: 'Create new dataset', value: 'new'}, new Separator(), ...datasetChoices],\n message: 'Select dataset to use',\n })\n\n if (selected === 'new') {\n const existingDatasetNames = datasets.map((ds) => ds.name)\n debug('User wants to create a new dataset, prompting for name')\n if (opts.showDefaultConfigPrompt && !existingDatasetNames.includes('production')) {\n this.log(datasetInfo)\n defaultConfig = await this.promptForDefaultConfig()\n }\n\n const newDatasetName = defaultConfig\n ? 'production'\n : await promptForDatasetName(\n {\n message: 'Dataset name:',\n },\n existingDatasetNames,\n )\n await createDataset({\n datasetName: newDatasetName,\n forcePublic: defaultConfig,\n output: this.output,\n projectFeatures,\n projectId: opts.projectId,\n visibility,\n })\n return {datasetName: newDatasetName, userAction: 'create'}\n }\n\n debug(`Returning selected dataset (${selected})`)\n return {datasetName: selected, userAction: 'select'}\n }\n\n private async getOrCreateProject({\n planId,\n user,\n }: {\n planId: string | undefined\n user: SanityOrgUser\n }): Promise<{\n displayName: string\n isFirstProject: boolean\n projectId: string\n userAction: 'create' | 'select'\n }> {\n const projectId = this.flags.project\n const organizationId = this.flags.organization\n let projects\n let organizations: ProjectOrganization[]\n\n try {\n const [allProjects, allOrgs] = await Promise.all([listProjects(), listOrganizations()])\n projects = allProjects.toSorted((a, b) => b.createdAt.localeCompare(a.createdAt))\n organizations = allOrgs\n } catch (err) {\n if (this.isUnattended() && projectId) {\n return {\n displayName: 'Unknown project',\n isFirstProject: false,\n projectId,\n userAction: 'select',\n }\n }\n this.error(`Failed to communicate with the Sanity API:\\n${err.message}`, {exit: 1})\n }\n\n if (projects.length === 0 && this.isUnattended()) {\n this.error('No projects found for current user', {exit: 1})\n }\n\n if (projectId) {\n const project = projects.find((proj) => proj.id === projectId)\n if (!project && !this.isUnattended()) {\n this.error(`Given project ID (${projectId}) not found, or you do not have access to it`, {\n exit: 1,\n })\n }\n\n return {\n displayName: project ? project.displayName : 'Unknown project',\n isFirstProject: false,\n projectId,\n userAction: 'select',\n }\n }\n\n if (organizationId) {\n const organization =\n organizations.find((org) => org.id === organizationId) ||\n organizations.find((org) => org.slug === organizationId)\n\n if (!organization) {\n this.error(\n `Given organization ID (${organizationId}) not found, or you do not have access to it`,\n {exit: 1},\n )\n }\n\n if (!(await hasProjectAttachGrant(organizationId))) {\n this.error('You lack the necessary permissions to attach a project to this organization', {\n exit: 1,\n })\n }\n }\n\n // If the user has no projects or is using a coupon (which can only be applied to new projects)\n // just ask for project details instead of showing a list of projects\n const isUsersFirstProject = projects.length === 0\n if (isUsersFirstProject || this.flags.coupon) {\n debug(\n isUsersFirstProject\n ? 'No projects found for user, prompting for name'\n : 'Using a coupon - skipping project selection',\n )\n\n const newProject = await this.promptForProjectCreation({\n isUsersFirstProject,\n organizationId,\n organizations,\n planId,\n user,\n })\n\n return {\n ...newProject,\n isFirstProject: isUsersFirstProject,\n userAction: 'create',\n }\n }\n\n debug(`User has ${projects.length} project(s) already, showing list of choices`)\n\n const projectChoices = projects.map((project) => ({\n name: `${project.displayName} (${project.id})`,\n value: project.id,\n }))\n\n const selected = await select({\n choices: [{name: 'Create new project', value: 'new'}, new Separator(), ...projectChoices],\n message: 'Create a new project or select an existing one',\n })\n\n if (selected === 'new') {\n debug('User wants to create a new project, prompting for name')\n\n const newProject = await this.promptForProjectCreation({\n isUsersFirstProject,\n organizationId,\n organizations,\n planId,\n user,\n })\n\n return {\n ...newProject,\n isFirstProject: isUsersFirstProject,\n userAction: 'create',\n }\n }\n\n debug(`Returning selected project (${selected})`)\n return {\n displayName: projects.find((proj) => proj.id === selected)?.displayName || '',\n isFirstProject: isUsersFirstProject,\n projectId: selected,\n userAction: 'select',\n }\n }\n\n private async getPlan(): Promise<string | undefined> {\n const intendedPlan = this.flags['project-plan']\n const intendedCoupon = this.flags.coupon\n\n if (intendedCoupon) {\n return this.verifyCoupon(intendedCoupon)\n } else if (intendedPlan) {\n return this.verifyPlan(intendedPlan)\n } else {\n return undefined\n }\n }\n\n private async getProjectDetails({\n isAppTemplate,\n planId,\n showDefaultConfigPrompt,\n user,\n }: {\n isAppTemplate: boolean\n planId: string | undefined\n showDefaultConfigPrompt: boolean\n user: SanityOrgUser\n }): Promise<{\n datasetName: string\n displayName: string\n isFirstProject: boolean\n organizationId?: string\n projectId: string\n schemaUrl?: string\n }> {\n if (isAppTemplate) {\n const organizations = await listOrganizations({\n includeImplicitMemberships: 'true',\n includeMembers: 'true',\n })\n\n const appOrganizationId = await this.promptUserForOrganization({organizations, user})\n\n return {\n datasetName: '',\n displayName: '',\n isFirstProject: false,\n organizationId: appOrganizationId,\n projectId: '',\n }\n }\n\n debug('Prompting user to select or create a project')\n const project = await this.getOrCreateProject({planId, user})\n debug(`Project with name ${project.displayName} selected`)\n\n // Now let's pick or create a dataset\n debug('Prompting user to select or create a dataset')\n const dataset = await this.getOrCreateDataset({\n displayName: project.displayName,\n projectId: project.projectId,\n showDefaultConfigPrompt,\n })\n debug(`Dataset with name ${dataset.datasetName} selected`)\n\n // @todo\n // trace.log({\n // step: 'createOrSelectDataset',\n // selectedOption: dataset.userAction,\n // datasetName: dataset.datasetName,\n // visibility: flags.visibility as 'private' | 'public',\n // })\n\n return {\n datasetName: dataset.datasetName,\n displayName: project.displayName,\n isFirstProject: project.isFirstProject,\n projectId: project.projectId,\n }\n }\n\n private async promptForDefaultConfig(): Promise<boolean> {\n return confirm({\n default: true,\n message: 'Use the default dataset configuration?',\n })\n }\n\n private async promptForProjectCreation({\n isUsersFirstProject,\n organizationId,\n organizations,\n planId,\n user,\n }: {\n isUsersFirstProject: boolean\n organizationId: string | undefined\n organizations: ProjectOrganization[]\n planId: string | undefined\n user: SanityOrgUser\n }) {\n const projectName = await input({\n default: 'My Sanity Project',\n message: 'Project name:',\n validate(input) {\n if (!input || input.trim() === '') {\n return 'Project name cannot be empty'\n }\n\n if (input.length > 80) {\n return 'Project name cannot be longer than 80 characters'\n }\n\n return true\n },\n })\n\n const organization =\n organizationId || (await this.promptUserForOrganization({organizations, user}))\n\n const newProject = await createProject({\n displayName: projectName,\n metadata: {coupon: this.flags.coupon},\n organizationId: organization,\n subscription: planId ? {planId} : undefined,\n })\n\n return {\n ...newProject,\n isFirstProject: isUsersFirstProject,\n userAction: 'create',\n }\n }\n\n private async promptUserForNewOrganization(\n user: SanityOrgUser,\n ): Promise<OrganizationCreateResponse> {\n const name = await input({\n default: user ? user.name : undefined,\n message: 'Organization name:',\n validate(input) {\n if (input.length === 0) {\n return 'Organization name cannot be empty'\n } else if (input.length > 100) {\n return 'Organization name cannot be longer than 100 characters'\n }\n return true\n },\n })\n\n const spin = spinner('Creating organization').start()\n const organization = await createOrganization(name)\n spin.succeed()\n\n return organization\n }\n\n private async promptUserForOrganization({\n organizations,\n user,\n }: {\n organizations: ProjectOrganization[]\n user: SanityOrgUser\n }) {\n // If the user has no organizations, prompt them to create one with the same name as\n // their user, but allow them to customize it if they want\n if (organizations.length === 0) {\n const newOrganization = await this.promptUserForNewOrganization(user)\n return newOrganization.id\n }\n\n // If the user has organizations, let them choose from them, but also allow them to\n // create a new one in case they do not have access to any of them, or they want to\n // create a personal/other organization.\n debug(`User has ${organizations.length} organization(s), checking attach access`)\n const withGrantInfo = await getOrganizationsWithAttachGrantInfo(organizations)\n const withAttach = withGrantInfo.filter(({hasAttachGrant}) => hasAttachGrant)\n\n debug('User has attach access to %d organizations.', withAttach.length)\n const organizationChoices = getOrganizationChoices(withAttach)\n\n // If the user only has a single organization (and they have attach access to it),\n // we'll default to that one. Otherwise, we'll default to the organization with the\n // same name as the user if it exists.\n const defaultOrganizationId =\n withAttach.length === 1\n ? withAttach[0].organization.id\n : organizations.find((org) => org.name === user?.name)?.id\n\n const chosenOrg = await select({\n choices: organizationChoices,\n default: defaultOrganizationId || undefined,\n message: 'Select organization:',\n })\n\n if (chosenOrg === '-new-') {\n const newOrganization = await this.promptUserForNewOrganization(user)\n return newOrganization.id\n }\n\n return chosenOrg || undefined\n }\n\n private async verifyCoupon(intendedCoupon: string): Promise<string | undefined> {\n try {\n const planId = await getPlanIdFromCoupon(intendedCoupon)\n this.log(`Coupon \"${intendedCoupon}\" validated!\\n`)\n return planId\n } catch (err: unknown) {\n if (!isHttpError(err) || err.statusCode !== 404) {\n const message = err instanceof Error ? err.message : `${err}`\n this.error(`Unable to validate coupon, please try again later:\\n\\n${message}`, {exit: 1})\n }\n\n const useDefaultPlan =\n this.isUnattended() ||\n (await confirm({\n default: true,\n message: `Coupon \"${intendedCoupon}\" is not available, use default plan instead?`,\n }))\n\n if (this.isUnattended()) {\n this.warn(`Coupon \"${intendedCoupon}\" is not available - using default plan`)\n }\n\n // @todo\n // trace.log({\n // step: 'useDefaultPlanCoupon',\n // selectedOption: useDefaultPlan ? 'yes' : 'no',\n // coupon: intendedCoupon,\n // })\n\n if (useDefaultPlan) {\n this.log('Using default plan.')\n } else {\n this.error(`Coupon \"${intendedCoupon}\" does not exist`, {exit: 1})\n }\n }\n }\n\n private async verifyPlan(intendedPlan: string): Promise<string | undefined> {\n try {\n const planId = await getPlanId(intendedPlan)\n return planId\n } catch (err: unknown) {\n if (!isHttpError(err) || err.statusCode !== 404) {\n const message = err instanceof Error ? err.message : `${err}`\n this.error(`Unable to validate plan, please try again later:\\n\\n${message}`, {exit: 1})\n }\n\n const useDefaultPlan =\n this.isUnattended() ||\n (await confirm({\n default: true,\n message: `Project plan \"${intendedPlan}\" does not exist, use default plan instead?`,\n }))\n\n if (this.isUnattended()) {\n this.warn(`Project plan \"${intendedPlan}\" does not exist - using default plan`)\n }\n\n // @todo\n // trace.log({\n // step: 'useDefaultPlanId',\n // selectedOption: useDefaultPlan ? 'yes' : 'no',\n // planId: intendedPlan,\n // })\n\n if (useDefaultPlan) {\n this.log('Using default plan.')\n } else {\n this.error(`Plan id \"${intendedPlan}\" does not exist`, {exit: 1})\n }\n }\n }\n}\n"],"names":["Args","Flags","CLIError","getCliToken","SanityCommand","subdebug","chalk","confirm","input","logSymbols","select","Separator","spinner","isHttpError","frameworks","detectFrameworkRecord","LocalFileSystemDetector","getProviderName","login","createDataset","determineAppTemplate","checkIsRemoteTemplate","getGitHubRepoInfo","getOrganizationChoices","getOrganizationsWithAttachGrantInfo","hasProjectAttachGrant","promptForDatasetName","createDatasetService","listDatasets","getProjectFeatures","createOrganization","listOrganizations","getPlanId","getPlanIdFromCoupon","createProject","listProjects","getCliUser","debug","InitCommand","args","type","string","hidden","description","enableJsonFlag","examples","command","flags","boolean","allowNo","default","exclusive","bare","coupon","helpValue","dataset","env","parse","startsWith","git","undefined","helpLabel","mcp","helpGroup","organization","options","project","aliases","provider","reconfigure","deprecated","message","version","template","typescript","visibility","yes","char","run","createProjectName","error","exit","defaultConfig","showDefaultConfigPrompt","isUnattended","detectedFramework","frameworkList","fs","process","cwd","isNextJs","slug","remoteTemplateInfo","name","checkFlagsInUnattendedMode","planId","getPlan","envFilenameDefault","_envFilename","user","ensureAuthenticated","isAppTemplate","log","success","_newProjectId","createProjectFromName","datasetName","projectId","getProjectDetails","cyan","orgForCreateProjectFlag","organizations","promptUserForOrganization","createdProject","displayName","trim","metadata","organizationId","subscription","spin","start","aclMode","succeed","isAuthenticated","output","email","getOrCreateDataset","opts","userAction","datasets","projectFeatures","Promise","all","existing","find","ds","forcePublic","datasetInfo","length","promptForDefaultConfig","datasetChoices","map","value","selected","choices","existingDatasetNames","includes","newDatasetName","getOrCreateProject","projects","allProjects","allOrgs","toSorted","a","b","createdAt","localeCompare","err","isFirstProject","proj","id","org","isUsersFirstProject","newProject","promptForProjectCreation","projectChoices","intendedPlan","intendedCoupon","verifyCoupon","verifyPlan","includeImplicitMemberships","includeMembers","appOrganizationId","projectName","validate","promptUserForNewOrganization","newOrganization","withGrantInfo","withAttach","filter","hasAttachGrant","organizationChoices","defaultOrganizationId","chosenOrg","statusCode","Error","useDefaultPlan","warn"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/commands/init.ts"],"sourcesContent":["// @Todo will remove by time migration of this command is complete\nimport {existsSync} from 'node:fs'\nimport {mkdir, writeFile} from 'node:fs/promises'\nimport path from 'node:path'\n\nimport {Args, Command, Flags} from '@oclif/core'\nimport {CLIError} from '@oclif/core/errors'\nimport {getCliToken, SanityCommand, type SanityOrgUser, subdebug} from '@sanity/cli-core'\nimport {chalk, confirm, input, logSymbols, select, Separator, spinner} from '@sanity/cli-core/ux'\nimport {type DatasetAclMode, isHttpError} from '@sanity/client'\nimport {DatasetImportCommand} from '@sanity/import'\nimport {type Framework, frameworks} from '@vercel/frameworks'\nimport {detectFrameworkRecord, LocalFileSystemDetector} from '@vercel/fs-detectors'\nimport {execa, type Options} from 'execa'\nimport {deburr} from 'lodash-es'\n\nimport {getProviderName} from '../actions/auth/getProviderName.js'\nimport {login} from '../actions/auth/login/login.js'\nimport {createDataset} from '../actions/dataset/create.js'\nimport {bootstrapTemplate} from '../actions/init/bootstrapTemplate.js'\nimport {checkNextJsReactCompatibility} from '../actions/init/checkNextJsReactCompatibility.js'\nimport {countNestedFolders} from '../actions/init/countNestedFolders.js'\nimport {determineAppTemplate} from '../actions/init/determineAppTemplate.js'\nimport {createOrAppendEnvVars} from '../actions/init/env/createOrAppendEnvVars.js'\nimport {fetchPostInitPrompt} from '../actions/init/fetchPostInitPrompt.js'\nimport {tryGitInit} from '../actions/init/git.js'\nimport {\n checkIsRemoteTemplate,\n getGitHubRepoInfo,\n type RepoInfo,\n} from '../actions/init/remoteTemplate.js'\nimport {resolvePackageManager} from '../actions/init/resolvePackageManager.js'\nimport {type EditorName, setupMCP} from '../actions/init/setupMCP.js'\nimport templates from '../actions/init/templates/index.js'\nimport {\n sanityCliTemplate,\n sanityConfigTemplate,\n sanityFolder,\n sanityStudioTemplate,\n} from '../actions/init/templates/nextjs/index.js'\nimport {type VersionedFramework} from '../actions/init/types.js'\nimport {getOrganizationChoices} from '../actions/organizations/getOrganizationChoices.js'\nimport {getOrganizationsWithAttachGrantInfo} from '../actions/organizations/getOrganizationsWithAttachGrantInfo.js'\nimport {hasProjectAttachGrant} from '../actions/organizations/hasProjectAttachGrant.js'\nimport {\n promptForAppendEnv,\n promptForConfigFiles,\n promptForEmbeddedStudio,\n promptForNextTemplate,\n promptForStudioPath,\n} from '../prompts/init/nextjs.js'\nimport {promptForTypeScript} from '../prompts/init/promptForTypescript.js'\nimport {promptForDatasetName} from '../prompts/promptForDatasetName.js'\nimport {createCorsOrigin, listCorsOrigins} from '../services/cors.js'\nimport {createDataset as createDatasetService, listDatasets} from '../services/datasets.js'\nimport {getProjectFeatures} from '../services/getProjectFeatures.js'\nimport {\n createOrganization,\n listOrganizations,\n type OrganizationCreateResponse,\n type ProjectOrganization,\n} from '../services/organizations.js'\nimport {getPlanId, getPlanIdFromCoupon} from '../services/plans.js'\nimport {createProject, listProjects, updateProjectInitializedAt} from '../services/projects.js'\nimport {getCliUser} from '../services/user.js'\nimport {absolutify, validateEmptyPath} from '../util/fsUtils.js'\nimport {getProjectDefaults} from '../util/getProjectDefaults.js'\nimport {\n installDeclaredPackages,\n installNewPackages,\n} from '../util/packageManager/installPackages.js'\nimport {\n getPartialEnvWithNpmPath,\n type PackageManager,\n} from '../util/packageManager/packageManagerChoice.js'\n\nconst debug = subdebug('init')\n\nexport class InitCommand extends SanityCommand<typeof InitCommand> {\n static override args = {type: Args.string({hidden: true})}\n static override description = 'Initialize a new Sanity Studio, project and/or app'\n static override enableJsonFlag = true\n\n static override examples = [\n '<%= config.bin %> <%= command.id %>',\n {\n command: '<%= config.bin %> <%= command.id %> --dataset-default',\n description: 'Initialize a new project with a public dataset named \"production\"',\n },\n {\n command:\n '<%= config.bin %> <%= command.id %> -y --project abc123 --dataset production --output-path ~/myproj',\n description: 'Initialize a project with the given project ID and dataset to the given path',\n },\n {\n command:\n '<%= config.bin %> <%= command.id %> -y --project abc123 --dataset staging --template moviedb --output-path .',\n description:\n 'Initialize a project with the given project ID and dataset using the moviedb template to the given path',\n },\n {\n command:\n '<%= config.bin %> <%= command.id %> -y --create-project \"Movies Unlimited\" --dataset moviedb --visibility private --template moviedb --output-path /Users/espenh/movies-unlimited',\n description: 'Create a brand new project with name \"Movies Unlimited\"',\n },\n ] satisfies Array<Command.Example>\n\n static override flags = {\n 'auto-updates': Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Enable auto updates of studio versions',\n exclusive: ['bare'],\n }),\n bare: Flags.boolean({\n description:\n 'Skip the Studio initialization and only print the selected project ID and dataset name to stdout',\n }),\n coupon: Flags.string({\n description:\n 'Optionally select a coupon for a new project (cannot be used with --project-plan)',\n exclusive: ['project-plan'],\n helpValue: '<code>',\n }),\n 'create-project': Flags.string({\n description: 'Create a new project with the given name',\n helpValue: '<name>',\n }),\n dataset: Flags.string({\n description: 'Dataset name for the studio',\n exclusive: ['dataset-default'],\n helpValue: '<name>',\n }),\n 'dataset-default': Flags.boolean({\n description: 'Set up a project with a public dataset named \"production\"',\n }),\n env: Flags.string({\n description: 'Write environment variables to file',\n exclusive: ['bare'],\n helpValue: '<filename>',\n parse: async (input) => {\n if (!input.startsWith('.env')) {\n throw new CLIError('Env filename (`--env`) must start with `.env`')\n }\n return input\n },\n }),\n 'from-create': Flags.boolean({\n description: 'Internal flag to indicate that the command is run from create-sanity',\n hidden: true,\n }),\n git: Flags.string({\n default: undefined,\n description: 'Specify a commit message for initial commit, or disable git init',\n exclusive: ['bare'],\n // oclif doesn't indent correctly with custom help labels, thus leading space :/\n helpLabel: ' --[no-]git',\n helpValue: '<message>',\n }),\n mcp: Flags.boolean({\n allowNo: true,\n default: true,\n description: 'Enable AI editor integration (MCP) setup',\n }),\n 'nextjs-add-config-files': Flags.boolean({\n allowNo: true,\n default: undefined,\n description: 'Add config files to Next.js project',\n helpGroup: 'Next.js',\n }),\n 'nextjs-append-env': Flags.boolean({\n allowNo: true,\n default: undefined,\n description: 'Append project ID and dataset to .env file',\n helpGroup: 'Next.js',\n }),\n 'nextjs-embed-studio': Flags.boolean({\n allowNo: true,\n default: undefined,\n description: 'Embed the Studio in Next.js application',\n helpGroup: 'Next.js',\n }),\n // oclif doesn't support a boolean/string flag combination, but listing both a\n // `--git` and a `--no-git` flag in help breaks conventions, so we hide this one,\n // but use it to \"combine\" the two in the actual logic.\n 'no-git': Flags.boolean({\n description: 'Disable git initialization',\n exclusive: ['git'],\n hidden: true,\n }),\n organization: Flags.string({\n description: 'Organization ID to use for the project',\n helpValue: '<id>',\n }),\n 'output-path': Flags.string({\n description: 'Path to write studio project to',\n exclusive: ['bare'],\n helpValue: '<path>',\n }),\n 'overwrite-files': Flags.boolean({\n allowNo: true,\n default: undefined,\n description: 'Overwrite existing files',\n }),\n 'package-manager': Flags.string({\n description: 'Specify which package manager to use [allowed: npm, yarn, pnpm]',\n exclusive: ['bare'],\n helpValue: '<manager>',\n options: ['npm', 'yarn', 'pnpm'],\n }),\n project: Flags.string({\n aliases: ['project-id'],\n description: 'Project ID to use for the studio',\n exclusive: ['create-project'],\n helpValue: '<id>',\n }),\n 'project-plan': Flags.string({\n description: 'Optionally select a plan for a new project',\n helpValue: '<name>',\n }),\n provider: Flags.string({\n description: 'Login provider to use',\n helpValue: '<provider>',\n }),\n quickstart: Flags.boolean({\n deprecated: true,\n description:\n 'Used for initializing a project from a server schema that is saved in the Journey API',\n hidden: true,\n }),\n reconfigure: Flags.boolean({\n deprecated: {message: 'This flag is no longer supported', version: '3.0.0'},\n description: 'Reconfigure an existing project',\n hidden: true,\n }),\n template: Flags.string({\n description: 'Project template to use [default: \"clean\"]',\n exclusive: ['bare'],\n helpValue: '<template>',\n }),\n // Porting over a beta flag\n // Oclif doesn't seem to support something in beta so hiding for now\n 'template-token': Flags.string({\n description: 'Used for accessing private GitHub repo templates',\n hidden: true,\n }),\n typescript: Flags.boolean({\n allowNo: true,\n default: undefined,\n description: 'Enable TypeScript support',\n exclusive: ['bare'],\n }),\n visibility: Flags.string({\n description: 'Visibility mode for dataset',\n helpValue: '<mode>',\n options: ['public', 'private'],\n }),\n yes: Flags.boolean({\n char: 'y',\n default: false,\n description:\n 'Unattended mode, answers \"yes\" to any \"yes/no\" prompt and otherwise uses defaults',\n }),\n }\n\n public async run(): Promise<void> {\n const workDir = process.cwd()\n\n const createProjectName = this.flags['create-project']\n // For backwards \"compatibility\" - we used to allow `sanity init plugin`,\n // and no longer do - but instead of printing an error about an unknown\n // _command_, we want to acknowledge that the user is trying to do something\n // that no longer exists but might have at some point in the past.\n if (this.args.type) {\n this.error(\n this.args.type === 'plugin'\n ? 'Initializing plugins through the CLI is no longer supported'\n : `Unknown init type \"${this.args.type}\"`,\n {exit: 1},\n )\n }\n\n // @todo\n //const trace = telemetry.trace(CLIInitStepCompleted)\n\n // Slightly more helpful message for removed flags rather than just saying the flag\n // does not exist.\n if (this.flags.reconfigure) {\n this.error('--reconfigure is deprecated - manual configuration is now required', {exit: 1})\n }\n\n // Oclif doesn't support custom exclusive error messaging\n if (this.flags.project && this.flags.organization) {\n this.error(\n 'You have specified both a project and an organization. To move a project to an organization please visit https://www.sanity.io/manage',\n {exit: 1},\n )\n }\n\n const defaultConfig = this.flags['dataset-default']\n let showDefaultConfigPrompt = !defaultConfig\n if (\n this.flags.dataset ||\n this.flags.visibility ||\n this.flags['dataset-default'] ||\n this.isUnattended()\n ) {\n showDefaultConfigPrompt = false\n }\n\n const detectedFramework = await detectFrameworkRecord({\n frameworkList: frameworks as readonly Framework[],\n fs: new LocalFileSystemDetector(process.cwd()),\n })\n const isNextJs = detectedFramework?.slug === 'nextjs'\n\n let remoteTemplateInfo: RepoInfo | undefined\n if (this.flags.template && checkIsRemoteTemplate(this.flags.template)) {\n remoteTemplateInfo = await getGitHubRepoInfo(\n this.flags.template,\n this.flags['template-token'],\n )\n }\n\n if (detectedFramework && detectedFramework.slug !== 'sanity' && remoteTemplateInfo) {\n this.error(\n `A remote template cannot be used with a detected framework. Detected: ${detectedFramework.name}`,\n {exit: 1},\n )\n }\n\n // Checks flags are present when in unattended mode\n if (this.isUnattended()) {\n this.checkFlagsInUnattendedMode({createProjectName, isNextJs})\n }\n\n // @todo\n // trace.start()\n // trace.log({\n // step: 'start',\n // flags: {\n // defaultConfig,\n // unattended,\n // plan: intendedPlan,\n // coupon: intendedCoupon,\n // reconfigure,\n // git: commitMessage,\n // bare: bareOutput,\n // env,\n // },\n // })\n\n // Plan can be set through `--project-plan`, or implied through `--coupon`.\n // As coupons can expire and project plans might change/be removed, we need to\n // verify that the passed flags are valid. The complexity of this is hidden in the\n // below plan methods, eventually returning a plan ID or undefined if we are told to\n // use the default plan.\n\n const planId = await this.getPlan()\n\n let envFilenameDefault = '.env'\n if (detectedFramework && detectedFramework.slug === 'nextjs') {\n envFilenameDefault = '.env.local'\n }\n const envFilename = typeof this.flags.env === 'string' ? this.flags.env : envFilenameDefault\n\n // If the user isn't already autenticated, make it so\n const {user} = await this.ensureAuthenticated()\n\n const isAppTemplate = this.flags.template ? determineAppTemplate(this.flags.template) : false // Default to false\n if (!isAppTemplate) {\n this.log(`${logSymbols.success} Fetching existing projects`)\n this.log('')\n }\n\n let newProject: string | undefined\n if (createProjectName) {\n newProject = await this.createProjectFromName({createProjectName, planId, user})\n }\n\n const {datasetName, displayName, isFirstProject, organizationId, projectId} =\n await this.getProjectDetails({\n isAppTemplate,\n newProject,\n planId,\n showDefaultConfigPrompt,\n user,\n })\n\n // If user doesn't want to output any template code\n if (this.flags.bare) {\n this.log(`${logSymbols.success} Below are your project details`)\n this.log('')\n this.log(`Project ID: ${chalk.cyan(projectId)}`)\n this.log(`Dataset: ${chalk.cyan(datasetName)}`)\n this.log(\n `\\nYou can find your project on Sanity Manage — https://www.sanity.io/manage/project/${projectId}\\n`,\n )\n return\n }\n\n let initNext = this.flagOrDefault('nextjs-add-config-files', false)\n if (isNextJs && this.promptForUndefinedFlag(this.flags['nextjs-add-config-files'])) {\n initNext = await promptForConfigFiles()\n }\n\n // @todo\n // trace.log({\n // step: 'useDetectedFramework',\n // selectedOption: initNext ? 'yes' : 'no',\n // detectedFramework: detectedFramework?.name,\n // })\n\n const sluggedName = deburr(displayName.toLowerCase())\n .replaceAll(/\\s+/g, '-')\n .replaceAll(/[^a-z0-9-]/g, '')\n\n // add more frameworks to this as we add support for them\n // this is used to skip the getProjectInfo prompt\n const initFramework = initNext\n\n // Gather project defaults based on environment\n const defaults = await getProjectDefaults({isPlugin: false, workDir})\n\n // Prompt the user for required information\n const outputPath = await this.getProjectOutputPath({\n initFramework,\n sluggedName,\n workDir,\n })\n\n // Set up MCP integration\n const mcpResult = await setupMCP({mcp: this.flags.mcp, output: this.output})\n // @todo\n // trace.log({\n // step: 'mcpSetup',\n // detectedEditors: mcpResult.detectedEditors,\n // configuredEditors: mcpResult.configuredEditors,\n // skipped: mcpResult.skipped,\n // })\n // if (mcpResult.error) {\n // trace.error(mcpResult.error)\n // }\n const mcpConfigured = mcpResult.configuredEditors\n\n if (isNextJs) {\n await checkNextJsReactCompatibility({\n detectedFramework,\n output: this.output,\n outputPath,\n })\n }\n\n if (initNext) {\n await this.initNextJs({\n datasetName,\n detectedFramework,\n envFilename,\n mcpConfigured,\n projectId,\n workDir,\n })\n }\n\n // user wants to write environment variables to file\n if (this.flags.env) {\n await createOrAppendEnvVars({\n envVars: {\n DATASET: datasetName,\n PROJECT_ID: projectId,\n },\n filename: envFilename,\n framework: detectedFramework,\n log: false,\n output: this.output,\n outputPath,\n })\n this.exit(0)\n }\n\n // Prompt for template to use\n const templateName = await this.promptForTemplate()\n // @todo\n // trace.log({step: 'selectProjectTemplate', selectedOption: templateName})\n const template = templates[templateName]\n if (!remoteTemplateInfo && !template) {\n this.error(`Template \"${templateName}\" not found`, {exit: 1})\n }\n\n let useTypeScript = this.flags.typescript\n if (!remoteTemplateInfo && template && template.typescriptOnly === true) {\n useTypeScript = true\n } else if (this.promptForUndefinedFlag(this.flags.typescript)) {\n useTypeScript = await promptForTypeScript()\n // @todo\n // trace.log({step: 'useTypeScript', selectedOption: useTypeScript ? 'yes' : 'no'})\n }\n\n // If the template has a sample dataset, prompt the user whether or not we should import it\n const shouldImport =\n !this.isUnattended() &&\n template?.datasetUrl &&\n (await this.promptForDatasetImport(template.importPrompt))\n\n // @todo\n // trace.log({step: 'importTemplateDataset', selectedOption: shouldImport ? 'yes' : 'no'})\n\n try {\n await updateProjectInitializedAt(projectId)\n } catch (err) {\n // Non-critical update\n debug('Failed to update cliInitializedAt metadata', err)\n }\n\n try {\n await bootstrapTemplate({\n autoUpdates: this.flags['auto-updates'],\n bearerToken: this.flags['template-token'],\n dataset: datasetName,\n organizationId,\n output: this.output,\n outputPath,\n overwriteFiles: this.flags['overwrite-files'],\n packageName: sluggedName,\n projectId,\n projectName: displayName || defaults.projectName,\n remoteTemplateInfo,\n templateName,\n useTypeScript,\n })\n } catch (error) {\n if (error instanceof Error) {\n throw error\n }\n throw new Error(String(error))\n }\n\n const pkgManager = await resolvePackageManager({\n interactive: !this.isUnattended(),\n output: this.output,\n packageManager: this.flags['package-manager'] as PackageManager,\n targetDir: outputPath,\n })\n\n // @todo\n // trace.log({selectedOption: pkgManager, step: 'selectPackageManager', })\n\n // Now for the slow part... installing dependencies\n await installDeclaredPackages(outputPath, pkgManager, {output: this.output, workDir})\n\n const useGit = this.flags.git === undefined || Boolean(this.flags.git)\n const commitMessage = this.flags.git\n // Try initializing a git repository\n if (useGit) {\n tryGitInit(outputPath, typeof commitMessage === 'string' ? commitMessage : undefined)\n }\n\n // Prompt for dataset import (if a dataset is defined)\n if (shouldImport && template?.datasetUrl) {\n const token = await getCliToken()\n if (!token) {\n this.error('Authentication required to import dataset', {exit: 1})\n }\n await DatasetImportCommand.run(\n [template.datasetUrl, '--project', projectId, '--dataset', datasetName, '--token', token],\n {\n root: outputPath,\n },\n )\n\n this.log('')\n this.log('If you want to delete the imported data, use')\n this.log(` ${chalk.cyan(`npx sanity dataset delete ${datasetName}`)}`)\n this.log('and create a new clean dataset with')\n this.log(` ${chalk.cyan(`npx sanity dataset create <name>`)}\\n`)\n }\n\n const devCommandMap: Record<PackageManager, string> = {\n bun: 'bun dev',\n manual: 'npm run dev',\n npm: 'npm run dev',\n pnpm: 'pnpm dev',\n yarn: 'yarn dev',\n }\n const devCommand = devCommandMap[pkgManager]\n\n const isCurrentDir = outputPath === process.cwd()\n const goToProjectDir = `\\n(${chalk.cyan(`cd ${outputPath}`)} to navigate to your new project directory)`\n\n if (isAppTemplate) {\n //output for custom apps here\n this.log(\n `${logSymbols.success} ${chalk.green.bold('Success!')} Your custom app has been scaffolded.`,\n )\n if (!isCurrentDir) this.log(goToProjectDir)\n this.log(\n `\\n${chalk.bold('Next')}, configure the project(s) and dataset(s) your app should work with.`,\n )\n this.log('\\nGet started in `src/App.tsx`, or refer to our documentation for a walkthrough:')\n this.log(chalk.blue.underline('https://www.sanity.io/docs/app-sdk/sdk-configuration'))\n if (mcpConfigured && mcpConfigured.length > 0) {\n const message = await this.getPostInitMCPPrompt(mcpConfigured)\n this.log(`\\n${message}`)\n this.log(`\\nLearn more: ${chalk.cyan('https://mcp.sanity.io')}`)\n this.log(\n `\\nHave feedback? Tell us in the community: ${chalk.cyan('https://www.sanity.io/community/join')}`,\n )\n }\n this.log('\\n')\n this.log(`Other helpful commands:`)\n this.log(`npx sanity docs browse to open the documentation in a browser`)\n this.log(`npx sanity dev to start the development server for your app`)\n this.log(`npx sanity deploy to deploy your app`)\n } else {\n //output for Studios here\n this.log(`✅ ${chalk.green.bold('Success!')} Your Studio has been created.`)\n if (!isCurrentDir) this.log(goToProjectDir)\n this.log(\n `\\nGet started by running ${chalk.cyan(devCommand)} to launch your Studio's development server`,\n )\n if (mcpConfigured && mcpConfigured.length > 0) {\n const message = await this.getPostInitMCPPrompt(mcpConfigured)\n this.log(`\\n${message}`)\n this.log(`\\nLearn more: ${chalk.cyan('https://mcp.sanity.io')}`)\n this.log(\n `\\nHave feedback? Tell us in the community: ${chalk.cyan('https://www.sanity.io/community/join')}`,\n )\n }\n this.log('\\n')\n this.log(`Other helpful commands:`)\n this.log(`npx sanity docs browse to open the documentation in a browser`)\n this.log(`npx sanity manage to open the project settings in a browser`)\n this.log(`npx sanity help to explore the CLI manual`)\n }\n\n if (isFirstProject) {\n // @todo\n // trace.log({step: 'sendCommunityInvite', selectedOption: 'yes'})\n\n const DISCORD_INVITE_LINK = 'https://www.sanity.io/community/join'\n\n this.log(`\\nJoin the Sanity community: ${chalk.cyan(DISCORD_INVITE_LINK)}`)\n this.log('We look forward to seeing you there!\\n')\n }\n\n // @todo\n // trace.complete()\n }\n\n private checkFlagsInUnattendedMode({\n createProjectName,\n isNextJs,\n }: {\n createProjectName: string | undefined\n isNextJs: boolean\n }) {\n debug('Unattended mode, validating required options')\n\n if (!this.flags['dataset']) {\n this.error(`\\`--dataset\\` must be specified in unattended mode`, {exit: 1})\n }\n\n // output-path is required in unattended mode when not using nextjs\n if (!isNextJs && !this.flags['output-path']) {\n this.error(`\\`--output-path\\` must be specified in unattended mode`, {exit: 1})\n }\n\n if (!this.flags.project && !createProjectName) {\n this.error(\n '`--project <id>` or `--create-project <name>` must be specified in unattended mode',\n {exit: 1},\n )\n }\n\n if (createProjectName && !this.flags.organization) {\n this.error(\n '--create-project is not supported in unattended mode without an organization, please specify an organization with `--organization <id>`',\n {exit: 1},\n )\n }\n }\n\n private async createProjectFromName({\n createProjectName,\n planId,\n user,\n }: {\n createProjectName: string\n planId: string | undefined\n user: SanityOrgUser\n }) {\n debug('--create-project specified, creating a new project')\n\n let orgForCreateProjectFlag = this.flags.organization\n\n if (!orgForCreateProjectFlag) {\n debug('no organization specified, selecting one')\n const organizations = await listOrganizations()\n orgForCreateProjectFlag = await this.promptUserForOrganization({organizations, user})\n }\n\n debug('creating a new project')\n const createdProject = await createProject({\n displayName: createProjectName.trim(),\n metadata: {coupon: this.flags.coupon},\n organizationId: orgForCreateProjectFlag,\n subscription: planId ? {planId} : undefined,\n })\n\n debug('Project with ID %s created', createdProject.projectId)\n if (this.flags.dataset) {\n debug('--dataset specified, creating dataset (%s)', this.flags.dataset)\n const spin = spinner('Creating dataset').start()\n await createDatasetService({\n aclMode: this.flags.visibility as DatasetAclMode,\n datasetName: this.flags.dataset,\n projectId: createdProject.projectId,\n })\n spin.succeed()\n }\n\n return createdProject.projectId\n }\n\n // @todo do we actually need to be authenticated for init? check flags and determine.\n private async ensureAuthenticated(): Promise<{user: SanityOrgUser}> {\n let isAuthenticated = (await getCliToken()) !== undefined\n debug(isAuthenticated ? 'User already has a token' : 'User has no token')\n\n let user: SanityOrgUser | undefined\n if (isAuthenticated) {\n // It _appears_ we are authenticated, but the token might be invalid/expired,\n // so we need to verify that we can actually make an authenticated request.\n try {\n user = await getCliUser()\n } catch {\n // assume that any error means that the token is invalid\n isAuthenticated = false\n }\n }\n\n if (isAuthenticated) {\n // @todo telemetry\n // trace.log({ step: 'login', alreadyLoggedIn: true })\n } else {\n if (this.isUnattended()) {\n this.error('Must be logged in to run this command in unattended mode, run `sanity login`', {\n exit: 1,\n })\n }\n\n // @todo telemetry\n //trace.log({step: 'login'})\n\n // @todo trigger login action, then get and return user info\n await login({output: this.output})\n }\n\n user = await getCliUser()\n\n this.log(\n `${logSymbols.success} You are logged in as ${user.email} using ${getProviderName(user.provider)}`,\n )\n return {user}\n }\n\n private flagOrDefault(flag: keyof typeof this.flags, defaultValue: boolean): boolean {\n return typeof this.flags[flag] === 'boolean' ? this.flags[flag] : defaultValue\n }\n\n private async getOrCreateDataset(opts: {\n displayName: string\n projectId: string\n showDefaultConfigPrompt: boolean\n }): Promise<{datasetName: string; userAction: 'create' | 'none' | 'select'}> {\n const visibility = this.flags.visibility\n const dataset = this.flags.dataset\n let defaultConfig = this.flags['dataset-default']\n\n if (dataset && this.isUnattended()) {\n return {datasetName: dataset, userAction: 'none'}\n }\n\n const [datasets, projectFeatures] = await Promise.all([\n listDatasets(opts.projectId),\n getProjectFeatures(opts.projectId),\n ])\n\n if (dataset) {\n debug('User has specified dataset through a flag (%s)', dataset)\n const existing = datasets.find((ds) => ds.name === dataset)\n if (!existing) {\n debug('Specified dataset not found, creating it')\n await createDataset({\n datasetName: dataset,\n forcePublic: defaultConfig,\n output: this.output,\n projectFeatures,\n projectId: opts.projectId,\n visibility,\n })\n }\n\n return {datasetName: dataset, userAction: 'none'}\n }\n\n const datasetInfo =\n 'Your content will be stored in a dataset that can be public or private, depending on\\nwhether you want to query your content with or without authentication.\\nThe default dataset configuration has a public dataset named \"production\".'\n\n if (datasets.length === 0) {\n debug('No datasets found for project, prompting for name')\n if (opts.showDefaultConfigPrompt) {\n this.log(datasetInfo)\n defaultConfig = await this.promptForDefaultConfig()\n }\n const name = defaultConfig\n ? 'production'\n : await promptForDatasetName({\n message: 'Name of your first dataset:',\n })\n await createDataset({\n datasetName: name,\n forcePublic: defaultConfig,\n output: this.output,\n projectFeatures,\n projectId: opts.projectId,\n visibility,\n })\n return {datasetName: name, userAction: 'create'}\n }\n\n debug(`User has ${datasets.length} dataset(s) already, showing list of choices`)\n const datasetChoices = datasets.map((dataset) => ({value: dataset.name}))\n\n const selected = await select({\n choices: [{name: 'Create new dataset', value: 'new'}, new Separator(), ...datasetChoices],\n message: 'Select dataset to use',\n })\n\n if (selected === 'new') {\n const existingDatasetNames = datasets.map((ds) => ds.name)\n debug('User wants to create a new dataset, prompting for name')\n if (opts.showDefaultConfigPrompt && !existingDatasetNames.includes('production')) {\n this.log(datasetInfo)\n defaultConfig = await this.promptForDefaultConfig()\n }\n\n const newDatasetName = defaultConfig\n ? 'production'\n : await promptForDatasetName(\n {\n message: 'Dataset name:',\n },\n existingDatasetNames,\n )\n await createDataset({\n datasetName: newDatasetName,\n forcePublic: defaultConfig,\n output: this.output,\n projectFeatures,\n projectId: opts.projectId,\n visibility,\n })\n return {datasetName: newDatasetName, userAction: 'create'}\n }\n\n debug(`Returning selected dataset (${selected})`)\n return {datasetName: selected, userAction: 'select'}\n }\n\n private async getOrCreateProject({\n newProject,\n planId,\n user,\n }: {\n newProject: string | undefined\n planId: string | undefined\n user: SanityOrgUser\n }): Promise<{\n displayName: string\n isFirstProject: boolean\n projectId: string\n userAction: 'create' | 'select'\n }> {\n const projectId = this.flags.project || newProject\n const organizationId = this.flags.organization\n let projects\n let organizations: ProjectOrganization[]\n\n try {\n const [allProjects, allOrgs] = await Promise.all([listProjects(), listOrganizations()])\n projects = allProjects.toSorted((a, b) => b.createdAt.localeCompare(a.createdAt))\n organizations = allOrgs\n } catch (err) {\n if (this.isUnattended() && projectId) {\n return {\n displayName: 'Unknown project',\n isFirstProject: false,\n projectId,\n userAction: 'select',\n }\n }\n this.error(`Failed to communicate with the Sanity API:\\n${err.message}`, {exit: 1})\n }\n\n if (projects.length === 0 && this.isUnattended()) {\n this.error('No projects found for current user', {exit: 1})\n }\n\n if (projectId) {\n const project = projects.find((proj) => proj.id === projectId)\n if (!project && !this.isUnattended()) {\n this.error(`Given project ID (${projectId}) not found, or you do not have access to it`, {\n exit: 1,\n })\n }\n\n return {\n displayName: project ? project.displayName : 'Unknown project',\n isFirstProject: false,\n projectId,\n userAction: 'select',\n }\n }\n\n if (organizationId) {\n const organization =\n organizations.find((org) => org.id === organizationId) ||\n organizations.find((org) => org.slug === organizationId)\n\n if (!organization) {\n this.error(\n `Given organization ID (${organizationId}) not found, or you do not have access to it`,\n {exit: 1},\n )\n }\n\n if (!(await hasProjectAttachGrant(organizationId))) {\n this.error('You lack the necessary permissions to attach a project to this organization', {\n exit: 1,\n })\n }\n }\n\n // If the user has no projects or is using a coupon (which can only be applied to new projects)\n // just ask for project details instead of showing a list of projects\n const isUsersFirstProject = projects.length === 0\n if (isUsersFirstProject || this.flags.coupon) {\n debug(\n isUsersFirstProject\n ? 'No projects found for user, prompting for name'\n : 'Using a coupon - skipping project selection',\n )\n\n const newProject = await this.promptForProjectCreation({\n isUsersFirstProject,\n organizationId,\n organizations,\n planId,\n user,\n })\n\n return {\n ...newProject,\n isFirstProject: isUsersFirstProject,\n userAction: 'create',\n }\n }\n\n debug(`User has ${projects.length} project(s) already, showing list of choices`)\n\n const projectChoices = projects.map((project) => ({\n name: `${project.displayName} (${project.id})`,\n value: project.id,\n }))\n\n const selected = await select({\n choices: [{name: 'Create new project', value: 'new'}, new Separator(), ...projectChoices],\n message: 'Create a new project or select an existing one',\n })\n\n if (selected === 'new') {\n debug('User wants to create a new project, prompting for name')\n\n const newProject = await this.promptForProjectCreation({\n isUsersFirstProject,\n organizationId,\n organizations,\n planId,\n user,\n })\n\n return {\n ...newProject,\n isFirstProject: isUsersFirstProject,\n userAction: 'create',\n }\n }\n\n debug(`Returning selected project (${selected})`)\n return {\n displayName: projects.find((proj) => proj.id === selected)?.displayName || '',\n isFirstProject: isUsersFirstProject,\n projectId: selected,\n userAction: 'select',\n }\n }\n\n private async getPlan(): Promise<string | undefined> {\n const intendedPlan = this.flags['project-plan']\n const intendedCoupon = this.flags.coupon\n\n if (intendedCoupon) {\n return this.verifyCoupon(intendedCoupon)\n } else if (intendedPlan) {\n return this.verifyPlan(intendedPlan)\n } else {\n return undefined\n }\n }\n\n private async getPostInitMCPPrompt(editorsNames: EditorName[]): Promise<string> {\n return fetchPostInitPrompt(new Intl.ListFormat('en').format(editorsNames))\n }\n\n private async getProjectDetails({\n isAppTemplate,\n newProject,\n planId,\n showDefaultConfigPrompt,\n user,\n }: {\n isAppTemplate: boolean\n newProject: string | undefined\n planId: string | undefined\n showDefaultConfigPrompt: boolean\n user: SanityOrgUser\n }): Promise<{\n datasetName: string\n displayName: string\n isFirstProject: boolean\n organizationId?: string\n projectId: string\n schemaUrl?: string\n }> {\n if (isAppTemplate) {\n const organizations = await listOrganizations({\n includeImplicitMemberships: 'true',\n includeMembers: 'true',\n })\n\n const appOrganizationId = await this.promptUserForOrganization({organizations, user})\n\n return {\n datasetName: '',\n displayName: '',\n isFirstProject: false,\n organizationId: appOrganizationId,\n projectId: '',\n }\n }\n\n debug('Prompting user to select or create a project')\n const project = await this.getOrCreateProject({newProject, planId, user})\n debug(`Project with name ${project.displayName} selected`)\n\n // Now let's pick or create a dataset\n debug('Prompting user to select or create a dataset')\n const dataset = await this.getOrCreateDataset({\n displayName: project.displayName,\n projectId: project.projectId,\n showDefaultConfigPrompt,\n })\n debug(`Dataset with name ${dataset.datasetName} selected`)\n\n // @todo\n // trace.log({\n // step: 'createOrSelectDataset',\n // selectedOption: dataset.userAction,\n // datasetName: dataset.datasetName,\n // visibility: flags.visibility as 'private' | 'public',\n // })\n\n return {\n datasetName: dataset.datasetName,\n displayName: project.displayName,\n isFirstProject: project.isFirstProject,\n projectId: project.projectId,\n }\n }\n\n private async getProjectOutputPath({\n initFramework,\n sluggedName,\n workDir,\n }: {\n initFramework: boolean\n sluggedName: string\n workDir: string\n }): Promise<string> {\n const outputPath = this.flags['output-path']\n const specifiedPath = outputPath && path.resolve(outputPath)\n if (this.isUnattended() || specifiedPath || this.flags.env || initFramework) {\n return specifiedPath || workDir\n }\n\n const inputPath = await input({\n default: path.join(workDir, sluggedName),\n message: 'Project output path:',\n validate: validateEmptyPath,\n })\n\n return absolutify(inputPath)\n }\n\n private async initNextJs({\n datasetName,\n detectedFramework,\n envFilename,\n mcpConfigured,\n projectId,\n workDir,\n }: {\n datasetName: string\n detectedFramework: VersionedFramework | null\n envFilename: string\n mcpConfigured: EditorName[]\n projectId: string\n workDir: string\n }) {\n let useTypeScript = this.flagOrDefault('typescript', true)\n if (this.promptForUndefinedFlag(this.flags.typescript)) {\n useTypeScript = await promptForTypeScript()\n }\n // @todo\n // trace.log({step: 'useTypeScript', selectedOption: useTypeScript ? 'yes' : 'no'})\n\n const fileExtension = useTypeScript ? 'ts' : 'js'\n let embeddedStudio = this.flagOrDefault('nextjs-embed-studio', true)\n if (this.promptForUndefinedFlag(this.flags['nextjs-embed-studio'])) {\n embeddedStudio = await promptForEmbeddedStudio()\n }\n let hasSrcFolder = false\n\n if (embeddedStudio) {\n // find source path (app or src/app)\n const appDir = 'app'\n let srcPath = path.join(workDir, appDir)\n\n if (!existsSync(srcPath)) {\n srcPath = path.join(workDir, 'src', appDir)\n hasSrcFolder = true\n if (!existsSync(srcPath)) {\n try {\n await mkdir(srcPath, {recursive: true})\n } catch {\n debug('Error creating folder %s', srcPath)\n }\n }\n }\n\n const studioPath = this.isUnattended() ? '/studio' : await promptForStudioPath()\n\n const embeddedStudioRouteFilePath = path.join(\n srcPath,\n `${studioPath}/`,\n `[[...tool]]/page.${fileExtension}x`,\n )\n\n // this selects the correct template string based on whether the user is using the app or pages directory and\n // replaces the \":configPath:\" placeholder in the template with the correct path to the sanity.config.ts file.\n // we account for the user-defined embeddedStudioPath (default /studio) is accounted for by creating enough \"../\"\n // relative paths to reach the root level of the project\n await this.writeOrOverwrite(\n embeddedStudioRouteFilePath,\n sanityStudioTemplate.replace(\n ':configPath:',\n `${'../'.repeat(countNestedFolders(embeddedStudioRouteFilePath.slice(workDir.length)))}sanity.config`,\n ),\n workDir,\n )\n\n const sanityConfigPath = path.join(workDir, `sanity.config.${fileExtension}`)\n await this.writeOrOverwrite(\n sanityConfigPath,\n sanityConfigTemplate(hasSrcFolder)\n .replace(':route:', embeddedStudioRouteFilePath.slice(workDir.length).replace('src/', ''))\n .replace(':basePath:', studioPath),\n workDir,\n )\n }\n\n const sanityCliPath = path.join(workDir, `sanity.cli.${fileExtension}`)\n await this.writeOrOverwrite(sanityCliPath, sanityCliTemplate, workDir)\n\n let templateToUse = this.flags.template ?? 'clean'\n if (this.promptForUndefinedFlag(this.flags.template)) {\n templateToUse = await promptForNextTemplate()\n }\n\n await this.writeSourceFiles({\n fileExtension,\n files: sanityFolder(useTypeScript, templateToUse as 'blog' | 'clean'),\n folderPath: undefined,\n srcFolderPrefix: hasSrcFolder,\n workDir,\n })\n\n let appendEnv = this.flagOrDefault('nextjs-append-env', true)\n if (this.promptForUndefinedFlag(this.flags['nextjs-append-env'])) {\n appendEnv = await promptForAppendEnv(envFilename)\n }\n\n if (appendEnv) {\n await createOrAppendEnvVars({\n envVars: {\n DATASET: datasetName,\n PROJECT_ID: projectId,\n },\n filename: envFilename,\n framework: detectedFramework,\n log: true,\n output: this.output,\n outputPath: workDir,\n })\n }\n\n if (embeddedStudio) {\n const nextjsLocalDevOrigin = 'http://localhost:3000'\n const existingCorsOrigins = await listCorsOrigins(projectId)\n const hasExistingCorsOrigin = existingCorsOrigins.some(\n (item: {origin: string}) => item.origin === nextjsLocalDevOrigin,\n )\n if (!hasExistingCorsOrigin) {\n try {\n const createCorsRes = await createCorsOrigin({\n allowCredentials: true,\n origin: nextjsLocalDevOrigin,\n projectId,\n })\n\n this.log(\n createCorsRes.id\n ? `Added ${nextjsLocalDevOrigin} to CORS origins`\n : `Failed to add ${nextjsLocalDevOrigin} to CORS origins`,\n )\n } catch (error) {\n debug(`Error creating new CORS Origin ${nextjsLocalDevOrigin}: ${error}`)\n this.error(`Failed to add ${nextjsLocalDevOrigin} to CORS origins: ${error}`, {exit: 1})\n }\n }\n }\n\n const chosen = await resolvePackageManager({\n interactive: !this.isUnattended(),\n output: this.output,\n packageManager: this.flags['package-manager'] as PackageManager,\n targetDir: workDir,\n })\n // @todo\n // trace.log({step: 'selectPackageManager', selectedOption: chosen})\n const packages = ['@sanity/vision@4', 'sanity@4', '@sanity/image-url@1', 'styled-components@6']\n if (templateToUse === 'blog') {\n packages.push('@sanity/icons')\n }\n await installNewPackages(\n {\n packageManager: chosen,\n packages,\n },\n {\n output: this.output,\n workDir,\n },\n )\n\n // will refactor this later\n const execOptions: Options = {\n cwd: workDir,\n encoding: 'utf8',\n env: getPartialEnvWithNpmPath(workDir),\n stdio: 'inherit',\n }\n\n switch (chosen) {\n case 'npm': {\n await execa('npm', ['install', '--legacy-peer-deps', 'next-sanity@11'], execOptions)\n break\n }\n case 'pnpm': {\n await execa('pnpm', ['install', 'next-sanity@11'], execOptions)\n break\n }\n case 'yarn': {\n await execa('npx', ['install-peerdeps', '--yarn', 'next-sanity@11'], execOptions)\n break\n }\n default: {\n // bun and manual - do nothing or handle differently\n break\n }\n }\n\n this.log(\n `\\n${chalk.green('Success!')} Your Sanity configuration files has been added to this project`,\n )\n if (mcpConfigured && mcpConfigured.length > 0) {\n const message = await this.getPostInitMCPPrompt(mcpConfigured)\n this.log(`\\n${message}`)\n this.log(`\\nLearn more: ${chalk.cyan('https://mcp.sanity.io')}`)\n this.log(\n `\\nHave feedback? Tell us in the community: ${chalk.cyan('https://www.sanity.io/community/join')}`,\n )\n }\n\n this.exit(0)\n }\n\n private async promptForDatasetImport(message?: string) {\n return confirm({\n default: true,\n message: message || 'This template includes a sample dataset, would you like to use it?',\n })\n }\n\n private async promptForDefaultConfig(): Promise<boolean> {\n return confirm({\n default: true,\n message: 'Use the default dataset configuration?',\n })\n }\n\n private async promptForProjectCreation({\n isUsersFirstProject,\n organizationId,\n organizations,\n planId,\n user,\n }: {\n isUsersFirstProject: boolean\n organizationId: string | undefined\n organizations: ProjectOrganization[]\n planId: string | undefined\n user: SanityOrgUser\n }) {\n const projectName = await input({\n default: 'My Sanity Project',\n message: 'Project name:',\n validate(input) {\n if (!input || input.trim() === '') {\n return 'Project name cannot be empty'\n }\n\n if (input.length > 80) {\n return 'Project name cannot be longer than 80 characters'\n }\n\n return true\n },\n })\n\n const organization =\n organizationId || (await this.promptUserForOrganization({organizations, user}))\n\n const newProject = await createProject({\n displayName: projectName,\n metadata: {coupon: this.flags.coupon},\n organizationId: organization,\n subscription: planId ? {planId} : undefined,\n })\n\n return {\n ...newProject,\n isFirstProject: isUsersFirstProject,\n userAction: 'create',\n }\n }\n\n private async promptForTemplate() {\n const template = this.flags.template\n\n const defaultTemplate = this.isUnattended() || template ? template || 'clean' : null\n if (defaultTemplate) {\n return defaultTemplate\n }\n\n return select({\n choices: [\n {\n name: 'Clean project with no predefined schema types',\n value: 'clean',\n },\n {\n name: 'Blog (schema)',\n value: 'blog',\n },\n {\n name: 'E-commerce (Shopify)',\n value: 'shopify',\n },\n {\n name: 'Movie project (schema + sample data)',\n value: 'moviedb',\n },\n ],\n message: 'Select project template',\n })\n }\n\n private promptForUndefinedFlag(flag: unknown) {\n return !this.isUnattended() && flag === undefined\n }\n\n private async promptUserForNewOrganization(\n user: SanityOrgUser,\n ): Promise<OrganizationCreateResponse> {\n const name = await input({\n default: user ? user.name : undefined,\n message: 'Organization name:',\n validate(input) {\n if (input.length === 0) {\n return 'Organization name cannot be empty'\n } else if (input.length > 100) {\n return 'Organization name cannot be longer than 100 characters'\n }\n return true\n },\n })\n\n const spin = spinner('Creating organization').start()\n const organization = await createOrganization(name)\n spin.succeed()\n\n return organization\n }\n\n private async promptUserForOrganization({\n organizations,\n user,\n }: {\n organizations: ProjectOrganization[]\n user: SanityOrgUser\n }) {\n // If the user has no organizations, prompt them to create one with the same name as\n // their user, but allow them to customize it if they want\n if (organizations.length === 0) {\n const newOrganization = await this.promptUserForNewOrganization(user)\n return newOrganization.id\n }\n\n // If the user has organizations, let them choose from them, but also allow them to\n // create a new one in case they do not have access to any of them, or they want to\n // create a personal/other organization.\n debug(`User has ${organizations.length} organization(s), checking attach access`)\n const withGrantInfo = await getOrganizationsWithAttachGrantInfo(organizations)\n const withAttach = withGrantInfo.filter(({hasAttachGrant}) => hasAttachGrant)\n\n debug('User has attach access to %d organizations.', withAttach.length)\n const organizationChoices = getOrganizationChoices(withAttach)\n\n // If the user only has a single organization (and they have attach access to it),\n // we'll default to that one. Otherwise, we'll default to the organization with the\n // same name as the user if it exists.\n const defaultOrganizationId =\n withAttach.length === 1\n ? withAttach[0].organization.id\n : organizations.find((org) => org.name === user?.name)?.id\n\n const chosenOrg = await select({\n choices: organizationChoices,\n default: defaultOrganizationId || undefined,\n message: 'Select organization:',\n })\n\n if (chosenOrg === '-new-') {\n const newOrganization = await this.promptUserForNewOrganization(user)\n return newOrganization.id\n }\n\n return chosenOrg || undefined\n }\n\n private async verifyCoupon(intendedCoupon: string): Promise<string | undefined> {\n try {\n const planId = await getPlanIdFromCoupon(intendedCoupon)\n this.log(`Coupon \"${intendedCoupon}\" validated!\\n`)\n return planId\n } catch (err: unknown) {\n if (!isHttpError(err) || err.statusCode !== 404) {\n const message = err instanceof Error ? err.message : `${err}`\n this.error(`Unable to validate coupon, please try again later:\\n\\n${message}`, {exit: 1})\n }\n\n const useDefaultPlan =\n this.isUnattended() ||\n (await confirm({\n default: true,\n message: `Coupon \"${intendedCoupon}\" is not available, use default plan instead?`,\n }))\n\n if (this.isUnattended()) {\n this.warn(`Coupon \"${intendedCoupon}\" is not available - using default plan`)\n }\n\n // @todo\n // trace.log({\n // step: 'useDefaultPlanCoupon',\n // selectedOption: useDefaultPlan ? 'yes' : 'no',\n // coupon: intendedCoupon,\n // })\n\n if (useDefaultPlan) {\n this.log('Using default plan.')\n } else {\n this.error(`Coupon \"${intendedCoupon}\" does not exist`, {exit: 1})\n }\n }\n }\n\n private async verifyPlan(intendedPlan: string): Promise<string | undefined> {\n try {\n const planId = await getPlanId(intendedPlan)\n return planId\n } catch (err: unknown) {\n if (!isHttpError(err) || err.statusCode !== 404) {\n const message = err instanceof Error ? err.message : `${err}`\n this.error(`Unable to validate plan, please try again later:\\n\\n${message}`, {exit: 1})\n }\n\n const useDefaultPlan =\n this.isUnattended() ||\n (await confirm({\n default: true,\n message: `Project plan \"${intendedPlan}\" does not exist, use default plan instead?`,\n }))\n\n if (this.isUnattended()) {\n this.warn(`Project plan \"${intendedPlan}\" does not exist - using default plan`)\n }\n\n // @todo\n // trace.log({\n // step: 'useDefaultPlanId',\n // selectedOption: useDefaultPlan ? 'yes' : 'no',\n // planId: intendedPlan,\n // })\n\n if (useDefaultPlan) {\n this.log('Using default plan.')\n } else {\n this.error(`Plan id \"${intendedPlan}\" does not exist`, {exit: 1})\n }\n }\n }\n\n private async writeOrOverwrite(filePath: string, content: string, workDir: string) {\n if (existsSync(filePath)) {\n let overwrite = this.flagOrDefault('overwrite-files', false)\n if (this.promptForUndefinedFlag(this.flags['overwrite-files'])) {\n overwrite = await confirm({\n default: false,\n message: `File ${chalk.yellow(\n filePath.replace(workDir, ''),\n )} already exists. Do you want to overwrite it?`,\n })\n }\n\n if (!overwrite) {\n return\n }\n }\n\n // make folder if not exists\n const folderPath = path.dirname(filePath)\n\n try {\n await mkdir(folderPath, {recursive: true})\n } catch {\n debug('Error creating folder %s', folderPath)\n }\n\n await writeFile(filePath, content, {\n encoding: 'utf8',\n })\n }\n\n // write sanity folder files\n private async writeSourceFiles({\n fileExtension,\n files,\n folderPath,\n srcFolderPrefix,\n workDir,\n }: {\n fileExtension: string\n files: Record<string, Record<string, string> | string>\n folderPath?: string\n srcFolderPrefix?: boolean\n workDir: string\n }) {\n for (const [filePath, content] of Object.entries(files)) {\n // check if file ends with full stop to indicate it's file and not directory (this only works with our template tree structure)\n if (filePath.includes('.') && typeof content === 'string') {\n await this.writeOrOverwrite(\n path.join(\n workDir,\n srcFolderPrefix ? 'src' : '',\n 'sanity',\n folderPath || '',\n `${filePath}${fileExtension}`,\n ),\n content,\n workDir,\n )\n } else {\n await mkdir(path.join(workDir, srcFolderPrefix ? 'src' : '', 'sanity', filePath), {\n recursive: true,\n })\n if (typeof content === 'object') {\n await this.writeSourceFiles({\n fileExtension,\n files: content,\n folderPath: filePath,\n srcFolderPrefix,\n workDir,\n })\n }\n }\n }\n }\n}\n"],"names":["existsSync","mkdir","writeFile","path","Args","Flags","CLIError","getCliToken","SanityCommand","subdebug","chalk","confirm","input","logSymbols","select","Separator","spinner","isHttpError","DatasetImportCommand","frameworks","detectFrameworkRecord","LocalFileSystemDetector","execa","deburr","getProviderName","login","createDataset","bootstrapTemplate","checkNextJsReactCompatibility","countNestedFolders","determineAppTemplate","createOrAppendEnvVars","fetchPostInitPrompt","tryGitInit","checkIsRemoteTemplate","getGitHubRepoInfo","resolvePackageManager","setupMCP","templates","sanityCliTemplate","sanityConfigTemplate","sanityFolder","sanityStudioTemplate","getOrganizationChoices","getOrganizationsWithAttachGrantInfo","hasProjectAttachGrant","promptForAppendEnv","promptForConfigFiles","promptForEmbeddedStudio","promptForNextTemplate","promptForStudioPath","promptForTypeScript","promptForDatasetName","createCorsOrigin","listCorsOrigins","createDatasetService","listDatasets","getProjectFeatures","createOrganization","listOrganizations","getPlanId","getPlanIdFromCoupon","createProject","listProjects","updateProjectInitializedAt","getCliUser","absolutify","validateEmptyPath","getProjectDefaults","installDeclaredPackages","installNewPackages","getPartialEnvWithNpmPath","debug","InitCommand","args","type","string","hidden","description","enableJsonFlag","examples","command","flags","boolean","allowNo","default","exclusive","bare","coupon","helpValue","dataset","env","parse","startsWith","git","undefined","helpLabel","mcp","helpGroup","organization","options","project","aliases","provider","quickstart","deprecated","reconfigure","message","version","template","typescript","visibility","yes","char","run","workDir","process","cwd","createProjectName","error","exit","defaultConfig","showDefaultConfigPrompt","isUnattended","detectedFramework","frameworkList","fs","isNextJs","slug","remoteTemplateInfo","name","checkFlagsInUnattendedMode","planId","getPlan","envFilenameDefault","envFilename","user","ensureAuthenticated","isAppTemplate","log","success","newProject","createProjectFromName","datasetName","displayName","isFirstProject","organizationId","projectId","getProjectDetails","cyan","initNext","flagOrDefault","promptForUndefinedFlag","sluggedName","toLowerCase","replaceAll","initFramework","defaults","isPlugin","outputPath","getProjectOutputPath","mcpResult","output","mcpConfigured","configuredEditors","initNextJs","envVars","DATASET","PROJECT_ID","filename","framework","templateName","promptForTemplate","useTypeScript","typescriptOnly","shouldImport","datasetUrl","promptForDatasetImport","importPrompt","err","autoUpdates","bearerToken","overwriteFiles","packageName","projectName","Error","String","pkgManager","interactive","packageManager","targetDir","useGit","Boolean","commitMessage","token","root","devCommandMap","bun","manual","npm","pnpm","yarn","devCommand","isCurrentDir","goToProjectDir","green","bold","blue","underline","length","getPostInitMCPPrompt","DISCORD_INVITE_LINK","orgForCreateProjectFlag","organizations","promptUserForOrganization","createdProject","trim","metadata","subscription","spin","start","aclMode","succeed","isAuthenticated","email","flag","defaultValue","getOrCreateDataset","opts","userAction","datasets","projectFeatures","Promise","all","existing","find","ds","forcePublic","datasetInfo","promptForDefaultConfig","datasetChoices","map","value","selected","choices","existingDatasetNames","includes","newDatasetName","getOrCreateProject","projects","allProjects","allOrgs","toSorted","a","b","createdAt","localeCompare","proj","id","org","isUsersFirstProject","promptForProjectCreation","projectChoices","intendedPlan","intendedCoupon","verifyCoupon","verifyPlan","editorsNames","Intl","ListFormat","format","includeImplicitMemberships","includeMembers","appOrganizationId","specifiedPath","resolve","inputPath","join","validate","fileExtension","embeddedStudio","hasSrcFolder","appDir","srcPath","recursive","studioPath","embeddedStudioRouteFilePath","writeOrOverwrite","replace","repeat","slice","sanityConfigPath","sanityCliPath","templateToUse","writeSourceFiles","files","folderPath","srcFolderPrefix","appendEnv","nextjsLocalDevOrigin","existingCorsOrigins","hasExistingCorsOrigin","some","item","origin","createCorsRes","allowCredentials","chosen","packages","push","execOptions","encoding","stdio","defaultTemplate","promptUserForNewOrganization","newOrganization","withGrantInfo","withAttach","filter","hasAttachGrant","organizationChoices","defaultOrganizationId","chosenOrg","statusCode","useDefaultPlan","warn","filePath","content","overwrite","yellow","dirname","Object","entries"],"mappings":"AAAA,kEAAkE;AAClE,SAAQA,UAAU,QAAO,UAAS;AAClC,SAAQC,KAAK,EAAEC,SAAS,QAAO,mBAAkB;AACjD,OAAOC,UAAU,YAAW;AAE5B,SAAQC,IAAI,EAAWC,KAAK,QAAO,cAAa;AAChD,SAAQC,QAAQ,QAAO,qBAAoB;AAC3C,SAAQC,WAAW,EAAEC,aAAa,EAAsBC,QAAQ,QAAO,mBAAkB;AACzF,SAAQC,KAAK,EAAEC,OAAO,EAAEC,KAAK,EAAEC,UAAU,EAAEC,MAAM,EAAEC,SAAS,EAAEC,OAAO,QAAO,sBAAqB;AACjG,SAA6BC,WAAW,QAAO,iBAAgB;AAC/D,SAAQC,oBAAoB,QAAO,iBAAgB;AACnD,SAAwBC,UAAU,QAAO,qBAAoB;AAC7D,SAAQC,qBAAqB,EAAEC,uBAAuB,QAAO,uBAAsB;AACnF,SAAQC,KAAK,QAAqB,QAAO;AACzC,SAAQC,MAAM,QAAO,YAAW;AAEhC,SAAQC,eAAe,QAAO,qCAAoC;AAClE,SAAQC,KAAK,QAAO,iCAAgC;AACpD,SAAQC,aAAa,QAAO,+BAA8B;AAC1D,SAAQC,iBAAiB,QAAO,uCAAsC;AACtE,SAAQC,6BAA6B,QAAO,mDAAkD;AAC9F,SAAQC,kBAAkB,QAAO,wCAAuC;AACxE,SAAQC,oBAAoB,QAAO,0CAAyC;AAC5E,SAAQC,qBAAqB,QAAO,+CAA8C;AAClF,SAAQC,mBAAmB,QAAO,yCAAwC;AAC1E,SAAQC,UAAU,QAAO,yBAAwB;AACjD,SACEC,qBAAqB,EACrBC,iBAAiB,QAEZ,oCAAmC;AAC1C,SAAQC,qBAAqB,QAAO,2CAA0C;AAC9E,SAAyBC,QAAQ,QAAO,8BAA6B;AACrE,OAAOC,eAAe,qCAAoC;AAC1D,SACEC,iBAAiB,EACjBC,oBAAoB,EACpBC,YAAY,EACZC,oBAAoB,QACf,4CAA2C;AAElD,SAAQC,sBAAsB,QAAO,qDAAoD;AACzF,SAAQC,mCAAmC,QAAO,kEAAiE;AACnH,SAAQC,qBAAqB,QAAO,oDAAmD;AACvF,SACEC,kBAAkB,EAClBC,oBAAoB,EACpBC,uBAAuB,EACvBC,qBAAqB,EACrBC,mBAAmB,QACd,4BAA2B;AAClC,SAAQC,mBAAmB,QAAO,yCAAwC;AAC1E,SAAQC,oBAAoB,QAAO,qCAAoC;AACvE,SAAQC,gBAAgB,EAAEC,eAAe,QAAO,sBAAqB;AACrE,SAAQ5B,iBAAiB6B,oBAAoB,EAAEC,YAAY,QAAO,0BAAyB;AAC3F,SAAQC,kBAAkB,QAAO,oCAAmC;AACpE,SACEC,kBAAkB,EAClBC,iBAAiB,QAGZ,+BAA8B;AACrC,SAAQC,SAAS,EAAEC,mBAAmB,QAAO,uBAAsB;AACnE,SAAQC,aAAa,EAAEC,YAAY,EAAEC,0BAA0B,QAAO,0BAAyB;AAC/F,SAAQC,UAAU,QAAO,sBAAqB;AAC9C,SAAQC,UAAU,EAAEC,iBAAiB,QAAO,qBAAoB;AAChE,SAAQC,kBAAkB,QAAO,gCAA+B;AAChE,SACEC,uBAAuB,EACvBC,kBAAkB,QACb,4CAA2C;AAClD,SACEC,wBAAwB,QAEnB,iDAAgD;AAEvD,MAAMC,QAAQ/D,SAAS;AAEvB,OAAO,MAAMgE,oBAAoBjE;IAC/B,OAAgBkE,OAAO;QAACC,MAAMvE,KAAKwE,MAAM,CAAC;YAACC,QAAQ;QAAI;IAAE,EAAC;IAC1D,OAAgBC,cAAc,qDAAoD;IAClF,OAAgBC,iBAAiB,KAAI;IAErC,OAAgBC,WAAW;QACzB;QACA;YACEC,SAAS;YACTH,aAAa;QACf;QACA;YACEG,SACE;YACFH,aAAa;QACf;QACA;YACEG,SACE;YACFH,aACE;QACJ;QACA;YACEG,SACE;YACFH,aAAa;QACf;KACD,CAAiC;IAElC,OAAgBI,QAAQ;QACtB,gBAAgB7E,MAAM8E,OAAO,CAAC;YAC5BC,SAAS;YACTC,SAAS;YACTP,aAAa;YACbQ,WAAW;gBAAC;aAAO;QACrB;QACAC,MAAMlF,MAAM8E,OAAO,CAAC;YAClBL,aACE;QACJ;QACAU,QAAQnF,MAAMuE,MAAM,CAAC;YACnBE,aACE;YACFQ,WAAW;gBAAC;aAAe;YAC3BG,WAAW;QACb;QACA,kBAAkBpF,MAAMuE,MAAM,CAAC;YAC7BE,aAAa;YACbW,WAAW;QACb;QACAC,SAASrF,MAAMuE,MAAM,CAAC;YACpBE,aAAa;YACbQ,WAAW;gBAAC;aAAkB;YAC9BG,WAAW;QACb;QACA,mBAAmBpF,MAAM8E,OAAO,CAAC;YAC/BL,aAAa;QACf;QACAa,KAAKtF,MAAMuE,MAAM,CAAC;YAChBE,aAAa;YACbQ,WAAW;gBAAC;aAAO;YACnBG,WAAW;YACXG,OAAO,OAAOhF;gBACZ,IAAI,CAACA,MAAMiF,UAAU,CAAC,SAAS;oBAC7B,MAAM,IAAIvF,SAAS;gBACrB;gBACA,OAAOM;YACT;QACF;QACA,eAAeP,MAAM8E,OAAO,CAAC;YAC3BL,aAAa;YACbD,QAAQ;QACV;QACAiB,KAAKzF,MAAMuE,MAAM,CAAC;YAChBS,SAASU;YACTjB,aAAa;YACbQ,WAAW;gBAAC;aAAO;YACnB,gFAAgF;YAChFU,WAAW;YACXP,WAAW;QACb;QACAQ,KAAK5F,MAAM8E,OAAO,CAAC;YACjBC,SAAS;YACTC,SAAS;YACTP,aAAa;QACf;QACA,2BAA2BzE,MAAM8E,OAAO,CAAC;YACvCC,SAAS;YACTC,SAASU;YACTjB,aAAa;YACboB,WAAW;QACb;QACA,qBAAqB7F,MAAM8E,OAAO,CAAC;YACjCC,SAAS;YACTC,SAASU;YACTjB,aAAa;YACboB,WAAW;QACb;QACA,uBAAuB7F,MAAM8E,OAAO,CAAC;YACnCC,SAAS;YACTC,SAASU;YACTjB,aAAa;YACboB,WAAW;QACb;QACA,8EAA8E;QAC9E,iFAAiF;QACjF,uDAAuD;QACvD,UAAU7F,MAAM8E,OAAO,CAAC;YACtBL,aAAa;YACbQ,WAAW;gBAAC;aAAM;YAClBT,QAAQ;QACV;QACAsB,cAAc9F,MAAMuE,MAAM,CAAC;YACzBE,aAAa;YACbW,WAAW;QACb;QACA,eAAepF,MAAMuE,MAAM,CAAC;YAC1BE,aAAa;YACbQ,WAAW;gBAAC;aAAO;YACnBG,WAAW;QACb;QACA,mBAAmBpF,MAAM8E,OAAO,CAAC;YAC/BC,SAAS;YACTC,SAASU;YACTjB,aAAa;QACf;QACA,mBAAmBzE,MAAMuE,MAAM,CAAC;YAC9BE,aAAa;YACbQ,WAAW;gBAAC;aAAO;YACnBG,WAAW;YACXW,SAAS;gBAAC;gBAAO;gBAAQ;aAAO;QAClC;QACAC,SAAShG,MAAMuE,MAAM,CAAC;YACpB0B,SAAS;gBAAC;aAAa;YACvBxB,aAAa;YACbQ,WAAW;gBAAC;aAAiB;YAC7BG,WAAW;QACb;QACA,gBAAgBpF,MAAMuE,MAAM,CAAC;YAC3BE,aAAa;YACbW,WAAW;QACb;QACAc,UAAUlG,MAAMuE,MAAM,CAAC;YACrBE,aAAa;YACbW,WAAW;QACb;QACAe,YAAYnG,MAAM8E,OAAO,CAAC;YACxBsB,YAAY;YACZ3B,aACE;YACFD,QAAQ;QACV;QACA6B,aAAarG,MAAM8E,OAAO,CAAC;YACzBsB,YAAY;gBAACE,SAAS;gBAAoCC,SAAS;YAAO;YAC1E9B,aAAa;YACbD,QAAQ;QACV;QACAgC,UAAUxG,MAAMuE,MAAM,CAAC;YACrBE,aAAa;YACbQ,WAAW;gBAAC;aAAO;YACnBG,WAAW;QACb;QACA,2BAA2B;QAC3B,oEAAoE;QACpE,kBAAkBpF,MAAMuE,MAAM,CAAC;YAC7BE,aAAa;YACbD,QAAQ;QACV;QACAiC,YAAYzG,MAAM8E,OAAO,CAAC;YACxBC,SAAS;YACTC,SAASU;YACTjB,aAAa;YACbQ,WAAW;gBAAC;aAAO;QACrB;QACAyB,YAAY1G,MAAMuE,MAAM,CAAC;YACvBE,aAAa;YACbW,WAAW;YACXW,SAAS;gBAAC;gBAAU;aAAU;QAChC;QACAY,KAAK3G,MAAM8E,OAAO,CAAC;YACjB8B,MAAM;YACN5B,SAAS;YACTP,aACE;QACJ;IACF,EAAC;IAED,MAAaoC,MAAqB;QAChC,MAAMC,UAAUC,QAAQC,GAAG;QAE3B,MAAMC,oBAAoB,IAAI,CAACpC,KAAK,CAAC,iBAAiB;QACtD,yEAAyE;QACzE,uEAAuE;QACvE,4EAA4E;QAC5E,kEAAkE;QAClE,IAAI,IAAI,CAACR,IAAI,CAACC,IAAI,EAAE;YAClB,IAAI,CAAC4C,KAAK,CACR,IAAI,CAAC7C,IAAI,CAACC,IAAI,KAAK,WACf,gEACA,CAAC,mBAAmB,EAAE,IAAI,CAACD,IAAI,CAACC,IAAI,CAAC,CAAC,CAAC,EAC3C;gBAAC6C,MAAM;YAAC;QAEZ;QAEA,QAAQ;QACR,qDAAqD;QAErD,mFAAmF;QACnF,kBAAkB;QAClB,IAAI,IAAI,CAACtC,KAAK,CAACwB,WAAW,EAAE;YAC1B,IAAI,CAACa,KAAK,CAAC,sEAAsE;gBAACC,MAAM;YAAC;QAC3F;QAEA,yDAAyD;QACzD,IAAI,IAAI,CAACtC,KAAK,CAACmB,OAAO,IAAI,IAAI,CAACnB,KAAK,CAACiB,YAAY,EAAE;YACjD,IAAI,CAACoB,KAAK,CACR,yIACA;gBAACC,MAAM;YAAC;QAEZ;QAEA,MAAMC,gBAAgB,IAAI,CAACvC,KAAK,CAAC,kBAAkB;QACnD,IAAIwC,0BAA0B,CAACD;QAC/B,IACE,IAAI,CAACvC,KAAK,CAACQ,OAAO,IAClB,IAAI,CAACR,KAAK,CAAC6B,UAAU,IACrB,IAAI,CAAC7B,KAAK,CAAC,kBAAkB,IAC7B,IAAI,CAACyC,YAAY,IACjB;YACAD,0BAA0B;QAC5B;QAEA,MAAME,oBAAoB,MAAMxG,sBAAsB;YACpDyG,eAAe1G;YACf2G,IAAI,IAAIzG,wBAAwB+F,QAAQC,GAAG;QAC7C;QACA,MAAMU,WAAWH,mBAAmBI,SAAS;QAE7C,IAAIC;QACJ,IAAI,IAAI,CAAC/C,KAAK,CAAC2B,QAAQ,IAAI3E,sBAAsB,IAAI,CAACgD,KAAK,CAAC2B,QAAQ,GAAG;YACrEoB,qBAAqB,MAAM9F,kBACzB,IAAI,CAAC+C,KAAK,CAAC2B,QAAQ,EACnB,IAAI,CAAC3B,KAAK,CAAC,iBAAiB;QAEhC;QAEA,IAAI0C,qBAAqBA,kBAAkBI,IAAI,KAAK,YAAYC,oBAAoB;YAClF,IAAI,CAACV,KAAK,CACR,CAAC,sEAAsE,EAAEK,kBAAkBM,IAAI,EAAE,EACjG;gBAACV,MAAM;YAAC;QAEZ;QAEA,mDAAmD;QACnD,IAAI,IAAI,CAACG,YAAY,IAAI;YACvB,IAAI,CAACQ,0BAA0B,CAAC;gBAACb;gBAAmBS;YAAQ;QAC9D;QAEA,QAAQ;QACR,gBAAgB;QAChB,cAAc;QACd,mBAAmB;QACnB,aAAa;QACb,qBAAqB;QACrB,kBAAkB;QAClB,0BAA0B;QAC1B,8BAA8B;QAC9B,mBAAmB;QACnB,0BAA0B;QAC1B,wBAAwB;QACxB,WAAW;QACX,OAAO;QACP,KAAK;QAEL,2EAA2E;QAC3E,8EAA8E;QAC9E,kFAAkF;QAClF,oFAAoF;QACpF,wBAAwB;QAExB,MAAMK,SAAS,MAAM,IAAI,CAACC,OAAO;QAEjC,IAAIC,qBAAqB;QACzB,IAAIV,qBAAqBA,kBAAkBI,IAAI,KAAK,UAAU;YAC5DM,qBAAqB;QACvB;QACA,MAAMC,cAAc,OAAO,IAAI,CAACrD,KAAK,CAACS,GAAG,KAAK,WAAW,IAAI,CAACT,KAAK,CAACS,GAAG,GAAG2C;QAE1E,qDAAqD;QACrD,MAAM,EAACE,IAAI,EAAC,GAAG,MAAM,IAAI,CAACC,mBAAmB;QAE7C,MAAMC,gBAAgB,IAAI,CAACxD,KAAK,CAAC2B,QAAQ,GAAG/E,qBAAqB,IAAI,CAACoD,KAAK,CAAC2B,QAAQ,IAAI,MAAM,mBAAmB;;QACjH,IAAI,CAAC6B,eAAe;YAClB,IAAI,CAACC,GAAG,CAAC,GAAG9H,WAAW+H,OAAO,CAAC,2BAA2B,CAAC;YAC3D,IAAI,CAACD,GAAG,CAAC;QACX;QAEA,IAAIE;QACJ,IAAIvB,mBAAmB;YACrBuB,aAAa,MAAM,IAAI,CAACC,qBAAqB,CAAC;gBAACxB;gBAAmBc;gBAAQI;YAAI;QAChF;QAEA,MAAM,EAACO,WAAW,EAAEC,WAAW,EAAEC,cAAc,EAAEC,cAAc,EAAEC,SAAS,EAAC,GACzE,MAAM,IAAI,CAACC,iBAAiB,CAAC;YAC3BV;YACAG;YACAT;YACAV;YACAc;QACF;QAEF,mDAAmD;QACnD,IAAI,IAAI,CAACtD,KAAK,CAACK,IAAI,EAAE;YACnB,IAAI,CAACoD,GAAG,CAAC,GAAG9H,WAAW+H,OAAO,CAAC,+BAA+B,CAAC;YAC/D,IAAI,CAACD,GAAG,CAAC;YACT,IAAI,CAACA,GAAG,CAAC,CAAC,YAAY,EAAEjI,MAAM2I,IAAI,CAACF,YAAY;YAC/C,IAAI,CAACR,GAAG,CAAC,CAAC,SAAS,EAAEjI,MAAM2I,IAAI,CAACN,cAAc;YAC9C,IAAI,CAACJ,GAAG,CACN,CAAC,oFAAoF,EAAEQ,UAAU,EAAE,CAAC;YAEtG;QACF;QAEA,IAAIG,WAAW,IAAI,CAACC,aAAa,CAAC,2BAA2B;QAC7D,IAAIxB,YAAY,IAAI,CAACyB,sBAAsB,CAAC,IAAI,CAACtE,KAAK,CAAC,0BAA0B,GAAG;YAClFoE,WAAW,MAAMvG;QACnB;QAEA,QAAQ;QACR,cAAc;QACd,kCAAkC;QAClC,6CAA6C;QAC7C,gDAAgD;QAChD,KAAK;QAEL,MAAM0G,cAAclI,OAAOyH,YAAYU,WAAW,IAC/CC,UAAU,CAAC,QAAQ,KACnBA,UAAU,CAAC,eAAe;QAE7B,yDAAyD;QACzD,iDAAiD;QACjD,MAAMC,gBAAgBN;QAEtB,+CAA+C;QAC/C,MAAMO,WAAW,MAAMzF,mBAAmB;YAAC0F,UAAU;YAAO3C;QAAO;QAEnE,2CAA2C;QAC3C,MAAM4C,aAAa,MAAM,IAAI,CAACC,oBAAoB,CAAC;YACjDJ;YACAH;YACAtC;QACF;QAEA,yBAAyB;QACzB,MAAM8C,YAAY,MAAM5H,SAAS;YAAC4D,KAAK,IAAI,CAACf,KAAK,CAACe,GAAG;YAAEiE,QAAQ,IAAI,CAACA,MAAM;QAAA;QAC1E,QAAQ;QACR,cAAc;QACd,sBAAsB;QACtB,gDAAgD;QAChD,oDAAoD;QACpD,gCAAgC;QAChC,KAAK;QACL,yBAAyB;QACzB,iCAAiC;QACjC,IAAI;QACJ,MAAMC,gBAAgBF,UAAUG,iBAAiB;QAEjD,IAAIrC,UAAU;YACZ,MAAMnG,8BAA8B;gBAClCgG;gBACAsC,QAAQ,IAAI,CAACA,MAAM;gBACnBH;YACF;QACF;QAEA,IAAIT,UAAU;YACZ,MAAM,IAAI,CAACe,UAAU,CAAC;gBACpBtB;gBACAnB;gBACAW;gBACA4B;gBACAhB;gBACAhC;YACF;QACF;QAEA,oDAAoD;QACpD,IAAI,IAAI,CAACjC,KAAK,CAACS,GAAG,EAAE;YAClB,MAAM5D,sBAAsB;gBAC1BuI,SAAS;oBACPC,SAASxB;oBACTyB,YAAYrB;gBACd;gBACAsB,UAAUlC;gBACVmC,WAAW9C;gBACXe,KAAK;gBACLuB,QAAQ,IAAI,CAACA,MAAM;gBACnBH;YACF;YACA,IAAI,CAACvC,IAAI,CAAC;QACZ;QAEA,6BAA6B;QAC7B,MAAMmD,eAAe,MAAM,IAAI,CAACC,iBAAiB;QACjD,QAAQ;QACR,2EAA2E;QAC3E,MAAM/D,WAAWvE,SAAS,CAACqI,aAAa;QACxC,IAAI,CAAC1C,sBAAsB,CAACpB,UAAU;YACpC,IAAI,CAACU,KAAK,CAAC,CAAC,UAAU,EAAEoD,aAAa,WAAW,CAAC,EAAE;gBAACnD,MAAM;YAAC;QAC7D;QAEA,IAAIqD,gBAAgB,IAAI,CAAC3F,KAAK,CAAC4B,UAAU;QACzC,IAAI,CAACmB,sBAAsBpB,YAAYA,SAASiE,cAAc,KAAK,MAAM;YACvED,gBAAgB;QAClB,OAAO,IAAI,IAAI,CAACrB,sBAAsB,CAAC,IAAI,CAACtE,KAAK,CAAC4B,UAAU,GAAG;YAC7D+D,gBAAgB,MAAM1H;QACtB,QAAQ;QACR,mFAAmF;QACrF;QAEA,2FAA2F;QAC3F,MAAM4H,eACJ,CAAC,IAAI,CAACpD,YAAY,MAClBd,UAAUmE,cACT,MAAM,IAAI,CAACC,sBAAsB,CAACpE,SAASqE,YAAY;QAE1D,QAAQ;QACR,0FAA0F;QAE1F,IAAI;YACF,MAAMlH,2BAA2BmF;QACnC,EAAE,OAAOgC,KAAK;YACZ,sBAAsB;YACtB3G,MAAM,8CAA8C2G;QACtD;QAEA,IAAI;YACF,MAAMxJ,kBAAkB;gBACtByJ,aAAa,IAAI,CAAClG,KAAK,CAAC,eAAe;gBACvCmG,aAAa,IAAI,CAACnG,KAAK,CAAC,iBAAiB;gBACzCQ,SAASqD;gBACTG;gBACAgB,QAAQ,IAAI,CAACA,MAAM;gBACnBH;gBACAuB,gBAAgB,IAAI,CAACpG,KAAK,CAAC,kBAAkB;gBAC7CqG,aAAa9B;gBACbN;gBACAqC,aAAaxC,eAAea,SAAS2B,WAAW;gBAChDvD;gBACA0C;gBACAE;YACF;QACF,EAAE,OAAOtD,OAAO;YACd,IAAIA,iBAAiBkE,OAAO;gBAC1B,MAAMlE;YACR;YACA,MAAM,IAAIkE,MAAMC,OAAOnE;QACzB;QAEA,MAAMoE,aAAa,MAAMvJ,sBAAsB;YAC7CwJ,aAAa,CAAC,IAAI,CAACjE,YAAY;YAC/BuC,QAAQ,IAAI,CAACA,MAAM;YACnB2B,gBAAgB,IAAI,CAAC3G,KAAK,CAAC,kBAAkB;YAC7C4G,WAAW/B;QACb;QAEA,QAAQ;QACR,0EAA0E;QAE1E,mDAAmD;QACnD,MAAM1F,wBAAwB0F,YAAY4B,YAAY;YAACzB,QAAQ,IAAI,CAACA,MAAM;YAAE/C;QAAO;QAEnF,MAAM4E,SAAS,IAAI,CAAC7G,KAAK,CAACY,GAAG,KAAKC,aAAaiG,QAAQ,IAAI,CAAC9G,KAAK,CAACY,GAAG;QACrE,MAAMmG,gBAAgB,IAAI,CAAC/G,KAAK,CAACY,GAAG;QACpC,oCAAoC;QACpC,IAAIiG,QAAQ;YACV9J,WAAW8H,YAAY,OAAOkC,kBAAkB,WAAWA,gBAAgBlG;QAC7E;QAEA,sDAAsD;QACtD,IAAIgF,gBAAgBlE,UAAUmE,YAAY;YACxC,MAAMkB,QAAQ,MAAM3L;YACpB,IAAI,CAAC2L,OAAO;gBACV,IAAI,CAAC3E,KAAK,CAAC,6CAA6C;oBAACC,MAAM;gBAAC;YAClE;YACA,MAAMtG,qBAAqBgG,GAAG,CAC5B;gBAACL,SAASmE,UAAU;gBAAE;gBAAa7B;gBAAW;gBAAaJ;gBAAa;gBAAWmD;aAAM,EACzF;gBACEC,MAAMpC;YACR;YAGF,IAAI,CAACpB,GAAG,CAAC;YACT,IAAI,CAACA,GAAG,CAAC;YACT,IAAI,CAACA,GAAG,CAAC,CAAC,EAAE,EAAEjI,MAAM2I,IAAI,CAAC,CAAC,0BAA0B,EAAEN,aAAa,GAAG;YACtE,IAAI,CAACJ,GAAG,CAAC;YACT,IAAI,CAACA,GAAG,CAAC,CAAC,EAAE,EAAEjI,MAAM2I,IAAI,CAAC,CAAC,gCAAgC,CAAC,EAAE,EAAE,CAAC;QAClE;QAEA,MAAM+C,gBAAgD;YACpDC,KAAK;YACLC,QAAQ;YACRC,KAAK;YACLC,MAAM;YACNC,MAAM;QACR;QACA,MAAMC,aAAaN,aAAa,CAACT,WAAW;QAE5C,MAAMgB,eAAe5C,eAAe3C,QAAQC,GAAG;QAC/C,MAAMuF,iBAAiB,CAAC,GAAG,EAAElM,MAAM2I,IAAI,CAAC,CAAC,GAAG,EAAEU,YAAY,EAAE,2CAA2C,CAAC;QAExG,IAAIrB,eAAe;YACjB,6BAA6B;YAC7B,IAAI,CAACC,GAAG,CACN,GAAG9H,WAAW+H,OAAO,CAAC,CAAC,EAAElI,MAAMmM,KAAK,CAACC,IAAI,CAAC,YAAY,qCAAqC,CAAC;YAE9F,IAAI,CAACH,cAAc,IAAI,CAAChE,GAAG,CAACiE;YAC5B,IAAI,CAACjE,GAAG,CACN,CAAC,EAAE,EAAEjI,MAAMoM,IAAI,CAAC,QAAQ,oEAAoE,CAAC;YAE/F,IAAI,CAACnE,GAAG,CAAC;YACT,IAAI,CAACA,GAAG,CAACjI,MAAMqM,IAAI,CAACC,SAAS,CAAC;YAC9B,IAAI7C,iBAAiBA,cAAc8C,MAAM,GAAG,GAAG;gBAC7C,MAAMtG,UAAU,MAAM,IAAI,CAACuG,oBAAoB,CAAC/C;gBAChD,IAAI,CAACxB,GAAG,CAAC,CAAC,EAAE,EAAEhC,SAAS;gBACvB,IAAI,CAACgC,GAAG,CAAC,CAAC,cAAc,EAAEjI,MAAM2I,IAAI,CAAC,0BAA0B;gBAC/D,IAAI,CAACV,GAAG,CACN,CAAC,2CAA2C,EAAEjI,MAAM2I,IAAI,CAAC,yCAAyC;YAEtG;YACA,IAAI,CAACV,GAAG,CAAC;YACT,IAAI,CAACA,GAAG,CAAC,CAAC,uBAAuB,CAAC;YAClC,IAAI,CAACA,GAAG,CAAC,CAAC,iEAAiE,CAAC;YAC5E,IAAI,CAACA,GAAG,CAAC,CAAC,uEAAuE,CAAC;YAClF,IAAI,CAACA,GAAG,CAAC,CAAC,6CAA6C,CAAC;QAC1D,OAAO;YACL,yBAAyB;YACzB,IAAI,CAACA,GAAG,CAAC,CAAC,EAAE,EAAEjI,MAAMmM,KAAK,CAACC,IAAI,CAAC,YAAY,8BAA8B,CAAC;YAC1E,IAAI,CAACH,cAAc,IAAI,CAAChE,GAAG,CAACiE;YAC5B,IAAI,CAACjE,GAAG,CACN,CAAC,yBAAyB,EAAEjI,MAAM2I,IAAI,CAACqD,YAAY,2CAA2C,CAAC;YAEjG,IAAIvC,iBAAiBA,cAAc8C,MAAM,GAAG,GAAG;gBAC7C,MAAMtG,UAAU,MAAM,IAAI,CAACuG,oBAAoB,CAAC/C;gBAChD,IAAI,CAACxB,GAAG,CAAC,CAAC,EAAE,EAAEhC,SAAS;gBACvB,IAAI,CAACgC,GAAG,CAAC,CAAC,cAAc,EAAEjI,MAAM2I,IAAI,CAAC,0BAA0B;gBAC/D,IAAI,CAACV,GAAG,CACN,CAAC,2CAA2C,EAAEjI,MAAM2I,IAAI,CAAC,yCAAyC;YAEtG;YACA,IAAI,CAACV,GAAG,CAAC;YACT,IAAI,CAACA,GAAG,CAAC,CAAC,uBAAuB,CAAC;YAClC,IAAI,CAACA,GAAG,CAAC,CAAC,iEAAiE,CAAC;YAC5E,IAAI,CAACA,GAAG,CAAC,CAAC,oEAAoE,CAAC;YAC/E,IAAI,CAACA,GAAG,CAAC,CAAC,oDAAoD,CAAC;QACjE;QAEA,IAAIM,gBAAgB;YAClB,QAAQ;YACR,kEAAkE;YAElE,MAAMkE,sBAAsB;YAE5B,IAAI,CAACxE,GAAG,CAAC,CAAC,6BAA6B,EAAEjI,MAAM2I,IAAI,CAAC8D,sBAAsB;YAC1E,IAAI,CAACxE,GAAG,CAAC;QACX;IAEA,QAAQ;IACR,mBAAmB;IACrB;IAEQR,2BAA2B,EACjCb,iBAAiB,EACjBS,QAAQ,EAIT,EAAE;QACDvD,MAAM;QAEN,IAAI,CAAC,IAAI,CAACU,KAAK,CAAC,UAAU,EAAE;YAC1B,IAAI,CAACqC,KAAK,CAAC,CAAC,kDAAkD,CAAC,EAAE;gBAACC,MAAM;YAAC;QAC3E;QAEA,mEAAmE;QACnE,IAAI,CAACO,YAAY,CAAC,IAAI,CAAC7C,KAAK,CAAC,cAAc,EAAE;YAC3C,IAAI,CAACqC,KAAK,CAAC,CAAC,sDAAsD,CAAC,EAAE;gBAACC,MAAM;YAAC;QAC/E;QAEA,IAAI,CAAC,IAAI,CAACtC,KAAK,CAACmB,OAAO,IAAI,CAACiB,mBAAmB;YAC7C,IAAI,CAACC,KAAK,CACR,sFACA;gBAACC,MAAM;YAAC;QAEZ;QAEA,IAAIF,qBAAqB,CAAC,IAAI,CAACpC,KAAK,CAACiB,YAAY,EAAE;YACjD,IAAI,CAACoB,KAAK,CACR,2IACA;gBAACC,MAAM;YAAC;QAEZ;IACF;IAEA,MAAcsB,sBAAsB,EAClCxB,iBAAiB,EACjBc,MAAM,EACNI,IAAI,EAKL,EAAE;QACDhE,MAAM;QAEN,IAAI4I,0BAA0B,IAAI,CAAClI,KAAK,CAACiB,YAAY;QAErD,IAAI,CAACiH,yBAAyB;YAC5B5I,MAAM;YACN,MAAM6I,gBAAgB,MAAM1J;YAC5ByJ,0BAA0B,MAAM,IAAI,CAACE,yBAAyB,CAAC;gBAACD;gBAAe7E;YAAI;QACrF;QAEAhE,MAAM;QACN,MAAM+I,iBAAiB,MAAMzJ,cAAc;YACzCkF,aAAa1B,kBAAkBkG,IAAI;YACnCC,UAAU;gBAACjI,QAAQ,IAAI,CAACN,KAAK,CAACM,MAAM;YAAA;YACpC0D,gBAAgBkE;YAChBM,cAActF,SAAS;gBAACA;YAAM,IAAIrC;QACpC;QAEAvB,MAAM,8BAA8B+I,eAAepE,SAAS;QAC5D,IAAI,IAAI,CAACjE,KAAK,CAACQ,OAAO,EAAE;YACtBlB,MAAM,8CAA8C,IAAI,CAACU,KAAK,CAACQ,OAAO;YACtE,MAAMiI,OAAO3M,QAAQ,oBAAoB4M,KAAK;YAC9C,MAAMrK,qBAAqB;gBACzBsK,SAAS,IAAI,CAAC3I,KAAK,CAAC6B,UAAU;gBAC9BgC,aAAa,IAAI,CAAC7D,KAAK,CAACQ,OAAO;gBAC/ByD,WAAWoE,eAAepE,SAAS;YACrC;YACAwE,KAAKG,OAAO;QACd;QAEA,OAAOP,eAAepE,SAAS;IACjC;IAEA,qFAAqF;IACrF,MAAcV,sBAAsD;QAClE,IAAIsF,kBAAkB,AAAC,MAAMxN,kBAAmBwF;QAChDvB,MAAMuJ,kBAAkB,6BAA6B;QAErD,IAAIvF;QACJ,IAAIuF,iBAAiB;YACnB,6EAA6E;YAC7E,2EAA2E;YAC3E,IAAI;gBACFvF,OAAO,MAAMvE;YACf,EAAE,OAAM;gBACN,wDAAwD;gBACxD8J,kBAAkB;YACpB;QACF;QAEA,IAAIA,iBAAiB;QACnB,kBAAkB;QAClB,sDAAsD;QACxD,OAAO;YACL,IAAI,IAAI,CAACpG,YAAY,IAAI;gBACvB,IAAI,CAACJ,KAAK,CAAC,gFAAgF;oBACzFC,MAAM;gBACR;YACF;YAEA,kBAAkB;YAClB,4BAA4B;YAE5B,4DAA4D;YAC5D,MAAM/F,MAAM;gBAACyI,QAAQ,IAAI,CAACA,MAAM;YAAA;QAClC;QAEA1B,OAAO,MAAMvE;QAEb,IAAI,CAAC0E,GAAG,CACN,GAAG9H,WAAW+H,OAAO,CAAC,sBAAsB,EAAEJ,KAAKwF,KAAK,CAAC,OAAO,EAAExM,gBAAgBgH,KAAKjC,QAAQ,GAAG;QAEpG,OAAO;YAACiC;QAAI;IACd;IAEQe,cAAc0E,IAA6B,EAAEC,YAAqB,EAAW;QACnF,OAAO,OAAO,IAAI,CAAChJ,KAAK,CAAC+I,KAAK,KAAK,YAAY,IAAI,CAAC/I,KAAK,CAAC+I,KAAK,GAAGC;IACpE;IAEA,MAAcC,mBAAmBC,IAIhC,EAA4E;QAC3E,MAAMrH,aAAa,IAAI,CAAC7B,KAAK,CAAC6B,UAAU;QACxC,MAAMrB,UAAU,IAAI,CAACR,KAAK,CAACQ,OAAO;QAClC,IAAI+B,gBAAgB,IAAI,CAACvC,KAAK,CAAC,kBAAkB;QAEjD,IAAIQ,WAAW,IAAI,CAACiC,YAAY,IAAI;YAClC,OAAO;gBAACoB,aAAarD;gBAAS2I,YAAY;YAAM;QAClD;QAEA,MAAM,CAACC,UAAUC,gBAAgB,GAAG,MAAMC,QAAQC,GAAG,CAAC;YACpDjL,aAAa4K,KAAKjF,SAAS;YAC3B1F,mBAAmB2K,KAAKjF,SAAS;SAClC;QAED,IAAIzD,SAAS;YACXlB,MAAM,kDAAkDkB;YACxD,MAAMgJ,WAAWJ,SAASK,IAAI,CAAC,CAACC,KAAOA,GAAG1G,IAAI,KAAKxC;YACnD,IAAI,CAACgJ,UAAU;gBACblK,MAAM;gBACN,MAAM9C,cAAc;oBAClBqH,aAAarD;oBACbmJ,aAAapH;oBACbyC,QAAQ,IAAI,CAACA,MAAM;oBACnBqE;oBACApF,WAAWiF,KAAKjF,SAAS;oBACzBpC;gBACF;YACF;YAEA,OAAO;gBAACgC,aAAarD;gBAAS2I,YAAY;YAAM;QAClD;QAEA,MAAMS,cACJ;QAEF,IAAIR,SAASrB,MAAM,KAAK,GAAG;YACzBzI,MAAM;YACN,IAAI4J,KAAK1G,uBAAuB,EAAE;gBAChC,IAAI,CAACiB,GAAG,CAACmG;gBACTrH,gBAAgB,MAAM,IAAI,CAACsH,sBAAsB;YACnD;YACA,MAAM7G,OAAOT,gBACT,eACA,MAAMrE,qBAAqB;gBACzBuD,SAAS;YACX;YACJ,MAAMjF,cAAc;gBAClBqH,aAAab;gBACb2G,aAAapH;gBACbyC,QAAQ,IAAI,CAACA,MAAM;gBACnBqE;gBACApF,WAAWiF,KAAKjF,SAAS;gBACzBpC;YACF;YACA,OAAO;gBAACgC,aAAab;gBAAMmG,YAAY;YAAQ;QACjD;QAEA7J,MAAM,CAAC,SAAS,EAAE8J,SAASrB,MAAM,CAAC,4CAA4C,CAAC;QAC/E,MAAM+B,iBAAiBV,SAASW,GAAG,CAAC,CAACvJ,UAAa,CAAA;gBAACwJ,OAAOxJ,QAAQwC,IAAI;YAAA,CAAA;QAEtE,MAAMiH,WAAW,MAAMrO,OAAO;YAC5BsO,SAAS;gBAAC;oBAAClH,MAAM;oBAAsBgH,OAAO;gBAAK;gBAAG,IAAInO;mBAAgBiO;aAAe;YACzFrI,SAAS;QACX;QAEA,IAAIwI,aAAa,OAAO;YACtB,MAAME,uBAAuBf,SAASW,GAAG,CAAC,CAACL,KAAOA,GAAG1G,IAAI;YACzD1D,MAAM;YACN,IAAI4J,KAAK1G,uBAAuB,IAAI,CAAC2H,qBAAqBC,QAAQ,CAAC,eAAe;gBAChF,IAAI,CAAC3G,GAAG,CAACmG;gBACTrH,gBAAgB,MAAM,IAAI,CAACsH,sBAAsB;YACnD;YAEA,MAAMQ,iBAAiB9H,gBACnB,eACA,MAAMrE,qBACJ;gBACEuD,SAAS;YACX,GACA0I;YAEN,MAAM3N,cAAc;gBAClBqH,aAAawG;gBACbV,aAAapH;gBACbyC,QAAQ,IAAI,CAACA,MAAM;gBACnBqE;gBACApF,WAAWiF,KAAKjF,SAAS;gBACzBpC;YACF;YACA,OAAO;gBAACgC,aAAawG;gBAAgBlB,YAAY;YAAQ;QAC3D;QAEA7J,MAAM,CAAC,4BAA4B,EAAE2K,SAAS,CAAC,CAAC;QAChD,OAAO;YAACpG,aAAaoG;YAAUd,YAAY;QAAQ;IACrD;IAEA,MAAcmB,mBAAmB,EAC/B3G,UAAU,EACVT,MAAM,EACNI,IAAI,EAKL,EAKE;QACD,MAAMW,YAAY,IAAI,CAACjE,KAAK,CAACmB,OAAO,IAAIwC;QACxC,MAAMK,iBAAiB,IAAI,CAAChE,KAAK,CAACiB,YAAY;QAC9C,IAAIsJ;QACJ,IAAIpC;QAEJ,IAAI;YACF,MAAM,CAACqC,aAAaC,QAAQ,GAAG,MAAMnB,QAAQC,GAAG,CAAC;gBAAC1K;gBAAgBJ;aAAoB;YACtF8L,WAAWC,YAAYE,QAAQ,CAAC,CAACC,GAAGC,IAAMA,EAAEC,SAAS,CAACC,aAAa,CAACH,EAAEE,SAAS;YAC/E1C,gBAAgBsC;QAClB,EAAE,OAAOxE,KAAK;YACZ,IAAI,IAAI,CAACxD,YAAY,MAAMwB,WAAW;gBACpC,OAAO;oBACLH,aAAa;oBACbC,gBAAgB;oBAChBE;oBACAkF,YAAY;gBACd;YACF;YACA,IAAI,CAAC9G,KAAK,CAAC,CAAC,4CAA4C,EAAE4D,IAAIxE,OAAO,EAAE,EAAE;gBAACa,MAAM;YAAC;QACnF;QAEA,IAAIiI,SAASxC,MAAM,KAAK,KAAK,IAAI,CAACtF,YAAY,IAAI;YAChD,IAAI,CAACJ,KAAK,CAAC,sCAAsC;gBAACC,MAAM;YAAC;QAC3D;QAEA,IAAI2B,WAAW;YACb,MAAM9C,UAAUoJ,SAASd,IAAI,CAAC,CAACsB,OAASA,KAAKC,EAAE,KAAK/G;YACpD,IAAI,CAAC9C,WAAW,CAAC,IAAI,CAACsB,YAAY,IAAI;gBACpC,IAAI,CAACJ,KAAK,CAAC,CAAC,kBAAkB,EAAE4B,UAAU,4CAA4C,CAAC,EAAE;oBACvF3B,MAAM;gBACR;YACF;YAEA,OAAO;gBACLwB,aAAa3C,UAAUA,QAAQ2C,WAAW,GAAG;gBAC7CC,gBAAgB;gBAChBE;gBACAkF,YAAY;YACd;QACF;QAEA,IAAInF,gBAAgB;YAClB,MAAM/C,eACJkH,cAAcsB,IAAI,CAAC,CAACwB,MAAQA,IAAID,EAAE,KAAKhH,mBACvCmE,cAAcsB,IAAI,CAAC,CAACwB,MAAQA,IAAInI,IAAI,KAAKkB;YAE3C,IAAI,CAAC/C,cAAc;gBACjB,IAAI,CAACoB,KAAK,CACR,CAAC,uBAAuB,EAAE2B,eAAe,4CAA4C,CAAC,EACtF;oBAAC1B,MAAM;gBAAC;YAEZ;YAEA,IAAI,CAAE,MAAM3E,sBAAsBqG,iBAAkB;gBAClD,IAAI,CAAC3B,KAAK,CAAC,+EAA+E;oBACxFC,MAAM;gBACR;YACF;QACF;QAEA,+FAA+F;QAC/F,qEAAqE;QACrE,MAAM4I,sBAAsBX,SAASxC,MAAM,KAAK;QAChD,IAAImD,uBAAuB,IAAI,CAAClL,KAAK,CAACM,MAAM,EAAE;YAC5ChB,MACE4L,sBACI,mDACA;YAGN,MAAMvH,aAAa,MAAM,IAAI,CAACwH,wBAAwB,CAAC;gBACrDD;gBACAlH;gBACAmE;gBACAjF;gBACAI;YACF;YAEA,OAAO;gBACL,GAAGK,UAAU;gBACbI,gBAAgBmH;gBAChB/B,YAAY;YACd;QACF;QAEA7J,MAAM,CAAC,SAAS,EAAEiL,SAASxC,MAAM,CAAC,4CAA4C,CAAC;QAE/E,MAAMqD,iBAAiBb,SAASR,GAAG,CAAC,CAAC5I,UAAa,CAAA;gBAChD6B,MAAM,GAAG7B,QAAQ2C,WAAW,CAAC,EAAE,EAAE3C,QAAQ6J,EAAE,CAAC,CAAC,CAAC;gBAC9ChB,OAAO7I,QAAQ6J,EAAE;YACnB,CAAA;QAEA,MAAMf,WAAW,MAAMrO,OAAO;YAC5BsO,SAAS;gBAAC;oBAAClH,MAAM;oBAAsBgH,OAAO;gBAAK;gBAAG,IAAInO;mBAAgBuP;aAAe;YACzF3J,SAAS;QACX;QAEA,IAAIwI,aAAa,OAAO;YACtB3K,MAAM;YAEN,MAAMqE,aAAa,MAAM,IAAI,CAACwH,wBAAwB,CAAC;gBACrDD;gBACAlH;gBACAmE;gBACAjF;gBACAI;YACF;YAEA,OAAO;gBACL,GAAGK,UAAU;gBACbI,gBAAgBmH;gBAChB/B,YAAY;YACd;QACF;QAEA7J,MAAM,CAAC,4BAA4B,EAAE2K,SAAS,CAAC,CAAC;QAChD,OAAO;YACLnG,aAAayG,SAASd,IAAI,CAAC,CAACsB,OAASA,KAAKC,EAAE,KAAKf,WAAWnG,eAAe;YAC3EC,gBAAgBmH;YAChBjH,WAAWgG;YACXd,YAAY;QACd;IACF;IAEA,MAAchG,UAAuC;QACnD,MAAMkI,eAAe,IAAI,CAACrL,KAAK,CAAC,eAAe;QAC/C,MAAMsL,iBAAiB,IAAI,CAACtL,KAAK,CAACM,MAAM;QAExC,IAAIgL,gBAAgB;YAClB,OAAO,IAAI,CAACC,YAAY,CAACD;QAC3B,OAAO,IAAID,cAAc;YACvB,OAAO,IAAI,CAACG,UAAU,CAACH;QACzB,OAAO;YACL,OAAOxK;QACT;IACF;IAEA,MAAcmH,qBAAqByD,YAA0B,EAAmB;QAC9E,OAAO3O,oBAAoB,IAAI4O,KAAKC,UAAU,CAAC,MAAMC,MAAM,CAACH;IAC9D;IAEA,MAAcvH,kBAAkB,EAC9BV,aAAa,EACbG,UAAU,EACVT,MAAM,EACNV,uBAAuB,EACvBc,IAAI,EAOL,EAOE;QACD,IAAIE,eAAe;YACjB,MAAM2E,gBAAgB,MAAM1J,kBAAkB;gBAC5CoN,4BAA4B;gBAC5BC,gBAAgB;YAClB;YAEA,MAAMC,oBAAoB,MAAM,IAAI,CAAC3D,yBAAyB,CAAC;gBAACD;gBAAe7E;YAAI;YAEnF,OAAO;gBACLO,aAAa;gBACbC,aAAa;gBACbC,gBAAgB;gBAChBC,gBAAgB+H;gBAChB9H,WAAW;YACb;QACF;QAEA3E,MAAM;QACN,MAAM6B,UAAU,MAAM,IAAI,CAACmJ,kBAAkB,CAAC;YAAC3G;YAAYT;YAAQI;QAAI;QACvEhE,MAAM,CAAC,kBAAkB,EAAE6B,QAAQ2C,WAAW,CAAC,SAAS,CAAC;QAEzD,qCAAqC;QACrCxE,MAAM;QACN,MAAMkB,UAAU,MAAM,IAAI,CAACyI,kBAAkB,CAAC;YAC5CnF,aAAa3C,QAAQ2C,WAAW;YAChCG,WAAW9C,QAAQ8C,SAAS;YAC5BzB;QACF;QACAlD,MAAM,CAAC,kBAAkB,EAAEkB,QAAQqD,WAAW,CAAC,SAAS,CAAC;QAEzD,QAAQ;QACR,cAAc;QACd,mCAAmC;QACnC,wCAAwC;QACxC,sCAAsC;QACtC,0DAA0D;QAC1D,KAAK;QAEL,OAAO;YACLA,aAAarD,QAAQqD,WAAW;YAChCC,aAAa3C,QAAQ2C,WAAW;YAChCC,gBAAgB5C,QAAQ4C,cAAc;YACtCE,WAAW9C,QAAQ8C,SAAS;QAC9B;IACF;IAEA,MAAca,qBAAqB,EACjCJ,aAAa,EACbH,WAAW,EACXtC,OAAO,EAKR,EAAmB;QAClB,MAAM4C,aAAa,IAAI,CAAC7E,KAAK,CAAC,cAAc;QAC5C,MAAMgM,gBAAgBnH,cAAc5J,KAAKgR,OAAO,CAACpH;QACjD,IAAI,IAAI,CAACpC,YAAY,MAAMuJ,iBAAiB,IAAI,CAAChM,KAAK,CAACS,GAAG,IAAIiE,eAAe;YAC3E,OAAOsH,iBAAiB/J;QAC1B;QAEA,MAAMiK,YAAY,MAAMxQ,MAAM;YAC5ByE,SAASlF,KAAKkR,IAAI,CAAClK,SAASsC;YAC5B9C,SAAS;YACT2K,UAAUnN;QACZ;QAEA,OAAOD,WAAWkN;IACpB;IAEA,MAAc/G,WAAW,EACvBtB,WAAW,EACXnB,iBAAiB,EACjBW,WAAW,EACX4B,aAAa,EACbhB,SAAS,EACThC,OAAO,EAQR,EAAE;QACD,IAAI0D,gBAAgB,IAAI,CAACtB,aAAa,CAAC,cAAc;QACrD,IAAI,IAAI,CAACC,sBAAsB,CAAC,IAAI,CAACtE,KAAK,CAAC4B,UAAU,GAAG;YACtD+D,gBAAgB,MAAM1H;QACxB;QACA,QAAQ;QACR,mFAAmF;QAEnF,MAAMoO,gBAAgB1G,gBAAgB,OAAO;QAC7C,IAAI2G,iBAAiB,IAAI,CAACjI,aAAa,CAAC,uBAAuB;QAC/D,IAAI,IAAI,CAACC,sBAAsB,CAAC,IAAI,CAACtE,KAAK,CAAC,sBAAsB,GAAG;YAClEsM,iBAAiB,MAAMxO;QACzB;QACA,IAAIyO,eAAe;QAEnB,IAAID,gBAAgB;YAClB,oCAAoC;YACpC,MAAME,SAAS;YACf,IAAIC,UAAUxR,KAAKkR,IAAI,CAAClK,SAASuK;YAEjC,IAAI,CAAC1R,WAAW2R,UAAU;gBACxBA,UAAUxR,KAAKkR,IAAI,CAAClK,SAAS,OAAOuK;gBACpCD,eAAe;gBACf,IAAI,CAACzR,WAAW2R,UAAU;oBACxB,IAAI;wBACF,MAAM1R,MAAM0R,SAAS;4BAACC,WAAW;wBAAI;oBACvC,EAAE,OAAM;wBACNpN,MAAM,4BAA4BmN;oBACpC;gBACF;YACF;YAEA,MAAME,aAAa,IAAI,CAAClK,YAAY,KAAK,YAAY,MAAMzE;YAE3D,MAAM4O,8BAA8B3R,KAAKkR,IAAI,CAC3CM,SACA,GAAGE,WAAW,CAAC,CAAC,EAChB,CAAC,iBAAiB,EAAEN,cAAc,CAAC,CAAC;YAGtC,6GAA6G;YAC7G,8GAA8G;YAC9G,iHAAiH;YACjH,wDAAwD;YACxD,MAAM,IAAI,CAACQ,gBAAgB,CACzBD,6BACApP,qBAAqBsP,OAAO,CAC1B,gBACA,GAAG,MAAMC,MAAM,CAACpQ,mBAAmBiQ,4BAA4BI,KAAK,CAAC/K,QAAQ8F,MAAM,IAAI,aAAa,CAAC,GAEvG9F;YAGF,MAAMgL,mBAAmBhS,KAAKkR,IAAI,CAAClK,SAAS,CAAC,cAAc,EAAEoK,eAAe;YAC5E,MAAM,IAAI,CAACQ,gBAAgB,CACzBI,kBACA3P,qBAAqBiP,cAClBO,OAAO,CAAC,WAAWF,4BAA4BI,KAAK,CAAC/K,QAAQ8F,MAAM,EAAE+E,OAAO,CAAC,QAAQ,KACrFA,OAAO,CAAC,cAAcH,aACzB1K;QAEJ;QAEA,MAAMiL,gBAAgBjS,KAAKkR,IAAI,CAAClK,SAAS,CAAC,WAAW,EAAEoK,eAAe;QACtE,MAAM,IAAI,CAACQ,gBAAgB,CAACK,eAAe7P,mBAAmB4E;QAE9D,IAAIkL,gBAAgB,IAAI,CAACnN,KAAK,CAAC2B,QAAQ,IAAI;QAC3C,IAAI,IAAI,CAAC2C,sBAAsB,CAAC,IAAI,CAACtE,KAAK,CAAC2B,QAAQ,GAAG;YACpDwL,gBAAgB,MAAMpP;QACxB;QAEA,MAAM,IAAI,CAACqP,gBAAgB,CAAC;YAC1Bf;YACAgB,OAAO9P,aAAaoI,eAAewH;YACnCG,YAAYzM;YACZ0M,iBAAiBhB;YACjBtK;QACF;QAEA,IAAIuL,YAAY,IAAI,CAACnJ,aAAa,CAAC,qBAAqB;QACxD,IAAI,IAAI,CAACC,sBAAsB,CAAC,IAAI,CAACtE,KAAK,CAAC,oBAAoB,GAAG;YAChEwN,YAAY,MAAM5P,mBAAmByF;QACvC;QAEA,IAAImK,WAAW;YACb,MAAM3Q,sBAAsB;gBAC1BuI,SAAS;oBACPC,SAASxB;oBACTyB,YAAYrB;gBACd;gBACAsB,UAAUlC;gBACVmC,WAAW9C;gBACXe,KAAK;gBACLuB,QAAQ,IAAI,CAACA,MAAM;gBACnBH,YAAY5C;YACd;QACF;QAEA,IAAIqK,gBAAgB;YAClB,MAAMmB,uBAAuB;YAC7B,MAAMC,sBAAsB,MAAMtP,gBAAgB6F;YAClD,MAAM0J,wBAAwBD,oBAAoBE,IAAI,CACpD,CAACC,OAA2BA,KAAKC,MAAM,KAAKL;YAE9C,IAAI,CAACE,uBAAuB;gBAC1B,IAAI;oBACF,MAAMI,gBAAgB,MAAM5P,iBAAiB;wBAC3C6P,kBAAkB;wBAClBF,QAAQL;wBACRxJ;oBACF;oBAEA,IAAI,CAACR,GAAG,CACNsK,cAAc/C,EAAE,GACZ,CAAC,MAAM,EAAEyC,qBAAqB,gBAAgB,CAAC,GAC/C,CAAC,cAAc,EAAEA,qBAAqB,gBAAgB,CAAC;gBAE/D,EAAE,OAAOpL,OAAO;oBACd/C,MAAM,CAAC,+BAA+B,EAAEmO,qBAAqB,EAAE,EAAEpL,OAAO;oBACxE,IAAI,CAACA,KAAK,CAAC,CAAC,cAAc,EAAEoL,qBAAqB,kBAAkB,EAAEpL,OAAO,EAAE;wBAACC,MAAM;oBAAC;gBACxF;YACF;QACF;QAEA,MAAM2L,SAAS,MAAM/Q,sBAAsB;YACzCwJ,aAAa,CAAC,IAAI,CAACjE,YAAY;YAC/BuC,QAAQ,IAAI,CAACA,MAAM;YACnB2B,gBAAgB,IAAI,CAAC3G,KAAK,CAAC,kBAAkB;YAC7C4G,WAAW3E;QACb;QACA,QAAQ;QACR,oEAAoE;QACpE,MAAMiM,WAAW;YAAC;YAAoB;YAAY;YAAuB;SAAsB;QAC/F,IAAIf,kBAAkB,QAAQ;YAC5Be,SAASC,IAAI,CAAC;QAChB;QACA,MAAM/O,mBACJ;YACEuH,gBAAgBsH;YAChBC;QACF,GACA;YACElJ,QAAQ,IAAI,CAACA,MAAM;YACnB/C;QACF;QAGF,2BAA2B;QAC3B,MAAMmM,cAAuB;YAC3BjM,KAAKF;YACLoM,UAAU;YACV5N,KAAKpB,yBAAyB4C;YAC9BqM,OAAO;QACT;QAEA,OAAQL;YACN,KAAK;gBAAO;oBACV,MAAM7R,MAAM,OAAO;wBAAC;wBAAW;wBAAsB;qBAAiB,EAAEgS;oBACxE;gBACF;YACA,KAAK;gBAAQ;oBACX,MAAMhS,MAAM,QAAQ;wBAAC;wBAAW;qBAAiB,EAAEgS;oBACnD;gBACF;YACA,KAAK;gBAAQ;oBACX,MAAMhS,MAAM,OAAO;wBAAC;wBAAoB;wBAAU;qBAAiB,EAAEgS;oBACrE;gBACF;YACA;gBAAS;oBAEP;gBACF;QACF;QAEA,IAAI,CAAC3K,GAAG,CACN,CAAC,EAAE,EAAEjI,MAAMmM,KAAK,CAAC,YAAY,+DAA+D,CAAC;QAE/F,IAAI1C,iBAAiBA,cAAc8C,MAAM,GAAG,GAAG;YAC7C,MAAMtG,UAAU,MAAM,IAAI,CAACuG,oBAAoB,CAAC/C;YAChD,IAAI,CAACxB,GAAG,CAAC,CAAC,EAAE,EAAEhC,SAAS;YACvB,IAAI,CAACgC,GAAG,CAAC,CAAC,cAAc,EAAEjI,MAAM2I,IAAI,CAAC,0BAA0B;YAC/D,IAAI,CAACV,GAAG,CACN,CAAC,2CAA2C,EAAEjI,MAAM2I,IAAI,CAAC,yCAAyC;QAEtG;QAEA,IAAI,CAAC7B,IAAI,CAAC;IACZ;IAEA,MAAcyD,uBAAuBtE,OAAgB,EAAE;QACrD,OAAOhG,QAAQ;YACb0E,SAAS;YACTsB,SAASA,WAAW;QACtB;IACF;IAEA,MAAcoI,yBAA2C;QACvD,OAAOpO,QAAQ;YACb0E,SAAS;YACTsB,SAAS;QACX;IACF;IAEA,MAAc0J,yBAAyB,EACrCD,mBAAmB,EACnBlH,cAAc,EACdmE,aAAa,EACbjF,MAAM,EACNI,IAAI,EAOL,EAAE;QACD,MAAMgD,cAAc,MAAM5K,MAAM;YAC9ByE,SAAS;YACTsB,SAAS;YACT2K,UAAS1Q,KAAK;gBACZ,IAAI,CAACA,SAASA,MAAM4M,IAAI,OAAO,IAAI;oBACjC,OAAO;gBACT;gBAEA,IAAI5M,MAAMqM,MAAM,GAAG,IAAI;oBACrB,OAAO;gBACT;gBAEA,OAAO;YACT;QACF;QAEA,MAAM9G,eACJ+C,kBAAmB,MAAM,IAAI,CAACoE,yBAAyB,CAAC;YAACD;YAAe7E;QAAI;QAE9E,MAAMK,aAAa,MAAM/E,cAAc;YACrCkF,aAAawC;YACbiC,UAAU;gBAACjI,QAAQ,IAAI,CAACN,KAAK,CAACM,MAAM;YAAA;YACpC0D,gBAAgB/C;YAChBuH,cAActF,SAAS;gBAACA;YAAM,IAAIrC;QACpC;QAEA,OAAO;YACL,GAAG8C,UAAU;YACbI,gBAAgBmH;YAChB/B,YAAY;QACd;IACF;IAEA,MAAczD,oBAAoB;QAChC,MAAM/D,WAAW,IAAI,CAAC3B,KAAK,CAAC2B,QAAQ;QAEpC,MAAM4M,kBAAkB,IAAI,CAAC9L,YAAY,MAAMd,WAAWA,YAAY,UAAU;QAChF,IAAI4M,iBAAiB;YACnB,OAAOA;QACT;QAEA,OAAO3S,OAAO;YACZsO,SAAS;gBACP;oBACElH,MAAM;oBACNgH,OAAO;gBACT;gBACA;oBACEhH,MAAM;oBACNgH,OAAO;gBACT;gBACA;oBACEhH,MAAM;oBACNgH,OAAO;gBACT;gBACA;oBACEhH,MAAM;oBACNgH,OAAO;gBACT;aACD;YACDvI,SAAS;QACX;IACF;IAEQ6C,uBAAuByE,IAAa,EAAE;QAC5C,OAAO,CAAC,IAAI,CAACtG,YAAY,MAAMsG,SAASlI;IAC1C;IAEA,MAAc2N,6BACZlL,IAAmB,EACkB;QACrC,MAAMN,OAAO,MAAMtH,MAAM;YACvByE,SAASmD,OAAOA,KAAKN,IAAI,GAAGnC;YAC5BY,SAAS;YACT2K,UAAS1Q,KAAK;gBACZ,IAAIA,MAAMqM,MAAM,KAAK,GAAG;oBACtB,OAAO;gBACT,OAAO,IAAIrM,MAAMqM,MAAM,GAAG,KAAK;oBAC7B,OAAO;gBACT;gBACA,OAAO;YACT;QACF;QAEA,MAAMU,OAAO3M,QAAQ,yBAAyB4M,KAAK;QACnD,MAAMzH,eAAe,MAAMzC,mBAAmBwE;QAC9CyF,KAAKG,OAAO;QAEZ,OAAO3H;IACT;IAEA,MAAcmH,0BAA0B,EACtCD,aAAa,EACb7E,IAAI,EAIL,EAAE;QACD,oFAAoF;QACpF,0DAA0D;QAC1D,IAAI6E,cAAcJ,MAAM,KAAK,GAAG;YAC9B,MAAM0G,kBAAkB,MAAM,IAAI,CAACD,4BAA4B,CAAClL;YAChE,OAAOmL,gBAAgBzD,EAAE;QAC3B;QAEA,mFAAmF;QACnF,mFAAmF;QACnF,wCAAwC;QACxC1L,MAAM,CAAC,SAAS,EAAE6I,cAAcJ,MAAM,CAAC,wCAAwC,CAAC;QAChF,MAAM2G,gBAAgB,MAAMhR,oCAAoCyK;QAChE,MAAMwG,aAAaD,cAAcE,MAAM,CAAC,CAAC,EAACC,cAAc,EAAC,GAAKA;QAE9DvP,MAAM,+CAA+CqP,WAAW5G,MAAM;QACtE,MAAM+G,sBAAsBrR,uBAAuBkR;QAEnD,kFAAkF;QAClF,mFAAmF;QACnF,sCAAsC;QACtC,MAAMI,wBACJJ,WAAW5G,MAAM,KAAK,IAClB4G,UAAU,CAAC,EAAE,CAAC1N,YAAY,CAAC+J,EAAE,GAC7B7C,cAAcsB,IAAI,CAAC,CAACwB,MAAQA,IAAIjI,IAAI,KAAKM,MAAMN,OAAOgI;QAE5D,MAAMgE,YAAY,MAAMpT,OAAO;YAC7BsO,SAAS4E;YACT3O,SAAS4O,yBAAyBlO;YAClCY,SAAS;QACX;QAEA,IAAIuN,cAAc,SAAS;YACzB,MAAMP,kBAAkB,MAAM,IAAI,CAACD,4BAA4B,CAAClL;YAChE,OAAOmL,gBAAgBzD,EAAE;QAC3B;QAEA,OAAOgE,aAAanO;IACtB;IAEA,MAAc0K,aAAaD,cAAsB,EAA+B;QAC9E,IAAI;YACF,MAAMpI,SAAS,MAAMvE,oBAAoB2M;YACzC,IAAI,CAAC7H,GAAG,CAAC,CAAC,QAAQ,EAAE6H,eAAe,cAAc,CAAC;YAClD,OAAOpI;QACT,EAAE,OAAO+C,KAAc;YACrB,IAAI,CAAClK,YAAYkK,QAAQA,IAAIgJ,UAAU,KAAK,KAAK;gBAC/C,MAAMxN,UAAUwE,eAAeM,QAAQN,IAAIxE,OAAO,GAAG,GAAGwE,KAAK;gBAC7D,IAAI,CAAC5D,KAAK,CAAC,CAAC,sDAAsD,EAAEZ,SAAS,EAAE;oBAACa,MAAM;gBAAC;YACzF;YAEA,MAAM4M,iBACJ,IAAI,CAACzM,YAAY,MAChB,MAAMhH,QAAQ;gBACb0E,SAAS;gBACTsB,SAAS,CAAC,QAAQ,EAAE6J,eAAe,6CAA6C,CAAC;YACnF;YAEF,IAAI,IAAI,CAAC7I,YAAY,IAAI;gBACvB,IAAI,CAAC0M,IAAI,CAAC,CAAC,QAAQ,EAAE7D,eAAe,uCAAuC,CAAC;YAC9E;YAEA,QAAQ;YACR,cAAc;YACd,kCAAkC;YAClC,mDAAmD;YACnD,4BAA4B;YAC5B,KAAK;YAEL,IAAI4D,gBAAgB;gBAClB,IAAI,CAACzL,GAAG,CAAC;YACX,OAAO;gBACL,IAAI,CAACpB,KAAK,CAAC,CAAC,QAAQ,EAAEiJ,eAAe,gBAAgB,CAAC,EAAE;oBAAChJ,MAAM;gBAAC;YAClE;QACF;IACF;IAEA,MAAckJ,WAAWH,YAAoB,EAA+B;QAC1E,IAAI;YACF,MAAMnI,SAAS,MAAMxE,UAAU2M;YAC/B,OAAOnI;QACT,EAAE,OAAO+C,KAAc;YACrB,IAAI,CAAClK,YAAYkK,QAAQA,IAAIgJ,UAAU,KAAK,KAAK;gBAC/C,MAAMxN,UAAUwE,eAAeM,QAAQN,IAAIxE,OAAO,GAAG,GAAGwE,KAAK;gBAC7D,IAAI,CAAC5D,KAAK,CAAC,CAAC,oDAAoD,EAAEZ,SAAS,EAAE;oBAACa,MAAM;gBAAC;YACvF;YAEA,MAAM4M,iBACJ,IAAI,CAACzM,YAAY,MAChB,MAAMhH,QAAQ;gBACb0E,SAAS;gBACTsB,SAAS,CAAC,cAAc,EAAE4J,aAAa,2CAA2C,CAAC;YACrF;YAEF,IAAI,IAAI,CAAC5I,YAAY,IAAI;gBACvB,IAAI,CAAC0M,IAAI,CAAC,CAAC,cAAc,EAAE9D,aAAa,qCAAqC,CAAC;YAChF;YAEA,QAAQ;YACR,cAAc;YACd,8BAA8B;YAC9B,mDAAmD;YACnD,0BAA0B;YAC1B,KAAK;YAEL,IAAI6D,gBAAgB;gBAClB,IAAI,CAACzL,GAAG,CAAC;YACX,OAAO;gBACL,IAAI,CAACpB,KAAK,CAAC,CAAC,SAAS,EAAEgJ,aAAa,gBAAgB,CAAC,EAAE;oBAAC/I,MAAM;gBAAC;YACjE;QACF;IACF;IAEA,MAAcuK,iBAAiBuC,QAAgB,EAAEC,OAAe,EAAEpN,OAAe,EAAE;QACjF,IAAInH,WAAWsU,WAAW;YACxB,IAAIE,YAAY,IAAI,CAACjL,aAAa,CAAC,mBAAmB;YACtD,IAAI,IAAI,CAACC,sBAAsB,CAAC,IAAI,CAACtE,KAAK,CAAC,kBAAkB,GAAG;gBAC9DsP,YAAY,MAAM7T,QAAQ;oBACxB0E,SAAS;oBACTsB,SAAS,CAAC,KAAK,EAAEjG,MAAM+T,MAAM,CAC3BH,SAAStC,OAAO,CAAC7K,SAAS,KAC1B,6CAA6C,CAAC;gBAClD;YACF;YAEA,IAAI,CAACqN,WAAW;gBACd;YACF;QACF;QAEA,4BAA4B;QAC5B,MAAMhC,aAAarS,KAAKuU,OAAO,CAACJ;QAEhC,IAAI;YACF,MAAMrU,MAAMuS,YAAY;gBAACZ,WAAW;YAAI;QAC1C,EAAE,OAAM;YACNpN,MAAM,4BAA4BgO;QACpC;QAEA,MAAMtS,UAAUoU,UAAUC,SAAS;YACjChB,UAAU;QACZ;IACF;IAEA,4BAA4B;IAC5B,MAAcjB,iBAAiB,EAC7Bf,aAAa,EACbgB,KAAK,EACLC,UAAU,EACVC,eAAe,EACftL,OAAO,EAOR,EAAE;QACD,KAAK,MAAM,CAACmN,UAAUC,QAAQ,IAAII,OAAOC,OAAO,CAACrC,OAAQ;YACvD,+HAA+H;YAC/H,IAAI+B,SAAShF,QAAQ,CAAC,QAAQ,OAAOiF,YAAY,UAAU;gBACzD,MAAM,IAAI,CAACxC,gBAAgB,CACzB5R,KAAKkR,IAAI,CACPlK,SACAsL,kBAAkB,QAAQ,IAC1B,UACAD,cAAc,IACd,GAAG8B,WAAW/C,eAAe,GAE/BgD,SACApN;YAEJ,OAAO;gBACL,MAAMlH,MAAME,KAAKkR,IAAI,CAAClK,SAASsL,kBAAkB,QAAQ,IAAI,UAAU6B,WAAW;oBAChF1C,WAAW;gBACb;gBACA,IAAI,OAAO2C,YAAY,UAAU;oBAC/B,MAAM,IAAI,CAACjC,gBAAgB,CAAC;wBAC1Bf;wBACAgB,OAAOgC;wBACP/B,YAAY8B;wBACZ7B;wBACAtL;oBACF;gBACF;YACF;QACF;IACF;AACF"}
@@ -15,7 +15,6 @@ export class Disable extends SanityCommand {
15
15
  await this.parse(Disable);
16
16
  try {
17
17
  const result = await setConsent({
18
- env: process.env,
19
18
  status: 'denied'
20
19
  });
21
20
  this.log(result.message);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/commands/telemetry/disable.ts"],"sourcesContent":["import {Command} from '@oclif/core'\nimport {type FlagInput} from '@oclif/core/interfaces'\nimport {SanityCommand} from '@sanity/cli-core'\n\nimport {setConsent} from '../../actions/telemetry/setConsent.js'\nimport {telemetryLearnMoreMessage} from '../../actions/telemetry/telemetryLearnMoreMessage.js'\n\nexport class Disable extends SanityCommand<typeof Disable> {\n static override description = 'Disable telemetry for your logged in user'\n\n static override examples: Array<Command.Example> = [\n {\n command: '<%= config.bin %> telemetry <%= command.id %>',\n description: 'Disable telemetry for your logged in user',\n },\n ]\n\n static override flags = {} satisfies FlagInput\n\n public async run(): Promise<void> {\n // Parse to ensure no invalid flags are passed\n await this.parse(Disable)\n\n try {\n const result = await setConsent({\n env: process.env,\n status: 'denied',\n })\n\n this.log(result.message)\n\n if (result.changed) {\n this.log(`\\n${telemetryLearnMoreMessage('denied')}`)\n }\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : 'An unknown error occurred'\n this.error(message, {exit: 1})\n }\n }\n}\n"],"names":["SanityCommand","setConsent","telemetryLearnMoreMessage","Disable","description","examples","command","flags","run","parse","result","env","process","status","log","message","changed","err","Error","error","exit"],"mappings":"AAEA,SAAQA,aAAa,QAAO,mBAAkB;AAE9C,SAAQC,UAAU,QAAO,wCAAuC;AAChE,SAAQC,yBAAyB,QAAO,uDAAsD;AAE9F,OAAO,MAAMC,gBAAgBH;IAC3B,OAAgBI,cAAc,4CAA2C;IAEzE,OAAgBC,WAAmC;QACjD;YACEC,SAAS;YACTF,aAAa;QACf;KACD,CAAA;IAED,OAAgBG,QAAQ,CAAC,EAAqB;IAE9C,MAAaC,MAAqB;QAChC,8CAA8C;QAC9C,MAAM,IAAI,CAACC,KAAK,CAACN;QAEjB,IAAI;YACF,MAAMO,SAAS,MAAMT,WAAW;gBAC9BU,KAAKC,QAAQD,GAAG;gBAChBE,QAAQ;YACV;YAEA,IAAI,CAACC,GAAG,CAACJ,OAAOK,OAAO;YAEvB,IAAIL,OAAOM,OAAO,EAAE;gBAClB,IAAI,CAACF,GAAG,CAAC,CAAC,EAAE,EAAEZ,0BAA0B,WAAW;YACrD;QACF,EAAE,OAAOe,KAAc;YACrB,MAAMF,UAAUE,eAAeC,QAAQD,IAAIF,OAAO,GAAG;YACrD,IAAI,CAACI,KAAK,CAACJ,SAAS;gBAACK,MAAM;YAAC;QAC9B;IACF;AACF"}
1
+ {"version":3,"sources":["../../../src/commands/telemetry/disable.ts"],"sourcesContent":["import {Command} from '@oclif/core'\nimport {type FlagInput} from '@oclif/core/interfaces'\nimport {SanityCommand} from '@sanity/cli-core'\n\nimport {setConsent} from '../../actions/telemetry/setConsent.js'\nimport {telemetryLearnMoreMessage} from '../../actions/telemetry/telemetryLearnMoreMessage.js'\n\nexport class Disable extends SanityCommand<typeof Disable> {\n static override description = 'Disable telemetry for your logged in user'\n\n static override examples: Array<Command.Example> = [\n {\n command: '<%= config.bin %> telemetry <%= command.id %>',\n description: 'Disable telemetry for your logged in user',\n },\n ]\n\n static override flags = {} satisfies FlagInput\n\n public async run(): Promise<void> {\n // Parse to ensure no invalid flags are passed\n await this.parse(Disable)\n\n try {\n const result = await setConsent({\n status: 'denied',\n })\n\n this.log(result.message)\n\n if (result.changed) {\n this.log(`\\n${telemetryLearnMoreMessage('denied')}`)\n }\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : 'An unknown error occurred'\n this.error(message, {exit: 1})\n }\n }\n}\n"],"names":["SanityCommand","setConsent","telemetryLearnMoreMessage","Disable","description","examples","command","flags","run","parse","result","status","log","message","changed","err","Error","error","exit"],"mappings":"AAEA,SAAQA,aAAa,QAAO,mBAAkB;AAE9C,SAAQC,UAAU,QAAO,wCAAuC;AAChE,SAAQC,yBAAyB,QAAO,uDAAsD;AAE9F,OAAO,MAAMC,gBAAgBH;IAC3B,OAAgBI,cAAc,4CAA2C;IAEzE,OAAgBC,WAAmC;QACjD;YACEC,SAAS;YACTF,aAAa;QACf;KACD,CAAA;IAED,OAAgBG,QAAQ,CAAC,EAAqB;IAE9C,MAAaC,MAAqB;QAChC,8CAA8C;QAC9C,MAAM,IAAI,CAACC,KAAK,CAACN;QAEjB,IAAI;YACF,MAAMO,SAAS,MAAMT,WAAW;gBAC9BU,QAAQ;YACV;YAEA,IAAI,CAACC,GAAG,CAACF,OAAOG,OAAO;YAEvB,IAAIH,OAAOI,OAAO,EAAE;gBAClB,IAAI,CAACF,GAAG,CAAC,CAAC,EAAE,EAAEV,0BAA0B,WAAW;YACrD;QACF,EAAE,OAAOa,KAAc;YACrB,MAAMF,UAAUE,eAAeC,QAAQD,IAAIF,OAAO,GAAG;YACrD,IAAI,CAACI,KAAK,CAACJ,SAAS;gBAACK,MAAM;YAAC;QAC9B;IACF;AACF"}
@@ -15,7 +15,6 @@ export class Enable extends SanityCommand {
15
15
  await this.parse(Enable);
16
16
  try {
17
17
  const result = await setConsent({
18
- env: process.env,
19
18
  status: 'granted'
20
19
  });
21
20
  this.log(result.message);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/commands/telemetry/enable.ts"],"sourcesContent":["import {Command} from '@oclif/core'\nimport {type FlagInput} from '@oclif/core/interfaces'\nimport {SanityCommand} from '@sanity/cli-core'\n\nimport {setConsent} from '../../actions/telemetry/setConsent.js'\nimport {telemetryLearnMoreMessage} from '../../actions/telemetry/telemetryLearnMoreMessage.js'\n\nexport class Enable extends SanityCommand<typeof Enable> {\n static override description = 'Enable telemetry for your logged in user'\n\n static override examples: Array<Command.Example> = [\n {\n command: '<%= config.bin %> telemetry <%= command.id %>',\n description: 'Enable telemetry for your logged in user',\n },\n ]\n\n static override flags = {} satisfies FlagInput\n\n public async run(): Promise<void> {\n // Parse to ensure no invalid flags are passed\n await this.parse(Enable)\n\n try {\n const result = await setConsent({\n env: process.env,\n status: 'granted',\n })\n\n this.log(result.message)\n\n if (result.changed) {\n this.log(`\\n${telemetryLearnMoreMessage('granted')}`)\n }\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : 'An unknown error occurred'\n this.error(message, {exit: 1})\n }\n }\n}\n"],"names":["SanityCommand","setConsent","telemetryLearnMoreMessage","Enable","description","examples","command","flags","run","parse","result","env","process","status","log","message","changed","err","Error","error","exit"],"mappings":"AAEA,SAAQA,aAAa,QAAO,mBAAkB;AAE9C,SAAQC,UAAU,QAAO,wCAAuC;AAChE,SAAQC,yBAAyB,QAAO,uDAAsD;AAE9F,OAAO,MAAMC,eAAeH;IAC1B,OAAgBI,cAAc,2CAA0C;IAExE,OAAgBC,WAAmC;QACjD;YACEC,SAAS;YACTF,aAAa;QACf;KACD,CAAA;IAED,OAAgBG,QAAQ,CAAC,EAAqB;IAE9C,MAAaC,MAAqB;QAChC,8CAA8C;QAC9C,MAAM,IAAI,CAACC,KAAK,CAACN;QAEjB,IAAI;YACF,MAAMO,SAAS,MAAMT,WAAW;gBAC9BU,KAAKC,QAAQD,GAAG;gBAChBE,QAAQ;YACV;YAEA,IAAI,CAACC,GAAG,CAACJ,OAAOK,OAAO;YAEvB,IAAIL,OAAOM,OAAO,EAAE;gBAClB,IAAI,CAACF,GAAG,CAAC,CAAC,EAAE,EAAEZ,0BAA0B,YAAY;YACtD;QACF,EAAE,OAAOe,KAAc;YACrB,MAAMF,UAAUE,eAAeC,QAAQD,IAAIF,OAAO,GAAG;YACrD,IAAI,CAACI,KAAK,CAACJ,SAAS;gBAACK,MAAM;YAAC;QAC9B;IACF;AACF"}
1
+ {"version":3,"sources":["../../../src/commands/telemetry/enable.ts"],"sourcesContent":["import {Command} from '@oclif/core'\nimport {type FlagInput} from '@oclif/core/interfaces'\nimport {SanityCommand} from '@sanity/cli-core'\n\nimport {setConsent} from '../../actions/telemetry/setConsent.js'\nimport {telemetryLearnMoreMessage} from '../../actions/telemetry/telemetryLearnMoreMessage.js'\n\nexport class Enable extends SanityCommand<typeof Enable> {\n static override description = 'Enable telemetry for your logged in user'\n\n static override examples: Array<Command.Example> = [\n {\n command: '<%= config.bin %> telemetry <%= command.id %>',\n description: 'Enable telemetry for your logged in user',\n },\n ]\n\n static override flags = {} satisfies FlagInput\n\n public async run(): Promise<void> {\n // Parse to ensure no invalid flags are passed\n await this.parse(Enable)\n\n try {\n const result = await setConsent({\n status: 'granted',\n })\n\n this.log(result.message)\n\n if (result.changed) {\n this.log(`\\n${telemetryLearnMoreMessage('granted')}`)\n }\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : 'An unknown error occurred'\n this.error(message, {exit: 1})\n }\n }\n}\n"],"names":["SanityCommand","setConsent","telemetryLearnMoreMessage","Enable","description","examples","command","flags","run","parse","result","status","log","message","changed","err","Error","error","exit"],"mappings":"AAEA,SAAQA,aAAa,QAAO,mBAAkB;AAE9C,SAAQC,UAAU,QAAO,wCAAuC;AAChE,SAAQC,yBAAyB,QAAO,uDAAsD;AAE9F,OAAO,MAAMC,eAAeH;IAC1B,OAAgBI,cAAc,2CAA0C;IAExE,OAAgBC,WAAmC;QACjD;YACEC,SAAS;YACTF,aAAa;QACf;KACD,CAAA;IAED,OAAgBG,QAAQ,CAAC,EAAqB;IAE9C,MAAaC,MAAqB;QAChC,8CAA8C;QAC9C,MAAM,IAAI,CAACC,KAAK,CAACN;QAEjB,IAAI;YACF,MAAMO,SAAS,MAAMT,WAAW;gBAC9BU,QAAQ;YACV;YAEA,IAAI,CAACC,GAAG,CAACF,OAAOG,OAAO;YAEvB,IAAIH,OAAOI,OAAO,EAAE;gBAClB,IAAI,CAACF,GAAG,CAAC,CAAC,EAAE,EAAEV,0BAA0B,YAAY;YACtD;QACF,EAAE,OAAOa,KAAc;YACrB,MAAMF,UAAUE,eAAeC,QAAQD,IAAIF,OAAO,GAAG;YACrD,IAAI,CAACI,KAAK,CAACJ,SAAS;gBAACK,MAAM;YAAC;QAC9B;IACF;AACF"}
@@ -14,9 +14,7 @@ export class Status extends SanityCommand {
14
14
  async run() {
15
15
  // Parse to ensure no invalid flags are passed
16
16
  await this.parse(Status);
17
- const consentInfo = await resolveConsent({
18
- env: process.env
19
- });
17
+ const consentInfo = await resolveConsent();
20
18
  const statusMessage = getStatusMessage(consentInfo);
21
19
  const learnMoreMessage = getLearnMoreMessage(consentInfo.status);
22
20
  this.log(statusMessage);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/commands/telemetry/status.ts"],"sourcesContent":["import {Command} from '@oclif/core'\nimport {type FlagInput} from '@oclif/core/interfaces'\nimport {SanityCommand} from '@sanity/cli-core'\n\nimport {getLearnMoreMessage} from '../../actions/telemetry/getLearnMoreMessage.js'\nimport {getStatusMessage} from '../../actions/telemetry/getStatusMessage.js'\nimport {resolveConsent} from '../../actions/telemetry/resolveConsent.js'\n\nexport class Status extends SanityCommand<typeof Status> {\n static override description = 'Check telemetry consent status for your logged in user'\n\n static override examples: Array<Command.Example> = [\n {\n command: '<%= config.bin %> telemetry <%= command.id %>',\n description: 'Check telemetry consent status for your logged in user',\n },\n ]\n\n static override flags = {} satisfies FlagInput\n\n public async run(): Promise<void> {\n // Parse to ensure no invalid flags are passed\n await this.parse(Status)\n\n const consentInfo = await resolveConsent({env: process.env})\n\n const statusMessage = getStatusMessage(consentInfo)\n const learnMoreMessage = getLearnMoreMessage(consentInfo.status)\n\n this.log(statusMessage)\n this.log(`\\n${learnMoreMessage}`)\n }\n}\n"],"names":["SanityCommand","getLearnMoreMessage","getStatusMessage","resolveConsent","Status","description","examples","command","flags","run","parse","consentInfo","env","process","statusMessage","learnMoreMessage","status","log"],"mappings":"AAEA,SAAQA,aAAa,QAAO,mBAAkB;AAE9C,SAAQC,mBAAmB,QAAO,iDAAgD;AAClF,SAAQC,gBAAgB,QAAO,8CAA6C;AAC5E,SAAQC,cAAc,QAAO,4CAA2C;AAExE,OAAO,MAAMC,eAAeJ;IAC1B,OAAgBK,cAAc,yDAAwD;IAEtF,OAAgBC,WAAmC;QACjD;YACEC,SAAS;YACTF,aAAa;QACf;KACD,CAAA;IAED,OAAgBG,QAAQ,CAAC,EAAqB;IAE9C,MAAaC,MAAqB;QAChC,8CAA8C;QAC9C,MAAM,IAAI,CAACC,KAAK,CAACN;QAEjB,MAAMO,cAAc,MAAMR,eAAe;YAACS,KAAKC,QAAQD,GAAG;QAAA;QAE1D,MAAME,gBAAgBZ,iBAAiBS;QACvC,MAAMI,mBAAmBd,oBAAoBU,YAAYK,MAAM;QAE/D,IAAI,CAACC,GAAG,CAACH;QACT,IAAI,CAACG,GAAG,CAAC,CAAC,EAAE,EAAEF,kBAAkB;IAClC;AACF"}
1
+ {"version":3,"sources":["../../../src/commands/telemetry/status.ts"],"sourcesContent":["import {Command} from '@oclif/core'\nimport {type FlagInput} from '@oclif/core/interfaces'\nimport {SanityCommand} from '@sanity/cli-core'\n\nimport {getLearnMoreMessage} from '../../actions/telemetry/getLearnMoreMessage.js'\nimport {getStatusMessage} from '../../actions/telemetry/getStatusMessage.js'\nimport {resolveConsent} from '../../actions/telemetry/resolveConsent.js'\n\nexport class Status extends SanityCommand<typeof Status> {\n static override description = 'Check telemetry consent status for your logged in user'\n\n static override examples: Array<Command.Example> = [\n {\n command: '<%= config.bin %> telemetry <%= command.id %>',\n description: 'Check telemetry consent status for your logged in user',\n },\n ]\n\n static override flags = {} satisfies FlagInput\n\n public async run(): Promise<void> {\n // Parse to ensure no invalid flags are passed\n await this.parse(Status)\n\n const consentInfo = await resolveConsent()\n\n const statusMessage = getStatusMessage(consentInfo)\n const learnMoreMessage = getLearnMoreMessage(consentInfo.status)\n\n this.log(statusMessage)\n this.log(`\\n${learnMoreMessage}`)\n }\n}\n"],"names":["SanityCommand","getLearnMoreMessage","getStatusMessage","resolveConsent","Status","description","examples","command","flags","run","parse","consentInfo","statusMessage","learnMoreMessage","status","log"],"mappings":"AAEA,SAAQA,aAAa,QAAO,mBAAkB;AAE9C,SAAQC,mBAAmB,QAAO,iDAAgD;AAClF,SAAQC,gBAAgB,QAAO,8CAA6C;AAC5E,SAAQC,cAAc,QAAO,4CAA2C;AAExE,OAAO,MAAMC,eAAeJ;IAC1B,OAAgBK,cAAc,yDAAwD;IAEtF,OAAgBC,WAAmC;QACjD;YACEC,SAAS;YACTF,aAAa;QACf;KACD,CAAA;IAED,OAAgBG,QAAQ,CAAC,EAAqB;IAE9C,MAAaC,MAAqB;QAChC,8CAA8C;QAC9C,MAAM,IAAI,CAACC,KAAK,CAACN;QAEjB,MAAMO,cAAc,MAAMR;QAE1B,MAAMS,gBAAgBV,iBAAiBS;QACvC,MAAME,mBAAmBZ,oBAAoBU,YAAYG,MAAM;QAE/D,IAAI,CAACC,GAAG,CAACH;QACT,IAAI,CAACG,GAAG,CAAC,CAAC,EAAE,EAAEF,kBAAkB;IAClC;AACF"}
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ export declare function runFlushWorker(): Promise<void>;
@@ -0,0 +1,22 @@
1
+ #!/usr/bin/env node
2
+ import { resolveConsent } from '../../actions/telemetry/resolveConsent.js';
3
+ import { sendEvents } from '../../services/telemetry.js';
4
+ import { flushTelemetryFiles } from '../../telemetry/store/flushTelemetryFiles.js';
5
+ export async function runFlushWorker() {
6
+ await flushTelemetryFiles({
7
+ resolveConsent,
8
+ sendEvents
9
+ });
10
+ }
11
+ // Only run if executed directly (not imported)
12
+ if (import.meta.url === `file://${process.argv[1]}`) {
13
+ try {
14
+ await runFlushWorker();
15
+ process.exit(0);
16
+ } catch {
17
+ // Silently exit - don't block parent process
18
+ process.exit(1);
19
+ }
20
+ }
21
+
22
+ //# sourceMappingURL=flushTelemetry.worker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/hooks/prerun/flushTelemetry.worker.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport {resolveConsent} from '../../actions/telemetry/resolveConsent.js'\nimport {sendEvents} from '../../services/telemetry.js'\nimport {flushTelemetryFiles} from '../../telemetry/store/flushTelemetryFiles.js'\n\nexport async function runFlushWorker() {\n await flushTelemetryFiles({resolveConsent, sendEvents})\n}\n\n// Only run if executed directly (not imported)\nif (import.meta.url === `file://${process.argv[1]}`) {\n try {\n await runFlushWorker()\n process.exit(0)\n } catch {\n // Silently exit - don't block parent process\n process.exit(1)\n }\n}\n"],"names":["resolveConsent","sendEvents","flushTelemetryFiles","runFlushWorker","url","process","argv","exit"],"mappings":";AAEA,SAAQA,cAAc,QAAO,4CAA2C;AACxE,SAAQC,UAAU,QAAO,8BAA6B;AACtD,SAAQC,mBAAmB,QAAO,+CAA8C;AAEhF,OAAO,eAAeC;IACpB,MAAMD,oBAAoB;QAACF;QAAgBC;IAAU;AACvD;AAEA,+CAA+C;AAC/C,IAAI,YAAYG,GAAG,KAAK,CAAC,OAAO,EAAEC,QAAQC,IAAI,CAAC,EAAE,EAAE,EAAE;IACnD,IAAI;QACF,MAAMH;QACNE,QAAQE,IAAI,CAAC;IACf,EAAE,OAAM;QACN,6CAA6C;QAC7CF,QAAQE,IAAI,CAAC;IACf;AACF"}
@@ -1,7 +1,71 @@
1
+ import { spawn } from 'node:child_process';
2
+ import { fileURLToPath } from 'node:url';
3
+ import { debug, findProjectRoot, getCliConfig } from '@sanity/cli-core';
4
+ import { createSessionId } from '@sanity/telemetry';
5
+ import { resolveConsent } from '../../actions/telemetry/resolveConsent.js';
6
+ import { telemetryDebug } from '../../actions/telemetry/telemetryDebug.js';
1
7
  import { telemetryDisclosure } from '../../actions/telemetry/telemetryDisclosure.js';
2
- export const setupTelemetry = async function() {
8
+ import { CliCommandTelemetry } from '../../telemetry/cli.telemetry.js';
9
+ import { createTelemetryStore } from '../../telemetry/store/createTelemetryStore.js';
10
+ import { detectRuntime } from '../../util/detectRuntime.js';
11
+ import { parseArguments } from '../../util/parseArguments.js';
12
+ export const setupTelemetry = async function({ config }) {
3
13
  // Show telemetry disclosure
4
14
  telemetryDisclosure();
15
+ const sessionId = createSessionId();
16
+ const store = createTelemetryStore(sessionId, {
17
+ resolveConsent
18
+ });
19
+ const projectRoot = await findProjectRoot(process.cwd());
20
+ const cliConfig = await getCliConfig(projectRoot.directory);
21
+ store.logger.updateUserProperties({
22
+ cliVersion: config.version,
23
+ cpuArchitecture: process.arch,
24
+ dataset: cliConfig?.api?.dataset,
25
+ machinePlatform: process.platform,
26
+ projectId: cliConfig?.api?.projectId,
27
+ runtime: detectRuntime(),
28
+ runtimeVersion: process.version
29
+ });
30
+ const args = parseArguments();
31
+ const traceOptions = {
32
+ commandArguments: args.argsWithoutOptions,
33
+ coreOptions: {
34
+ debug: args.coreOptions.debug ?? undefined,
35
+ help: args.coreOptions.help ?? undefined,
36
+ version: args.coreOptions.version ?? undefined
37
+ },
38
+ extraArguments: args.extraArguments,
39
+ groupOrCommand: args.groupOrCommand
40
+ };
41
+ telemetryDebug('Starting command trace', traceOptions);
42
+ const cliCommandTrace = store.logger.trace(CliCommandTelemetry, traceOptions);
43
+ cliCommandTrace.start();
44
+ // Handle process exit - complete trace and spawn worker to flush all telemetry
45
+ process.once('exit', (status)=>{
46
+ if (status === 0) {
47
+ cliCommandTrace.complete();
48
+ } else {
49
+ // TODO: Properly handle errors
50
+ // https://oclif.io/docs/error_handling/#error-handling-in-the-catch-method
51
+ cliCommandTrace.error(new Error('Process exited with status ' + status));
52
+ }
53
+ const workerPath = fileURLToPath(new URL('flushTelemetry.worker.js', import.meta.url));
54
+ telemetryDebug(`Spawning "${process.execPath} ${workerPath}"`);
55
+ // Spawn detached worker to flush all telemetry files
56
+ // unref will ensure the child process can keep doing work even after the parent process exits
57
+ spawn(process.execPath, [
58
+ workerPath
59
+ ], {
60
+ detached: true,
61
+ env: {
62
+ ...process.env,
63
+ SANITY_TELEMETRY_PROJECT_ID: cliConfig?.api?.projectId || ''
64
+ },
65
+ // If debug is enabled, spawn the worker with stdio inherit to see the output
66
+ stdio: debug.enabled ? 'inherit' : 'ignore'
67
+ }).unref();
68
+ });
5
69
  };
6
70
 
7
71
  //# sourceMappingURL=setupTelemetry.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/hooks/prerun/setupTelemetry.ts"],"sourcesContent":["import {type Hook} from '@oclif/core'\n\nimport {telemetryDisclosure} from '../../actions/telemetry/telemetryDisclosure.js'\n\nexport const setupTelemetry: Hook.Prerun = async function () {\n // Show telemetry disclosure\n telemetryDisclosure()\n}\n"],"names":["telemetryDisclosure","setupTelemetry"],"mappings":"AAEA,SAAQA,mBAAmB,QAAO,iDAAgD;AAElF,OAAO,MAAMC,iBAA8B;IACzC,4BAA4B;IAC5BD;AACF,EAAC"}
1
+ {"version":3,"sources":["../../../src/hooks/prerun/setupTelemetry.ts"],"sourcesContent":["import {spawn} from 'node:child_process'\nimport {fileURLToPath} from 'node:url'\n\nimport {type Hook} from '@oclif/core'\nimport {debug, findProjectRoot, getCliConfig} from '@sanity/cli-core'\nimport {createSessionId} from '@sanity/telemetry'\n\nimport {resolveConsent} from '../../actions/telemetry/resolveConsent.js'\nimport {telemetryDebug} from '../../actions/telemetry/telemetryDebug.js'\nimport {telemetryDisclosure} from '../../actions/telemetry/telemetryDisclosure.js'\nimport {CliCommandTelemetry, type CLITraceData} from '../../telemetry/cli.telemetry.js'\nimport {createTelemetryStore} from '../../telemetry/store/createTelemetryStore.js'\nimport {detectRuntime} from '../../util/detectRuntime.js'\nimport {parseArguments} from '../../util/parseArguments.js'\n\nexport const setupTelemetry: Hook.Prerun = async function ({config}) {\n // Show telemetry disclosure\n telemetryDisclosure()\n\n const sessionId = createSessionId()\n\n const store = createTelemetryStore(sessionId, {\n resolveConsent,\n })\n\n const projectRoot = await findProjectRoot(process.cwd())\n const cliConfig = await getCliConfig(projectRoot.directory)\n\n store.logger.updateUserProperties({\n cliVersion: config.version,\n cpuArchitecture: process.arch,\n dataset: cliConfig?.api?.dataset,\n machinePlatform: process.platform,\n projectId: cliConfig?.api?.projectId,\n runtime: detectRuntime(),\n runtimeVersion: process.version,\n })\n\n const args = parseArguments()\n\n const traceOptions: CLITraceData = {\n commandArguments: args.argsWithoutOptions,\n coreOptions: {\n debug: args.coreOptions.debug ?? undefined,\n help: args.coreOptions.help ?? undefined,\n version: args.coreOptions.version ?? undefined,\n },\n extraArguments: args.extraArguments,\n groupOrCommand: args.groupOrCommand,\n }\n\n telemetryDebug('Starting command trace', traceOptions)\n\n const cliCommandTrace = store.logger.trace(CliCommandTelemetry, traceOptions)\n cliCommandTrace.start()\n\n // Handle process exit - complete trace and spawn worker to flush all telemetry\n process.once('exit', (status) => {\n if (status === 0) {\n cliCommandTrace.complete()\n } else {\n // TODO: Properly handle errors\n // https://oclif.io/docs/error_handling/#error-handling-in-the-catch-method\n cliCommandTrace.error(new Error('Process exited with status ' + status))\n }\n\n const workerPath = fileURLToPath(new URL('flushTelemetry.worker.js', import.meta.url))\n telemetryDebug(`Spawning \"${process.execPath} ${workerPath}\"`)\n\n // Spawn detached worker to flush all telemetry files\n // unref will ensure the child process can keep doing work even after the parent process exits\n spawn(process.execPath, [workerPath], {\n detached: true,\n env: {\n ...process.env,\n SANITY_TELEMETRY_PROJECT_ID: cliConfig?.api?.projectId || '',\n },\n // If debug is enabled, spawn the worker with stdio inherit to see the output\n stdio: debug.enabled ? 'inherit' : 'ignore',\n }).unref()\n })\n}\n"],"names":["spawn","fileURLToPath","debug","findProjectRoot","getCliConfig","createSessionId","resolveConsent","telemetryDebug","telemetryDisclosure","CliCommandTelemetry","createTelemetryStore","detectRuntime","parseArguments","setupTelemetry","config","sessionId","store","projectRoot","process","cwd","cliConfig","directory","logger","updateUserProperties","cliVersion","version","cpuArchitecture","arch","dataset","api","machinePlatform","platform","projectId","runtime","runtimeVersion","args","traceOptions","commandArguments","argsWithoutOptions","coreOptions","undefined","help","extraArguments","groupOrCommand","cliCommandTrace","trace","start","once","status","complete","error","Error","workerPath","URL","url","execPath","detached","env","SANITY_TELEMETRY_PROJECT_ID","stdio","enabled","unref"],"mappings":"AAAA,SAAQA,KAAK,QAAO,qBAAoB;AACxC,SAAQC,aAAa,QAAO,WAAU;AAGtC,SAAQC,KAAK,EAAEC,eAAe,EAAEC,YAAY,QAAO,mBAAkB;AACrE,SAAQC,eAAe,QAAO,oBAAmB;AAEjD,SAAQC,cAAc,QAAO,4CAA2C;AACxE,SAAQC,cAAc,QAAO,4CAA2C;AACxE,SAAQC,mBAAmB,QAAO,iDAAgD;AAClF,SAAQC,mBAAmB,QAA0B,mCAAkC;AACvF,SAAQC,oBAAoB,QAAO,gDAA+C;AAClF,SAAQC,aAAa,QAAO,8BAA6B;AACzD,SAAQC,cAAc,QAAO,+BAA8B;AAE3D,OAAO,MAAMC,iBAA8B,eAAgB,EAACC,MAAM,EAAC;IACjE,4BAA4B;IAC5BN;IAEA,MAAMO,YAAYV;IAElB,MAAMW,QAAQN,qBAAqBK,WAAW;QAC5CT;IACF;IAEA,MAAMW,cAAc,MAAMd,gBAAgBe,QAAQC,GAAG;IACrD,MAAMC,YAAY,MAAMhB,aAAaa,YAAYI,SAAS;IAE1DL,MAAMM,MAAM,CAACC,oBAAoB,CAAC;QAChCC,YAAYV,OAAOW,OAAO;QAC1BC,iBAAiBR,QAAQS,IAAI;QAC7BC,SAASR,WAAWS,KAAKD;QACzBE,iBAAiBZ,QAAQa,QAAQ;QACjCC,WAAWZ,WAAWS,KAAKG;QAC3BC,SAAStB;QACTuB,gBAAgBhB,QAAQO,OAAO;IACjC;IAEA,MAAMU,OAAOvB;IAEb,MAAMwB,eAA6B;QACjCC,kBAAkBF,KAAKG,kBAAkB;QACzCC,aAAa;YACXrC,OAAOiC,KAAKI,WAAW,CAACrC,KAAK,IAAIsC;YACjCC,MAAMN,KAAKI,WAAW,CAACE,IAAI,IAAID;YAC/Bf,SAASU,KAAKI,WAAW,CAACd,OAAO,IAAIe;QACvC;QACAE,gBAAgBP,KAAKO,cAAc;QACnCC,gBAAgBR,KAAKQ,cAAc;IACrC;IAEApC,eAAe,0BAA0B6B;IAEzC,MAAMQ,kBAAkB5B,MAAMM,MAAM,CAACuB,KAAK,CAACpC,qBAAqB2B;IAChEQ,gBAAgBE,KAAK;IAErB,+EAA+E;IAC/E5B,QAAQ6B,IAAI,CAAC,QAAQ,CAACC;QACpB,IAAIA,WAAW,GAAG;YAChBJ,gBAAgBK,QAAQ;QAC1B,OAAO;YACL,+BAA+B;YAC/B,2EAA2E;YAC3EL,gBAAgBM,KAAK,CAAC,IAAIC,MAAM,gCAAgCH;QAClE;QAEA,MAAMI,aAAanD,cAAc,IAAIoD,IAAI,4BAA4B,YAAYC,GAAG;QACpF/C,eAAe,CAAC,UAAU,EAAEW,QAAQqC,QAAQ,CAAC,CAAC,EAAEH,WAAW,CAAC,CAAC;QAE7D,qDAAqD;QACrD,8FAA8F;QAC9FpD,MAAMkB,QAAQqC,QAAQ,EAAE;YAACH;SAAW,EAAE;YACpCI,UAAU;YACVC,KAAK;gBACH,GAAGvC,QAAQuC,GAAG;gBACdC,6BAA6BtC,WAAWS,KAAKG,aAAa;YAC5D;YACA,6EAA6E;YAC7E2B,OAAOzD,MAAM0D,OAAO,GAAG,YAAY;QACrC,GAAGC,KAAK;IACV;AACF,EAAC"}
@@ -0,0 +1,5 @@
1
+ export declare function promptForEmbeddedStudio(): Promise<boolean>;
2
+ export declare function promptForStudioPath(): Promise<string>;
3
+ export declare function promptForNextTemplate(): Promise<'blog' | 'clean'>;
4
+ export declare function promptForAppendEnv(envFilename: string): Promise<boolean>;
5
+ export declare function promptForConfigFiles(): Promise<boolean>;