@aws-cdk/cloud-assembly-schema 42.0.0 → 43.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -16,7 +16,7 @@
16
16
  "stability": "stable"
17
17
  },
18
18
  "homepage": "https://github.com/aws/aws-cdk",
19
- "jsiiVersion": "5.6.13 (build 629499a)",
19
+ "jsiiVersion": "5.6.14 (build d974ee4)",
20
20
  "keywords": [
21
21
  "aws",
22
22
  "cdk"
@@ -32,7 +32,7 @@
32
32
  },
33
33
  "name": "@aws-cdk/cloud-assembly-schema",
34
34
  "readme": {
35
- "markdown": "# Cloud Assembly Schema\n\nThis module is part of the [AWS Cloud Development Kit](https://github.com/aws/aws-cdk) project.\n\n## Cloud Assembly\n\nThe _Cloud Assembly_ is the output of the synthesis operation. It is produced as part of the\n[`cdk synth`](https://github.com/aws/aws-cdk/tree/main/packages/aws-cdk#cdk-synthesize)\ncommand, or the [`app.synth()`](https://github.com/aws/aws-cdk/blob/main/packages/@aws-cdk/core/lib/app.ts#L135) method invocation.\n\nIts essentially a set of files and directories, one of which is the `manifest.json` file. It defines the set of instructions that are\nneeded in order to deploy the assembly directory.\n\n> For example, when `cdk deploy` is executed, the CLI reads this file and performs its instructions:\n>\n> - Build container images.\n> - Upload assets.\n> - Deploy CloudFormation templates.\n\nTherefore, the assembly is how the CDK class library and CDK CLI (or any other consumer) communicate. To ensure compatibility\nbetween the assembly and its consumers, we treat the manifest file as a well defined, versioned schema.\n\n## Schema\n\nThis module contains the typescript structs that comprise the `manifest.json` file, as well as the\ngenerated [_json-schema_](./schema/cloud-assembly.schema.json).\n\n## Versioning\n\nThe schema version is specified my the major version of the package release. It follows semantic versioning, but with a small twist.\n\nWhen we add instructions to the assembly, they are reflected in the manifest file and the _json-schema_ accordingly.\nEvery such instruction, is crucial for ensuring the correct deployment behavior. This means that to properly deploy a cloud assembly,\nconsumers must be aware of every such instruction modification.\n\nFor this reason, every change to the schema, even though it might not strictly break validation of the _json-schema_ format,\nis considered `major` version bump. All changes that do not impact the schema are considered a `minor` version bump.\n\n## How to consume\n\nIf you'd like to consume the [schema file](./schema/cloud-assembly.schema.json) in order to do validations on `manifest.json` files,\nsimply download it from this repo and run it against standard _json-schema_ validators, such as [jsonschema](https://www.npmjs.com/package/jsonschema).\n\nConsumers must take into account the `major` version of the schema they are consuming. They should reject cloud assemblies\nwith a `major` version that is higher than what they expect. While schema validation might pass on such assemblies, the deployment integrity\ncannot be guaranteed because some instructions will be ignored.\n\n> For example, if your consumer was built when the schema version was 2.0.0, you should reject deploying cloud assemblies with a\n> manifest version of 3.0.0.\n\n## Contributing\n\nSee [Contribution Guide](./CONTRIBUTING.md)\n\n"
35
+ "markdown": "# Cloud Assembly Schema\n\nThis module is part of the [AWS Cloud Development Kit](https://github.com/aws/aws-cdk) project.\n\n## Cloud Assembly\n\nThe _Cloud Assembly_ is the output of the synthesis operation. It is produced as part of the\n[`cdk synth`](https://github.com/aws/aws-cdk-cli/tree/main/packages/aws-cdk#cdk-synthesize)\ncommand, or the [`app.synth()`](https://github.com/aws/aws-cdk/blob/main/packages/aws-cdk-lib/core/lib/stage.ts#L219) method invocation.\n\nIts essentially a set of files and directories, one of which is the `manifest.json` file. It defines the set of instructions that are\nneeded in order to deploy the assembly directory.\n\n> For example, when `cdk deploy` is executed, the CLI reads this file and performs its instructions:\n>\n> - Build container images.\n> - Upload assets.\n> - Deploy CloudFormation templates.\n\nTherefore, the assembly is how the CDK class library and CDK CLI (or any other consumer) communicate. To ensure compatibility\nbetween the assembly and its consumers, we treat the manifest file as a well defined, versioned schema.\n\n## Schema\n\nThis module contains the typescript structs that comprise the `manifest.json` file, as well as the\ngenerated [_json-schema_](./schema/cloud-assembly.schema.json).\n\n## Versioning\n\nThe schema version is specified my the major version of the package release. It follows semantic versioning, but with a small twist.\n\nWhen we add instructions to the assembly, they are reflected in the manifest file and the _json-schema_ accordingly.\nEvery such instruction, is crucial for ensuring the correct deployment behavior. This means that to properly deploy a cloud assembly,\nconsumers must be aware of every such instruction modification.\n\nFor this reason, every change to the schema, even though it might not strictly break validation of the _json-schema_ format,\nis considered `major` version bump. All changes that do not impact the schema are considered a `minor` version bump.\n\n## How to consume\n\nIf you'd like to consume the [schema file](./schema/cloud-assembly.schema.json) in order to do validations on `manifest.json` files,\nsimply download it from this repo and run it against standard _json-schema_ validators, such as [jsonschema](https://www.npmjs.com/package/jsonschema).\n\nConsumers must take into account the `major` version of the schema they are consuming. They should reject cloud assemblies\nwith a `major` version that is higher than what they expect. While schema validation might pass on such assemblies, the deployment integrity\ncannot be guaranteed because some instructions will be ignored.\n\n> For example, if your consumer was built when the schema version was 2.0.0, you should reject deploying cloud assemblies with a\n> manifest version of 3.0.0.\n\n## Contributing\n\nSee [Contribution Guide](./CONTRIBUTING.md)\n"
36
36
  },
37
37
  "repository": {
38
38
  "directory": "packages/@aws-cdk/cloud-assembly-schema",
@@ -1238,7 +1238,7 @@
1238
1238
  "datatype": true,
1239
1239
  "docs": {
1240
1240
  "stability": "stable",
1241
- "summary": "Query input for lookup up Cloudformation resources using CC API."
1241
+ "summary": "Query input for lookup up CloudFormation resources using CC API."
1242
1242
  },
1243
1243
  "fqn": "@aws-cdk/cloud-assembly-schema.CcApiContextQuery",
1244
1244
  "interfaces": [
@@ -1261,7 +1261,7 @@
1261
1261
  "immutable": true,
1262
1262
  "locationInModule": {
1263
1263
  "filename": "lib/cloud-assembly/context-queries.ts",
1264
- "line": 414
1264
+ "line": 417
1265
1265
  },
1266
1266
  "name": "propertiesToReturn",
1267
1267
  "type": {
@@ -1278,7 +1278,7 @@
1278
1278
  "docs": {
1279
1279
  "remarks": "See https://docs.aws.amazon.com/cloudcontrolapi/latest/userguide/supported-resources.html",
1280
1280
  "stability": "stable",
1281
- "summary": "The Cloudformation resource type."
1281
+ "summary": "The CloudFormation resource type."
1282
1282
  },
1283
1283
  "immutable": true,
1284
1284
  "locationInModule": {
@@ -1301,7 +1301,7 @@
1301
1301
  "immutable": true,
1302
1302
  "locationInModule": {
1303
1303
  "filename": "lib/cloud-assembly/context-queries.ts",
1304
- "line": 428
1304
+ "line": 448
1305
1305
  },
1306
1306
  "name": "dummyValue",
1307
1307
  "optional": true,
@@ -1313,7 +1313,7 @@
1313
1313
  "abstract": true,
1314
1314
  "docs": {
1315
1315
  "default": "- Either exactIdentifier or propertyMatch should be specified.",
1316
- "remarks": "Specifying exactIdentifier will return exactly one result, or throw an error.",
1316
+ "remarks": "Specifying exactIdentifier will return exactly one result, or throw an error\nunless `ignoreErrorOnMissingContext` is set.",
1317
1317
  "stability": "stable",
1318
1318
  "summary": "Identifier of the resource to look up using `GetResource`."
1319
1319
  },
@@ -1328,18 +1328,37 @@
1328
1328
  "primitive": "string"
1329
1329
  }
1330
1330
  },
1331
+ {
1332
+ "abstract": true,
1333
+ "docs": {
1334
+ "default": "'any'",
1335
+ "remarks": "If the expected result count does not match the actual count,\nby default an error is produced and the result is not committed to cached\ncontext, and the user can correct the situation and try again without\nhaving to manually clear out the context key using `cdk context --remove`\n\nIf the value of * `ignoreErrorOnMissingContext` is `true`, the value of\n`expectedMatchCount` is `at-least-one | exactly-one` and the number\nof found resources is 0, `dummyValue` is returned and committed to context\ninstead.",
1336
+ "stability": "stable",
1337
+ "summary": "Expected count of results if `propertyMatch` is specified."
1338
+ },
1339
+ "immutable": true,
1340
+ "locationInModule": {
1341
+ "filename": "lib/cloud-assembly/context-queries.ts",
1342
+ "line": 434
1343
+ },
1344
+ "name": "expectedMatchCount",
1345
+ "optional": true,
1346
+ "type": {
1347
+ "primitive": "string"
1348
+ }
1349
+ },
1331
1350
  {
1332
1351
  "abstract": true,
1333
1352
  "docs": {
1334
1353
  "default": "false",
1335
- "remarks": "- In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with\n that identifier was not found.\n- In case of a `propertyMatch` lookup, this setting currently does not have any effect,\n as `propertyMatch` queries can legally return 0 resources.\n\nif `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.",
1354
+ "remarks": "- In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with\n that identifier was not found.\n- In case of a `propertyMatch` lookup, return the `dummyValue` if `expectedMatchCount`\n is `at-least-one | exactly-one` and the number of resources found was 0.\n\nif `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.",
1336
1355
  "stability": "stable",
1337
1356
  "summary": "Ignore an error and return the `dummyValue` instead if the resource was not found."
1338
1357
  },
1339
1358
  "immutable": true,
1340
1359
  "locationInModule": {
1341
1360
  "filename": "lib/cloud-assembly/context-queries.ts",
1342
- "line": 442
1361
+ "line": 462
1343
1362
  },
1344
1363
  "name": "ignoreErrorOnMissingContext",
1345
1364
  "optional": true,
@@ -1351,14 +1370,14 @@
1351
1370
  "abstract": true,
1352
1371
  "docs": {
1353
1372
  "default": "- Either exactIdentifier or propertyMatch should be specified.",
1354
- "remarks": "Specifying propertyMatch will return 0 or more results.\n\n## Notes on property completeness\n\nCloudControl API's `ListResources` may return fewer properties than\n`GetResource` would, depending on the resource implementation.\n\nThe resources that `propertyMatch` matches against will *only ever* be the\nproperties returned by the `ListResources` call.",
1373
+ "remarks": "By default, specifying propertyMatch will successfully return 0 or more\nresults. To throw an error if the number of results is unexpected (and\nprevent the query results from being committed to context), specify\n`expectedMatchCount`.\n\n## Notes on property completeness\n\nCloudControl API's `ListResources` may return fewer properties than\n`GetResource` would, depending on the resource implementation.\n\nThe resources that `propertyMatch` matches against will *only ever* be the\nproperties returned by the `ListResources` call.",
1355
1374
  "stability": "stable",
1356
1375
  "summary": "Returns any resources matching these properties, using `ListResources`."
1357
1376
  },
1358
1377
  "immutable": true,
1359
1378
  "locationInModule": {
1360
1379
  "filename": "lib/cloud-assembly/context-queries.ts",
1361
- "line": 392
1380
+ "line": 395
1362
1381
  },
1363
1382
  "name": "propertyMatch",
1364
1383
  "optional": true,
@@ -5141,7 +5160,7 @@
5141
5160
  "kind": "interface",
5142
5161
  "locationInModule": {
5143
5162
  "filename": "lib/cloud-assembly/context-queries.ts",
5144
- "line": 451
5163
+ "line": 471
5145
5164
  },
5146
5165
  "name": "PluginContextQuery",
5147
5166
  "properties": [
@@ -5154,7 +5173,7 @@
5154
5173
  "immutable": true,
5155
5174
  "locationInModule": {
5156
5175
  "filename": "lib/cloud-assembly/context-queries.ts",
5157
- "line": 455
5176
+ "line": 475
5158
5177
  },
5159
5178
  "name": "pluginName",
5160
5179
  "type": {
@@ -5758,6 +5777,6 @@
5758
5777
  "symbolId": "lib/cloud-assembly/context-queries:VpcContextQuery"
5759
5778
  }
5760
5779
  },
5761
- "version": "42.0.0",
5762
- "fingerprint": "BL5pRq7R15nJdxKtzs57jDdVk8bMEmotECKuxsZl67s="
5780
+ "version": "43.0.0",
5781
+ "fingerprint": "y1M7bjPyGfaaf4QttfJKE6ALBmLLGYbHU+Qop7qCAe0="
5763
5782
  }
package/README.md CHANGED
@@ -5,8 +5,8 @@ This module is part of the [AWS Cloud Development Kit](https://github.com/aws/aw
5
5
  ## Cloud Assembly
6
6
 
7
7
  The _Cloud Assembly_ is the output of the synthesis operation. It is produced as part of the
8
- [`cdk synth`](https://github.com/aws/aws-cdk/tree/main/packages/aws-cdk#cdk-synthesize)
9
- command, or the [`app.synth()`](https://github.com/aws/aws-cdk/blob/main/packages/@aws-cdk/core/lib/app.ts#L135) method invocation.
8
+ [`cdk synth`](https://github.com/aws/aws-cdk-cli/tree/main/packages/aws-cdk#cdk-synthesize)
9
+ command, or the [`app.synth()`](https://github.com/aws/aws-cdk/blob/main/packages/aws-cdk-lib/core/lib/stage.ts#L219) method invocation.
10
10
 
11
11
  Its essentially a set of files and directories, one of which is the `manifest.json` file. It defines the set of instructions that are
12
12
  needed in order to deploy the assembly directory.
@@ -51,4 +51,3 @@ cannot be guaranteed because some instructions will be ignored.
51
51
  ## Contributing
52
52
 
53
53
  See [Contribution Guide](./CONTRIBUTING.md)
54
-
package/cli-version.json CHANGED
@@ -1 +1 @@
1
- {"version":"2.1006.0"}
1
+ {"version":"2.1007.0"}
@@ -312,19 +312,19 @@ export interface KeyContextQuery extends ContextLookupRoleOptions {
312
312
  readonly aliasName: string;
313
313
  }
314
314
  /**
315
- * Query input for lookup up Cloudformation resources using CC API
315
+ * Query input for lookup up CloudFormation resources using CC API
316
316
  */
317
317
  export interface CcApiContextQuery extends ContextLookupRoleOptions {
318
318
  /**
319
- * The Cloudformation resource type.
319
+ * The CloudFormation resource type.
320
320
  * See https://docs.aws.amazon.com/cloudcontrolapi/latest/userguide/supported-resources.html
321
321
  */
322
322
  readonly typeName: string;
323
323
  /**
324
324
  * Identifier of the resource to look up using `GetResource`.
325
325
  *
326
- * Specifying exactIdentifier will return exactly one result, or throw an error.
327
- *
326
+ * Specifying exactIdentifier will return exactly one result, or throw an error
327
+ * unless `ignoreErrorOnMissingContext` is set.
328
328
  *
329
329
  * @default - Either exactIdentifier or propertyMatch should be specified.
330
330
  */
@@ -332,7 +332,10 @@ export interface CcApiContextQuery extends ContextLookupRoleOptions {
332
332
  /**
333
333
  * Returns any resources matching these properties, using `ListResources`.
334
334
  *
335
- * Specifying propertyMatch will return 0 or more results.
335
+ * By default, specifying propertyMatch will successfully return 0 or more
336
+ * results. To throw an error if the number of results is unexpected (and
337
+ * prevent the query results from being committed to context), specify
338
+ * `expectedMatchCount`.
336
339
  *
337
340
  * ## Notes on property completeness
338
341
  *
@@ -366,6 +369,22 @@ export interface CcApiContextQuery extends ContextLookupRoleOptions {
366
369
  * `GetResource` call for resources matched by `propertyMatch`.
367
370
  */
368
371
  readonly propertiesToReturn: string[];
372
+ /**
373
+ * Expected count of results if `propertyMatch` is specified.
374
+ *
375
+ * If the expected result count does not match the actual count,
376
+ * by default an error is produced and the result is not committed to cached
377
+ * context, and the user can correct the situation and try again without
378
+ * having to manually clear out the context key using `cdk context --remove`
379
+ *
380
+ * If the value of * `ignoreErrorOnMissingContext` is `true`, the value of
381
+ * `expectedMatchCount` is `at-least-one | exactly-one` and the number
382
+ * of found resources is 0, `dummyValue` is returned and committed to context
383
+ * instead.
384
+ *
385
+ * @default 'any'
386
+ */
387
+ readonly expectedMatchCount?: 'any' | 'at-least-one' | 'at-most-one' | 'exactly-one';
369
388
  /**
370
389
  * The value to return if the resource was not found and `ignoreErrorOnMissingContext` is true.
371
390
  *
@@ -384,8 +403,8 @@ export interface CcApiContextQuery extends ContextLookupRoleOptions {
384
403
  *
385
404
  * - In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with
386
405
  * that identifier was not found.
387
- * - In case of a `propertyMatch` lookup, this setting currently does not have any effect,
388
- * as `propertyMatch` queries can legally return 0 resources.
406
+ * - In case of a `propertyMatch` lookup, return the `dummyValue` if `expectedMatchCount`
407
+ * is `at-least-one | exactly-one` and the number of resources found was 0.
389
408
  *
390
409
  * if `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.
391
410
  *
@@ -99,4 +99,4 @@ var LoadBalancerListenerProtocol;
99
99
  * */
100
100
  LoadBalancerListenerProtocol["TCP_UDP"] = "TCP_UDP";
101
101
  })(LoadBalancerListenerProtocol || (exports.LoadBalancerListenerProtocol = LoadBalancerListenerProtocol = {}));
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-queries.js","sourceRoot":"","sources":["context-queries.ts"],"names":[],"mappings":";;;AAEA;;GAEG;AACH,IAAY,eA4DX;AA5DD,WAAY,eAAe;IACzB;;OAEG;IACH,uCAAoB,CAAA;IAEpB;;OAEG;IACH,oEAAiD,CAAA;IAEjD;;OAEG;IACH,uDAAoC,CAAA;IAEpC;;OAEG;IACH,iDAA8B,CAAA;IAE9B;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,sGAAmF,CAAA;IAEnF;;OAEG;IACH,2DAAwC,CAAA;IAExC;;OAEG;IACH,6EAA0D,CAAA;IAE1D;;OAEG;IACH,6DAA0C,CAAA;IAE1C;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,sDAAmC,CAAA;IAEnC;;OAEG;IACH,oCAAiB,CAAA;AACnB,CAAC,EA5DW,eAAe,+BAAf,eAAe,QA4D1B;AA0JD;;GAEG;AACH,IAAY,gBAUX;AAVD,WAAY,gBAAgB;IAC1B;;OAEG;IACH,uCAAmB,CAAA;IAEnB;;OAEG;IACH,+CAA2B,CAAA;AAC7B,CAAC,EAVW,gBAAgB,gCAAhB,gBAAgB,QAU3B;AA8BD;;GAEG;AACH,IAAY,4BA8BX;AA9BD,WAAY,4BAA4B;IACtC;;OAEG;IACH,6CAAa,CAAA;IAEb;;OAEG;IACH,+CAAe,CAAA;IAEf;;OAEG;IACH,2CAAW,CAAA;IAEX;;OAEG;IACH,2CAAW,CAAA;IAEX;;SAEK;IACL,2CAAW,CAAA;IAEX;;SAEK;IACL,mDAAmB,CAAA;AACrB,CAAC,EA9BW,4BAA4B,4CAA5B,4BAA4B,QA8BvC","sourcesContent":["import type { Tag } from './metadata-schema';\n\n/**\n * Identifier for the context provider\n */\nexport enum ContextProvider {\n  /**\n   * AMI provider\n   */\n  AMI_PROVIDER = 'ami',\n\n  /**\n   * AZ provider\n   */\n  AVAILABILITY_ZONE_PROVIDER = 'availability-zones',\n\n  /**\n   * Route53 Hosted Zone provider\n   */\n  HOSTED_ZONE_PROVIDER = 'hosted-zone',\n\n  /**\n   * SSM Parameter Provider\n   */\n  SSM_PARAMETER_PROVIDER = 'ssm',\n\n  /**\n   * VPC Provider\n   */\n  VPC_PROVIDER = 'vpc-provider',\n\n  /**\n   * VPC Endpoint Service AZ Provider\n   */\n  ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = 'endpoint-service-availability-zones',\n\n  /**\n   * Load balancer provider\n   */\n  LOAD_BALANCER_PROVIDER = 'load-balancer',\n\n  /**\n   * Load balancer listener provider\n   */\n  LOAD_BALANCER_LISTENER_PROVIDER = 'load-balancer-listener',\n\n  /**\n   * Security group provider\n   */\n  SECURITY_GROUP_PROVIDER = 'security-group',\n\n  /**\n   * KMS Key Provider\n   */\n  KEY_PROVIDER = 'key-provider',\n\n  /**\n   * CCAPI Provider\n   */\n  CC_API_PROVIDER = 'cc-api-provider',\n\n  /**\n   * A plugin provider (the actual plugin name will be in the properties)\n   */\n  PLUGIN = 'plugin',\n}\n\n/**\n * Options for context lookup roles.\n */\nexport interface ContextLookupRoleOptions {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * The ExternalId that needs to be supplied while assuming this role\n   *\n   * @default - No ExternalId will be supplied\n   */\n  readonly lookupRoleExternalId?: string;\n\n  /**\n   * Additional options to pass to STS when assuming the lookup role.\n   *\n   * - `RoleArn` should not be used. Use the dedicated `lookupRoleArn` property instead.\n   * - `ExternalId` should not be used. Use the dedicated `lookupRoleExternalId` instead.\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n   * @default - No additional options.\n   */\n  readonly assumeRoleAdditionalOptions?: { [key: string]: any };\n}\n\n/**\n * Query to AMI context provider\n */\nexport interface AmiContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Owners to DescribeImages call\n   *\n   * @default - All owners\n   */\n  readonly owners?: string[];\n\n  /**\n   * Filters to DescribeImages call\n   */\n  readonly filters: { [key: string]: string[] };\n}\n\n/**\n * Query to availability zone context provider\n */\nexport interface AvailabilityZonesContextQuery extends ContextLookupRoleOptions {\n}\n\n/**\n * Query to hosted zone context provider\n */\nexport interface HostedZoneContextQuery extends ContextLookupRoleOptions {\n  /**\n   * The domain name e.g. example.com to lookup\n   */\n  readonly domainName: string;\n\n  /**\n   * True if the zone you want to find is a private hosted zone\n   *\n   * @default false\n   */\n  readonly privateZone?: boolean;\n\n  /**\n   * The VPC ID to that the private zone must be associated with\n   *\n   * If you provide VPC ID and privateZone is false, this will return no results\n   * and raise an error.\n   *\n   * @default - Required if privateZone=true\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query to SSM Parameter Context Provider\n */\nexport interface SSMParameterContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Parameter name to query\n   */\n  readonly parameterName: string;\n}\n\n/**\n * Query input for looking up a VPC\n */\nexport interface VpcContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Filters to apply to the VPC\n   *\n   * Filter parameters are the same as passed to DescribeVpcs.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeVpcs.html\n   */\n  readonly filter: { [key: string]: string };\n\n  /**\n   * Whether to populate the subnetGroups field of the `VpcContextResponse`,\n   * which contains potentially asymmetric subnet groups.\n   *\n   * @default false\n   */\n  readonly returnAsymmetricSubnets?: boolean;\n\n  /**\n   * Optional tag for subnet group name.\n   * If not provided, we'll look at the aws-cdk:subnet-name tag.\n   * If the subnet does not have the specified tag,\n   * we'll use its type as the name.\n   *\n   * @default 'aws-cdk:subnet-name'\n   */\n  readonly subnetGroupNameTag?: string;\n\n  /**\n   * Whether to populate the `vpnGatewayId` field of the `VpcContextResponse`,\n   * which contains the VPN Gateway ID, if one exists. You can explicitly\n   * disable this in order to avoid the lookup if you know the VPC does not have\n   * a VPN Gatway attached.\n   *\n   * @default true\n   */\n  readonly returnVpnGateways?: boolean;\n}\n\n/**\n * Query to endpoint service context provider\n */\nexport interface EndpointServiceAvailabilityZonesContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Query service name\n   */\n  readonly serviceName: string;\n}\n\n/**\n * Type of load balancer\n */\nexport enum LoadBalancerType {\n  /**\n   * Network load balancer\n   */\n  NETWORK = 'network',\n\n  /**\n   * Application load balancer\n   */\n  APPLICATION = 'application',\n}\n\n/**\n * Filters for selecting load balancers\n */\nexport interface LoadBalancerFilter extends ContextLookupRoleOptions {\n  /**\n   * Filter load balancers by their type\n   */\n  readonly loadBalancerType: LoadBalancerType;\n\n  /**\n   * Find by load balancer's ARN\n   * @default - does not search by load balancer arn\n   */\n  readonly loadBalancerArn?: string;\n\n  /**\n   * Match load balancer tags\n   * @default - does not match load balancers by tags\n   */\n  readonly loadBalancerTags?: Tag[];\n}\n\n/**\n * Query input for looking up a load balancer\n */\nexport interface LoadBalancerContextQuery extends LoadBalancerFilter {\n}\n\n/**\n * The protocol for connections from clients to the load balancer\n */\nexport enum LoadBalancerListenerProtocol {\n  /**\n   * HTTP protocol\n   */\n  HTTP = 'HTTP',\n\n  /**\n   * HTTPS protocol\n   */\n  HTTPS = 'HTTPS',\n\n  /**\n   * TCP protocol\n   */\n  TCP = 'TCP',\n\n  /**\n   * TLS protocol\n   */\n  TLS = 'TLS',\n\n  /**\n   * UDP protocol\n   * */\n  UDP = 'UDP',\n\n  /**\n   * TCP and UDP protocol\n   * */\n  TCP_UDP = 'TCP_UDP',\n}\n\n/**\n * Query input for looking up a load balancer listener\n */\nexport interface LoadBalancerListenerContextQuery extends LoadBalancerFilter {\n  /**\n   * Find by listener's arn\n   * @default - does not find by listener arn\n   */\n  readonly listenerArn?: string;\n\n  /**\n   * Filter by listener protocol\n   * @default - does not filter by listener protocol\n   */\n  readonly listenerProtocol?: LoadBalancerListenerProtocol;\n\n  /**\n   * Filter listeners by listener port\n   * @default - does not filter by a listener port\n   */\n  readonly listenerPort?: number;\n}\n\n/**\n * Query input for looking up a security group\n */\nexport interface SecurityGroupContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Security group id\n   *\n   * @default - None\n   */\n  readonly securityGroupId?: string;\n\n  /**\n   * Security group name\n   *\n   * @default - None\n   */\n  readonly securityGroupName?: string;\n\n  /**\n   * VPC ID\n   *\n   * @default - None\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query input for looking up a KMS Key\n */\nexport interface KeyContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Alias name used to search the Key\n   */\n  readonly aliasName: string;\n}\n\n/**\n * Query input for lookup up Cloudformation resources using CC API\n */\nexport interface CcApiContextQuery extends ContextLookupRoleOptions {\n  /**\n   * The Cloudformation resource type.\n   * See https://docs.aws.amazon.com/cloudcontrolapi/latest/userguide/supported-resources.html\n   */\n  readonly typeName: string;\n\n  /**\n   * Identifier of the resource to look up using `GetResource`.\n   *\n   * Specifying exactIdentifier will return exactly one result, or throw an error.\n   *\n   *\n   * @default - Either exactIdentifier or propertyMatch should be specified.\n   */\n  readonly exactIdentifier?: string;\n\n  /**\n   * Returns any resources matching these properties, using `ListResources`.\n   *\n   * Specifying propertyMatch will return 0 or more results.\n   *\n   * ## Notes on property completeness\n   *\n   * CloudControl API's `ListResources` may return fewer properties than\n   * `GetResource` would, depending on the resource implementation.\n   *\n   * The resources that `propertyMatch` matches against will *only ever* be the\n   * properties returned by the `ListResources` call.\n   *\n   * @default - Either exactIdentifier or propertyMatch should be specified.\n   */\n  readonly propertyMatch?: Record<string, unknown>;\n\n  /**\n   * This is a set of properties returned from CC API that we want to return from ContextQuery.\n   *\n   * If any properties listed here are absent from the target resource, an error will be thrown.\n   *\n   * The returned object will always include the key `Identifier` with the CC-API returned\n   * field `Identifier`.\n   *\n   * ## Notes on property completeness\n   *\n   * CloudControl API's `ListResources` may return fewer properties than\n   * `GetResource` would, depending on the resource implementation.\n   *\n   * The returned properties here are *currently* selected from the response\n   * object that CloudControl API returns to the CDK CLI.\n   *\n   * However, if we find there is need to do so, we may decide to change this\n   * behavior in the future: we might change it to perform an additional\n   * `GetResource` call for resources matched by `propertyMatch`.\n   */\n  readonly propertiesToReturn: string[];\n\n  /**\n   * The value to return if the resource was not found and `ignoreErrorOnMissingContext` is true.\n   *\n   * If supplied, `dummyValue` should be an array of objects.\n   *\n   * `dummyValue` does not have to have elements, and it may have objects with\n   * different properties than the properties in `propertiesToReturn`, but it\n   * will be easiest for downstream code if the `dummyValue` conforms to\n   * the expected response shape.\n   *\n   * @default - No dummy value available\n   */\n  readonly dummyValue?: any;\n\n  /**\n   * Ignore an error and return the `dummyValue` instead if the resource was not found.\n   *\n   * - In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with\n   *   that identifier was not found.\n   * - In case of a `propertyMatch` lookup, this setting currently does not have any effect,\n   *   as `propertyMatch` queries can legally return 0 resources.\n   *\n   * if `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.\n   *\n   * @default false\n   */\n  readonly ignoreErrorOnMissingContext?: boolean;\n}\n\n/**\n * Query input for plugins\n *\n * This alternate branch is necessary because it needs to be able to escape all type checking\n * we do on on the cloud assembly -- we cannot know the properties that will be used a priori.\n */\nexport interface PluginContextQuery {\n  /**\n   * The name of the plugin\n   */\n  readonly pluginName: string;\n\n  /**\n   * Arbitrary other arguments for the plugin.\n   *\n   * This index signature is not usable in non-TypeScript/JavaScript languages.\n   *\n   * @jsii ignore\n   */\n  [key: string]: any;\n}\n\nexport type ContextQueryProperties =\n  | AmiContextQuery\n  | AvailabilityZonesContextQuery\n  | HostedZoneContextQuery\n  | SSMParameterContextQuery\n  | VpcContextQuery\n  | EndpointServiceAvailabilityZonesContextQuery\n  | LoadBalancerContextQuery\n  | LoadBalancerListenerContextQuery\n  | SecurityGroupContextQuery\n  | KeyContextQuery\n  | CcApiContextQuery\n  | PluginContextQuery;\n"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-queries.js","sourceRoot":"","sources":["context-queries.ts"],"names":[],"mappings":";;;AAEA;;GAEG;AACH,IAAY,eA4DX;AA5DD,WAAY,eAAe;IACzB;;OAEG;IACH,uCAAoB,CAAA;IAEpB;;OAEG;IACH,oEAAiD,CAAA;IAEjD;;OAEG;IACH,uDAAoC,CAAA;IAEpC;;OAEG;IACH,iDAA8B,CAAA;IAE9B;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,sGAAmF,CAAA;IAEnF;;OAEG;IACH,2DAAwC,CAAA;IAExC;;OAEG;IACH,6EAA0D,CAAA;IAE1D;;OAEG;IACH,6DAA0C,CAAA;IAE1C;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,sDAAmC,CAAA;IAEnC;;OAEG;IACH,oCAAiB,CAAA;AACnB,CAAC,EA5DW,eAAe,+BAAf,eAAe,QA4D1B;AA0JD;;GAEG;AACH,IAAY,gBAUX;AAVD,WAAY,gBAAgB;IAC1B;;OAEG;IACH,uCAAmB,CAAA;IAEnB;;OAEG;IACH,+CAA2B,CAAA;AAC7B,CAAC,EAVW,gBAAgB,gCAAhB,gBAAgB,QAU3B;AA8BD;;GAEG;AACH,IAAY,4BA8BX;AA9BD,WAAY,4BAA4B;IACtC;;OAEG;IACH,6CAAa,CAAA;IAEb;;OAEG;IACH,+CAAe,CAAA;IAEf;;OAEG;IACH,2CAAW,CAAA;IAEX;;OAEG;IACH,2CAAW,CAAA;IAEX;;SAEK;IACL,2CAAW,CAAA;IAEX;;SAEK;IACL,mDAAmB,CAAA;AACrB,CAAC,EA9BW,4BAA4B,4CAA5B,4BAA4B,QA8BvC","sourcesContent":["import type { Tag } from './metadata-schema';\n\n/**\n * Identifier for the context provider\n */\nexport enum ContextProvider {\n  /**\n   * AMI provider\n   */\n  AMI_PROVIDER = 'ami',\n\n  /**\n   * AZ provider\n   */\n  AVAILABILITY_ZONE_PROVIDER = 'availability-zones',\n\n  /**\n   * Route53 Hosted Zone provider\n   */\n  HOSTED_ZONE_PROVIDER = 'hosted-zone',\n\n  /**\n   * SSM Parameter Provider\n   */\n  SSM_PARAMETER_PROVIDER = 'ssm',\n\n  /**\n   * VPC Provider\n   */\n  VPC_PROVIDER = 'vpc-provider',\n\n  /**\n   * VPC Endpoint Service AZ Provider\n   */\n  ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = 'endpoint-service-availability-zones',\n\n  /**\n   * Load balancer provider\n   */\n  LOAD_BALANCER_PROVIDER = 'load-balancer',\n\n  /**\n   * Load balancer listener provider\n   */\n  LOAD_BALANCER_LISTENER_PROVIDER = 'load-balancer-listener',\n\n  /**\n   * Security group provider\n   */\n  SECURITY_GROUP_PROVIDER = 'security-group',\n\n  /**\n   * KMS Key Provider\n   */\n  KEY_PROVIDER = 'key-provider',\n\n  /**\n   * CCAPI Provider\n   */\n  CC_API_PROVIDER = 'cc-api-provider',\n\n  /**\n   * A plugin provider (the actual plugin name will be in the properties)\n   */\n  PLUGIN = 'plugin',\n}\n\n/**\n * Options for context lookup roles.\n */\nexport interface ContextLookupRoleOptions {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * The ExternalId that needs to be supplied while assuming this role\n   *\n   * @default - No ExternalId will be supplied\n   */\n  readonly lookupRoleExternalId?: string;\n\n  /**\n   * Additional options to pass to STS when assuming the lookup role.\n   *\n   * - `RoleArn` should not be used. Use the dedicated `lookupRoleArn` property instead.\n   * - `ExternalId` should not be used. Use the dedicated `lookupRoleExternalId` instead.\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n   * @default - No additional options.\n   */\n  readonly assumeRoleAdditionalOptions?: { [key: string]: any };\n}\n\n/**\n * Query to AMI context provider\n */\nexport interface AmiContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Owners to DescribeImages call\n   *\n   * @default - All owners\n   */\n  readonly owners?: string[];\n\n  /**\n   * Filters to DescribeImages call\n   */\n  readonly filters: { [key: string]: string[] };\n}\n\n/**\n * Query to availability zone context provider\n */\nexport interface AvailabilityZonesContextQuery extends ContextLookupRoleOptions {\n}\n\n/**\n * Query to hosted zone context provider\n */\nexport interface HostedZoneContextQuery extends ContextLookupRoleOptions {\n  /**\n   * The domain name e.g. example.com to lookup\n   */\n  readonly domainName: string;\n\n  /**\n   * True if the zone you want to find is a private hosted zone\n   *\n   * @default false\n   */\n  readonly privateZone?: boolean;\n\n  /**\n   * The VPC ID to that the private zone must be associated with\n   *\n   * If you provide VPC ID and privateZone is false, this will return no results\n   * and raise an error.\n   *\n   * @default - Required if privateZone=true\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query to SSM Parameter Context Provider\n */\nexport interface SSMParameterContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Parameter name to query\n   */\n  readonly parameterName: string;\n}\n\n/**\n * Query input for looking up a VPC\n */\nexport interface VpcContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Filters to apply to the VPC\n   *\n   * Filter parameters are the same as passed to DescribeVpcs.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeVpcs.html\n   */\n  readonly filter: { [key: string]: string };\n\n  /**\n   * Whether to populate the subnetGroups field of the `VpcContextResponse`,\n   * which contains potentially asymmetric subnet groups.\n   *\n   * @default false\n   */\n  readonly returnAsymmetricSubnets?: boolean;\n\n  /**\n   * Optional tag for subnet group name.\n   * If not provided, we'll look at the aws-cdk:subnet-name tag.\n   * If the subnet does not have the specified tag,\n   * we'll use its type as the name.\n   *\n   * @default 'aws-cdk:subnet-name'\n   */\n  readonly subnetGroupNameTag?: string;\n\n  /**\n   * Whether to populate the `vpnGatewayId` field of the `VpcContextResponse`,\n   * which contains the VPN Gateway ID, if one exists. You can explicitly\n   * disable this in order to avoid the lookup if you know the VPC does not have\n   * a VPN Gatway attached.\n   *\n   * @default true\n   */\n  readonly returnVpnGateways?: boolean;\n}\n\n/**\n * Query to endpoint service context provider\n */\nexport interface EndpointServiceAvailabilityZonesContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Query service name\n   */\n  readonly serviceName: string;\n}\n\n/**\n * Type of load balancer\n */\nexport enum LoadBalancerType {\n  /**\n   * Network load balancer\n   */\n  NETWORK = 'network',\n\n  /**\n   * Application load balancer\n   */\n  APPLICATION = 'application',\n}\n\n/**\n * Filters for selecting load balancers\n */\nexport interface LoadBalancerFilter extends ContextLookupRoleOptions {\n  /**\n   * Filter load balancers by their type\n   */\n  readonly loadBalancerType: LoadBalancerType;\n\n  /**\n   * Find by load balancer's ARN\n   * @default - does not search by load balancer arn\n   */\n  readonly loadBalancerArn?: string;\n\n  /**\n   * Match load balancer tags\n   * @default - does not match load balancers by tags\n   */\n  readonly loadBalancerTags?: Tag[];\n}\n\n/**\n * Query input for looking up a load balancer\n */\nexport interface LoadBalancerContextQuery extends LoadBalancerFilter {\n}\n\n/**\n * The protocol for connections from clients to the load balancer\n */\nexport enum LoadBalancerListenerProtocol {\n  /**\n   * HTTP protocol\n   */\n  HTTP = 'HTTP',\n\n  /**\n   * HTTPS protocol\n   */\n  HTTPS = 'HTTPS',\n\n  /**\n   * TCP protocol\n   */\n  TCP = 'TCP',\n\n  /**\n   * TLS protocol\n   */\n  TLS = 'TLS',\n\n  /**\n   * UDP protocol\n   * */\n  UDP = 'UDP',\n\n  /**\n   * TCP and UDP protocol\n   * */\n  TCP_UDP = 'TCP_UDP',\n}\n\n/**\n * Query input for looking up a load balancer listener\n */\nexport interface LoadBalancerListenerContextQuery extends LoadBalancerFilter {\n  /**\n   * Find by listener's arn\n   * @default - does not find by listener arn\n   */\n  readonly listenerArn?: string;\n\n  /**\n   * Filter by listener protocol\n   * @default - does not filter by listener protocol\n   */\n  readonly listenerProtocol?: LoadBalancerListenerProtocol;\n\n  /**\n   * Filter listeners by listener port\n   * @default - does not filter by a listener port\n   */\n  readonly listenerPort?: number;\n}\n\n/**\n * Query input for looking up a security group\n */\nexport interface SecurityGroupContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Security group id\n   *\n   * @default - None\n   */\n  readonly securityGroupId?: string;\n\n  /**\n   * Security group name\n   *\n   * @default - None\n   */\n  readonly securityGroupName?: string;\n\n  /**\n   * VPC ID\n   *\n   * @default - None\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query input for looking up a KMS Key\n */\nexport interface KeyContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Alias name used to search the Key\n   */\n  readonly aliasName: string;\n}\n\n/**\n * Query input for lookup up CloudFormation resources using CC API\n */\nexport interface CcApiContextQuery extends ContextLookupRoleOptions {\n  /**\n   * The CloudFormation resource type.\n   * See https://docs.aws.amazon.com/cloudcontrolapi/latest/userguide/supported-resources.html\n   */\n  readonly typeName: string;\n\n  /**\n   * Identifier of the resource to look up using `GetResource`.\n   *\n   * Specifying exactIdentifier will return exactly one result, or throw an error\n   * unless `ignoreErrorOnMissingContext` is set.\n   *\n   * @default - Either exactIdentifier or propertyMatch should be specified.\n   */\n  readonly exactIdentifier?: string;\n\n  /**\n   * Returns any resources matching these properties, using `ListResources`.\n   *\n   * By default, specifying propertyMatch will successfully return 0 or more\n   * results. To throw an error if the number of results is unexpected (and\n   * prevent the query results from being committed to context), specify\n   * `expectedMatchCount`.\n   *\n   * ## Notes on property completeness\n   *\n   * CloudControl API's `ListResources` may return fewer properties than\n   * `GetResource` would, depending on the resource implementation.\n   *\n   * The resources that `propertyMatch` matches against will *only ever* be the\n   * properties returned by the `ListResources` call.\n   *\n   * @default - Either exactIdentifier or propertyMatch should be specified.\n   */\n  readonly propertyMatch?: Record<string, unknown>;\n\n  /**\n   * This is a set of properties returned from CC API that we want to return from ContextQuery.\n   *\n   * If any properties listed here are absent from the target resource, an error will be thrown.\n   *\n   * The returned object will always include the key `Identifier` with the CC-API returned\n   * field `Identifier`.\n   *\n   * ## Notes on property completeness\n   *\n   * CloudControl API's `ListResources` may return fewer properties than\n   * `GetResource` would, depending on the resource implementation.\n   *\n   * The returned properties here are *currently* selected from the response\n   * object that CloudControl API returns to the CDK CLI.\n   *\n   * However, if we find there is need to do so, we may decide to change this\n   * behavior in the future: we might change it to perform an additional\n   * `GetResource` call for resources matched by `propertyMatch`.\n   */\n  readonly propertiesToReturn: string[];\n\n  /**\n   * Expected count of results if `propertyMatch` is specified.\n   *\n   * If the expected result count does not match the actual count,\n   * by default an error is produced and the result is not committed to cached\n   * context, and the user can correct the situation and try again without\n   * having to manually clear out the context key using `cdk context --remove`\n   *\n   * If the value of * `ignoreErrorOnMissingContext` is `true`, the value of\n   * `expectedMatchCount` is `at-least-one | exactly-one` and the number\n   * of found resources is 0, `dummyValue` is returned and committed to context\n   * instead.\n   *\n   * @default 'any'\n   */\n  readonly expectedMatchCount?: 'any' | 'at-least-one' | 'at-most-one' | 'exactly-one';\n\n  /**\n   * The value to return if the resource was not found and `ignoreErrorOnMissingContext` is true.\n   *\n   * If supplied, `dummyValue` should be an array of objects.\n   *\n   * `dummyValue` does not have to have elements, and it may have objects with\n   * different properties than the properties in `propertiesToReturn`, but it\n   * will be easiest for downstream code if the `dummyValue` conforms to\n   * the expected response shape.\n   *\n   * @default - No dummy value available\n   */\n  readonly dummyValue?: any;\n\n  /**\n   * Ignore an error and return the `dummyValue` instead if the resource was not found.\n   *\n   * - In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with\n   *   that identifier was not found.\n   * - In case of a `propertyMatch` lookup, return the `dummyValue` if `expectedMatchCount`\n   *   is `at-least-one | exactly-one` and the number of resources found was 0.\n   *\n   * if `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.\n   *\n   * @default false\n   */\n  readonly ignoreErrorOnMissingContext?: boolean;\n}\n\n/**\n * Query input for plugins\n *\n * This alternate branch is necessary because it needs to be able to escape all type checking\n * we do on on the cloud assembly -- we cannot know the properties that will be used a priori.\n */\nexport interface PluginContextQuery {\n  /**\n   * The name of the plugin\n   */\n  readonly pluginName: string;\n\n  /**\n   * Arbitrary other arguments for the plugin.\n   *\n   * This index signature is not usable in non-TypeScript/JavaScript languages.\n   *\n   * @jsii ignore\n   */\n  [key: string]: any;\n}\n\nexport type ContextQueryProperties =\n  | AmiContextQuery\n  | AvailabilityZonesContextQuery\n  | HostedZoneContextQuery\n  | SSMParameterContextQuery\n  | VpcContextQuery\n  | EndpointServiceAvailabilityZonesContextQuery\n  | LoadBalancerContextQuery\n  | LoadBalancerListenerContextQuery\n  | SecurityGroupContextQuery\n  | KeyContextQuery\n  | CcApiContextQuery\n  | PluginContextQuery;\n"]}
package/lib/manifest.js CHANGED
@@ -269,7 +269,7 @@ class Manifest {
269
269
  }
270
270
  exports.Manifest = Manifest;
271
271
  _a = JSII_RTTI_SYMBOL_1;
272
- Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "42.0.0" };
272
+ Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "43.0.0" };
273
273
  function mapValues(xs, fn) {
274
274
  if (!xs) {
275
275
  return undefined;
package/package.json CHANGED
@@ -42,18 +42,18 @@
42
42
  "@stylistic/eslint-plugin": "^3",
43
43
  "@types/jest": "^29.5.14",
44
44
  "@types/node": "^16",
45
- "@types/semver": "^7.5.8",
45
+ "@types/semver": "^7.7.0",
46
46
  "@typescript-eslint/eslint-plugin": "^8",
47
47
  "@typescript-eslint/parser": "^8",
48
48
  "commit-and-tag-version": "^12",
49
49
  "constructs": "^10.0.0",
50
50
  "eslint": "^9",
51
51
  "eslint-config-prettier": "^10.1.1",
52
- "eslint-import-resolver-typescript": "^3.9.1",
52
+ "eslint-import-resolver-typescript": "^3.10.0",
53
53
  "eslint-plugin-import": "^2.31.0",
54
54
  "eslint-plugin-jest": "^28.11.0",
55
55
  "eslint-plugin-jsdoc": "^50.6.9",
56
- "eslint-plugin-prettier": "^5.2.3",
56
+ "eslint-plugin-prettier": "^5.2.5",
57
57
  "jest": "^29.7.0",
58
58
  "jest-junit": "^16",
59
59
  "jsii": "5.6",
@@ -64,7 +64,7 @@
64
64
  "mock-fs": "^5.5.0",
65
65
  "prettier": "^2.8",
66
66
  "projen": "^0.91.18",
67
- "ts-jest": "^29.2.6",
67
+ "ts-jest": "^29.3.0",
68
68
  "tsx": "^4.19.3",
69
69
  "typescript": "5.6",
70
70
  "typescript-json-schema": "^0.65.1"
@@ -90,7 +90,7 @@
90
90
  "publishConfig": {
91
91
  "access": "public"
92
92
  },
93
- "version": "42.0.0",
93
+ "version": "43.0.0",
94
94
  "types": "lib/index.d.ts",
95
95
  "stability": "stable",
96
96
  "jsii": {
@@ -1024,19 +1024,19 @@
1024
1024
  ]
1025
1025
  },
1026
1026
  "CcApiContextQuery": {
1027
- "description": "Query input for lookup up Cloudformation resources using CC API",
1027
+ "description": "Query input for lookup up CloudFormation resources using CC API",
1028
1028
  "type": "object",
1029
1029
  "properties": {
1030
1030
  "typeName": {
1031
- "description": "The Cloudformation resource type.\nSee https://docs.aws.amazon.com/cloudcontrolapi/latest/userguide/supported-resources.html",
1031
+ "description": "The CloudFormation resource type.\nSee https://docs.aws.amazon.com/cloudcontrolapi/latest/userguide/supported-resources.html",
1032
1032
  "type": "string"
1033
1033
  },
1034
1034
  "exactIdentifier": {
1035
- "description": "Identifier of the resource to look up using `GetResource`.\n\nSpecifying exactIdentifier will return exactly one result, or throw an error. (Default - Either exactIdentifier or propertyMatch should be specified.)",
1035
+ "description": "Identifier of the resource to look up using `GetResource`.\n\nSpecifying exactIdentifier will return exactly one result, or throw an error\nunless `ignoreErrorOnMissingContext` is set. (Default - Either exactIdentifier or propertyMatch should be specified.)",
1036
1036
  "type": "string"
1037
1037
  },
1038
1038
  "propertyMatch": {
1039
- "description": "Returns any resources matching these properties, using `ListResources`.\n\nSpecifying propertyMatch will return 0 or more results.\n\n## Notes on property completeness\n\nCloudControl API's `ListResources` may return fewer properties than\n`GetResource` would, depending on the resource implementation.\n\nThe resources that `propertyMatch` matches against will *only ever* be the\nproperties returned by the `ListResources` call. (Default - Either exactIdentifier or propertyMatch should be specified.)",
1039
+ "description": "Returns any resources matching these properties, using `ListResources`.\n\nBy default, specifying propertyMatch will successfully return 0 or more\nresults. To throw an error if the number of results is unexpected (and\nprevent the query results from being committed to context), specify\n`expectedMatchCount`.\n\n## Notes on property completeness\n\nCloudControl API's `ListResources` may return fewer properties than\n`GetResource` would, depending on the resource implementation.\n\nThe resources that `propertyMatch` matches against will *only ever* be the\nproperties returned by the `ListResources` call. (Default - Either exactIdentifier or propertyMatch should be specified.)",
1040
1040
  "$ref": "#/definitions/Record<string,unknown>"
1041
1041
  },
1042
1042
  "propertiesToReturn": {
@@ -1046,11 +1046,21 @@
1046
1046
  "type": "string"
1047
1047
  }
1048
1048
  },
1049
+ "expectedMatchCount": {
1050
+ "description": "Expected count of results if `propertyMatch` is specified.\n\nIf the expected result count does not match the actual count,\nby default an error is produced and the result is not committed to cached\ncontext, and the user can correct the situation and try again without\nhaving to manually clear out the context key using `cdk context --remove`\n\nIf the value of * `ignoreErrorOnMissingContext` is `true`, the value of\n`expectedMatchCount` is `at-least-one | exactly-one` and the number\nof found resources is 0, `dummyValue` is returned and committed to context\ninstead. (Default 'any')",
1051
+ "enum": [
1052
+ "any",
1053
+ "at-least-one",
1054
+ "at-most-one",
1055
+ "exactly-one"
1056
+ ],
1057
+ "type": "string"
1058
+ },
1049
1059
  "dummyValue": {
1050
1060
  "description": "The value to return if the resource was not found and `ignoreErrorOnMissingContext` is true.\n\nIf supplied, `dummyValue` should be an array of objects.\n\n`dummyValue` does not have to have elements, and it may have objects with\ndifferent properties than the properties in `propertiesToReturn`, but it\nwill be easiest for downstream code if the `dummyValue` conforms to\nthe expected response shape. (Default - No dummy value available)"
1051
1061
  },
1052
1062
  "ignoreErrorOnMissingContext": {
1053
- "description": "Ignore an error and return the `dummyValue` instead if the resource was not found.\n\n- In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with\n that identifier was not found.\n- In case of a `propertyMatch` lookup, this setting currently does not have any effect,\n as `propertyMatch` queries can legally return 0 resources.\n\nif `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.",
1063
+ "description": "Ignore an error and return the `dummyValue` instead if the resource was not found.\n\n- In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with\n that identifier was not found.\n- In case of a `propertyMatch` lookup, return the `dummyValue` if `expectedMatchCount`\n is `at-least-one | exactly-one` and the number of resources found was 0.\n\nif `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.",
1054
1064
  "default": false,
1055
1065
  "type": "boolean"
1056
1066
  },
@@ -1,4 +1,4 @@
1
1
  {
2
- "schemaHash": "5683db246fac20b864d94d7bceef24ebda1a38c8c1f8ef0d5978534097dc9504",
3
- "revision": 42
2
+ "schemaHash": "78936b0f9299bbe47497dd77f8065d71e65d8d739a0413ad7698ad03b22ef83e",
3
+ "revision": 43
4
4
  }