@backstage/cli 0.7.16 → 0.9.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.
Files changed (61) hide show
  1. package/CHANGELOG.md +73 -0
  2. package/config/jest.js +42 -14
  3. package/config/jestEsmTransform.js +4 -21
  4. package/config/jestSucraseTransform.js +66 -0
  5. package/dist/cjs/{build-adad8b22.cjs.js → build-5907bd33.cjs.js} +4 -3
  6. package/dist/cjs/{build-093508d5.cjs.js → build-73b8edfc.cjs.js} +4 -3
  7. package/dist/cjs/{build-d7862d7c.cjs.js → build-7571e64b.cjs.js} +4 -3
  8. package/dist/cjs/{build-292d259f.cjs.js → build-9e812f65.cjs.js} +6 -5
  9. package/dist/cjs/{buildImage-7e3cf320.cjs.js → buildImage-7b597eb4.cjs.js} +5 -4
  10. package/dist/cjs/{buildWorkspace-cfea104f.cjs.js → buildWorkspace-779679cc.cjs.js} +5 -4
  11. package/dist/cjs/{bump-27623ef3.cjs.js → bump-67695db2.cjs.js} +31 -8
  12. package/dist/cjs/{bundle-80c7cf66.cjs.js → bundle-561463d9.cjs.js} +6 -5
  13. package/dist/cjs/{clean-f750c0dc.cjs.js → clean-1156a89f.cjs.js} +3 -2
  14. package/dist/cjs/{config-3e7b308b.cjs.js → config-10d49423.cjs.js} +21 -6
  15. package/dist/cjs/create-b0f456f9.cjs.js +483 -0
  16. package/dist/cjs/{createPlugin-a03aceea.cjs.js → createPlugin-2c95815c.cjs.js} +11 -9
  17. package/dist/cjs/{dev-f7d06c3d.cjs.js → dev-a04f9251.cjs.js} +5 -4
  18. package/dist/cjs/{diff-fd2bda97.cjs.js → diff-d009aa81.cjs.js} +3 -2
  19. package/dist/cjs/{docs-8dde3bb5.cjs.js → docs-d4bb9d0c.cjs.js} +4 -3
  20. package/dist/cjs/{index-8ece1803.cjs.js → index-25ca4442.cjs.js} +172 -51
  21. package/dist/cjs/{index-07ce0d55.cjs.js → index-351d0371.cjs.js} +3 -2
  22. package/dist/cjs/{index-39056740.cjs.js → index-af2b13e0.cjs.js} +13 -11
  23. package/dist/cjs/{info-85a45abd.cjs.js → info-05aaf204.cjs.js} +4 -3
  24. package/dist/cjs/{install-8c0b53e3.cjs.js → install-5d8e8fe5.cjs.js} +5 -4
  25. package/dist/cjs/{lint-fffadef5.cjs.js → lint-85c90960.cjs.js} +4 -3
  26. package/dist/cjs/{lint-d2e5b1ca.cjs.js → lint-d1316de9.cjs.js} +4 -3
  27. package/dist/cjs/{pack-f73a4522.cjs.js → pack-58a2ab5d.cjs.js} +3 -2
  28. package/dist/cjs/{packager-e61b2b16.cjs.js → packager-b251454c.cjs.js} +2 -2
  29. package/dist/cjs/{packages-be161005.cjs.js → packages-4a2d7110.cjs.js} +3 -3
  30. package/dist/cjs/{paths-5e0e5ffc.cjs.js → paths-034708b3.cjs.js} +20 -5
  31. package/dist/cjs/{print-5df69d1b.cjs.js → print-5d03aebd.cjs.js} +6 -4
  32. package/dist/cjs/{removePlugin-865c314e.cjs.js → removePlugin-c64823bb.cjs.js} +13 -3
  33. package/dist/cjs/{run-cc82f277.cjs.js → run-924136d8.cjs.js} +9 -4
  34. package/dist/cjs/{schema-66b2f248.cjs.js → schema-d59459da.cjs.js} +4 -3
  35. package/dist/cjs/{serve-7656d962.cjs.js → serve-0f30d0fc.cjs.js} +7 -6
  36. package/dist/cjs/{serve-b1a08c13.cjs.js → serve-28c83157.cjs.js} +8 -7
  37. package/dist/cjs/{server-4f73b8b5.cjs.js → server-652ec9a3.cjs.js} +2 -2
  38. package/dist/cjs/{tasks-4d9e9b1f.cjs.js → tasks-802f087f.cjs.js} +78 -12
  39. package/dist/cjs/{testCommand-55c14530.cjs.js → testCommand-11d07d1b.cjs.js} +4 -3
  40. package/dist/cjs/{validate-1542a59a.cjs.js → validate-3cc188fa.cjs.js} +6 -4
  41. package/dist/index.cjs.js +2 -1
  42. package/package.json +21 -22
  43. package/templates/default-backend-plugin/package.json.hbs +39 -37
  44. package/templates/default-common-plugin-package/.eslintrc.js +3 -0
  45. package/templates/default-common-plugin-package/README.md.hbs +5 -0
  46. package/templates/default-common-plugin-package/package.json.hbs +34 -0
  47. package/templates/default-common-plugin-package/src/index.ts.hbs +19 -0
  48. package/templates/default-common-plugin-package/src/setupTests.ts +1 -0
  49. package/templates/default-common-plugin-package/tsconfig.json +9 -0
  50. package/templates/default-plugin/package.json.hbs +5 -3
  51. package/templates/default-plugin/src/components/ExampleComponent/ExampleComponent.test.tsx.hbs +5 -2
  52. package/templates/default-plugin/src/components/ExampleFetchComponent/ExampleFetchComponent.test.tsx.hbs +2 -2
  53. package/templates/scaffolder-module/.eslintrc.js +3 -0
  54. package/templates/scaffolder-module/README.md.hbs +5 -0
  55. package/templates/scaffolder-module/package.json.hbs +37 -0
  56. package/templates/scaffolder-module/src/actions/example/example.test.ts +50 -0
  57. package/templates/scaffolder-module/src/actions/example/example.ts +57 -0
  58. package/templates/scaffolder-module/src/actions/example/index.ts +1 -0
  59. package/templates/scaffolder-module/src/actions/index.ts +1 -0
  60. package/templates/scaffolder-module/src/index.ts.hbs +8 -0
  61. package/templates/scaffolder-module/tsconfig.json +9 -0
@@ -4,11 +4,14 @@ var fs = require('fs-extra');
4
4
  var path = require('path');
5
5
  var chalk = require('chalk');
6
6
  var inquirer = require('inquirer');
7
- var tasks = require('./tasks-4d9e9b1f.cjs.js');
8
- var index = require('./index-8ece1803.cjs.js');
7
+ var tasks = require('./tasks-802f087f.cjs.js');
8
+ var index = require('./index-25ca4442.cjs.js');
9
+ var errors = require('@backstage/errors');
9
10
  require('handlebars');
10
11
  require('ora');
12
+ require('util');
11
13
  require('recursive-readdir');
14
+ require('child_process');
12
15
  require('commander');
13
16
  require('semver');
14
17
  require('@backstage/cli-common');
@@ -31,6 +34,7 @@ const checkExists = async (rootDir, pluginName) => {
31
34
  throw new Error(chalk__default['default'].red(` Plugin ${chalk__default['default'].cyan(pluginName)} does not exist!`));
32
35
  }
33
36
  } catch (e) {
37
+ errors.assertError(e);
34
38
  throw new Error(chalk__default['default'].red(` There was an error removing plugin ${chalk__default['default'].cyan(pluginName)}: ${e.message}`));
35
39
  }
36
40
  });
@@ -40,6 +44,7 @@ const removePluginDirectory = async (destination) => {
40
44
  try {
41
45
  await fs__default['default'].remove(destination);
42
46
  } catch (e) {
47
+ errors.assertError(e);
43
48
  throw Error(chalk__default['default'].red(` There was a problem removing the plugin directory: ${e.message}`));
44
49
  }
45
50
  });
@@ -51,6 +56,7 @@ const removeSymLink = async (destination) => {
51
56
  try {
52
57
  await fs__default['default'].remove(destination);
53
58
  } catch (e) {
59
+ errors.assertError(e);
54
60
  throw Error(chalk__default['default'].red(` Could not remove symbolic link ${chalk__default['default'].cyan(destination)}: ${e.message}`));
55
61
  }
56
62
  }
@@ -70,6 +76,7 @@ const removeReferencesFromPluginsFile = async (pluginsFile, pluginName) => {
70
76
  try {
71
77
  await removeAllStatementsContainingID(pluginsFile, pluginNameCapitalized);
72
78
  } catch (e) {
79
+ errors.assertError(e);
73
80
  throw new Error(chalk__default['default'].red(` There was an error removing export statement for plugin ${chalk__default['default'].cyan(pluginNameCapitalized)}: ${e.message}`));
74
81
  }
75
82
  });
@@ -79,6 +86,7 @@ const removePluginFromCodeOwners = async (codeOwnersFile, pluginName) => {
79
86
  try {
80
87
  await removeAllStatementsContainingID(codeOwnersFile, pluginName);
81
88
  } catch (e) {
89
+ errors.assertError(e);
82
90
  throw new Error(chalk__default['default'].red(` There was an error removing code owners statement for plugin ${chalk__default['default'].cyan(pluginName)}: ${e.message}`));
83
91
  }
84
92
  });
@@ -97,6 +105,7 @@ const removeReferencesFromAppPackage = async (appPackageFile, pluginName) => {
97
105
  await fs__default['default'].writeFile(appPackageFile, `${JSON.stringify(appPackageFileContentJSON, null, 2)}
98
106
  `, "utf-8");
99
107
  } catch (e) {
108
+ errors.assertError(e);
100
109
  throw new Error(chalk__default['default'].red(` Failed to remove plugin as dependency in app: ${chalk__default['default'].cyan(appPackageFile)}: ${e.message}`));
101
110
  }
102
111
  });
@@ -149,6 +158,7 @@ var removePlugin = async () => {
149
158
  tasks.Task.log(`\u{1F947} Successfully removed ${chalk__default['default'].cyan(`@backstage/plugin-${answers.id}`)}`);
150
159
  tasks.Task.log();
151
160
  } catch (error) {
161
+ errors.assertError(error);
152
162
  tasks.Task.error(error.message);
153
163
  tasks.Task.log("It seems that something went wrong when removing the plugin \u{1F914}");
154
164
  }
@@ -161,4 +171,4 @@ exports.removePluginFromCodeOwners = removePluginFromCodeOwners;
161
171
  exports.removeReferencesFromAppPackage = removeReferencesFromAppPackage;
162
172
  exports.removeReferencesFromPluginsFile = removeReferencesFromPluginsFile;
163
173
  exports.removeSymLink = removeSymLink;
164
- //# sourceMappingURL=removePlugin-865c314e.cjs.js.map
174
+ //# sourceMappingURL=removePlugin-c64823bb.cjs.js.map
@@ -1,8 +1,9 @@
1
1
  'use strict';
2
2
 
3
3
  var child_process = require('child_process');
4
- var index = require('./index-8ece1803.cjs.js');
4
+ var index = require('./index-25ca4442.cjs.js');
5
5
  var util = require('util');
6
+ var errors = require('@backstage/errors');
6
7
 
7
8
  const execFile = util.promisify(child_process.execFile);
8
9
  async function run(name, args = [], options = {}) {
@@ -37,10 +38,14 @@ async function runPlain(cmd, ...args) {
37
38
  const {stdout} = await execFile(cmd, args, {shell: true});
38
39
  return stdout.trim();
39
40
  } catch (error) {
40
- if (error.stderr) {
41
+ errors.assertError(error);
42
+ if ("stderr" in error) {
41
43
  process.stderr.write(error.stderr);
42
44
  }
43
- throw new index.ExitCodeError(error.code, [cmd, ...args].join(" "));
45
+ if (typeof error.code === "number") {
46
+ throw new index.ExitCodeError(error.code, [cmd, ...args].join(" "));
47
+ }
48
+ throw new errors.ForwardedError("Unknown execution error", error);
44
49
  }
45
50
  }
46
51
  async function runCheck(cmd, ...args) {
@@ -73,4 +78,4 @@ async function waitForExit(child, name) {
73
78
  exports.run = run;
74
79
  exports.runCheck = runCheck;
75
80
  exports.runPlain = runPlain;
76
- //# sourceMappingURL=run-cc82f277.cjs.js.map
81
+ //# sourceMappingURL=run-924136d8.cjs.js.map
@@ -1,16 +1,17 @@
1
1
  'use strict';
2
2
 
3
3
  var yaml = require('yaml');
4
- var config = require('./config-3e7b308b.cjs.js');
4
+ var config = require('./config-10d49423.cjs.js');
5
5
  var configLoader = require('@backstage/config-loader');
6
6
  require('@backstage/config');
7
- require('./index-8ece1803.cjs.js');
7
+ require('./index-25ca4442.cjs.js');
8
8
  require('commander');
9
9
  require('chalk');
10
10
  require('fs-extra');
11
11
  require('semver');
12
12
  require('@backstage/cli-common');
13
13
  require('@backstage/config/package.json');
14
+ require('@backstage/errors');
14
15
 
15
16
  var schema = async (cmd) => {
16
17
  const {schema} = await config.loadCliConfig({
@@ -31,4 +32,4 @@ var schema = async (cmd) => {
31
32
  };
32
33
 
33
34
  exports.default = schema;
34
- //# sourceMappingURL=schema-66b2f248.cjs.js.map
35
+ //# sourceMappingURL=schema-d59459da.cjs.js.map
@@ -11,23 +11,24 @@ require('webpack-node-externals');
11
11
  require('@backstage/cli-common');
12
12
  require('terser-webpack-plugin');
13
13
  require('mini-css-extract-plugin');
14
- var index = require('./index-8ece1803.cjs.js');
15
- require('./run-cc82f277.cjs.js');
14
+ var index = require('./index-25ca4442.cjs.js');
15
+ require('./run-924136d8.cjs.js');
16
16
  require('lodash/pickBy');
17
17
  require('yn');
18
18
  require('react-dev-utils/FileSizeReporter');
19
19
  require('react-dev-utils/formatWebpackMessages');
20
20
  require('chalk');
21
- var server = require('./server-4f73b8b5.cjs.js');
22
- var config = require('./config-3e7b308b.cjs.js');
21
+ var server = require('./server-652ec9a3.cjs.js');
22
+ var config = require('./config-10d49423.cjs.js');
23
23
  require('commander');
24
24
  require('semver');
25
25
  require('@backstage/config/package.json');
26
+ require('@backstage/errors');
26
27
  require('child_process');
27
28
  require('util');
28
29
  require('webpack-dev-server');
29
30
  require('react-dev-utils/openBrowser');
30
- require('./paths-5e0e5ffc.cjs.js');
31
+ require('./paths-034708b3.cjs.js');
31
32
  require('./parallel-a4714c72.cjs.js');
32
33
  require('./svgrTemplate-2d0d15cf.cjs.js');
33
34
  require('@backstage/config-loader');
@@ -52,4 +53,4 @@ var serve = async (cmd) => {
52
53
  };
53
54
 
54
55
  exports.default = serve;
55
- //# sourceMappingURL=serve-7656d962.cjs.js.map
56
+ //# sourceMappingURL=serve-0f30d0fc.cjs.js.map
@@ -13,24 +13,25 @@ require('webpack-node-externals');
13
13
  require('@backstage/cli-common');
14
14
  require('terser-webpack-plugin');
15
15
  require('mini-css-extract-plugin');
16
- var index = require('./index-8ece1803.cjs.js');
17
- require('./run-cc82f277.cjs.js');
16
+ var index = require('./index-25ca4442.cjs.js');
17
+ require('./run-924136d8.cjs.js');
18
18
  require('lodash/pickBy');
19
19
  require('yn');
20
20
  require('react-dev-utils/FileSizeReporter');
21
21
  require('react-dev-utils/formatWebpackMessages');
22
- var server = require('./server-4f73b8b5.cjs.js');
23
- var config = require('./config-3e7b308b.cjs.js');
22
+ var server = require('./server-652ec9a3.cjs.js');
23
+ var config = require('./config-10d49423.cjs.js');
24
24
  var Lockfile = require('./Lockfile-80f0eec4.cjs.js');
25
- var lint = require('./lint-d2e5b1ca.cjs.js');
25
+ var lint = require('./lint-d1316de9.cjs.js');
26
26
  require('commander');
27
27
  require('semver');
28
28
  require('@backstage/config/package.json');
29
+ require('@backstage/errors');
29
30
  require('child_process');
30
31
  require('util');
31
32
  require('webpack-dev-server');
32
33
  require('react-dev-utils/openBrowser');
33
- require('./paths-5e0e5ffc.cjs.js');
34
+ require('./paths-034708b3.cjs.js');
34
35
  require('./parallel-a4714c72.cjs.js');
35
36
  require('./svgrTemplate-2d0d15cf.cjs.js');
36
37
  require('@backstage/config-loader');
@@ -74,4 +75,4 @@ var serve = async (cmd) => {
74
75
  };
75
76
 
76
77
  exports.default = serve;
77
- //# sourceMappingURL=serve-b1a08c13.cjs.js.map
78
+ //# sourceMappingURL=serve-28c83157.cjs.js.map
@@ -4,7 +4,7 @@ var fs = require('fs-extra');
4
4
  var webpack = require('webpack');
5
5
  var WebpackDevServer = require('webpack-dev-server');
6
6
  var openBrowser = require('react-dev-utils/openBrowser');
7
- var paths = require('./paths-5e0e5ffc.cjs.js');
7
+ var paths = require('./paths-034708b3.cjs.js');
8
8
 
9
9
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
10
10
 
@@ -70,4 +70,4 @@ async function serveBundle(options) {
70
70
  }
71
71
 
72
72
  exports.serveBundle = serveBundle;
73
- //# sourceMappingURL=server-4f73b8b5.cjs.js.map
73
+ //# sourceMappingURL=server-652ec9a3.cjs.js.map
@@ -2,11 +2,14 @@
2
2
 
3
3
  var fs = require('fs-extra');
4
4
  var path = require('path');
5
+ var index = require('./index-25ca4442.cjs.js');
5
6
  var chalk = require('chalk');
6
7
  var handlebars = require('handlebars');
7
8
  var ora = require('ora');
9
+ var util = require('util');
8
10
  var recursive = require('recursive-readdir');
9
- var index = require('./index-8ece1803.cjs.js');
11
+ var child_process = require('child_process');
12
+ var errors = require('@backstage/errors');
10
13
 
11
14
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
12
15
 
@@ -22,13 +25,13 @@ const USER_ID_RE = /^@[-\w]+$/;
22
25
  const EMAIL_RE = /^[^@]+@[-.\w]+\.[-\w]+$/i;
23
26
  const DEFAULT_OWNER = "@backstage/maintainers";
24
27
  async function getCodeownersFilePath(rootDir) {
25
- const paths = [
28
+ const possiblePaths = [
26
29
  path__default['default'].join(rootDir, ".github", "CODEOWNERS"),
27
30
  path__default['default'].join(rootDir, ".gitlab", "CODEOWNERS"),
28
31
  path__default['default'].join(rootDir, "docs", "CODEOWNERS"),
29
32
  path__default['default'].join(rootDir, "CODEOWNERS")
30
33
  ];
31
- for (const p of paths) {
34
+ for (const p of possiblePaths) {
32
35
  if (await fs__default['default'].pathExists(p)) {
33
36
  return p;
34
37
  }
@@ -51,8 +54,19 @@ function parseOwnerIds(spaceSeparatedOwnerIds) {
51
54
  }
52
55
  return ids;
53
56
  }
54
- async function addCodeownersEntry(codeownersFilePath, ownedPath, ownerIds) {
55
- const allLines = (await fs__default['default'].readFile(codeownersFilePath, "utf8")).split("\n");
57
+ async function addCodeownersEntry(ownedPath, ownerStr, codeownersFilePath) {
58
+ const ownerIds = parseOwnerIds(ownerStr);
59
+ if (!ownerIds || ownerIds.length === 0) {
60
+ return false;
61
+ }
62
+ let filePath = codeownersFilePath;
63
+ if (!filePath) {
64
+ filePath = await getCodeownersFilePath(index.paths.targetRoot);
65
+ if (!filePath) {
66
+ return false;
67
+ }
68
+ }
69
+ const allLines = (await fs__default['default'].readFile(filePath, "utf8")).split("\n");
56
70
  const commentLines = [];
57
71
  for (const line of allLines) {
58
72
  if (line[0] !== "#") {
@@ -75,24 +89,26 @@ async function addCodeownersEntry(codeownersFilePath, ownedPath, ownerIds) {
75
89
  return [entryPath, ...entry.ownerIds].join(" ");
76
90
  });
77
91
  const newLines = [...commentLines, "", ...newDeclarationLines, ""];
78
- await fs__default['default'].writeFile(codeownersFilePath, newLines.join("\n"), "utf8");
92
+ await fs__default['default'].writeFile(filePath, newLines.join("\n"), "utf8");
93
+ return true;
79
94
  }
80
95
 
96
+ const exec = util.promisify(child_process.exec);
81
97
  const TASK_NAME_MAX_LENGTH = 14;
82
98
  class Task {
83
99
  static log(name = "") {
84
- process.stdout.write(`${chalk__default['default'].green(name)}
100
+ process.stderr.write(`${chalk__default['default'].green(name)}
85
101
  `);
86
102
  }
87
103
  static error(message = "") {
88
- process.stdout.write(`
104
+ process.stderr.write(`
89
105
  ${chalk__default['default'].red(message)}
90
106
 
91
107
  `);
92
108
  }
93
109
  static section(name) {
94
110
  const title = chalk__default['default'].green(`${name}:`);
95
- process.stdout.write(`
111
+ process.stderr.write(`
96
112
  ${title}
97
113
  `);
98
114
  }
@@ -107,13 +123,34 @@ ${chalk__default['default'].red(message)}
107
123
  color: "green"
108
124
  }).start();
109
125
  try {
110
- await taskFunc();
126
+ const result = await taskFunc();
111
127
  spinner.succeed();
128
+ return result;
112
129
  } catch (error) {
113
130
  spinner.fail();
114
131
  throw error;
115
132
  }
116
133
  }
134
+ static async forCommand(command, options) {
135
+ try {
136
+ await Task.forItem("executing", command, async () => {
137
+ await exec(command, {cwd: options == null ? void 0 : options.cwd});
138
+ });
139
+ } catch (error) {
140
+ errors.assertError(error);
141
+ if (error.stderr) {
142
+ process.stderr.write(error.stderr);
143
+ }
144
+ if (error.stdout) {
145
+ process.stdout.write(error.stdout);
146
+ }
147
+ if (options == null ? void 0 : options.optional) {
148
+ Task.error(`Warning: Failed to execute command ${chalk__default['default'].cyan(command)}`);
149
+ } else {
150
+ throw new Error(`Failed to execute command '${chalk__default['default'].cyan(command)}', ${error}`);
151
+ }
152
+ }
153
+ }
117
154
  }
118
155
  async function templatingTask(templateDir, destinationDir, context, versionProvider) {
119
156
  const files = await recursive__default['default'](templateDir).catch((error) => {
@@ -127,7 +164,9 @@ async function templatingTask(templateDir, destinationDir, context, versionProvi
127
164
  await Task.forItem("templating", path.basename(file), async () => {
128
165
  const destination = destinationFile.replace(/\.hbs$/, "");
129
166
  const template = await fs__default['default'].readFile(file);
130
- const compiled = handlebars__default['default'].compile(template.toString());
167
+ const compiled = handlebars__default['default'].compile(template.toString(), {
168
+ strict: true
169
+ });
131
170
  const contents = compiled({name: path.basename(destination), ...context}, {
132
171
  helpers: {
133
172
  versionQuery(name, versionHint) {
@@ -152,10 +191,37 @@ async function templatingTask(templateDir, destinationDir, context, versionProvi
152
191
  }
153
192
  }
154
193
  }
194
+ async function addPackageDependency(path, options) {
195
+ try {
196
+ const pkgJson = await fs__default['default'].readJson(path);
197
+ const normalize = (obj) => {
198
+ if (Object.keys(obj).length === 0) {
199
+ return void 0;
200
+ }
201
+ return Object.fromEntries(Object.keys(obj).sort().map((key) => [key, obj[key]]));
202
+ };
203
+ pkgJson.dependencies = normalize({
204
+ ...pkgJson.dependencies,
205
+ ...options.dependencies
206
+ });
207
+ pkgJson.devDependencies = normalize({
208
+ ...pkgJson.devDependencies,
209
+ ...options.devDependencies
210
+ });
211
+ pkgJson.peerDependencies = normalize({
212
+ ...pkgJson.peerDependencies,
213
+ ...options.peerDependencies
214
+ });
215
+ await fs__default['default'].writeJson(path, pkgJson, {spaces: 2});
216
+ } catch (error) {
217
+ throw new Error(`Failed to add package dependencies, ${error}`);
218
+ }
219
+ }
155
220
 
156
221
  exports.Task = Task;
157
222
  exports.addCodeownersEntry = addCodeownersEntry;
223
+ exports.addPackageDependency = addPackageDependency;
158
224
  exports.getCodeownersFilePath = getCodeownersFilePath;
159
225
  exports.parseOwnerIds = parseOwnerIds;
160
226
  exports.templatingTask = templatingTask;
161
- //# sourceMappingURL=tasks-4d9e9b1f.cjs.js.map
227
+ //# sourceMappingURL=tasks-802f087f.cjs.js.map
@@ -1,13 +1,14 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-8ece1803.cjs.js');
4
- var run = require('./run-cc82f277.cjs.js');
3
+ var index = require('./index-25ca4442.cjs.js');
4
+ var run = require('./run-924136d8.cjs.js');
5
5
  require('commander');
6
6
  require('chalk');
7
7
  require('fs-extra');
8
8
  require('semver');
9
9
  require('@backstage/cli-common');
10
10
  require('@backstage/config/package.json');
11
+ require('@backstage/errors');
11
12
  require('child_process');
12
13
  require('util');
13
14
 
@@ -44,4 +45,4 @@ var testCommand = async (cmd) => {
44
45
  };
45
46
 
46
47
  exports.default = testCommand;
47
- //# sourceMappingURL=testCommand-55c14530.cjs.js.map
48
+ //# sourceMappingURL=testCommand-11d07d1b.cjs.js.map
@@ -1,23 +1,25 @@
1
1
  'use strict';
2
2
 
3
- var config = require('./config-3e7b308b.cjs.js');
3
+ var config = require('./config-10d49423.cjs.js');
4
4
  require('@backstage/config-loader');
5
5
  require('@backstage/config');
6
- require('./index-8ece1803.cjs.js');
6
+ require('./index-25ca4442.cjs.js');
7
7
  require('commander');
8
8
  require('chalk');
9
9
  require('fs-extra');
10
10
  require('semver');
11
11
  require('@backstage/cli-common');
12
12
  require('@backstage/config/package.json');
13
+ require('@backstage/errors');
13
14
 
14
15
  var validate = async (cmd) => {
15
16
  await config.loadCliConfig({
16
17
  args: cmd.config,
17
18
  fromPackage: cmd.package,
18
- mockEnv: cmd.lax
19
+ mockEnv: cmd.lax,
20
+ fullVisibility: !cmd.frontend
19
21
  });
20
22
  };
21
23
 
22
24
  exports.default = validate;
23
- //# sourceMappingURL=validate-1542a59a.cjs.js.map
25
+ //# sourceMappingURL=validate-3cc188fa.cjs.js.map
package/dist/index.cjs.js CHANGED
@@ -2,10 +2,11 @@
2
2
 
3
3
  require('commander');
4
4
  require('chalk');
5
- require('./cjs/index-8ece1803.cjs.js');
5
+ require('./cjs/index-25ca4442.cjs.js');
6
6
  require('fs-extra');
7
7
  require('semver');
8
8
  require('@backstage/cli-common');
9
9
  require('@backstage/config/package.json');
10
+ require('@backstage/errors');
10
11
 
11
12
  //# sourceMappingURL=index.cjs.js.map
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@backstage/cli",
3
3
  "description": "CLI for developing Backstage plugins and apps",
4
- "version": "0.7.16",
4
+ "version": "0.9.0",
5
5
  "private": false,
6
6
  "publishConfig": {
7
7
  "access": "public"
@@ -28,22 +28,22 @@
28
28
  "backstage-cli": "bin/backstage-cli"
29
29
  },
30
30
  "dependencies": {
31
- "@babel/core": "^7.4.4",
32
- "@babel/plugin-transform-modules-commonjs": "^7.4.4",
33
- "@backstage/cli-common": "^0.1.4",
34
- "@backstage/config": "^0.1.10",
35
- "@backstage/config-loader": "^0.6.10",
31
+ "@backstage/cli-common": "^0.1.6",
32
+ "@backstage/config": "^0.1.11",
33
+ "@backstage/config-loader": "^0.8.0",
34
+ "@backstage/errors": "^0.1.4",
35
+ "@backstage/types": "^0.1.1",
36
36
  "@hot-loader/react-dom": "^16.13.0",
37
37
  "@lerna/package-graph": "^4.0.0",
38
38
  "@lerna/project": "^4.0.0",
39
39
  "@octokit/request": "^5.4.12",
40
- "@rollup/plugin-commonjs": "^17.1.0",
40
+ "@rollup/plugin-commonjs": "^21.0.1",
41
41
  "@rollup/plugin-json": "^4.0.2",
42
42
  "@rollup/plugin-node-resolve": "^13.0.0",
43
43
  "@rollup/plugin-yaml": "^3.0.0",
44
- "@spotify/eslint-config-base": "^9.0.0",
45
- "@spotify/eslint-config-react": "^10.0.0",
46
- "@spotify/eslint-config-typescript": "^10.0.0",
44
+ "@spotify/eslint-config-base": "^12.0.0",
45
+ "@spotify/eslint-config-react": "^12.0.0",
46
+ "@spotify/eslint-config-typescript": "^12.0.0",
47
47
  "@sucrase/jest-plugin": "^2.1.1",
48
48
  "@sucrase/webpack-loader": "^2.0.0",
49
49
  "@svgr/plugin-jsx": "5.5.x",
@@ -54,7 +54,6 @@
54
54
  "@typescript-eslint/eslint-plugin": "^v4.30.0",
55
55
  "@typescript-eslint/parser": "^v4.28.3",
56
56
  "@yarnpkg/lockfile": "^1.1.0",
57
- "babel-plugin-dynamic-import-node": "^2.3.3",
58
57
  "bfj": "^7.0.2",
59
58
  "buffer": "^6.0.3",
60
59
  "chalk": "^4.0.0",
@@ -83,7 +82,7 @@
83
82
  "jest": "^26.0.1",
84
83
  "jest-css-modules": "^2.1.0",
85
84
  "jest-transform-yaml": "^0.1.1",
86
- "json-schema": "^0.3.0",
85
+ "json-schema": "^0.4.0",
87
86
  "lodash": "^4.17.21",
88
87
  "mini-css-extract-plugin": "^2.4.2",
89
88
  "node-libs-browser": "^2.2.1",
@@ -111,21 +110,21 @@
111
110
  "typescript": "^4.0.3",
112
111
  "util": "^0.12.3",
113
112
  "webpack": "^5.48.0",
114
- "webpack-dev-server": "4.0.0-rc.0",
113
+ "webpack-dev-server": "4.3.1",
115
114
  "webpack-node-externals": "^3.0.0",
116
115
  "yaml": "^1.10.0",
117
116
  "yml-loader": "^2.1.0",
118
117
  "yn": "^4.0.0"
119
118
  },
120
119
  "devDependencies": {
121
- "@backstage/backend-common": "^0.9.6",
122
- "@backstage/config": "^0.1.10",
123
- "@backstage/core-app-api": "^0.1.17",
124
- "@backstage/core-components": "^0.7.0",
125
- "@backstage/core-plugin-api": "^0.1.10",
126
- "@backstage/dev-utils": "^0.2.12",
127
- "@backstage/test-utils": "^0.1.19",
128
- "@backstage/theme": "^0.2.11",
120
+ "@backstage/backend-common": "^0.9.10",
121
+ "@backstage/config": "^0.1.11",
122
+ "@backstage/core-app-api": "^0.1.21",
123
+ "@backstage/core-components": "^0.7.4",
124
+ "@backstage/core-plugin-api": "^0.2.0",
125
+ "@backstage/dev-utils": "^0.2.13",
126
+ "@backstage/test-utils": "^0.1.22",
127
+ "@backstage/theme": "^0.2.13",
129
128
  "@types/diff": "^5.0.0",
130
129
  "@types/express": "^4.17.6",
131
130
  "@types/fs-extra": "^9.0.1",
@@ -235,5 +234,5 @@
235
234
  }
236
235
  }
237
236
  },
238
- "gitHead": "1b02df9f467ea11a4571df46faabe655c3ee10c8"
237
+ "gitHead": "ddfdcd2b44dc9848cf550cea5346d5f9916a36d9"
239
238
  }
@@ -4,41 +4,43 @@
4
4
  "main": "src/index.ts",
5
5
  "types": "src/index.ts",
6
6
  "license": "Apache-2.0",
7
- {{#if privatePackage}} "private": {{privatePackage}},
8
- {{/if}}
7
+ {{#if privatePackage}}
8
+ "private": {{privatePackage}},
9
+ {{/if}}
9
10
  "publishConfig": {
10
- {{#if npmRegistry}} "registry": "{{npmRegistry}}",
11
- {{/if}}
12
- "access": "public",
13
- "main": "dist/index.cjs.js",
14
- "types": "dist/index.d.ts"
15
- },
16
- "scripts": {
17
- "start": "backstage-cli backend:dev",
18
- "build": "backstage-cli backend:build",
19
- "lint": "backstage-cli lint",
20
- "test": "backstage-cli test",
21
- "prepack": "backstage-cli prepack",
22
- "postpack": "backstage-cli postpack",
23
- "clean": "backstage-cli clean"
24
- },
25
- "dependencies": {
26
- "@backstage/backend-common": "{{versionQuery '@backstage/backend-common'}}",
27
- "@backstage/config": "{{versionQuery '@backstage/config'}}",
28
- "@types/express": "{{versionQuery '@types/express' '4.17.6'}}",
29
- "express": "{{versionQuery 'express' '4.17.1'}}",
30
- "express-promise-router": "{{versionQuery 'express-promise-router' '4.1.0'}}",
31
- "winston": "{{versionQuery 'winston' '3.2.1'}}",
32
- "cross-fetch": "{{versionQuery 'cross-fetch' '3.0.6'}}",
33
- "yn": "{{versionQuery 'yn' '4.0.0'}}"
34
- },
35
- "devDependencies": {
36
- "@backstage/cli": "{{versionQuery '@backstage/cli'}}",
37
- "@types/supertest": "{{versionQuery '@types/supertest' '2.0.8'}}",
38
- "supertest": "{{versionQuery 'supertest' '4.0.2'}}",
39
- "msw": "{{versionQuery 'msw' '0.29.0'}}"
40
- },
41
- "files": [
42
- "dist"
43
- ]
44
- }
11
+ {{#if npmRegistry}}
12
+ "registry": "{{npmRegistry}}",
13
+ {{/if}}
14
+ "access": "public",
15
+ "main": "dist/index.cjs.js",
16
+ "types": "dist/index.d.ts"
17
+ },
18
+ "scripts": {
19
+ "start": "backstage-cli backend:dev",
20
+ "build": "backstage-cli backend:build",
21
+ "lint": "backstage-cli lint",
22
+ "test": "backstage-cli test",
23
+ "prepack": "backstage-cli prepack",
24
+ "postpack": "backstage-cli postpack",
25
+ "clean": "backstage-cli clean"
26
+ },
27
+ "dependencies": {
28
+ "@backstage/backend-common": "{{versionQuery '@backstage/backend-common'}}",
29
+ "@backstage/config": "{{versionQuery '@backstage/config'}}",
30
+ "@types/express": "{{versionQuery '@types/express' '4.17.6'}}",
31
+ "express": "{{versionQuery 'express' '4.17.1'}}",
32
+ "express-promise-router": "{{versionQuery 'express-promise-router' '4.1.0'}}",
33
+ "winston": "{{versionQuery 'winston' '3.2.1'}}",
34
+ "cross-fetch": "{{versionQuery 'cross-fetch' '3.0.6'}}",
35
+ "yn": "{{versionQuery 'yn' '4.0.0'}}"
36
+ },
37
+ "devDependencies": {
38
+ "@backstage/cli": "{{versionQuery '@backstage/cli'}}",
39
+ "@types/supertest": "{{versionQuery '@types/supertest' '2.0.8'}}",
40
+ "supertest": "{{versionQuery 'supertest' '4.0.2'}}",
41
+ "msw": "{{versionQuery 'msw' '0.35.0'}}"
42
+ },
43
+ "files": [
44
+ "dist"
45
+ ]
46
+ }
@@ -0,0 +1,3 @@
1
+ module.exports = {
2
+ extends: [require.resolve('@backstage/cli/config/eslint')],
3
+ };
@@ -0,0 +1,5 @@
1
+ # {{name}}
2
+
3
+ Welcome to the common package for the {{id}} plugin!
4
+
5
+ _This plugin was created through the Backstage CLI_