@aws-cdk/cloud-assembly-schema 41.2.0 → 42.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.
|
|
19
|
+
"jsiiVersion": "5.6.13 (build 629499a)",
|
|
20
20
|
"keywords": [
|
|
21
21
|
"aws",
|
|
22
22
|
"cdk"
|
|
@@ -1254,13 +1254,14 @@
|
|
|
1254
1254
|
{
|
|
1255
1255
|
"abstract": true,
|
|
1256
1256
|
"docs": {
|
|
1257
|
+
"remarks": "If any properties listed here are absent from the target resource, an error will be thrown.\n\nThe returned object will always include the key `Identifier` with the CC-API returned\nfield `Identifier`.\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 returned properties here are *currently* selected from the response\nobject that CloudControl API returns to the CDK CLI.\n\nHowever, if we find there is need to do so, we may decide to change this\nbehavior in the future: we might change it to perform an additional\n`GetResource` call for resources matched by `propertyMatch`.",
|
|
1257
1258
|
"stability": "stable",
|
|
1258
1259
|
"summary": "This is a set of properties returned from CC API that we want to return from ContextQuery."
|
|
1259
1260
|
},
|
|
1260
1261
|
"immutable": true,
|
|
1261
1262
|
"locationInModule": {
|
|
1262
1263
|
"filename": "lib/cloud-assembly/context-queries.ts",
|
|
1263
|
-
"line":
|
|
1264
|
+
"line": 414
|
|
1264
1265
|
},
|
|
1265
1266
|
"name": "propertiesToReturn",
|
|
1266
1267
|
"type": {
|
|
@@ -1292,15 +1293,34 @@
|
|
|
1292
1293
|
{
|
|
1293
1294
|
"abstract": true,
|
|
1294
1295
|
"docs": {
|
|
1295
|
-
"default": "-
|
|
1296
|
-
"remarks": "
|
|
1296
|
+
"default": "- No dummy value available",
|
|
1297
|
+
"remarks": "If 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.",
|
|
1297
1298
|
"stability": "stable",
|
|
1298
|
-
"summary": "
|
|
1299
|
+
"summary": "The value to return if the resource was not found and `ignoreErrorOnMissingContext` is true."
|
|
1299
1300
|
},
|
|
1300
1301
|
"immutable": true,
|
|
1301
1302
|
"locationInModule": {
|
|
1302
1303
|
"filename": "lib/cloud-assembly/context-queries.ts",
|
|
1303
|
-
"line":
|
|
1304
|
+
"line": 428
|
|
1305
|
+
},
|
|
1306
|
+
"name": "dummyValue",
|
|
1307
|
+
"optional": true,
|
|
1308
|
+
"type": {
|
|
1309
|
+
"primitive": "any"
|
|
1310
|
+
}
|
|
1311
|
+
},
|
|
1312
|
+
{
|
|
1313
|
+
"abstract": true,
|
|
1314
|
+
"docs": {
|
|
1315
|
+
"default": "- Either exactIdentifier or propertyMatch should be specified.",
|
|
1316
|
+
"remarks": "Specifying exactIdentifier will return exactly one result, or throw an error.",
|
|
1317
|
+
"stability": "stable",
|
|
1318
|
+
"summary": "Identifier of the resource to look up using `GetResource`."
|
|
1319
|
+
},
|
|
1320
|
+
"immutable": true,
|
|
1321
|
+
"locationInModule": {
|
|
1322
|
+
"filename": "lib/cloud-assembly/context-queries.ts",
|
|
1323
|
+
"line": 375
|
|
1304
1324
|
},
|
|
1305
1325
|
"name": "exactIdentifier",
|
|
1306
1326
|
"optional": true,
|
|
@@ -1311,15 +1331,34 @@
|
|
|
1311
1331
|
{
|
|
1312
1332
|
"abstract": true,
|
|
1313
1333
|
"docs": {
|
|
1314
|
-
"default": "
|
|
1315
|
-
"remarks": "
|
|
1334
|
+
"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.",
|
|
1336
|
+
"stability": "stable",
|
|
1337
|
+
"summary": "Ignore an error and return the `dummyValue` instead if the resource was not found."
|
|
1338
|
+
},
|
|
1339
|
+
"immutable": true,
|
|
1340
|
+
"locationInModule": {
|
|
1341
|
+
"filename": "lib/cloud-assembly/context-queries.ts",
|
|
1342
|
+
"line": 442
|
|
1343
|
+
},
|
|
1344
|
+
"name": "ignoreErrorOnMissingContext",
|
|
1345
|
+
"optional": true,
|
|
1346
|
+
"type": {
|
|
1347
|
+
"primitive": "boolean"
|
|
1348
|
+
}
|
|
1349
|
+
},
|
|
1350
|
+
{
|
|
1351
|
+
"abstract": true,
|
|
1352
|
+
"docs": {
|
|
1353
|
+
"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.",
|
|
1316
1355
|
"stability": "stable",
|
|
1317
|
-
"summary": "
|
|
1356
|
+
"summary": "Returns any resources matching these properties, using `ListResources`."
|
|
1318
1357
|
},
|
|
1319
1358
|
"immutable": true,
|
|
1320
1359
|
"locationInModule": {
|
|
1321
1360
|
"filename": "lib/cloud-assembly/context-queries.ts",
|
|
1322
|
-
"line":
|
|
1361
|
+
"line": 392
|
|
1323
1362
|
},
|
|
1324
1363
|
"name": "propertyMatch",
|
|
1325
1364
|
"optional": true,
|
|
@@ -5102,7 +5141,7 @@
|
|
|
5102
5141
|
"kind": "interface",
|
|
5103
5142
|
"locationInModule": {
|
|
5104
5143
|
"filename": "lib/cloud-assembly/context-queries.ts",
|
|
5105
|
-
"line":
|
|
5144
|
+
"line": 451
|
|
5106
5145
|
},
|
|
5107
5146
|
"name": "PluginContextQuery",
|
|
5108
5147
|
"properties": [
|
|
@@ -5115,7 +5154,7 @@
|
|
|
5115
5154
|
"immutable": true,
|
|
5116
5155
|
"locationInModule": {
|
|
5117
5156
|
"filename": "lib/cloud-assembly/context-queries.ts",
|
|
5118
|
-
"line":
|
|
5157
|
+
"line": 455
|
|
5119
5158
|
},
|
|
5120
5159
|
"name": "pluginName",
|
|
5121
5160
|
"type": {
|
|
@@ -5719,6 +5758,6 @@
|
|
|
5719
5758
|
"symbolId": "lib/cloud-assembly/context-queries:VpcContextQuery"
|
|
5720
5759
|
}
|
|
5721
5760
|
},
|
|
5722
|
-
"version": "
|
|
5723
|
-
"fingerprint": "
|
|
5761
|
+
"version": "42.0.0",
|
|
5762
|
+
"fingerprint": "BL5pRq7R15nJdxKtzs57jDdVk8bMEmotECKuxsZl67s="
|
|
5724
5763
|
}
|
package/cli-version.json
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":"2.
|
|
1
|
+
{"version":"2.1006.0"}
|
|
@@ -321,24 +321,77 @@ export interface CcApiContextQuery extends ContextLookupRoleOptions {
|
|
|
321
321
|
*/
|
|
322
322
|
readonly typeName: string;
|
|
323
323
|
/**
|
|
324
|
-
*
|
|
325
|
-
*
|
|
326
|
-
*
|
|
327
|
-
*
|
|
324
|
+
* Identifier of the resource to look up using `GetResource`.
|
|
325
|
+
*
|
|
326
|
+
* Specifying exactIdentifier will return exactly one result, or throw an error.
|
|
327
|
+
*
|
|
328
|
+
*
|
|
329
|
+
* @default - Either exactIdentifier or propertyMatch should be specified.
|
|
328
330
|
*/
|
|
329
331
|
readonly exactIdentifier?: string;
|
|
330
332
|
/**
|
|
331
|
-
*
|
|
332
|
-
*
|
|
333
|
+
* Returns any resources matching these properties, using `ListResources`.
|
|
334
|
+
*
|
|
333
335
|
* Specifying propertyMatch will return 0 or more results.
|
|
334
|
-
*
|
|
335
|
-
*
|
|
336
|
+
*
|
|
337
|
+
* ## Notes on property completeness
|
|
338
|
+
*
|
|
339
|
+
* CloudControl API's `ListResources` may return fewer properties than
|
|
340
|
+
* `GetResource` would, depending on the resource implementation.
|
|
341
|
+
*
|
|
342
|
+
* The resources that `propertyMatch` matches against will *only ever* be the
|
|
343
|
+
* properties returned by the `ListResources` call.
|
|
344
|
+
*
|
|
345
|
+
* @default - Either exactIdentifier or propertyMatch should be specified.
|
|
336
346
|
*/
|
|
337
347
|
readonly propertyMatch?: Record<string, unknown>;
|
|
338
348
|
/**
|
|
339
349
|
* This is a set of properties returned from CC API that we want to return from ContextQuery.
|
|
350
|
+
*
|
|
351
|
+
* If any properties listed here are absent from the target resource, an error will be thrown.
|
|
352
|
+
*
|
|
353
|
+
* The returned object will always include the key `Identifier` with the CC-API returned
|
|
354
|
+
* field `Identifier`.
|
|
355
|
+
*
|
|
356
|
+
* ## Notes on property completeness
|
|
357
|
+
*
|
|
358
|
+
* CloudControl API's `ListResources` may return fewer properties than
|
|
359
|
+
* `GetResource` would, depending on the resource implementation.
|
|
360
|
+
*
|
|
361
|
+
* The returned properties here are *currently* selected from the response
|
|
362
|
+
* object that CloudControl API returns to the CDK CLI.
|
|
363
|
+
*
|
|
364
|
+
* However, if we find there is need to do so, we may decide to change this
|
|
365
|
+
* behavior in the future: we might change it to perform an additional
|
|
366
|
+
* `GetResource` call for resources matched by `propertyMatch`.
|
|
340
367
|
*/
|
|
341
368
|
readonly propertiesToReturn: string[];
|
|
369
|
+
/**
|
|
370
|
+
* The value to return if the resource was not found and `ignoreErrorOnMissingContext` is true.
|
|
371
|
+
*
|
|
372
|
+
* If supplied, `dummyValue` should be an array of objects.
|
|
373
|
+
*
|
|
374
|
+
* `dummyValue` does not have to have elements, and it may have objects with
|
|
375
|
+
* different properties than the properties in `propertiesToReturn`, but it
|
|
376
|
+
* will be easiest for downstream code if the `dummyValue` conforms to
|
|
377
|
+
* the expected response shape.
|
|
378
|
+
*
|
|
379
|
+
* @default - No dummy value available
|
|
380
|
+
*/
|
|
381
|
+
readonly dummyValue?: any;
|
|
382
|
+
/**
|
|
383
|
+
* Ignore an error and return the `dummyValue` instead if the resource was not found.
|
|
384
|
+
*
|
|
385
|
+
* - In case of an `exactIdentifier` lookup, return the `dummyValue` if the resource with
|
|
386
|
+
* 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.
|
|
389
|
+
*
|
|
390
|
+
* if `ignoreErrorOnMissingContext` is set, `dummyValue` should be set and be an array.
|
|
391
|
+
*
|
|
392
|
+
* @default false
|
|
393
|
+
*/
|
|
394
|
+
readonly ignoreErrorOnMissingContext?: boolean;
|
|
342
395
|
}
|
|
343
396
|
/**
|
|
344
397
|
* Query input for plugins
|
|
@@ -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   * exactIdentifier of the resource.\n   * Specifying exactIdentifier will return at most one result.\n   * Either exactIdentifier or propertyMatch should be specified.\n   * @default - None\n   */\n  readonly exactIdentifier?: string;\n\n  /**\n   * This indicates the property to search for.\n   * If both exactIdentifier and propertyMatch are specified, then exactIdentifier is used.\n   * Specifying propertyMatch will return 0 or more results.\n   * Either exactIdentifier or propertyMatch should be specified.\n   * @default - None\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  readonly propertiesToReturn: string[];\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   *\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"]}
|
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: "
|
|
272
|
+
Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "42.0.0" };
|
|
273
273
|
function mapValues(xs, fn) {
|
|
274
274
|
if (!xs) {
|
|
275
275
|
return undefined;
|
package/package.json
CHANGED
|
@@ -39,7 +39,7 @@
|
|
|
39
39
|
},
|
|
40
40
|
"devDependencies": {
|
|
41
41
|
"@cdklabs/eslint-plugin": "^1.3.2",
|
|
42
|
-
"@stylistic/eslint-plugin": "^3
|
|
42
|
+
"@stylistic/eslint-plugin": "^3",
|
|
43
43
|
"@types/jest": "^29.5.14",
|
|
44
44
|
"@types/node": "^16",
|
|
45
45
|
"@types/semver": "^7.5.8",
|
|
@@ -48,22 +48,22 @@
|
|
|
48
48
|
"commit-and-tag-version": "^12",
|
|
49
49
|
"constructs": "^10.0.0",
|
|
50
50
|
"eslint": "^9",
|
|
51
|
-
"eslint-config-prettier": "^10.
|
|
52
|
-
"eslint-import-resolver-typescript": "^3.
|
|
51
|
+
"eslint-config-prettier": "^10.1.1",
|
|
52
|
+
"eslint-import-resolver-typescript": "^3.9.1",
|
|
53
53
|
"eslint-plugin-import": "^2.31.0",
|
|
54
54
|
"eslint-plugin-jest": "^28.11.0",
|
|
55
|
-
"eslint-plugin-jsdoc": "^50.6.
|
|
55
|
+
"eslint-plugin-jsdoc": "^50.6.9",
|
|
56
56
|
"eslint-plugin-prettier": "^5.2.3",
|
|
57
57
|
"jest": "^29.7.0",
|
|
58
58
|
"jest-junit": "^16",
|
|
59
59
|
"jsii": "5.6",
|
|
60
|
-
"jsii-diff": "^1.
|
|
61
|
-
"jsii-pacmak": "^1.
|
|
60
|
+
"jsii-diff": "^1.110.0",
|
|
61
|
+
"jsii-pacmak": "^1.110.0",
|
|
62
62
|
"jsii-rosetta": "5.6",
|
|
63
63
|
"license-checker": "^25.0.1",
|
|
64
64
|
"mock-fs": "^5.5.0",
|
|
65
65
|
"prettier": "^2.8",
|
|
66
|
-
"projen": "^0.91.
|
|
66
|
+
"projen": "^0.91.18",
|
|
67
67
|
"ts-jest": "^29.2.6",
|
|
68
68
|
"tsx": "^4.19.3",
|
|
69
69
|
"typescript": "5.6",
|
|
@@ -90,7 +90,7 @@
|
|
|
90
90
|
"publishConfig": {
|
|
91
91
|
"access": "public"
|
|
92
92
|
},
|
|
93
|
-
"version": "
|
|
93
|
+
"version": "42.0.0",
|
|
94
94
|
"types": "lib/index.d.ts",
|
|
95
95
|
"stability": "stable",
|
|
96
96
|
"jsii": {
|
|
@@ -1032,20 +1032,28 @@
|
|
|
1032
1032
|
"type": "string"
|
|
1033
1033
|
},
|
|
1034
1034
|
"exactIdentifier": {
|
|
1035
|
-
"description": "
|
|
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.)",
|
|
1036
1036
|
"type": "string"
|
|
1037
1037
|
},
|
|
1038
1038
|
"propertyMatch": {
|
|
1039
|
-
"description": "
|
|
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.)",
|
|
1040
1040
|
"$ref": "#/definitions/Record<string,unknown>"
|
|
1041
1041
|
},
|
|
1042
1042
|
"propertiesToReturn": {
|
|
1043
|
-
"description": "This is a set of properties returned from CC API that we want to return from ContextQuery
|
|
1043
|
+
"description": "This is a set of properties returned from CC API that we want to return from ContextQuery.\n\nIf any properties listed here are absent from the target resource, an error will be thrown.\n\nThe returned object will always include the key `Identifier` with the CC-API returned\nfield `Identifier`.\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 returned properties here are *currently* selected from the response\nobject that CloudControl API returns to the CDK CLI.\n\nHowever, if we find there is need to do so, we may decide to change this\nbehavior in the future: we might change it to perform an additional\n`GetResource` call for resources matched by `propertyMatch`.",
|
|
1044
1044
|
"type": "array",
|
|
1045
1045
|
"items": {
|
|
1046
1046
|
"type": "string"
|
|
1047
1047
|
}
|
|
1048
1048
|
},
|
|
1049
|
+
"dummyValue": {
|
|
1050
|
+
"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
|
+
},
|
|
1052
|
+
"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.",
|
|
1054
|
+
"default": false,
|
|
1055
|
+
"type": "boolean"
|
|
1056
|
+
},
|
|
1049
1057
|
"account": {
|
|
1050
1058
|
"description": "Query account",
|
|
1051
1059
|
"type": "string"
|
package/schema/version.json
CHANGED