@backstage/cli 0.0.0-nightly-20220724025214 → 0.0.0-nightly-20220727025454
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 +9 -1
- package/dist/cjs/{Lockfile-48dc675e.cjs.js → Lockfile-72b7072e.cjs.js} +25 -9
- package/dist/cjs/{PackageGraph-8493bd3a.cjs.js → PackageGraph-6e1d4bd4.cjs.js} +17 -9
- package/dist/cjs/{build-5a8721eb.cjs.js → build-3b11f7c9.cjs.js} +26 -15
- package/dist/cjs/{buildBackend-57d4caef.cjs.js → buildBackend-87996ad4.cjs.js} +61 -36
- package/dist/cjs/{buildWorkspace-5de1b0b7.cjs.js → buildWorkspace-425726da.cjs.js} +7 -7
- package/dist/cjs/{bump-3a48bfcd.cjs.js → bump-f3c6b3cd.cjs.js} +88 -33
- package/dist/cjs/{clean-cc6b16e0.cjs.js → clean-798512b5.cjs.js} +2 -2
- package/dist/cjs/{config-7846b979.cjs.js → config-4a59f918.cjs.js} +15 -11
- package/dist/cjs/{create-68d975e4.cjs.js → create-a7269bb5.cjs.js} +80 -32
- package/dist/cjs/{createDistWorkspace-eb755997.cjs.js → createDistWorkspace-cb9a9a84.cjs.js} +137 -65
- package/dist/cjs/{createPlugin-aa21421a.cjs.js → createPlugin-fca2c26e.cjs.js} +69 -30
- package/dist/cjs/{diff-a8fae7fc.cjs.js → diff-3dec490d.cjs.js} +68 -16
- package/dist/cjs/{docs-492c2ada.cjs.js → docs-e60d4fe7.cjs.js} +9 -5
- package/dist/cjs/{fix-c0dbaaa6.cjs.js → fix-b60a5395.cjs.js} +17 -7
- package/dist/cjs/{index-33baaa73.cjs.js → index-131467e2.cjs.js} +10 -10
- package/dist/cjs/{index-8f7ddece.cjs.js → index-50703ee1.cjs.js} +147 -46
- package/dist/cjs/{index-75b07df0.cjs.js → index-71d143d5.cjs.js} +57 -38
- package/dist/cjs/{index-8c180b21.cjs.js → index-7efbd23e.cjs.js} +39 -12
- package/dist/cjs/{info-12026684.cjs.js → info-04610119.cjs.js} +20 -6
- package/dist/cjs/{install-15d7418e.cjs.js → install-589f1c25.cjs.js} +44 -17
- package/dist/cjs/{lint-8c117129.cjs.js → lint-41010f96.cjs.js} +37 -11
- package/dist/cjs/{lint-7e355f5f.cjs.js → lint-6fcb9a70.cjs.js} +5 -3
- package/dist/cjs/{lint-d43c64c2.cjs.js → lint-7f6b0d33.cjs.js} +4 -4
- package/dist/cjs/{list-deprecations-fa400a5f.cjs.js → list-deprecations-8aee2123.cjs.js} +3 -3
- package/dist/cjs/{pack-45520c93.cjs.js → pack-91881c2f.cjs.js} +17 -11
- package/dist/cjs/packageLintConfigs-f9e5fcc6.cjs.js +83 -0
- package/dist/cjs/packageRole-16eb6c89.cjs.js +59 -0
- package/dist/cjs/{packageRoles-459b027c.cjs.js → packageRoles-96528891.cjs.js} +5 -3
- package/dist/cjs/packageScripts-eb2443c2.cjs.js +98 -0
- package/dist/cjs/{packages-b58a9650.cjs.js → packages-1b40c101.cjs.js} +17 -12
- package/dist/cjs/parallel-a8f6219c.cjs.js +187 -0
- package/dist/cjs/{paths-7d932860.cjs.js → paths-b34f135a.cjs.js} +100 -55
- package/dist/cjs/{print-db2f2c89.cjs.js → print-e99d7c2e.cjs.js} +4 -4
- package/dist/cjs/{run-b41544c4.cjs.js → run-722b1384.cjs.js} +2 -2
- package/dist/cjs/{schema-f9516e5d.cjs.js → schema-c636e913.cjs.js} +9 -5
- package/dist/cjs/{tasks-adcaca36.cjs.js → tasks-4776baa6.cjs.js} +29 -12
- package/dist/cjs/{test-d226acfd.cjs.js → test-76539f57.cjs.js} +3 -3
- package/dist/cjs/{validate-61c683b8.cjs.js → validate-f9273594.cjs.js} +4 -4
- package/dist/index.cjs.js +1 -1
- package/package.json +7 -7
- package/dist/cjs/packageLintConfigs-760acc65.cjs.js +0 -74
- package/dist/cjs/packageRole-7e9216d7.cjs.js +0 -53
- package/dist/cjs/packageScripts-db1393e2.cjs.js +0 -96
- package/dist/cjs/parallel-8286d3fa.cjs.js +0 -171
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var fs = require('fs-extra');
|
|
4
|
-
var index = require('./index-
|
|
4
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
5
5
|
var webpack = require('webpack');
|
|
6
|
-
var paths = require('./paths-
|
|
6
|
+
var paths = require('./paths-b34f135a.cjs.js');
|
|
7
7
|
require('yn');
|
|
8
8
|
require('path');
|
|
9
9
|
require('react-dev-utils/FileSizeReporter');
|
|
@@ -16,18 +16,18 @@ require('webpack-node-externals');
|
|
|
16
16
|
require('@backstage/cli-common');
|
|
17
17
|
require('@manypkg/get-packages');
|
|
18
18
|
require('mini-css-extract-plugin');
|
|
19
|
-
require('./run-
|
|
19
|
+
require('./run-722b1384.cjs.js');
|
|
20
20
|
require('eslint-webpack-plugin');
|
|
21
21
|
require('lodash/pickBy');
|
|
22
22
|
var chalk = require('chalk');
|
|
23
23
|
var WebpackDevServer = require('webpack-dev-server');
|
|
24
24
|
var openBrowser = require('react-dev-utils/openBrowser');
|
|
25
25
|
var uniq = require('lodash/uniq');
|
|
26
|
-
var config = require('./config-
|
|
27
|
-
var Lockfile = require('./Lockfile-
|
|
26
|
+
var config = require('./config-4a59f918.cjs.js');
|
|
27
|
+
var Lockfile = require('./Lockfile-72b7072e.cjs.js');
|
|
28
28
|
require('minimatch');
|
|
29
|
-
var lint = require('./lint-
|
|
30
|
-
var packageRoles = require('./packageRoles-
|
|
29
|
+
var lint = require('./lint-41010f96.cjs.js');
|
|
30
|
+
var packageRoles = require('./packageRoles-96528891.cjs.js');
|
|
31
31
|
require('commander');
|
|
32
32
|
require('semver');
|
|
33
33
|
require('@backstage/errors');
|
|
@@ -36,7 +36,7 @@ require('child_process');
|
|
|
36
36
|
require('util');
|
|
37
37
|
require('@backstage/config-loader');
|
|
38
38
|
require('@backstage/config');
|
|
39
|
-
require('./PackageGraph-
|
|
39
|
+
require('./PackageGraph-6e1d4bd4.cjs.js');
|
|
40
40
|
require('@yarnpkg/parsers');
|
|
41
41
|
require('@yarnpkg/lockfile');
|
|
42
42
|
require('lodash/partition');
|
|
@@ -89,28 +89,31 @@ async function serveBundle(options) {
|
|
|
89
89
|
baseUrl: url
|
|
90
90
|
});
|
|
91
91
|
const compiler = webpack__default["default"](config);
|
|
92
|
-
const server = new WebpackDevServer__default["default"](
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
92
|
+
const server = new WebpackDevServer__default["default"](
|
|
93
|
+
{
|
|
94
|
+
hot: !process.env.CI,
|
|
95
|
+
devMiddleware: {
|
|
96
|
+
publicPath: (_a = config.output) == null ? void 0 : _a.publicPath,
|
|
97
|
+
stats: "errors-warnings"
|
|
98
|
+
},
|
|
99
|
+
static: paths$1.targetPublic ? {
|
|
100
|
+
publicPath: (_b = config.output) == null ? void 0 : _b.publicPath,
|
|
101
|
+
directory: paths$1.targetPublic
|
|
102
|
+
} : void 0,
|
|
103
|
+
historyApiFallback: {
|
|
104
|
+
disableDotRule: true
|
|
105
|
+
},
|
|
106
|
+
https: url.protocol === "https:",
|
|
107
|
+
host,
|
|
108
|
+
port,
|
|
109
|
+
proxy: pkg.proxy,
|
|
110
|
+
allowedHosts: [url.hostname],
|
|
111
|
+
client: {
|
|
112
|
+
webSocketURL: "auto://0.0.0.0:0/ws"
|
|
113
|
+
}
|
|
104
114
|
},
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
port,
|
|
108
|
-
proxy: pkg.proxy,
|
|
109
|
-
allowedHosts: [url.hostname],
|
|
110
|
-
client: {
|
|
111
|
-
webSocketURL: "auto://0.0.0.0:0/ws"
|
|
112
|
-
}
|
|
113
|
-
}, compiler);
|
|
115
|
+
compiler
|
|
116
|
+
);
|
|
114
117
|
await new Promise((resolve, reject) => {
|
|
115
118
|
server.startCallback((err) => {
|
|
116
119
|
if (err) {
|
|
@@ -151,16 +154,26 @@ async function startFrontend(options) {
|
|
|
151
154
|
const result = lockfile.analyze({
|
|
152
155
|
filter: lint.includedFilter
|
|
153
156
|
});
|
|
154
|
-
const problemPackages = [...result.newVersions, ...result.newRanges].map(
|
|
157
|
+
const problemPackages = [...result.newVersions, ...result.newRanges].map(
|
|
158
|
+
({ name: name2 }) => name2
|
|
159
|
+
);
|
|
155
160
|
if (problemPackages.length > 1) {
|
|
156
|
-
console.log(
|
|
161
|
+
console.log(
|
|
162
|
+
chalk__default["default"].yellow(
|
|
163
|
+
`\u26A0\uFE0F Some of the following packages may be outdated or have duplicate installations:
|
|
157
164
|
|
|
158
165
|
${uniq__default["default"](problemPackages).join(", ")}
|
|
159
|
-
`
|
|
160
|
-
|
|
166
|
+
`
|
|
167
|
+
)
|
|
168
|
+
);
|
|
169
|
+
console.log(
|
|
170
|
+
chalk__default["default"].yellow(
|
|
171
|
+
`\u26A0\uFE0F This can be resolved using the following command:
|
|
161
172
|
|
|
162
173
|
yarn backstage-cli versions:check --fix
|
|
163
|
-
`
|
|
174
|
+
`
|
|
175
|
+
)
|
|
176
|
+
);
|
|
164
177
|
}
|
|
165
178
|
}
|
|
166
179
|
const { name } = await fs__default["default"].readJson(index.paths.resolveTarget("package.json"));
|
|
@@ -172,7 +185,9 @@ async function startFrontend(options) {
|
|
|
172
185
|
const appBaseUrl = config$1.frontendConfig.getString("app.baseUrl");
|
|
173
186
|
const backendBaseUrl = config$1.frontendConfig.getString("backend.baseUrl");
|
|
174
187
|
if (appBaseUrl === backendBaseUrl) {
|
|
175
|
-
console.log(
|
|
188
|
+
console.log(
|
|
189
|
+
chalk__default["default"].yellow(
|
|
190
|
+
`\u26A0\uFE0F Conflict between app baseUrl and backend baseUrl:
|
|
176
191
|
|
|
177
192
|
app.baseUrl: ${appBaseUrl}
|
|
178
193
|
backend.baseUrl: ${appBaseUrl}
|
|
@@ -180,7 +195,9 @@ async function startFrontend(options) {
|
|
|
180
195
|
Must have unique hostname and/or ports.
|
|
181
196
|
|
|
182
197
|
This can be resolved by changing app.baseUrl and backend.baseUrl to point to their respective local development ports.
|
|
183
|
-
`
|
|
198
|
+
`
|
|
199
|
+
)
|
|
200
|
+
);
|
|
184
201
|
}
|
|
185
202
|
const waitForExit = await serveBundle({
|
|
186
203
|
entry: options.entry,
|
|
@@ -215,9 +232,11 @@ async function command(opts) {
|
|
|
215
232
|
case "frontend-plugin-module":
|
|
216
233
|
return startFrontend({ entry: "dev/index", ...options });
|
|
217
234
|
default:
|
|
218
|
-
throw new Error(
|
|
235
|
+
throw new Error(
|
|
236
|
+
`Start command is not supported for package role '${role}'`
|
|
237
|
+
);
|
|
219
238
|
}
|
|
220
239
|
}
|
|
221
240
|
|
|
222
241
|
exports.command = command;
|
|
223
|
-
//# sourceMappingURL=index-
|
|
242
|
+
//# sourceMappingURL=index-71d143d5.cjs.js.map
|
|
@@ -4,7 +4,7 @@ var fs = require('fs-extra');
|
|
|
4
4
|
var chalk = require('chalk');
|
|
5
5
|
var yaml = require('yaml');
|
|
6
6
|
var inquirer = require('inquirer');
|
|
7
|
-
var index$1 = require('./index-
|
|
7
|
+
var index$1 = require('./index-50703ee1.cjs.js');
|
|
8
8
|
var crypto = require('crypto');
|
|
9
9
|
var openBrowser = require('react-dev-utils/openBrowser');
|
|
10
10
|
var request = require('@octokit/request');
|
|
@@ -89,7 +89,11 @@ class GithubCreateAppServer {
|
|
|
89
89
|
app.get("/", this.formHandler);
|
|
90
90
|
const callPromise = new Promise((resolve, reject) => {
|
|
91
91
|
app.get("/callback", (req, res) => {
|
|
92
|
-
request.request(
|
|
92
|
+
request.request(
|
|
93
|
+
`POST /app-manifests/${encodeURIComponent(
|
|
94
|
+
req.query.code
|
|
95
|
+
)}/conversions`
|
|
96
|
+
).then(({ data }) => {
|
|
93
97
|
resolve({
|
|
94
98
|
name: data.name,
|
|
95
99
|
slug: data.slug,
|
|
@@ -159,40 +163,63 @@ var index = async (org) => {
|
|
|
159
163
|
${yaml.stringify(config)}`;
|
|
160
164
|
await fs__default["default"].writeFile(index$1.paths.resolveTargetRoot(fileName), content);
|
|
161
165
|
console.log(`GitHub App configuration written to ${chalk__default["default"].cyan(fileName)}`);
|
|
162
|
-
console.log(
|
|
163
|
-
|
|
164
|
-
|
|
166
|
+
console.log(
|
|
167
|
+
chalk__default["default"].yellow(
|
|
168
|
+
"This file contains sensitive credentials, it should not be committed to version control and handled with care!"
|
|
169
|
+
)
|
|
170
|
+
);
|
|
171
|
+
console.log(
|
|
172
|
+
"Here's an example on how to update the integrations section in app-config.yaml"
|
|
173
|
+
);
|
|
174
|
+
console.log(
|
|
175
|
+
chalk__default["default"].green(`
|
|
165
176
|
integrations:
|
|
166
177
|
github:
|
|
167
178
|
- host: github.com
|
|
168
179
|
apps:
|
|
169
|
-
- $include: ${fileName}`)
|
|
180
|
+
- $include: ${fileName}`)
|
|
181
|
+
);
|
|
170
182
|
};
|
|
171
183
|
async function verifyGithubOrg(org) {
|
|
172
184
|
let response;
|
|
173
185
|
try {
|
|
174
|
-
response = await fetch__default["default"](
|
|
186
|
+
response = await fetch__default["default"](
|
|
187
|
+
`https://api.github.com/orgs/${encodeURIComponent(org)}`
|
|
188
|
+
);
|
|
175
189
|
} catch (e) {
|
|
176
|
-
console.log(
|
|
190
|
+
console.log(
|
|
191
|
+
chalk__default["default"].yellow(
|
|
192
|
+
"Warning: Unable to verify existence of GitHub organization. ",
|
|
193
|
+
e
|
|
194
|
+
)
|
|
195
|
+
);
|
|
177
196
|
}
|
|
178
197
|
if ((response == null ? void 0 : response.status) === 404) {
|
|
179
198
|
const questions = [
|
|
180
199
|
{
|
|
181
200
|
type: "confirm",
|
|
182
201
|
name: "shouldCreateOrg",
|
|
183
|
-
message: `GitHub organization ${chalk__default["default"].cyan(
|
|
202
|
+
message: `GitHub organization ${chalk__default["default"].cyan(
|
|
203
|
+
org
|
|
204
|
+
)} does not exist. Would you like to create a new Organization instead?`
|
|
184
205
|
}
|
|
185
206
|
];
|
|
186
207
|
const answers = await inquirer__default["default"].prompt(questions);
|
|
187
208
|
if (!answers.shouldCreateOrg) {
|
|
188
|
-
console.log(
|
|
209
|
+
console.log(
|
|
210
|
+
chalk__default["default"].yellow("GitHub organization must exist to create GitHub app")
|
|
211
|
+
);
|
|
189
212
|
process.exit(1);
|
|
190
213
|
}
|
|
191
214
|
openBrowser__default["default"]("https://github.com/account/organizations/new");
|
|
192
|
-
console.log(
|
|
215
|
+
console.log(
|
|
216
|
+
chalk__default["default"].yellow(
|
|
217
|
+
"Please re-run this command when you have created your new organization"
|
|
218
|
+
)
|
|
219
|
+
);
|
|
193
220
|
process.exit(0);
|
|
194
221
|
}
|
|
195
222
|
}
|
|
196
223
|
|
|
197
224
|
exports["default"] = index;
|
|
198
|
-
//# sourceMappingURL=index-
|
|
225
|
+
//# sourceMappingURL=index-7efbd23e.cjs.js.map
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var index = require('./index-
|
|
3
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
4
4
|
var os = require('os');
|
|
5
|
-
var run = require('./run-
|
|
6
|
-
var Lockfile = require('./Lockfile-
|
|
5
|
+
var run = require('./run-722b1384.cjs.js');
|
|
6
|
+
var Lockfile = require('./Lockfile-72b7072e.cjs.js');
|
|
7
7
|
require('minimatch');
|
|
8
8
|
require('@manypkg/get-packages');
|
|
9
9
|
require('chalk');
|
|
10
|
+
var fs = require('fs-extra');
|
|
10
11
|
require('commander');
|
|
11
|
-
require('fs-extra');
|
|
12
12
|
require('semver');
|
|
13
13
|
require('@backstage/cli-common');
|
|
14
14
|
require('@backstage/errors');
|
|
@@ -20,15 +20,29 @@ require('@yarnpkg/lockfile');
|
|
|
20
20
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
21
21
|
|
|
22
22
|
var os__default = /*#__PURE__*/_interopDefaultLegacy(os);
|
|
23
|
+
var fs__default = /*#__PURE__*/_interopDefaultLegacy(fs);
|
|
23
24
|
|
|
24
25
|
var info = async () => {
|
|
25
26
|
await new Promise(async () => {
|
|
27
|
+
var _a;
|
|
26
28
|
const yarnVersion = await run.runPlain("yarn --version");
|
|
27
|
-
const isLocal =
|
|
29
|
+
const isLocal = fs__default["default"].existsSync(index.paths.resolveOwn("./src"));
|
|
30
|
+
const backstageFile = index.paths.resolveTargetRoot("backstage.json");
|
|
31
|
+
let backstageVersion = "N/A";
|
|
32
|
+
if (fs__default["default"].existsSync(backstageFile)) {
|
|
33
|
+
try {
|
|
34
|
+
const backstageJson = await fs__default["default"].readJSON(backstageFile);
|
|
35
|
+
backstageVersion = (_a = backstageJson.version) != null ? _a : "N/A";
|
|
36
|
+
} catch (error) {
|
|
37
|
+
console.warn('The "backstage.json" file is not in the expected format');
|
|
38
|
+
console.log();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
28
41
|
console.log(`OS: ${os__default["default"].type} ${os__default["default"].release} - ${os__default["default"].platform}/${os__default["default"].arch}`);
|
|
29
42
|
console.log(`node: ${process.version}`);
|
|
30
43
|
console.log(`yarn: ${yarnVersion}`);
|
|
31
44
|
console.log(`cli: ${index.version$1} (${isLocal ? "local" : "installed"})`);
|
|
45
|
+
console.log(`backstage: ${backstageVersion}`);
|
|
32
46
|
console.log();
|
|
33
47
|
console.log("Dependencies:");
|
|
34
48
|
const lockfilePath = index.paths.resolveTargetRoot("yarn.lock");
|
|
@@ -43,4 +57,4 @@ var info = async () => {
|
|
|
43
57
|
};
|
|
44
58
|
|
|
45
59
|
exports["default"] = info;
|
|
46
|
-
//# sourceMappingURL=info-
|
|
60
|
+
//# sourceMappingURL=info-04610119.cjs.js.map
|
|
@@ -4,12 +4,12 @@ var fs = require('fs-extra');
|
|
|
4
4
|
require('semver');
|
|
5
5
|
require('@yarnpkg/parsers');
|
|
6
6
|
require('@yarnpkg/lockfile');
|
|
7
|
-
var packages = require('./packages-
|
|
8
|
-
var index = require('./index-
|
|
7
|
+
var packages = require('./packages-1b40c101.cjs.js');
|
|
8
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
9
9
|
var chalk = require('chalk');
|
|
10
10
|
var sortBy = require('lodash/sortBy');
|
|
11
11
|
var groupBy = require('lodash/groupBy');
|
|
12
|
-
var run = require('./run-
|
|
12
|
+
var run = require('./run-722b1384.cjs.js');
|
|
13
13
|
require('minimatch');
|
|
14
14
|
require('@manypkg/get-packages');
|
|
15
15
|
require('commander');
|
|
@@ -39,7 +39,10 @@ class AppRouteStep {
|
|
|
39
39
|
const appTsxPath = index.paths.resolveTargetRoot("packages/app/src/App.tsx");
|
|
40
40
|
const contents = await fs__default["default"].readFile(appTsxPath, "utf-8");
|
|
41
41
|
let failed = false;
|
|
42
|
-
const contentsWithRoute = contents.replace(
|
|
42
|
+
const contentsWithRoute = contents.replace(
|
|
43
|
+
/(\s*)<\/FlatRoutes>/,
|
|
44
|
+
`$1 <Route path="${path}" element={${element}} />$1</FlatRoutes>`
|
|
45
|
+
);
|
|
43
46
|
if (contentsWithRoute === contents) {
|
|
44
47
|
failed = true;
|
|
45
48
|
}
|
|
@@ -47,13 +50,18 @@ class AppRouteStep {
|
|
|
47
50
|
if (!componentName) {
|
|
48
51
|
throw new Error(`Could not find component name in ${element}`);
|
|
49
52
|
}
|
|
50
|
-
const contentsWithImport = contentsWithRoute.replace(
|
|
51
|
-
import
|
|
53
|
+
const contentsWithImport = contentsWithRoute.replace(
|
|
54
|
+
/^import /m,
|
|
55
|
+
`import { ${componentName} } from '${packageName}';
|
|
56
|
+
import `
|
|
57
|
+
);
|
|
52
58
|
if (contentsWithImport === contentsWithRoute) {
|
|
53
59
|
failed = true;
|
|
54
60
|
}
|
|
55
61
|
if (failed) {
|
|
56
|
-
console.log(
|
|
62
|
+
console.log(
|
|
63
|
+
"Failed to automatically add a route to package/app/src/App.tsx"
|
|
64
|
+
);
|
|
57
65
|
console.log(`Action needed, add the following:`);
|
|
58
66
|
console.log(`1. import { ${componentName} } from '${packageName}';`);
|
|
59
67
|
console.log(`2. <Route path="${path}" element={${element}} />`);
|
|
@@ -95,12 +103,16 @@ class DependenciesStep {
|
|
|
95
103
|
pkgJson[dep.type][dep.name] = dep.query;
|
|
96
104
|
}
|
|
97
105
|
for (const depType of depTypes) {
|
|
98
|
-
pkgJson[depType] = Object.fromEntries(
|
|
106
|
+
pkgJson[depType] = Object.fromEntries(
|
|
107
|
+
sortBy__default["default"](Object.entries(pkgJson[depType]), ([key]) => key)
|
|
108
|
+
);
|
|
99
109
|
}
|
|
100
110
|
await fs__default["default"].writeJson(pkgPath, pkgJson, { spaces: 2 });
|
|
101
111
|
}
|
|
102
112
|
console.log();
|
|
103
|
-
console.log(
|
|
113
|
+
console.log(
|
|
114
|
+
`Running ${chalk__default["default"].blue("yarn install")} to install new versions`
|
|
115
|
+
);
|
|
104
116
|
console.log();
|
|
105
117
|
await run.run("yarn", ["install"]);
|
|
106
118
|
}
|
|
@@ -128,7 +140,9 @@ const message = createStepDefinition({
|
|
|
128
140
|
deserialize(obj) {
|
|
129
141
|
const { message: msg } = obj;
|
|
130
142
|
if (!msg || typeof msg !== "string" && !Array.isArray(msg)) {
|
|
131
|
-
throw new Error(
|
|
143
|
+
throw new Error(
|
|
144
|
+
"Invalid install step, 'message' must be a string or array"
|
|
145
|
+
);
|
|
132
146
|
}
|
|
133
147
|
return new MessageStep({ message: [msg].flat().join("") });
|
|
134
148
|
},
|
|
@@ -149,7 +163,9 @@ async function fetchPluginPackage(id) {
|
|
|
149
163
|
const searchNames = [`@backstage/plugin-${id}`, `backstage-plugin-${id}`, id];
|
|
150
164
|
for (const name of searchNames) {
|
|
151
165
|
try {
|
|
152
|
-
const packageInfo = await packages.fetchPackageInfo(
|
|
166
|
+
const packageInfo = await packages.fetchPackageInfo(
|
|
167
|
+
name
|
|
168
|
+
);
|
|
153
169
|
return packageInfo;
|
|
154
170
|
} catch (error) {
|
|
155
171
|
if (error.name !== "NotFoundError") {
|
|
@@ -157,7 +173,9 @@ async function fetchPluginPackage(id) {
|
|
|
157
173
|
}
|
|
158
174
|
}
|
|
159
175
|
}
|
|
160
|
-
throw new index.NotFoundError(
|
|
176
|
+
throw new index.NotFoundError(
|
|
177
|
+
`No matching package found for '${id}', tried ${searchNames.join(", ")}`
|
|
178
|
+
);
|
|
161
179
|
}
|
|
162
180
|
class PluginInstaller {
|
|
163
181
|
constructor(steps) {
|
|
@@ -205,8 +223,13 @@ async function installPluginAndPeerPlugins(pkg) {
|
|
|
205
223
|
console.log(`Installing ${pkg.name} AND any peer plugin dependencies.`);
|
|
206
224
|
for (const [_pluginDepName, pluginDep] of pluginDeps.entries()) {
|
|
207
225
|
const { pkg: pluginDepPkg, versionToInstall } = pluginDep;
|
|
208
|
-
console.log(
|
|
209
|
-
|
|
226
|
+
console.log(
|
|
227
|
+
`Installing plugin: ${pluginDepPkg.name}: ${versionToInstall || pluginDepPkg.version}`
|
|
228
|
+
);
|
|
229
|
+
const steps = await PluginInstaller.resolveSteps(
|
|
230
|
+
pluginDepPkg,
|
|
231
|
+
versionToInstall
|
|
232
|
+
);
|
|
210
233
|
const installer = new PluginInstaller(steps);
|
|
211
234
|
await installer.run();
|
|
212
235
|
}
|
|
@@ -219,7 +242,9 @@ async function loadPackageJson(plugin) {
|
|
|
219
242
|
}
|
|
220
243
|
async function loadPeerPluginDeps(pkg, pluginMap) {
|
|
221
244
|
var _a, _b;
|
|
222
|
-
for (const [pluginId, pluginVersion] of Object.entries(
|
|
245
|
+
for (const [pluginId, pluginVersion] of Object.entries(
|
|
246
|
+
(_b = (_a = pkg.experimentalInstallationRecipe) == null ? void 0 : _a.peerPluginDependencies) != null ? _b : {}
|
|
247
|
+
)) {
|
|
223
248
|
const depPkg = await loadPackageJson(pluginId);
|
|
224
249
|
if (!pluginMap.get(depPkg.name)) {
|
|
225
250
|
pluginMap.set(depPkg.name, {
|
|
@@ -233,11 +258,13 @@ async function loadPeerPluginDeps(pkg, pluginMap) {
|
|
|
233
258
|
var install = async (pluginId, cmd) => {
|
|
234
259
|
const from = pluginId || (cmd == null ? void 0 : cmd.from);
|
|
235
260
|
if (!from) {
|
|
236
|
-
throw new Error(
|
|
261
|
+
throw new Error(
|
|
262
|
+
"Missing both <plugin-id> or a package.json file path in the --from flag."
|
|
263
|
+
);
|
|
237
264
|
}
|
|
238
265
|
const pkg = await loadPackageJson(from);
|
|
239
266
|
await installPluginAndPeerPlugins(pkg);
|
|
240
267
|
};
|
|
241
268
|
|
|
242
269
|
exports["default"] = install;
|
|
243
|
-
//# sourceMappingURL=install-
|
|
270
|
+
//# sourceMappingURL=install-589f1c25.cjs.js.map
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var Lockfile = require('./Lockfile-
|
|
3
|
+
var Lockfile = require('./Lockfile-72b7072e.cjs.js');
|
|
4
4
|
require('minimatch');
|
|
5
5
|
require('@manypkg/get-packages');
|
|
6
|
-
require('./run-
|
|
6
|
+
require('./run-722b1384.cjs.js');
|
|
7
7
|
require('chalk');
|
|
8
|
-
var index = require('./index-
|
|
8
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
9
9
|
var partition = require('lodash/partition');
|
|
10
10
|
require('fs-extra');
|
|
11
11
|
require('semver');
|
|
@@ -41,24 +41,50 @@ var lint = async (cmd) => {
|
|
|
41
41
|
const result = lockfile.analyze({
|
|
42
42
|
filter: includedFilter
|
|
43
43
|
});
|
|
44
|
-
logArray(
|
|
44
|
+
logArray(
|
|
45
|
+
result.invalidRanges,
|
|
46
|
+
"The following packages versions are invalid and can't be analyzed:",
|
|
47
|
+
(e) => ` ${e.name} @ ${e.range}`
|
|
48
|
+
);
|
|
45
49
|
if (fix) {
|
|
46
50
|
lockfile.replaceVersions(result.newVersions);
|
|
47
51
|
await lockfile.save();
|
|
48
52
|
} else {
|
|
49
|
-
const [newVersionsForbidden, newVersionsAllowed] = partition__default["default"](
|
|
53
|
+
const [newVersionsForbidden, newVersionsAllowed] = partition__default["default"](
|
|
54
|
+
result.newVersions,
|
|
55
|
+
({ name }) => forbiddenDuplicatesFilter(name)
|
|
56
|
+
);
|
|
50
57
|
if (newVersionsForbidden.length && !fix) {
|
|
51
58
|
success = false;
|
|
52
59
|
}
|
|
53
|
-
logArray(
|
|
54
|
-
|
|
60
|
+
logArray(
|
|
61
|
+
newVersionsForbidden,
|
|
62
|
+
"The following packages must be deduplicated, this can be done automatically with --fix",
|
|
63
|
+
(e) => ` ${e.name} @ ${e.range} bumped from ${e.oldVersion} to ${e.newVersion}`
|
|
64
|
+
);
|
|
65
|
+
logArray(
|
|
66
|
+
newVersionsAllowed,
|
|
67
|
+
"The following packages can be deduplicated, this can be done automatically with --fix",
|
|
68
|
+
(e) => ` ${e.name} @ ${e.range} bumped from ${e.oldVersion} to ${e.newVersion}`
|
|
69
|
+
);
|
|
55
70
|
}
|
|
56
|
-
const [newRangesForbidden, newRangesAllowed] = partition__default["default"](
|
|
71
|
+
const [newRangesForbidden, newRangesAllowed] = partition__default["default"](
|
|
72
|
+
result.newRanges,
|
|
73
|
+
({ name }) => forbiddenDuplicatesFilter(name)
|
|
74
|
+
);
|
|
57
75
|
if (newRangesForbidden.length) {
|
|
58
76
|
success = false;
|
|
59
77
|
}
|
|
60
|
-
logArray(
|
|
61
|
-
|
|
78
|
+
logArray(
|
|
79
|
+
newRangesForbidden,
|
|
80
|
+
"The following packages must be deduplicated by updating dependencies in package.json",
|
|
81
|
+
(e) => ` ${e.name} @ ${e.oldRange} should be changed to ${e.newRange}`
|
|
82
|
+
);
|
|
83
|
+
logArray(
|
|
84
|
+
newRangesAllowed,
|
|
85
|
+
"The following packages can be deduplicated by updating dependencies in package.json",
|
|
86
|
+
(e) => ` ${e.name} @ ${e.oldRange} should be changed to ${e.newRange}`
|
|
87
|
+
);
|
|
62
88
|
if (!success) {
|
|
63
89
|
throw new Error("Failed versioning check");
|
|
64
90
|
}
|
|
@@ -78,4 +104,4 @@ function logArray(arr, header, each) {
|
|
|
78
104
|
exports["default"] = lint;
|
|
79
105
|
exports.forbiddenDuplicatesFilter = forbiddenDuplicatesFilter;
|
|
80
106
|
exports.includedFilter = includedFilter;
|
|
81
|
-
//# sourceMappingURL=lint-
|
|
107
|
+
//# sourceMappingURL=lint-41010f96.cjs.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var index = require('./index-
|
|
3
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
4
4
|
var eslint = require('eslint');
|
|
5
5
|
require('commander');
|
|
6
6
|
require('chalk');
|
|
@@ -15,7 +15,9 @@ var lint = async (directories, opts) => {
|
|
|
15
15
|
fix: opts.fix,
|
|
16
16
|
extensions: ["js", "jsx", "ts", "tsx", "mjs", "cjs"]
|
|
17
17
|
});
|
|
18
|
-
const results = await eslint$1.lintFiles(
|
|
18
|
+
const results = await eslint$1.lintFiles(
|
|
19
|
+
directories.length ? directories : ["."]
|
|
20
|
+
);
|
|
19
21
|
if (opts.fix) {
|
|
20
22
|
await eslint.ESLint.outputFixes(results);
|
|
21
23
|
}
|
|
@@ -31,4 +33,4 @@ var lint = async (directories, opts) => {
|
|
|
31
33
|
};
|
|
32
34
|
|
|
33
35
|
exports["default"] = lint;
|
|
34
|
-
//# sourceMappingURL=lint-
|
|
36
|
+
//# sourceMappingURL=lint-6fcb9a70.cjs.js.map
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
var chalk = require('chalk');
|
|
4
4
|
var path = require('path');
|
|
5
|
-
var PackageGraph = require('./PackageGraph-
|
|
6
|
-
var parallel = require('./parallel-
|
|
7
|
-
var index = require('./index-
|
|
5
|
+
var PackageGraph = require('./PackageGraph-6e1d4bd4.cjs.js');
|
|
6
|
+
var parallel = require('./parallel-a8f6219c.cjs.js');
|
|
7
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
8
8
|
require('@manypkg/get-packages');
|
|
9
9
|
require('@backstage/errors');
|
|
10
10
|
require('child_process');
|
|
@@ -88,4 +88,4 @@ async function command(opts) {
|
|
|
88
88
|
}
|
|
89
89
|
|
|
90
90
|
exports.command = command;
|
|
91
|
-
//# sourceMappingURL=lint-
|
|
91
|
+
//# sourceMappingURL=lint-7f6b0d33.cjs.js.map
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
var chalk = require('chalk');
|
|
4
4
|
var eslint = require('eslint');
|
|
5
5
|
var path = require('path');
|
|
6
|
-
var index = require('./index-
|
|
7
|
-
var PackageGraph = require('./PackageGraph-
|
|
6
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
7
|
+
var PackageGraph = require('./PackageGraph-6e1d4bd4.cjs.js');
|
|
8
8
|
require('commander');
|
|
9
9
|
require('fs-extra');
|
|
10
10
|
require('semver');
|
|
@@ -79,4 +79,4 @@ async function command(opts) {
|
|
|
79
79
|
}
|
|
80
80
|
|
|
81
81
|
exports.command = command;
|
|
82
|
-
//# sourceMappingURL=list-deprecations-
|
|
82
|
+
//# sourceMappingURL=list-deprecations-8aee2123.cjs.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var fs = require('fs-extra');
|
|
4
|
-
var index = require('./index-
|
|
4
|
+
var index = require('./index-50703ee1.cjs.js');
|
|
5
5
|
var path = require('path');
|
|
6
6
|
require('commander');
|
|
7
7
|
require('chalk');
|
|
@@ -22,14 +22,18 @@ function resolveEntrypoint(pkg, name) {
|
|
|
22
22
|
}
|
|
23
23
|
async function writeReleaseStageEntrypoint(pkg, stage) {
|
|
24
24
|
await fs__default["default"].ensureDir(index.paths.resolveTarget(stage));
|
|
25
|
-
await fs__default["default"].writeJson(
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
25
|
+
await fs__default["default"].writeJson(
|
|
26
|
+
index.paths.resolveTarget(stage, PKG_PATH),
|
|
27
|
+
{
|
|
28
|
+
name: pkg.name,
|
|
29
|
+
version: pkg.version,
|
|
30
|
+
main: resolveEntrypoint(pkg, "main"),
|
|
31
|
+
module: resolveEntrypoint(pkg, "module"),
|
|
32
|
+
browser: resolveEntrypoint(pkg, "browser"),
|
|
33
|
+
types: path.join("..", pkg.publishConfig[`${stage}Types`])
|
|
34
|
+
},
|
|
35
|
+
{ encoding: "utf8", spaces: 2 }
|
|
36
|
+
);
|
|
33
37
|
}
|
|
34
38
|
const pre = async () => {
|
|
35
39
|
var _a;
|
|
@@ -63,10 +67,12 @@ const post = async () => {
|
|
|
63
67
|
await fs__default["default"].remove(index.paths.resolveTarget("beta"));
|
|
64
68
|
}
|
|
65
69
|
} catch (error) {
|
|
66
|
-
console.warn(
|
|
70
|
+
console.warn(
|
|
71
|
+
`Failed to restore package.json during postpack, ${error}. Your package will be fine but you may have ended up with some garbage in the repo.`
|
|
72
|
+
);
|
|
67
73
|
}
|
|
68
74
|
};
|
|
69
75
|
|
|
70
76
|
exports.post = post;
|
|
71
77
|
exports.pre = pre;
|
|
72
|
-
//# sourceMappingURL=pack-
|
|
78
|
+
//# sourceMappingURL=pack-91881c2f.cjs.js.map
|