@aws-cdk/cloud-assembly-schema 2.151.0 → 36.0.2

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/lib/manifest.js CHANGED
@@ -2,7 +2,6 @@
2
2
  var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.Manifest = exports.VERSION_MISMATCH = void 0;
5
- const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7
6
  const fs = require("fs");
8
7
  const jsonschema = require("jsonschema");
@@ -14,13 +13,13 @@ const assembly = require("./cloud-assembly");
14
13
  // in which case we want to instruct the user to upgrade his CLI.
15
14
  // see exec.ts#createAssembly
16
15
  exports.VERSION_MISMATCH = 'Cloud assembly schema version mismatch';
17
- const ASSETS_SCHEMA = require('../schema/assets.schema.json');
18
- const ASSEMBLY_SCHEMA = require('../schema/cloud-assembly.schema.json');
16
+ const ASSETS_SCHEMA = require("../schema/assets.schema.json");
17
+ const ASSEMBLY_SCHEMA = require("../schema/cloud-assembly.schema.json");
18
+ const INTEG_SCHEMA = require("../schema/integ.schema.json");
19
19
  /**
20
20
  * Version is shared for both manifests
21
21
  */
22
- const SCHEMA_VERSION = require('../schema/cloud-assembly.version.json').version;
23
- const INTEG_SCHEMA = require('../schema/integ.schema.json');
22
+ const SCHEMA_VERSION = require('../package.json').version;
24
23
  /**
25
24
  * Protocol utility class.
26
25
  */
@@ -32,15 +31,6 @@ class Manifest {
32
31
  * @param filePath - output file path.
33
32
  */
34
33
  static saveAssemblyManifest(manifest, filePath) {
35
- try {
36
- jsiiDeprecationWarnings._aws_cdk_cloud_assembly_schema_AssemblyManifest(manifest);
37
- }
38
- catch (error) {
39
- if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
40
- Error.captureStackTrace(error, this.saveAssemblyManifest);
41
- }
42
- throw error;
43
- }
44
34
  Manifest.saveManifest(manifest, filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnWrite);
45
35
  }
46
36
  /**
@@ -49,15 +39,6 @@ class Manifest {
49
39
  * @param filePath - path to the manifest file.
50
40
  */
51
41
  static loadAssemblyManifest(filePath, options) {
52
- try {
53
- jsiiDeprecationWarnings._aws_cdk_cloud_assembly_schema_LoadManifestOptions(options);
54
- }
55
- catch (error) {
56
- if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
57
- Error.captureStackTrace(error, this.loadAssemblyManifest);
58
- }
59
- throw error;
60
- }
61
42
  return Manifest.loadManifest(filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnRead, options);
62
43
  }
63
44
  /**
@@ -67,15 +48,6 @@ class Manifest {
67
48
  * @param filePath - output file path.
68
49
  */
69
50
  static saveAssetManifest(manifest, filePath) {
70
- try {
71
- jsiiDeprecationWarnings._aws_cdk_cloud_assembly_schema_AssetManifest(manifest);
72
- }
73
- catch (error) {
74
- if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
75
- Error.captureStackTrace(error, this.saveAssetManifest);
76
- }
77
- throw error;
78
- }
79
51
  Manifest.saveManifest(manifest, filePath, ASSETS_SCHEMA, Manifest.patchStackTagsOnRead);
80
52
  }
81
53
  /**
@@ -93,15 +65,6 @@ class Manifest {
93
65
  * @param filePath - output file path.
94
66
  */
95
67
  static saveIntegManifest(manifest, filePath) {
96
- try {
97
- jsiiDeprecationWarnings._aws_cdk_cloud_assembly_schema_IntegManifest(manifest);
98
- }
99
- catch (error) {
100
- if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
101
- Error.captureStackTrace(error, this.saveIntegManifest);
102
- }
103
- throw error;
104
- }
105
68
  Manifest.saveManifest(manifest, filePath, INTEG_SCHEMA);
106
69
  }
107
70
  /**
@@ -122,29 +85,16 @@ class Manifest {
122
85
  * Deprecated
123
86
  * @deprecated use `saveAssemblyManifest()`
124
87
  */
125
- static save(manifest, filePath) { try {
126
- jsiiDeprecationWarnings.print("@aws-cdk/cloud-assembly-schema.Manifest#save", "use `saveAssemblyManifest()`");
127
- jsiiDeprecationWarnings._aws_cdk_cloud_assembly_schema_AssemblyManifest(manifest);
88
+ static save(manifest, filePath) {
89
+ return this.saveAssemblyManifest(manifest, filePath);
128
90
  }
129
- catch (error) {
130
- if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
131
- Error.captureStackTrace(error, this.save);
132
- }
133
- throw error;
134
- } return this.saveAssemblyManifest(manifest, filePath); }
135
91
  /**
136
92
  * Deprecated
137
93
  * @deprecated use `loadAssemblyManifest()`
138
94
  */
139
- static load(filePath) { try {
140
- jsiiDeprecationWarnings.print("@aws-cdk/cloud-assembly-schema.Manifest#load", "use `loadAssemblyManifest()`");
95
+ static load(filePath) {
96
+ return this.loadAssemblyManifest(filePath);
141
97
  }
142
- catch (error) {
143
- if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
144
- Error.captureStackTrace(error, this.load);
145
- }
146
- throw error;
147
- } return this.loadAssemblyManifest(filePath); }
148
98
  static validate(manifest, schema, options) {
149
99
  function parseVersion(version) {
150
100
  const ver = semver.valid(version);
@@ -174,7 +124,7 @@ class Manifest {
174
124
  errors = stripEnumErrors(errors);
175
125
  }
176
126
  if (errors.length > 0) {
177
- throw new Error(`Invalid assembly manifest:\n${errors.map(e => e.stack).join('\n')}`);
127
+ throw new Error(`Invalid assembly manifest:\n${errors.map((e) => e.stack).join('\n')}`);
178
128
  }
179
129
  }
180
130
  static saveManifest(manifest, filePath, schema, preprocess) {
@@ -216,7 +166,7 @@ class Manifest {
216
166
  * backwards-compatibility code and it just doesn't seem to be worth the effort.
217
167
  */
218
168
  static patchStackTagsOnRead(manifest) {
219
- return Manifest.replaceStackTags(manifest, tags => tags.map((diskTag) => ({
169
+ return Manifest.replaceStackTags(manifest, (tags) => tags.map((diskTag) => ({
220
170
  key: diskTag.Key,
221
171
  value: diskTag.Value,
222
172
  })));
@@ -227,7 +177,7 @@ class Manifest {
227
177
  * Translate stack tags metadata if it has the "right" casing.
228
178
  */
229
179
  static patchStackTagsOnWrite(manifest) {
230
- return Manifest.replaceStackTags(manifest, tags => tags.map(memTag =>
180
+ return Manifest.replaceStackTags(manifest, (tags) => tags.map((memTag) =>
231
181
  // Might already be uppercased (because stack synthesis generates it in final form yet)
232
182
  ('Key' in memTag ? memTag : { Key: memTag.key, Value: memTag.value })));
233
183
  }
@@ -239,14 +189,15 @@ class Manifest {
239
189
  // about the keys with values that are `undefined` (even though they would never be JSON.stringified)
240
190
  return noUndefined({
241
191
  ...manifest,
242
- artifacts: mapValues(manifest.artifacts, artifact => {
192
+ artifacts: mapValues(manifest.artifacts, (artifact) => {
243
193
  if (artifact.type !== assembly.ArtifactType.AWS_CLOUDFORMATION_STACK) {
244
194
  return artifact;
245
195
  }
246
196
  return noUndefined({
247
197
  ...artifact,
248
- metadata: mapValues(artifact.metadata, metadataEntries => metadataEntries.map(metadataEntry => {
249
- if (metadataEntry.type !== assembly.ArtifactMetadataEntryType.STACK_TAGS || !metadataEntry.data) {
198
+ metadata: mapValues(artifact.metadata, (metadataEntries) => metadataEntries.map((metadataEntry) => {
199
+ if (metadataEntry.type !== assembly.ArtifactMetadataEntryType.STACK_TAGS ||
200
+ !metadataEntry.data) {
250
201
  return metadataEntry;
251
202
  }
252
203
  return {
@@ -262,7 +213,7 @@ class Manifest {
262
213
  }
263
214
  exports.Manifest = Manifest;
264
215
  _a = JSII_RTTI_SYMBOL_1;
265
- Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "2.151.0" };
216
+ Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "36.0.2" };
266
217
  function mapValues(xs, fn) {
267
218
  if (!xs) {
268
219
  return undefined;
@@ -283,6 +234,6 @@ function noUndefined(xs) {
283
234
  return ret;
284
235
  }
285
236
  function stripEnumErrors(errors) {
286
- return errors.filter(e => typeof e.schema === 'string' || !('enum' in e.schema));
237
+ return errors.filter((e) => typeof e.schema === 'string' || !('enum' in e.schema));
287
238
  }
288
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.js","sourceRoot":"","sources":["manifest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as jsonschema from 'jsonschema';\nimport * as semver from 'semver';\nimport * as assets from './assets';\nimport * as assembly from './cloud-assembly';\nimport * as integ from './integ-tests';\n\n/* eslint-disable @typescript-eslint/no-var-requires */\n/* eslint-disable @typescript-eslint/no-require-imports */\n\n// this prefix is used by the CLI to identify this specific error.\n// in which case we want to instruct the user to upgrade his CLI.\n// see exec.ts#createAssembly\nexport const VERSION_MISMATCH: string = 'Cloud assembly schema version mismatch';\n\nconst ASSETS_SCHEMA = require('../schema/assets.schema.json');\n\nconst ASSEMBLY_SCHEMA = require('../schema/cloud-assembly.schema.json');\n\n/**\n * Version is shared for both manifests\n */\nconst SCHEMA_VERSION = require('../schema/cloud-assembly.version.json').version;\n\nconst INTEG_SCHEMA = require('../schema/integ.schema.json');\n\n/**\n * Options for the loadManifest operation\n */\nexport interface LoadManifestOptions {\n  /**\n   * Skip the version check\n   *\n   * This means you may read a newer cloud assembly than the CX API is designed\n   * to support, and your application may not be aware of all features that in use\n   * in the Cloud Assembly.\n   *\n   * @default false\n   */\n  readonly skipVersionCheck?: boolean;\n\n  /**\n   * Skip enum checks\n   *\n   * This means you may read enum values you don't know about yet. Make sure to always\n   * check the values of enums you encounter in the manifest.\n   *\n   * @default false\n   */\n  readonly skipEnumCheck?: boolean;\n\n  /**\n   * Topologically sort all artifacts\n   *\n   * This parameter is only respected by the constructor of `CloudAssembly`. The\n   * property lives here for backwards compatibility reasons.\n   *\n   * @default true\n   */\n  readonly topoSort?: boolean;\n}\n\n/**\n * Protocol utility class.\n */\nexport class Manifest {\n  /**\n   * Validates and saves the cloud assembly manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssemblyManifest(manifest: assembly.AssemblyManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnWrite);\n  }\n\n  /**\n   * Load and validates the cloud assembly manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssemblyManifest(filePath: string, options?: LoadManifestOptions): assembly.AssemblyManifest {\n    return Manifest.loadManifest(filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnRead, options);\n  }\n\n  /**\n   * Validates and saves the asset manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssetManifest(manifest: assets.AssetManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSETS_SCHEMA, Manifest.patchStackTagsOnRead);\n  }\n\n  /**\n   * Load and validates the asset manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssetManifest(filePath: string): assets.AssetManifest {\n    return this.loadManifest(filePath, ASSETS_SCHEMA);\n  }\n\n  /**\n   * Validates and saves the integ manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveIntegManifest(manifest: integ.IntegManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Load and validates the integ manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadIntegManifest(filePath: string): integ.IntegManifest {\n    return this.loadManifest(filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Fetch the current schema version number.\n   */\n  public static version(): string {\n    return SCHEMA_VERSION;\n  }\n\n  /**\n   * Deprecated\n   * @deprecated use `saveAssemblyManifest()`\n   */\n  public static save(manifest: assembly.AssemblyManifest, filePath: string) { return this.saveAssemblyManifest(manifest, filePath); }\n\n  /**\n   * Deprecated\n   * @deprecated use `loadAssemblyManifest()`\n   */\n  public static load(filePath: string): assembly.AssemblyManifest { return this.loadAssemblyManifest(filePath); }\n\n  private static validate(manifest: { version: string }, schema: jsonschema.Schema, options?: LoadManifestOptions) {\n    function parseVersion(version: string) {\n      const ver = semver.valid(version);\n      if (!ver) {\n        throw new Error(`Invalid semver string: \"${version}\"`);\n      }\n      return ver;\n    }\n\n    const maxSupported = parseVersion(Manifest.version());\n    const actual = parseVersion(manifest.version);\n\n    // first validate the version should be accepted.\n    if (semver.gt(actual, maxSupported) && !options?.skipVersionCheck) {\n      // we use a well known error prefix so that the CLI can identify this specific error\n      // and print some more context to the user.\n      throw new Error(`${VERSION_MISMATCH}: Maximum schema version supported is ${maxSupported}, but found ${actual}`);\n    }\n\n    // now validate the format is good.\n    const validator = new jsonschema.Validator();\n    const result = validator.validate(manifest, schema, {\n\n      // does exist but is not in the TypeScript definitions\n      nestedErrors: true,\n\n      allowUnknownAttributes: false,\n\n    } as any);\n\n    let errors = result.errors;\n    if (options?.skipEnumCheck) {\n      // Enum validations aren't useful when\n      errors = stripEnumErrors(errors);\n    }\n\n    if (errors.length > 0) {\n      throw new Error(`Invalid assembly manifest:\\n${errors.map(e => e.stack).join('\\n')}`);\n    }\n  }\n\n  private static saveManifest(manifest: any, filePath: string, schema: jsonschema.Schema, preprocess?: (obj: any) => any) {\n    let withVersion = { ...manifest, version: Manifest.version() };\n    Manifest.validate(withVersion, schema);\n    if (preprocess) {\n      withVersion = preprocess(withVersion);\n    }\n    fs.writeFileSync(filePath, JSON.stringify(withVersion, undefined, 2));\n  }\n\n  private static loadManifest(filePath: string, schema: jsonschema.Schema, preprocess?: (obj: any) => any, options?: LoadManifestOptions) {\n    const contents = fs.readFileSync(filePath, { encoding: 'utf-8' });\n    let obj;\n    try {\n      obj = JSON.parse(contents);\n    } catch (e: any) {\n      throw new Error(`${e.message}, while parsing ${JSON.stringify(contents)}`);\n    }\n    if (preprocess) {\n      obj = preprocess(obj);\n    }\n    Manifest.validate(obj, schema, options);\n    return obj;\n  }\n\n  /**\n   * This requires some explaining...\n   *\n   * We previously used `{ Key, Value }` for the object that represents a stack tag. (Notice the casing)\n   * @link https://github.com/aws/aws-cdk/blob/v1.27.0/packages/aws-cdk/lib/api/cxapp/stacks.ts#L427.\n   *\n   * When that object moved to this package, it had to be JSII compliant, which meant the property\n   * names must be `camelCased`, and not `PascalCased`. This meant it no longer matches the structure in the `manifest.json` file.\n   * In order to support current manifest files, we have to translate the `PascalCased` representation to the new `camelCased` one.\n   *\n   * Note that the serialization itself still writes `PascalCased` because it relates to how CloudFormation expects it.\n   *\n   * Ideally, we would start writing the `camelCased` and translate to how CloudFormation expects it when needed. But this requires nasty\n   * backwards-compatibility code and it just doesn't seem to be worth the effort.\n   */\n  private static patchStackTagsOnRead(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, tags => tags.map((diskTag: any) => ({\n      key: diskTag.Key,\n      value: diskTag.Value,\n    })));\n  }\n\n  /**\n   * See explanation on `patchStackTagsOnRead`\n   *\n   * Translate stack tags metadata if it has the \"right\" casing.\n   */\n  private static patchStackTagsOnWrite(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, tags => tags.map(memTag =>\n      // Might already be uppercased (because stack synthesis generates it in final form yet)\n      ('Key' in memTag ? memTag : { Key: memTag.key, Value: memTag.value }) as any,\n    ));\n  }\n\n  /**\n   * Recursively replace stack tags in the stack metadata\n   */\n  private static replaceStackTags(manifest: assembly.AssemblyManifest, fn: Endofunctor<assembly.StackTagsMetadataEntry>): assembly.AssemblyManifest {\n    // Need to add in the `noUndefined`s because otherwise jest snapshot tests are going to freak out\n    // about the keys with values that are `undefined` (even though they would never be JSON.stringified)\n    return noUndefined({\n      ...manifest,\n      artifacts: mapValues(manifest.artifacts, artifact => {\n        if (artifact.type !== assembly.ArtifactType.AWS_CLOUDFORMATION_STACK) { return artifact; }\n        return noUndefined({\n          ...artifact,\n          metadata: mapValues(artifact.metadata, metadataEntries => metadataEntries.map(metadataEntry => {\n            if (metadataEntry.type !== assembly.ArtifactMetadataEntryType.STACK_TAGS || !metadataEntry.data) { return metadataEntry; }\n            return {\n              ...metadataEntry,\n              data: fn(metadataEntry.data as assembly.StackTagsMetadataEntry),\n            };\n          })),\n        } as assembly.ArtifactManifest);\n      }),\n    });\n  }\n\n  private constructor() {}\n}\n\ntype Endofunctor<A> = (x: A) => A;\n\nfunction mapValues<A, B>(xs: Record<string, A> | undefined, fn: (x: A) => B): Record<string, B> | undefined {\n  if (!xs) { return undefined; }\n  const ret: Record<string, B> | undefined = {};\n  for (const [k, v] of Object.entries(xs)) {\n    ret[k] = fn(v);\n  }\n  return ret;\n}\n\nfunction noUndefined<A extends object>(xs: A): A {\n  const ret: any = {};\n  for (const [k, v] of Object.entries(xs)) {\n    if (v !== undefined) {\n      ret[k] = v;\n    }\n  }\n  return ret;\n}\n\nfunction stripEnumErrors(errors: jsonschema.ValidationError[]) {\n  return errors.filter(e => typeof e.schema ==='string' || !('enum' in e.schema));\n}\n"]}
239
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.js","sourceRoot":"","sources":["manifest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as jsonschema from 'jsonschema';\nimport * as semver from 'semver';\nimport * as assets from './assets';\nimport * as assembly from './cloud-assembly';\nimport * as integ from './integ-tests';\n\n/* eslint-disable @typescript-eslint/no-var-requires */\n/* eslint-disable @typescript-eslint/no-require-imports */\n\n// this prefix is used by the CLI to identify this specific error.\n// in which case we want to instruct the user to upgrade his CLI.\n// see exec.ts#createAssembly\nexport const VERSION_MISMATCH: string = 'Cloud assembly schema version mismatch';\n\nimport ASSETS_SCHEMA = require('../schema/assets.schema.json');\n\nimport ASSEMBLY_SCHEMA = require('../schema/cloud-assembly.schema.json');\n\nimport INTEG_SCHEMA = require('../schema/integ.schema.json');\n\n/**\n * Version is shared for both manifests\n */\nconst SCHEMA_VERSION = require('../package.json').version;\n\n/**\n * Options for the loadManifest operation\n */\nexport interface LoadManifestOptions {\n  /**\n   * Skip the version check\n   *\n   * This means you may read a newer cloud assembly than the CX API is designed\n   * to support, and your application may not be aware of all features that in use\n   * in the Cloud Assembly.\n   *\n   * @default false\n   */\n  readonly skipVersionCheck?: boolean;\n\n  /**\n   * Skip enum checks\n   *\n   * This means you may read enum values you don't know about yet. Make sure to always\n   * check the values of enums you encounter in the manifest.\n   *\n   * @default false\n   */\n  readonly skipEnumCheck?: boolean;\n\n  /**\n   * Topologically sort all artifacts\n   *\n   * This parameter is only respected by the constructor of `CloudAssembly`. The\n   * property lives here for backwards compatibility reasons.\n   *\n   * @default true\n   */\n  readonly topoSort?: boolean;\n}\n\n/**\n * Protocol utility class.\n */\nexport class Manifest {\n  /**\n   * Validates and saves the cloud assembly manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssemblyManifest(manifest: assembly.AssemblyManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnWrite);\n  }\n\n  /**\n   * Load and validates the cloud assembly manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssemblyManifest(\n    filePath: string,\n    options?: LoadManifestOptions\n  ): assembly.AssemblyManifest {\n    return Manifest.loadManifest(filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnRead, options);\n  }\n\n  /**\n   * Validates and saves the asset manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssetManifest(manifest: assets.AssetManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSETS_SCHEMA, Manifest.patchStackTagsOnRead);\n  }\n\n  /**\n   * Load and validates the asset manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssetManifest(filePath: string): assets.AssetManifest {\n    return this.loadManifest(filePath, ASSETS_SCHEMA);\n  }\n\n  /**\n   * Validates and saves the integ manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveIntegManifest(manifest: integ.IntegManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Load and validates the integ manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadIntegManifest(filePath: string): integ.IntegManifest {\n    return this.loadManifest(filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Fetch the current schema version number.\n   */\n  public static version(): string {\n    return SCHEMA_VERSION;\n  }\n\n  /**\n   * Deprecated\n   * @deprecated use `saveAssemblyManifest()`\n   */\n  public static save(manifest: assembly.AssemblyManifest, filePath: string) {\n    return this.saveAssemblyManifest(manifest, filePath);\n  }\n\n  /**\n   * Deprecated\n   * @deprecated use `loadAssemblyManifest()`\n   */\n  public static load(filePath: string): assembly.AssemblyManifest {\n    return this.loadAssemblyManifest(filePath);\n  }\n\n  private static validate(\n    manifest: { version: string },\n    schema: jsonschema.Schema,\n    options?: LoadManifestOptions\n  ) {\n    function parseVersion(version: string) {\n      const ver = semver.valid(version);\n      if (!ver) {\n        throw new Error(`Invalid semver string: \"${version}\"`);\n      }\n      return ver;\n    }\n\n    const maxSupported = parseVersion(Manifest.version());\n    const actual = parseVersion(manifest.version);\n\n    // first validate the version should be accepted.\n    if (semver.gt(actual, maxSupported) && !options?.skipVersionCheck) {\n      // we use a well known error prefix so that the CLI can identify this specific error\n      // and print some more context to the user.\n      throw new Error(\n        `${VERSION_MISMATCH}: Maximum schema version supported is ${maxSupported}, but found ${actual}`\n      );\n    }\n\n    // now validate the format is good.\n    const validator = new jsonschema.Validator();\n    const result = validator.validate(manifest, schema, {\n      // does exist but is not in the TypeScript definitions\n      nestedErrors: true,\n\n      allowUnknownAttributes: false,\n    } as any);\n\n    let errors = result.errors;\n    if (options?.skipEnumCheck) {\n      // Enum validations aren't useful when\n      errors = stripEnumErrors(errors);\n    }\n\n    if (errors.length > 0) {\n      throw new Error(`Invalid assembly manifest:\\n${errors.map((e) => e.stack).join('\\n')}`);\n    }\n  }\n\n  private static saveManifest(\n    manifest: any,\n    filePath: string,\n    schema: jsonschema.Schema,\n    preprocess?: (obj: any) => any\n  ) {\n    let withVersion = { ...manifest, version: Manifest.version() };\n    Manifest.validate(withVersion, schema);\n    if (preprocess) {\n      withVersion = preprocess(withVersion);\n    }\n    fs.writeFileSync(filePath, JSON.stringify(withVersion, undefined, 2));\n  }\n\n  private static loadManifest(\n    filePath: string,\n    schema: jsonschema.Schema,\n    preprocess?: (obj: any) => any,\n    options?: LoadManifestOptions\n  ) {\n    const contents = fs.readFileSync(filePath, { encoding: 'utf-8' });\n    let obj;\n    try {\n      obj = JSON.parse(contents);\n    } catch (e: any) {\n      throw new Error(`${e.message}, while parsing ${JSON.stringify(contents)}`);\n    }\n    if (preprocess) {\n      obj = preprocess(obj);\n    }\n    Manifest.validate(obj, schema, options);\n    return obj;\n  }\n\n  /**\n   * This requires some explaining...\n   *\n   * We previously used `{ Key, Value }` for the object that represents a stack tag. (Notice the casing)\n   * @link https://github.com/aws/aws-cdk/blob/v1.27.0/packages/aws-cdk/lib/api/cxapp/stacks.ts#L427.\n   *\n   * When that object moved to this package, it had to be JSII compliant, which meant the property\n   * names must be `camelCased`, and not `PascalCased`. This meant it no longer matches the structure in the `manifest.json` file.\n   * In order to support current manifest files, we have to translate the `PascalCased` representation to the new `camelCased` one.\n   *\n   * Note that the serialization itself still writes `PascalCased` because it relates to how CloudFormation expects it.\n   *\n   * Ideally, we would start writing the `camelCased` and translate to how CloudFormation expects it when needed. But this requires nasty\n   * backwards-compatibility code and it just doesn't seem to be worth the effort.\n   */\n  private static patchStackTagsOnRead(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, (tags) =>\n      tags.map((diskTag: any) => ({\n        key: diskTag.Key,\n        value: diskTag.Value,\n      }))\n    );\n  }\n\n  /**\n   * See explanation on `patchStackTagsOnRead`\n   *\n   * Translate stack tags metadata if it has the \"right\" casing.\n   */\n  private static patchStackTagsOnWrite(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, (tags) =>\n      tags.map(\n        (memTag) =>\n          // Might already be uppercased (because stack synthesis generates it in final form yet)\n          ('Key' in memTag ? memTag : { Key: memTag.key, Value: memTag.value }) as any\n      )\n    );\n  }\n\n  /**\n   * Recursively replace stack tags in the stack metadata\n   */\n  private static replaceStackTags(\n    manifest: assembly.AssemblyManifest,\n    fn: Endofunctor<assembly.StackTagsMetadataEntry>\n  ): assembly.AssemblyManifest {\n    // Need to add in the `noUndefined`s because otherwise jest snapshot tests are going to freak out\n    // about the keys with values that are `undefined` (even though they would never be JSON.stringified)\n    return noUndefined({\n      ...manifest,\n      artifacts: mapValues(manifest.artifacts, (artifact) => {\n        if (artifact.type !== assembly.ArtifactType.AWS_CLOUDFORMATION_STACK) {\n          return artifact;\n        }\n        return noUndefined({\n          ...artifact,\n          metadata: mapValues(artifact.metadata, (metadataEntries) =>\n            metadataEntries.map((metadataEntry) => {\n              if (\n                metadataEntry.type !== assembly.ArtifactMetadataEntryType.STACK_TAGS ||\n                !metadataEntry.data\n              ) {\n                return metadataEntry;\n              }\n              return {\n                ...metadataEntry,\n                data: fn(metadataEntry.data as assembly.StackTagsMetadataEntry),\n              };\n            })\n          ),\n        } as assembly.ArtifactManifest);\n      }),\n    });\n  }\n\n  private constructor() {}\n}\n\ntype Endofunctor<A> = (x: A) => A;\n\nfunction mapValues<A, B>(\n  xs: Record<string, A> | undefined,\n  fn: (x: A) => B\n): Record<string, B> | undefined {\n  if (!xs) {\n    return undefined;\n  }\n  const ret: Record<string, B> | undefined = {};\n  for (const [k, v] of Object.entries(xs)) {\n    ret[k] = fn(v);\n  }\n  return ret;\n}\n\nfunction noUndefined<A extends object>(xs: A): A {\n  const ret: any = {};\n  for (const [k, v] of Object.entries(xs)) {\n    if (v !== undefined) {\n      ret[k] = v;\n    }\n  }\n  return ret;\n}\n\nfunction stripEnumErrors(errors: jsonschema.ValidationError[]) {\n  return errors.filter((e) => typeof e.schema === 'string' || !('enum' in e.schema));\n}\n"]}
@@ -459,7 +459,7 @@ strings that they parse.
459
459
  in descending order when passed to `Array.sort()`.
460
460
  * `compareBuild(v1, v2)`: The same as `compare` but considers `build` when two versions
461
461
  are equal. Sorts in ascending order if passed to `Array.sort()`.
462
- * `compareLoose(v1, v2)`: Short for ``compare(v1, v2, { loose: true })`.
462
+ * `compareLoose(v1, v2)`: Short for `compare(v1, v2, { loose: true })`.
463
463
  * `diff(v1, v2)`: Returns the difference between two versions by the release type
464
464
  (`major`, `premajor`, `minor`, `preminor`, `patch`, `prepatch`, or `prerelease`),
465
465
  or null if the versions are the same.
@@ -1,3 +1,5 @@
1
+ const SPACE_CHARACTERS = /\s+/g
2
+
1
3
  // hoisted class for cyclic dependency
2
4
  class Range {
3
5
  constructor (range, options) {
@@ -18,7 +20,7 @@ class Range {
18
20
  // just put it in the set and return
19
21
  this.raw = range.value
20
22
  this.set = [[range]]
21
- this.format()
23
+ this.formatted = undefined
22
24
  return this
23
25
  }
24
26
 
@@ -29,10 +31,7 @@ class Range {
29
31
  // First reduce all whitespace as much as possible so we do not have to rely
30
32
  // on potentially slow regexes like \s*. This is then stored and used for
31
33
  // future error messages as well.
32
- this.raw = range
33
- .trim()
34
- .split(/\s+/)
35
- .join(' ')
34
+ this.raw = range.trim().replace(SPACE_CHARACTERS, ' ')
36
35
 
37
36
  // First, split on ||
38
37
  this.set = this.raw
@@ -66,14 +65,29 @@ class Range {
66
65
  }
67
66
  }
68
67
 
69
- this.format()
68
+ this.formatted = undefined
69
+ }
70
+
71
+ get range () {
72
+ if (this.formatted === undefined) {
73
+ this.formatted = ''
74
+ for (let i = 0; i < this.set.length; i++) {
75
+ if (i > 0) {
76
+ this.formatted += '||'
77
+ }
78
+ const comps = this.set[i]
79
+ for (let k = 0; k < comps.length; k++) {
80
+ if (k > 0) {
81
+ this.formatted += ' '
82
+ }
83
+ this.formatted += comps[k].toString().trim()
84
+ }
85
+ }
86
+ }
87
+ return this.formatted
70
88
  }
71
89
 
72
90
  format () {
73
- this.range = this.set
74
- .map((comps) => comps.join(' ').trim())
75
- .join('||')
76
- .trim()
77
91
  return this.range
78
92
  }
79
93
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "semver",
3
- "version": "7.6.2",
3
+ "version": "7.6.3",
4
4
  "description": "The semantic version parser used by npm.",
5
5
  "main": "index.js",
6
6
  "scripts": {
package/package.json CHANGED
@@ -1,31 +1,93 @@
1
1
  {
2
2
  "name": "@aws-cdk/cloud-assembly-schema",
3
- "version": "2.151.0",
4
3
  "description": "Cloud Assembly Schema",
4
+ "repository": {
5
+ "type": "git",
6
+ "url": "https://github.com/cdklabs/cloud-assembly-schema.git"
7
+ },
8
+ "scripts": {
9
+ "build": "npx projen build",
10
+ "bump": "npx projen bump",
11
+ "clobber": "npx projen clobber",
12
+ "compat": "npx projen compat",
13
+ "compile": "npx projen compile",
14
+ "default": "npx projen default",
15
+ "eject": "npx projen eject",
16
+ "eslint": "npx projen eslint",
17
+ "package": "npx projen package",
18
+ "package-all": "npx projen package-all",
19
+ "package:dotnet": "npx projen package:dotnet",
20
+ "package:go": "npx projen package:go",
21
+ "package:java": "npx projen package:java",
22
+ "package:js": "npx projen package:js",
23
+ "package:python": "npx projen package:python",
24
+ "post-compile": "npx projen post-compile",
25
+ "post-upgrade": "npx projen post-upgrade",
26
+ "pre-compile": "npx projen pre-compile",
27
+ "pre-release": "npx projen pre-release",
28
+ "release": "npx projen release",
29
+ "test": "npx projen test",
30
+ "test:watch": "npx projen test:watch",
31
+ "unbump": "npx projen unbump",
32
+ "upgrade": "npx projen upgrade",
33
+ "watch": "npx projen watch",
34
+ "projen": "npx projen",
35
+ "update-schema": "ts-node --prefer-ts-exts -e \"require('./projenrc/update.ts').update()\""
36
+ },
37
+ "author": {
38
+ "name": "Amazon Web Services",
39
+ "url": "https://aws.amazon.com",
40
+ "organization": true
41
+ },
42
+ "devDependencies": {
43
+ "@types/jest": "29",
44
+ "@types/node": "^18",
45
+ "@types/semver": "^7.5.8",
46
+ "@typescript-eslint/eslint-plugin": "^7",
47
+ "@typescript-eslint/parser": "^7",
48
+ "constructs": "^10.0.0",
49
+ "eslint": "^8",
50
+ "eslint-config-prettier": "^9.1.0",
51
+ "eslint-import-resolver-typescript": "^3.6.1",
52
+ "eslint-plugin-import": "^2.29.1",
53
+ "eslint-plugin-prettier": "^5.2.1",
54
+ "jest": "29",
55
+ "jest-junit": "^15",
56
+ "jsii": "~5.4.31",
57
+ "jsii-diff": "^1.102.0",
58
+ "jsii-pacmak": "^1.102.0",
59
+ "jsii-rosetta": "~5.4.29",
60
+ "mock-fs": "^5.2.0",
61
+ "prettier": "^3.3.3",
62
+ "projen": "^0.85.0",
63
+ "standard-version": "^9",
64
+ "ts-jest": "29",
65
+ "ts-node": "^10.9.2",
66
+ "typescript": "^5.5.4",
67
+ "typescript-json-schema": "^0.64.0"
68
+ },
69
+ "dependencies": {
70
+ "jsonschema": "^1.4.1",
71
+ "semver": "^7.6.3"
72
+ },
73
+ "bundledDependencies": [
74
+ "jsonschema",
75
+ "semver"
76
+ ],
77
+ "keywords": [
78
+ "aws",
79
+ "cdk"
80
+ ],
81
+ "engines": {
82
+ "node": ">= 18.18.0"
83
+ },
5
84
  "main": "lib/index.js",
85
+ "license": "Apache-2.0",
86
+ "homepage": "https://github.com/cdklabs/cloud-assembly-schema",
87
+ "version": "36.0.2",
6
88
  "types": "lib/index.d.ts",
7
- "nx": {
8
- "targets": {
9
- "build": {
10
- "outputs": [
11
- "{projectRoot}/**/*.js",
12
- "{projectRoot}/**/*.d.ts",
13
- "{projectRoot}/.jsii",
14
- "{projectRoot}/.warnings.jsii.js",
15
- "{projectRoot}/.gitignore",
16
- "{projectRoot}/tsconfig.json",
17
- "{projectRoot}/schema/**/*",
18
- "{projectRoot}/README.md",
19
- "{projectRoot}/rosetta",
20
- "!{projectRoot}/node_modules/**/*"
21
- ]
22
- }
23
- }
24
- },
89
+ "stability": "stable",
25
90
  "jsii": {
26
- "excludeTypescript": [
27
- "**/test/**/*.ts"
28
- ],
29
91
  "outdir": "dist",
30
92
  "targets": {
31
93
  "java": {
@@ -35,11 +97,6 @@
35
97
  "artifactId": "cdk-cloud-assembly-schema"
36
98
  }
37
99
  },
38
- "dotnet": {
39
- "namespace": "Amazon.CDK.CloudAssembly.Schema",
40
- "packageId": "Amazon.CDK.CloudAssembly.Schema",
41
- "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png"
42
- },
43
100
  "python": {
44
101
  "distName": "aws-cdk.cloud-assembly-schema",
45
102
  "module": "aws_cdk.cloud_assembly_schema",
@@ -47,76 +104,23 @@
47
104
  "Framework :: AWS CDK",
48
105
  "Framework :: AWS CDK :: 2"
49
106
  ]
107
+ },
108
+ "dotnet": {
109
+ "namespace": "Amazon.CDK.CloudAssembly.Schema",
110
+ "packageId": "Amazon.CDK.CloudAssembly.Schema",
111
+ "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png"
112
+ },
113
+ "go": {
114
+ "moduleName": "github.com/aws/aws-cdk-go/awscdk/cloudassemblyschema/awscdkcloudassemblyschema/v_NEXT"
50
115
  }
51
116
  },
52
- "projectReferences": true,
53
- "metadata": {
54
- "jsii": {
55
- "rosetta": {
56
- "strict": false
57
- }
58
- }
59
- }
60
- },
61
- "scripts": {
62
- "build": "cdk-build --skip-lint",
63
- "gen": "cdk-copy cloud-assembly-schema",
64
- "watch": "cdk-watch",
65
- "test": "cdk-test",
66
- "pkglint": "pkglint -f",
67
- "package": "cdk-package",
68
- "awslint": "cdk-awslint",
69
- "build+test+package": "yarn build+test && yarn package",
70
- "build+test": "yarn build && yarn test",
71
- "compat": "cdk-compat",
72
- "rosetta:extract": "yarn --silent jsii-rosetta extract",
73
- "build+extract": "yarn build && yarn rosetta:extract",
74
- "build+test+extract": "yarn build+test && yarn rosetta:extract"
75
- },
76
- "author": {
77
- "name": "Amazon Web Services",
78
- "url": "https://aws.amazon.com",
79
- "organization": true
80
- },
81
- "license": "Apache-2.0",
82
- "devDependencies": {
83
- "@aws-cdk/cdk-build-tools": "2.151.0-alpha.0",
84
- "@aws-cdk/pkglint": "2.151.0-alpha.0",
85
- "@types/jest": "^29.5.12",
86
- "@types/mock-fs": "^4.13.4",
87
- "@types/semver": "^7.5.8",
88
- "aws-cdk-lib": "2.151.0",
89
- "jest": "^29.7.0",
90
- "mock-fs": "^4.14.0",
91
- "typescript-json-schema": "^0.64.0"
92
- },
93
- "repository": {
94
- "url": "https://github.com/aws/aws-cdk.git",
95
- "type": "git",
96
- "directory": "packages/@aws-cdk/cloud-assembly-schema"
97
- },
98
- "keywords": [
99
- "aws",
100
- "cdk"
101
- ],
102
- "homepage": "https://github.com/aws/aws-cdk",
103
- "bundledDependencies": [
104
- "jsonschema",
105
- "semver"
106
- ],
107
- "engines": {
108
- "node": ">= 14.15.0"
109
- },
110
- "stability": "stable",
111
- "dependencies": {
112
- "jsonschema": "^1.4.1",
113
- "semver": "^7.6.2"
114
- },
115
- "awscdkio": {
116
- "announce": false
117
+ "tsc": {
118
+ "outDir": "lib",
119
+ "rootDir": "lib"
120
+ },
121
+ "excludeTypescript": [
122
+ "**/test/**/*.ts"
123
+ ]
117
124
  },
118
- "maturity": "stable",
119
- "publishConfig": {
120
- "tag": "latest"
121
- }
122
- }
125
+ "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\"."
126
+ }
package/schema/README.md CHANGED
@@ -2,4 +2,4 @@
2
2
 
3
3
  **DO NOT MODIFY FILES IN THIS DIRECTORY BY HAND**
4
4
 
5
- To modify, run `yarn update-schema`.
5
+ Schema files will be automatically updated by `yarn build`. They may also be updated separately by running `yarn update-schema`.
Binary file