construct-hub 0.3.274 → 0.3.275
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/.jsii +2 -2
- package/changelog.md +6 -1
- package/lib/backend/ingestion/framework-detection.lambda-shared.d.ts +1 -1
- package/lib/backend/ingestion/framework-detection.lambda-shared.js +76 -57
- package/lib/backend/ingestion/ingestion.lambda.bundle/index.js +109 -111
- package/lib/backend/ingestion/ingestion.lambda.bundle/index.js.map +2 -2
- package/lib/backend/ingestion/ingestion.lambda.js +4 -4
- package/lib/construct-hub.js +1 -1
- package/lib/package-sources/code-artifact.js +1 -1
- package/lib/package-sources/npmjs.js +1 -1
- package/lib/package-tag/index.js +3 -3
- package/lib/package-tag-group/index.js +2 -2
- package/lib/preload-file/index.js +1 -1
- package/lib/s3/storage.js +1 -1
- package/lib/spdx-license.js +1 -1
- package/package.json +1 -1
- package/releasetag.txt +1 -1
- package/version.txt +1 -1
package/.jsii
CHANGED
@@ -14540,6 +14540,6 @@
|
|
14540
14540
|
"symbolId": "src/package-sources/npmjs:NpmJsProps"
|
14541
14541
|
}
|
14542
14542
|
},
|
14543
|
-
"version": "0.3.
|
14544
|
-
"fingerprint": "
|
14543
|
+
"version": "0.3.275",
|
14544
|
+
"fingerprint": "61ipjh2Rs2qxaJlMHcIQ6A5ZXmqKyIPsjTRunohsDCI="
|
14545
14545
|
}
|
package/changelog.md
CHANGED
@@ -1,2 +1,7 @@
|
|
1
1
|
|
2
|
-
### [0.3.
|
2
|
+
### [0.3.275](https://github.com/cdklabs/construct-hub/compare/v0.3.274...v0.3.275) (2022-03-15)
|
3
|
+
|
4
|
+
|
5
|
+
### Features
|
6
|
+
|
7
|
+
* tag packages with multiple construct frameworks ([#794](https://github.com/cdklabs/construct-hub/issues/794)) ([78ea2dd](https://github.com/cdklabs/construct-hub/commit/78ea2dd76aef0556fea83b07c85d50039d199301)), closes [#717](https://github.com/cdklabs/construct-hub/issues/717)
|
@@ -23,4 +23,4 @@ export interface ConstructFramework {
|
|
23
23
|
*
|
24
24
|
* @returns a construct framework if one could be identified.
|
25
25
|
*/
|
26
|
-
export declare function
|
26
|
+
export declare function detectConstructFrameworks(assembly: Assembly): ConstructFramework[];
|
@@ -1,7 +1,20 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.
|
3
|
+
exports.detectConstructFrameworks = void 0;
|
4
|
+
// eslint-disable-next-line @typescript-eslint/no-require-imports
|
5
|
+
const assert = require("assert");
|
4
6
|
const semver_1 = require("semver");
|
7
|
+
/**
|
8
|
+
* Predicates that determine whether a package is indicative of the CDK
|
9
|
+
* framework someone is using.
|
10
|
+
*/
|
11
|
+
const FRAMEWORK_MATCHERS = {
|
12
|
+
["aws-cdk" /* AWS_CDK */]: (name) => name.startsWith('@aws-cdk/') || name === 'aws-cdk-lib' || name === 'monocdk',
|
13
|
+
["cdk8s" /* CDK8S */]: (name) => name === 'cdk8s' || /^cdk8s-plus(?:-(?:17|20|21|22))?$/.test(name),
|
14
|
+
// cdktf providers dependencies ("@cdktf/provider-xxx") are major versioned
|
15
|
+
// differently than the core library, so do not take them into account
|
16
|
+
["cdktf" /* CDKTF */]: (name) => name === 'cdktf',
|
17
|
+
};
|
5
18
|
/**
|
6
19
|
* Determines the Construct framework used by the provided assembly.
|
7
20
|
*
|
@@ -10,69 +23,75 @@ const semver_1 = require("semver");
|
|
10
23
|
*
|
11
24
|
* @returns a construct framework if one could be identified.
|
12
25
|
*/
|
13
|
-
function
|
14
|
-
var _a
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
// also take other CDK types as dependencies
|
21
|
-
if (assembly.name.startsWith('@cdktf/')) {
|
22
|
-
name = "cdktf" /* CDKTF */;
|
23
|
-
if ('cdktf' in ((_a = assembly.dependencyClosure) !== null && _a !== void 0 ? _a : {})) {
|
24
|
-
detectConstructFrameworkPackage('cdktf');
|
25
|
-
}
|
26
|
-
return { name, majorVersion };
|
27
|
-
}
|
26
|
+
function detectConstructFrameworks(assembly) {
|
27
|
+
var _a;
|
28
|
+
// "not-sure" means we haven't seen a major version for the framework yet,
|
29
|
+
// e.g. in the case of a transitive dependency where the info isn't provided
|
30
|
+
// "ambiguous" means we have seen multiple major versions so it's impossible
|
31
|
+
// to resolve a single number
|
32
|
+
const detectedFrameworks = {};
|
28
33
|
detectConstructFrameworkPackage(assembly.name, assembly.version);
|
29
|
-
for (const depName of Object.keys((
|
34
|
+
for (const depName of Object.keys((_a = assembly.dependencyClosure) !== null && _a !== void 0 ? _a : {})) {
|
30
35
|
detectConstructFrameworkPackage(depName);
|
31
|
-
if (nameAmbiguous) {
|
32
|
-
return undefined;
|
33
|
-
}
|
34
36
|
}
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
if (
|
39
|
-
|
40
|
-
if (name && name !== "aws-cdk" /* AWS_CDK */) {
|
41
|
-
// Identified multiple candidates, so returning ambiguous...
|
42
|
-
nameAmbiguous = true;
|
43
|
-
return;
|
44
|
-
}
|
45
|
-
name = "aws-cdk" /* AWS_CDK */;
|
46
|
-
}
|
47
|
-
else if (packageName === 'cdktf') {
|
48
|
-
if (name && name !== "cdktf" /* CDKTF */) {
|
49
|
-
// Identified multiple candidates, so returning ambiguous...
|
50
|
-
nameAmbiguous = true;
|
51
|
-
return;
|
52
|
-
}
|
53
|
-
name = "cdktf" /* CDKTF */;
|
37
|
+
const frameworks = new Array();
|
38
|
+
for (const [frameworkName, majorVersion] of Object.entries(detectedFrameworks)) {
|
39
|
+
const name = frameworkName;
|
40
|
+
if (majorVersion === undefined) {
|
41
|
+
continue;
|
54
42
|
}
|
55
|
-
else if (
|
56
|
-
|
57
|
-
// Identified multiple candidates, so returning ambiguous...
|
58
|
-
nameAmbiguous = true;
|
59
|
-
return;
|
60
|
-
}
|
61
|
-
name = "cdk8s" /* CDK8S */;
|
43
|
+
else if (majorVersion === 'ambiguous' || majorVersion === 'no-data') {
|
44
|
+
frameworks.push({ name });
|
62
45
|
}
|
63
|
-
else {
|
64
|
-
|
46
|
+
else if (typeof majorVersion === 'number') {
|
47
|
+
frameworks.push({ name, majorVersion });
|
65
48
|
}
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
49
|
+
}
|
50
|
+
return frameworks;
|
51
|
+
/**
|
52
|
+
* Analyses the package name and version range, and updates
|
53
|
+
* `detectedFrameworks` from the parent scope appropriately
|
54
|
+
*/
|
55
|
+
function detectConstructFrameworkPackage(packageName, versionRange) {
|
56
|
+
var _a, _b, _c;
|
57
|
+
if (versionRange === void 0) { versionRange = (_a = assembly.dependencies) === null || _a === void 0 ? void 0 : _a[packageName]; }
|
58
|
+
for (const frameworkName of ["aws-cdk" /* AWS_CDK */, "cdk8s" /* CDK8S */, "cdktf" /* CDKTF */]) {
|
59
|
+
const matchesFramework = FRAMEWORK_MATCHERS[frameworkName];
|
60
|
+
if (matchesFramework(packageName)) {
|
61
|
+
const frameworkVersion = detectedFrameworks[frameworkName];
|
62
|
+
if (frameworkVersion === 'ambiguous') {
|
63
|
+
// We have already seen multiple major versions and have determined
|
64
|
+
// the major version is ambiguous, so this package won't give
|
65
|
+
// us any new information.
|
66
|
+
return;
|
67
|
+
}
|
68
|
+
const packageMajor = (_c = (versionRange ? (_b = semver_1.minVersion(versionRange)) === null || _b === void 0 ? void 0 : _b.major : undefined)) !== null && _c !== void 0 ? _c : 'no-data';
|
69
|
+
if (frameworkVersion === undefined) {
|
70
|
+
// It's the first time seeing this major version, so we record
|
71
|
+
// whatever new information we found ("no-data" or number).
|
72
|
+
detectedFrameworks[frameworkName] = packageMajor;
|
73
|
+
return;
|
74
|
+
}
|
75
|
+
else if (frameworkVersion === 'no-data') {
|
76
|
+
// We've seen this framework before but haven't seen a major version,
|
77
|
+
// so record whatever new information we found ("no-data" or number).
|
78
|
+
detectedFrameworks[frameworkName] = packageMajor;
|
79
|
+
return;
|
80
|
+
}
|
81
|
+
else {
|
82
|
+
// At this point, frameworkVersion can only be a MV number
|
83
|
+
assert(typeof frameworkVersion === 'number');
|
84
|
+
// We've seen evidence of a particular major version for this
|
85
|
+
// framework, so only update if this package conflicts with what
|
86
|
+
// we're expecting.
|
87
|
+
if (packageMajor !== 'no-data' && frameworkVersion !== packageMajor) {
|
88
|
+
detectedFrameworks[frameworkName] = 'ambiguous';
|
89
|
+
}
|
90
|
+
return;
|
91
|
+
}
|
71
92
|
}
|
72
|
-
majorVersion = major;
|
73
93
|
}
|
74
|
-
return;
|
75
94
|
}
|
76
95
|
}
|
77
|
-
exports.
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
96
|
+
exports.detectConstructFrameworks = detectConstructFrameworks;
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"framework-detection.lambda-shared.js","sourceRoot":"","sources":["../../../src/backend/ingestion/framework-detection.lambda-shared.ts"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable-next-line @typescript-eslint/no-require-imports\nimport assert = require('assert');\n\nimport { Assembly } from '@jsii/spec';\nimport { minVersion } from 'semver';\n\n\nexport const enum ConstructFrameworkName {\n  AWS_CDK = 'aws-cdk',\n  CDK8S = 'cdk8s',\n  CDKTF = 'cdktf',\n}\n\nexport interface ConstructFramework {\n  /**\n   * The name of the construct framework.\n   */\n  readonly name: ConstructFrameworkName;\n\n  /**\n   * The major version of the construct framework that is used, if it could be\n   * identified.\n   */\n  readonly majorVersion?: number;\n}\n\n/**\n * Predicates that determine whether a package is indicative of the CDK\n * framework someone is using.\n */\nconst FRAMEWORK_MATCHERS: Record<ConstructFrameworkName, (name: string) => boolean> = {\n  [ConstructFrameworkName.AWS_CDK]: (name: string) => name.startsWith('@aws-cdk/') || name === 'aws-cdk-lib' || name === 'monocdk',\n  [ConstructFrameworkName.CDK8S]: (name: string) => name === 'cdk8s' || /^cdk8s-plus(?:-(?:17|20|21|22))?$/.test(name),\n  // cdktf providers dependencies (\"@cdktf/provider-xxx\") are major versioned\n  // differently than the core library, so do not take them into account\n  [ConstructFrameworkName.CDKTF]: (name: string) => name === 'cdktf',\n};\n\n/**\n * Determines the Construct framework used by the provided assembly.\n *\n * @param assembly the assembly for which a construct framework should be\n *                 identified.\n *\n * @returns a construct framework if one could be identified.\n */\nexport function detectConstructFrameworks(assembly: Assembly): ConstructFramework[] {\n  // \"not-sure\" means we haven't seen a major version for the framework yet,\n  // e.g. in the case of a transitive dependency where the info isn't provided\n  // \"ambiguous\" means we have seen multiple major versions so it's impossible\n  // to resolve a single number\n  const detectedFrameworks: { [P in ConstructFrameworkName]?: number | 'no-data' | 'ambiguous' } = {};\n\n  detectConstructFrameworkPackage(assembly.name, assembly.version);\n  for (const depName of Object.keys(assembly.dependencyClosure ?? {})) {\n    detectConstructFrameworkPackage(depName);\n  }\n\n  const frameworks = new Array<ConstructFramework>();\n  for (const [frameworkName, majorVersion] of Object.entries(detectedFrameworks)) {\n    const name = frameworkName as ConstructFrameworkName;\n    if (majorVersion === undefined) {\n      continue;\n    } else if (majorVersion === 'ambiguous' || majorVersion === 'no-data') {\n      frameworks.push({ name });\n    } else if (typeof majorVersion === 'number') {\n      frameworks.push({ name, majorVersion });\n    }\n  }\n\n  return frameworks;\n\n  /**\n   * Analyses the package name and version range, and updates\n   * `detectedFrameworks` from the parent scope appropriately\n   */\n  function detectConstructFrameworkPackage(packageName: string, versionRange = assembly.dependencies?.[packageName]): void {\n    for (const frameworkName of [ConstructFrameworkName.AWS_CDK, ConstructFrameworkName.CDK8S, ConstructFrameworkName.CDKTF]) {\n      const matchesFramework = FRAMEWORK_MATCHERS[frameworkName];\n      if (matchesFramework(packageName)) {\n        const frameworkVersion = detectedFrameworks[frameworkName];\n        if (frameworkVersion === 'ambiguous') {\n          // We have already seen multiple major versions and have determined\n          // the major version is ambiguous, so this package won't give\n          // us any new information.\n          return;\n        }\n\n        const packageMajor = (versionRange ? minVersion(versionRange)?.major : undefined) ?? 'no-data';\n\n        if (frameworkVersion === undefined) {\n          // It's the first time seeing this major version, so we record\n          // whatever new information we found (\"no-data\" or number).\n          detectedFrameworks[frameworkName] = packageMajor;\n          return;\n        } else if (frameworkVersion === 'no-data') {\n          // We've seen this framework before but haven't seen a major version,\n          // so record whatever new information we found (\"no-data\" or number).\n          detectedFrameworks[frameworkName] = packageMajor;\n          return;\n        } else {\n          // At this point, frameworkVersion can only be a MV number\n          assert(typeof frameworkVersion === 'number');\n\n          // We've seen evidence of a particular major version for this\n          // framework, so only update if this package conflicts with what\n          // we're expecting.\n          if (packageMajor !== 'no-data' && frameworkVersion !== packageMajor) {\n            detectedFrameworks[frameworkName] = 'ambiguous';\n          }\n          return;\n        }\n      }\n    }\n  }\n}\n"]}
|