@backstage/cli 0.8.0 → 0.9.1

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 (62) hide show
  1. package/CHANGELOG.md +74 -0
  2. package/config/jest.js +1 -0
  3. package/config/jestSucraseTransform.js +5 -1
  4. package/dist/cjs/{build-67600f1b.cjs.js → build-33ad5323.cjs.js} +3 -3
  5. package/dist/cjs/{build-e40a0213.cjs.js → build-7302d21d.cjs.js} +3 -3
  6. package/dist/cjs/{build-bc4676c2.cjs.js → build-75ee78ab.cjs.js} +5 -5
  7. package/dist/cjs/{build-b1d7370a.cjs.js → build-e21fe681.cjs.js} +3 -3
  8. package/dist/cjs/{buildImage-87db5bdc.cjs.js → buildImage-477aa186.cjs.js} +4 -4
  9. package/dist/cjs/{buildWorkspace-a2cdfe01.cjs.js → buildWorkspace-fa590fad.cjs.js} +4 -4
  10. package/dist/cjs/{bump-ac730182.cjs.js → bump-5e4ffccb.cjs.js} +28 -6
  11. package/dist/cjs/{bundle-87d28bdc.cjs.js → bundle-4390c300.cjs.js} +5 -5
  12. package/dist/cjs/{clean-35a57bd3.cjs.js → clean-9279505e.cjs.js} +2 -2
  13. package/dist/cjs/{config-1cb21231.cjs.js → config-6ab0fc63.cjs.js} +21 -6
  14. package/dist/cjs/create-4ffadaca.cjs.js +483 -0
  15. package/dist/cjs/{createPlugin-2f659d68.cjs.js → createPlugin-eb7251ea.cjs.js} +8 -9
  16. package/dist/cjs/{dev-16c0ce16.cjs.js → dev-02640e59.cjs.js} +4 -4
  17. package/dist/cjs/{diff-a4954af4.cjs.js → diff-56188f93.cjs.js} +2 -2
  18. package/dist/cjs/{docs-a7479ba6.cjs.js → docs-8039cb55.cjs.js} +3 -3
  19. package/dist/cjs/{index-b7f652f5.cjs.js → index-994e77d9.cjs.js} +170 -51
  20. package/dist/cjs/{index-0f748910.cjs.js → index-a18a4cd9.cjs.js} +13 -11
  21. package/dist/cjs/{index-4c79e77e.cjs.js → index-e84c4ef7.cjs.js} +2 -2
  22. package/dist/cjs/{info-ce3b675b.cjs.js → info-2a0746e3.cjs.js} +3 -3
  23. package/dist/cjs/{install-f429b250.cjs.js → install-807a9039.cjs.js} +4 -4
  24. package/dist/cjs/{lint-91629493.cjs.js → lint-03faccc3.cjs.js} +3 -3
  25. package/dist/cjs/{lint-593f7432.cjs.js → lint-50ae8c8b.cjs.js} +3 -3
  26. package/dist/cjs/{pack-55575502.cjs.js → pack-7d39c708.cjs.js} +2 -2
  27. package/dist/cjs/{packager-ffd3916c.cjs.js → packager-d328c8db.cjs.js} +2 -2
  28. package/dist/cjs/{packages-cf50189b.cjs.js → packages-24e76f27.cjs.js} +3 -3
  29. package/dist/cjs/{paths-905effc9.cjs.js → paths-eecbbe83.cjs.js} +20 -5
  30. package/dist/cjs/{print-e38bfaf2.cjs.js → print-fec91280.cjs.js} +5 -4
  31. package/dist/cjs/{removePlugin-54aea35e.cjs.js → removePlugin-595ea65d.cjs.js} +5 -3
  32. package/dist/cjs/{run-01f17015.cjs.js → run-40072d67.cjs.js} +2 -2
  33. package/dist/cjs/{schema-da983141.cjs.js → schema-00648d3a.cjs.js} +3 -3
  34. package/dist/cjs/{serve-e5e1b0f5.cjs.js → serve-199d043b.cjs.js} +7 -7
  35. package/dist/cjs/{serve-66ee41a6.cjs.js → serve-e57a7acf.cjs.js} +6 -6
  36. package/dist/cjs/{server-d911b5cc.cjs.js → server-c7c24602.cjs.js} +2 -2
  37. package/dist/cjs/{tasks-c4f76ac0.cjs.js → tasks-0f3092d3.cjs.js} +78 -12
  38. package/dist/cjs/{testCommand-7bcc9228.cjs.js → testCommand-a5c5fec6.cjs.js} +3 -3
  39. package/dist/cjs/{validate-ce36976b.cjs.js → validate-011c509c.cjs.js} +5 -4
  40. package/dist/index.cjs.js +1 -1
  41. package/package.json +21 -20
  42. package/templates/default-backend-plugin/package.json.hbs +39 -37
  43. package/templates/default-backend-plugin/src/run.ts.hbs +1 -1
  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/default-plugin/src/routes.ts.hbs +1 -1
  54. package/templates/scaffolder-module/.eslintrc.js +3 -0
  55. package/templates/scaffolder-module/README.md.hbs +5 -0
  56. package/templates/scaffolder-module/package.json.hbs +37 -0
  57. package/templates/scaffolder-module/src/actions/example/example.test.ts +50 -0
  58. package/templates/scaffolder-module/src/actions/example/example.ts +57 -0
  59. package/templates/scaffolder-module/src/actions/example/index.ts +1 -0
  60. package/templates/scaffolder-module/src/actions/index.ts +1 -0
  61. package/templates/scaffolder-module/src/index.ts.hbs +8 -0
  62. package/templates/scaffolder-module/tsconfig.json +9 -0
@@ -13,16 +13,16 @@ 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-b7f652f5.cjs.js');
17
- require('./run-01f17015.cjs.js');
16
+ var index = require('./index-994e77d9.cjs.js');
17
+ require('./run-40072d67.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-d911b5cc.cjs.js');
23
- var config = require('./config-1cb21231.cjs.js');
22
+ var server = require('./server-c7c24602.cjs.js');
23
+ var config = require('./config-6ab0fc63.cjs.js');
24
24
  var Lockfile = require('./Lockfile-80f0eec4.cjs.js');
25
- var lint = require('./lint-593f7432.cjs.js');
25
+ var lint = require('./lint-50ae8c8b.cjs.js');
26
26
  require('commander');
27
27
  require('semver');
28
28
  require('@backstage/config/package.json');
@@ -31,7 +31,7 @@ require('child_process');
31
31
  require('util');
32
32
  require('webpack-dev-server');
33
33
  require('react-dev-utils/openBrowser');
34
- require('./paths-905effc9.cjs.js');
34
+ require('./paths-eecbbe83.cjs.js');
35
35
  require('./parallel-a4714c72.cjs.js');
36
36
  require('./svgrTemplate-2d0d15cf.cjs.js');
37
37
  require('@backstage/config-loader');
@@ -75,4 +75,4 @@ var serve = async (cmd) => {
75
75
  };
76
76
 
77
77
  exports.default = serve;
78
- //# sourceMappingURL=serve-e5e1b0f5.cjs.js.map
78
+ //# sourceMappingURL=serve-199d043b.cjs.js.map
@@ -11,15 +11,15 @@ 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-b7f652f5.cjs.js');
15
- require('./run-01f17015.cjs.js');
14
+ var index = require('./index-994e77d9.cjs.js');
15
+ require('./run-40072d67.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-d911b5cc.cjs.js');
22
- var config = require('./config-1cb21231.cjs.js');
21
+ var server = require('./server-c7c24602.cjs.js');
22
+ var config = require('./config-6ab0fc63.cjs.js');
23
23
  require('commander');
24
24
  require('semver');
25
25
  require('@backstage/config/package.json');
@@ -28,7 +28,7 @@ require('child_process');
28
28
  require('util');
29
29
  require('webpack-dev-server');
30
30
  require('react-dev-utils/openBrowser');
31
- require('./paths-905effc9.cjs.js');
31
+ require('./paths-eecbbe83.cjs.js');
32
32
  require('./parallel-a4714c72.cjs.js');
33
33
  require('./svgrTemplate-2d0d15cf.cjs.js');
34
34
  require('@backstage/config-loader');
@@ -53,4 +53,4 @@ var serve = async (cmd) => {
53
53
  };
54
54
 
55
55
  exports.default = serve;
56
- //# sourceMappingURL=serve-66ee41a6.cjs.js.map
56
+ //# sourceMappingURL=serve-e57a7acf.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-905effc9.cjs.js');
7
+ var paths = require('./paths-eecbbe83.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-d911b5cc.cjs.js.map
73
+ //# sourceMappingURL=server-c7c24602.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-994e77d9.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-b7f652f5.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-c4f76ac0.cjs.js.map
227
+ //# sourceMappingURL=tasks-0f3092d3.cjs.js.map
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-b7f652f5.cjs.js');
4
- var run = require('./run-01f17015.cjs.js');
3
+ var index = require('./index-994e77d9.cjs.js');
4
+ var run = require('./run-40072d67.cjs.js');
5
5
  require('commander');
6
6
  require('chalk');
7
7
  require('fs-extra');
@@ -45,4 +45,4 @@ var testCommand = async (cmd) => {
45
45
  };
46
46
 
47
47
  exports.default = testCommand;
48
- //# sourceMappingURL=testCommand-7bcc9228.cjs.js.map
48
+ //# sourceMappingURL=testCommand-a5c5fec6.cjs.js.map
@@ -1,9 +1,9 @@
1
1
  'use strict';
2
2
 
3
- var config = require('./config-1cb21231.cjs.js');
3
+ var config = require('./config-6ab0fc63.cjs.js');
4
4
  require('@backstage/config-loader');
5
5
  require('@backstage/config');
6
- require('./index-b7f652f5.cjs.js');
6
+ require('./index-994e77d9.cjs.js');
7
7
  require('commander');
8
8
  require('chalk');
9
9
  require('fs-extra');
@@ -16,9 +16,10 @@ var validate = async (cmd) => {
16
16
  await config.loadCliConfig({
17
17
  args: cmd.config,
18
18
  fromPackage: cmd.package,
19
- mockEnv: cmd.lax
19
+ mockEnv: cmd.lax,
20
+ fullVisibility: !cmd.frontend
20
21
  });
21
22
  };
22
23
 
23
24
  exports.default = validate;
24
- //# sourceMappingURL=validate-ce36976b.cjs.js.map
25
+ //# sourceMappingURL=validate-011c509c.cjs.js.map
package/dist/index.cjs.js CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  require('commander');
4
4
  require('chalk');
5
- require('./cjs/index-b7f652f5.cjs.js');
5
+ require('./cjs/index-994e77d9.cjs.js');
6
6
  require('fs-extra');
7
7
  require('semver');
8
8
  require('@backstage/cli-common');
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.8.0",
4
+ "version": "0.9.1",
5
5
  "private": false,
6
6
  "publishConfig": {
7
7
  "access": "public"
@@ -28,21 +28,22 @@
28
28
  "backstage-cli": "bin/backstage-cli"
29
29
  },
30
30
  "dependencies": {
31
- "@backstage/cli-common": "^0.1.4",
32
- "@backstage/config": "^0.1.10",
33
- "@backstage/config-loader": "^0.7.0",
34
- "@backstage/errors": "^0.1.3",
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.5",
35
+ "@backstage/types": "^0.1.1",
35
36
  "@hot-loader/react-dom": "^16.13.0",
36
37
  "@lerna/package-graph": "^4.0.0",
37
38
  "@lerna/project": "^4.0.0",
38
39
  "@octokit/request": "^5.4.12",
39
- "@rollup/plugin-commonjs": "^17.1.0",
40
+ "@rollup/plugin-commonjs": "^21.0.1",
40
41
  "@rollup/plugin-json": "^4.0.2",
41
42
  "@rollup/plugin-node-resolve": "^13.0.0",
42
43
  "@rollup/plugin-yaml": "^3.0.0",
43
- "@spotify/eslint-config-base": "^9.0.0",
44
- "@spotify/eslint-config-react": "^10.0.0",
45
- "@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",
46
47
  "@sucrase/jest-plugin": "^2.1.1",
47
48
  "@sucrase/webpack-loader": "^2.0.0",
48
49
  "@svgr/plugin-jsx": "5.5.x",
@@ -81,7 +82,7 @@
81
82
  "jest": "^26.0.1",
82
83
  "jest-css-modules": "^2.1.0",
83
84
  "jest-transform-yaml": "^0.1.1",
84
- "json-schema": "^0.3.0",
85
+ "json-schema": "^0.4.0",
85
86
  "lodash": "^4.17.21",
86
87
  "mini-css-extract-plugin": "^2.4.2",
87
88
  "node-libs-browser": "^2.2.1",
@@ -109,21 +110,21 @@
109
110
  "typescript": "^4.0.3",
110
111
  "util": "^0.12.3",
111
112
  "webpack": "^5.48.0",
112
- "webpack-dev-server": "4.0.0-rc.0",
113
+ "webpack-dev-server": "4.3.1",
113
114
  "webpack-node-externals": "^3.0.0",
114
115
  "yaml": "^1.10.0",
115
116
  "yml-loader": "^2.1.0",
116
117
  "yn": "^4.0.0"
117
118
  },
118
119
  "devDependencies": {
119
- "@backstage/backend-common": "^0.9.7",
120
- "@backstage/config": "^0.1.10",
121
- "@backstage/core-app-api": "^0.1.18",
122
- "@backstage/core-components": "^0.7.1",
123
- "@backstage/core-plugin-api": "^0.1.11",
124
- "@backstage/dev-utils": "^0.2.12",
125
- "@backstage/test-utils": "^0.1.19",
126
- "@backstage/theme": "^0.2.11",
120
+ "@backstage/backend-common": "^0.9.11",
121
+ "@backstage/config": "^0.1.11",
122
+ "@backstage/core-app-api": "^0.1.23",
123
+ "@backstage/core-components": "^0.7.5",
124
+ "@backstage/core-plugin-api": "^0.2.1",
125
+ "@backstage/dev-utils": "^0.2.13",
126
+ "@backstage/test-utils": "^0.1.23",
127
+ "@backstage/theme": "^0.2.13",
127
128
  "@types/diff": "^5.0.0",
128
129
  "@types/express": "^4.17.6",
129
130
  "@types/fs-extra": "^9.0.1",
@@ -233,5 +234,5 @@
233
234
  }
234
235
  }
235
236
  },
236
- "gitHead": "017a47e585642733ac3b4b294cd00fc517d3ba08"
237
+ "gitHead": "85c127e436a24140bb3606f17f034f82aa9c7c0d"
237
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
+ }
@@ -18,7 +18,7 @@ import { getRootLogger } from '@backstage/backend-common';
18
18
  import yn from 'yn';
19
19
  import { startStandaloneServer } from './service/standaloneServer';
20
20
 
21
- const port = process.env.PLUGIN_PORT ? Number(process.env.PLUGIN_PORT) : 7000;
21
+ const port = process.env.PLUGIN_PORT ? Number(process.env.PLUGIN_PORT) : 7007;
22
22
  const enableCors = yn(process.env.PLUGIN_CORS, { default: false });
23
23
  const logger = getRootLogger();
24
24
 
@@ -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_
@@ -0,0 +1,34 @@
1
+ {
2
+ "name": "{{name}}",
3
+ "description": "Common functionalities for the {{id}} plugin",
4
+ "version": "{{pluginVersion}}",
5
+ "main": "src/index.ts",
6
+ "types": "src/index.ts",
7
+ "license": "Apache-2.0",
8
+ {{#if privatePackage}}
9
+ "private": {{privatePackage}},
10
+ {{/if}}
11
+ "publishConfig": {
12
+ {{#if npmRegistry}}
13
+ "registry": "{{npmRegistry}}",
14
+ {{/if}}
15
+ "access": "public",
16
+ "main": "dist/index.cjs.js",
17
+ "module": "dist/index.esm.js",
18
+ "types": "dist/index.d.ts"
19
+ },
20
+ "scripts": {
21
+ "build": "backstage-cli build",
22
+ "lint": "backstage-cli lint",
23
+ "test": "backstage-cli test",
24
+ "prepack": "backstage-cli prepack",
25
+ "postpack": "backstage-cli postpack",
26
+ "clean": "backstage-cli clean"
27
+ },
28
+ "devDependencies": {
29
+ "@backstage/cli": "{{versionQuery '@backstage/cli'}}"
30
+ },
31
+ "files": [
32
+ "dist"
33
+ ]
34
+ }
@@ -0,0 +1,19 @@
1
+ /***/
2
+ /**
3
+ * Common functionalities for the {{id}} plugin.
4
+ *
5
+ * @packageDocumentation
6
+ */
7
+
8
+ /**
9
+ * In this package you might for example declare types that are common
10
+ * between the frontend and backend plugin packages.
11
+ */
12
+ export type CommonType = {
13
+ field: string
14
+ }
15
+
16
+ /**
17
+ * Or you might declare some common constants.
18
+ */
19
+ export const COMMON_CONSTANT = 1
@@ -0,0 +1,9 @@
1
+ {
2
+ "extends": "@backstage/cli/config/tsconfig.json",
3
+ "include": ["src"],
4
+ "exclude": ["node_modules"],
5
+ "compilerOptions": {
6
+ "outDir": "dist-types",
7
+ "rootDir": "."
8
+ }
9
+ }
@@ -4,10 +4,12 @@
4
4
  "main": "src/index.ts",
5
5
  "types": "src/index.ts",
6
6
  "license": "Apache-2.0",
7
- {{#if privatePackage}} "private": {{privatePackage}},
7
+ {{#if privatePackage}}
8
+ "private": {{privatePackage}},
8
9
  {{/if}}
9
10
  "publishConfig": {
10
- {{#if npmRegistry}} "registry": "{{npmRegistry}}",
11
+ {{#if npmRegistry}}
12
+ "registry": "{{npmRegistry}}",
11
13
  {{/if}}
12
14
  "access": "public",
13
15
  "main": "dist/index.esm.js",
@@ -44,7 +46,7 @@
44
46
  "@testing-library/user-event": "{{versionQuery '@testing-library/user-event' '13.1.8'}}",
45
47
  "@types/jest": "{{versionQuery '@types/jest' '26.0.7'}}",
46
48
  "@types/node": "{{versionQuery '@types/node' '14.14.32'}}",
47
- "msw": "{{versionQuery 'msw' '0.29.0'}}",
49
+ "msw": "{{versionQuery 'msw' '0.35.0'}}",
48
50
  "cross-fetch": "{{versionQuery 'cross-fetch' '3.0.6'}}"
49
51
  },
50
52
  "files": [
@@ -4,12 +4,15 @@ import { ThemeProvider } from '@material-ui/core';
4
4
  import { lightTheme } from '@backstage/theme';
5
5
  import { rest } from 'msw';
6
6
  import { setupServer } from 'msw/node';
7
- import { msw, renderInTestApp } from '@backstage/test-utils';
7
+ import {
8
+ setupRequestMockHandlers,
9
+ renderInTestApp,
10
+ } from "@backstage/test-utils";
8
11
 
9
12
  describe('ExampleComponent', () => {
10
13
  const server = setupServer();
11
14
  // Enable sane handlers for network requests
12
- msw.setupDefaultHandlers(server);
15
+ setupRequestMockHandlers(server);
13
16
 
14
17
  // setup mock response
15
18
  beforeEach(() => {
@@ -3,12 +3,12 @@ import { render } from '@testing-library/react';
3
3
  import { ExampleFetchComponent } from './ExampleFetchComponent';
4
4
  import { rest } from 'msw';
5
5
  import { setupServer } from 'msw/node';
6
- import { msw } from '@backstage/test-utils';
6
+ import { setupRequestMockHandlers } from '@backstage/test-utils';
7
7
 
8
8
  describe('ExampleFetchComponent', () => {
9
9
  const server = setupServer();
10
10
  // Enable sane handlers for network requests
11
- msw.setupDefaultHandlers(server);
11
+ setupRequestMockHandlers(server);
12
12
 
13
13
  // setup mock response
14
14
  beforeEach(() => {
@@ -1,5 +1,5 @@
1
1
  import { createRouteRef } from '@backstage/core-plugin-api';
2
2
 
3
3
  export const rootRouteRef = createRouteRef({
4
- title: '{{ id }}',
4
+ id: '{{ id }}',
5
5
  });
@@ -0,0 +1,3 @@
1
+ module.exports = {
2
+ extends: [require.resolve('@backstage/cli/config/eslint.backend')],
3
+ };
@@ -0,0 +1,5 @@
1
+ # {{name}}
2
+
3
+ The {{id}} module for [@backstage/plugin-scaffolder-backend](https://www.npmjs.com/package/@backstage/plugin-scaffolder-backend).
4
+
5
+ _This plugin was created through the Backstage CLI_