construct-hub 0.3.274 → 0.3.275
Sign up to get free protection for your applications and to get access to all the features.
- 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"]}
|