create-strapi-starter
Advanced tools
Comparing version 0.0.0-experimental.df9d17f2840e984f8f4485694b739bf2b27ffc81 to 0.0.0-experimental.e033e9b9c89837331a60b1b6a2c21a779fffc801
"use strict"; | ||
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||
if (k2 === undefined) k2 = k; | ||
var desc = Object.getOwnPropertyDescriptor(m, k); | ||
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||
desc = { enumerable: true, get: function() { return m[k]; } }; | ||
const node_fs = require("node:fs"); | ||
const node_path = require("node:path"); | ||
const commander = require("commander"); | ||
const path = require("path"); | ||
const os = require("os"); | ||
const fse = require("fs-extra"); | ||
const ora = require("ora"); | ||
const ciEnv = require("ci-info"); | ||
const chalk = require("chalk"); | ||
const generateNew = require("@strapi/generate-new"); | ||
const execa = require("execa"); | ||
const child_process = require("child_process"); | ||
const inquirer = require("inquirer"); | ||
const _interopDefault = (e) => e && e.__esModule ? e : { default: e }; | ||
const commander__default = /* @__PURE__ */ _interopDefault(commander); | ||
const path__default = /* @__PURE__ */ _interopDefault(path); | ||
const os__default = /* @__PURE__ */ _interopDefault(os); | ||
const fse__default = /* @__PURE__ */ _interopDefault(fse); | ||
const ora__default = /* @__PURE__ */ _interopDefault(ora); | ||
const ciEnv__default = /* @__PURE__ */ _interopDefault(ciEnv); | ||
const chalk__default = /* @__PURE__ */ _interopDefault(chalk); | ||
const execa__default = /* @__PURE__ */ _interopDefault(execa); | ||
const inquirer__default = /* @__PURE__ */ _interopDefault(inquirer); | ||
function hasYarn() { | ||
try { | ||
const { exitCode } = execa__default.default.commandSync("yarn --version", { shell: true }); | ||
if (exitCode === 0) | ||
return true; | ||
} catch (err) { | ||
return false; | ||
} | ||
} | ||
const logger = { | ||
error(message) { | ||
console.error(`${chalk__default.default.red("error")}: ${message}`); | ||
}, | ||
warn(message) { | ||
console.log(`${chalk__default.default.yellow("warning")}: ${message}`); | ||
}, | ||
info(message) { | ||
console.log(`${chalk__default.default.blue("info")}: ${message}`); | ||
} | ||
}; | ||
function runInstall(path2, { useYarn } = {}) { | ||
return execa__default.default(useYarn ? "yarn" : "npm", ["install"], { | ||
cwd: path2, | ||
stdin: "ignore" | ||
}); | ||
} | ||
function runApp(rootPath, { useYarn } = {}) { | ||
if (useYarn) { | ||
return execa__default.default("yarn", ["develop"], { | ||
stdio: "inherit", | ||
cwd: rootPath | ||
}); | ||
} | ||
return execa__default.default("npm", ["run", "develop"], { | ||
stdio: "inherit", | ||
cwd: rootPath | ||
}); | ||
} | ||
async function initGit(rootPath) { | ||
try { | ||
await execa__default.default("git", ["init"], { | ||
cwd: rootPath | ||
}); | ||
} catch (err) { | ||
logger.warn("Could not initialize a git repository"); | ||
} | ||
try { | ||
await execa__default.default("git", ["add", "-A"], { cwd: rootPath }); | ||
child_process.execSync('git commit -m "Create Strapi starter project"', { | ||
cwd: rootPath | ||
}); | ||
} catch (err) { | ||
logger.warn("Could not create initial git commit"); | ||
} | ||
} | ||
function stopProcess(message) { | ||
if (message) { | ||
logger.error(message); | ||
} | ||
return process.exit(1); | ||
} | ||
async function getPackageInfo(packageName, options) { | ||
const { useYarn } = options ?? {}; | ||
if (useYarn) { | ||
const { stdout: stdout2 } = await execa__default.default("yarn", ["info", packageName, "--json"]); | ||
const yarnInfo = JSON.parse(stdout2); | ||
return { | ||
name: yarnInfo.data.name, | ||
version: yarnInfo.data.version | ||
}; | ||
} | ||
const { stdout } = await execa__default.default("npm", ["view", packageName, "name", "version", "--silent"]); | ||
const match = stdout.match(/(?<=')(.*?)(?=')/gm); | ||
if (!match) { | ||
throw new Error("No match for name@version"); | ||
} | ||
const [name, version] = match; | ||
return { name, version }; | ||
} | ||
async function getStarterPackageInfo(starter, options) { | ||
const { useYarn } = options ?? {}; | ||
try { | ||
const longhand = `@strapi/starter-${starter}`; | ||
return await getPackageInfo(longhand, { useYarn }); | ||
} catch (error) { | ||
} | ||
try { | ||
return await getPackageInfo(starter, { useYarn }); | ||
} catch (error) { | ||
return stopProcess(`Could not find package ${chalk__default.default.yellow(starter)} on npm`); | ||
} | ||
} | ||
async function downloadNpmStarter(packageInfo, parentDir, options) { | ||
const { name, version } = packageInfo; | ||
const { useYarn } = options ?? {}; | ||
if (useYarn) { | ||
await execa__default.default("yarn", ["add", `${name}@${version}`, "--no-lockfile", "--silent"], { | ||
cwd: parentDir | ||
}); | ||
} else { | ||
await execa__default.default("npm", ["install", `${name}@${version}`, "--no-save", "--silent"], { | ||
cwd: parentDir | ||
}); | ||
} | ||
const exactStarterPath = path__default.default.dirname( | ||
require.resolve(`${name}/package.json`, { paths: [parentDir] }) | ||
); | ||
return exactStarterPath; | ||
} | ||
function readStarterJson(filePath, starter) { | ||
try { | ||
const data = fse__default.default.readFileSync(filePath); | ||
return JSON.parse(data.toString()); | ||
} catch (err) { | ||
stopProcess(`Could not find ${chalk__default.default.yellow("starter.json")} in ${chalk__default.default.yellow(starter)}`); | ||
} | ||
} | ||
async function initPackageJson(rootPath, projectName, { useYarn } = {}) { | ||
const packageManager = useYarn ? "yarn --cwd" : "npm run --prefix"; | ||
try { | ||
await fse__default.default.writeJson( | ||
path.join(rootPath, "package.json"), | ||
{ | ||
name: projectName, | ||
private: true, | ||
version: "0.0.0", | ||
scripts: { | ||
"develop:backend": `${packageManager} backend develop`, | ||
"develop:frontend": `wait-on http://localhost:1337/admin && ${packageManager} frontend develop`, | ||
develop: "cross-env FORCE_COLOR=1 npm-run-all -l -p develop:*" | ||
}, | ||
devDependencies: { | ||
"npm-run-all": "4.1.5", | ||
"wait-on": "5.2.1", | ||
"cross-env": "7.0.3" | ||
} | ||
}, | ||
{ | ||
spaces: 2 | ||
} | ||
); | ||
} catch (err) { | ||
stopProcess(`Failed to create ${chalk__default.default.yellow("package.json")} in ${chalk__default.default.yellow(rootPath)}`); | ||
} | ||
} | ||
async function installWithLogs(path2, options) { | ||
const installPrefix = chalk__default.default.yellow("Installing dependencies:"); | ||
const loader = ora__default.default(installPrefix).start(); | ||
const logInstall = (chunk = "") => { | ||
loader.text = `${installPrefix} ${chunk.toString().split("\n").join(" ")}`; | ||
}; | ||
const runner = runInstall(path2, options); | ||
runner.stdout?.on("data", logInstall); | ||
runner.stderr?.on("data", logInstall); | ||
await runner; | ||
loader.stop(); | ||
console.log(`Dependencies installed ${chalk__default.default.green("successfully")}.`); | ||
} | ||
async function getStarterInfo(starter, { useYarn } = {}) { | ||
const isLocalStarter = ["./", "../", "/"].some((filePrefix) => starter.startsWith(filePrefix)); | ||
let starterPath; | ||
let starterParentPath; | ||
let starterPackageInfo; | ||
if (isLocalStarter) { | ||
console.log("Installing local starter."); | ||
starterPath = path.resolve(starter); | ||
} else { | ||
starterPackageInfo = await getStarterPackageInfo(starter, { useYarn }); | ||
console.log(`Installing ${chalk__default.default.yellow(starterPackageInfo.name)} starter.`); | ||
starterParentPath = await fse__default.default.mkdtemp(path.join(os__default.default.tmpdir(), "strapi-")); | ||
starterPath = await downloadNpmStarter(starterPackageInfo, starterParentPath, { useYarn }); | ||
} | ||
return { isLocalStarter, starterPath, starterParentPath, starterPackageInfo }; | ||
} | ||
async function buildStarter({ projectName, starter }, program2) { | ||
const hasYarnInstalled = hasYarn(); | ||
const { isLocalStarter, starterPath, starterParentPath, starterPackageInfo } = await getStarterInfo(starter, { useYarn: hasYarnInstalled }); | ||
const rootPath = path.resolve(projectName); | ||
const projectBasename = path.basename(rootPath); | ||
const starterJson = readStarterJson(path.join(starterPath, "starter.json"), starter); | ||
try { | ||
await fse__default.default.ensureDir(rootPath); | ||
} catch (error) { | ||
if (error instanceof Error) { | ||
stopProcess(`Failed to create ${chalk__default.default.yellow(rootPath)}: ${error.message}`); | ||
} | ||
Object.defineProperty(o, k2, desc); | ||
}) : (function(o, m, k, k2) { | ||
if (k2 === undefined) k2 = k; | ||
o[k2] = m[k]; | ||
})); | ||
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { | ||
Object.defineProperty(o, "default", { enumerable: true, value: v }); | ||
}) : function(o, v) { | ||
o["default"] = v; | ||
}); | ||
var __importStar = (this && this.__importStar) || function (mod) { | ||
if (mod && mod.__esModule) return mod; | ||
var result = {}; | ||
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||
__setModuleDefault(result, mod); | ||
return result; | ||
}; | ||
var __importDefault = (this && this.__importDefault) || function (mod) { | ||
return (mod && mod.__esModule) ? mod : { "default": mod }; | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const node_fs_1 = require("node:fs"); | ||
const node_path_1 = require("node:path"); | ||
const commander_1 = __importStar(require("commander")); | ||
const build_starter_1 = __importDefault(require("./utils/build-starter")); | ||
const prompt_user_1 = __importDefault(require("./utils/prompt-user")); | ||
const packageJson = JSON.parse((0, node_fs_1.readFileSync)((0, node_path_1.resolve)(__dirname, '../package.json'), 'utf8')); | ||
const program = new commander_1.default.Command(packageJson.name); | ||
stopProcess(`Failed to create ${chalk__default.default.yellow(rootPath)}: ${error}`); | ||
} | ||
const frontendPath = path.join(rootPath, "frontend"); | ||
try { | ||
await fse__default.default.copy(path.join(starterPath, "starter"), frontendPath, { | ||
overwrite: true, | ||
recursive: true | ||
}); | ||
} catch (error) { | ||
if (error instanceof Error) { | ||
stopProcess(`Failed to create ${chalk__default.default.yellow(frontendPath)}: ${error.message}`); | ||
} | ||
stopProcess(`Failed to create ${chalk__default.default.yellow(frontendPath)}`); | ||
} | ||
if (!isLocalStarter && starterParentPath) { | ||
await fse__default.default.remove(starterParentPath); | ||
} | ||
const generateStrapiAppOptions = { | ||
...program2, | ||
starter: starterPackageInfo?.name, | ||
run: false | ||
}; | ||
if (starterJson.template.version) { | ||
generateStrapiAppOptions.template = `${starterJson.template.name}@${starterJson.template.version}`; | ||
} else { | ||
generateStrapiAppOptions.template = starterJson.template.name; | ||
} | ||
await generateNew.generateNewApp(path.join(rootPath, "backend"), generateStrapiAppOptions); | ||
console.log(`Creating Strapi starter frontend at ${chalk__default.default.yellow(frontendPath)}.`); | ||
console.log("Installing frontend dependencies"); | ||
await installWithLogs(frontendPath, { useYarn: hasYarnInstalled }); | ||
initPackageJson(rootPath, projectBasename, { useYarn: hasYarnInstalled }); | ||
try { | ||
const gitignore = path.join(__dirname, "..", "resources", "gitignore"); | ||
await fse__default.default.copy(gitignore, path.join(rootPath, ".gitignore")); | ||
} catch (err) { | ||
logger.warn(`Failed to create file: ${chalk__default.default.yellow(".gitignore")}`); | ||
} | ||
await installWithLogs(rootPath, { useYarn: hasYarnInstalled }); | ||
if (!ciEnv__default.default.isCI) { | ||
await initGit(rootPath); | ||
} | ||
console.log(chalk__default.default.green("Starting the app")); | ||
await runApp(rootPath, { useYarn: hasYarnInstalled }); | ||
} | ||
async function promptUser(projectName, starter, program2) { | ||
const questions = [ | ||
{ | ||
type: "input", | ||
default: "my-strapi-project", | ||
name: "directory", | ||
message: "What would you like to name your project?", | ||
when: !projectName | ||
}, | ||
{ | ||
type: "list", | ||
name: "quick", | ||
message: "Choose your installation type", | ||
when: !program2.quickstart, | ||
choices: [ | ||
{ | ||
name: "Quickstart (recommended)", | ||
value: true | ||
}, | ||
{ | ||
name: "Custom (manual settings)", | ||
value: false | ||
} | ||
] | ||
}, | ||
{ | ||
type: "input", | ||
name: "starter", | ||
when: !starter, | ||
message: "Please provide the npm package name of the starter you want to use:" | ||
} | ||
]; | ||
return inquirer__default.default.prompt(questions); | ||
} | ||
const packageJson = JSON.parse(node_fs.readFileSync(node_path.resolve(__dirname, "../package.json"), "utf8")); | ||
const program = new commander__default.default.Command(packageJson.name); | ||
const incompatibleQuickstartOptions = [ | ||
'dbclient', | ||
'dbhost', | ||
'dbport', | ||
'dbname', | ||
'dbusername', | ||
'dbpassword', | ||
'dbssl', | ||
'dbfile', | ||
"dbclient", | ||
"dbhost", | ||
"dbport", | ||
"dbname", | ||
"dbusername", | ||
"dbpassword", | ||
"dbssl", | ||
"dbfile" | ||
]; | ||
program | ||
.version(packageJson.version) | ||
.arguments('[directory], [starter]') | ||
.option('--use-npm', 'Force usage of npm instead of yarn to create the project') | ||
.option('--debug', 'Display database connection error') | ||
.option('--quickstart', 'Quickstart app creation') | ||
.option('--dbclient <dbclient>', 'Database client') | ||
.option('--dbhost <dbhost>', 'Database host') | ||
.option('--dbport <dbport>', 'Database port') | ||
.option('--dbname <dbname>', 'Database name') | ||
.option('--dbusername <dbusername>', 'Database username') | ||
.option('--dbpassword <dbpassword>', 'Database password') | ||
.option('--dbssl <dbssl>', 'Database SSL') | ||
.option('--dbfile <dbfile>', 'Database file path for sqlite') | ||
.option('--dbforce', 'Overwrite database content if any') | ||
.description('Create a fullstack monorepo application using the strapi backend template specified in the provided starter') | ||
.action((directory, starter, programArgs) => { | ||
const projectArgs = { projectName: directory, starter }; | ||
initProject(projectArgs, programArgs); | ||
program.version(packageJson.version).arguments("[directory], [starter]").option("--use-npm", "Force usage of npm instead of yarn to create the project").option("--debug", "Display database connection error").option("--quickstart", "Quickstart app creation").option("--dbclient <dbclient>", "Database client").option("--dbhost <dbhost>", "Database host").option("--dbport <dbport>", "Database port").option("--dbname <dbname>", "Database name").option("--dbusername <dbusername>", "Database username").option("--dbpassword <dbpassword>", "Database password").option("--dbssl <dbssl>", "Database SSL").option("--dbfile <dbfile>", "Database file path for sqlite").option("--dbforce", "Overwrite database content if any").description( | ||
"Create a fullstack monorepo application using the strapi backend template specified in the provided starter" | ||
).action((directory, starter, programArgs) => { | ||
const projectArgs = { projectName: directory, starter }; | ||
initProject(projectArgs, programArgs); | ||
}); | ||
function generateApp(projectArgs, programArgs) { | ||
if (!projectArgs.projectName || !projectArgs.starter) { | ||
console.error('Please specify the <directory> and <starter> of your project when using --quickstart'); | ||
// eslint-disable-next-line no-process-exit | ||
process.exit(1); | ||
} | ||
return (0, build_starter_1.default)(projectArgs, programArgs); | ||
if (!projectArgs.projectName || !projectArgs.starter) { | ||
console.error( | ||
"Please specify the <directory> and <starter> of your project when using --quickstart" | ||
); | ||
process.exit(1); | ||
} | ||
return buildStarter(projectArgs, programArgs); | ||
} | ||
async function initProject(projectArgs, programArgs) { | ||
const hasIncompatibleQuickstartOptions = incompatibleQuickstartOptions.some((opt) => programArgs[opt]); | ||
if (programArgs.quickstart && hasIncompatibleQuickstartOptions) { | ||
console.error(`The quickstart option is incompatible with the following options: ${incompatibleQuickstartOptions.join(', ')}`); | ||
process.exit(1); | ||
} | ||
if (hasIncompatibleQuickstartOptions) { | ||
programArgs.quickstart = false; // Will disable the quickstart question because != 'undefined' | ||
} | ||
const { projectName, starter } = projectArgs; | ||
if (programArgs.quickstart) { | ||
return generateApp(projectArgs, programArgs); | ||
} | ||
const prompt = await (0, prompt_user_1.default)(projectName, starter, programArgs); | ||
const promptProjectArgs = { | ||
projectName: prompt.directory || projectName, | ||
starter: prompt.starter || starter, | ||
}; | ||
return generateApp(promptProjectArgs, { | ||
...programArgs, | ||
quickstart: prompt.quick || programArgs.quickstart, | ||
}); | ||
const hasIncompatibleQuickstartOptions = incompatibleQuickstartOptions.some( | ||
(opt) => programArgs[opt] | ||
); | ||
if (programArgs.quickstart && hasIncompatibleQuickstartOptions) { | ||
console.error( | ||
`The quickstart option is incompatible with the following options: ${incompatibleQuickstartOptions.join( | ||
", " | ||
)}` | ||
); | ||
process.exit(1); | ||
} | ||
if (hasIncompatibleQuickstartOptions) { | ||
programArgs.quickstart = false; | ||
} | ||
const { projectName, starter } = projectArgs; | ||
if (programArgs.quickstart) { | ||
return generateApp(projectArgs, programArgs); | ||
} | ||
const prompt = await promptUser(projectName, starter, programArgs); | ||
const promptProjectArgs = { | ||
projectName: prompt.directory || projectName, | ||
starter: prompt.starter || starter | ||
}; | ||
return generateApp(promptProjectArgs, { | ||
...programArgs, | ||
quickstart: prompt.quick || programArgs.quickstart | ||
}); | ||
} | ||
try { | ||
program.parse(process.argv); | ||
} | ||
catch (err) { | ||
if (err instanceof commander_1.CommanderError) { | ||
if (err.exitCode && err.exitCode !== 0) { | ||
program.outputHelp(); | ||
} | ||
program.parse(process.argv); | ||
} catch (err) { | ||
if (err instanceof commander.CommanderError) { | ||
if (err.exitCode && err.exitCode !== 0) { | ||
program.outputHelp(); | ||
} | ||
} | ||
} | ||
//# sourceMappingURL=create-strapi-starter.js.map | ||
//# sourceMappingURL=create-strapi-starter.js.map |
{ | ||
"name": "create-strapi-starter", | ||
"version": "0.0.0-experimental.df9d17f2840e984f8f4485694b739bf2b27ffc81", | ||
"version": "0.0.0-experimental.e033e9b9c89837331a60b1b6a2c21a779fffc801", | ||
"description": "Generate a new Strapi application.", | ||
@@ -33,2 +33,3 @@ "keywords": [ | ||
], | ||
"main": "", | ||
"bin": "./bin/index.js", | ||
@@ -40,11 +41,9 @@ "files": [ | ||
"scripts": { | ||
"build": "run -T tsc", | ||
"build:ts": "run -T tsc", | ||
"watch": "run -T tsc -w --preserveWatchOutput", | ||
"build": "pack-up build", | ||
"clean": "run -T rimraf ./dist", | ||
"prepublishOnly": "yarn clean && yarn build", | ||
"lint": "run -T eslint ." | ||
"lint": "run -T eslint .", | ||
"watch": "pack-up watch" | ||
}, | ||
"dependencies": { | ||
"@strapi/generate-new": "0.0.0-experimental.df9d17f2840e984f8f4485694b739bf2b27ffc81", | ||
"@strapi/generate-new": "0.0.0-experimental.e033e9b9c89837331a60b1b6a2c21a779fffc801", | ||
"chalk": "4.1.2", | ||
@@ -59,10 +58,11 @@ "ci-info": "3.8.0", | ||
"devDependencies": { | ||
"eslint-config-custom": "0.0.0-experimental.df9d17f2840e984f8f4485694b739bf2b27ffc81", | ||
"tsconfig": "0.0.0-experimental.df9d17f2840e984f8f4485694b739bf2b27ffc81" | ||
"@strapi/pack-up": "4.23.0", | ||
"eslint-config-custom": "0.0.0-experimental.e033e9b9c89837331a60b1b6a2c21a779fffc801", | ||
"tsconfig": "0.0.0-experimental.e033e9b9c89837331a60b1b6a2c21a779fffc801" | ||
}, | ||
"engines": { | ||
"node": ">=16.0.0 <=20.x.x", | ||
"node": ">=18.0.0 <=20.x.x", | ||
"npm": ">=6.0.0" | ||
}, | ||
"gitHead": "df9d17f2840e984f8f4485694b739bf2b27ffc81" | ||
"gitHead": "e033e9b9c89837331a60b1b6a2c21a779fffc801" | ||
} |
@@ -0,1 +1,5 @@ | ||
> [!WARNING] | ||
> This package is only compatible with Strapi v4 version <br/> | ||
> The most recent versions of Strapi packages can be found at [https://github.com/strapi/strapi](https://github.com/strapi/strapi) | ||
# Create strapi starter | ||
@@ -2,0 +6,0 @@ |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Unidentified License
License(Experimental) Something that seems like a license was found, but its contents could not be matched with a known license.
Found 1 instance in 1 package
78026
706
40
3
8
1
80
4
3
+ Added@strapi/generate-new@0.0.0-experimental.e033e9b9c89837331a60b1b6a2c21a779fffc801(transitive)
+ Addedminipass@5.0.0(transitive)
+ Addedtar@6.2.1(transitive)
- Removed@strapi/generate-new@0.0.0-experimental.df9d17f2840e984f8f4485694b739bf2b27ffc81(transitive)
- Removedminipass@4.2.8(transitive)
- Removedtar@6.1.13(transitive)
Updated@strapi/generate-new@0.0.0-experimental.e033e9b9c89837331a60b1b6a2c21a779fffc801