@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.
- package/CHANGELOG.md +73 -0
- package/config/jest.js +42 -14
- package/config/jestEsmTransform.js +4 -21
- package/config/jestSucraseTransform.js +66 -0
- package/dist/cjs/{build-adad8b22.cjs.js → build-5907bd33.cjs.js} +4 -3
- package/dist/cjs/{build-093508d5.cjs.js → build-73b8edfc.cjs.js} +4 -3
- package/dist/cjs/{build-d7862d7c.cjs.js → build-7571e64b.cjs.js} +4 -3
- package/dist/cjs/{build-292d259f.cjs.js → build-9e812f65.cjs.js} +6 -5
- package/dist/cjs/{buildImage-7e3cf320.cjs.js → buildImage-7b597eb4.cjs.js} +5 -4
- package/dist/cjs/{buildWorkspace-cfea104f.cjs.js → buildWorkspace-779679cc.cjs.js} +5 -4
- package/dist/cjs/{bump-27623ef3.cjs.js → bump-67695db2.cjs.js} +31 -8
- package/dist/cjs/{bundle-80c7cf66.cjs.js → bundle-561463d9.cjs.js} +6 -5
- package/dist/cjs/{clean-f750c0dc.cjs.js → clean-1156a89f.cjs.js} +3 -2
- package/dist/cjs/{config-3e7b308b.cjs.js → config-10d49423.cjs.js} +21 -6
- package/dist/cjs/create-b0f456f9.cjs.js +483 -0
- package/dist/cjs/{createPlugin-a03aceea.cjs.js → createPlugin-2c95815c.cjs.js} +11 -9
- package/dist/cjs/{dev-f7d06c3d.cjs.js → dev-a04f9251.cjs.js} +5 -4
- package/dist/cjs/{diff-fd2bda97.cjs.js → diff-d009aa81.cjs.js} +3 -2
- package/dist/cjs/{docs-8dde3bb5.cjs.js → docs-d4bb9d0c.cjs.js} +4 -3
- package/dist/cjs/{index-8ece1803.cjs.js → index-25ca4442.cjs.js} +172 -51
- package/dist/cjs/{index-07ce0d55.cjs.js → index-351d0371.cjs.js} +3 -2
- package/dist/cjs/{index-39056740.cjs.js → index-af2b13e0.cjs.js} +13 -11
- package/dist/cjs/{info-85a45abd.cjs.js → info-05aaf204.cjs.js} +4 -3
- package/dist/cjs/{install-8c0b53e3.cjs.js → install-5d8e8fe5.cjs.js} +5 -4
- package/dist/cjs/{lint-fffadef5.cjs.js → lint-85c90960.cjs.js} +4 -3
- package/dist/cjs/{lint-d2e5b1ca.cjs.js → lint-d1316de9.cjs.js} +4 -3
- package/dist/cjs/{pack-f73a4522.cjs.js → pack-58a2ab5d.cjs.js} +3 -2
- package/dist/cjs/{packager-e61b2b16.cjs.js → packager-b251454c.cjs.js} +2 -2
- package/dist/cjs/{packages-be161005.cjs.js → packages-4a2d7110.cjs.js} +3 -3
- package/dist/cjs/{paths-5e0e5ffc.cjs.js → paths-034708b3.cjs.js} +20 -5
- package/dist/cjs/{print-5df69d1b.cjs.js → print-5d03aebd.cjs.js} +6 -4
- package/dist/cjs/{removePlugin-865c314e.cjs.js → removePlugin-c64823bb.cjs.js} +13 -3
- package/dist/cjs/{run-cc82f277.cjs.js → run-924136d8.cjs.js} +9 -4
- package/dist/cjs/{schema-66b2f248.cjs.js → schema-d59459da.cjs.js} +4 -3
- package/dist/cjs/{serve-7656d962.cjs.js → serve-0f30d0fc.cjs.js} +7 -6
- package/dist/cjs/{serve-b1a08c13.cjs.js → serve-28c83157.cjs.js} +8 -7
- package/dist/cjs/{server-4f73b8b5.cjs.js → server-652ec9a3.cjs.js} +2 -2
- package/dist/cjs/{tasks-4d9e9b1f.cjs.js → tasks-802f087f.cjs.js} +78 -12
- package/dist/cjs/{testCommand-55c14530.cjs.js → testCommand-11d07d1b.cjs.js} +4 -3
- package/dist/cjs/{validate-1542a59a.cjs.js → validate-3cc188fa.cjs.js} +6 -4
- package/dist/index.cjs.js +2 -1
- package/package.json +21 -22
- package/templates/default-backend-plugin/package.json.hbs +39 -37
- package/templates/default-common-plugin-package/.eslintrc.js +3 -0
- package/templates/default-common-plugin-package/README.md.hbs +5 -0
- package/templates/default-common-plugin-package/package.json.hbs +34 -0
- package/templates/default-common-plugin-package/src/index.ts.hbs +19 -0
- package/templates/default-common-plugin-package/src/setupTests.ts +1 -0
- package/templates/default-common-plugin-package/tsconfig.json +9 -0
- package/templates/default-plugin/package.json.hbs +5 -3
- package/templates/default-plugin/src/components/ExampleComponent/ExampleComponent.test.tsx.hbs +5 -2
- package/templates/default-plugin/src/components/ExampleFetchComponent/ExampleFetchComponent.test.tsx.hbs +2 -2
- package/templates/scaffolder-module/.eslintrc.js +3 -0
- package/templates/scaffolder-module/README.md.hbs +5 -0
- package/templates/scaffolder-module/package.json.hbs +37 -0
- package/templates/scaffolder-module/src/actions/example/example.test.ts +50 -0
- package/templates/scaffolder-module/src/actions/example/example.ts +57 -0
- package/templates/scaffolder-module/src/actions/example/index.ts +1 -0
- package/templates/scaffolder-module/src/actions/index.ts +1 -0
- package/templates/scaffolder-module/src/index.ts.hbs +8 -0
- 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-
|
|
8
|
-
var index = require('./index-
|
|
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-
|
|
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-
|
|
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
|
-
|
|
41
|
+
errors.assertError(error);
|
|
42
|
+
if ("stderr" in error) {
|
|
41
43
|
process.stderr.write(error.stderr);
|
|
42
44
|
}
|
|
43
|
-
|
|
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-
|
|
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-
|
|
4
|
+
var config = require('./config-10d49423.cjs.js');
|
|
5
5
|
var configLoader = require('@backstage/config-loader');
|
|
6
6
|
require('@backstage/config');
|
|
7
|
-
require('./index-
|
|
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-
|
|
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-
|
|
15
|
-
require('./run-
|
|
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-
|
|
22
|
-
var config = require('./config-
|
|
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-
|
|
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-
|
|
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-
|
|
17
|
-
require('./run-
|
|
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-
|
|
23
|
-
var config = require('./config-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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
|
|
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
|
|
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
|
|
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(
|
|
55
|
-
const
|
|
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(
|
|
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.
|
|
100
|
+
process.stderr.write(`${chalk__default['default'].green(name)}
|
|
85
101
|
`);
|
|
86
102
|
}
|
|
87
103
|
static error(message = "") {
|
|
88
|
-
process.
|
|
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.
|
|
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-
|
|
227
|
+
//# sourceMappingURL=tasks-802f087f.cjs.js.map
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var index = require('./index-
|
|
4
|
-
var run = require('./run-
|
|
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-
|
|
48
|
+
//# sourceMappingURL=testCommand-11d07d1b.cjs.js.map
|
|
@@ -1,23 +1,25 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var config = require('./config-
|
|
3
|
+
var config = require('./config-10d49423.cjs.js');
|
|
4
4
|
require('@backstage/config-loader');
|
|
5
5
|
require('@backstage/config');
|
|
6
|
-
require('./index-
|
|
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-
|
|
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-
|
|
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.
|
|
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
|
-
"@
|
|
32
|
-
"@
|
|
33
|
-
"@backstage/
|
|
34
|
-
"@backstage/
|
|
35
|
-
"@backstage/
|
|
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": "^
|
|
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": "^
|
|
45
|
-
"@spotify/eslint-config-react": "^
|
|
46
|
-
"@spotify/eslint-config-typescript": "^
|
|
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.
|
|
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.
|
|
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.
|
|
122
|
-
"@backstage/config": "^0.1.
|
|
123
|
-
"@backstage/core-app-api": "^0.1.
|
|
124
|
-
"@backstage/core-components": "^0.7.
|
|
125
|
-
"@backstage/core-plugin-api": "^0.
|
|
126
|
-
"@backstage/dev-utils": "^0.2.
|
|
127
|
-
"@backstage/test-utils": "^0.1.
|
|
128
|
-
"@backstage/theme": "^0.2.
|
|
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": "
|
|
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
|
-
|
|
8
|
-
{{
|
|
7
|
+
{{#if privatePackage}}
|
|
8
|
+
"private": {{privatePackage}},
|
|
9
|
+
{{/if}}
|
|
9
10
|
"publishConfig": {
|
|
10
|
-
|
|
11
|
-
{{
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
|
|
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
|
+
}
|