@slicemachine/init 2.10.44-beta.3 → 2.10.44-beta.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/slicemachine-init.js +28 -0
- package/dist/SliceMachineInitProcess.cjs +12 -3
- package/dist/SliceMachineInitProcess.cjs.map +1 -1
- package/dist/SliceMachineInitProcess.js +12 -3
- package/dist/SliceMachineInitProcess.js.map +1 -1
- package/dist/_node_modules/@babel/code-frame/lib/index.cjs +1 -1
- package/dist/_node_modules/@babel/code-frame/lib/index.js +1 -1
- package/dist/_node_modules/@babel/helper-validator-identifier/lib/index.cjs +1 -1
- package/dist/_node_modules/@babel/helper-validator-identifier/lib/index.js +1 -1
- package/dist/_node_modules/@babel/highlight/lib/index.cjs +3 -3
- package/dist/_node_modules/@babel/highlight/lib/index.js +3 -3
- package/dist/_node_modules/@nodelib/fs.scandir/out/providers/async.cjs +1 -1
- package/dist/_node_modules/@nodelib/fs.scandir/out/providers/async.js +1 -1
- package/dist/_node_modules/@nodelib/fs.scandir/out/providers/sync.cjs +1 -1
- package/dist/_node_modules/@nodelib/fs.scandir/out/providers/sync.js +1 -1
- package/dist/_node_modules/@nodelib/fs.scandir/out/settings.cjs +1 -1
- package/dist/_node_modules/@nodelib/fs.scandir/out/settings.js +1 -1
- package/dist/_node_modules/@nodelib/fs.stat/out/index.cjs +1 -1
- package/dist/_node_modules/@nodelib/fs.stat/out/index.js +1 -1
- package/dist/_node_modules/@nodelib/fs.walk/out/index.cjs +1 -1
- package/dist/_node_modules/@nodelib/fs.walk/out/index.js +1 -1
- package/dist/_node_modules/fast-glob/out/readers/async.cjs +1 -1
- package/dist/_node_modules/fast-glob/out/readers/async.js +1 -1
- package/dist/_node_modules/fast-glob/out/readers/reader.cjs +1 -1
- package/dist/_node_modules/fast-glob/out/readers/reader.js +1 -1
- package/dist/_node_modules/fast-glob/out/readers/stream.cjs +2 -2
- package/dist/_node_modules/fast-glob/out/readers/stream.js +2 -2
- package/dist/_node_modules/fast-glob/out/readers/sync.cjs +2 -2
- package/dist/_node_modules/fast-glob/out/readers/sync.js +2 -2
- package/dist/_node_modules/js-tokens/index.cjs +1 -1
- package/dist/_node_modules/js-tokens/index.js +1 -1
- package/dist/_node_modules/path-key/index.cjs +1 -1
- package/dist/_node_modules/path-key/index.js +1 -1
- package/dist/_node_modules/read-pkg/_node_modules/hosted-git-info/index.cjs +1 -1
- package/dist/_node_modules/read-pkg/_node_modules/hosted-git-info/index.js +1 -1
- package/dist/_virtual/index13.cjs +2 -2
- package/dist/_virtual/index13.js +2 -2
- package/dist/_virtual/index15.cjs +2 -2
- package/dist/_virtual/index15.js +2 -2
- package/dist/_virtual/index16.cjs +2 -2
- package/dist/_virtual/index16.js +2 -2
- package/dist/_virtual/index17.cjs +2 -2
- package/dist/_virtual/index17.js +2 -2
- package/dist/_virtual/index18.cjs +2 -2
- package/dist/_virtual/index18.js +2 -2
- package/dist/_virtual/index19.cjs +2 -2
- package/dist/_virtual/index19.js +2 -2
- package/dist/lib/starters.cjs +5 -4
- package/dist/lib/starters.cjs.map +1 -1
- package/dist/lib/starters.js +5 -4
- package/dist/lib/starters.js.map +1 -1
- package/dist/packages/init/package.json.cjs +6 -1
- package/dist/packages/init/package.json.cjs.map +1 -1
- package/dist/packages/init/package.json.js +6 -1
- package/dist/packages/init/package.json.js.map +1 -1
- package/package.json +6 -3
- package/src/SliceMachineInitProcess.ts +21 -3
- package/src/lib/starters.ts +5 -4
package/bin/slicemachine-init.js
CHANGED
|
@@ -1,3 +1,31 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
|
|
3
|
+
import semver from "semver";
|
|
4
|
+
import { readFileSync } from "node:fs";
|
|
5
|
+
import { fileURLToPath } from "node:url";
|
|
6
|
+
import { dirname, join } from "node:path";
|
|
7
|
+
import chalk from "chalk";
|
|
8
|
+
|
|
9
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
10
|
+
const pkg = JSON.parse(
|
|
11
|
+
readFileSync(join(__dirname, "../package.json"), "utf8"),
|
|
12
|
+
);
|
|
13
|
+
|
|
14
|
+
const requiredVersion = pkg.engines.node;
|
|
15
|
+
|
|
16
|
+
if (!requiredVersion) {
|
|
17
|
+
throw new Error("Missing engines.node in package.json.");
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const currentVersion = process.version;
|
|
21
|
+
|
|
22
|
+
if (!semver.satisfies(currentVersion, requiredVersion)) {
|
|
23
|
+
console.warn(
|
|
24
|
+
chalk.yellow(
|
|
25
|
+
`⚠️ Warning: You are using Node.js ${currentVersion}, but this tool requires ${requiredVersion}.\n` +
|
|
26
|
+
` Some features may not work correctly. Please upgrade your Node.js version.\n`,
|
|
27
|
+
),
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
|
|
3
31
|
import("../dist/cli.cjs");
|
|
@@ -358,7 +358,7 @@ ${logSymbols.error} Dependency installation failed, try again with:
|
|
|
358
358
|
}
|
|
359
359
|
getLoggingInTitle(subtitle, ...extra) {
|
|
360
360
|
return `Logging in to Prismic...
|
|
361
|
-
|
|
361
|
+
|
|
362
362
|
███████████████████████████████████████████████████████████████████████████
|
|
363
363
|
|
|
364
364
|
${subtitle ? `* * ${subtitle}` : ""}
|
|
@@ -608,11 +608,20 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
|
|
|
608
608
|
task: async (_, task) => {
|
|
609
609
|
assertExists.assertExists(this.context.repository, "Repository selection must be available through context to run `createNewRepository`");
|
|
610
610
|
assertExists.assertExists(this.context.framework, "Project framework must be available through context to run `createNewRepository`");
|
|
611
|
+
let starterId = this.context.starterId;
|
|
612
|
+
if (!starterId && this.options.starter) {
|
|
613
|
+
const frameworkToMinimalStarter = {
|
|
614
|
+
next: "next_minimal",
|
|
615
|
+
nuxt: "nuxt_minimal",
|
|
616
|
+
sveltekit: "sveltekit_minimal"
|
|
617
|
+
};
|
|
618
|
+
starterId = frameworkToMinimalStarter[this.context.framework.wroomTelemetryID];
|
|
619
|
+
}
|
|
611
620
|
try {
|
|
612
621
|
await this.manager.prismicRepository.create({
|
|
613
622
|
domain: this.context.repository.domain,
|
|
614
623
|
framework: this.context.framework.wroomTelemetryID,
|
|
615
|
-
starterId
|
|
624
|
+
starterId
|
|
616
625
|
});
|
|
617
626
|
} catch (error) {
|
|
618
627
|
await this.manager.user.logout();
|
|
@@ -623,7 +632,7 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
|
|
|
623
632
|
await this.manager.prismicRepository.create({
|
|
624
633
|
domain: this.context.repository.domain,
|
|
625
634
|
framework: this.context.framework.wroomTelemetryID,
|
|
626
|
-
starterId
|
|
635
|
+
starterId
|
|
627
636
|
});
|
|
628
637
|
}
|
|
629
638
|
this.context.repository.exists = true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SliceMachineInitProcess.cjs","sources":["../../src/SliceMachineInitProcess.ts"],"sourcesContent":["import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\n\nimport chalk from \"chalk\";\n\nimport { execaCommand, type ExecaChildProcess } from \"execa\";\n\nimport open from \"open\";\nimport logSymbols from \"log-symbols\";\nimport { globby } from \"globby\";\nimport { downloadTemplate } from \"giget\";\nimport pLimit from \"p-limit\";\n\nimport {\n\tcreateSliceMachineManager,\n\tPrismicUserProfile,\n\tPrismicRepository,\n\tSliceMachineManager,\n\tPackageManager,\n\tStarterId,\n\tREPOSITORY_NAME_VALIDATION,\n} from \"@slicemachine/manager\";\n\nimport pkg from \"../package.json\";\nimport { detectFramework, Framework } from \"./lib/framework\";\nimport { getRunScriptCommand } from \"./lib/getRunScriptCommand\";\nimport { getExecuteCommand } from \"./lib/getExecuteCommand\";\nimport {\n\tgetRandomRepositoryDomain,\n\tformatRepositoryDomain,\n\tvalidateRepositoryDomain,\n\tvalidateRepositoryDomainAndAvailability,\n\tgetErrorMessageForRepositoryDomainValidation,\n} from \"./lib/repositoryDomain\";\nimport { listr, listrRun } from \"./lib/listr\";\nimport { prompt } from \"./lib/prompt\";\nimport { assertExists } from \"./lib/assertExists\";\nimport {\n\tGIGET_ORGANIZATION,\n\tGIGET_PROVIDER,\n\tSLICE_MACHINE_INIT_USER_AGENT,\n\tSTART_SCRIPT_KEY,\n\tSTART_SCRIPT_VALUE,\n} from \"./constants\";\nimport { detectStarterId } from \"./lib/starters\";\nimport { setupSentry } from \"./lib/setupSentry\";\nimport { trackSentryError } from \"./lib/sentryErrorHandlers\";\nimport { updateSentryContext } from \"./lib/updateSentryContext\";\n\nexport type SliceMachineInitProcessOptions = {\n\trepository?: string;\n\tstarter?: string;\n\tdirectoryName?: string;\n\tpush?: boolean;\n\tpushSlices?: boolean;\n\tpushCustomTypes?: boolean;\n\tpushDocuments?: boolean;\n\tstartSlicemachine?: boolean;\n\tcwd?: string;\n} & Record<string, unknown>;\n\nconst DEFAULT_OPTIONS: SliceMachineInitProcessOptions = {\n\tpush: true,\n\tpushSlices: true,\n\tpushCustomTypes: true,\n\tpushDocuments: true,\n\tstartSlicemachine: true,\n};\n\nexport const createSliceMachineInitProcess = (\n\toptions?: SliceMachineInitProcessOptions,\n): SliceMachineInitProcess => {\n\treturn new SliceMachineInitProcess(options);\n};\n\ntype SliceMachineInitProcessContext = {\n\tframework?: Framework;\n\tpackageManager?: PackageManager;\n\tinstallProcess?: ExecaChildProcess;\n\tuserProfile?: PrismicUserProfile;\n\tuserRepositories?: PrismicRepository[];\n\trepository?: {\n\t\tdomain: string;\n\t\texists: boolean;\n\t};\n\tprojectInitialization?: {\n\t\tpatchedScript?: boolean;\n\t};\n\tstarterId?: StarterId;\n};\n\nexport class SliceMachineInitProcess {\n\tprotected options: SliceMachineInitProcessOptions;\n\tprotected manager: SliceMachineManager;\n\n\tprotected context: SliceMachineInitProcessContext;\n\n\tconstructor(options?: SliceMachineInitProcessOptions) {\n\t\tthis.options = { ...DEFAULT_OPTIONS, ...options };\n\t\tthis.manager = createSliceMachineManager({ cwd: options?.cwd });\n\n\t\tthis.context = {};\n\t}\n\n\tasync run(): Promise<void> {\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGray(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"→\",\n\t\t\t)} Initializing\\n`,\n\t\t);\n\n\t\ttry {\n\t\t\ttry {\n\t\t\t\tawait setupSentry();\n\t\t\t} catch (error) {\n\t\t\t\t// noop - We don't want to stop the user from using Slice Machine\n\t\t\t\t// because of failed tracking set up. We probably couldn't determine the\n\t\t\t\t// Sentry environment.\n\t\t\t}\n\t\t\tif (this.options.starter) {\n\t\t\t\tawait this.copyStarter();\n\t\t\t} else if (this.options.directoryName) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${logSymbols.warning} --directory-name has no effect because --starter is not specified\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (await this.manager.telemetry.checkIsTelemetryEnabled()) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${\n\t\t\t\t\t\tlogSymbols.info\n\t\t\t\t\t} We collect telemetry data to improve user experience.\\n Learn more: ${chalk.cyan(\n\t\t\t\t\t\t\"https://prismic.dev/slice-machine/telemetry\",\n\t\t\t\t\t)}\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tawait this.manager.telemetry.initTelemetry({\n\t\t\t\tappName: pkg.name,\n\t\t\t\tappVersion: pkg.version,\n\t\t\t});\n\n\t\t\tawait this.manager.telemetry.track({\n\t\t\t\tevent: \"command:init:start\",\n\t\t\t\trepository: this.options.repository,\n\t\t\t});\n\n\t\t\tawait this.detectEnvironment();\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.framework,\n\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.beginCoreDependenciesInstallation();\n\n\t\t\tif (this.options.repository) {\n\t\t\t\tawait this.useRepositoryFlag();\n\t\t\t} else {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tawait this.selectRepository();\n\t\t\t}\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.repository,\n\t\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.finishCoreDependenciesInstallation();\n\t\t\tawait this.upsertSliceMachineConfigurationAndStartPluginRunner();\n\n\t\t\tconst isLoginRequired = await this.checkIsLoginRequired();\n\t\t\tif (isLoginRequired) {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tif (this.context.repository.exists) {\n\t\t\t\t\tthis.validateWriteAccess();\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!this.context.repository.exists) {\n\t\t\t\tawait this.createNewRepository();\n\t\t\t\tawait this.setDefaultMasterLocale();\n\t\t\t}\n\n\t\t\tawait this.syncDataWithPrismic();\n\t\t\tawait this.initializeProject();\n\t\t\tawait this.initializePlugins();\n\t\t\tawait this.completeOnboardingSteps();\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\n\t\t\tthrow error;\n\t\t}\n\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework.sliceMachineTelemetryID,\n\t\t\trepository: this.context.repository.domain,\n\t\t\tsuccess: true,\n\t\t});\n\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGreen(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"→\",\n\t\t\t)} Initialization successful!\n\nContinue with next steps in Slice Machine.\n`,\n\t\t);\n\n\t\ttry {\n\t\t\tif (this.options.startSlicemachine) {\n\t\t\t\tconst runSmCommand = this.context.projectInitialization?.patchedScript\n\t\t\t\t\t? await getRunScriptCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"slicemachine\",\n\t\t\t\t\t })\n\t\t\t\t\t: await getExecuteCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"start-slicemachine\",\n\t\t\t\t\t });\n\n\t\t\t\tconst { startSlicemachine } = await prompt<\n\t\t\t\t\tboolean,\n\t\t\t\t\t\"startSlicemachine\"\n\t\t\t\t>({\n\t\t\t\t\ttype: \"confirm\",\n\t\t\t\t\tname: \"startSlicemachine\",\n\t\t\t\t\tmessage: `Run Slice Machine (${chalk.cyan(runSmCommand)})?`,\n\t\t\t\t\tinitial: true,\n\t\t\t\t});\n\n\t\t\t\tif (startSlicemachine) {\n\t\t\t\t\tconst commandReturnValue = await execaCommand(runSmCommand, {\n\t\t\t\t\t\tenv: { FORCE_COLOR: \"true\" },\n\t\t\t\t\t}).pipeStdout?.(process.stdout);\n\t\t\t\t\tif (commandReturnValue !== undefined) {\n\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\tconsole.log(commandReturnValue.stdout);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\t// Only track this error with Sentry, it's only the final convenience message\n\t\t\tawait this.trackSentryError(error);\n\t\t}\n\t}\n\n\tprotected async checkIsLoginRequired(): Promise<boolean> {\n\t\ttry {\n\t\t\tassertExists(this.context.repository, \"\");\n\t\t\tif (this.context.repository.exists === false) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tconst [slices, ctLibrary, documentsGlob] = await Promise.all([\n\t\t\t\tthis.readAllSlices(),\n\t\t\t\tthis.manager.customTypes.readCustomTypeLibrary(),\n\t\t\t\tthis.readDocuments(),\n\t\t\t]);\n\n\t\t\t// If repository exists, and there's anything to push\n\t\t\tif (\n\t\t\t\tslices.length > 0 ||\n\t\t\t\tctLibrary.ids.length > 0 ||\n\t\t\t\t(documentsGlob !== undefined && documentsGlob.documents.length > 0)\n\t\t\t) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// If repository exists, and there might be things to pull\n\t\t\tif (ctLibrary.ids.length === 0) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t} catch (error) {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\tprotected trackError = async (error: unknown): Promise<void> => {\n\t\tawait this.trackSentryError(error);\n\t\tawait this.trackTelemetryError(error);\n\t};\n\n\tprotected trackTelemetryError = async (error: unknown): Promise<void> => {\n\t\t// Transform error to string and prevent hitting Segment 500kb API limit or sending ridiculously long trace\n\t\tconst safeError = (\n\t\t\terror instanceof Error ? error.message : `${error}`\n\t\t).slice(0, 512);\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t\trepository: this.context.repository?.domain || \"\",\n\t\t\tsuccess: false,\n\t\t\terror: safeError,\n\t\t});\n\t};\n\n\tprotected trackSentryError = async (error: unknown): Promise<void> => {\n\t\tawait updateSentryContext({\n\t\t\tmanager: this.manager,\n\t\t\trepositoryName: this.context.repository?.domain || \"\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t});\n\t\ttrackSentryError(error);\n\t};\n\n\tprotected async copyStarter(): Promise<void> {\n\t\tconst dir = await this.getStarterDirectoryName();\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Copying starter...\\n\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tconst starter = this.options.starter;\n\n\t\t\t\t\tawait downloadTemplate(\n\t\t\t\t\t\t`${GIGET_PROVIDER}:${GIGET_ORGANIZATION}/${starter}#HEAD`,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tdir,\n\t\t\t\t\t\t},\n\t\t\t\t\t);\n\n\t\t\t\t\tprocess.chdir(dir);\n\t\t\t\t\tthis.manager.cwd = process.cwd();\n\n\t\t\t\t\ttask.title = \"Starter copied\\n\";\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async getStarterDirectoryName(): Promise<string> {\n\t\tlet directoryName: string;\n\t\tconst folderNames = await fs.readdir(process.cwd());\n\n\t\tif (\n\t\t\tthis.options.directoryName &&\n\t\t\t!folderNames.includes(this.options.directoryName)\n\t\t) {\n\t\t\t// Use provided directory\n\t\t\tdirectoryName = this.options.directoryName;\n\t\t} else if (\n\t\t\tthis.options.repository &&\n\t\t\t!folderNames.includes(this.options.repository)\n\t\t) {\n\t\t\t// Use repository name\n\t\t\tdirectoryName = this.options.repository;\n\t\t} else {\n\t\t\t// Use random name\n\t\t\tlet suggestedName: string;\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (folderNames.includes(suggestedName));\n\n\t\t\tconst { selectedDirectory } = await prompt<string, \"selectedDirectory\">({\n\t\t\t\ttype: \"text\",\n\t\t\t\tname: \"selectedDirectory\",\n\t\t\t\tmessage: \"Your starter directory name\",\n\t\t\t\tinitial: suggestedName,\n\t\t\t\tvalidate: async (rawDirectory: string) => {\n\t\t\t\t\tif (folderNames.includes(rawDirectory)) {\n\t\t\t\t\t\treturn \"Directory name already exists\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn true;\n\t\t\t\t},\n\t\t\t});\n\n\t\t\tdirectoryName = selectedDirectory;\n\t\t}\n\n\t\treturn directoryName;\n\t}\n\n\tprotected detectEnvironment(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Detecting environment...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting framework...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.framework = await detectFramework(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting package manager...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.packageManager =\n\t\t\t\t\t\t\t\t\tawait this.manager.project.detectPackageManager({\n\t\t\t\t\t\t\t\t\t\troot: this.manager.cwd,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\ttask.title = `Detected package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\tparentTask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)} and package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting starter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.starterId = await detectStarterId(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\tif (this.context.starterId) {\n\t\t\t\t\t\t\t\t\ttask.title = `Detected starter ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.starterId,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\ttask.title = \"No starter detected\";\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected beginCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Beginning core dependencies installation...\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\"Project package manager must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst { execaProcess } =\n\t\t\t\t\t\tawait this.manager.project.installDependencies({\n\t\t\t\t\t\t\tpackageManager: this.context.packageManager,\n\t\t\t\t\t\t\tdependencies: this.context.framework.devDependencies,\n\t\t\t\t\t\t\tdev: true,\n\t\t\t\t\t\t\t// Picked up later\n\t\t\t\t\t\t\tlog: () => {\n\t\t\t\t\t\t\t\t/* ... */\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\n\t\t\t\t\t// Fail hard if process fails\n\t\t\t\t\texecaProcess.catch(async (error) => {\n\t\t\t\t\t\tconst [_, ...argv1n] = process.argv;\n\t\t\t\t\t\t// Command the user used\n\t\t\t\t\t\tlet tryAgainCommand = [process.argv0, ...argv1n].join(\" \");\n\n\t\t\t\t\t\t// If the `repository` option wasn't used AND the repository was selected/created\n\t\t\t\t\t\tif (!this.options.repository && this.context.repository) {\n\t\t\t\t\t\t\ttryAgainCommand = `${tryAgainCommand} --repository=${this.context.repository.domain}`;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tawait this.trackError(error);\n\t\t\t\t\t\tconsole.error(\n\t\t\t\t\t\t\t`\\n\\n${error.shortMessage}\\n${error.stderr}\\n\\n${\n\t\t\t\t\t\t\t\tlogSymbols.error\n\t\t\t\t\t\t\t} Dependency installation failed, try again with:\\n\\n ${chalk.gray(\n\t\t\t\t\t\t\t\t\"$\",\n\t\t\t\t\t\t\t)} ${chalk.cyan(tryAgainCommand)}`,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tprocess.exit(1);\n\t\t\t\t\t});\n\n\t\t\t\t\tthis.context.installProcess = execaProcess;\n\n\t\t\t\t\ttask.title = `Began core dependencies installation with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)} ... (running in background)`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async fetchUserProfile(): Promise<void> {\n\t\tthis.context.userProfile = await this.manager.user.getProfile();\n\n\t\tawait this.manager.telemetry.identify({\n\t\t\tuserID: this.context.userProfile.shortId,\n\t\t\tintercomHash: this.context.userProfile.intercomHash,\n\t\t});\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:identify\",\n\t\t\trepository: this.options.repository,\n\t\t});\n\t}\n\n\tprotected async fetchUserRepositories(): Promise<void> {\n\t\tthis.context.userRepositories =\n\t\t\tawait this.manager.prismicRepository.readAll();\n\t}\n\n\tprotected validateWriteAccess(): void {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to validate write access\",\n\t\t);\n\t\tconst { domain } = this.context.repository;\n\t\tconst maybeRepository = this.context.userRepositories.find(\n\t\t\t(repository) => repository.domain === domain,\n\t\t);\n\n\t\tif (maybeRepository) {\n\t\t\tif (!this.manager.prismicRepository.hasWriteAccess(maybeRepository)) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Cannot run init command with repository ${chalk.cyan(\n\t\t\t\t\t\tmaybeRepository.domain,\n\t\t\t\t\t)}: you are not a developer or admin of this repository`,\n\t\t\t\t);\n\t\t\t}\n\t\t} else {\n\t\t\tthrow new Error(\n\t\t\t\t`Cannot validate write access for repository ${chalk.cyan(\n\t\t\t\t\tdomain,\n\t\t\t\t)}: you are not part of this repository`,\n\t\t\t);\n\t\t}\n\t}\n\n\tprotected getLoggingInTitle(subtitle?: string, ...extra: string[]): string {\n\t\treturn `Logging in to Prismic...\n\t\t\n███████████████████████████████████████████████████████████████████████████\n\n${subtitle ? `* * ${subtitle}` : \"\"}\n${extra.length ? `\\n${extra.map((line) => ` ${line}`).join(\"\\n\")}\\n` : \"\"}\n███████████████████████████████████████████████████████████████████████████\n`;\n\t}\n\n\tprotected loginAndFetchUserData(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: this.getLoggingInTitle(),\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\"Validating session...\");\n\t\t\t\t\tconst isLoggedIn = await this.manager.user.checkIsLoggedIn();\n\n\t\t\t\t\tif (!isLoggedIn) {\n\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\tchalk.cyan(\"Press any key to open the browser to login...\"),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\tawait this.waitingForLogin(({ url }) => {\n\t\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\t\tchalk.cyan(\"Opening browser, waiting for you to login...\"),\n\t\t\t\t\t\t\t\tchalk.yellow(\n\t\t\t\t\t\t\t\t\t\"If your browser did not open automatically, please use the url below:\",\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tparentTask.title = `Logged in`;\n\n\t\t\t\t\treturn listr(\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user profile...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserProfile();\n\t\t\t\t\t\t\t\t\tparentTask.title = `Logged in as ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.userProfile?.email,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user profile\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user repositories...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserRepositories();\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user repositories\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t],\n\t\t\t\t\t\t{ concurrent: true },\n\t\t\t\t\t);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async pressKeyToLogin(): Promise<void> {\n\t\tawait new Promise((resolve) => {\n\t\t\tconst initialRawMode = !!process.stdin.isRaw;\n\t\t\tprocess.stdin.setRawMode?.(true);\n\t\t\tprocess.stdin.resume();\n\t\t\tprocess.stdin.once(\"data\", (data: Buffer) => {\n\t\t\t\tprocess.stdin.setRawMode?.(initialRawMode);\n\t\t\t\tprocess.stdin.pause();\n\t\t\t\tresolve(data.toString(\"utf-8\"));\n\t\t\t});\n\t\t});\n\t}\n\n\tprotected async waitingForLogin(\n\t\tonListenCallback?: (\n\t\t\tsessionInfo: Awaited<\n\t\t\t\tReturnType<typeof this.manager.user.getLoginSessionInfo>\n\t\t\t>,\n\t\t) => void,\n\t): Promise<void> {\n\t\tconst sessionInfo = await this.manager.user.getLoginSessionInfo();\n\t\tawait this.manager.user.nodeLoginSession({\n\t\t\tport: sessionInfo.port,\n\t\t\tonListenCallback() {\n\t\t\t\topen(sessionInfo.url);\n\t\t\t\tonListenCallback?.(sessionInfo);\n\t\t\t},\n\t\t});\n\t}\n\n\tprotected useRepositoryFlag(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Flag ${chalk.cyan(\"repository\")} used, validating input...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.options.repository,\n\t\t\t\t\t\t\"Flag `repository` must be set to run `useRepositoryFlag`\",\n\t\t\t\t\t);\n\t\t\t\t\tconst domain = formatRepositoryDomain(this.options.repository);\n\t\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t\t});\n\n\t\t\t\t\tif (validation.LessThanMin || validation.MoreThanMax) {\n\t\t\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\t\t\tvalidation: {\n\t\t\t\t\t\t\t\t...validation,\n\t\t\t\t\t\t\t\t// We don't want to throw if repo already exists.\n\t\t\t\t\t\t\t\t// User most probably just created it via their dashboard.\n\t\t\t\t\t\t\t\tAlreadyExists: false,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (errorMessage) {\n\t\t\t\t\t\t\tthrow new Error(errorMessage);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Selected repository ${chalk.cyan(\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t)} (flag ${chalk.cyan(\"repository\")} used)`;\n\n\t\t\t\t\tthis.context.repository = {\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texists: validation.AlreadyExists ?? false,\n\t\t\t\t\t};\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async selectRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `selectRepository`\",\n\t\t);\n\n\t\tif (this.context.userRepositories.length) {\n\t\t\tawait this.trySelectExistingRepository();\n\t\t}\n\n\t\tif (!this.context.repository) {\n\t\t\tawait this.selectNewRepository();\n\t\t}\n\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`${logSymbols.success} Selected repository ${chalk.cyan(\n\t\t\t\tthis.context.repository.domain,\n\t\t\t)}`,\n\t\t);\n\t}\n\n\tprotected async trySelectExistingRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `trySelectExistingRepository`\",\n\t\t);\n\n\t\tconst { maybeDomain } = await prompt<string, \"maybeDomain\">({\n\t\t\ttype: \"select\",\n\t\t\tname: \"maybeDomain\",\n\t\t\tmessage: \"Pick a repository to connect to or choose to create a new one\",\n\t\t\twarn: \"You are not a developer or admin of this repository\",\n\t\t\tchoices: [\n\t\t\t\t{\n\t\t\t\t\ttitle: \"CREATE NEW\",\n\t\t\t\t\tdescription: \"Create a new Prismic repository\\n\",\n\t\t\t\t\tvalue: \"\",\n\t\t\t\t},\n\t\t\t\t...this.context.userRepositories\n\t\t\t\t\t.map((repository) => {\n\t\t\t\t\t\tconst hasWriteAccess =\n\t\t\t\t\t\t\tthis.manager.prismicRepository.hasWriteAccess(repository);\n\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\ttitle: `${repository.domain}${\n\t\t\t\t\t\t\t\thasWriteAccess ? \"\" : \" (Unauthorized)\"\n\t\t\t\t\t\t\t}`,\n\t\t\t\t\t\t\tdescription: `Connect to ${chalk.cyan(repository.domain)}`,\n\t\t\t\t\t\t\tvalue: repository.domain,\n\t\t\t\t\t\t\tdisabled: !hasWriteAccess,\n\t\t\t\t\t\t};\n\t\t\t\t\t})\n\t\t\t\t\t.sort((a, b) => (a.value > b.value ? 1 : -1)),\n\t\t\t],\n\t\t});\n\n\t\tif (maybeDomain) {\n\t\t\tthis.context.repository = {\n\t\t\t\tdomain: maybeDomain,\n\t\t\t\texists: true,\n\t\t\t};\n\t\t}\n\t}\n\n\tprotected async selectNewRepository(): Promise<void> {\n\t\tlet suggestedName = \"\";\n\n\t\t// TODO: Improve concurrency\n\t\tconst trySuggestName = async (name: string): Promise<string | void> => {\n\t\t\tif (name) {\n\t\t\t\tconst formattedName = formatRepositoryDomain(name);\n\n\t\t\t\tif (\n\t\t\t\t\t!validateRepositoryDomain({ domain: formattedName }).hasErrors &&\n\t\t\t\t\t!(await this.manager.prismicRepository.checkExists({\n\t\t\t\t\t\tdomain: formattedName,\n\t\t\t\t\t}))\n\t\t\t\t) {\n\t\t\t\t\treturn formattedName;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\t// 1. Try to suggest name after directory name\n\t\tconst maybeSuggestion = await trySuggestName(\n\t\t\tpath.basename(this.manager.cwd),\n\t\t);\n\t\tif (maybeSuggestion) {\n\t\t\tsuggestedName = maybeSuggestion;\n\t\t}\n\n\t\t// 2. Try to suggest name after package name\n\t\tif (!suggestedName) {\n\t\t\ttry {\n\t\t\t\tconst pkgJSONPath = path.join(this.manager.cwd, \"package.json\");\n\t\t\t\tconst pkg = JSON.parse(await fs.readFile(pkgJSONPath, \"utf-8\"));\n\n\t\t\t\tconst maybeSuggestion = await trySuggestName(pkg.name);\n\t\t\t\tif (maybeSuggestion) {\n\t\t\t\t\tsuggestedName = maybeSuggestion;\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Noop\n\t\t\t}\n\t\t}\n\n\t\t// 3. Use random name\n\t\tif (!suggestedName) {\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (\n\t\t\t\tawait this.manager.prismicRepository.checkExists({\n\t\t\t\t\tdomain: suggestedName,\n\t\t\t\t})\n\t\t\t);\n\t\t}\n\n\t\tconst { domain } = await prompt<string, \"domain\">({\n\t\t\ttype: \"text\",\n\t\t\tname: \"domain\",\n\t\t\t// Overriden by the `onRender` function, just used as a fallback\n\t\t\tmessage: \"Choose a name for your Prismic repository\",\n\t\t\tinitial: suggestedName,\n\t\t\tonRender() {\n\t\t\t\tconst rawDomain = this.value || this.initial || \"\";\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = validateRepositoryDomain({ domain });\n\n\t\t\t\tconst minRule = validation.LessThanMin\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tconst maxRule = validation.MoreThanMax\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tthis.msg = chalk.reset(\n\t\t\t\t\t`\nChoose a name for your Prismic repository\n\n NAMING RULES\n ${minRule}\n ${maxRule}\n 3. Name will be ${chalk.cyan(\"kebab-cased\")} automatically\n\n CONSIDERATIONS\n 1. Once picked, your repository name ${chalk.cyan(\"cannot be changed\")}\n 2. A ${chalk.cyan(\n\t\t\t\"display name\",\n\t\t)} for the repository can be configured later on\n\n PREVIEW\n Dashboard ${chalk.cyan(`https://${domain}.prismic.io`)}\n API ${chalk.cyan(`https://${domain}.cdn.prismic.io/api/v2`)}\n\n${chalk.cyan(\"?\")} Your Prismic repository name`.replace(\"\\n\", \"\"),\n\t\t\t\t);\n\t\t\t},\n\t\t\tvalidate: async (rawDomain: string) => {\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\tdomain,\n\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t});\n\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\tvalidation,\n\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t});\n\n\t\t\t\treturn errorMessage || true;\n\t\t\t},\n\t\t\tformat: (value) => {\n\t\t\t\treturn formatRepositoryDomain(value);\n\t\t\t},\n\t\t});\n\n\t\t// Clear extra lines\n\t\tprocess.stdout.moveCursor?.(0, -16);\n\t\tprocess.stdout.clearScreenDown?.();\n\n\t\tthis.context.repository = {\n\t\t\tdomain,\n\t\t\texists: false,\n\t\t};\n\t}\n\n\tprotected async completeOnboardingSteps(): Promise<void> {\n\t\ttry {\n\t\t\tawait this.manager.prismicRepository.completeOnboardingStep(\n\t\t\t\t\"chooseLocale\",\n\t\t\t\t\"createProject\",\n\t\t\t\t\"setupSliceMachine\",\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\t\t}\n\t}\n\n\tprotected createNewRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t);\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Creating new repository ${chalk.cyan(\n\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId: this.context.starterId,\n\t\t\t\t\t\t});\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t// When we have an error here, it's most probably because the user has a stale SESSION cookie\n\n\t\t\t\t\t\t// Ensure to logout user to remove SESSION and prismic-auth cookies\n\t\t\t\t\t\tawait this.manager.user.logout();\n\n\t\t\t\t\t\t// Force a new login to get a brand new cookies value\n\t\t\t\t\t\ttask.output =\n\t\t\t\t\t\t\t\"It seems there is an authentication problem, press any key to open the browser to login again...\";\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\ttask.output = \"Browser opened, waiting for you to login...\";\n\t\t\t\t\t\tawait this.waitingForLogin();\n\n\t\t\t\t\t\t// Try to create repository again with the new cookies value\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId: this.context.starterId,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.context.repository.exists = true;\n\t\t\t\t\ttask.output = \"\";\n\t\t\t\t\ttask.title = `Created new repository ${chalk.cyan(\n\t\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async setDefaultMasterLocale(): Promise<void> {\n\t\tconst documentsRead = await this.readDocuments();\n\n\t\tif (documentsRead !== undefined && documentsRead.documents.length > 0) {\n\t\t\t// if there are documents to push, we assume it's a starter which has a master locale already set\n\t\t\treturn;\n\t\t}\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Setting main content language...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tawait this.manager.prismicRepository.setDefaultMasterLocale();\n\t\t\t\t\ttask.title = `Main content language set to ${chalk.cyan(\n\t\t\t\t\t\t\"English - United States\",\n\t\t\t\t\t)} 🇺🇸. You can change it anytime in your project settings.`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected finishCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Finishing core dependencies installation with ${chalk.cyan(\n\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.installProcess,\n\t\t\t\t\t\t\"Initial dependencies installation process must be available through context to run `finishCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst updateOutput = (data: Buffer | null) => {\n\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\n\t\t\t\t\t// Don't clutter console with logs when process is non TTY (CI, etc.)\n\t\t\t\t\tif (process.stdout.isTTY || process.env.NODE_ENV === \"test\") {\n\t\t\t\t\t\tthis.context.installProcess.stdout?.on(\"data\", updateOutput);\n\t\t\t\t\t}\n\t\t\t\t\tthis.context.installProcess.stderr?.on(\"data\", updateOutput);\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.context.installProcess;\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * Error catching happens when then process is started ealier so\n\t\t\t\t\t\t * that all install errors, earlier and presents, can be catched.\n\t\t\t\t\t\t *\n\t\t\t\t\t\t * Here, we force the task to wait so that it is neither marked as\n\t\t\t\t\t\t * done or has the opportunity to handle the error itself.\n\t\t\t\t\t\t */\n\t\t\t\t\t\t// If for whatever reason the process is not exited by now, we still throw the error\n\t\t\t\t\t\tawait new Promise((resolve) => setTimeout(resolve, 5000));\n\t\t\t\t\t\tthrow error;\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Installed core dependencies with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected upsertSliceMachineConfigurationAndStartPluginRunner(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Resolving Slice Machine configuration...\",\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tlet sliceMachineConfigExists = false;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.project.getSliceMachineConfigPath();\n\t\t\t\t\t\tsliceMachineConfigExists = true;\n\t\t\t\t\t} catch {\n\t\t\t\t\t\t// noop, config does not exists, we'll create it\n\t\t\t\t\t}\n\n\t\t\t\t\tif (sliceMachineConfigExists) {\n\t\t\t\t\t\tparentTask.title = \"Updating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst config = await this.manager.project.getSliceMachineConfig();\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\t...config,\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\t\t\t\t\t\tparentTask.title = \"Updated Slice Machine configuration\";\n\t\t\t\t\t} else {\n\t\t\t\t\t\tparentTask.title = \"Creating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst sliceMachineConfigPath =\n\t\t\t\t\t\t\tawait this.manager.project.suggestSliceMachineConfigPath();\n\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t\tlibraries: [\"./slices\"],\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tpath: sliceMachineConfigPath,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tparentTask.title = \"Created Slice Machine configuration\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn listr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t// title: \"Starting plugin runner...\",\n\t\t\t\t\t\t\ttitle: \"Loading adapter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tawait this.manager.plugins.initPlugins();\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// task.title = \"Started plugin runner\";\n\t\t\t\t\t\t\t\ttask.title = \"Loaded adapter\";\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// parentTask.title = `${parentTask.title} and started plugin runner`;\n\t\t\t\t\t\t\t\tparentTask.title = `${parentTask.title} and loaded adapter`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async readAllSlices(): Promise<\n\t\t{ libraryID: string; sliceID: string }[]\n\t> {\n\t\tconst { libraries, errors } =\n\t\t\tawait this.manager.slices.readAllSliceLibraries();\n\n\t\tif (errors.length > 0) {\n\t\t\t// TODO: Provide better error message.\n\t\t\tthrow new Error(`Failed to read slice libraries: ${errors.join(\", \")}`);\n\t\t}\n\n\t\tconst slices: { libraryID: string; sliceID: string }[] = [];\n\t\tfor (const library of libraries) {\n\t\t\tif (library.sliceIDs) {\n\t\t\t\tfor (const sliceID of library.sliceIDs) {\n\t\t\t\t\tslices.push({\n\t\t\t\t\t\tlibraryID: library.libraryID,\n\t\t\t\t\t\tsliceID,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn slices;\n\t}\n\n\tprotected async readDocuments(): Promise<\n\t\t| {\n\t\t\t\tsignature: string;\n\t\t\t\tdocuments: string[];\n\t\t\t\tdirectoryPath: string;\n\t\t }\n\t\t| undefined\n\t> {\n\t\tconst root = await this.manager.project.getRoot();\n\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\ttry {\n\t\t\tawait fs.access(documentsDirectoryPath);\n\t\t} catch {\n\t\t\treturn;\n\t\t}\n\t\tconst signaturePath = path.resolve(documentsDirectoryPath, \"index.json\");\n\t\tconst rawSignature = await fs.readFile(signaturePath, \"utf-8\");\n\t\tconst signature: string = JSON.parse(rawSignature).signature;\n\n\t\tconst documents = await globby(\"*/*.json\", {\n\t\t\tcwd: documentsDirectoryPath,\n\t\t});\n\n\t\treturn { signature, documents, directoryPath: documentsDirectoryPath };\n\t}\n\n\tprotected syncDataWithPrismic(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Syncing data with Prismic...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing slices...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushSlices) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-slices used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst slices = await this.readAllSlices();\n\n\t\t\t\t\t\t\t\tif (slices.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No slice to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushing slices... (initializing ACL)\";\n\t\t\t\t\t\t\t\tawait this.manager.screenshots.initS3ACL();\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (0/${slices.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tslices.map(async (slice) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.slices.pushSlice({\n\t\t\t\t\t\t\t\t\t\t\t...slice,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (${pushed}/${slices.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all slices\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing types...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushCustomTypes) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-custom-types used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (!ids || ids.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No custom type to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing types... (0/${ids.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tids.map(async (id) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.pushCustomType({\n\t\t\t\t\t\t\t\t\t\t\tid,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing types... (${pushed}/${ids.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all types\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing documents...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushDocuments) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-documents used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\t\t\t\"Repository selection must be available through context to run `syncDataWithPrismic`\",\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst documentsRead = await this.readDocuments();\n\n\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\tdocumentsRead === undefined ||\n\t\t\t\t\t\t\t\t\t\tdocumentsRead.documents.length === 0\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tconst { signature, documents, directoryPath } = documentsRead;\n\n\t\t\t\t\t\t\t\t\t// TODO: Replace `unknown` with a Prismic document type.\n\t\t\t\t\t\t\t\t\t// The exact format is not know at this time, hence the `unknown`.\n\t\t\t\t\t\t\t\t\tconst recordDocument: Record<string, unknown> = {};\n\n\t\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\t\tdocuments.map(async (documentPath) => {\n\t\t\t\t\t\t\t\t\t\t\tconst filename = path.basename(documentPath, \".json\");\n\t\t\t\t\t\t\t\t\t\t\tconst fileContent = await fs.readFile(\n\t\t\t\t\t\t\t\t\t\t\t\tpath.resolve(directoryPath, documentPath),\n\t\t\t\t\t\t\t\t\t\t\t\t\"utf-8\",\n\t\t\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\t\t\t// TOOD: Validate the contents of the JSON file and skip on invalid documents.\n\t\t\t\t\t\t\t\t\t\t\t\tconst parsedContents = JSON.parse(fileContent);\n\n\t\t\t\t\t\t\t\t\t\t\t\trecordDocument[filename] = parsedContents;\n\t\t\t\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t\t\t\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\t\t\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t\t\t\t\t\t\t\t`Skipped document due to its invalid format: ${documentPath}`,\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\tawait this.manager.prismicRepository.pushDocuments({\n\t\t\t\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\t\t\t\tdocuments: recordDocument,\n\t\t\t\t\t\t\t\t\t\tsignature,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\ttask.title = \"Pushed all documents\";\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Cleaning up data push artifacts\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst root = await this.manager.project.getRoot();\n\t\t\t\t\t\t\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tawait fs.rm(documentsDirectoryPath, {\n\t\t\t\t\t\t\t\t\t\tforce: true,\n\t\t\t\t\t\t\t\t\t\trecursive: true,\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t// Noop, it's not that big of a deal if we cannot delete this directory\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Cleaned up data push artifacts\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pulling existing types...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (ids && ids.length > 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"Types already exist\");\n\t\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tconst remoteTypes =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.fetchRemoteCustomTypes();\n\n\t\t\t\t\t\t\t\tconst createCustomTypeLimit = pLimit(8);\n\n\t\t\t\t\t\t\t\tlet pulled = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (0/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tremoteTypes.map(async (model) => {\n\t\t\t\t\t\t\t\t\t\tawait createCustomTypeLimit(() =>\n\t\t\t\t\t\t\t\t\t\t\tthis.manager.customTypes.createCustomType({ model }),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\tpulled++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (${pulled}/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pulled existing types\";\n\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializeProject(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Initializing project...\",\n\t\t\t\ttask: async (_, parentTask) =>\n\t\t\t\t\t// We return another Listr instance in the event we have additional task to perform to initialize the project\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: `Patching ${chalk.cyan(\"package.json\")} scripts...`,\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst pkgPath = path.join(this.manager.cwd, \"package.json\");\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst pkgRaw = await fs.readFile(pkgPath, \"utf-8\");\n\t\t\t\t\t\t\t\t\tconst pkg = JSON.parse(pkgRaw);\n\n\t\t\t\t\t\t\t\t\tpkg.scripts ||= {};\n\n\t\t\t\t\t\t\t\t\tif (!pkg.scripts[START_SCRIPT_KEY]) {\n\t\t\t\t\t\t\t\t\t\tpkg.scripts[START_SCRIPT_KEY] = START_SCRIPT_VALUE;\n\n\t\t\t\t\t\t\t\t\t\t// Cheap indent detection based on https://github.com/sindresorhus/detect-indent (simplified because we're only dealing with JSON here)\n\t\t\t\t\t\t\t\t\t\tconst firstIndent = pkgRaw\n\t\t\t\t\t\t\t\t\t\t\t.split(\"\\n\")\n\t\t\t\t\t\t\t\t\t\t\t.find((line) => line.match(/^(?:( )+|\\t+)/));\n\t\t\t\t\t\t\t\t\t\tconst indent = firstIndent?.match(/^(?:( )+|\\t+)/)?.[0];\n\n\t\t\t\t\t\t\t\t\t\tawait fs.writeFile(\n\t\t\t\t\t\t\t\t\t\t\tpkgPath,\n\t\t\t\t\t\t\t\t\t\t\tJSON.stringify(\n\t\t\t\t\t\t\t\t\t\t\t\tpkg,\n\t\t\t\t\t\t\t\t\t\t\t\tnull,\n\t\t\t\t\t\t\t\t\t\t\t\tindent && indent !== \" \" ? indent : \" \",\n\t\t\t\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\t\t\t\t!pkg.scripts[\"slicemachine\"].startsWith(START_SCRIPT_VALUE)\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\tthrow new Error(\"Script already exists\");\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t\t\t\ttask.title = `Could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts (warning)`;\n\t\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts)`;\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tthis.context.projectInitialization ||= {};\n\t\t\t\t\t\t\t\tthis.context.projectInitialization.patchedScript = true;\n\n\t\t\t\t\t\t\t\ttask.title = `Patched ${chalk.cyan(\"package.json\")} scripts`;\n\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (patched ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t)} scripts)`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializePlugins(): Promise<void> {\n\t\treturn listrRun(\n\t\t\t[\n\t\t\t\t{\n\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t// title: \"Initializing plugins...\",\n\t\t\t\t\ttitle: \"Initializing adapter...\",\n\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\tconst updateOutput = (data: Buffer | string | null) => {\n\t\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t\t} else if (typeof data === \"string\") {\n\t\t\t\t\t\t\t\ttask.output = data;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tawait this.manager.project.initProject({\n\t\t\t\t\t\t\tlog: updateOutput,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t// task.title = \"Initialized plugins\";\n\t\t\t\t\t\ttask.title = \"Initialized adapter\";\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t],\n\t\t\t{ exitOnError: false },\n\t\t).catch(() => void 0);\n\t}\n}\n"],"names":["updateSentryContext","trackSentryError","createSliceMachineManager","setupSentry","pkg","assertExists","getRunScriptCommand","getExecuteCommand","prompt","execaCommand","listrRun","downloadTemplate","GIGET_PROVIDER","GIGET_ORGANIZATION","fs","getRandomRepositoryDomain","listr","_","detectFramework","detectStarterId","_b","_a","formatRepositoryDomain","validateRepositoryDomainAndAvailability","domain","getErrorMessageForRepositoryDomainValidation","validateRepositoryDomain","path","maybeSuggestion","REPOSITORY_NAME_VALIDATION","globby","SLICE_MACHINE_INIT_USER_AGENT","pLimit","START_SCRIPT_KEY","START_SCRIPT_VALUE"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"SliceMachineInitProcess.cjs","sources":["../../src/SliceMachineInitProcess.ts"],"sourcesContent":["import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\n\nimport chalk from \"chalk\";\n\nimport { execaCommand, type ExecaChildProcess } from \"execa\";\n\nimport open from \"open\";\nimport logSymbols from \"log-symbols\";\nimport { globby } from \"globby\";\nimport { downloadTemplate } from \"giget\";\nimport pLimit from \"p-limit\";\n\nimport {\n\tcreateSliceMachineManager,\n\tFrameworkWroomTelemetryID,\n\tPrismicUserProfile,\n\tPrismicRepository,\n\tSliceMachineManager,\n\tPackageManager,\n\tStarterId,\n\tREPOSITORY_NAME_VALIDATION,\n} from \"@slicemachine/manager\";\n\nimport pkg from \"../package.json\";\nimport { detectFramework, Framework } from \"./lib/framework\";\nimport { getRunScriptCommand } from \"./lib/getRunScriptCommand\";\nimport { getExecuteCommand } from \"./lib/getExecuteCommand\";\nimport {\n\tgetRandomRepositoryDomain,\n\tformatRepositoryDomain,\n\tvalidateRepositoryDomain,\n\tvalidateRepositoryDomainAndAvailability,\n\tgetErrorMessageForRepositoryDomainValidation,\n} from \"./lib/repositoryDomain\";\nimport { listr, listrRun } from \"./lib/listr\";\nimport { prompt } from \"./lib/prompt\";\nimport { assertExists } from \"./lib/assertExists\";\nimport {\n\tGIGET_ORGANIZATION,\n\tGIGET_PROVIDER,\n\tSLICE_MACHINE_INIT_USER_AGENT,\n\tSTART_SCRIPT_KEY,\n\tSTART_SCRIPT_VALUE,\n} from \"./constants\";\nimport { detectStarterId } from \"./lib/starters\";\nimport { setupSentry } from \"./lib/setupSentry\";\nimport { trackSentryError } from \"./lib/sentryErrorHandlers\";\nimport { updateSentryContext } from \"./lib/updateSentryContext\";\n\nexport type SliceMachineInitProcessOptions = {\n\trepository?: string;\n\tstarter?: string;\n\tdirectoryName?: string;\n\tpush?: boolean;\n\tpushSlices?: boolean;\n\tpushCustomTypes?: boolean;\n\tpushDocuments?: boolean;\n\tstartSlicemachine?: boolean;\n\tcwd?: string;\n} & Record<string, unknown>;\n\nconst DEFAULT_OPTIONS: SliceMachineInitProcessOptions = {\n\tpush: true,\n\tpushSlices: true,\n\tpushCustomTypes: true,\n\tpushDocuments: true,\n\tstartSlicemachine: true,\n};\n\nexport const createSliceMachineInitProcess = (\n\toptions?: SliceMachineInitProcessOptions,\n): SliceMachineInitProcess => {\n\treturn new SliceMachineInitProcess(options);\n};\n\ntype SliceMachineInitProcessContext = {\n\tframework?: Framework;\n\tpackageManager?: PackageManager;\n\tinstallProcess?: ExecaChildProcess;\n\tuserProfile?: PrismicUserProfile;\n\tuserRepositories?: PrismicRepository[];\n\trepository?: {\n\t\tdomain: string;\n\t\texists: boolean;\n\t};\n\tprojectInitialization?: {\n\t\tpatchedScript?: boolean;\n\t};\n\tstarterId?: StarterId;\n};\n\nexport class SliceMachineInitProcess {\n\tprotected options: SliceMachineInitProcessOptions;\n\tprotected manager: SliceMachineManager;\n\n\tprotected context: SliceMachineInitProcessContext;\n\n\tconstructor(options?: SliceMachineInitProcessOptions) {\n\t\tthis.options = { ...DEFAULT_OPTIONS, ...options };\n\t\tthis.manager = createSliceMachineManager({ cwd: options?.cwd });\n\n\t\tthis.context = {};\n\t}\n\n\tasync run(): Promise<void> {\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGray(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"→\",\n\t\t\t)} Initializing\\n`,\n\t\t);\n\n\t\ttry {\n\t\t\ttry {\n\t\t\t\tawait setupSentry();\n\t\t\t} catch (error) {\n\t\t\t\t// noop - We don't want to stop the user from using Slice Machine\n\t\t\t\t// because of failed tracking set up. We probably couldn't determine the\n\t\t\t\t// Sentry environment.\n\t\t\t}\n\t\t\tif (this.options.starter) {\n\t\t\t\tawait this.copyStarter();\n\t\t\t} else if (this.options.directoryName) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${logSymbols.warning} --directory-name has no effect because --starter is not specified\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (await this.manager.telemetry.checkIsTelemetryEnabled()) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${\n\t\t\t\t\t\tlogSymbols.info\n\t\t\t\t\t} We collect telemetry data to improve user experience.\\n Learn more: ${chalk.cyan(\n\t\t\t\t\t\t\"https://prismic.dev/slice-machine/telemetry\",\n\t\t\t\t\t)}\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tawait this.manager.telemetry.initTelemetry({\n\t\t\t\tappName: pkg.name,\n\t\t\t\tappVersion: pkg.version,\n\t\t\t});\n\n\t\t\tawait this.manager.telemetry.track({\n\t\t\t\tevent: \"command:init:start\",\n\t\t\t\trepository: this.options.repository,\n\t\t\t});\n\n\t\t\tawait this.detectEnvironment();\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.framework,\n\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.beginCoreDependenciesInstallation();\n\n\t\t\tif (this.options.repository) {\n\t\t\t\tawait this.useRepositoryFlag();\n\t\t\t} else {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tawait this.selectRepository();\n\t\t\t}\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.repository,\n\t\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.finishCoreDependenciesInstallation();\n\t\t\tawait this.upsertSliceMachineConfigurationAndStartPluginRunner();\n\n\t\t\tconst isLoginRequired = await this.checkIsLoginRequired();\n\t\t\tif (isLoginRequired) {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tif (this.context.repository.exists) {\n\t\t\t\t\tthis.validateWriteAccess();\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!this.context.repository.exists) {\n\t\t\t\tawait this.createNewRepository();\n\t\t\t\tawait this.setDefaultMasterLocale();\n\t\t\t}\n\n\t\t\tawait this.syncDataWithPrismic();\n\t\t\tawait this.initializeProject();\n\t\t\tawait this.initializePlugins();\n\t\t\tawait this.completeOnboardingSteps();\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\n\t\t\tthrow error;\n\t\t}\n\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework.sliceMachineTelemetryID,\n\t\t\trepository: this.context.repository.domain,\n\t\t\tsuccess: true,\n\t\t});\n\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGreen(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"→\",\n\t\t\t)} Initialization successful!\n\nContinue with next steps in Slice Machine.\n`,\n\t\t);\n\n\t\ttry {\n\t\t\tif (this.options.startSlicemachine) {\n\t\t\t\tconst runSmCommand = this.context.projectInitialization?.patchedScript\n\t\t\t\t\t? await getRunScriptCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"slicemachine\",\n\t\t\t\t\t })\n\t\t\t\t\t: await getExecuteCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"start-slicemachine\",\n\t\t\t\t\t });\n\n\t\t\t\tconst { startSlicemachine } = await prompt<\n\t\t\t\t\tboolean,\n\t\t\t\t\t\"startSlicemachine\"\n\t\t\t\t>({\n\t\t\t\t\ttype: \"confirm\",\n\t\t\t\t\tname: \"startSlicemachine\",\n\t\t\t\t\tmessage: `Run Slice Machine (${chalk.cyan(runSmCommand)})?`,\n\t\t\t\t\tinitial: true,\n\t\t\t\t});\n\n\t\t\t\tif (startSlicemachine) {\n\t\t\t\t\tconst commandReturnValue = await execaCommand(runSmCommand, {\n\t\t\t\t\t\tenv: { FORCE_COLOR: \"true\" },\n\t\t\t\t\t}).pipeStdout?.(process.stdout);\n\t\t\t\t\tif (commandReturnValue !== undefined) {\n\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\tconsole.log(commandReturnValue.stdout);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\t// Only track this error with Sentry, it's only the final convenience message\n\t\t\tawait this.trackSentryError(error);\n\t\t}\n\t}\n\n\tprotected async checkIsLoginRequired(): Promise<boolean> {\n\t\ttry {\n\t\t\tassertExists(this.context.repository, \"\");\n\t\t\tif (this.context.repository.exists === false) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tconst [slices, ctLibrary, documentsGlob] = await Promise.all([\n\t\t\t\tthis.readAllSlices(),\n\t\t\t\tthis.manager.customTypes.readCustomTypeLibrary(),\n\t\t\t\tthis.readDocuments(),\n\t\t\t]);\n\n\t\t\t// If repository exists, and there's anything to push\n\t\t\tif (\n\t\t\t\tslices.length > 0 ||\n\t\t\t\tctLibrary.ids.length > 0 ||\n\t\t\t\t(documentsGlob !== undefined && documentsGlob.documents.length > 0)\n\t\t\t) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// If repository exists, and there might be things to pull\n\t\t\tif (ctLibrary.ids.length === 0) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t} catch (error) {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\tprotected trackError = async (error: unknown): Promise<void> => {\n\t\tawait this.trackSentryError(error);\n\t\tawait this.trackTelemetryError(error);\n\t};\n\n\tprotected trackTelemetryError = async (error: unknown): Promise<void> => {\n\t\t// Transform error to string and prevent hitting Segment 500kb API limit or sending ridiculously long trace\n\t\tconst safeError = (\n\t\t\terror instanceof Error ? error.message : `${error}`\n\t\t).slice(0, 512);\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t\trepository: this.context.repository?.domain || \"\",\n\t\t\tsuccess: false,\n\t\t\terror: safeError,\n\t\t});\n\t};\n\n\tprotected trackSentryError = async (error: unknown): Promise<void> => {\n\t\tawait updateSentryContext({\n\t\t\tmanager: this.manager,\n\t\t\trepositoryName: this.context.repository?.domain || \"\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t});\n\t\ttrackSentryError(error);\n\t};\n\n\tprotected async copyStarter(): Promise<void> {\n\t\tconst dir = await this.getStarterDirectoryName();\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Copying starter...\\n\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tconst starter = this.options.starter;\n\n\t\t\t\t\tawait downloadTemplate(\n\t\t\t\t\t\t`${GIGET_PROVIDER}:${GIGET_ORGANIZATION}/${starter}#HEAD`,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tdir,\n\t\t\t\t\t\t},\n\t\t\t\t\t);\n\n\t\t\t\t\tprocess.chdir(dir);\n\t\t\t\t\tthis.manager.cwd = process.cwd();\n\n\t\t\t\t\ttask.title = \"Starter copied\\n\";\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async getStarterDirectoryName(): Promise<string> {\n\t\tlet directoryName: string;\n\t\tconst folderNames = await fs.readdir(process.cwd());\n\n\t\tif (\n\t\t\tthis.options.directoryName &&\n\t\t\t!folderNames.includes(this.options.directoryName)\n\t\t) {\n\t\t\t// Use provided directory\n\t\t\tdirectoryName = this.options.directoryName;\n\t\t} else if (\n\t\t\tthis.options.repository &&\n\t\t\t!folderNames.includes(this.options.repository)\n\t\t) {\n\t\t\t// Use repository name\n\t\t\tdirectoryName = this.options.repository;\n\t\t} else {\n\t\t\t// Use random name\n\t\t\tlet suggestedName: string;\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (folderNames.includes(suggestedName));\n\n\t\t\tconst { selectedDirectory } = await prompt<string, \"selectedDirectory\">({\n\t\t\t\ttype: \"text\",\n\t\t\t\tname: \"selectedDirectory\",\n\t\t\t\tmessage: \"Your starter directory name\",\n\t\t\t\tinitial: suggestedName,\n\t\t\t\tvalidate: async (rawDirectory: string) => {\n\t\t\t\t\tif (folderNames.includes(rawDirectory)) {\n\t\t\t\t\t\treturn \"Directory name already exists\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn true;\n\t\t\t\t},\n\t\t\t});\n\n\t\t\tdirectoryName = selectedDirectory;\n\t\t}\n\n\t\treturn directoryName;\n\t}\n\n\tprotected detectEnvironment(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Detecting environment...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting framework...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.framework = await detectFramework(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting package manager...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.packageManager =\n\t\t\t\t\t\t\t\t\tawait this.manager.project.detectPackageManager({\n\t\t\t\t\t\t\t\t\t\troot: this.manager.cwd,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\ttask.title = `Detected package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\tparentTask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)} and package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting starter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.starterId = await detectStarterId(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\tif (this.context.starterId) {\n\t\t\t\t\t\t\t\t\ttask.title = `Detected starter ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.starterId,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\ttask.title = \"No starter detected\";\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected beginCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Beginning core dependencies installation...\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\"Project package manager must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst { execaProcess } =\n\t\t\t\t\t\tawait this.manager.project.installDependencies({\n\t\t\t\t\t\t\tpackageManager: this.context.packageManager,\n\t\t\t\t\t\t\tdependencies: this.context.framework.devDependencies,\n\t\t\t\t\t\t\tdev: true,\n\t\t\t\t\t\t\t// Picked up later\n\t\t\t\t\t\t\tlog: () => {\n\t\t\t\t\t\t\t\t/* ... */\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\n\t\t\t\t\t// Fail hard if process fails\n\t\t\t\t\texecaProcess.catch(async (error) => {\n\t\t\t\t\t\tconst [_, ...argv1n] = process.argv;\n\t\t\t\t\t\t// Command the user used\n\t\t\t\t\t\tlet tryAgainCommand = [process.argv0, ...argv1n].join(\" \");\n\n\t\t\t\t\t\t// If the `repository` option wasn't used AND the repository was selected/created\n\t\t\t\t\t\tif (!this.options.repository && this.context.repository) {\n\t\t\t\t\t\t\ttryAgainCommand = `${tryAgainCommand} --repository=${this.context.repository.domain}`;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tawait this.trackError(error);\n\t\t\t\t\t\tconsole.error(\n\t\t\t\t\t\t\t`\\n\\n${error.shortMessage}\\n${error.stderr}\\n\\n${\n\t\t\t\t\t\t\t\tlogSymbols.error\n\t\t\t\t\t\t\t} Dependency installation failed, try again with:\\n\\n ${chalk.gray(\n\t\t\t\t\t\t\t\t\"$\",\n\t\t\t\t\t\t\t)} ${chalk.cyan(tryAgainCommand)}`,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tprocess.exit(1);\n\t\t\t\t\t});\n\n\t\t\t\t\tthis.context.installProcess = execaProcess;\n\n\t\t\t\t\ttask.title = `Began core dependencies installation with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)} ... (running in background)`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async fetchUserProfile(): Promise<void> {\n\t\tthis.context.userProfile = await this.manager.user.getProfile();\n\n\t\tawait this.manager.telemetry.identify({\n\t\t\tuserID: this.context.userProfile.shortId,\n\t\t\tintercomHash: this.context.userProfile.intercomHash,\n\t\t});\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:identify\",\n\t\t\trepository: this.options.repository,\n\t\t});\n\t}\n\n\tprotected async fetchUserRepositories(): Promise<void> {\n\t\tthis.context.userRepositories =\n\t\t\tawait this.manager.prismicRepository.readAll();\n\t}\n\n\tprotected validateWriteAccess(): void {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to validate write access\",\n\t\t);\n\t\tconst { domain } = this.context.repository;\n\t\tconst maybeRepository = this.context.userRepositories.find(\n\t\t\t(repository) => repository.domain === domain,\n\t\t);\n\n\t\tif (maybeRepository) {\n\t\t\tif (!this.manager.prismicRepository.hasWriteAccess(maybeRepository)) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Cannot run init command with repository ${chalk.cyan(\n\t\t\t\t\t\tmaybeRepository.domain,\n\t\t\t\t\t)}: you are not a developer or admin of this repository`,\n\t\t\t\t);\n\t\t\t}\n\t\t} else {\n\t\t\tthrow new Error(\n\t\t\t\t`Cannot validate write access for repository ${chalk.cyan(\n\t\t\t\t\tdomain,\n\t\t\t\t)}: you are not part of this repository`,\n\t\t\t);\n\t\t}\n\t}\n\n\tprotected getLoggingInTitle(subtitle?: string, ...extra: string[]): string {\n\t\treturn `Logging in to Prismic...\n\n███████████████████████████████████████████████████████████████████████████\n\n${subtitle ? `* * ${subtitle}` : \"\"}\n${extra.length ? `\\n${extra.map((line) => ` ${line}`).join(\"\\n\")}\\n` : \"\"}\n███████████████████████████████████████████████████████████████████████████\n`;\n\t}\n\n\tprotected loginAndFetchUserData(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: this.getLoggingInTitle(),\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\"Validating session...\");\n\t\t\t\t\tconst isLoggedIn = await this.manager.user.checkIsLoggedIn();\n\n\t\t\t\t\tif (!isLoggedIn) {\n\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\tchalk.cyan(\"Press any key to open the browser to login...\"),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\tawait this.waitingForLogin(({ url }) => {\n\t\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\t\tchalk.cyan(\"Opening browser, waiting for you to login...\"),\n\t\t\t\t\t\t\t\tchalk.yellow(\n\t\t\t\t\t\t\t\t\t\"If your browser did not open automatically, please use the url below:\",\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tparentTask.title = `Logged in`;\n\n\t\t\t\t\treturn listr(\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user profile...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserProfile();\n\t\t\t\t\t\t\t\t\tparentTask.title = `Logged in as ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.userProfile?.email,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user profile\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user repositories...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserRepositories();\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user repositories\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t],\n\t\t\t\t\t\t{ concurrent: true },\n\t\t\t\t\t);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async pressKeyToLogin(): Promise<void> {\n\t\tawait new Promise((resolve) => {\n\t\t\tconst initialRawMode = !!process.stdin.isRaw;\n\t\t\tprocess.stdin.setRawMode?.(true);\n\t\t\tprocess.stdin.resume();\n\t\t\tprocess.stdin.once(\"data\", (data: Buffer) => {\n\t\t\t\tprocess.stdin.setRawMode?.(initialRawMode);\n\t\t\t\tprocess.stdin.pause();\n\t\t\t\tresolve(data.toString(\"utf-8\"));\n\t\t\t});\n\t\t});\n\t}\n\n\tprotected async waitingForLogin(\n\t\tonListenCallback?: (\n\t\t\tsessionInfo: Awaited<\n\t\t\t\tReturnType<typeof this.manager.user.getLoginSessionInfo>\n\t\t\t>,\n\t\t) => void,\n\t): Promise<void> {\n\t\tconst sessionInfo = await this.manager.user.getLoginSessionInfo();\n\t\tawait this.manager.user.nodeLoginSession({\n\t\t\tport: sessionInfo.port,\n\t\t\tonListenCallback() {\n\t\t\t\topen(sessionInfo.url);\n\t\t\t\tonListenCallback?.(sessionInfo);\n\t\t\t},\n\t\t});\n\t}\n\n\tprotected useRepositoryFlag(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Flag ${chalk.cyan(\"repository\")} used, validating input...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.options.repository,\n\t\t\t\t\t\t\"Flag `repository` must be set to run `useRepositoryFlag`\",\n\t\t\t\t\t);\n\t\t\t\t\tconst domain = formatRepositoryDomain(this.options.repository);\n\t\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t\t});\n\n\t\t\t\t\tif (validation.LessThanMin || validation.MoreThanMax) {\n\t\t\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\t\t\tvalidation: {\n\t\t\t\t\t\t\t\t...validation,\n\t\t\t\t\t\t\t\t// We don't want to throw if repo already exists.\n\t\t\t\t\t\t\t\t// User most probably just created it via their dashboard.\n\t\t\t\t\t\t\t\tAlreadyExists: false,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (errorMessage) {\n\t\t\t\t\t\t\tthrow new Error(errorMessage);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Selected repository ${chalk.cyan(\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t)} (flag ${chalk.cyan(\"repository\")} used)`;\n\n\t\t\t\t\tthis.context.repository = {\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texists: validation.AlreadyExists ?? false,\n\t\t\t\t\t};\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async selectRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `selectRepository`\",\n\t\t);\n\n\t\tif (this.context.userRepositories.length) {\n\t\t\tawait this.trySelectExistingRepository();\n\t\t}\n\n\t\tif (!this.context.repository) {\n\t\t\tawait this.selectNewRepository();\n\t\t}\n\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`${logSymbols.success} Selected repository ${chalk.cyan(\n\t\t\t\tthis.context.repository.domain,\n\t\t\t)}`,\n\t\t);\n\t}\n\n\tprotected async trySelectExistingRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `trySelectExistingRepository`\",\n\t\t);\n\n\t\tconst { maybeDomain } = await prompt<string, \"maybeDomain\">({\n\t\t\ttype: \"select\",\n\t\t\tname: \"maybeDomain\",\n\t\t\tmessage: \"Pick a repository to connect to or choose to create a new one\",\n\t\t\twarn: \"You are not a developer or admin of this repository\",\n\t\t\tchoices: [\n\t\t\t\t{\n\t\t\t\t\ttitle: \"CREATE NEW\",\n\t\t\t\t\tdescription: \"Create a new Prismic repository\\n\",\n\t\t\t\t\tvalue: \"\",\n\t\t\t\t},\n\t\t\t\t...this.context.userRepositories\n\t\t\t\t\t.map((repository) => {\n\t\t\t\t\t\tconst hasWriteAccess =\n\t\t\t\t\t\t\tthis.manager.prismicRepository.hasWriteAccess(repository);\n\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\ttitle: `${repository.domain}${\n\t\t\t\t\t\t\t\thasWriteAccess ? \"\" : \" (Unauthorized)\"\n\t\t\t\t\t\t\t}`,\n\t\t\t\t\t\t\tdescription: `Connect to ${chalk.cyan(repository.domain)}`,\n\t\t\t\t\t\t\tvalue: repository.domain,\n\t\t\t\t\t\t\tdisabled: !hasWriteAccess,\n\t\t\t\t\t\t};\n\t\t\t\t\t})\n\t\t\t\t\t.sort((a, b) => (a.value > b.value ? 1 : -1)),\n\t\t\t],\n\t\t});\n\n\t\tif (maybeDomain) {\n\t\t\tthis.context.repository = {\n\t\t\t\tdomain: maybeDomain,\n\t\t\t\texists: true,\n\t\t\t};\n\t\t}\n\t}\n\n\tprotected async selectNewRepository(): Promise<void> {\n\t\tlet suggestedName = \"\";\n\n\t\t// TODO: Improve concurrency\n\t\tconst trySuggestName = async (name: string): Promise<string | void> => {\n\t\t\tif (name) {\n\t\t\t\tconst formattedName = formatRepositoryDomain(name);\n\n\t\t\t\tif (\n\t\t\t\t\t!validateRepositoryDomain({ domain: formattedName }).hasErrors &&\n\t\t\t\t\t!(await this.manager.prismicRepository.checkExists({\n\t\t\t\t\t\tdomain: formattedName,\n\t\t\t\t\t}))\n\t\t\t\t) {\n\t\t\t\t\treturn formattedName;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\t// 1. Try to suggest name after directory name\n\t\tconst maybeSuggestion = await trySuggestName(\n\t\t\tpath.basename(this.manager.cwd),\n\t\t);\n\t\tif (maybeSuggestion) {\n\t\t\tsuggestedName = maybeSuggestion;\n\t\t}\n\n\t\t// 2. Try to suggest name after package name\n\t\tif (!suggestedName) {\n\t\t\ttry {\n\t\t\t\tconst pkgJSONPath = path.join(this.manager.cwd, \"package.json\");\n\t\t\t\tconst pkg = JSON.parse(await fs.readFile(pkgJSONPath, \"utf-8\"));\n\n\t\t\t\tconst maybeSuggestion = await trySuggestName(pkg.name);\n\t\t\t\tif (maybeSuggestion) {\n\t\t\t\t\tsuggestedName = maybeSuggestion;\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Noop\n\t\t\t}\n\t\t}\n\n\t\t// 3. Use random name\n\t\tif (!suggestedName) {\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (\n\t\t\t\tawait this.manager.prismicRepository.checkExists({\n\t\t\t\t\tdomain: suggestedName,\n\t\t\t\t})\n\t\t\t);\n\t\t}\n\n\t\tconst { domain } = await prompt<string, \"domain\">({\n\t\t\ttype: \"text\",\n\t\t\tname: \"domain\",\n\t\t\t// Overriden by the `onRender` function, just used as a fallback\n\t\t\tmessage: \"Choose a name for your Prismic repository\",\n\t\t\tinitial: suggestedName,\n\t\t\tonRender() {\n\t\t\t\tconst rawDomain = this.value || this.initial || \"\";\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = validateRepositoryDomain({ domain });\n\n\t\t\t\tconst minRule = validation.LessThanMin\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tconst maxRule = validation.MoreThanMax\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tthis.msg = chalk.reset(\n\t\t\t\t\t`\nChoose a name for your Prismic repository\n\n NAMING RULES\n ${minRule}\n ${maxRule}\n 3. Name will be ${chalk.cyan(\"kebab-cased\")} automatically\n\n CONSIDERATIONS\n 1. Once picked, your repository name ${chalk.cyan(\"cannot be changed\")}\n 2. A ${chalk.cyan(\n\t\t\t\"display name\",\n\t\t)} for the repository can be configured later on\n\n PREVIEW\n Dashboard ${chalk.cyan(`https://${domain}.prismic.io`)}\n API ${chalk.cyan(`https://${domain}.cdn.prismic.io/api/v2`)}\n\n${chalk.cyan(\"?\")} Your Prismic repository name`.replace(\"\\n\", \"\"),\n\t\t\t\t);\n\t\t\t},\n\t\t\tvalidate: async (rawDomain: string) => {\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\tdomain,\n\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t});\n\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\tvalidation,\n\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t});\n\n\t\t\t\treturn errorMessage || true;\n\t\t\t},\n\t\t\tformat: (value) => {\n\t\t\t\treturn formatRepositoryDomain(value);\n\t\t\t},\n\t\t});\n\n\t\t// Clear extra lines\n\t\tprocess.stdout.moveCursor?.(0, -16);\n\t\tprocess.stdout.clearScreenDown?.();\n\n\t\tthis.context.repository = {\n\t\t\tdomain,\n\t\t\texists: false,\n\t\t};\n\t}\n\n\tprotected async completeOnboardingSteps(): Promise<void> {\n\t\ttry {\n\t\t\tawait this.manager.prismicRepository.completeOnboardingStep(\n\t\t\t\t\"chooseLocale\",\n\t\t\t\t\"createProject\",\n\t\t\t\t\"setupSliceMachine\",\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\t\t}\n\t}\n\n\tprotected createNewRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t);\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Creating new repository ${chalk.cyan(\n\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\n\t\t\t\t\t// Fallback to minimal starter if no starter detected and --starter flag was passed.\n\t\t\t\t\t// This allows for uploading documents even in unknown starters.\n\t\t\t\t\tlet starterId = this.context.starterId;\n\t\t\t\t\tif (!starterId && this.options.starter) {\n\t\t\t\t\t\tconst frameworkToMinimalStarter: Partial<\n\t\t\t\t\t\t\tRecord<FrameworkWroomTelemetryID, StarterId>\n\t\t\t\t\t\t> = {\n\t\t\t\t\t\t\tnext: \"next_minimal\",\n\t\t\t\t\t\t\tnuxt: \"nuxt_minimal\",\n\t\t\t\t\t\t\tsveltekit: \"sveltekit_minimal\",\n\t\t\t\t\t\t};\n\t\t\t\t\t\tstarterId =\n\t\t\t\t\t\t\tframeworkToMinimalStarter[\n\t\t\t\t\t\t\t\tthis.context.framework.wroomTelemetryID\n\t\t\t\t\t\t\t];\n\t\t\t\t\t}\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId,\n\t\t\t\t\t\t});\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t// When we have an error here, it's most probably because the user has a stale SESSION cookie\n\n\t\t\t\t\t\t// Ensure to logout user to remove SESSION and prismic-auth cookies\n\t\t\t\t\t\tawait this.manager.user.logout();\n\n\t\t\t\t\t\t// Force a new login to get a brand new cookies value\n\t\t\t\t\t\ttask.output =\n\t\t\t\t\t\t\t\"It seems there is an authentication problem, press any key to open the browser to login again...\";\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\ttask.output = \"Browser opened, waiting for you to login...\";\n\t\t\t\t\t\tawait this.waitingForLogin();\n\n\t\t\t\t\t\t// Try to create repository again with the new cookies value\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.context.repository.exists = true;\n\t\t\t\t\ttask.output = \"\";\n\t\t\t\t\ttask.title = `Created new repository ${chalk.cyan(\n\t\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async setDefaultMasterLocale(): Promise<void> {\n\t\tconst documentsRead = await this.readDocuments();\n\n\t\tif (documentsRead !== undefined && documentsRead.documents.length > 0) {\n\t\t\t// if there are documents to push, we assume it's a starter which has a master locale already set\n\t\t\treturn;\n\t\t}\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Setting main content language...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tawait this.manager.prismicRepository.setDefaultMasterLocale();\n\t\t\t\t\ttask.title = `Main content language set to ${chalk.cyan(\n\t\t\t\t\t\t\"English - United States\",\n\t\t\t\t\t)} 🇺🇸. You can change it anytime in your project settings.`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected finishCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Finishing core dependencies installation with ${chalk.cyan(\n\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.installProcess,\n\t\t\t\t\t\t\"Initial dependencies installation process must be available through context to run `finishCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst updateOutput = (data: Buffer | null) => {\n\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\n\t\t\t\t\t// Don't clutter console with logs when process is non TTY (CI, etc.)\n\t\t\t\t\tif (process.stdout.isTTY || process.env.NODE_ENV === \"test\") {\n\t\t\t\t\t\tthis.context.installProcess.stdout?.on(\"data\", updateOutput);\n\t\t\t\t\t}\n\t\t\t\t\tthis.context.installProcess.stderr?.on(\"data\", updateOutput);\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.context.installProcess;\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * Error catching happens when then process is started ealier so\n\t\t\t\t\t\t * that all install errors, earlier and presents, can be catched.\n\t\t\t\t\t\t *\n\t\t\t\t\t\t * Here, we force the task to wait so that it is neither marked as\n\t\t\t\t\t\t * done or has the opportunity to handle the error itself.\n\t\t\t\t\t\t */\n\t\t\t\t\t\t// If for whatever reason the process is not exited by now, we still throw the error\n\t\t\t\t\t\tawait new Promise((resolve) => setTimeout(resolve, 5000));\n\t\t\t\t\t\tthrow error;\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Installed core dependencies with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected upsertSliceMachineConfigurationAndStartPluginRunner(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Resolving Slice Machine configuration...\",\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tlet sliceMachineConfigExists = false;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.project.getSliceMachineConfigPath();\n\t\t\t\t\t\tsliceMachineConfigExists = true;\n\t\t\t\t\t} catch {\n\t\t\t\t\t\t// noop, config does not exists, we'll create it\n\t\t\t\t\t}\n\n\t\t\t\t\tif (sliceMachineConfigExists) {\n\t\t\t\t\t\tparentTask.title = \"Updating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst config = await this.manager.project.getSliceMachineConfig();\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\t...config,\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\t\t\t\t\t\tparentTask.title = \"Updated Slice Machine configuration\";\n\t\t\t\t\t} else {\n\t\t\t\t\t\tparentTask.title = \"Creating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst sliceMachineConfigPath =\n\t\t\t\t\t\t\tawait this.manager.project.suggestSliceMachineConfigPath();\n\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t\tlibraries: [\"./slices\"],\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tpath: sliceMachineConfigPath,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tparentTask.title = \"Created Slice Machine configuration\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn listr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t// title: \"Starting plugin runner...\",\n\t\t\t\t\t\t\ttitle: \"Loading adapter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tawait this.manager.plugins.initPlugins();\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// task.title = \"Started plugin runner\";\n\t\t\t\t\t\t\t\ttask.title = \"Loaded adapter\";\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// parentTask.title = `${parentTask.title} and started plugin runner`;\n\t\t\t\t\t\t\t\tparentTask.title = `${parentTask.title} and loaded adapter`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async readAllSlices(): Promise<\n\t\t{ libraryID: string; sliceID: string }[]\n\t> {\n\t\tconst { libraries, errors } =\n\t\t\tawait this.manager.slices.readAllSliceLibraries();\n\n\t\tif (errors.length > 0) {\n\t\t\t// TODO: Provide better error message.\n\t\t\tthrow new Error(`Failed to read slice libraries: ${errors.join(\", \")}`);\n\t\t}\n\n\t\tconst slices: { libraryID: string; sliceID: string }[] = [];\n\t\tfor (const library of libraries) {\n\t\t\tif (library.sliceIDs) {\n\t\t\t\tfor (const sliceID of library.sliceIDs) {\n\t\t\t\t\tslices.push({\n\t\t\t\t\t\tlibraryID: library.libraryID,\n\t\t\t\t\t\tsliceID,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn slices;\n\t}\n\n\tprotected async readDocuments(): Promise<\n\t\t| {\n\t\t\t\tsignature: string;\n\t\t\t\tdocuments: string[];\n\t\t\t\tdirectoryPath: string;\n\t\t }\n\t\t| undefined\n\t> {\n\t\tconst root = await this.manager.project.getRoot();\n\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\ttry {\n\t\t\tawait fs.access(documentsDirectoryPath);\n\t\t} catch {\n\t\t\treturn;\n\t\t}\n\t\tconst signaturePath = path.resolve(documentsDirectoryPath, \"index.json\");\n\t\tconst rawSignature = await fs.readFile(signaturePath, \"utf-8\");\n\t\tconst signature: string = JSON.parse(rawSignature).signature;\n\n\t\tconst documents = await globby(\"*/*.json\", {\n\t\t\tcwd: documentsDirectoryPath,\n\t\t});\n\n\t\treturn { signature, documents, directoryPath: documentsDirectoryPath };\n\t}\n\n\tprotected syncDataWithPrismic(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Syncing data with Prismic...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing slices...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushSlices) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-slices used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst slices = await this.readAllSlices();\n\n\t\t\t\t\t\t\t\tif (slices.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No slice to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushing slices... (initializing ACL)\";\n\t\t\t\t\t\t\t\tawait this.manager.screenshots.initS3ACL();\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (0/${slices.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tslices.map(async (slice) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.slices.pushSlice({\n\t\t\t\t\t\t\t\t\t\t\t...slice,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (${pushed}/${slices.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all slices\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing types...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushCustomTypes) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-custom-types used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (!ids || ids.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No custom type to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing types... (0/${ids.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tids.map(async (id) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.pushCustomType({\n\t\t\t\t\t\t\t\t\t\t\tid,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing types... (${pushed}/${ids.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all types\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing documents...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushDocuments) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-documents used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\t\t\t\"Repository selection must be available through context to run `syncDataWithPrismic`\",\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst documentsRead = await this.readDocuments();\n\n\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\tdocumentsRead === undefined ||\n\t\t\t\t\t\t\t\t\t\tdocumentsRead.documents.length === 0\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tconst { signature, documents, directoryPath } = documentsRead;\n\n\t\t\t\t\t\t\t\t\t// TODO: Replace `unknown` with a Prismic document type.\n\t\t\t\t\t\t\t\t\t// The exact format is not know at this time, hence the `unknown`.\n\t\t\t\t\t\t\t\t\tconst recordDocument: Record<string, unknown> = {};\n\n\t\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\t\tdocuments.map(async (documentPath) => {\n\t\t\t\t\t\t\t\t\t\t\tconst filename = path.basename(documentPath, \".json\");\n\t\t\t\t\t\t\t\t\t\t\tconst fileContent = await fs.readFile(\n\t\t\t\t\t\t\t\t\t\t\t\tpath.resolve(directoryPath, documentPath),\n\t\t\t\t\t\t\t\t\t\t\t\t\"utf-8\",\n\t\t\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\t\t\t// TOOD: Validate the contents of the JSON file and skip on invalid documents.\n\t\t\t\t\t\t\t\t\t\t\t\tconst parsedContents = JSON.parse(fileContent);\n\n\t\t\t\t\t\t\t\t\t\t\t\trecordDocument[filename] = parsedContents;\n\t\t\t\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t\t\t\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\t\t\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t\t\t\t\t\t\t\t`Skipped document due to its invalid format: ${documentPath}`,\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\tawait this.manager.prismicRepository.pushDocuments({\n\t\t\t\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\t\t\t\tdocuments: recordDocument,\n\t\t\t\t\t\t\t\t\t\tsignature,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\ttask.title = \"Pushed all documents\";\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Cleaning up data push artifacts\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst root = await this.manager.project.getRoot();\n\t\t\t\t\t\t\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tawait fs.rm(documentsDirectoryPath, {\n\t\t\t\t\t\t\t\t\t\tforce: true,\n\t\t\t\t\t\t\t\t\t\trecursive: true,\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t// Noop, it's not that big of a deal if we cannot delete this directory\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Cleaned up data push artifacts\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pulling existing types...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (ids && ids.length > 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"Types already exist\");\n\t\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tconst remoteTypes =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.fetchRemoteCustomTypes();\n\n\t\t\t\t\t\t\t\tconst createCustomTypeLimit = pLimit(8);\n\n\t\t\t\t\t\t\t\tlet pulled = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (0/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tremoteTypes.map(async (model) => {\n\t\t\t\t\t\t\t\t\t\tawait createCustomTypeLimit(() =>\n\t\t\t\t\t\t\t\t\t\t\tthis.manager.customTypes.createCustomType({ model }),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\tpulled++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (${pulled}/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pulled existing types\";\n\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializeProject(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Initializing project...\",\n\t\t\t\ttask: async (_, parentTask) =>\n\t\t\t\t\t// We return another Listr instance in the event we have additional task to perform to initialize the project\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: `Patching ${chalk.cyan(\"package.json\")} scripts...`,\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst pkgPath = path.join(this.manager.cwd, \"package.json\");\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst pkgRaw = await fs.readFile(pkgPath, \"utf-8\");\n\t\t\t\t\t\t\t\t\tconst pkg = JSON.parse(pkgRaw);\n\n\t\t\t\t\t\t\t\t\tpkg.scripts ||= {};\n\n\t\t\t\t\t\t\t\t\tif (!pkg.scripts[START_SCRIPT_KEY]) {\n\t\t\t\t\t\t\t\t\t\tpkg.scripts[START_SCRIPT_KEY] = START_SCRIPT_VALUE;\n\n\t\t\t\t\t\t\t\t\t\t// Cheap indent detection based on https://github.com/sindresorhus/detect-indent (simplified because we're only dealing with JSON here)\n\t\t\t\t\t\t\t\t\t\tconst firstIndent = pkgRaw\n\t\t\t\t\t\t\t\t\t\t\t.split(\"\\n\")\n\t\t\t\t\t\t\t\t\t\t\t.find((line) => line.match(/^(?:( )+|\\t+)/));\n\t\t\t\t\t\t\t\t\t\tconst indent = firstIndent?.match(/^(?:( )+|\\t+)/)?.[0];\n\n\t\t\t\t\t\t\t\t\t\tawait fs.writeFile(\n\t\t\t\t\t\t\t\t\t\t\tpkgPath,\n\t\t\t\t\t\t\t\t\t\t\tJSON.stringify(\n\t\t\t\t\t\t\t\t\t\t\t\tpkg,\n\t\t\t\t\t\t\t\t\t\t\t\tnull,\n\t\t\t\t\t\t\t\t\t\t\t\tindent && indent !== \" \" ? indent : \" \",\n\t\t\t\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\t\t\t\t!pkg.scripts[\"slicemachine\"].startsWith(START_SCRIPT_VALUE)\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\tthrow new Error(\"Script already exists\");\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t\t\t\ttask.title = `Could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts (warning)`;\n\t\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts)`;\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tthis.context.projectInitialization ||= {};\n\t\t\t\t\t\t\t\tthis.context.projectInitialization.patchedScript = true;\n\n\t\t\t\t\t\t\t\ttask.title = `Patched ${chalk.cyan(\"package.json\")} scripts`;\n\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (patched ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t)} scripts)`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializePlugins(): Promise<void> {\n\t\treturn listrRun(\n\t\t\t[\n\t\t\t\t{\n\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t// title: \"Initializing plugins...\",\n\t\t\t\t\ttitle: \"Initializing adapter...\",\n\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\tconst updateOutput = (data: Buffer | string | null) => {\n\t\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t\t} else if (typeof data === \"string\") {\n\t\t\t\t\t\t\t\ttask.output = data;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tawait this.manager.project.initProject({\n\t\t\t\t\t\t\tlog: updateOutput,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t// task.title = \"Initialized plugins\";\n\t\t\t\t\t\ttask.title = \"Initialized adapter\";\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t],\n\t\t\t{ exitOnError: false },\n\t\t).catch(() => void 0);\n\t}\n}\n"],"names":["updateSentryContext","trackSentryError","createSliceMachineManager","setupSentry","pkg","assertExists","getRunScriptCommand","getExecuteCommand","prompt","execaCommand","listrRun","downloadTemplate","GIGET_PROVIDER","GIGET_ORGANIZATION","fs","getRandomRepositoryDomain","listr","_","detectFramework","detectStarterId","_b","_a","formatRepositoryDomain","validateRepositoryDomainAndAvailability","domain","getErrorMessageForRepositoryDomainValidation","validateRepositoryDomain","path","maybeSuggestion","REPOSITORY_NAME_VALIDATION","globby","SLICE_MACHINE_INIT_USER_AGENT","pLimit","START_SCRIPT_KEY","START_SCRIPT_VALUE"],"mappings":"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"}
|
|
@@ -338,7 +338,7 @@ ${logSymbols.error} Dependency installation failed, try again with:
|
|
|
338
338
|
}
|
|
339
339
|
getLoggingInTitle(subtitle, ...extra) {
|
|
340
340
|
return `Logging in to Prismic...
|
|
341
|
-
|
|
341
|
+
|
|
342
342
|
███████████████████████████████████████████████████████████████████████████
|
|
343
343
|
|
|
344
344
|
${subtitle ? `* * ${subtitle}` : ""}
|
|
@@ -588,11 +588,20 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
|
|
|
588
588
|
task: async (_, task) => {
|
|
589
589
|
assertExists(this.context.repository, "Repository selection must be available through context to run `createNewRepository`");
|
|
590
590
|
assertExists(this.context.framework, "Project framework must be available through context to run `createNewRepository`");
|
|
591
|
+
let starterId = this.context.starterId;
|
|
592
|
+
if (!starterId && this.options.starter) {
|
|
593
|
+
const frameworkToMinimalStarter = {
|
|
594
|
+
next: "next_minimal",
|
|
595
|
+
nuxt: "nuxt_minimal",
|
|
596
|
+
sveltekit: "sveltekit_minimal"
|
|
597
|
+
};
|
|
598
|
+
starterId = frameworkToMinimalStarter[this.context.framework.wroomTelemetryID];
|
|
599
|
+
}
|
|
591
600
|
try {
|
|
592
601
|
await this.manager.prismicRepository.create({
|
|
593
602
|
domain: this.context.repository.domain,
|
|
594
603
|
framework: this.context.framework.wroomTelemetryID,
|
|
595
|
-
starterId
|
|
604
|
+
starterId
|
|
596
605
|
});
|
|
597
606
|
} catch (error) {
|
|
598
607
|
await this.manager.user.logout();
|
|
@@ -603,7 +612,7 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
|
|
|
603
612
|
await this.manager.prismicRepository.create({
|
|
604
613
|
domain: this.context.repository.domain,
|
|
605
614
|
framework: this.context.framework.wroomTelemetryID,
|
|
606
|
-
starterId
|
|
615
|
+
starterId
|
|
607
616
|
});
|
|
608
617
|
}
|
|
609
618
|
this.context.repository.exists = true;
|