@backstage/create-app 0.5.12 → 0.5.14-next.0

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/CHANGELOG.md CHANGED
@@ -1,5 +1,21 @@
1
1
  # @backstage/create-app
2
2
 
3
+ ## 0.5.14-next.0
4
+
5
+ ### Patch Changes
6
+
7
+ - Bumped create-app version.
8
+ - Updated dependencies
9
+ - @backstage/cli-common@0.1.13
10
+
11
+ ## 0.5.13
12
+
13
+ ### Patch Changes
14
+
15
+ - Bumped create-app version.
16
+ - Updated dependencies
17
+ - @backstage/cli-common@0.1.13
18
+
3
19
  ## 0.5.12
4
20
 
5
21
  ### Patch Changes
package/dist/index.cjs.js CHANGED
@@ -14,16 +14,16 @@ var fetch = require('node-fetch');
14
14
  var child_process = require('child_process');
15
15
  var util = require('util');
16
16
 
17
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
17
+ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
18
18
 
19
- var chalk__default = /*#__PURE__*/_interopDefaultLegacy(chalk);
20
- var inquirer__default = /*#__PURE__*/_interopDefaultLegacy(inquirer);
21
- var os__default = /*#__PURE__*/_interopDefaultLegacy(os);
22
- var fs__default = /*#__PURE__*/_interopDefaultLegacy(fs);
23
- var handlebars__default = /*#__PURE__*/_interopDefaultLegacy(handlebars);
24
- var ora__default = /*#__PURE__*/_interopDefaultLegacy(ora);
25
- var recursive__default = /*#__PURE__*/_interopDefaultLegacy(recursive);
26
- var fetch__default = /*#__PURE__*/_interopDefaultLegacy(fetch);
19
+ var chalk__default = /*#__PURE__*/_interopDefaultCompat(chalk);
20
+ var inquirer__default = /*#__PURE__*/_interopDefaultCompat(inquirer);
21
+ var os__default = /*#__PURE__*/_interopDefaultCompat(os);
22
+ var fs__default = /*#__PURE__*/_interopDefaultCompat(fs);
23
+ var handlebars__default = /*#__PURE__*/_interopDefaultCompat(handlebars);
24
+ var ora__default = /*#__PURE__*/_interopDefaultCompat(ora);
25
+ var recursive__default = /*#__PURE__*/_interopDefaultCompat(recursive);
26
+ var fetch__default = /*#__PURE__*/_interopDefaultCompat(fetch);
27
27
 
28
28
  var __defProp = Object.defineProperty;
29
29
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
@@ -54,40 +54,40 @@ class ExitCodeError extends CustomError {
54
54
  function exitWithError(error) {
55
55
  if (error instanceof ExitCodeError) {
56
56
  process.stderr.write(`
57
- ${chalk__default["default"].red(error.message)}
57
+ ${chalk__default.default.red(error.message)}
58
58
 
59
59
  `);
60
60
  process.exit(error.code);
61
61
  } else {
62
62
  process.stderr.write(`
63
- ${chalk__default["default"].red(`${error}`)}
63
+ ${chalk__default.default.red(`${error}`)}
64
64
 
65
65
  `);
66
66
  process.exit(1);
67
67
  }
68
68
  }
69
69
 
70
- var version$T = "1.24.0";
70
+ var version$T = "1.26.0-next.0";
71
71
 
72
- var version$S = "1.5.1";
72
+ var version$S = "1.5.4-next.0";
73
73
 
74
- var version$R = "0.21.4";
74
+ var version$R = "0.21.7-next.0";
75
75
 
76
- var version$Q = "0.2.14";
76
+ var version$Q = "0.2.17-next.0";
77
77
 
78
- var version$P = "0.5.19";
78
+ var version$P = "0.5.22-next.0";
79
79
 
80
- var version$O = "1.6.1";
80
+ var version$O = "1.6.3";
81
81
 
82
82
  var version$N = "1.4.5";
83
83
 
84
- var version$M = "0.26.0";
84
+ var version$M = "0.26.3-next.0";
85
85
 
86
86
  var version$L = "1.2.0";
87
87
 
88
- var version$K = "1.12.1";
88
+ var version$K = "1.12.3";
89
89
 
90
- var version$J = "0.14.1";
90
+ var version$J = "0.14.4-next.0";
91
91
 
92
92
  var version$I = "1.9.1";
93
93
 
@@ -95,89 +95,89 @@ var version$H = "0.1.1";
95
95
 
96
96
  var version$G = "1.2.4";
97
97
 
98
- var version$F = "1.1.25";
98
+ var version$F = "1.1.26-next.0";
99
99
 
100
- var version$E = "1.5.1";
100
+ var version$E = "1.5.3";
101
101
 
102
102
  var version$D = "0.5.2";
103
103
 
104
- var version$C = "0.11.1";
104
+ var version$C = "0.11.4-next.0";
105
105
 
106
- var version$B = "0.3.62";
106
+ var version$B = "0.3.65-next.0";
107
107
 
108
- var version$A = "0.22.0";
108
+ var version$A = "0.22.4-next.0";
109
109
 
110
- var version$z = "0.1.11";
110
+ var version$z = "0.1.14-next.0";
111
111
 
112
- var version$y = "0.1.0";
112
+ var version$y = "0.1.3-next.0";
113
113
 
114
- var version$x = "0.4.9";
114
+ var version$x = "0.4.12-next.0";
115
115
 
116
- var version$w = "1.18.0";
116
+ var version$w = "1.19.0-next.0";
117
117
 
118
118
  var version$v = "1.0.22";
119
119
 
120
- var version$u = "1.11.0";
120
+ var version$u = "1.11.3-next.0";
121
121
 
122
- var version$t = "1.18.0";
122
+ var version$t = "1.21.1-next.0";
123
123
 
124
- var version$s = "0.1.11";
124
+ var version$s = "0.1.15-next.0";
125
125
 
126
- var version$r = "0.4.1";
126
+ var version$r = "0.4.4-next.0";
127
127
 
128
- var version$q = "0.10.7";
128
+ var version$q = "0.10.10-next.0";
129
129
 
130
- var version$p = "0.4.17";
130
+ var version$p = "0.4.20-next.0";
131
131
 
132
- var version$o = "0.6.12";
132
+ var version$o = "0.6.15-next.0";
133
133
 
134
- var version$n = "0.4.16";
134
+ var version$n = "0.4.19-next.0";
135
135
 
136
- var version$m = "0.6.21";
136
+ var version$m = "0.6.24-next.0";
137
137
 
138
- var version$l = "0.5.37";
138
+ var version$l = "0.5.41-next.0";
139
139
 
140
- var version$k = "0.1.11";
140
+ var version$k = "0.1.14-next.0";
141
141
 
142
142
  var version$j = "0.7.13";
143
143
 
144
144
  var version$i = "0.4.21";
145
145
 
146
- var version$h = "0.7.25";
146
+ var version$h = "0.7.28-next.0";
147
147
 
148
- var version$g = "0.4.12";
148
+ var version$g = "0.4.15-next.0";
149
149
 
150
- var version$f = "0.1.59";
150
+ var version$f = "0.1.62-next.0";
151
151
 
152
- var version$e = "1.19.0";
152
+ var version$e = "1.19.3-next.0";
153
153
 
154
- var version$d = "1.22.0";
154
+ var version$d = "1.22.4-next.0";
155
155
 
156
- var version$c = "1.4.7";
156
+ var version$c = "1.4.10-next.0";
157
157
 
158
- var version$b = "1.7.7";
158
+ var version$b = "1.7.10-next.0";
159
159
 
160
- var version$a = "1.5.4";
160
+ var version$a = "1.5.7-next.0";
161
161
 
162
- var version$9 = "0.1.18";
162
+ var version$9 = "0.1.22-next.0";
163
163
 
164
- var version$8 = "0.5.23";
164
+ var version$8 = "0.5.26-next.0";
165
165
 
166
- var version$7 = "0.1.18";
166
+ var version$7 = "0.1.22-next.0";
167
167
 
168
- var version$6 = "1.2.18";
168
+ var version$6 = "1.2.21-next.0";
169
169
 
170
- var version$5 = "0.7.0";
170
+ var version$5 = "0.7.3-next.0";
171
171
 
172
- var version$4 = "1.10.1";
172
+ var version$4 = "1.10.4-next.0";
173
173
 
174
- var version$3 = "1.2.0";
174
+ var version$3 = "1.2.3-next.0";
175
175
 
176
- var version$2 = "1.1.6";
176
+ var version$2 = "1.1.9-next.0";
177
177
 
178
- var version$1 = "1.10.0";
178
+ var version$1 = "1.10.4-next.0";
179
179
 
180
- var version = "0.8.2";
180
+ var version = "0.8.5-next.0";
181
181
 
182
182
  const packageVersions = {
183
183
  root: version$T,
@@ -243,17 +243,17 @@ const TEN_MINUTES_MS = 1e3 * 60 * 10;
243
243
  const exec = util.promisify(child_process.exec);
244
244
  class Task {
245
245
  static log(name = "") {
246
- process.stdout.write(`${chalk__default["default"].green(name)}
246
+ process.stdout.write(`${chalk__default.default.green(name)}
247
247
  `);
248
248
  }
249
249
  static error(message = "") {
250
250
  process.stdout.write(`
251
- ${chalk__default["default"].red(message)}
251
+ ${chalk__default.default.red(message)}
252
252
 
253
253
  `);
254
254
  }
255
255
  static section(name) {
256
- const title = chalk__default["default"].green(`${name}:`);
256
+ const title = chalk__default.default.green(`${name}:`);
257
257
  process.stdout.write(`
258
258
  ${title}
259
259
  `);
@@ -262,9 +262,9 @@ ${chalk__default["default"].red(message)}
262
262
  process.exit(code);
263
263
  }
264
264
  static async forItem(task, item, taskFunc) {
265
- const paddedTask = chalk__default["default"].green(task.padEnd(TASK_NAME_MAX_LENGTH));
266
- const spinner = ora__default["default"]({
267
- prefixText: chalk__default["default"].green(` ${paddedTask}${chalk__default["default"].cyan(item)}`),
265
+ const paddedTask = chalk__default.default.green(task.padEnd(TASK_NAME_MAX_LENGTH));
266
+ const spinner = ora__default.default({
267
+ prefixText: chalk__default.default.green(` ${paddedTask}${chalk__default.default.cyan(item)}`),
268
268
  spinner: "arc",
269
269
  color: "green"
270
270
  }).start();
@@ -278,7 +278,7 @@ ${chalk__default["default"].red(message)}
278
278
  }
279
279
  }
280
280
  async function templatingTask(templateDir, destinationDir, context) {
281
- const files = await recursive__default["default"](templateDir).catch((error) => {
281
+ const files = await recursive__default.default(templateDir).catch((error) => {
282
282
  throw new Error(`Failed to read template directory: ${error.message}`);
283
283
  });
284
284
  for (const file of files) {
@@ -286,12 +286,12 @@ async function templatingTask(templateDir, destinationDir, context) {
286
286
  destinationDir,
287
287
  path.relative(templateDir, file)
288
288
  );
289
- await fs__default["default"].ensureDir(path.dirname(destinationFile));
289
+ await fs__default.default.ensureDir(path.dirname(destinationFile));
290
290
  if (file.endsWith(".hbs")) {
291
291
  await Task.forItem("templating", path.basename(file), async () => {
292
292
  const destination = destinationFile.replace(/\.hbs$/, "");
293
- const template = await fs__default["default"].readFile(file);
294
- const compiled = handlebars__default["default"].compile(template.toString());
293
+ const template = await fs__default.default.readFile(file);
294
+ const compiled = handlebars__default.default.compile(template.toString());
295
295
  const contents = compiled(
296
296
  { name: path.basename(destination), ...context },
297
297
  {
@@ -305,7 +305,7 @@ async function templatingTask(templateDir, destinationDir, context) {
305
305
  }
306
306
  }
307
307
  );
308
- await fs__default["default"].writeFile(destination, contents).catch((error) => {
308
+ await fs__default.default.writeFile(destination, contents).catch((error) => {
309
309
  throw new Error(
310
310
  `Failed to create file: ${destination}: ${error.message}`
311
311
  );
@@ -313,7 +313,7 @@ async function templatingTask(templateDir, destinationDir, context) {
313
313
  });
314
314
  } else {
315
315
  await Task.forItem("copying", path.basename(file), async () => {
316
- await fs__default["default"].copyFile(file, destinationFile).catch((error) => {
316
+ await fs__default.default.copyFile(file, destinationFile).catch((error) => {
317
317
  const destination = destinationFile;
318
318
  throw new Error(
319
319
  `Failed to copy file to ${destination} : ${error.message}`
@@ -326,8 +326,8 @@ async function templatingTask(templateDir, destinationDir, context) {
326
326
  async function checkAppExistsTask(rootDir, name) {
327
327
  await Task.forItem("checking", name, async () => {
328
328
  const destination = path.resolve(rootDir, name);
329
- if (await fs__default["default"].pathExists(destination)) {
330
- const existing = chalk__default["default"].cyan(destination.replace(`${rootDir}/`, ""));
329
+ if (await fs__default.default.pathExists(destination)) {
330
+ const existing = chalk__default.default.cyan(destination.replace(`${rootDir}/`, ""));
331
331
  throw new Error(
332
332
  `A directory with the same name already exists: ${existing}
333
333
  Please try again with a different app name`
@@ -338,7 +338,7 @@ Please try again with a different app name`
338
338
  async function checkPathExistsTask(path) {
339
339
  await Task.forItem("checking", path, async () => {
340
340
  try {
341
- await fs__default["default"].mkdirs(path);
341
+ await fs__default.default.mkdirs(path);
342
342
  } catch (error) {
343
343
  throw new Error(`Failed to create app directory: ${error.message}`);
344
344
  }
@@ -361,7 +361,7 @@ async function buildAppTask(appDir) {
361
361
  await exec(cmd).catch((error) => {
362
362
  process.stdout.write(error.stderr);
363
363
  process.stdout.write(error.stdout);
364
- throw new Error(`Could not execute command ${chalk__default["default"].cyan(cmd)}`);
364
+ throw new Error(`Could not execute command ${chalk__default.default.cyan(cmd)}`);
365
365
  });
366
366
  });
367
367
  };
@@ -375,18 +375,18 @@ async function buildAppTask(appDir) {
375
375
  }
376
376
  async function moveAppTask(tempDir, destination, id) {
377
377
  await Task.forItem("moving", id, async () => {
378
- await fs__default["default"].move(tempDir, destination).catch((error) => {
378
+ await fs__default.default.move(tempDir, destination).catch((error) => {
379
379
  throw new Error(
380
380
  `Failed to move app from ${tempDir} to ${destination}: ${error.message}`
381
381
  );
382
382
  }).finally(() => {
383
- fs__default["default"].removeSync(tempDir);
383
+ fs__default.default.removeSync(tempDir);
384
384
  });
385
385
  });
386
386
  }
387
387
  async function readGitConfig() {
388
388
  var _a;
389
- const tempDir = await fs__default["default"].mkdtemp(path.resolve(os__default["default"].tmpdir(), "git-temp-dir-"));
389
+ const tempDir = await fs__default.default.mkdtemp(path.resolve(os__default.default.tmpdir(), "git-temp-dir-"));
390
390
  try {
391
391
  await exec("git init", { cwd: tempDir });
392
392
  await exec('git commit --allow-empty -m "Initial commit"', {
@@ -402,7 +402,7 @@ async function readGitConfig() {
402
402
  } catch (error) {
403
403
  return void 0;
404
404
  } finally {
405
- await fs__default["default"].rm(tempDir, { recursive: true });
405
+ await fs__default.default.rm(tempDir, { recursive: true });
406
406
  }
407
407
  }
408
408
  async function tryInitGitRepository(dir) {
@@ -418,7 +418,7 @@ async function tryInitGitRepository(dir) {
418
418
  return true;
419
419
  } catch (error) {
420
420
  try {
421
- await fs__default["default"].rm(path.resolve(dir, ".git"), { recursive: true, force: true });
421
+ await fs__default.default.rm(path.resolve(dir, ".git"), { recursive: true, force: true });
422
422
  } catch {
423
423
  throw new Error("Failed to remove .git folder");
424
424
  }
@@ -430,7 +430,7 @@ async function fetchYarnLockSeedTask(dir) {
430
430
  await Task.forItem("fetching", "yarn.lock seed", async () => {
431
431
  const controller = new AbortController();
432
432
  const timeout = setTimeout(() => controller.abort(), 3e3);
433
- const res = await fetch__default["default"](
433
+ const res = await fetch__default.default(
434
434
  "https://raw.githubusercontent.com/backstage/backstage/master/packages/create-app/seed-yarn.lock",
435
435
  {
436
436
  signal: controller.signal
@@ -443,7 +443,7 @@ async function fetchYarnLockSeedTask(dir) {
443
443
  );
444
444
  }
445
445
  const initialYarnLockContent = await res.text();
446
- await fs__default["default"].writeFile(
446
+ await fs__default.default.writeFile(
447
447
  path.resolve(dir, "yarn.lock"),
448
448
  initialYarnLockContent.split("\n").filter((l) => !l.startsWith("//")).join("\n"),
449
449
  "utf8"
@@ -459,17 +459,17 @@ const DEFAULT_BRANCH = "master";
459
459
  var createApp = async (opts) => {
460
460
  var _a, _b, _c, _d;
461
461
  const paths = cliCommon.findPaths(__dirname);
462
- const answers = await inquirer__default["default"].prompt([
462
+ const answers = await inquirer__default.default.prompt([
463
463
  {
464
464
  type: "input",
465
465
  name: "name",
466
466
  default: "backstage",
467
- message: chalk__default["default"].blue("Enter a name for the app [required]"),
467
+ message: chalk__default.default.blue("Enter a name for the app [required]"),
468
468
  validate: (value) => {
469
469
  if (!value) {
470
- return chalk__default["default"].red("Please enter a name for the app");
470
+ return chalk__default.default.red("Please enter a name for the app");
471
471
  } else if (!/^[a-z0-9]+(-[a-z0-9]+)*$/.test(value)) {
472
- return chalk__default["default"].red(
472
+ return chalk__default.default.red(
473
473
  "App name must be lowercase and contain only letters, digits, and dashes."
474
474
  );
475
475
  }
@@ -503,7 +503,7 @@ var createApp = async (opts) => {
503
503
  Task.section("Checking if the directory is available");
504
504
  await checkAppExistsTask(paths.targetDir, answers.name);
505
505
  Task.section("Creating a temporary app directory");
506
- const tempDir = await fs__default["default"].mkdtemp(path.resolve(os__default["default"].tmpdir(), answers.name));
506
+ const tempDir = await fs__default.default.mkdtemp(path.resolve(os__default.default.tmpdir(), answers.name));
507
507
  Task.section("Preparing files");
508
508
  await templatingTask(templateDir, tempDir, {
509
509
  ...answers,
@@ -525,12 +525,12 @@ var createApp = async (opts) => {
525
525
  }
526
526
  Task.log();
527
527
  Task.log(
528
- chalk__default["default"].green(`\u{1F947} Successfully created ${chalk__default["default"].cyan(answers.name)}`)
528
+ chalk__default.default.green(`\u{1F947} Successfully created ${chalk__default.default.cyan(answers.name)}`)
529
529
  );
530
530
  Task.log();
531
531
  if (!fetchedYarnLockSeed) {
532
532
  Task.log(
533
- chalk__default["default"].yellow(
533
+ chalk__default.default.yellow(
534
534
  [
535
535
  "Warning: Failed to fetch the yarn.lock seed file.",
536
536
  " You may end up with incompatible dependencies that break the app.",
@@ -543,13 +543,13 @@ var createApp = async (opts) => {
543
543
  Task.section("All set! Now you might want to");
544
544
  if (opts.skipInstall) {
545
545
  Task.log(
546
- ` Install the dependencies: ${chalk__default["default"].cyan(
546
+ ` Install the dependencies: ${chalk__default.default.cyan(
547
547
  `cd ${(_c = opts.path) != null ? _c : answers.name} && yarn install`
548
548
  )}`
549
549
  );
550
550
  }
551
551
  Task.log(
552
- ` Run the app: ${chalk__default["default"].cyan(
552
+ ` Run the app: ${chalk__default.default.cyan(
553
553
  `cd ${(_d = opts.path) != null ? _d : answers.name} && yarn dev`
554
554
  )}`
555
555
  );
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../src/lib/errors.ts","../src/lib/versions.ts","../src/lib/tasks.ts","../src/createApp.ts","../src/index.ts"],"sourcesContent":["/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport chalk from 'chalk';\n\nexport class CustomError extends Error {\n get name(): string {\n return this.constructor.name;\n }\n}\n\nexport class ExitCodeError extends CustomError {\n readonly code: number;\n\n constructor(code: number, command?: string) {\n if (command) {\n super(`Command '${command}' exited with code ${code}`);\n } else {\n super(`Child exited with code ${code}`);\n }\n this.code = code;\n }\n}\n\nexport function exitWithError(error: Error): never {\n if (error instanceof ExitCodeError) {\n process.stderr.write(`\\n${chalk.red(error.message)}\\n\\n`);\n process.exit(error.code);\n } else {\n process.stderr.write(`\\n${chalk.red(`${error}`)}\\n\\n`);\n process.exit(1);\n }\n}\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/* eslint-disable @backstage/no-relative-monorepo-imports */\n\n/*\nThis is a list of all packages used by the template. If dependencies are added or removed,\nthis list should be updated as well.\n\nThere is a release step that ensures that this package is always bumped with every\nrelease, meaning these version will always be up to date.\n\nThis does not create an actual dependency on these packages and does not bring in any code.\nRelative imports are used rather than package imports to make sure the packages aren't externalized.\nRollup will extract the value of the version field in each package at build time without\nleaving any imports in place.\n*/\n\nimport { version as root } from '../../../../package.json';\n\nimport { version as appDefaults } from '../../../app-defaults/package.json';\nimport { version as backendCommon } from '../../../backend-common/package.json';\nimport { version as backendDefaults } from '../../../backend-defaults/package.json';\nimport { version as backendTasks } from '../../../backend-tasks/package.json';\nimport { version as catalogClient } from '../../../catalog-client/package.json';\nimport { version as catalogModel } from '../../../catalog-model/package.json';\nimport { version as cli } from '../../../cli/package.json';\nimport { version as config } from '../../../config/package.json';\nimport { version as coreAppApi } from '../../../core-app-api/package.json';\nimport { version as coreComponents } from '../../../core-components/package.json';\nimport { version as corePluginApi } from '../../../core-plugin-api/package.json';\nimport { version as e2eTestUtils } from '../../../e2e-test-utils/package.json';\nimport { version as errors } from '../../../errors/package.json';\nimport { version as integrationReact } from '../../../integration-react/package.json';\nimport { version as testUtils } from '../../../test-utils/package.json';\nimport { version as theme } from '../../../theme/package.json';\n\nimport { version as pluginApiDocs } from '../../../../plugins/api-docs/package.json';\nimport { version as pluginAppBackend } from '../../../../plugins/app-backend/package.json';\nimport { version as pluginAuthBackend } from '../../../../plugins/auth-backend/package.json';\nimport { version as pluginAuthBackendModuleGithubProvider } from '../../../../plugins/auth-backend-module-github-provider/package.json';\nimport { version as pluginAuthBackendModuleGuestProvider } from '../../../../plugins/auth-backend-module-guest-provider/package.json';\nimport { version as pluginAuthNode } from '../../../../plugins/auth-node/package.json';\nimport { version as pluginCatalog } from '../../../../plugins/catalog/package.json';\nimport { version as pluginCatalogCommon } from '../../../../plugins/catalog-common/package.json';\nimport { version as pluginCatalogReact } from '../../../../plugins/catalog-react/package.json';\nimport { version as pluginCatalogBackend } from '../../../../plugins/catalog-backend/package.json';\nimport { version as pluginCatalogBackendModuleScaffolderEntityModel } from '../../../../plugins/catalog-backend-module-scaffolder-entity-model/package.json';\nimport { version as pluginCatalogGraph } from '../../../../plugins/catalog-graph/package.json';\nimport { version as pluginCatalogImport } from '../../../../plugins/catalog-import/package.json';\nimport { version as pluginExplore } from '../../../../plugins/explore/package.json';\nimport { version as pluginGithubActions } from '../../../../plugins/github-actions/package.json';\nimport { version as pluginLighthouse } from '../../../../plugins/lighthouse/package.json';\nimport { version as pluginOrg } from '../../../../plugins/org/package.json';\nimport { version as pluginPermissionBackend } from '../../../../plugins/permission-backend/package.json';\nimport { version as pluginPermissionBackendModulePolicyAllowAll } from '../../../../plugins/permission-backend-module-policy-allow-all/package.json';\nimport { version as pluginPermissionCommon } from '../../../../plugins/permission-common/package.json';\nimport { version as pluginPermissionReact } from '../../../../plugins/permission-react/package.json';\nimport { version as pluginPermissionNode } from '../../../../plugins/permission-node/package.json';\nimport { version as pluginProxyBackend } from '../../../../plugins/proxy-backend/package.json';\nimport { version as pluginRollbarBackend } from '../../../../plugins/rollbar-backend/package.json';\nimport { version as pluginScaffolder } from '../../../../plugins/scaffolder/package.json';\nimport { version as pluginScaffolderBackend } from '../../../../plugins/scaffolder-backend/package.json';\nimport { version as pluginSearch } from '../../../../plugins/search/package.json';\nimport { version as pluginSearchReact } from '../../../../plugins/search-react/package.json';\nimport { version as pluginSearchBackend } from '../../../../plugins/search-backend/package.json';\nimport { version as pluginSearchBackendModuleCatalog } from '../../../../plugins/search-backend-module-catalog/package.json';\nimport { version as pluginSearchBackendModulePg } from '../../../../plugins/search-backend-module-pg/package.json';\nimport { version as pluginSearchBackendModuleTechdocs } from '../../../../plugins/search-backend-module-techdocs/package.json';\nimport { version as pluginSearchBackendNode } from '../../../../plugins/search-backend-node/package.json';\nimport { version as pluginTechRadar } from '../../../../plugins/tech-radar/package.json';\nimport { version as pluginTechdocs } from '../../../../plugins/techdocs/package.json';\nimport { version as pluginTechdocsReact } from '../../../../plugins/techdocs-react/package.json';\nimport { version as pluginTechdocsModuleAddonsContrib } from '../../../../plugins/techdocs-module-addons-contrib/package.json';\nimport { version as pluginTechdocsBackend } from '../../../../plugins/techdocs-backend/package.json';\nimport { version as pluginUserSettings } from '../../../../plugins/user-settings/package.json';\n\nexport const packageVersions = {\n root,\n '@backstage/app-defaults': appDefaults,\n '@backstage/backend-common': backendCommon,\n '@backstage/backend-defaults': backendDefaults,\n '@backstage/backend-tasks': backendTasks,\n '@backstage/catalog-client': catalogClient,\n '@backstage/catalog-model': catalogModel,\n '@backstage/cli': cli,\n '@backstage/config': config,\n '@backstage/core-app-api': coreAppApi,\n '@backstage/core-components': coreComponents,\n '@backstage/core-plugin-api': corePluginApi,\n '@backstage/e2e-test-utils': e2eTestUtils,\n '@backstage/errors': errors,\n '@backstage/integration-react': integrationReact,\n '@backstage/plugin-api-docs': pluginApiDocs,\n '@backstage/plugin-app-backend': pluginAppBackend,\n '@backstage/plugin-auth-backend': pluginAuthBackend,\n '@backstage/plugin-auth-backend-module-github-provider':\n pluginAuthBackendModuleGithubProvider,\n '@backstage/plugin-auth-backend-module-guest-provider':\n pluginAuthBackendModuleGuestProvider,\n '@backstage/plugin-auth-node': pluginAuthNode,\n '@backstage/plugin-catalog': pluginCatalog,\n '@backstage/plugin-catalog-common': pluginCatalogCommon,\n '@backstage/plugin-catalog-react': pluginCatalogReact,\n '@backstage/plugin-catalog-backend': pluginCatalogBackend,\n '@backstage/plugin-catalog-backend-module-scaffolder-entity-model':\n pluginCatalogBackendModuleScaffolderEntityModel,\n '@backstage/plugin-catalog-graph': pluginCatalogGraph,\n '@backstage/plugin-catalog-import': pluginCatalogImport,\n '@backstage/plugin-explore': pluginExplore,\n '@backstage/plugin-github-actions': pluginGithubActions,\n '@backstage/plugin-lighthouse': pluginLighthouse,\n '@backstage/plugin-org': pluginOrg,\n '@backstage/plugin-permission-backend': pluginPermissionBackend,\n '@backstage/plugin-permission-backend-module-allow-all-policy':\n pluginPermissionBackendModulePolicyAllowAll,\n '@backstage/plugin-permission-common': pluginPermissionCommon,\n '@backstage/plugin-permission-node': pluginPermissionNode,\n '@backstage/plugin-permission-react': pluginPermissionReact,\n '@backstage/plugin-proxy-backend': pluginProxyBackend,\n '@backstage/plugin-rollbar-backend': pluginRollbarBackend,\n '@backstage/plugin-scaffolder': pluginScaffolder,\n '@backstage/plugin-scaffolder-backend': pluginScaffolderBackend,\n '@backstage/plugin-search': pluginSearch,\n '@backstage/plugin-search-react': pluginSearchReact,\n '@backstage/plugin-search-backend': pluginSearchBackend,\n '@backstage/plugin-search-backend-module-catalog':\n pluginSearchBackendModuleCatalog,\n '@backstage/plugin-search-backend-module-pg': pluginSearchBackendModulePg,\n '@backstage/plugin-search-backend-module-techdocs':\n pluginSearchBackendModuleTechdocs,\n '@backstage/plugin-search-backend-node': pluginSearchBackendNode,\n '@backstage/plugin-tech-radar': pluginTechRadar,\n '@backstage/plugin-techdocs': pluginTechdocs,\n '@backstage/plugin-techdocs-react': pluginTechdocsReact,\n '@backstage/plugin-techdocs-module-addons-contrib':\n pluginTechdocsModuleAddonsContrib,\n '@backstage/plugin-techdocs-backend': pluginTechdocsBackend,\n '@backstage/plugin-user-settings': pluginUserSettings,\n '@backstage/test-utils': testUtils,\n '@backstage/theme': theme,\n};\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport chalk from 'chalk';\nimport fs from 'fs-extra';\nimport handlebars from 'handlebars';\nimport ora from 'ora';\nimport recursive from 'recursive-readdir';\nimport {\n basename,\n dirname,\n resolve as resolvePath,\n relative as relativePath,\n} from 'path';\nimport fetch from 'node-fetch';\nimport { exec as execCb } from 'child_process';\nimport { packageVersions } from './versions';\nimport { promisify } from 'util';\nimport os from 'os';\n\nconst TASK_NAME_MAX_LENGTH = 14;\nconst TEN_MINUTES_MS = 1000 * 60 * 10;\nconst exec = promisify(execCb);\n\nexport type GitConfig = {\n defaultBranch?: string;\n};\n\nexport class Task {\n static log(name: string = '') {\n process.stdout.write(`${chalk.green(name)}\\n`);\n }\n\n static error(message: string = '') {\n process.stdout.write(`\\n${chalk.red(message)}\\n\\n`);\n }\n\n static section(name: string) {\n const title = chalk.green(`${name}:`);\n process.stdout.write(`\\n ${title}\\n`);\n }\n\n static exit(code: number = 0) {\n process.exit(code);\n }\n\n static async forItem(\n task: string,\n item: string,\n taskFunc: () => Promise<void>,\n ): Promise<void> {\n const paddedTask = chalk.green(task.padEnd(TASK_NAME_MAX_LENGTH));\n\n const spinner = ora({\n prefixText: chalk.green(` ${paddedTask}${chalk.cyan(item)}`),\n spinner: 'arc',\n color: 'green',\n }).start();\n\n try {\n await taskFunc();\n spinner.succeed();\n } catch (error) {\n spinner.fail();\n throw error;\n }\n }\n}\n\n/**\n * Generate a templated backstage project\n *\n * @param templateDir - location containing template files\n * @param destinationDir - location to save templated project\n * @param context - template parameters\n */\nexport async function templatingTask(\n templateDir: string,\n destinationDir: string,\n context: any,\n) {\n const files = await recursive(templateDir).catch(error => {\n throw new Error(`Failed to read template directory: ${error.message}`);\n });\n\n for (const file of files) {\n const destinationFile = resolvePath(\n destinationDir,\n relativePath(templateDir, file),\n );\n await fs.ensureDir(dirname(destinationFile));\n\n if (file.endsWith('.hbs')) {\n await Task.forItem('templating', basename(file), async () => {\n const destination = destinationFile.replace(/\\.hbs$/, '');\n\n const template = await fs.readFile(file);\n const compiled = handlebars.compile(template.toString());\n const contents = compiled(\n { name: basename(destination), ...context },\n {\n helpers: {\n version(name: keyof typeof packageVersions) {\n if (name in packageVersions) {\n return packageVersions[name];\n }\n throw new Error(`No version available for package ${name}`);\n },\n },\n },\n );\n\n await fs.writeFile(destination, contents).catch(error => {\n throw new Error(\n `Failed to create file: ${destination}: ${error.message}`,\n );\n });\n });\n } else {\n await Task.forItem('copying', basename(file), async () => {\n await fs.copyFile(file, destinationFile).catch(error => {\n const destination = destinationFile;\n throw new Error(\n `Failed to copy file to ${destination} : ${error.message}`,\n );\n });\n });\n }\n }\n}\n\n/**\n * Verify that application target does not already exist\n *\n * @param rootDir - The directory to create application folder `name`\n * @param name - The specified name of the application\n * @Throws Error - If directory with name of `destination` already exists\n */\nexport async function checkAppExistsTask(rootDir: string, name: string) {\n await Task.forItem('checking', name, async () => {\n const destination = resolvePath(rootDir, name);\n\n if (await fs.pathExists(destination)) {\n const existing = chalk.cyan(destination.replace(`${rootDir}/`, ''));\n throw new Error(\n `A directory with the same name already exists: ${existing}\\nPlease try again with a different app name`,\n );\n }\n });\n}\n\n/**\n * Verify that application `path` exists, otherwise create the directory\n *\n * @param path - target to create directory\n * @throws if `path` is a file, or `fs.mkdir` fails\n */\nexport async function checkPathExistsTask(path: string) {\n await Task.forItem('checking', path, async () => {\n try {\n await fs.mkdirs(path);\n } catch (error) {\n // will fail if a file already exists at given `path`\n throw new Error(`Failed to create app directory: ${error.message}`);\n }\n });\n}\n\n/**\n * Run `yarn install` and `run tsc` in application directory\n *\n * @param appDir - location of application to build\n */\nexport async function buildAppTask(appDir: string) {\n process.chdir(appDir);\n\n await Task.forItem('determining', 'yarn version', async () => {\n const result = await exec('yarn --version');\n const yarnVersion = result.stdout?.trim();\n\n if (yarnVersion && !yarnVersion.startsWith('1.')) {\n throw new Error(\n `@backstage/create-app requires Yarn v1, found '${yarnVersion}'. You can migrate the project to Yarn 3 after creation using https://backstage.io/docs/tutorials/yarn-migration`,\n );\n }\n });\n\n const runCmd = async (cmd: string) => {\n await Task.forItem('executing', cmd, async () => {\n await exec(cmd).catch(error => {\n process.stdout.write(error.stderr);\n process.stdout.write(error.stdout);\n throw new Error(`Could not execute command ${chalk.cyan(cmd)}`);\n });\n });\n };\n\n const installTimeout = setTimeout(() => {\n Task.error(\n \"\\n⏱️ It's taking a long time to install dependencies, you may want to exit (Ctrl-C) and run 'yarn install' and 'yarn tsc' manually\",\n );\n }, TEN_MINUTES_MS);\n\n await runCmd('yarn install').finally(() => clearTimeout(installTimeout));\n await runCmd('yarn tsc');\n}\n\n/**\n * Move temporary directory to destination application folder\n *\n * @param tempDir - source path to copy files from\n * @param destination - target path to copy files\n * @param id - item ID\n * @throws if `fs.move` fails\n */\nexport async function moveAppTask(\n tempDir: string,\n destination: string,\n id: string,\n) {\n await Task.forItem('moving', id, async () => {\n await fs\n .move(tempDir, destination)\n .catch(error => {\n throw new Error(\n `Failed to move app from ${tempDir} to ${destination}: ${error.message}`,\n );\n })\n .finally(() => {\n // remove temporary files on both success and failure\n fs.removeSync(tempDir);\n });\n });\n}\n\n/**\n * Read git configs by creating a temp folder and initializing a repo\n *\n * @throws if `exec` fails\n */\nexport async function readGitConfig(): Promise<GitConfig | undefined> {\n const tempDir = await fs.mkdtemp(resolvePath(os.tmpdir(), 'git-temp-dir-'));\n\n try {\n await exec('git init', { cwd: tempDir });\n await exec('git commit --allow-empty -m \"Initial commit\"', {\n cwd: tempDir,\n });\n\n const getDefaultBranch = await exec(\n 'git branch --format=\"%(refname:short)\"',\n { cwd: tempDir },\n );\n\n return {\n defaultBranch: getDefaultBranch.stdout?.trim() || undefined,\n };\n } catch (error) {\n return undefined;\n } finally {\n await fs.rm(tempDir, { recursive: true });\n }\n}\n\n/**\n * Initializes a git repository in the destination folder if possible\n *\n * @param dir - source path to initialize git repository in\n * @returns true if git repository was initialized\n */\nexport async function tryInitGitRepository(dir: string) {\n try {\n // Check if we're already in a git repo\n await exec('git rev-parse --is-inside-work-tree', { cwd: dir });\n return false;\n } catch {\n /* ignored */\n }\n\n try {\n await exec('git init', { cwd: dir });\n await exec('git add .', { cwd: dir });\n await exec('git commit -m \"Initial commit\"', { cwd: dir });\n return true;\n } catch (error) {\n try {\n await fs.rm(resolvePath(dir, '.git'), { recursive: true, force: true });\n } catch {\n throw new Error('Failed to remove .git folder');\n }\n\n return false;\n }\n}\n\n/**\n * This fetches the yarn.lock seed file at https://github.com/backstage/backstage/blob/master/packages/create-app/seed-yarn.lock\n * Its purpose is to lock individual dependencies with broken releases to known working versions.\n * This flow is decoupled from the release of the create-app package in order to avoid\n * the need to re-publish the create-app package whenever we want to update the seed file.\n *\n * @returns true if the yarn.lock seed file was fetched successfully\n */\nexport async function fetchYarnLockSeedTask(dir: string) {\n try {\n await Task.forItem('fetching', 'yarn.lock seed', async () => {\n const controller = new AbortController();\n const timeout = setTimeout(() => controller.abort(), 3000);\n const res = await fetch(\n 'https://raw.githubusercontent.com/backstage/backstage/master/packages/create-app/seed-yarn.lock',\n {\n signal: controller.signal,\n },\n );\n clearTimeout(timeout);\n\n if (!res.ok) {\n throw new Error(\n `Request failed with status ${res.status} ${res.statusText}`,\n );\n }\n\n const initialYarnLockContent = await res.text();\n\n await fs.writeFile(\n resolvePath(dir, 'yarn.lock'),\n initialYarnLockContent\n .split('\\n')\n .filter(l => !l.startsWith('//'))\n .join('\\n'),\n 'utf8',\n );\n });\n return true;\n } catch {\n return false;\n }\n}\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport chalk from 'chalk';\nimport { OptionValues } from 'commander';\nimport inquirer, { Answers } from 'inquirer';\nimport { resolve as resolvePath } from 'path';\nimport { findPaths } from '@backstage/cli-common';\nimport os from 'os';\nimport fs from 'fs-extra';\nimport {\n Task,\n buildAppTask,\n checkAppExistsTask,\n checkPathExistsTask,\n moveAppTask,\n templatingTask,\n tryInitGitRepository,\n readGitConfig,\n fetchYarnLockSeedTask,\n} from './lib/tasks';\n\nconst DEFAULT_BRANCH = 'master';\n\nexport default async (opts: OptionValues): Promise<void> => {\n /* eslint-disable-next-line no-restricted-syntax */\n const paths = findPaths(__dirname);\n const answers: Answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'name',\n default: 'backstage',\n message: chalk.blue('Enter a name for the app [required]'),\n validate: (value: any) => {\n if (!value) {\n return chalk.red('Please enter a name for the app');\n } else if (!/^[a-z0-9]+(-[a-z0-9]+)*$/.test(value)) {\n return chalk.red(\n 'App name must be lowercase and contain only letters, digits, and dashes.',\n );\n }\n return true;\n },\n when: (a: Answers) => {\n const envName = process.env.BACKSTAGE_APP_NAME;\n if (envName) {\n a.name = envName;\n return false;\n }\n return true;\n },\n },\n ]);\n\n const templateDir = opts.templatePath\n ? paths.resolveTarget(opts.templatePath)\n : paths.resolveOwn('templates/default-app');\n\n // Use `--path` argument as application directory when specified, otherwise\n // create a directory using `answers.name`\n const appDir = opts.path\n ? resolvePath(paths.targetDir, opts.path)\n : resolvePath(paths.targetDir, answers.name);\n\n Task.log();\n Task.log('Creating the app...');\n\n try {\n const gitConfig = await readGitConfig();\n\n if (opts.path) {\n // Template directly to specified path\n\n Task.section('Checking that supplied path exists');\n await checkPathExistsTask(appDir);\n\n Task.section('Preparing files');\n await templatingTask(templateDir, opts.path, {\n ...answers,\n defaultBranch: gitConfig?.defaultBranch ?? DEFAULT_BRANCH,\n });\n } else {\n // Template to temporary location, and then move files\n\n Task.section('Checking if the directory is available');\n await checkAppExistsTask(paths.targetDir, answers.name);\n\n Task.section('Creating a temporary app directory');\n const tempDir = await fs.mkdtemp(resolvePath(os.tmpdir(), answers.name));\n\n Task.section('Preparing files');\n await templatingTask(templateDir, tempDir, {\n ...answers,\n defaultBranch: gitConfig?.defaultBranch ?? DEFAULT_BRANCH,\n });\n\n Task.section('Moving to final location');\n await moveAppTask(tempDir, appDir, answers.name);\n }\n\n const fetchedYarnLockSeed = await fetchYarnLockSeedTask(appDir);\n\n if (gitConfig) {\n if (await tryInitGitRepository(appDir)) {\n // Since we don't know whether we were able to init git before we\n // try, we can't track the actual task execution\n Task.forItem('init', 'git repository', async () => {});\n }\n }\n\n if (!opts.skipInstall) {\n Task.section('Installing dependencies');\n await buildAppTask(appDir);\n }\n\n Task.log();\n Task.log(\n chalk.green(`🥇 Successfully created ${chalk.cyan(answers.name)}`),\n );\n Task.log();\n\n if (!fetchedYarnLockSeed) {\n Task.log(\n chalk.yellow(\n [\n 'Warning: Failed to fetch the yarn.lock seed file.',\n ' You may end up with incompatible dependencies that break the app.',\n ' If you run into any errors, please search the issues at',\n ' https://github.com/backstage/backstage/issues for potential solutions',\n ].join('\\n'),\n ),\n );\n }\n\n Task.section('All set! Now you might want to');\n if (opts.skipInstall) {\n Task.log(\n ` Install the dependencies: ${chalk.cyan(\n `cd ${opts.path ?? answers.name} && yarn install`,\n )}`,\n );\n }\n Task.log(\n ` Run the app: ${chalk.cyan(\n `cd ${opts.path ?? answers.name} && yarn dev`,\n )}`,\n );\n Task.log(\n ' Set up the software catalog: https://backstage.io/docs/features/software-catalog/configuration',\n );\n Task.log(' Add authentication: https://backstage.io/docs/auth/');\n Task.log();\n Task.exit();\n } catch (error) {\n Task.error(String(error));\n\n Task.log('It seems that something went wrong when creating the app 🤔');\n\n Task.error('🔥 Failed to create app!');\n Task.exit(1);\n }\n};\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * A CLI that helps you create your own Backstage app\n *\n * @packageDocumentation\n */\n\nimport { program } from 'commander';\nimport { exitWithError } from './lib/errors';\n// eslint-disable-next-line @backstage/no-relative-monorepo-imports\nimport { version } from '../../../package.json';\nimport createApp from './createApp';\n\nconst main = (argv: string[]) => {\n program\n .name('backstage-create-app')\n .version(version)\n .description('Creates a new app in a new directory or specified path')\n .option(\n '--path [directory]',\n 'Location to store the app defaulting to a new folder with the app name',\n )\n .option(\n '--skip-install',\n 'Skip the install and builds steps after creating the app',\n )\n .option(\n '--template-path [directory]',\n 'Use an external application template instead of the default template',\n )\n .action(cmd => createApp(cmd));\n\n program.parse(argv);\n};\n\nprocess.on('unhandledRejection', rejection => {\n if (rejection instanceof Error) {\n exitWithError(rejection);\n } else {\n exitWithError(new Error(`Unknown rejection: '${rejection}'`));\n }\n});\n\nmain(process.argv);\n"],"names":["chalk","root","appDefaults","backendCommon","backendDefaults","backendTasks","catalogClient","catalogModel","cli","config","coreAppApi","coreComponents","corePluginApi","e2eTestUtils","errors","integrationReact","pluginApiDocs","pluginAppBackend","pluginAuthBackend","pluginAuthBackendModuleGithubProvider","pluginAuthBackendModuleGuestProvider","pluginAuthNode","pluginCatalog","pluginCatalogCommon","pluginCatalogReact","pluginCatalogBackend","pluginCatalogBackendModuleScaffolderEntityModel","pluginCatalogGraph","pluginCatalogImport","pluginExplore","pluginGithubActions","pluginLighthouse","pluginOrg","pluginPermissionBackend","pluginPermissionBackendModulePolicyAllowAll","pluginPermissionCommon","pluginPermissionNode","pluginPermissionReact","pluginProxyBackend","pluginRollbarBackend","pluginScaffolder","pluginScaffolderBackend","pluginSearch","pluginSearchReact","pluginSearchBackend","pluginSearchBackendModuleCatalog","pluginSearchBackendModulePg","pluginSearchBackendModuleTechdocs","pluginSearchBackendNode","pluginTechRadar","pluginTechdocs","pluginTechdocsReact","pluginTechdocsModuleAddonsContrib","pluginTechdocsBackend","pluginUserSettings","testUtils","theme","promisify","execCb","ora","recursive","resolvePath","relativePath","fs","dirname","basename","handlebars","os","fetch","findPaths","inquirer","program","version"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/lib/errors.ts","../src/lib/versions.ts","../src/lib/tasks.ts","../src/createApp.ts","../src/index.ts"],"sourcesContent":["/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport chalk from 'chalk';\n\nexport class CustomError extends Error {\n get name(): string {\n return this.constructor.name;\n }\n}\n\nexport class ExitCodeError extends CustomError {\n readonly code: number;\n\n constructor(code: number, command?: string) {\n if (command) {\n super(`Command '${command}' exited with code ${code}`);\n } else {\n super(`Child exited with code ${code}`);\n }\n this.code = code;\n }\n}\n\nexport function exitWithError(error: Error): never {\n if (error instanceof ExitCodeError) {\n process.stderr.write(`\\n${chalk.red(error.message)}\\n\\n`);\n process.exit(error.code);\n } else {\n process.stderr.write(`\\n${chalk.red(`${error}`)}\\n\\n`);\n process.exit(1);\n }\n}\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/* eslint-disable @backstage/no-relative-monorepo-imports */\n\n/*\nThis is a list of all packages used by the template. If dependencies are added or removed,\nthis list should be updated as well.\n\nThere is a release step that ensures that this package is always bumped with every\nrelease, meaning these version will always be up to date.\n\nThis does not create an actual dependency on these packages and does not bring in any code.\nRelative imports are used rather than package imports to make sure the packages aren't externalized.\nRollup will extract the value of the version field in each package at build time without\nleaving any imports in place.\n*/\n\nimport { version as root } from '../../../../package.json';\n\nimport { version as appDefaults } from '../../../app-defaults/package.json';\nimport { version as backendCommon } from '../../../backend-common/package.json';\nimport { version as backendDefaults } from '../../../backend-defaults/package.json';\nimport { version as backendTasks } from '../../../backend-tasks/package.json';\nimport { version as catalogClient } from '../../../catalog-client/package.json';\nimport { version as catalogModel } from '../../../catalog-model/package.json';\nimport { version as cli } from '../../../cli/package.json';\nimport { version as config } from '../../../config/package.json';\nimport { version as coreAppApi } from '../../../core-app-api/package.json';\nimport { version as coreComponents } from '../../../core-components/package.json';\nimport { version as corePluginApi } from '../../../core-plugin-api/package.json';\nimport { version as e2eTestUtils } from '../../../e2e-test-utils/package.json';\nimport { version as errors } from '../../../errors/package.json';\nimport { version as integrationReact } from '../../../integration-react/package.json';\nimport { version as testUtils } from '../../../test-utils/package.json';\nimport { version as theme } from '../../../theme/package.json';\n\nimport { version as pluginApiDocs } from '../../../../plugins/api-docs/package.json';\nimport { version as pluginAppBackend } from '../../../../plugins/app-backend/package.json';\nimport { version as pluginAuthBackend } from '../../../../plugins/auth-backend/package.json';\nimport { version as pluginAuthBackendModuleGithubProvider } from '../../../../plugins/auth-backend-module-github-provider/package.json';\nimport { version as pluginAuthBackendModuleGuestProvider } from '../../../../plugins/auth-backend-module-guest-provider/package.json';\nimport { version as pluginAuthNode } from '../../../../plugins/auth-node/package.json';\nimport { version as pluginCatalog } from '../../../../plugins/catalog/package.json';\nimport { version as pluginCatalogCommon } from '../../../../plugins/catalog-common/package.json';\nimport { version as pluginCatalogReact } from '../../../../plugins/catalog-react/package.json';\nimport { version as pluginCatalogBackend } from '../../../../plugins/catalog-backend/package.json';\nimport { version as pluginCatalogBackendModuleScaffolderEntityModel } from '../../../../plugins/catalog-backend-module-scaffolder-entity-model/package.json';\nimport { version as pluginCatalogGraph } from '../../../../plugins/catalog-graph/package.json';\nimport { version as pluginCatalogImport } from '../../../../plugins/catalog-import/package.json';\nimport { version as pluginExplore } from '../../../../plugins/explore/package.json';\nimport { version as pluginGithubActions } from '../../../../plugins/github-actions/package.json';\nimport { version as pluginLighthouse } from '../../../../plugins/lighthouse/package.json';\nimport { version as pluginOrg } from '../../../../plugins/org/package.json';\nimport { version as pluginPermissionBackend } from '../../../../plugins/permission-backend/package.json';\nimport { version as pluginPermissionBackendModulePolicyAllowAll } from '../../../../plugins/permission-backend-module-policy-allow-all/package.json';\nimport { version as pluginPermissionCommon } from '../../../../plugins/permission-common/package.json';\nimport { version as pluginPermissionReact } from '../../../../plugins/permission-react/package.json';\nimport { version as pluginPermissionNode } from '../../../../plugins/permission-node/package.json';\nimport { version as pluginProxyBackend } from '../../../../plugins/proxy-backend/package.json';\nimport { version as pluginRollbarBackend } from '../../../../plugins/rollbar-backend/package.json';\nimport { version as pluginScaffolder } from '../../../../plugins/scaffolder/package.json';\nimport { version as pluginScaffolderBackend } from '../../../../plugins/scaffolder-backend/package.json';\nimport { version as pluginSearch } from '../../../../plugins/search/package.json';\nimport { version as pluginSearchReact } from '../../../../plugins/search-react/package.json';\nimport { version as pluginSearchBackend } from '../../../../plugins/search-backend/package.json';\nimport { version as pluginSearchBackendModuleCatalog } from '../../../../plugins/search-backend-module-catalog/package.json';\nimport { version as pluginSearchBackendModulePg } from '../../../../plugins/search-backend-module-pg/package.json';\nimport { version as pluginSearchBackendModuleTechdocs } from '../../../../plugins/search-backend-module-techdocs/package.json';\nimport { version as pluginSearchBackendNode } from '../../../../plugins/search-backend-node/package.json';\nimport { version as pluginTechRadar } from '../../../../plugins/tech-radar/package.json';\nimport { version as pluginTechdocs } from '../../../../plugins/techdocs/package.json';\nimport { version as pluginTechdocsReact } from '../../../../plugins/techdocs-react/package.json';\nimport { version as pluginTechdocsModuleAddonsContrib } from '../../../../plugins/techdocs-module-addons-contrib/package.json';\nimport { version as pluginTechdocsBackend } from '../../../../plugins/techdocs-backend/package.json';\nimport { version as pluginUserSettings } from '../../../../plugins/user-settings/package.json';\n\nexport const packageVersions = {\n root,\n '@backstage/app-defaults': appDefaults,\n '@backstage/backend-common': backendCommon,\n '@backstage/backend-defaults': backendDefaults,\n '@backstage/backend-tasks': backendTasks,\n '@backstage/catalog-client': catalogClient,\n '@backstage/catalog-model': catalogModel,\n '@backstage/cli': cli,\n '@backstage/config': config,\n '@backstage/core-app-api': coreAppApi,\n '@backstage/core-components': coreComponents,\n '@backstage/core-plugin-api': corePluginApi,\n '@backstage/e2e-test-utils': e2eTestUtils,\n '@backstage/errors': errors,\n '@backstage/integration-react': integrationReact,\n '@backstage/plugin-api-docs': pluginApiDocs,\n '@backstage/plugin-app-backend': pluginAppBackend,\n '@backstage/plugin-auth-backend': pluginAuthBackend,\n '@backstage/plugin-auth-backend-module-github-provider':\n pluginAuthBackendModuleGithubProvider,\n '@backstage/plugin-auth-backend-module-guest-provider':\n pluginAuthBackendModuleGuestProvider,\n '@backstage/plugin-auth-node': pluginAuthNode,\n '@backstage/plugin-catalog': pluginCatalog,\n '@backstage/plugin-catalog-common': pluginCatalogCommon,\n '@backstage/plugin-catalog-react': pluginCatalogReact,\n '@backstage/plugin-catalog-backend': pluginCatalogBackend,\n '@backstage/plugin-catalog-backend-module-scaffolder-entity-model':\n pluginCatalogBackendModuleScaffolderEntityModel,\n '@backstage/plugin-catalog-graph': pluginCatalogGraph,\n '@backstage/plugin-catalog-import': pluginCatalogImport,\n '@backstage/plugin-explore': pluginExplore,\n '@backstage/plugin-github-actions': pluginGithubActions,\n '@backstage/plugin-lighthouse': pluginLighthouse,\n '@backstage/plugin-org': pluginOrg,\n '@backstage/plugin-permission-backend': pluginPermissionBackend,\n '@backstage/plugin-permission-backend-module-allow-all-policy':\n pluginPermissionBackendModulePolicyAllowAll,\n '@backstage/plugin-permission-common': pluginPermissionCommon,\n '@backstage/plugin-permission-node': pluginPermissionNode,\n '@backstage/plugin-permission-react': pluginPermissionReact,\n '@backstage/plugin-proxy-backend': pluginProxyBackend,\n '@backstage/plugin-rollbar-backend': pluginRollbarBackend,\n '@backstage/plugin-scaffolder': pluginScaffolder,\n '@backstage/plugin-scaffolder-backend': pluginScaffolderBackend,\n '@backstage/plugin-search': pluginSearch,\n '@backstage/plugin-search-react': pluginSearchReact,\n '@backstage/plugin-search-backend': pluginSearchBackend,\n '@backstage/plugin-search-backend-module-catalog':\n pluginSearchBackendModuleCatalog,\n '@backstage/plugin-search-backend-module-pg': pluginSearchBackendModulePg,\n '@backstage/plugin-search-backend-module-techdocs':\n pluginSearchBackendModuleTechdocs,\n '@backstage/plugin-search-backend-node': pluginSearchBackendNode,\n '@backstage/plugin-tech-radar': pluginTechRadar,\n '@backstage/plugin-techdocs': pluginTechdocs,\n '@backstage/plugin-techdocs-react': pluginTechdocsReact,\n '@backstage/plugin-techdocs-module-addons-contrib':\n pluginTechdocsModuleAddonsContrib,\n '@backstage/plugin-techdocs-backend': pluginTechdocsBackend,\n '@backstage/plugin-user-settings': pluginUserSettings,\n '@backstage/test-utils': testUtils,\n '@backstage/theme': theme,\n};\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport chalk from 'chalk';\nimport fs from 'fs-extra';\nimport handlebars from 'handlebars';\nimport ora from 'ora';\nimport recursive from 'recursive-readdir';\nimport {\n basename,\n dirname,\n resolve as resolvePath,\n relative as relativePath,\n} from 'path';\nimport fetch from 'node-fetch';\nimport { exec as execCb } from 'child_process';\nimport { packageVersions } from './versions';\nimport { promisify } from 'util';\nimport os from 'os';\n\nconst TASK_NAME_MAX_LENGTH = 14;\nconst TEN_MINUTES_MS = 1000 * 60 * 10;\nconst exec = promisify(execCb);\n\nexport type GitConfig = {\n defaultBranch?: string;\n};\n\nexport class Task {\n static log(name: string = '') {\n process.stdout.write(`${chalk.green(name)}\\n`);\n }\n\n static error(message: string = '') {\n process.stdout.write(`\\n${chalk.red(message)}\\n\\n`);\n }\n\n static section(name: string) {\n const title = chalk.green(`${name}:`);\n process.stdout.write(`\\n ${title}\\n`);\n }\n\n static exit(code: number = 0) {\n process.exit(code);\n }\n\n static async forItem(\n task: string,\n item: string,\n taskFunc: () => Promise<void>,\n ): Promise<void> {\n const paddedTask = chalk.green(task.padEnd(TASK_NAME_MAX_LENGTH));\n\n const spinner = ora({\n prefixText: chalk.green(` ${paddedTask}${chalk.cyan(item)}`),\n spinner: 'arc',\n color: 'green',\n }).start();\n\n try {\n await taskFunc();\n spinner.succeed();\n } catch (error) {\n spinner.fail();\n throw error;\n }\n }\n}\n\n/**\n * Generate a templated backstage project\n *\n * @param templateDir - location containing template files\n * @param destinationDir - location to save templated project\n * @param context - template parameters\n */\nexport async function templatingTask(\n templateDir: string,\n destinationDir: string,\n context: any,\n) {\n const files = await recursive(templateDir).catch(error => {\n throw new Error(`Failed to read template directory: ${error.message}`);\n });\n\n for (const file of files) {\n const destinationFile = resolvePath(\n destinationDir,\n relativePath(templateDir, file),\n );\n await fs.ensureDir(dirname(destinationFile));\n\n if (file.endsWith('.hbs')) {\n await Task.forItem('templating', basename(file), async () => {\n const destination = destinationFile.replace(/\\.hbs$/, '');\n\n const template = await fs.readFile(file);\n const compiled = handlebars.compile(template.toString());\n const contents = compiled(\n { name: basename(destination), ...context },\n {\n helpers: {\n version(name: keyof typeof packageVersions) {\n if (name in packageVersions) {\n return packageVersions[name];\n }\n throw new Error(`No version available for package ${name}`);\n },\n },\n },\n );\n\n await fs.writeFile(destination, contents).catch(error => {\n throw new Error(\n `Failed to create file: ${destination}: ${error.message}`,\n );\n });\n });\n } else {\n await Task.forItem('copying', basename(file), async () => {\n await fs.copyFile(file, destinationFile).catch(error => {\n const destination = destinationFile;\n throw new Error(\n `Failed to copy file to ${destination} : ${error.message}`,\n );\n });\n });\n }\n }\n}\n\n/**\n * Verify that application target does not already exist\n *\n * @param rootDir - The directory to create application folder `name`\n * @param name - The specified name of the application\n * @Throws Error - If directory with name of `destination` already exists\n */\nexport async function checkAppExistsTask(rootDir: string, name: string) {\n await Task.forItem('checking', name, async () => {\n const destination = resolvePath(rootDir, name);\n\n if (await fs.pathExists(destination)) {\n const existing = chalk.cyan(destination.replace(`${rootDir}/`, ''));\n throw new Error(\n `A directory with the same name already exists: ${existing}\\nPlease try again with a different app name`,\n );\n }\n });\n}\n\n/**\n * Verify that application `path` exists, otherwise create the directory\n *\n * @param path - target to create directory\n * @throws if `path` is a file, or `fs.mkdir` fails\n */\nexport async function checkPathExistsTask(path: string) {\n await Task.forItem('checking', path, async () => {\n try {\n await fs.mkdirs(path);\n } catch (error) {\n // will fail if a file already exists at given `path`\n throw new Error(`Failed to create app directory: ${error.message}`);\n }\n });\n}\n\n/**\n * Run `yarn install` and `run tsc` in application directory\n *\n * @param appDir - location of application to build\n */\nexport async function buildAppTask(appDir: string) {\n process.chdir(appDir);\n\n await Task.forItem('determining', 'yarn version', async () => {\n const result = await exec('yarn --version');\n const yarnVersion = result.stdout?.trim();\n\n if (yarnVersion && !yarnVersion.startsWith('1.')) {\n throw new Error(\n `@backstage/create-app requires Yarn v1, found '${yarnVersion}'. You can migrate the project to Yarn 3 after creation using https://backstage.io/docs/tutorials/yarn-migration`,\n );\n }\n });\n\n const runCmd = async (cmd: string) => {\n await Task.forItem('executing', cmd, async () => {\n await exec(cmd).catch(error => {\n process.stdout.write(error.stderr);\n process.stdout.write(error.stdout);\n throw new Error(`Could not execute command ${chalk.cyan(cmd)}`);\n });\n });\n };\n\n const installTimeout = setTimeout(() => {\n Task.error(\n \"\\n⏱️ It's taking a long time to install dependencies, you may want to exit (Ctrl-C) and run 'yarn install' and 'yarn tsc' manually\",\n );\n }, TEN_MINUTES_MS);\n\n await runCmd('yarn install').finally(() => clearTimeout(installTimeout));\n await runCmd('yarn tsc');\n}\n\n/**\n * Move temporary directory to destination application folder\n *\n * @param tempDir - source path to copy files from\n * @param destination - target path to copy files\n * @param id - item ID\n * @throws if `fs.move` fails\n */\nexport async function moveAppTask(\n tempDir: string,\n destination: string,\n id: string,\n) {\n await Task.forItem('moving', id, async () => {\n await fs\n .move(tempDir, destination)\n .catch(error => {\n throw new Error(\n `Failed to move app from ${tempDir} to ${destination}: ${error.message}`,\n );\n })\n .finally(() => {\n // remove temporary files on both success and failure\n fs.removeSync(tempDir);\n });\n });\n}\n\n/**\n * Read git configs by creating a temp folder and initializing a repo\n *\n * @throws if `exec` fails\n */\nexport async function readGitConfig(): Promise<GitConfig | undefined> {\n const tempDir = await fs.mkdtemp(resolvePath(os.tmpdir(), 'git-temp-dir-'));\n\n try {\n await exec('git init', { cwd: tempDir });\n await exec('git commit --allow-empty -m \"Initial commit\"', {\n cwd: tempDir,\n });\n\n const getDefaultBranch = await exec(\n 'git branch --format=\"%(refname:short)\"',\n { cwd: tempDir },\n );\n\n return {\n defaultBranch: getDefaultBranch.stdout?.trim() || undefined,\n };\n } catch (error) {\n return undefined;\n } finally {\n await fs.rm(tempDir, { recursive: true });\n }\n}\n\n/**\n * Initializes a git repository in the destination folder if possible\n *\n * @param dir - source path to initialize git repository in\n * @returns true if git repository was initialized\n */\nexport async function tryInitGitRepository(dir: string) {\n try {\n // Check if we're already in a git repo\n await exec('git rev-parse --is-inside-work-tree', { cwd: dir });\n return false;\n } catch {\n /* ignored */\n }\n\n try {\n await exec('git init', { cwd: dir });\n await exec('git add .', { cwd: dir });\n await exec('git commit -m \"Initial commit\"', { cwd: dir });\n return true;\n } catch (error) {\n try {\n await fs.rm(resolvePath(dir, '.git'), { recursive: true, force: true });\n } catch {\n throw new Error('Failed to remove .git folder');\n }\n\n return false;\n }\n}\n\n/**\n * This fetches the yarn.lock seed file at https://github.com/backstage/backstage/blob/master/packages/create-app/seed-yarn.lock\n * Its purpose is to lock individual dependencies with broken releases to known working versions.\n * This flow is decoupled from the release of the create-app package in order to avoid\n * the need to re-publish the create-app package whenever we want to update the seed file.\n *\n * @returns true if the yarn.lock seed file was fetched successfully\n */\nexport async function fetchYarnLockSeedTask(dir: string) {\n try {\n await Task.forItem('fetching', 'yarn.lock seed', async () => {\n const controller = new AbortController();\n const timeout = setTimeout(() => controller.abort(), 3000);\n const res = await fetch(\n 'https://raw.githubusercontent.com/backstage/backstage/master/packages/create-app/seed-yarn.lock',\n {\n signal: controller.signal,\n },\n );\n clearTimeout(timeout);\n\n if (!res.ok) {\n throw new Error(\n `Request failed with status ${res.status} ${res.statusText}`,\n );\n }\n\n const initialYarnLockContent = await res.text();\n\n await fs.writeFile(\n resolvePath(dir, 'yarn.lock'),\n initialYarnLockContent\n .split('\\n')\n .filter(l => !l.startsWith('//'))\n .join('\\n'),\n 'utf8',\n );\n });\n return true;\n } catch {\n return false;\n }\n}\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport chalk from 'chalk';\nimport { OptionValues } from 'commander';\nimport inquirer, { Answers } from 'inquirer';\nimport { resolve as resolvePath } from 'path';\nimport { findPaths } from '@backstage/cli-common';\nimport os from 'os';\nimport fs from 'fs-extra';\nimport {\n Task,\n buildAppTask,\n checkAppExistsTask,\n checkPathExistsTask,\n moveAppTask,\n templatingTask,\n tryInitGitRepository,\n readGitConfig,\n fetchYarnLockSeedTask,\n} from './lib/tasks';\n\nconst DEFAULT_BRANCH = 'master';\n\nexport default async (opts: OptionValues): Promise<void> => {\n /* eslint-disable-next-line no-restricted-syntax */\n const paths = findPaths(__dirname);\n const answers: Answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'name',\n default: 'backstage',\n message: chalk.blue('Enter a name for the app [required]'),\n validate: (value: any) => {\n if (!value) {\n return chalk.red('Please enter a name for the app');\n } else if (!/^[a-z0-9]+(-[a-z0-9]+)*$/.test(value)) {\n return chalk.red(\n 'App name must be lowercase and contain only letters, digits, and dashes.',\n );\n }\n return true;\n },\n when: (a: Answers) => {\n const envName = process.env.BACKSTAGE_APP_NAME;\n if (envName) {\n a.name = envName;\n return false;\n }\n return true;\n },\n },\n ]);\n\n const templateDir = opts.templatePath\n ? paths.resolveTarget(opts.templatePath)\n : paths.resolveOwn('templates/default-app');\n\n // Use `--path` argument as application directory when specified, otherwise\n // create a directory using `answers.name`\n const appDir = opts.path\n ? resolvePath(paths.targetDir, opts.path)\n : resolvePath(paths.targetDir, answers.name);\n\n Task.log();\n Task.log('Creating the app...');\n\n try {\n const gitConfig = await readGitConfig();\n\n if (opts.path) {\n // Template directly to specified path\n\n Task.section('Checking that supplied path exists');\n await checkPathExistsTask(appDir);\n\n Task.section('Preparing files');\n await templatingTask(templateDir, opts.path, {\n ...answers,\n defaultBranch: gitConfig?.defaultBranch ?? DEFAULT_BRANCH,\n });\n } else {\n // Template to temporary location, and then move files\n\n Task.section('Checking if the directory is available');\n await checkAppExistsTask(paths.targetDir, answers.name);\n\n Task.section('Creating a temporary app directory');\n const tempDir = await fs.mkdtemp(resolvePath(os.tmpdir(), answers.name));\n\n Task.section('Preparing files');\n await templatingTask(templateDir, tempDir, {\n ...answers,\n defaultBranch: gitConfig?.defaultBranch ?? DEFAULT_BRANCH,\n });\n\n Task.section('Moving to final location');\n await moveAppTask(tempDir, appDir, answers.name);\n }\n\n const fetchedYarnLockSeed = await fetchYarnLockSeedTask(appDir);\n\n if (gitConfig) {\n if (await tryInitGitRepository(appDir)) {\n // Since we don't know whether we were able to init git before we\n // try, we can't track the actual task execution\n Task.forItem('init', 'git repository', async () => {});\n }\n }\n\n if (!opts.skipInstall) {\n Task.section('Installing dependencies');\n await buildAppTask(appDir);\n }\n\n Task.log();\n Task.log(\n chalk.green(`🥇 Successfully created ${chalk.cyan(answers.name)}`),\n );\n Task.log();\n\n if (!fetchedYarnLockSeed) {\n Task.log(\n chalk.yellow(\n [\n 'Warning: Failed to fetch the yarn.lock seed file.',\n ' You may end up with incompatible dependencies that break the app.',\n ' If you run into any errors, please search the issues at',\n ' https://github.com/backstage/backstage/issues for potential solutions',\n ].join('\\n'),\n ),\n );\n }\n\n Task.section('All set! Now you might want to');\n if (opts.skipInstall) {\n Task.log(\n ` Install the dependencies: ${chalk.cyan(\n `cd ${opts.path ?? answers.name} && yarn install`,\n )}`,\n );\n }\n Task.log(\n ` Run the app: ${chalk.cyan(\n `cd ${opts.path ?? answers.name} && yarn dev`,\n )}`,\n );\n Task.log(\n ' Set up the software catalog: https://backstage.io/docs/features/software-catalog/configuration',\n );\n Task.log(' Add authentication: https://backstage.io/docs/auth/');\n Task.log();\n Task.exit();\n } catch (error) {\n Task.error(String(error));\n\n Task.log('It seems that something went wrong when creating the app 🤔');\n\n Task.error('🔥 Failed to create app!');\n Task.exit(1);\n }\n};\n","/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * A CLI that helps you create your own Backstage app\n *\n * @packageDocumentation\n */\n\nimport { program } from 'commander';\nimport { exitWithError } from './lib/errors';\n// eslint-disable-next-line @backstage/no-relative-monorepo-imports\nimport { version } from '../../../package.json';\nimport createApp from './createApp';\n\nconst main = (argv: string[]) => {\n program\n .name('backstage-create-app')\n .version(version)\n .description('Creates a new app in a new directory or specified path')\n .option(\n '--path [directory]',\n 'Location to store the app defaulting to a new folder with the app name',\n )\n .option(\n '--skip-install',\n 'Skip the install and builds steps after creating the app',\n )\n .option(\n '--template-path [directory]',\n 'Use an external application template instead of the default template',\n )\n .action(cmd => createApp(cmd));\n\n program.parse(argv);\n};\n\nprocess.on('unhandledRejection', rejection => {\n if (rejection instanceof Error) {\n exitWithError(rejection);\n } else {\n exitWithError(new Error(`Unknown rejection: '${rejection}'`));\n }\n});\n\nmain(process.argv);\n"],"names":["chalk","root","appDefaults","backendCommon","backendDefaults","backendTasks","catalogClient","catalogModel","cli","config","coreAppApi","coreComponents","corePluginApi","e2eTestUtils","errors","integrationReact","pluginApiDocs","pluginAppBackend","pluginAuthBackend","pluginAuthBackendModuleGithubProvider","pluginAuthBackendModuleGuestProvider","pluginAuthNode","pluginCatalog","pluginCatalogCommon","pluginCatalogReact","pluginCatalogBackend","pluginCatalogBackendModuleScaffolderEntityModel","pluginCatalogGraph","pluginCatalogImport","pluginExplore","pluginGithubActions","pluginLighthouse","pluginOrg","pluginPermissionBackend","pluginPermissionBackendModulePolicyAllowAll","pluginPermissionCommon","pluginPermissionNode","pluginPermissionReact","pluginProxyBackend","pluginRollbarBackend","pluginScaffolder","pluginScaffolderBackend","pluginSearch","pluginSearchReact","pluginSearchBackend","pluginSearchBackendModuleCatalog","pluginSearchBackendModulePg","pluginSearchBackendModuleTechdocs","pluginSearchBackendNode","pluginTechRadar","pluginTechdocs","pluginTechdocsReact","pluginTechdocsModuleAddonsContrib","pluginTechdocsBackend","pluginUserSettings","testUtils","theme","promisify","execCb","ora","recursive","resolvePath","relativePath","fs","dirname","basename","handlebars","os","fetch","findPaths","inquirer","program","version"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@backstage/create-app",
3
3
  "description": "A CLI that helps you create your own Backstage app",
4
- "version": "0.5.12",
4
+ "version": "0.5.14-next.0",
5
5
  "publishConfig": {
6
6
  "access": "public"
7
7
  },
@@ -44,8 +44,8 @@
44
44
  "recursive-readdir": "^2.2.2"
45
45
  },
46
46
  "devDependencies": {
47
- "@backstage/backend-test-utils": "^0.3.4",
48
- "@backstage/cli": "^0.26.0",
47
+ "@backstage/backend-test-utils": "^0.3.7-next.0",
48
+ "@backstage/cli": "^0.26.3-next.0",
49
49
  "@types/command-exists": "^1.2.0",
50
50
  "@types/fs-extra": "^11.0.0",
51
51
  "@types/inquirer": "^8.1.3",