@horietakehiro/aws-cdk-utul 0.41.55 → 0.41.56

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.
Files changed (33) hide show
  1. package/lib/types/cfn-resource-types/aws-billingconductor-customlineitem.d.ts +6 -4
  2. package/lib/types/cfn-resource-types/aws-billingconductor-customlineitem.js +1 -1
  3. package/lib/types/cfn-resource-types/aws-connectcampaignsv2-campaign.d.ts +30 -2
  4. package/lib/types/cfn-resource-types/aws-connectcampaignsv2-campaign.js +1 -1
  5. package/lib/types/cfn-resource-types/aws-ec2-networkinterface.d.ts +35 -21
  6. package/lib/types/cfn-resource-types/aws-ec2-networkinterface.js +1 -1
  7. package/lib/types/cfn-resource-types/aws-eks-nodegroup.d.ts +45 -4
  8. package/lib/types/cfn-resource-types/aws-eks-nodegroup.js +1 -1
  9. package/lib/types/cfn-resource-types/aws-elasticloadbalancingv2-listener.d.ts +16 -1
  10. package/lib/types/cfn-resource-types/aws-elasticloadbalancingv2-listener.js +1 -1
  11. package/lib/types/cfn-resource-types/aws-elasticloadbalancingv2-listenerrule.d.ts +15 -0
  12. package/lib/types/cfn-resource-types/aws-elasticloadbalancingv2-listenerrule.js +1 -1
  13. package/lib/types/cfn-resource-types/aws-elasticloadbalancingv2-loadbalancer.d.ts +3 -0
  14. package/lib/types/cfn-resource-types/aws-elasticloadbalancingv2-loadbalancer.js +1 -1
  15. package/lib/types/cfn-resource-types/aws-entityresolution-matchingworkflow.d.ts +8 -1
  16. package/lib/types/cfn-resource-types/aws-entityresolution-matchingworkflow.js +1 -1
  17. package/lib/types/cfn-resource-types/aws-fsx-s3accesspointattachment.d.ts +96 -4
  18. package/lib/types/cfn-resource-types/aws-fsx-s3accesspointattachment.js +1 -1
  19. package/lib/types/cfn-resource-types/aws-msk-cluster.d.ts +2 -0
  20. package/lib/types/cfn-resource-types/aws-msk-cluster.js +1 -1
  21. package/lib/types/cfn-resource-types/aws-observabilityadmin-organizationtelemetryrule.d.ts +189 -1
  22. package/lib/types/cfn-resource-types/aws-observabilityadmin-organizationtelemetryrule.js +1 -1
  23. package/lib/types/cfn-resource-types/aws-observabilityadmin-telemetryrule.d.ts +202 -2
  24. package/lib/types/cfn-resource-types/aws-observabilityadmin-telemetryrule.js +1 -1
  25. package/lib/types/cfn-resource-types/aws-organizations-policy.d.ts +1 -1
  26. package/lib/types/cfn-resource-types/aws-organizations-policy.js +1 -1
  27. package/lib/types/cfn-resource-types/aws-ram-resourceshare.d.ts +20 -0
  28. package/lib/types/cfn-resource-types/aws-ram-resourceshare.js +1 -1
  29. package/lib/types/cfn-resource-types/aws-route53profiles-profile.d.ts +4 -0
  30. package/lib/types/cfn-resource-types/aws-route53profiles-profile.js +1 -1
  31. package/lib/types/cfn-resource-types/aws-workspacesweb-usersettings.d.ts +36 -0
  32. package/lib/types/cfn-resource-types/aws-workspacesweb-usersettings.js +1 -1
  33. package/package.json +1 -1
@@ -1,5 +1,6 @@
1
1
  export type Type = ("FEE" | "CREDIT");
2
2
  export type LineItemFilterValue = "SAVINGS_PLAN_NEGATION";
3
+ export type AttributeValue = string;
3
4
  export type LineItemFilters = LineItemFilter[];
4
5
  export type InclusiveStartBillingPeriod = string;
5
6
  export type ExclusiveEndBillingPeriod = string;
@@ -11,7 +12,7 @@ export interface _AWS_BILLINGCONDUCTOR_CUSTOMLINEITEM {
11
12
  /**
12
13
  * The display settings of the Custom Line Item.
13
14
  */
14
- ComputationRule?: "CONSOLIDATED";
15
+ ComputationRule?: ("CONSOLIDATED" | "ITEMIZED");
15
16
  PresentationDetails?: {
16
17
  Service: string;
17
18
  };
@@ -60,9 +61,10 @@ export interface CustomLineItemPercentageChargeDetails {
60
61
  PercentageValue: number;
61
62
  }
62
63
  export interface LineItemFilter {
63
- Attribute: "LINE_ITEM_TYPE";
64
- MatchOption: "NOT_EQUAL";
65
- Values: LineItemFilterValue[];
64
+ Attribute: ("LINE_ITEM_TYPE" | "SERVICE");
65
+ MatchOption: ("NOT_EQUAL" | "EQUAL");
66
+ Values?: LineItemFilterValue[];
67
+ AttributeValues?: AttributeValue[];
66
68
  }
67
69
  export interface BillingPeriodRange {
68
70
  InclusiveStartBillingPeriod?: InclusiveStartBillingPeriod;
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWJpbGxpbmdjb25kdWN0b3ItY3VzdG9tbGluZWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhd3MtYmlsbGluZ2NvbmR1Y3Rvci1jdXN0b21saW5laXRlbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgVHlwZSA9IChcIkZFRVwiIHwgXCJDUkVESVRcIilcbmV4cG9ydCB0eXBlIExpbmVJdGVtRmlsdGVyVmFsdWUgPSBcIlNBVklOR1NfUExBTl9ORUdBVElPTlwiXG5leHBvcnQgdHlwZSBMaW5lSXRlbUZpbHRlcnMgPSBMaW5lSXRlbUZpbHRlcltdXG5leHBvcnQgdHlwZSBJbmNsdXNpdmVTdGFydEJpbGxpbmdQZXJpb2QgPSBzdHJpbmdcbmV4cG9ydCB0eXBlIEV4Y2x1c2l2ZUVuZEJpbGxpbmdQZXJpb2QgPSBzdHJpbmdcblxuLyoqXG4gKiBBIGN1c3RvbSBsaW5lIGl0ZW0gaXMgYW4gb25lIHRpbWUgY2hhcmdlIHRoYXQgaXMgYXBwbGllZCB0byBhIHNwZWNpZmljIGJpbGxpbmcgZ3JvdXAncyBiaWxsLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIF9BV1NfQklMTElOR0NPTkRVQ1RPUl9DVVNUT01MSU5FSVRFTSB7XG5OYW1lOiBzdHJpbmdcbi8qKlxuICogVGhlIGRpc3BsYXkgc2V0dGluZ3Mgb2YgdGhlIEN1c3RvbSBMaW5lIEl0ZW0uXG4gKi9cbkNvbXB1dGF0aW9uUnVsZT86IFwiQ09OU09MSURBVEVEXCJcblByZXNlbnRhdGlvbkRldGFpbHM/OiB7XG5TZXJ2aWNlOiBzdHJpbmdcbn1cbkRlc2NyaXB0aW9uPzogc3RyaW5nXG5DdXN0b21MaW5lSXRlbUNoYXJnZURldGFpbHM/OiBDdXN0b21MaW5lSXRlbUNoYXJnZURldGFpbHNcbi8qKlxuICogQmlsbGluZyBHcm91cCBBUk5cbiAqL1xuQmlsbGluZ0dyb3VwQXJuOiBzdHJpbmdcbkJpbGxpbmdQZXJpb2RSYW5nZT86IEJpbGxpbmdQZXJpb2RSYW5nZVxuLyoqXG4gKiBBUk5cbiAqL1xuQXJuPzogc3RyaW5nXG4vKipcbiAqIENyZWF0aW9uIHRpbWVzdGFtcCBpbiBVTklYIGVwb2NoIHRpbWUgZm9ybWF0XG4gKi9cbkNyZWF0aW9uVGltZT86IG51bWJlclxuLyoqXG4gKiBMYXRlc3QgbW9kaWZpZWQgdGltZXN0YW1wIGluIFVOSVggZXBvY2ggdGltZSBmb3JtYXRcbiAqL1xuTGFzdE1vZGlmaWVkVGltZT86IG51bWJlclxuLyoqXG4gKiBOdW1iZXIgb2Ygc291cmNlIHZhbHVlcyBhc3NvY2lhdGVkIHRvIHRoaXMgY3VzdG9tIGxpbmUgaXRlbVxuICovXG5Bc3NvY2lhdGlvblNpemU/OiBudW1iZXJcblByb2R1Y3RDb2RlPzogc3RyaW5nXG5DdXJyZW5jeUNvZGU/OiAoXCJVU0RcIiB8IFwiQ05ZXCIpXG4vKipcbiAqIFRoZSBhY2NvdW50IHdoaWNoIHRoaXMgY3VzdG9tIGxpbmUgaXRlbSB3aWxsIGJlIGNoYXJnZWQgdG9cbiAqL1xuQWNjb3VudElkPzogc3RyaW5nXG5UYWdzPzogVGFnW11cbn1cbmV4cG9ydCBpbnRlcmZhY2UgQ3VzdG9tTGluZUl0ZW1DaGFyZ2VEZXRhaWxzIHtcbkZsYXQ/OiBDdXN0b21MaW5lSXRlbUZsYXRDaGFyZ2VEZXRhaWxzXG5QZXJjZW50YWdlPzogQ3VzdG9tTGluZUl0ZW1QZXJjZW50YWdlQ2hhcmdlRGV0YWlsc1xuVHlwZTogVHlwZVxuTGluZUl0ZW1GaWx0ZXJzPzogTGluZUl0ZW1GaWx0ZXJzXG59XG5leHBvcnQgaW50ZXJmYWNlIEN1c3RvbUxpbmVJdGVtRmxhdENoYXJnZURldGFpbHMge1xuQ2hhcmdlVmFsdWU6IG51bWJlclxufVxuZXhwb3J0IGludGVyZmFjZSBDdXN0b21MaW5lSXRlbVBlcmNlbnRhZ2VDaGFyZ2VEZXRhaWxzIHtcbkNoaWxkQXNzb2NpYXRlZFJlc291cmNlcz86IHN0cmluZ1tdXG5QZXJjZW50YWdlVmFsdWU6IG51bWJlclxufVxuZXhwb3J0IGludGVyZmFjZSBMaW5lSXRlbUZpbHRlciB7XG5BdHRyaWJ1dGU6IFwiTElORV9JVEVNX1RZUEVcIlxuTWF0Y2hPcHRpb246IFwiTk9UX0VRVUFMXCJcblZhbHVlczogTGluZUl0ZW1GaWx0ZXJWYWx1ZVtdXG59XG5leHBvcnQgaW50ZXJmYWNlIEJpbGxpbmdQZXJpb2RSYW5nZSB7XG5JbmNsdXNpdmVTdGFydEJpbGxpbmdQZXJpb2Q/OiBJbmNsdXNpdmVTdGFydEJpbGxpbmdQZXJpb2RcbkV4Y2x1c2l2ZUVuZEJpbGxpbmdQZXJpb2Q/OiBFeGNsdXNpdmVFbmRCaWxsaW5nUGVyaW9kXG59XG5leHBvcnQgaW50ZXJmYWNlIFRhZyB7XG5LZXk6IHN0cmluZ1xuVmFsdWU6IHN0cmluZ1xufVxuIl19
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWJpbGxpbmdjb25kdWN0b3ItY3VzdG9tbGluZWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhd3MtYmlsbGluZ2NvbmR1Y3Rvci1jdXN0b21saW5laXRlbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgVHlwZSA9IChcIkZFRVwiIHwgXCJDUkVESVRcIilcbmV4cG9ydCB0eXBlIExpbmVJdGVtRmlsdGVyVmFsdWUgPSBcIlNBVklOR1NfUExBTl9ORUdBVElPTlwiXG5leHBvcnQgdHlwZSBBdHRyaWJ1dGVWYWx1ZSA9IHN0cmluZ1xuZXhwb3J0IHR5cGUgTGluZUl0ZW1GaWx0ZXJzID0gTGluZUl0ZW1GaWx0ZXJbXVxuZXhwb3J0IHR5cGUgSW5jbHVzaXZlU3RhcnRCaWxsaW5nUGVyaW9kID0gc3RyaW5nXG5leHBvcnQgdHlwZSBFeGNsdXNpdmVFbmRCaWxsaW5nUGVyaW9kID0gc3RyaW5nXG5cbi8qKlxuICogQSBjdXN0b20gbGluZSBpdGVtIGlzIGFuIG9uZSB0aW1lIGNoYXJnZSB0aGF0IGlzIGFwcGxpZWQgdG8gYSBzcGVjaWZpYyBiaWxsaW5nIGdyb3VwJ3MgYmlsbC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBfQVdTX0JJTExJTkdDT05EVUNUT1JfQ1VTVE9NTElORUlURU0ge1xuTmFtZTogc3RyaW5nXG4vKipcbiAqIFRoZSBkaXNwbGF5IHNldHRpbmdzIG9mIHRoZSBDdXN0b20gTGluZSBJdGVtLlxuICovXG5Db21wdXRhdGlvblJ1bGU/OiAoXCJDT05TT0xJREFURURcIiB8IFwiSVRFTUlaRURcIilcblByZXNlbnRhdGlvbkRldGFpbHM/OiB7XG5TZXJ2aWNlOiBzdHJpbmdcbn1cbkRlc2NyaXB0aW9uPzogc3RyaW5nXG5DdXN0b21MaW5lSXRlbUNoYXJnZURldGFpbHM/OiBDdXN0b21MaW5lSXRlbUNoYXJnZURldGFpbHNcbi8qKlxuICogQmlsbGluZyBHcm91cCBBUk5cbiAqL1xuQmlsbGluZ0dyb3VwQXJuOiBzdHJpbmdcbkJpbGxpbmdQZXJpb2RSYW5nZT86IEJpbGxpbmdQZXJpb2RSYW5nZVxuLyoqXG4gKiBBUk5cbiAqL1xuQXJuPzogc3RyaW5nXG4vKipcbiAqIENyZWF0aW9uIHRpbWVzdGFtcCBpbiBVTklYIGVwb2NoIHRpbWUgZm9ybWF0XG4gKi9cbkNyZWF0aW9uVGltZT86IG51bWJlclxuLyoqXG4gKiBMYXRlc3QgbW9kaWZpZWQgdGltZXN0YW1wIGluIFVOSVggZXBvY2ggdGltZSBmb3JtYXRcbiAqL1xuTGFzdE1vZGlmaWVkVGltZT86IG51bWJlclxuLyoqXG4gKiBOdW1iZXIgb2Ygc291cmNlIHZhbHVlcyBhc3NvY2lhdGVkIHRvIHRoaXMgY3VzdG9tIGxpbmUgaXRlbVxuICovXG5Bc3NvY2lhdGlvblNpemU/OiBudW1iZXJcblByb2R1Y3RDb2RlPzogc3RyaW5nXG5DdXJyZW5jeUNvZGU/OiAoXCJVU0RcIiB8IFwiQ05ZXCIpXG4vKipcbiAqIFRoZSBhY2NvdW50IHdoaWNoIHRoaXMgY3VzdG9tIGxpbmUgaXRlbSB3aWxsIGJlIGNoYXJnZWQgdG9cbiAqL1xuQWNjb3VudElkPzogc3RyaW5nXG5UYWdzPzogVGFnW11cbn1cbmV4cG9ydCBpbnRlcmZhY2UgQ3VzdG9tTGluZUl0ZW1DaGFyZ2VEZXRhaWxzIHtcbkZsYXQ/OiBDdXN0b21MaW5lSXRlbUZsYXRDaGFyZ2VEZXRhaWxzXG5QZXJjZW50YWdlPzogQ3VzdG9tTGluZUl0ZW1QZXJjZW50YWdlQ2hhcmdlRGV0YWlsc1xuVHlwZTogVHlwZVxuTGluZUl0ZW1GaWx0ZXJzPzogTGluZUl0ZW1GaWx0ZXJzXG59XG5leHBvcnQgaW50ZXJmYWNlIEN1c3RvbUxpbmVJdGVtRmxhdENoYXJnZURldGFpbHMge1xuQ2hhcmdlVmFsdWU6IG51bWJlclxufVxuZXhwb3J0IGludGVyZmFjZSBDdXN0b21MaW5lSXRlbVBlcmNlbnRhZ2VDaGFyZ2VEZXRhaWxzIHtcbkNoaWxkQXNzb2NpYXRlZFJlc291cmNlcz86IHN0cmluZ1tdXG5QZXJjZW50YWdlVmFsdWU6IG51bWJlclxufVxuZXhwb3J0IGludGVyZmFjZSBMaW5lSXRlbUZpbHRlciB7XG5BdHRyaWJ1dGU6IChcIkxJTkVfSVRFTV9UWVBFXCIgfCBcIlNFUlZJQ0VcIilcbk1hdGNoT3B0aW9uOiAoXCJOT1RfRVFVQUxcIiB8IFwiRVFVQUxcIilcblZhbHVlcz86IExpbmVJdGVtRmlsdGVyVmFsdWVbXVxuQXR0cmlidXRlVmFsdWVzPzogQXR0cmlidXRlVmFsdWVbXVxufVxuZXhwb3J0IGludGVyZmFjZSBCaWxsaW5nUGVyaW9kUmFuZ2Uge1xuSW5jbHVzaXZlU3RhcnRCaWxsaW5nUGVyaW9kPzogSW5jbHVzaXZlU3RhcnRCaWxsaW5nUGVyaW9kXG5FeGNsdXNpdmVFbmRCaWxsaW5nUGVyaW9kPzogRXhjbHVzaXZlRW5kQmlsbGluZ1BlcmlvZFxufVxuZXhwb3J0IGludGVyZmFjZSBUYWcge1xuS2V5OiBzdHJpbmdcblZhbHVlOiBzdHJpbmdcbn1cbiJdfQ==
@@ -2,6 +2,10 @@
2
2
  * Campaign name
3
3
  */
4
4
  export type CampaignName = string;
5
+ /**
6
+ * Campaign type
7
+ */
8
+ export type CampaignType = ("MANAGED" | "JOURNEY");
5
9
  /**
6
10
  * Amazon Connect Instance Id
7
11
  */
@@ -13,6 +17,7 @@ export type ChannelSubtypeConfig = (ChannelSubtypeConfig1 & {
13
17
  Telephony?: TelephonyChannelSubtypeConfig;
14
18
  Sms?: SmsChannelSubtypeConfig;
15
19
  Email?: EmailChannelSubtypeConfig;
20
+ WhatsApp?: WhatsAppChannelSubtypeConfig;
16
21
  });
17
22
  export type ChannelSubtypeConfig1 = {
18
23
  [k: string]: unknown;
@@ -161,8 +166,9 @@ export interface _AWS_CONNECTCAMPAIGNSV2_CAMPAIGN {
161
166
  */
162
167
  Arn?: string;
163
168
  Name: CampaignName;
169
+ Type?: CampaignType;
164
170
  ConnectInstanceId: InstanceId;
165
- ChannelSubtypeConfig: ChannelSubtypeConfig;
171
+ ChannelSubtypeConfig?: ChannelSubtypeConfig;
166
172
  Source?: Source;
167
173
  ConnectCampaignFlowArn?: Arn;
168
174
  Schedule?: Schedule;
@@ -274,13 +280,34 @@ export interface EmailOutboundMode {
274
280
  AgentlessConfig?: AgentlessConfig;
275
281
  }
276
282
  /**
277
- * Default SMS outbound config
283
+ * Default Email outbound config
278
284
  */
279
285
  export interface EmailOutboundConfig {
280
286
  ConnectSourceEmailAddress: EmailAddress;
281
287
  SourceEmailAddressDisplayName?: SourceEmailAddressDisplayName;
282
288
  WisdomTemplateArn: Arn;
283
289
  }
290
+ /**
291
+ * WhatsApp Channel Subtype config
292
+ */
293
+ export interface WhatsAppChannelSubtypeConfig {
294
+ Capacity?: Capacity;
295
+ OutboundMode: WhatsAppOutboundMode;
296
+ DefaultOutboundConfig: WhatsAppOutboundConfig;
297
+ }
298
+ /**
299
+ * WhatsApp Outbound Mode
300
+ */
301
+ export interface WhatsAppOutboundMode {
302
+ AgentlessConfig?: AgentlessConfig;
303
+ }
304
+ /**
305
+ * Default WhatsApp outbound config
306
+ */
307
+ export interface WhatsAppOutboundConfig {
308
+ ConnectSourcePhoneNumberArn: Arn;
309
+ WisdomTemplateArn: Arn;
310
+ }
284
311
  /**
285
312
  * The event trigger of the campaign
286
313
  */
@@ -303,6 +330,7 @@ export interface CommunicationTimeConfig {
303
330
  Telephony?: TimeWindow;
304
331
  Sms?: TimeWindow;
305
332
  Email?: TimeWindow;
333
+ WhatsApp?: TimeWindow;
306
334
  }
307
335
  /**
308
336
  * Local time zone config
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-connectcampaignsv2-campaign.js","sourceRoot":"","sources":["aws-connectcampaignsv2-campaign.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * Campaign name\n */\nexport type CampaignName = string\n/**\n * Amazon Connect Instance Id\n */\nexport type InstanceId = string\n/**\n * The possible types of channel subtype config parameters\n */\nexport type ChannelSubtypeConfig = (ChannelSubtypeConfig1 & {\nTelephony?: TelephonyChannelSubtypeConfig\nSms?: SmsChannelSubtypeConfig\nEmail?: EmailChannelSubtypeConfig\n})\nexport type ChannelSubtypeConfig1 = {\n[k: string]: unknown\n}\n/**\n * Allocates outbound capacity for the specific channel of this campaign between multiple active campaigns\n */\nexport type Capacity = number\n/**\n * The queue for the call\n */\nexport type QueueId = string\n/**\n * Telephony Outbound Mode\n */\nexport type TelephonyOutboundMode = ({\nProgressiveConfig?: ProgressiveConfig\nPredictiveConfig?: PredictiveConfig\nAgentlessConfig?: AgentlessConfig\nPreviewConfig?: PreviewConfig\n} & TelephonyOutboundMode1)\n/**\n * The bandwidth allocation of a queue resource.\n */\nexport type BandwidthAllocation = number\n/**\n * Timeout duration for a preview contact in seconds\n */\nexport type TimeoutDuration = number\n/**\n * Actions that can performed on a contact by an agent\n */\nexport type AgentAction = \"DISCARD\"\n/**\n * Actions that can be performed by agent during preview phase\n */\nexport type AgentActions = AgentAction[]\nexport type TelephonyOutboundMode1 = {\n[k: string]: unknown\n}\n/**\n * The identifier of the contact flow for the outbound call\n */\nexport type ContactFlowId = string\n/**\n * The phone number associated with the Amazon Connect instance, in E.164 format. If you do not specify a source phone number, you must specify a queue.\n */\nexport type SourcePhoneNumber = string\n/**\n * Maximum ring time for outbound calls in seconds\n */\nexport type RingTimeout = number\n/**\n * Arn\n */\nexport type Arn = string\n/**\n * Email address used for Email messages\n */\nexport type EmailAddress = string\n/**\n * The name of the source email address display name\n */\nexport type SourceEmailAddressDisplayName = string\n/**\n * The possible source of the campaign\n */\nexport type Source = ({\nCustomerProfilesSegmentArn?: Arn\nEventTrigger?: EventTrigger\n} & Source1)\nexport type Source1 = {\n[k: string]: unknown\n}\n/**\n * Timestamp with no UTC offset or timezone\n */\nexport type TimeStamp = string\n/**\n * Time duration in ISO 8601 format\n */\nexport type Iso8601Duration = string\n/**\n * Time Zone Id in the IANA format\n */\nexport type TimeZone = string\n/**\n * Local TimeZone Detection method\n */\nexport type LocalTimeZoneDetectionType = (\"ZIP_CODE\" | \"AREA_CODE\")\n/**\n * Local TimeZone Detection method list\n */\nexport type LocalTimeZoneDetection = LocalTimeZoneDetectionType[]\n/**\n * Day of week\n */\nexport type DayOfWeek = (\"MONDAY\" | \"TUESDAY\" | \"WEDNESDAY\" | \"THURSDAY\" | \"FRIDAY\" | \"SATURDAY\" | \"SUNDAY\")\n/**\n * Time in ISO 8601 format, e.g. T23:11\n */\nexport type Iso8601Time = string\n/**\n * List of time range\n */\nexport type TimeRangeList = TimeRange[]\n/**\n * Daily Hours map\n */\nexport type DailyHours = DailyHour[]\n/**\n * Restricted period config\n */\nexport type RestrictedPeriods = ({\nRestrictedPeriodList?: RestrictedPeriodList\n} & RestrictedPeriods1)\n/**\n * Date in ISO 8601 format, e.g. 2024-01-01\n */\nexport type Iso8601Date = string\n/**\n * List of restricted period\n */\nexport type RestrictedPeriodList = RestrictedPeriod[]\nexport type RestrictedPeriods1 = {\n[k: string]: unknown\n}\n/**\n * The communication limit time unit\n */\nexport type CommunicationLimitTimeUnit = \"DAY\"\n/**\n * List of communication limit\n */\nexport type CommunicationLimitList = CommunicationLimit[]\n/**\n * Enumeration of Instance Limits handling in a Campaign\n */\nexport type InstanceLimitsHandling = (\"OPT_IN\" | \"OPT_OUT\")\n\n/**\n * Definition of AWS::ConnectCampaignsV2::Campaign Resource Type\n */\nexport interface _AWS_CONNECTCAMPAIGNSV2_CAMPAIGN {\n/**\n * Amazon Connect Campaign Arn\n */\nArn?: string\nName: CampaignName\nConnectInstanceId: InstanceId\nChannelSubtypeConfig: ChannelSubtypeConfig\nSource?: Source\nConnectCampaignFlowArn?: Arn\nSchedule?: Schedule\nCommunicationTimeConfig?: CommunicationTimeConfig\nCommunicationLimitsOverride?: CommunicationLimitsConfig\n/**\n * One or more tags.\n * \n * @maxItems 50\n */\nTags?: Tag[]\n}\n/**\n * Telephony Channel Subtype config\n */\nexport interface TelephonyChannelSubtypeConfig {\nCapacity?: Capacity\nConnectQueueId?: QueueId\nOutboundMode: TelephonyOutboundMode\nDefaultOutboundConfig: TelephonyOutboundConfig\n}\n/**\n * Progressive config\n */\nexport interface ProgressiveConfig {\nBandwidthAllocation: BandwidthAllocation\n}\n/**\n * Predictive config\n */\nexport interface PredictiveConfig {\nBandwidthAllocation: BandwidthAllocation\n}\n/**\n * Agentless config\n */\nexport interface AgentlessConfig {\n\n}\n/**\n * Preview config\n */\nexport interface PreviewConfig {\nBandwidthAllocation: BandwidthAllocation\nTimeoutConfig: TimeoutConfig\nAgentActions?: AgentActions\n}\n/**\n * Timeout Config for preview contacts\n */\nexport interface TimeoutConfig {\nDurationInSeconds?: TimeoutDuration\n[k: string]: unknown\n}\n/**\n * Default Telephone Outbound config\n */\nexport interface TelephonyOutboundConfig {\nConnectContactFlowId: ContactFlowId\nConnectSourcePhoneNumber?: SourcePhoneNumber\nAnswerMachineDetectionConfig?: AnswerMachineDetectionConfig\nRingTimeout?: RingTimeout\n}\n/**\n * The configuration used for answering machine detection during outbound calls\n */\nexport interface AnswerMachineDetectionConfig {\n/**\n * Flag to decided whether outbound calls should have answering machine detection enabled or not\n */\nEnableAnswerMachineDetection: boolean\n/**\n * Enables detection of prompts (e.g., beep after after a voicemail greeting)\n */\nAwaitAnswerMachinePrompt?: boolean\n}\n/**\n * SMS Channel Subtype config\n */\nexport interface SmsChannelSubtypeConfig {\nCapacity?: Capacity\nOutboundMode: SmsOutboundMode\nDefaultOutboundConfig: SmsOutboundConfig\n}\n/**\n * SMS Outbound Mode\n */\nexport interface SmsOutboundMode {\nAgentlessConfig?: AgentlessConfig\n}\n/**\n * Default SMS outbound config\n */\nexport interface SmsOutboundConfig {\nConnectSourcePhoneNumberArn: Arn\nWisdomTemplateArn: Arn\n}\n/**\n * Email Channel Subtype config\n */\nexport interface EmailChannelSubtypeConfig {\nCapacity?: Capacity\nOutboundMode: EmailOutboundMode\nDefaultOutboundConfig: EmailOutboundConfig\n}\n/**\n * Email Outbound Mode\n */\nexport interface EmailOutboundMode {\nAgentlessConfig?: AgentlessConfig\n}\n/**\n * Default SMS outbound config\n */\nexport interface EmailOutboundConfig {\nConnectSourceEmailAddress: EmailAddress\nSourceEmailAddressDisplayName?: SourceEmailAddressDisplayName\nWisdomTemplateArn: Arn\n}\n/**\n * The event trigger of the campaign\n */\nexport interface EventTrigger {\nCustomerProfilesDomainArn?: Arn\n}\n/**\n * Campaign schedule\n */\nexport interface Schedule {\nStartTime: TimeStamp\nEndTime: TimeStamp\nRefreshFrequency?: Iso8601Duration\n}\n/**\n * Campaign communication time config\n */\nexport interface CommunicationTimeConfig {\nLocalTimeZoneConfig: LocalTimeZoneConfig\nTelephony?: TimeWindow\nSms?: TimeWindow\nEmail?: TimeWindow\n}\n/**\n * Local time zone config\n */\nexport interface LocalTimeZoneConfig {\nDefaultTimeZone?: TimeZone\nLocalTimeZoneDetection?: LocalTimeZoneDetection\n}\n/**\n * Time window config\n */\nexport interface TimeWindow {\nOpenHours: OpenHours\nRestrictedPeriods?: RestrictedPeriods\n}\n/**\n * Open Hours config\n */\nexport interface OpenHours {\nDailyHours: DailyHours\n}\n/**\n * Daily Hour\n */\nexport interface DailyHour {\nKey?: DayOfWeek\nValue?: TimeRangeList\n}\n/**\n * Time range in 24 hour format\n */\nexport interface TimeRange {\nStartTime: Iso8601Time\nEndTime: Iso8601Time\n}\n/**\n * Restricted period\n */\nexport interface RestrictedPeriod {\n/**\n * The name of a restricted period\n */\nName?: string\nStartDate: Iso8601Date\nEndDate: Iso8601Date\n}\n/**\n * Communication limits config\n */\nexport interface CommunicationLimitsConfig {\nAllChannelsSubtypes?: CommunicationLimits\nInstanceLimitsHandling?: InstanceLimitsHandling\n}\n/**\n * Communication limits\n */\nexport interface CommunicationLimits {\nCommunicationLimitList?: CommunicationLimitList\n}\n/**\n * Communication Limit\n */\nexport interface CommunicationLimit {\nMaxCountPerRecipient: number\nFrequency: number\nUnit: CommunicationLimitTimeUnit\n}\nexport interface Tag {\n/**\n * The key name of the tag.\n */\nKey: string\n/**\n * The value for the tag.\n */\nValue: string\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-connectcampaignsv2-campaign.js","sourceRoot":"","sources":["aws-connectcampaignsv2-campaign.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * Campaign name\n */\nexport type CampaignName = string\n/**\n * Campaign type\n */\nexport type CampaignType = (\"MANAGED\" | \"JOURNEY\")\n/**\n * Amazon Connect Instance Id\n */\nexport type InstanceId = string\n/**\n * The possible types of channel subtype config parameters\n */\nexport type ChannelSubtypeConfig = (ChannelSubtypeConfig1 & {\nTelephony?: TelephonyChannelSubtypeConfig\nSms?: SmsChannelSubtypeConfig\nEmail?: EmailChannelSubtypeConfig\nWhatsApp?: WhatsAppChannelSubtypeConfig\n})\nexport type ChannelSubtypeConfig1 = {\n[k: string]: unknown\n}\n/**\n * Allocates outbound capacity for the specific channel of this campaign between multiple active campaigns\n */\nexport type Capacity = number\n/**\n * The queue for the call\n */\nexport type QueueId = string\n/**\n * Telephony Outbound Mode\n */\nexport type TelephonyOutboundMode = ({\nProgressiveConfig?: ProgressiveConfig\nPredictiveConfig?: PredictiveConfig\nAgentlessConfig?: AgentlessConfig\nPreviewConfig?: PreviewConfig\n} & TelephonyOutboundMode1)\n/**\n * The bandwidth allocation of a queue resource.\n */\nexport type BandwidthAllocation = number\n/**\n * Timeout duration for a preview contact in seconds\n */\nexport type TimeoutDuration = number\n/**\n * Actions that can performed on a contact by an agent\n */\nexport type AgentAction = \"DISCARD\"\n/**\n * Actions that can be performed by agent during preview phase\n */\nexport type AgentActions = AgentAction[]\nexport type TelephonyOutboundMode1 = {\n[k: string]: unknown\n}\n/**\n * The identifier of the contact flow for the outbound call\n */\nexport type ContactFlowId = string\n/**\n * The phone number associated with the Amazon Connect instance, in E.164 format. If you do not specify a source phone number, you must specify a queue.\n */\nexport type SourcePhoneNumber = string\n/**\n * Maximum ring time for outbound calls in seconds\n */\nexport type RingTimeout = number\n/**\n * Arn\n */\nexport type Arn = string\n/**\n * Email address used for Email messages\n */\nexport type EmailAddress = string\n/**\n * The name of the source email address display name\n */\nexport type SourceEmailAddressDisplayName = string\n/**\n * The possible source of the campaign\n */\nexport type Source = ({\nCustomerProfilesSegmentArn?: Arn\nEventTrigger?: EventTrigger\n} & Source1)\nexport type Source1 = {\n[k: string]: unknown\n}\n/**\n * Timestamp with no UTC offset or timezone\n */\nexport type TimeStamp = string\n/**\n * Time duration in ISO 8601 format\n */\nexport type Iso8601Duration = string\n/**\n * Time Zone Id in the IANA format\n */\nexport type TimeZone = string\n/**\n * Local TimeZone Detection method\n */\nexport type LocalTimeZoneDetectionType = (\"ZIP_CODE\" | \"AREA_CODE\")\n/**\n * Local TimeZone Detection method list\n */\nexport type LocalTimeZoneDetection = LocalTimeZoneDetectionType[]\n/**\n * Day of week\n */\nexport type DayOfWeek = (\"MONDAY\" | \"TUESDAY\" | \"WEDNESDAY\" | \"THURSDAY\" | \"FRIDAY\" | \"SATURDAY\" | \"SUNDAY\")\n/**\n * Time in ISO 8601 format, e.g. T23:11\n */\nexport type Iso8601Time = string\n/**\n * List of time range\n */\nexport type TimeRangeList = TimeRange[]\n/**\n * Daily Hours map\n */\nexport type DailyHours = DailyHour[]\n/**\n * Restricted period config\n */\nexport type RestrictedPeriods = ({\nRestrictedPeriodList?: RestrictedPeriodList\n} & RestrictedPeriods1)\n/**\n * Date in ISO 8601 format, e.g. 2024-01-01\n */\nexport type Iso8601Date = string\n/**\n * List of restricted period\n */\nexport type RestrictedPeriodList = RestrictedPeriod[]\nexport type RestrictedPeriods1 = {\n[k: string]: unknown\n}\n/**\n * The communication limit time unit\n */\nexport type CommunicationLimitTimeUnit = \"DAY\"\n/**\n * List of communication limit\n */\nexport type CommunicationLimitList = CommunicationLimit[]\n/**\n * Enumeration of Instance Limits handling in a Campaign\n */\nexport type InstanceLimitsHandling = (\"OPT_IN\" | \"OPT_OUT\")\n\n/**\n * Definition of AWS::ConnectCampaignsV2::Campaign Resource Type\n */\nexport interface _AWS_CONNECTCAMPAIGNSV2_CAMPAIGN {\n/**\n * Amazon Connect Campaign Arn\n */\nArn?: string\nName: CampaignName\nType?: CampaignType\nConnectInstanceId: InstanceId\nChannelSubtypeConfig?: ChannelSubtypeConfig\nSource?: Source\nConnectCampaignFlowArn?: Arn\nSchedule?: Schedule\nCommunicationTimeConfig?: CommunicationTimeConfig\nCommunicationLimitsOverride?: CommunicationLimitsConfig\n/**\n * One or more tags.\n * \n * @maxItems 50\n */\nTags?: Tag[]\n}\n/**\n * Telephony Channel Subtype config\n */\nexport interface TelephonyChannelSubtypeConfig {\nCapacity?: Capacity\nConnectQueueId?: QueueId\nOutboundMode: TelephonyOutboundMode\nDefaultOutboundConfig: TelephonyOutboundConfig\n}\n/**\n * Progressive config\n */\nexport interface ProgressiveConfig {\nBandwidthAllocation: BandwidthAllocation\n}\n/**\n * Predictive config\n */\nexport interface PredictiveConfig {\nBandwidthAllocation: BandwidthAllocation\n}\n/**\n * Agentless config\n */\nexport interface AgentlessConfig {\n\n}\n/**\n * Preview config\n */\nexport interface PreviewConfig {\nBandwidthAllocation: BandwidthAllocation\nTimeoutConfig: TimeoutConfig\nAgentActions?: AgentActions\n}\n/**\n * Timeout Config for preview contacts\n */\nexport interface TimeoutConfig {\nDurationInSeconds?: TimeoutDuration\n[k: string]: unknown\n}\n/**\n * Default Telephone Outbound config\n */\nexport interface TelephonyOutboundConfig {\nConnectContactFlowId: ContactFlowId\nConnectSourcePhoneNumber?: SourcePhoneNumber\nAnswerMachineDetectionConfig?: AnswerMachineDetectionConfig\nRingTimeout?: RingTimeout\n}\n/**\n * The configuration used for answering machine detection during outbound calls\n */\nexport interface AnswerMachineDetectionConfig {\n/**\n * Flag to decided whether outbound calls should have answering machine detection enabled or not\n */\nEnableAnswerMachineDetection: boolean\n/**\n * Enables detection of prompts (e.g., beep after after a voicemail greeting)\n */\nAwaitAnswerMachinePrompt?: boolean\n}\n/**\n * SMS Channel Subtype config\n */\nexport interface SmsChannelSubtypeConfig {\nCapacity?: Capacity\nOutboundMode: SmsOutboundMode\nDefaultOutboundConfig: SmsOutboundConfig\n}\n/**\n * SMS Outbound Mode\n */\nexport interface SmsOutboundMode {\nAgentlessConfig?: AgentlessConfig\n}\n/**\n * Default SMS outbound config\n */\nexport interface SmsOutboundConfig {\nConnectSourcePhoneNumberArn: Arn\nWisdomTemplateArn: Arn\n}\n/**\n * Email Channel Subtype config\n */\nexport interface EmailChannelSubtypeConfig {\nCapacity?: Capacity\nOutboundMode: EmailOutboundMode\nDefaultOutboundConfig: EmailOutboundConfig\n}\n/**\n * Email Outbound Mode\n */\nexport interface EmailOutboundMode {\nAgentlessConfig?: AgentlessConfig\n}\n/**\n * Default Email outbound config\n */\nexport interface EmailOutboundConfig {\nConnectSourceEmailAddress: EmailAddress\nSourceEmailAddressDisplayName?: SourceEmailAddressDisplayName\nWisdomTemplateArn: Arn\n}\n/**\n * WhatsApp Channel Subtype config\n */\nexport interface WhatsAppChannelSubtypeConfig {\nCapacity?: Capacity\nOutboundMode: WhatsAppOutboundMode\nDefaultOutboundConfig: WhatsAppOutboundConfig\n}\n/**\n * WhatsApp Outbound Mode\n */\nexport interface WhatsAppOutboundMode {\nAgentlessConfig?: AgentlessConfig\n}\n/**\n * Default WhatsApp outbound config\n */\nexport interface WhatsAppOutboundConfig {\nConnectSourcePhoneNumberArn: Arn\nWisdomTemplateArn: Arn\n}\n/**\n * The event trigger of the campaign\n */\nexport interface EventTrigger {\nCustomerProfilesDomainArn?: Arn\n}\n/**\n * Campaign schedule\n */\nexport interface Schedule {\nStartTime: TimeStamp\nEndTime: TimeStamp\nRefreshFrequency?: Iso8601Duration\n}\n/**\n * Campaign communication time config\n */\nexport interface CommunicationTimeConfig {\nLocalTimeZoneConfig: LocalTimeZoneConfig\nTelephony?: TimeWindow\nSms?: TimeWindow\nEmail?: TimeWindow\nWhatsApp?: TimeWindow\n}\n/**\n * Local time zone config\n */\nexport interface LocalTimeZoneConfig {\nDefaultTimeZone?: TimeZone\nLocalTimeZoneDetection?: LocalTimeZoneDetection\n}\n/**\n * Time window config\n */\nexport interface TimeWindow {\nOpenHours: OpenHours\nRestrictedPeriods?: RestrictedPeriods\n}\n/**\n * Open Hours config\n */\nexport interface OpenHours {\nDailyHours: DailyHours\n}\n/**\n * Daily Hour\n */\nexport interface DailyHour {\nKey?: DayOfWeek\nValue?: TimeRangeList\n}\n/**\n * Time range in 24 hour format\n */\nexport interface TimeRange {\nStartTime: Iso8601Time\nEndTime: Iso8601Time\n}\n/**\n * Restricted period\n */\nexport interface RestrictedPeriod {\n/**\n * The name of a restricted period\n */\nName?: string\nStartDate: Iso8601Date\nEndDate: Iso8601Date\n}\n/**\n * Communication limits config\n */\nexport interface CommunicationLimitsConfig {\nAllChannelsSubtypes?: CommunicationLimits\nInstanceLimitsHandling?: InstanceLimitsHandling\n}\n/**\n * Communication limits\n */\nexport interface CommunicationLimits {\nCommunicationLimitList?: CommunicationLimitList\n}\n/**\n * Communication Limit\n */\nexport interface CommunicationLimit {\nMaxCountPerRecipient: number\nFrequency: number\nUnit: CommunicationLimitTimeUnit\n}\nexport interface Tag {\n/**\n * The key name of the tag.\n */\nKey: string\n/**\n * The value for the tag.\n */\nValue: string\n}\n"]}
@@ -10,10 +10,6 @@ export interface _AWS_EC2_NETWORKINTERFACE {
10
10
  * Assigns a single private IP address to the network interface, which is used as the primary private IP address. If you want to specify multiple private IP address, use the PrivateIpAddresses property.
11
11
  */
12
12
  PrivateIpAddress?: string;
13
- /**
14
- * The primary IPv6 address
15
- */
16
- PrimaryIpv6Address?: string;
17
13
  /**
18
14
  * Assigns a list of private IP addresses to the network interface. You can specify a primary private IP address by setting the value of the Primary property to true in the PrivateIpAddressSpecification property. If you want EC2 to automatically assign private IP addresses, use the SecondaryPrivateIpAddressCount property and do not specify this property.
19
15
  */
@@ -22,10 +18,6 @@ export interface _AWS_EC2_NETWORKINTERFACE {
22
18
  * The number of secondary private IPv4 addresses to assign to a network interface. When you specify a number of secondary IPv4 addresses, Amazon EC2 selects these IP addresses within the subnet's IPv4 CIDR range. You can't specify this option and specify more than one private IP address using privateIpAddresses
23
19
  */
24
20
  SecondaryPrivateIpAddressCount?: number;
25
- /**
26
- * The number of IPv6 prefixes to assign to a network interface. When you specify a number of IPv6 prefixes, Amazon EC2 selects these prefixes from your existing subnet CIDR reservations, if available, or from free spaces in the subnet. By default, these will be /80 prefixes. You can't specify a count of IPv6 prefixes if you've specified one of the following: specific IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.
27
- */
28
- Ipv6PrefixCount?: number;
29
21
  /**
30
22
  * Returns the primary private IP address of the network interface.
31
23
  */
@@ -38,10 +30,6 @@ export interface _AWS_EC2_NETWORKINTERFACE {
38
30
  * The number of IPv4 prefixes to assign to a network interface. When you specify a number of IPv4 prefixes, Amazon EC2 selects these prefixes from your existing subnet CIDR reservations, if available, or from free spaces in the subnet. By default, these will be /28 prefixes. You can't specify a count of IPv4 prefixes if you've specified one of the following: specific IPv4 prefixes, specific private IPv4 addresses, or a count of private IPv4 addresses.
39
31
  */
40
32
  Ipv4PrefixCount?: number;
41
- /**
42
- * If you have instances or ENIs that rely on the IPv6 address not changing, to avoid disrupting traffic to instances or ENIs, you can enable a primary IPv6 address. Enable this option to automatically assign an IPv6 associated with the ENI attached to your instance to be the primary IPv6 address. When you enable an IPv6 address to be a primary IPv6, you cannot disable it. Traffic will be routed to the primary IPv6 address until the instance is terminated or the ENI is detached. If you have multiple IPv6 addresses associated with an ENI and you enable a primary IPv6 address, the first IPv6 address associated with the ENI becomes the primary IPv6 address.
43
- */
44
- EnablePrimaryIpv6?: boolean;
45
33
  /**
46
34
  * A list of security group IDs associated with this network interface.
47
35
  */
@@ -54,6 +42,10 @@ export interface _AWS_EC2_NETWORKINTERFACE {
54
42
  * Assigns a list of IPv6 prefixes to the network interface. If you want EC2 to automatically assign IPv6 prefixes, use the Ipv6PrefixCount property and do not specify this property. Presently, only /80 prefixes are supported. You can't specify IPv6 prefixes if you've specified one of the following: a count of IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.
55
43
  */
56
44
  Ipv6Prefixes?: Ipv6PrefixSpecification[];
45
+ /**
46
+ * The number of IPv6 prefixes to assign to a network interface. When you specify a number of IPv6 prefixes, Amazon EC2 selects these prefixes from your existing subnet CIDR reservations, if available, or from free spaces in the subnet. By default, these will be /80 prefixes. You can't specify a count of IPv6 prefixes if you've specified one of the following: specific IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.
47
+ */
48
+ Ipv6PrefixCount?: number;
57
49
  /**
58
50
  * The ID of the subnet to associate with the network interface.
59
51
  */
@@ -70,14 +62,19 @@ export interface _AWS_EC2_NETWORKINTERFACE {
70
62
  * Returns the secondary private IP addresses of the network interface.
71
63
  */
72
64
  SecondaryPrivateIpAddresses?: string[];
73
- /**
74
- * The ID of the VPC
75
- */
76
- VpcId?: string;
77
65
  /**
78
66
  * The number of IPv6 addresses to assign to a network interface. Amazon EC2 automatically selects the IPv6 addresses from the subnet range. To specify specific IPv6 addresses, use the Ipv6Addresses property and don't specify this property.
79
67
  */
80
68
  Ipv6AddressCount?: number;
69
+ /**
70
+ * If you have instances or ENIs that rely on the IPv6 address not changing, to avoid disrupting traffic to instances or ENIs, you can enable a primary IPv6 address. Enable this option to automatically assign an IPv6 associated with the ENI attached to your instance to be the primary IPv6 address. When you enable an IPv6 address to be a primary IPv6, you cannot disable it. Traffic will be routed to the primary IPv6 address until the instance is terminated or the ENI is detached. If you have multiple IPv6 addresses associated with an ENI and you enable a primary IPv6 address, the first IPv6 address associated with the ENI becomes the primary IPv6 address.
71
+ */
72
+ EnablePrimaryIpv6?: boolean;
73
+ /**
74
+ * The primary IPv6 address
75
+ */
76
+ PrimaryIpv6Address?: string;
77
+ ConnectionTrackingSpecification?: ConnectionTrackingSpecification;
81
78
  /**
82
79
  * Network interface id.
83
80
  */
@@ -86,7 +83,15 @@ export interface _AWS_EC2_NETWORKINTERFACE {
86
83
  * An arbitrary set of tags (key-value pairs) for this network interface.
87
84
  */
88
85
  Tags?: Tag[];
89
- ConnectionTrackingSpecification?: ConnectionTrackingSpecification;
86
+ /**
87
+ * The ID of the VPC
88
+ */
89
+ VpcId?: string;
90
+ /**
91
+ * Public IP DNS hostname type
92
+ */
93
+ PublicIpDnsHostnameTypeSpecification?: ("public-dual-stack-dns-name" | "public-ipv4-dns-name" | "public-ipv6-dns-name");
94
+ PublicIpDnsNameOptions?: PublicIpDnsNameOptions;
90
95
  }
91
96
  export interface PrivateIpAddressSpecification {
92
97
  PrivateIpAddress: string;
@@ -101,12 +106,21 @@ export interface InstanceIpv6Address {
101
106
  export interface Ipv6PrefixSpecification {
102
107
  Ipv6Prefix: string;
103
108
  }
109
+ export interface ConnectionTrackingSpecification {
110
+ TcpEstablishedTimeout?: number;
111
+ UdpStreamTimeout?: number;
112
+ UdpTimeout?: number;
113
+ }
104
114
  export interface Tag {
105
115
  Value: string;
106
116
  Key: string;
107
117
  }
108
- export interface ConnectionTrackingSpecification {
109
- UdpTimeout?: number;
110
- TcpEstablishedTimeout?: number;
111
- UdpStreamTimeout?: number;
118
+ /**
119
+ * Describes the public hostname type options, including public hostname type, IPv4-enabled public hostname, IPv6-enabled public hostname, and dual-stack public hostname.
120
+ */
121
+ export interface PublicIpDnsNameOptions {
122
+ DnsHostnameType?: string;
123
+ PublicIpv4DnsName?: string;
124
+ PublicIpv6DnsName?: string;
125
+ PublicDualStackDnsName?: string;
112
126
  }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWVjMi1uZXR3b3JraW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWVjMi1uZXR3b3JraW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoZSBBV1M6OkVDMjo6TmV0d29ya0ludGVyZmFjZSByZXNvdXJjZSBjcmVhdGVzIG5ldHdvcmsgaW50ZXJmYWNlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgX0FXU19FQzJfTkVUV09SS0lOVEVSRkFDRSB7XG4vKipcbiAqIEEgZGVzY3JpcHRpb24gZm9yIHRoZSBuZXR3b3JrIGludGVyZmFjZS5cbiAqL1xuRGVzY3JpcHRpb24/OiBzdHJpbmdcbi8qKlxuICogQXNzaWducyBhIHNpbmdsZSBwcml2YXRlIElQIGFkZHJlc3MgdG8gdGhlIG5ldHdvcmsgaW50ZXJmYWNlLCB3aGljaCBpcyB1c2VkIGFzIHRoZSBwcmltYXJ5IHByaXZhdGUgSVAgYWRkcmVzcy4gSWYgeW91IHdhbnQgdG8gc3BlY2lmeSBtdWx0aXBsZSBwcml2YXRlIElQIGFkZHJlc3MsIHVzZSB0aGUgUHJpdmF0ZUlwQWRkcmVzc2VzIHByb3BlcnR5LiBcbiAqL1xuUHJpdmF0ZUlwQWRkcmVzcz86IHN0cmluZ1xuLyoqXG4gKiBUaGUgcHJpbWFyeSBJUHY2IGFkZHJlc3NcbiAqL1xuUHJpbWFyeUlwdjZBZGRyZXNzPzogc3RyaW5nXG4vKipcbiAqIEFzc2lnbnMgYSBsaXN0IG9mIHByaXZhdGUgSVAgYWRkcmVzc2VzIHRvIHRoZSBuZXR3b3JrIGludGVyZmFjZS4gWW91IGNhbiBzcGVjaWZ5IGEgcHJpbWFyeSBwcml2YXRlIElQIGFkZHJlc3MgYnkgc2V0dGluZyB0aGUgdmFsdWUgb2YgdGhlIFByaW1hcnkgcHJvcGVydHkgdG8gdHJ1ZSBpbiB0aGUgUHJpdmF0ZUlwQWRkcmVzc1NwZWNpZmljYXRpb24gcHJvcGVydHkuIElmIHlvdSB3YW50IEVDMiB0byBhdXRvbWF0aWNhbGx5IGFzc2lnbiBwcml2YXRlIElQIGFkZHJlc3NlcywgdXNlIHRoZSBTZWNvbmRhcnlQcml2YXRlSXBBZGRyZXNzQ291bnQgcHJvcGVydHkgYW5kIGRvIG5vdCBzcGVjaWZ5IHRoaXMgcHJvcGVydHkuXG4gKi9cblByaXZhdGVJcEFkZHJlc3Nlcz86IFByaXZhdGVJcEFkZHJlc3NTcGVjaWZpY2F0aW9uW11cbi8qKlxuICogVGhlIG51bWJlciBvZiBzZWNvbmRhcnkgcHJpdmF0ZSBJUHY0IGFkZHJlc3NlcyB0byBhc3NpZ24gdG8gYSBuZXR3b3JrIGludGVyZmFjZS4gV2hlbiB5b3Ugc3BlY2lmeSBhIG51bWJlciBvZiBzZWNvbmRhcnkgSVB2NCBhZGRyZXNzZXMsIEFtYXpvbiBFQzIgc2VsZWN0cyB0aGVzZSBJUCBhZGRyZXNzZXMgd2l0aGluIHRoZSBzdWJuZXQncyBJUHY0IENJRFIgcmFuZ2UuIFlvdSBjYW4ndCBzcGVjaWZ5IHRoaXMgb3B0aW9uIGFuZCBzcGVjaWZ5IG1vcmUgdGhhbiBvbmUgcHJpdmF0ZSBJUCBhZGRyZXNzIHVzaW5nIHByaXZhdGVJcEFkZHJlc3Nlc1xuICovXG5TZWNvbmRhcnlQcml2YXRlSXBBZGRyZXNzQ291bnQ/OiBudW1iZXJcbi8qKlxuICogVGhlIG51bWJlciBvZiBJUHY2IHByZWZpeGVzIHRvIGFzc2lnbiB0byBhIG5ldHdvcmsgaW50ZXJmYWNlLiBXaGVuIHlvdSBzcGVjaWZ5IGEgbnVtYmVyIG9mIElQdjYgcHJlZml4ZXMsIEFtYXpvbiBFQzIgc2VsZWN0cyB0aGVzZSBwcmVmaXhlcyBmcm9tIHlvdXIgZXhpc3Rpbmcgc3VibmV0IENJRFIgcmVzZXJ2YXRpb25zLCBpZiBhdmFpbGFibGUsIG9yIGZyb20gZnJlZSBzcGFjZXMgaW4gdGhlIHN1Ym5ldC4gQnkgZGVmYXVsdCwgdGhlc2Ugd2lsbCBiZSAvODAgcHJlZml4ZXMuIFlvdSBjYW4ndCBzcGVjaWZ5IGEgY291bnQgb2YgSVB2NiBwcmVmaXhlcyBpZiB5b3UndmUgc3BlY2lmaWVkIG9uZSBvZiB0aGUgZm9sbG93aW5nOiBzcGVjaWZpYyBJUHY2IHByZWZpeGVzLCBzcGVjaWZpYyBJUHY2IGFkZHJlc3Nlcywgb3IgYSBjb3VudCBvZiBJUHY2IGFkZHJlc3Nlcy5cbiAqL1xuSXB2NlByZWZpeENvdW50PzogbnVtYmVyXG4vKipcbiAqIFJldHVybnMgdGhlIHByaW1hcnkgcHJpdmF0ZSBJUCBhZGRyZXNzIG9mIHRoZSBuZXR3b3JrIGludGVyZmFjZS5cbiAqL1xuUHJpbWFyeVByaXZhdGVJcEFkZHJlc3M/OiBzdHJpbmdcbi8qKlxuICogQXNzaWducyBhIGxpc3Qgb2YgSVB2NCBwcmVmaXhlcyB0byB0aGUgbmV0d29yayBpbnRlcmZhY2UuIElmIHlvdSB3YW50IEVDMiB0byBhdXRvbWF0aWNhbGx5IGFzc2lnbiBJUHY0IHByZWZpeGVzLCB1c2UgdGhlIElwdjRQcmVmaXhDb3VudCBwcm9wZXJ0eSBhbmQgZG8gbm90IHNwZWNpZnkgdGhpcyBwcm9wZXJ0eS4gUHJlc2VudGx5LCBvbmx5IC8yOCBwcmVmaXhlcyBhcmUgc3VwcG9ydGVkLiBZb3UgY2FuJ3Qgc3BlY2lmeSBJUHY0IHByZWZpeGVzIGlmIHlvdSd2ZSBzcGVjaWZpZWQgb25lIG9mIHRoZSBmb2xsb3dpbmc6IGEgY291bnQgb2YgSVB2NCBwcmVmaXhlcywgc3BlY2lmaWMgcHJpdmF0ZSBJUHY0IGFkZHJlc3Nlcywgb3IgYSBjb3VudCBvZiBwcml2YXRlIElQdjQgYWRkcmVzc2VzLlxuICovXG5JcHY0UHJlZml4ZXM/OiBJcHY0UHJlZml4U3BlY2lmaWNhdGlvbltdXG4vKipcbiAqIFRoZSBudW1iZXIgb2YgSVB2NCBwcmVmaXhlcyB0byBhc3NpZ24gdG8gYSBuZXR3b3JrIGludGVyZmFjZS4gV2hlbiB5b3Ugc3BlY2lmeSBhIG51bWJlciBvZiBJUHY0IHByZWZpeGVzLCBBbWF6b24gRUMyIHNlbGVjdHMgdGhlc2UgcHJlZml4ZXMgZnJvbSB5b3VyIGV4aXN0aW5nIHN1Ym5ldCBDSURSIHJlc2VydmF0aW9ucywgaWYgYXZhaWxhYmxlLCBvciBmcm9tIGZyZWUgc3BhY2VzIGluIHRoZSBzdWJuZXQuIEJ5IGRlZmF1bHQsIHRoZXNlIHdpbGwgYmUgLzI4IHByZWZpeGVzLiBZb3UgY2FuJ3Qgc3BlY2lmeSBhIGNvdW50IG9mIElQdjQgcHJlZml4ZXMgaWYgeW91J3ZlIHNwZWNpZmllZCBvbmUgb2YgdGhlIGZvbGxvd2luZzogc3BlY2lmaWMgSVB2NCBwcmVmaXhlcywgc3BlY2lmaWMgcHJpdmF0ZSBJUHY0IGFkZHJlc3Nlcywgb3IgYSBjb3VudCBvZiBwcml2YXRlIElQdjQgYWRkcmVzc2VzLlxuICovXG5JcHY0UHJlZml4Q291bnQ/OiBudW1iZXJcbi8qKlxuICogSWYgeW91IGhhdmUgaW5zdGFuY2VzIG9yIEVOSXMgdGhhdCByZWx5IG9uIHRoZSBJUHY2IGFkZHJlc3Mgbm90IGNoYW5naW5nLCB0byBhdm9pZCBkaXNydXB0aW5nIHRyYWZmaWMgdG8gaW5zdGFuY2VzIG9yIEVOSXMsIHlvdSBjYW4gZW5hYmxlIGEgcHJpbWFyeSBJUHY2IGFkZHJlc3MuIEVuYWJsZSB0aGlzIG9wdGlvbiB0byBhdXRvbWF0aWNhbGx5IGFzc2lnbiBhbiBJUHY2IGFzc29jaWF0ZWQgd2l0aCB0aGUgRU5JIGF0dGFjaGVkIHRvIHlvdXIgaW5zdGFuY2UgdG8gYmUgdGhlIHByaW1hcnkgSVB2NiBhZGRyZXNzLiBXaGVuIHlvdSBlbmFibGUgYW4gSVB2NiBhZGRyZXNzIHRvIGJlIGEgcHJpbWFyeSBJUHY2LCB5b3UgY2Fubm90IGRpc2FibGUgaXQuIFRyYWZmaWMgd2lsbCBiZSByb3V0ZWQgdG8gdGhlIHByaW1hcnkgSVB2NiBhZGRyZXNzIHVudGlsIHRoZSBpbnN0YW5jZSBpcyB0ZXJtaW5hdGVkIG9yIHRoZSBFTkkgaXMgZGV0YWNoZWQuIElmIHlvdSBoYXZlIG11bHRpcGxlIElQdjYgYWRkcmVzc2VzIGFzc29jaWF0ZWQgd2l0aCBhbiBFTkkgYW5kIHlvdSBlbmFibGUgYSBwcmltYXJ5IElQdjYgYWRkcmVzcywgdGhlIGZpcnN0IElQdjYgYWRkcmVzcyBhc3NvY2lhdGVkIHdpdGggdGhlIEVOSSBiZWNvbWVzIHRoZSBwcmltYXJ5IElQdjYgYWRkcmVzcy5cbiAqL1xuRW5hYmxlUHJpbWFyeUlwdjY/OiBib29sZWFuXG4vKipcbiAqIEEgbGlzdCBvZiBzZWN1cml0eSBncm91cCBJRHMgYXNzb2NpYXRlZCB3aXRoIHRoaXMgbmV0d29yayBpbnRlcmZhY2UuXG4gKi9cbkdyb3VwU2V0Pzogc3RyaW5nW11cbi8qKlxuICogT25lIG9yIG1vcmUgc3BlY2lmaWMgSVB2NiBhZGRyZXNzZXMgZnJvbSB0aGUgSVB2NiBDSURSIGJsb2NrIHJhbmdlIG9mIHlvdXIgc3VibmV0IHRvIGFzc29jaWF0ZSB3aXRoIHRoZSBuZXR3b3JrIGludGVyZmFjZS4gSWYgeW91J3JlIHNwZWNpZnlpbmcgYSBudW1iZXIgb2YgSVB2NiBhZGRyZXNzZXMsIHVzZSB0aGUgSXB2NkFkZHJlc3NDb3VudCBwcm9wZXJ0eSBhbmQgZG9uJ3Qgc3BlY2lmeSB0aGlzIHByb3BlcnR5LlxuICovXG5JcHY2QWRkcmVzc2VzPzogSW5zdGFuY2VJcHY2QWRkcmVzc1tdXG4vKipcbiAqIEFzc2lnbnMgYSBsaXN0IG9mIElQdjYgcHJlZml4ZXMgdG8gdGhlIG5ldHdvcmsgaW50ZXJmYWNlLiBJZiB5b3Ugd2FudCBFQzIgdG8gYXV0b21hdGljYWxseSBhc3NpZ24gSVB2NiBwcmVmaXhlcywgdXNlIHRoZSBJcHY2UHJlZml4Q291bnQgcHJvcGVydHkgYW5kIGRvIG5vdCBzcGVjaWZ5IHRoaXMgcHJvcGVydHkuIFByZXNlbnRseSwgb25seSAvODAgcHJlZml4ZXMgYXJlIHN1cHBvcnRlZC4gWW91IGNhbid0IHNwZWNpZnkgSVB2NiBwcmVmaXhlcyBpZiB5b3UndmUgc3BlY2lmaWVkIG9uZSBvZiB0aGUgZm9sbG93aW5nOiBhIGNvdW50IG9mIElQdjYgcHJlZml4ZXMsIHNwZWNpZmljIElQdjYgYWRkcmVzc2VzLCBvciBhIGNvdW50IG9mIElQdjYgYWRkcmVzc2VzLlxuICovXG5JcHY2UHJlZml4ZXM/OiBJcHY2UHJlZml4U3BlY2lmaWNhdGlvbltdXG4vKipcbiAqIFRoZSBJRCBvZiB0aGUgc3VibmV0IHRvIGFzc29jaWF0ZSB3aXRoIHRoZSBuZXR3b3JrIGludGVyZmFjZS5cbiAqL1xuU3VibmV0SWQ6IHN0cmluZ1xuLyoqXG4gKiBJbmRpY2F0ZXMgd2hldGhlciB0cmFmZmljIHRvIG9yIGZyb20gdGhlIGluc3RhbmNlIGlzIHZhbGlkYXRlZC5cbiAqL1xuU291cmNlRGVzdENoZWNrPzogYm9vbGVhblxuLyoqXG4gKiBJbmRpY2F0ZXMgdGhlIHR5cGUgb2YgbmV0d29yayBpbnRlcmZhY2UuXG4gKi9cbkludGVyZmFjZVR5cGU/OiBzdHJpbmdcbi8qKlxuICogUmV0dXJucyB0aGUgc2Vjb25kYXJ5IHByaXZhdGUgSVAgYWRkcmVzc2VzIG9mIHRoZSBuZXR3b3JrIGludGVyZmFjZS5cbiAqL1xuU2Vjb25kYXJ5UHJpdmF0ZUlwQWRkcmVzc2VzPzogc3RyaW5nW11cbi8qKlxuICogVGhlIElEIG9mIHRoZSBWUENcbiAqL1xuVnBjSWQ/OiBzdHJpbmdcbi8qKlxuICogVGhlIG51bWJlciBvZiBJUHY2IGFkZHJlc3NlcyB0byBhc3NpZ24gdG8gYSBuZXR3b3JrIGludGVyZmFjZS4gQW1hem9uIEVDMiBhdXRvbWF0aWNhbGx5IHNlbGVjdHMgdGhlIElQdjYgYWRkcmVzc2VzIGZyb20gdGhlIHN1Ym5ldCByYW5nZS4gVG8gc3BlY2lmeSBzcGVjaWZpYyBJUHY2IGFkZHJlc3NlcywgdXNlIHRoZSBJcHY2QWRkcmVzc2VzIHByb3BlcnR5IGFuZCBkb24ndCBzcGVjaWZ5IHRoaXMgcHJvcGVydHkuXG4gKi9cbklwdjZBZGRyZXNzQ291bnQ/OiBudW1iZXJcbi8qKlxuICogTmV0d29yayBpbnRlcmZhY2UgaWQuXG4gKi9cbklkPzogc3RyaW5nXG4vKipcbiAqIEFuIGFyYml0cmFyeSBzZXQgb2YgdGFncyAoa2V5LXZhbHVlIHBhaXJzKSBmb3IgdGhpcyBuZXR3b3JrIGludGVyZmFjZS5cbiAqL1xuVGFncz86IFRhZ1tdXG5Db25uZWN0aW9uVHJhY2tpbmdTcGVjaWZpY2F0aW9uPzogQ29ubmVjdGlvblRyYWNraW5nU3BlY2lmaWNhdGlvblxufVxuZXhwb3J0IGludGVyZmFjZSBQcml2YXRlSXBBZGRyZXNzU3BlY2lmaWNhdGlvbiB7XG5Qcml2YXRlSXBBZGRyZXNzOiBzdHJpbmdcblByaW1hcnk6IGJvb2xlYW5cbn1cbmV4cG9ydCBpbnRlcmZhY2UgSXB2NFByZWZpeFNwZWNpZmljYXRpb24ge1xuSXB2NFByZWZpeDogc3RyaW5nXG59XG5leHBvcnQgaW50ZXJmYWNlIEluc3RhbmNlSXB2NkFkZHJlc3Mge1xuSXB2NkFkZHJlc3M6IHN0cmluZ1xufVxuZXhwb3J0IGludGVyZmFjZSBJcHY2UHJlZml4U3BlY2lmaWNhdGlvbiB7XG5JcHY2UHJlZml4OiBzdHJpbmdcbn1cbmV4cG9ydCBpbnRlcmZhY2UgVGFnIHtcblZhbHVlOiBzdHJpbmdcbktleTogc3RyaW5nXG59XG5leHBvcnQgaW50ZXJmYWNlIENvbm5lY3Rpb25UcmFja2luZ1NwZWNpZmljYXRpb24ge1xuVWRwVGltZW91dD86IG51bWJlclxuVGNwRXN0YWJsaXNoZWRUaW1lb3V0PzogbnVtYmVyXG5VZHBTdHJlYW1UaW1lb3V0PzogbnVtYmVyXG59XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-ec2-networkinterface.js","sourceRoot":"","sources":["aws-ec2-networkinterface.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * The AWS::EC2::NetworkInterface resource creates network interface\n */\nexport interface _AWS_EC2_NETWORKINTERFACE {\n/**\n * A description for the network interface.\n */\nDescription?: string\n/**\n * Assigns a single private IP address to the network interface, which is used as the primary private IP address. If you want to specify multiple private IP address, use the PrivateIpAddresses property. \n */\nPrivateIpAddress?: string\n/**\n * Assigns a list of private IP addresses to the network interface. You can specify a primary private IP address by setting the value of the Primary property to true in the PrivateIpAddressSpecification property. If you want EC2 to automatically assign private IP addresses, use the SecondaryPrivateIpAddressCount property and do not specify this property.\n */\nPrivateIpAddresses?: PrivateIpAddressSpecification[]\n/**\n * The number of secondary private IPv4 addresses to assign to a network interface. When you specify a number of secondary IPv4 addresses, Amazon EC2 selects these IP addresses within the subnet's IPv4 CIDR range. You can't specify this option and specify more than one private IP address using privateIpAddresses\n */\nSecondaryPrivateIpAddressCount?: number\n/**\n * Returns the primary private IP address of the network interface.\n */\nPrimaryPrivateIpAddress?: string\n/**\n * Assigns a list of IPv4 prefixes to the network interface. If you want EC2 to automatically assign IPv4 prefixes, use the Ipv4PrefixCount property and do not specify this property. Presently, only /28 prefixes are supported. You can't specify IPv4 prefixes if you've specified one of the following: a count of IPv4 prefixes, specific private IPv4 addresses, or a count of private IPv4 addresses.\n */\nIpv4Prefixes?: Ipv4PrefixSpecification[]\n/**\n * The number of IPv4 prefixes to assign to a network interface. When you specify a number of IPv4 prefixes, Amazon EC2 selects these prefixes from your existing subnet CIDR reservations, if available, or from free spaces in the subnet. By default, these will be /28 prefixes. You can't specify a count of IPv4 prefixes if you've specified one of the following: specific IPv4 prefixes, specific private IPv4 addresses, or a count of private IPv4 addresses.\n */\nIpv4PrefixCount?: number\n/**\n * A list of security group IDs associated with this network interface.\n */\nGroupSet?: string[]\n/**\n * One or more specific IPv6 addresses from the IPv6 CIDR block range of your subnet to associate with the network interface. If you're specifying a number of IPv6 addresses, use the Ipv6AddressCount property and don't specify this property.\n */\nIpv6Addresses?: InstanceIpv6Address[]\n/**\n * Assigns a list of IPv6 prefixes to the network interface. If you want EC2 to automatically assign IPv6 prefixes, use the Ipv6PrefixCount property and do not specify this property. Presently, only /80 prefixes are supported. You can't specify IPv6 prefixes if you've specified one of the following: a count of IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.\n */\nIpv6Prefixes?: Ipv6PrefixSpecification[]\n/**\n * The number of IPv6 prefixes to assign to a network interface. When you specify a number of IPv6 prefixes, Amazon EC2 selects these prefixes from your existing subnet CIDR reservations, if available, or from free spaces in the subnet. By default, these will be /80 prefixes. You can't specify a count of IPv6 prefixes if you've specified one of the following: specific IPv6 prefixes, specific IPv6 addresses, or a count of IPv6 addresses.\n */\nIpv6PrefixCount?: number\n/**\n * The ID of the subnet to associate with the network interface.\n */\nSubnetId: string\n/**\n * Indicates whether traffic to or from the instance is validated.\n */\nSourceDestCheck?: boolean\n/**\n * Indicates the type of network interface.\n */\nInterfaceType?: string\n/**\n * Returns the secondary private IP addresses of the network interface.\n */\nSecondaryPrivateIpAddresses?: string[]\n/**\n * The number of IPv6 addresses to assign to a network interface. Amazon EC2 automatically selects the IPv6 addresses from the subnet range. To specify specific IPv6 addresses, use the Ipv6Addresses property and don't specify this property.\n */\nIpv6AddressCount?: number\n/**\n * If you have instances or ENIs that rely on the IPv6 address not changing, to avoid disrupting traffic to instances or ENIs, you can enable a primary IPv6 address. Enable this option to automatically assign an IPv6 associated with the ENI attached to your instance to be the primary IPv6 address. When you enable an IPv6 address to be a primary IPv6, you cannot disable it. Traffic will be routed to the primary IPv6 address until the instance is terminated or the ENI is detached. If you have multiple IPv6 addresses associated with an ENI and you enable a primary IPv6 address, the first IPv6 address associated with the ENI becomes the primary IPv6 address.\n */\nEnablePrimaryIpv6?: boolean\n/**\n * The primary IPv6 address\n */\nPrimaryIpv6Address?: string\nConnectionTrackingSpecification?: ConnectionTrackingSpecification\n/**\n * Network interface id.\n */\nId?: string\n/**\n * An arbitrary set of tags (key-value pairs) for this network interface.\n */\nTags?: Tag[]\n/**\n * The ID of the VPC\n */\nVpcId?: string\n/**\n * Public IP DNS hostname type\n */\nPublicIpDnsHostnameTypeSpecification?: (\"public-dual-stack-dns-name\" | \"public-ipv4-dns-name\" | \"public-ipv6-dns-name\")\nPublicIpDnsNameOptions?: PublicIpDnsNameOptions\n}\nexport interface PrivateIpAddressSpecification {\nPrivateIpAddress: string\nPrimary: boolean\n}\nexport interface Ipv4PrefixSpecification {\nIpv4Prefix: string\n}\nexport interface InstanceIpv6Address {\nIpv6Address: string\n}\nexport interface Ipv6PrefixSpecification {\nIpv6Prefix: string\n}\nexport interface ConnectionTrackingSpecification {\nTcpEstablishedTimeout?: number\nUdpStreamTimeout?: number\nUdpTimeout?: number\n}\nexport interface Tag {\nValue: string\nKey: string\n}\n/**\n * Describes the public hostname type options, including public hostname type, IPv4-enabled public hostname, IPv6-enabled public hostname, and dual-stack public hostname.\n */\nexport interface PublicIpDnsNameOptions {\nDnsHostnameType?: string\nPublicIpv4DnsName?: string\nPublicIpv6DnsName?: string\nPublicDualStackDnsName?: string\n}\n"]}
@@ -113,6 +113,10 @@ export interface Taint {
113
113
  * The node group update configuration.
114
114
  */
115
115
  export interface UpdateConfig {
116
+ /**
117
+ * The configuration for the behavior to follow during an node group version update of this managed node group. You choose between two possible strategies for replacing nodes during an UpdateNodegroupVersion action.
118
+ */
119
+ UpdateStrategy?: string;
116
120
  /**
117
121
  * The maximum number of nodes unavailable at once during a version update. Nodes will be updated in parallel. This value or maxUnavailablePercentage is required to have a value.The maximum number is 100.
118
122
  */
@@ -121,10 +125,6 @@ export interface UpdateConfig {
121
125
  * The maximum percentage of nodes unavailable during a version update. This percentage of nodes will be updated in parallel, up to 100 nodes at once. This value or maxUnavailable is required to have a value.
122
126
  */
123
127
  MaxUnavailablePercentage?: number;
124
- /**
125
- * The configuration for the behavior to follow during an node group version update of this managed node group. You choose between two possible strategies for replacing nodes during an UpdateNodegroupVersion action.
126
- */
127
- UpdateStrategy?: string;
128
128
  }
129
129
  /**
130
130
  * The node auto repair configuration for node group.
@@ -134,4 +134,45 @@ export interface NodeRepairConfig {
134
134
  * Set this value to true to enable node auto repair for the node group.
135
135
  */
136
136
  Enabled?: boolean;
137
+ /**
138
+ * Specify a count threshold of unhealthy nodes, above which node auto repair actions will stop. When using this, you cannot also set MaxUnhealthyNodeThresholdPercentage at the same time.
139
+ */
140
+ MaxUnhealthyNodeThresholdCount?: number;
141
+ /**
142
+ * Specify a percentage threshold of unhealthy nodes, above which node auto repair actions will stop. When using this, you cannot also set MaxUnhealthyNodeThresholdCount at the same time.
143
+ */
144
+ MaxUnhealthyNodeThresholdPercentage?: number;
145
+ /**
146
+ * Specify the maximum number of nodes that can be repaired concurrently or in parallel, expressed as a count of unhealthy nodes. This gives you finer-grained control over the pace of node replacements. When using this, you cannot also set MaxParallelNodesRepairedPercentage at the same time.
147
+ */
148
+ MaxParallelNodesRepairedCount?: number;
149
+ /**
150
+ * Specify the maximum number of nodes that can be repaired concurrently or in parallel, expressed as a percentage of unhealthy nodes. This gives you finer-grained control over the pace of node replacements. When using this, you cannot also set MaxParallelNodesRepairedCount at the same time.
151
+ */
152
+ MaxParallelNodesRepairedPercentage?: number;
153
+ /**
154
+ * Specify granular overrides for specific repair actions. These overrides control the repair action and the repair delay time before a node is considered eligible for repair. If you use this, you must specify all the values.
155
+ */
156
+ NodeRepairConfigOverrides?: NodeRepairConfigOverrides[];
157
+ }
158
+ /**
159
+ * Specify granular overrides for specific repair actions. These overrides control the repair action and the repair delay time before a node is considered eligible for repair. If you use this, you must specify all the values.
160
+ */
161
+ export interface NodeRepairConfigOverrides {
162
+ /**
163
+ * Specify an unhealthy condition reported by the node monitoring agent that this override would apply to.
164
+ */
165
+ NodeMonitoringCondition?: string;
166
+ /**
167
+ * Specify a reason reported by the node monitoring agent that this override would apply to.
168
+ */
169
+ NodeUnhealthyReason?: string;
170
+ /**
171
+ * Specify the minimum time in minutes to wait before attempting to repair a node with this specific NodeMonitoringCondition and NodeUnhealthyReason.
172
+ */
173
+ MinRepairWaitTimeMins?: number;
174
+ /**
175
+ * Specify the repair action to take for nodes when all of the specified conditions are met.
176
+ */
177
+ RepairAction?: ("Replace" | "Reboot" | "NoAction");
137
178
  }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWVrcy1ub2RlZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhd3MtZWtzLW5vZGVncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBSZXNvdXJjZSBzY2hlbWEgZm9yIEFXUzo6RUtTOjpOb2RlZ3JvdXBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBfQVdTX0VLU19OT0RFR1JPVVAge1xuLyoqXG4gKiBUaGUgQU1JIHR5cGUgZm9yIHlvdXIgbm9kZSBncm91cC5cbiAqL1xuQW1pVHlwZT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgY2FwYWNpdHkgdHlwZSBvZiB5b3VyIG1hbmFnZWQgbm9kZSBncm91cC5cbiAqL1xuQ2FwYWNpdHlUeXBlPzogc3RyaW5nXG4vKipcbiAqIE5hbWUgb2YgdGhlIGNsdXN0ZXIgdG8gY3JlYXRlIHRoZSBub2RlIGdyb3VwIGluLlxuICovXG5DbHVzdGVyTmFtZTogc3RyaW5nXG4vKipcbiAqIFRoZSByb290IGRldmljZSBkaXNrIHNpemUgKGluIEdpQikgZm9yIHlvdXIgbm9kZSBncm91cCBpbnN0YW5jZXMuXG4gKi9cbkRpc2tTaXplPzogbnVtYmVyXG4vKipcbiAqIEZvcmNlIHRoZSB1cGRhdGUgaWYgdGhlIGV4aXN0aW5nIG5vZGUgZ3JvdXAncyBwb2RzIGFyZSB1bmFibGUgdG8gYmUgZHJhaW5lZCBkdWUgdG8gYSBwb2QgZGlzcnVwdGlvbiBidWRnZXQgaXNzdWUuXG4gKi9cbkZvcmNlVXBkYXRlRW5hYmxlZD86IGJvb2xlYW5cbi8qKlxuICogU3BlY2lmeSB0aGUgaW5zdGFuY2UgdHlwZXMgZm9yIGEgbm9kZSBncm91cC5cbiAqL1xuSW5zdGFuY2VUeXBlcz86IHN0cmluZ1tdXG4vKipcbiAqIFRoZSBLdWJlcm5ldGVzIGxhYmVscyB0byBiZSBhcHBsaWVkIHRvIHRoZSBub2RlcyBpbiB0aGUgbm9kZSBncm91cCB3aGVuIHRoZXkgYXJlIGNyZWF0ZWQuXG4gKi9cbkxhYmVscz86IHtcbi8qKlxuICogVGhpcyBpbnRlcmZhY2Ugd2FzIHJlZmVyZW5jZWQgYnkgYHVuZGVmaW5lZGAncyBKU09OLVNjaGVtYSBkZWZpbml0aW9uXG4gKiB2aWEgdGhlIGBwYXR0ZXJuUHJvcGVydHlgIFwiXi4rJFwiLlxuICovXG5bazogc3RyaW5nXTogc3RyaW5nXG59XG5MYXVuY2hUZW1wbGF0ZT86IExhdW5jaFRlbXBsYXRlU3BlY2lmaWNhdGlvblxuLyoqXG4gKiBUaGUgdW5pcXVlIG5hbWUgdG8gZ2l2ZSB5b3VyIG5vZGUgZ3JvdXAuXG4gKi9cbk5vZGVncm91cE5hbWU/OiBzdHJpbmdcbi8qKlxuICogVGhlIEFtYXpvbiBSZXNvdXJjZSBOYW1lIChBUk4pIG9mIHRoZSBJQU0gcm9sZSB0byBhc3NvY2lhdGUgd2l0aCB5b3VyIG5vZGUgZ3JvdXAuXG4gKi9cbk5vZGVSb2xlOiBzdHJpbmdcbi8qKlxuICogVGhlIEFNSSB2ZXJzaW9uIG9mIHRoZSBBbWF6b24gRUtTLW9wdGltaXplZCBBTUkgdG8gdXNlIHdpdGggeW91ciBub2RlIGdyb3VwLlxuICovXG5SZWxlYXNlVmVyc2lvbj86IHN0cmluZ1xuUmVtb3RlQWNjZXNzPzogUmVtb3RlQWNjZXNzXG5TY2FsaW5nQ29uZmlnPzogU2NhbGluZ0NvbmZpZ1xuLyoqXG4gKiBUaGUgc3VibmV0cyB0byB1c2UgZm9yIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgdGhhdCBpcyBjcmVhdGVkIGZvciB5b3VyIG5vZGUgZ3JvdXAuXG4gKi9cblN1Ym5ldHM6IHN0cmluZ1tdXG4vKipcbiAqIFRoZSBtZXRhZGF0YSwgYXMga2V5LXZhbHVlIHBhaXJzLCB0byBhcHBseSB0byB0aGUgbm9kZSBncm91cCB0byBhc3Npc3Qgd2l0aCBjYXRlZ29yaXphdGlvbiBhbmQgb3JnYW5pemF0aW9uLiBGb2xsb3dzIHNhbWUgc2NoZW1hIGFzIExhYmVscyBmb3IgY29uc2lzdGVuY3kuXG4gKi9cblRhZ3M/OiB7XG4vKipcbiAqIFRoaXMgaW50ZXJmYWNlIHdhcyByZWZlcmVuY2VkIGJ5IGB1bmRlZmluZWRgJ3MgSlNPTi1TY2hlbWEgZGVmaW5pdGlvblxuICogdmlhIHRoZSBgcGF0dGVyblByb3BlcnR5YCBcIl4uKyRcIi5cbiAqL1xuW2s6IHN0cmluZ106IHN0cmluZ1xufVxuLyoqXG4gKiBUaGUgS3ViZXJuZXRlcyB0YWludHMgdG8gYmUgYXBwbGllZCB0byB0aGUgbm9kZXMgaW4gdGhlIG5vZGUgZ3JvdXAgd2hlbiB0aGV5IGFyZSBjcmVhdGVkLlxuICovXG5UYWludHM/OiBUYWludFtdXG5VcGRhdGVDb25maWc/OiBVcGRhdGVDb25maWdcbk5vZGVSZXBhaXJDb25maWc/OiBOb2RlUmVwYWlyQ29uZmlnXG4vKipcbiAqIFRoZSBLdWJlcm5ldGVzIHZlcnNpb24gdG8gdXNlIGZvciB5b3VyIG1hbmFnZWQgbm9kZXMuXG4gKi9cblZlcnNpb24/OiBzdHJpbmdcbklkPzogc3RyaW5nXG5Bcm4/OiBzdHJpbmdcbn1cbi8qKlxuICogQW4gb2JqZWN0IHJlcHJlc2VudGluZyBhIG5vZGUgZ3JvdXAncyBsYXVuY2ggdGVtcGxhdGUgc3BlY2lmaWNhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMYXVuY2hUZW1wbGF0ZVNwZWNpZmljYXRpb24ge1xuSWQ/OiBzdHJpbmdcblZlcnNpb24/OiBzdHJpbmdcbk5hbWU/OiBzdHJpbmdcbn1cbi8qKlxuICogVGhlIHJlbW90ZSBhY2Nlc3MgKFNTSCkgY29uZmlndXJhdGlvbiB0byB1c2Ugd2l0aCB5b3VyIG5vZGUgZ3JvdXAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVtb3RlQWNjZXNzIHtcblNvdXJjZVNlY3VyaXR5R3JvdXBzPzogc3RyaW5nW11cbkVjMlNzaEtleTogc3RyaW5nXG59XG4vKipcbiAqIFRoZSBzY2FsaW5nIGNvbmZpZ3VyYXRpb24gZGV0YWlscyBmb3IgdGhlIEF1dG8gU2NhbGluZyBncm91cCB0aGF0IGlzIGNyZWF0ZWQgZm9yIHlvdXIgbm9kZSBncm91cC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTY2FsaW5nQ29uZmlnIHtcbk1pblNpemU/OiBudW1iZXJcbkRlc2lyZWRTaXplPzogbnVtYmVyXG5NYXhTaXplPzogbnVtYmVyXG59XG4vKipcbiAqIEFuIG9iamVjdCByZXByZXNlbnRpbmcgYSBUYWludCBzcGVjaWZpY2F0aW9uIGZvciBBV1MgRUtTIE5vZGVncm91cC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYWludCB7XG5LZXk/OiBzdHJpbmdcblZhbHVlPzogc3RyaW5nXG5FZmZlY3Q/OiBzdHJpbmdcbn1cbi8qKlxuICogVGhlIG5vZGUgZ3JvdXAgdXBkYXRlIGNvbmZpZ3VyYXRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlQ29uZmlnIHtcbi8qKlxuICogVGhlIG1heGltdW0gbnVtYmVyIG9mIG5vZGVzIHVuYXZhaWxhYmxlIGF0IG9uY2UgZHVyaW5nIGEgdmVyc2lvbiB1cGRhdGUuIE5vZGVzIHdpbGwgYmUgdXBkYXRlZCBpbiBwYXJhbGxlbC4gVGhpcyB2YWx1ZSBvciBtYXhVbmF2YWlsYWJsZVBlcmNlbnRhZ2UgaXMgcmVxdWlyZWQgdG8gaGF2ZSBhIHZhbHVlLlRoZSBtYXhpbXVtIG51bWJlciBpcyAxMDAuIFxuICovXG5NYXhVbmF2YWlsYWJsZT86IG51bWJlclxuLyoqXG4gKiBUaGUgbWF4aW11bSBwZXJjZW50YWdlIG9mIG5vZGVzIHVuYXZhaWxhYmxlIGR1cmluZyBhIHZlcnNpb24gdXBkYXRlLiBUaGlzIHBlcmNlbnRhZ2Ugb2Ygbm9kZXMgd2lsbCBiZSB1cGRhdGVkIGluIHBhcmFsbGVsLCB1cCB0byAxMDAgbm9kZXMgYXQgb25jZS4gVGhpcyB2YWx1ZSBvciBtYXhVbmF2YWlsYWJsZSBpcyByZXF1aXJlZCB0byBoYXZlIGEgdmFsdWUuXG4gKi9cbk1heFVuYXZhaWxhYmxlUGVyY2VudGFnZT86IG51bWJlclxuLyoqXG4gKiBUaGUgY29uZmlndXJhdGlvbiBmb3IgdGhlIGJlaGF2aW9yIHRvIGZvbGxvdyBkdXJpbmcgYW4gbm9kZSBncm91cCB2ZXJzaW9uIHVwZGF0ZSBvZiB0aGlzIG1hbmFnZWQgbm9kZSBncm91cC4gWW91IGNob29zZSBiZXR3ZWVuIHR3byBwb3NzaWJsZSBzdHJhdGVnaWVzIGZvciByZXBsYWNpbmcgbm9kZXMgZHVyaW5nIGFuIFVwZGF0ZU5vZGVncm91cFZlcnNpb24gYWN0aW9uLlxuICovXG5VcGRhdGVTdHJhdGVneT86IHN0cmluZ1xufVxuLyoqXG4gKiBUaGUgbm9kZSBhdXRvIHJlcGFpciBjb25maWd1cmF0aW9uIGZvciBub2RlIGdyb3VwLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5vZGVSZXBhaXJDb25maWcge1xuLyoqXG4gKiBTZXQgdGhpcyB2YWx1ZSB0byB0cnVlIHRvIGVuYWJsZSBub2RlIGF1dG8gcmVwYWlyIGZvciB0aGUgbm9kZSBncm91cC5cbiAqL1xuRW5hYmxlZD86IGJvb2xlYW5cbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-eks-nodegroup.js","sourceRoot":"","sources":["aws-eks-nodegroup.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * Resource schema for AWS::EKS::Nodegroup\n */\nexport interface _AWS_EKS_NODEGROUP {\n/**\n * The AMI type for your node group.\n */\nAmiType?: string\n/**\n * The capacity type of your managed node group.\n */\nCapacityType?: string\n/**\n * Name of the cluster to create the node group in.\n */\nClusterName: string\n/**\n * The root device disk size (in GiB) for your node group instances.\n */\nDiskSize?: number\n/**\n * Force the update if the existing node group's pods are unable to be drained due to a pod disruption budget issue.\n */\nForceUpdateEnabled?: boolean\n/**\n * Specify the instance types for a node group.\n */\nInstanceTypes?: string[]\n/**\n * The Kubernetes labels to be applied to the nodes in the node group when they are created.\n */\nLabels?: {\n/**\n * This interface was referenced by `undefined`'s JSON-Schema definition\n * via the `patternProperty` \"^.+$\".\n */\n[k: string]: string\n}\nLaunchTemplate?: LaunchTemplateSpecification\n/**\n * The unique name to give your node group.\n */\nNodegroupName?: string\n/**\n * The Amazon Resource Name (ARN) of the IAM role to associate with your node group.\n */\nNodeRole: string\n/**\n * The AMI version of the Amazon EKS-optimized AMI to use with your node group.\n */\nReleaseVersion?: string\nRemoteAccess?: RemoteAccess\nScalingConfig?: ScalingConfig\n/**\n * The subnets to use for the Auto Scaling group that is created for your node group.\n */\nSubnets: string[]\n/**\n * The metadata, as key-value pairs, to apply to the node group to assist with categorization and organization. Follows same schema as Labels for consistency.\n */\nTags?: {\n/**\n * This interface was referenced by `undefined`'s JSON-Schema definition\n * via the `patternProperty` \"^.+$\".\n */\n[k: string]: string\n}\n/**\n * The Kubernetes taints to be applied to the nodes in the node group when they are created.\n */\nTaints?: Taint[]\nUpdateConfig?: UpdateConfig\nNodeRepairConfig?: NodeRepairConfig\n/**\n * The Kubernetes version to use for your managed nodes.\n */\nVersion?: string\nId?: string\nArn?: string\n}\n/**\n * An object representing a node group's launch template specification.\n */\nexport interface LaunchTemplateSpecification {\nId?: string\nVersion?: string\nName?: string\n}\n/**\n * The remote access (SSH) configuration to use with your node group.\n */\nexport interface RemoteAccess {\nSourceSecurityGroups?: string[]\nEc2SshKey: string\n}\n/**\n * The scaling configuration details for the Auto Scaling group that is created for your node group.\n */\nexport interface ScalingConfig {\nMinSize?: number\nDesiredSize?: number\nMaxSize?: number\n}\n/**\n * An object representing a Taint specification for AWS EKS Nodegroup.\n */\nexport interface Taint {\nKey?: string\nValue?: string\nEffect?: string\n}\n/**\n * The node group update configuration.\n */\nexport interface UpdateConfig {\n/**\n * The configuration for the behavior to follow during an node group version update of this managed node group. You choose between two possible strategies for replacing nodes during an UpdateNodegroupVersion action.\n */\nUpdateStrategy?: string\n/**\n * The maximum number of nodes unavailable at once during a version update. Nodes will be updated in parallel. This value or maxUnavailablePercentage is required to have a value.The maximum number is 100. \n */\nMaxUnavailable?: number\n/**\n * The maximum percentage of nodes unavailable during a version update. This percentage of nodes will be updated in parallel, up to 100 nodes at once. This value or maxUnavailable is required to have a value.\n */\nMaxUnavailablePercentage?: number\n}\n/**\n * The node auto repair configuration for node group.\n */\nexport interface NodeRepairConfig {\n/**\n * Set this value to true to enable node auto repair for the node group.\n */\nEnabled?: boolean\n/**\n * Specify a count threshold of unhealthy nodes, above which node auto repair actions will stop. When using this, you cannot also set MaxUnhealthyNodeThresholdPercentage at the same time.\n */\nMaxUnhealthyNodeThresholdCount?: number\n/**\n * Specify a percentage threshold of unhealthy nodes, above which node auto repair actions will stop. When using this, you cannot also set MaxUnhealthyNodeThresholdCount at the same time.\n */\nMaxUnhealthyNodeThresholdPercentage?: number\n/**\n * Specify the maximum number of nodes that can be repaired concurrently or in parallel, expressed as a count of unhealthy nodes. This gives you finer-grained control over the pace of node replacements. When using this, you cannot also set MaxParallelNodesRepairedPercentage at the same time.\n */\nMaxParallelNodesRepairedCount?: number\n/**\n * Specify the maximum number of nodes that can be repaired concurrently or in parallel, expressed as a percentage of unhealthy nodes. This gives you finer-grained control over the pace of node replacements. When using this, you cannot also set MaxParallelNodesRepairedCount at the same time.\n */\nMaxParallelNodesRepairedPercentage?: number\n/**\n * Specify granular overrides for specific repair actions. These overrides control the repair action and the repair delay time before a node is considered eligible for repair. If you use this, you must specify all the values.\n */\nNodeRepairConfigOverrides?: NodeRepairConfigOverrides[]\n}\n/**\n * Specify granular overrides for specific repair actions. These overrides control the repair action and the repair delay time before a node is considered eligible for repair. If you use this, you must specify all the values.\n */\nexport interface NodeRepairConfigOverrides {\n/**\n * Specify an unhealthy condition reported by the node monitoring agent that this override would apply to.\n */\nNodeMonitoringCondition?: string\n/**\n * Specify a reason reported by the node monitoring agent that this override would apply to.\n */\nNodeUnhealthyReason?: string\n/**\n * Specify the minimum time in minutes to wait before attempting to repair a node with this specific NodeMonitoringCondition and NodeUnhealthyReason.\n */\nMinRepairWaitTimeMins?: number\n/**\n * Specify the repair action to take for nodes when all of the specified conditions are met.\n */\nRepairAction?: (\"Replace\" | \"Reboot\" | \"NoAction\")\n}\n"]}
@@ -102,7 +102,7 @@ export interface _AWS_ELASTICLOADBALANCINGV2_LISTENER {
102
102
  */
103
103
  Certificates?: Certificate[];
104
104
  /**
105
- * The protocol for connections from clients to the load balancer. For Application Load Balancers, the supported protocols are HTTP and HTTPS. For Network Load Balancers, the supported protocols are TCP, TLS, UDP, and TCP_UDP. You can’t specify the UDP or TCP_UDP protocol if dual-stack mode is enabled. You can't specify a protocol for a Gateway Load Balancer.
105
+ * The protocol for connections from clients to the load balancer. For Application Load Balancers, the supported protocols are HTTP and HTTPS. For Network Load Balancers, the supported protocols are TCP, TLS, UDP, TCP_UDP, QUIC, and TCP_QUIC. You can’t specify the UDP, TCP_UDP, QUIC, or TCP_QUIC protocol if dual-stack mode is enabled. You can't specify a protocol for a Gateway Load Balancer.
106
106
  */
107
107
  Protocol?: string;
108
108
  }
@@ -282,14 +282,29 @@ export interface RedirectConfig {
282
282
  */
283
283
  StatusCode: string;
284
284
  }
285
+ /**
286
+ * [HTTPS listeners] Information for validating JWT access tokens in client requests. Specify only when ``Type`` is ``jwt-validation``.
287
+ */
285
288
  export interface JwtValidationConfig {
286
289
  JwksEndpoint: string;
287
290
  Issuer: string;
288
291
  AdditionalClaims?: JwtValidationActionAdditionalClaim[];
289
292
  }
293
+ /**
294
+ * Information about an additional claim to validate.
295
+ */
290
296
  export interface JwtValidationActionAdditionalClaim {
297
+ /**
298
+ * The format of the claim value.
299
+ */
291
300
  Format: string;
301
+ /**
302
+ * The claim value. The maximum size of the list is 10. Each value can be up to 256 characters in length. If the format is ``space-separated-values``, the values can't include spaces.
303
+ */
292
304
  Values: string[];
305
+ /**
306
+ * The name of the claim. You can't specify ``exp``, ``iss``, ``nbf``, or ``iat`` because we validate them by default.
307
+ */
293
308
  Name: string;
294
309
  }
295
310
  /**
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-elasticloadbalancingv2-listener.js","sourceRoot":"","sources":["aws-elasticloadbalancingv2-listener.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * [HTTPS listeners] Information about an identity provider that is compliant with OpenID Connect (OIDC). Specify only when ``Type`` is ``authenticate-oidc``.\n */\nexport type AuthenticateOidcConfig = ({\n[k: string]: unknown\n} & {\n/**\n * The behavior if the user is not authenticated. The following are possible values:\n *   +  deny```` - Return an HTTP 401 Unauthorized error.\n *   +  allow```` - Allow the request to be forwarded to the target.\n *   +  authenticate```` - Redirect the request to the IdP authorization endpoint. This is the default value.\n */\nOnUnauthenticatedRequest?: string\n/**\n * The token endpoint of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nTokenEndpoint: string\n/**\n * Indicates whether to use the existing client secret when modifying a rule. If you are creating a rule, you can omit this parameter or set it to false.\n */\nUseExistingClientSecret?: boolean\n/**\n * The maximum duration of the authentication session, in seconds. The default is 604800 seconds (7 days).\n */\nSessionTimeout?: string\n/**\n * The set of user claims to be requested from the IdP. The default is ``openid``.\n *  To verify which scope values your IdP supports and how to separate multiple values, see the documentation for your IdP.\n */\nScope?: string\n/**\n * The OIDC issuer identifier of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nIssuer: string\n/**\n * The OAuth 2.0 client secret. This parameter is required if you are creating a rule. If you are modifying a rule, you can omit this parameter if you set ``UseExistingClientSecret`` to true.\n */\nClientSecret?: string\n/**\n * The user info endpoint of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nUserInfoEndpoint: string\n/**\n * The OAuth 2.0 client identifier.\n */\nClientId: string\n/**\n * The authorization endpoint of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nAuthorizationEndpoint: string\n/**\n * The name of the cookie used to maintain session information. The default is AWSELBAuthSessionCookie.\n */\nSessionCookieName?: string\n/**\n * The query parameters (up to 10) to include in the redirect request to the authorization endpoint.\n */\nAuthenticationRequestExtraParams?: {\n/**\n * This interface was referenced by `undefined`'s JSON-Schema definition\n * via the `patternProperty` \"[a-zA-Z0-9]+\".\n */\n[k: string]: string\n}\n})\n\n/**\n * Specifies a listener for an Application Load Balancer, Network Load Balancer, or Gateway Load Balancer.\n */\nexport interface _AWS_ELASTICLOADBALANCINGV2_LISTENER {\nListenerArn?: string\nMutualAuthentication?: MutualAuthentication\n/**\n * The listener attributes. Attributes that you do not modify retain their current values.\n */\nListenerAttributes?: ListenerAttribute[]\n/**\n * [TLS listener] The name of the Application-Layer Protocol Negotiation (ALPN) policy.\n */\nAlpnPolicy?: string[]\n/**\n * [HTTPS and TLS listeners] The security policy that defines which protocols and ciphers are supported. For more information, see [Security policies](https://docs.aws.amazon.com/elasticloadbalancing/latest/application/describe-ssl-policies.html) in the *Application Load Balancers Guide* and [Security policies](https://docs.aws.amazon.com/elasticloadbalancing/latest/network/describe-ssl-policies.html) in the *Network Load Balancers Guide*.\n *  [HTTPS listeners] Updating the security policy can result in interruptions if the load balancer is handling a high volume of traffic. To decrease the possibility of an interruption if your load balancer is handling a high volume of traffic, create an additional load balancer or request an LCU reservation.\n */\nSslPolicy?: string\n/**\n * The Amazon Resource Name (ARN) of the load balancer.\n */\nLoadBalancerArn: string\n/**\n * The actions for the default rule. You cannot define a condition for a default rule.\n *  To create additional rules for an Application Load Balancer, use [AWS::ElasticLoadBalancingV2::ListenerRule](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-elasticloadbalancingv2-listenerrule.html).\n */\nDefaultActions: Action[]\n/**\n * The port on which the load balancer is listening. You can't specify a port for a Gateway Load Balancer.\n */\nPort?: number\n/**\n * The default SSL server certificate for a secure listener. You must provide exactly one certificate if the listener protocol is HTTPS or TLS.\n *  For an HTTPS listener, update requires some interruptions. For a TLS listener, update requires no interruption.\n *  To create a certificate list for a secure listener, use [AWS::ElasticLoadBalancingV2::ListenerCertificate](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-elasticloadbalancingv2-listenercertificate.html).\n */\nCertificates?: Certificate[]\n/**\n * The protocol for connections from clients to the load balancer. For Application Load Balancers, the supported protocols are HTTP and HTTPS. For Network Load Balancers, the supported protocols are TCP, TLS, UDP, and TCP_UDP. You can’t specify the UDP or TCP_UDP protocol if dual-stack mode is enabled. You can't specify a protocol for a Gateway Load Balancer.\n */\nProtocol?: string\n}\n/**\n * The mutual authentication configuration information.\n */\nexport interface MutualAuthentication {\n/**\n * Indicates whether expired client certificates are ignored.\n */\nIgnoreClientCertificateExpiry?: boolean\n/**\n * The client certificate handling method. Options are ``off``, ``passthrough`` or ``verify``. The default value is ``off``.\n */\nMode?: string\n/**\n * The Amazon Resource Name (ARN) of the trust store.\n */\nTrustStoreArn?: string\n/**\n * Indicates whether trust store CA certificate names are advertised.\n */\nAdvertiseTrustStoreCaNames?: string\n}\n/**\n * Information about a listener attribute.\n */\nexport interface ListenerAttribute {\n/**\n * The value of the attribute.\n */\nValue?: string\n/**\n * The name of the attribute.\n *  The following attribute is supported by Network Load Balancers, and Gateway Load Balancers.\n *   +  ``tcp.idle_timeout.seconds`` - The tcp idle timeout value, in seconds. The valid range is 60-6000 seconds. The default is 350 seconds.\n *   \n *  The following attributes are only supported by Application Load Balancers.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_serial_number.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Serial-Number* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_issuer.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Issuer* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_subject.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Subject* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_validity.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Validity* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_leaf.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Leaf* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert* HTTP request header.\n *   +  ``routing.http.request.x_amzn_tls_version.header_name`` - Enables you to modify the header name of the *X-Amzn-Tls-Version* HTTP request header.\n *   +  ``routing.http.request.x_amzn_tls_cipher_suite.header_name`` - Enables you to modify the header name of the *X-Amzn-Tls-Cipher-Suite* HTTP request header.\n *   +  ``routing.http.response.server.enabled`` - Enables you to allow or remove the HTTP response server header.\n *   +  ``routing.http.response.strict_transport_security.header_value`` - Informs browsers that the site should only be accessed using HTTPS, and that any future attempts to access it using HTTP should automatically be converted to HTTPS.\n *   +  ``routing.http.response.access_control_allow_origin.header_value`` - Specifies which origins are allowed to access the server.\n *   +  ``routing.http.response.access_control_allow_methods.header_value`` - Returns which HTTP methods are allowed when accessing the server from a different origin.\n *   +  ``routing.http.response.access_control_allow_headers.header_value`` - Specifies which headers can be used during the request.\n *   +  ``routing.http.response.access_control_allow_credentials.header_value`` - Indicates whether the browser should include credentials such as cookies or authentication when making requests.\n *   +  ``routing.http.response.access_control_expose_headers.header_value`` - Returns which headers the browser can expose to the requesting client.\n *   +  ``routing.http.response.access_control_max_age.header_value`` - Specifies how long the results of a preflight request can be cached, in seconds.\n *   +  ``routing.http.response.content_security_policy.header_value`` - Specifies restrictions enforced by the browser to help minimize the risk of certain types of security threats.\n *   +  ``routing.http.response.x_content_type_options.header_value`` - Indicates whether the MIME types advertised in the *Content-Type* headers should be followed and not be changed.\n *   +  ``routing.http.response.x_frame_options.header_value`` - Indicates whether the browser is allowed to render a page in a *frame*, *iframe*, *embed* or *object*.\n */\nKey?: string\n}\n/**\n * Specifies an action for a listener rule.\n */\nexport interface Action {\n/**\n * The order for the action. This value is required for rules with multiple actions. The action with the lowest value for order is performed first.\n */\nOrder?: number\n/**\n * The Amazon Resource Name (ARN) of the target group. Specify only when ``Type`` is ``forward`` and you want to route to a single target group. To route to multiple target groups, you must use ``ForwardConfig`` instead.\n */\nTargetGroupArn?: string\nFixedResponseConfig?: FixedResponseConfig\nAuthenticateCognitoConfig?: AuthenticateCognitoConfig\n/**\n * The type of action.\n */\nType: string\nRedirectConfig?: RedirectConfig\nJwtValidationConfig?: JwtValidationConfig\nForwardConfig?: ForwardConfig\nAuthenticateOidcConfig?: AuthenticateOidcConfig\n}\n/**\n * [Application Load Balancer] Information for creating an action that returns a custom HTTP response. Specify only when ``Type`` is ``fixed-response``.\n */\nexport interface FixedResponseConfig {\n/**\n * The content type.\n *  Valid Values: text/plain | text/css | text/html | application/javascript | application/json\n */\nContentType?: string\n/**\n * The HTTP response code (2XX, 4XX, or 5XX).\n */\nStatusCode: string\n/**\n * The message.\n */\nMessageBody?: string\n}\n/**\n * [HTTPS listeners] Information for using Amazon Cognito to authenticate users. Specify only when ``Type`` is ``authenticate-cognito``.\n */\nexport interface AuthenticateCognitoConfig {\n/**\n * The behavior if the user is not authenticated. The following are possible values:\n *   +  deny```` - Return an HTTP 401 Unauthorized error.\n *   +  allow```` - Allow the request to be forwarded to the target.\n *   +  authenticate```` - Redirect the request to the IdP authorization endpoint. This is the default value.\n */\nOnUnauthenticatedRequest?: string\n/**\n * The ID of the Amazon Cognito user pool client.\n */\nUserPoolClientId: ({\n[k: string]: unknown\n} & string)\n/**\n * The domain prefix or fully-qualified domain name of the Amazon Cognito user pool.\n */\nUserPoolDomain: string\n/**\n * The maximum duration of the authentication session, in seconds. The default is 604800 seconds (7 days).\n */\nSessionTimeout?: string\n/**\n * The set of user claims to be requested from the IdP. The default is ``openid``.\n *  To verify which scope values your IdP supports and how to separate multiple values, see the documentation for your IdP.\n */\nScope?: string\n/**\n * The name of the cookie used to maintain session information. The default is AWSELBAuthSessionCookie.\n */\nSessionCookieName?: string\n/**\n * The Amazon Resource Name (ARN) of the Amazon Cognito user pool.\n */\nUserPoolArn: string\n/**\n * The query parameters (up to 10) to include in the redirect request to the authorization endpoint.\n */\nAuthenticationRequestExtraParams?: {\n/**\n * This interface was referenced by `undefined`'s JSON-Schema definition\n * via the `patternProperty` \"[a-zA-Z0-9]+\".\n */\n[k: string]: string\n}\n}\n/**\n * [Application Load Balancer] Information for creating a redirect action. Specify only when ``Type`` is ``redirect``.\n */\nexport interface RedirectConfig {\n/**\n * The absolute path, starting with the leading \"/\". This component is not percent-encoded. The path can contain #{host}, #{path}, and #{port}.\n */\nPath?: string\n/**\n * The query parameters, URL-encoded when necessary, but not percent-encoded. Do not include the leading \"?\", as it is automatically added. You can specify any of the reserved keywords.\n */\nQuery?: string\n/**\n * The port. You can specify a value from 1 to 65535 or #{port}.\n */\nPort?: string\n/**\n * The hostname. This component is not percent-encoded. The hostname can contain #{host}.\n */\nHost?: string\n/**\n * The protocol. You can specify HTTP, HTTPS, or #{protocol}. You can redirect HTTP to HTTP, HTTP to HTTPS, and HTTPS to HTTPS. You can't redirect HTTPS to HTTP.\n */\nProtocol?: string\n/**\n * The HTTP redirect code. The redirect is either permanent (HTTP 301) or temporary (HTTP 302).\n */\nStatusCode: string\n}\nexport interface JwtValidationConfig {\nJwksEndpoint: string\nIssuer: string\nAdditionalClaims?: JwtValidationActionAdditionalClaim[]\n}\nexport interface JwtValidationActionAdditionalClaim {\nFormat: string\nValues: string[]\nName: string\n}\n/**\n * Information for creating an action that distributes requests among multiple target groups. Specify only when ``Type`` is ``forward``.\n *  If you specify both ``ForwardConfig`` and ``TargetGroupArn``, you can specify only one target group using ``ForwardConfig`` and it must be the same target group specified in ``TargetGroupArn``.\n */\nexport interface ForwardConfig {\nTargetGroupStickinessConfig?: TargetGroupStickinessConfig\n/**\n * Information about how traffic will be distributed between multiple target groups in a forward rule.\n */\nTargetGroups?: TargetGroupTuple[]\n}\n/**\n * Information about the target group stickiness for a rule.\n */\nexport interface TargetGroupStickinessConfig {\n/**\n * Indicates whether target group stickiness is enabled.\n */\nEnabled?: boolean\n/**\n * [Application Load Balancers] The time period, in seconds, during which requests from a client should be routed to the same target group. The range is 1-604800 seconds (7 days). You must specify this value when enabling target group stickiness.\n */\nDurationSeconds?: number\n}\n/**\n * Information about how traffic will be distributed between multiple target groups in a forward rule.\n */\nexport interface TargetGroupTuple {\n/**\n * The Amazon Resource Name (ARN) of the target group.\n */\nTargetGroupArn?: string\n/**\n * The weight. The range is 0 to 999.\n */\nWeight?: number\n}\n/**\n * Specifies an SSL server certificate to use as the default certificate for a secure listener.\n */\nexport interface Certificate {\n/**\n * The Amazon Resource Name (ARN) of the certificate.\n */\nCertificateArn?: ({\n[k: string]: unknown\n} & string)\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-elasticloadbalancingv2-listener.js","sourceRoot":"","sources":["aws-elasticloadbalancingv2-listener.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * [HTTPS listeners] Information about an identity provider that is compliant with OpenID Connect (OIDC). Specify only when ``Type`` is ``authenticate-oidc``.\n */\nexport type AuthenticateOidcConfig = ({\n[k: string]: unknown\n} & {\n/**\n * The behavior if the user is not authenticated. The following are possible values:\n *   +  deny```` - Return an HTTP 401 Unauthorized error.\n *   +  allow```` - Allow the request to be forwarded to the target.\n *   +  authenticate```` - Redirect the request to the IdP authorization endpoint. This is the default value.\n */\nOnUnauthenticatedRequest?: string\n/**\n * The token endpoint of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nTokenEndpoint: string\n/**\n * Indicates whether to use the existing client secret when modifying a rule. If you are creating a rule, you can omit this parameter or set it to false.\n */\nUseExistingClientSecret?: boolean\n/**\n * The maximum duration of the authentication session, in seconds. The default is 604800 seconds (7 days).\n */\nSessionTimeout?: string\n/**\n * The set of user claims to be requested from the IdP. The default is ``openid``.\n *  To verify which scope values your IdP supports and how to separate multiple values, see the documentation for your IdP.\n */\nScope?: string\n/**\n * The OIDC issuer identifier of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nIssuer: string\n/**\n * The OAuth 2.0 client secret. This parameter is required if you are creating a rule. If you are modifying a rule, you can omit this parameter if you set ``UseExistingClientSecret`` to true.\n */\nClientSecret?: string\n/**\n * The user info endpoint of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nUserInfoEndpoint: string\n/**\n * The OAuth 2.0 client identifier.\n */\nClientId: string\n/**\n * The authorization endpoint of the IdP. This must be a full URL, including the HTTPS protocol, the domain, and the path.\n */\nAuthorizationEndpoint: string\n/**\n * The name of the cookie used to maintain session information. The default is AWSELBAuthSessionCookie.\n */\nSessionCookieName?: string\n/**\n * The query parameters (up to 10) to include in the redirect request to the authorization endpoint.\n */\nAuthenticationRequestExtraParams?: {\n/**\n * This interface was referenced by `undefined`'s JSON-Schema definition\n * via the `patternProperty` \"[a-zA-Z0-9]+\".\n */\n[k: string]: string\n}\n})\n\n/**\n * Specifies a listener for an Application Load Balancer, Network Load Balancer, or Gateway Load Balancer.\n */\nexport interface _AWS_ELASTICLOADBALANCINGV2_LISTENER {\nListenerArn?: string\nMutualAuthentication?: MutualAuthentication\n/**\n * The listener attributes. Attributes that you do not modify retain their current values.\n */\nListenerAttributes?: ListenerAttribute[]\n/**\n * [TLS listener] The name of the Application-Layer Protocol Negotiation (ALPN) policy.\n */\nAlpnPolicy?: string[]\n/**\n * [HTTPS and TLS listeners] The security policy that defines which protocols and ciphers are supported. For more information, see [Security policies](https://docs.aws.amazon.com/elasticloadbalancing/latest/application/describe-ssl-policies.html) in the *Application Load Balancers Guide* and [Security policies](https://docs.aws.amazon.com/elasticloadbalancing/latest/network/describe-ssl-policies.html) in the *Network Load Balancers Guide*.\n *  [HTTPS listeners] Updating the security policy can result in interruptions if the load balancer is handling a high volume of traffic. To decrease the possibility of an interruption if your load balancer is handling a high volume of traffic, create an additional load balancer or request an LCU reservation.\n */\nSslPolicy?: string\n/**\n * The Amazon Resource Name (ARN) of the load balancer.\n */\nLoadBalancerArn: string\n/**\n * The actions for the default rule. You cannot define a condition for a default rule.\n *  To create additional rules for an Application Load Balancer, use [AWS::ElasticLoadBalancingV2::ListenerRule](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-elasticloadbalancingv2-listenerrule.html).\n */\nDefaultActions: Action[]\n/**\n * The port on which the load balancer is listening. You can't specify a port for a Gateway Load Balancer.\n */\nPort?: number\n/**\n * The default SSL server certificate for a secure listener. You must provide exactly one certificate if the listener protocol is HTTPS or TLS.\n *  For an HTTPS listener, update requires some interruptions. For a TLS listener, update requires no interruption.\n *  To create a certificate list for a secure listener, use [AWS::ElasticLoadBalancingV2::ListenerCertificate](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-elasticloadbalancingv2-listenercertificate.html).\n */\nCertificates?: Certificate[]\n/**\n * The protocol for connections from clients to the load balancer. For Application Load Balancers, the supported protocols are HTTP and HTTPS. For Network Load Balancers, the supported protocols are TCP, TLS, UDP, TCP_UDP, QUIC, and TCP_QUIC. You can’t specify the UDP, TCP_UDP, QUIC, or TCP_QUIC protocol if dual-stack mode is enabled. You can't specify a protocol for a Gateway Load Balancer.\n */\nProtocol?: string\n}\n/**\n * The mutual authentication configuration information.\n */\nexport interface MutualAuthentication {\n/**\n * Indicates whether expired client certificates are ignored.\n */\nIgnoreClientCertificateExpiry?: boolean\n/**\n * The client certificate handling method. Options are ``off``, ``passthrough`` or ``verify``. The default value is ``off``.\n */\nMode?: string\n/**\n * The Amazon Resource Name (ARN) of the trust store.\n */\nTrustStoreArn?: string\n/**\n * Indicates whether trust store CA certificate names are advertised.\n */\nAdvertiseTrustStoreCaNames?: string\n}\n/**\n * Information about a listener attribute.\n */\nexport interface ListenerAttribute {\n/**\n * The value of the attribute.\n */\nValue?: string\n/**\n * The name of the attribute.\n *  The following attribute is supported by Network Load Balancers, and Gateway Load Balancers.\n *   +  ``tcp.idle_timeout.seconds`` - The tcp idle timeout value, in seconds. The valid range is 60-6000 seconds. The default is 350 seconds.\n *   \n *  The following attributes are only supported by Application Load Balancers.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_serial_number.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Serial-Number* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_issuer.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Issuer* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_subject.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Subject* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_validity.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Validity* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert_leaf.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert-Leaf* HTTP request header.\n *   +  ``routing.http.request.x_amzn_mtls_clientcert.header_name`` - Enables you to modify the header name of the *X-Amzn-Mtls-Clientcert* HTTP request header.\n *   +  ``routing.http.request.x_amzn_tls_version.header_name`` - Enables you to modify the header name of the *X-Amzn-Tls-Version* HTTP request header.\n *   +  ``routing.http.request.x_amzn_tls_cipher_suite.header_name`` - Enables you to modify the header name of the *X-Amzn-Tls-Cipher-Suite* HTTP request header.\n *   +  ``routing.http.response.server.enabled`` - Enables you to allow or remove the HTTP response server header.\n *   +  ``routing.http.response.strict_transport_security.header_value`` - Informs browsers that the site should only be accessed using HTTPS, and that any future attempts to access it using HTTP should automatically be converted to HTTPS.\n *   +  ``routing.http.response.access_control_allow_origin.header_value`` - Specifies which origins are allowed to access the server.\n *   +  ``routing.http.response.access_control_allow_methods.header_value`` - Returns which HTTP methods are allowed when accessing the server from a different origin.\n *   +  ``routing.http.response.access_control_allow_headers.header_value`` - Specifies which headers can be used during the request.\n *   +  ``routing.http.response.access_control_allow_credentials.header_value`` - Indicates whether the browser should include credentials such as cookies or authentication when making requests.\n *   +  ``routing.http.response.access_control_expose_headers.header_value`` - Returns which headers the browser can expose to the requesting client.\n *   +  ``routing.http.response.access_control_max_age.header_value`` - Specifies how long the results of a preflight request can be cached, in seconds.\n *   +  ``routing.http.response.content_security_policy.header_value`` - Specifies restrictions enforced by the browser to help minimize the risk of certain types of security threats.\n *   +  ``routing.http.response.x_content_type_options.header_value`` - Indicates whether the MIME types advertised in the *Content-Type* headers should be followed and not be changed.\n *   +  ``routing.http.response.x_frame_options.header_value`` - Indicates whether the browser is allowed to render a page in a *frame*, *iframe*, *embed* or *object*.\n */\nKey?: string\n}\n/**\n * Specifies an action for a listener rule.\n */\nexport interface Action {\n/**\n * The order for the action. This value is required for rules with multiple actions. The action with the lowest value for order is performed first.\n */\nOrder?: number\n/**\n * The Amazon Resource Name (ARN) of the target group. Specify only when ``Type`` is ``forward`` and you want to route to a single target group. To route to multiple target groups, you must use ``ForwardConfig`` instead.\n */\nTargetGroupArn?: string\nFixedResponseConfig?: FixedResponseConfig\nAuthenticateCognitoConfig?: AuthenticateCognitoConfig\n/**\n * The type of action.\n */\nType: string\nRedirectConfig?: RedirectConfig\nJwtValidationConfig?: JwtValidationConfig\nForwardConfig?: ForwardConfig\nAuthenticateOidcConfig?: AuthenticateOidcConfig\n}\n/**\n * [Application Load Balancer] Information for creating an action that returns a custom HTTP response. Specify only when ``Type`` is ``fixed-response``.\n */\nexport interface FixedResponseConfig {\n/**\n * The content type.\n *  Valid Values: text/plain | text/css | text/html | application/javascript | application/json\n */\nContentType?: string\n/**\n * The HTTP response code (2XX, 4XX, or 5XX).\n */\nStatusCode: string\n/**\n * The message.\n */\nMessageBody?: string\n}\n/**\n * [HTTPS listeners] Information for using Amazon Cognito to authenticate users. Specify only when ``Type`` is ``authenticate-cognito``.\n */\nexport interface AuthenticateCognitoConfig {\n/**\n * The behavior if the user is not authenticated. The following are possible values:\n *   +  deny```` - Return an HTTP 401 Unauthorized error.\n *   +  allow```` - Allow the request to be forwarded to the target.\n *   +  authenticate```` - Redirect the request to the IdP authorization endpoint. This is the default value.\n */\nOnUnauthenticatedRequest?: string\n/**\n * The ID of the Amazon Cognito user pool client.\n */\nUserPoolClientId: ({\n[k: string]: unknown\n} & string)\n/**\n * The domain prefix or fully-qualified domain name of the Amazon Cognito user pool.\n */\nUserPoolDomain: string\n/**\n * The maximum duration of the authentication session, in seconds. The default is 604800 seconds (7 days).\n */\nSessionTimeout?: string\n/**\n * The set of user claims to be requested from the IdP. The default is ``openid``.\n *  To verify which scope values your IdP supports and how to separate multiple values, see the documentation for your IdP.\n */\nScope?: string\n/**\n * The name of the cookie used to maintain session information. The default is AWSELBAuthSessionCookie.\n */\nSessionCookieName?: string\n/**\n * The Amazon Resource Name (ARN) of the Amazon Cognito user pool.\n */\nUserPoolArn: string\n/**\n * The query parameters (up to 10) to include in the redirect request to the authorization endpoint.\n */\nAuthenticationRequestExtraParams?: {\n/**\n * This interface was referenced by `undefined`'s JSON-Schema definition\n * via the `patternProperty` \"[a-zA-Z0-9]+\".\n */\n[k: string]: string\n}\n}\n/**\n * [Application Load Balancer] Information for creating a redirect action. Specify only when ``Type`` is ``redirect``.\n */\nexport interface RedirectConfig {\n/**\n * The absolute path, starting with the leading \"/\". This component is not percent-encoded. The path can contain #{host}, #{path}, and #{port}.\n */\nPath?: string\n/**\n * The query parameters, URL-encoded when necessary, but not percent-encoded. Do not include the leading \"?\", as it is automatically added. You can specify any of the reserved keywords.\n */\nQuery?: string\n/**\n * The port. You can specify a value from 1 to 65535 or #{port}.\n */\nPort?: string\n/**\n * The hostname. This component is not percent-encoded. The hostname can contain #{host}.\n */\nHost?: string\n/**\n * The protocol. You can specify HTTP, HTTPS, or #{protocol}. You can redirect HTTP to HTTP, HTTP to HTTPS, and HTTPS to HTTPS. You can't redirect HTTPS to HTTP.\n */\nProtocol?: string\n/**\n * The HTTP redirect code. The redirect is either permanent (HTTP 301) or temporary (HTTP 302).\n */\nStatusCode: string\n}\n/**\n * [HTTPS listeners] Information for validating JWT access tokens in client requests. Specify only when ``Type`` is ``jwt-validation``.\n */\nexport interface JwtValidationConfig {\nJwksEndpoint: string\nIssuer: string\nAdditionalClaims?: JwtValidationActionAdditionalClaim[]\n}\n/**\n * Information about an additional claim to validate.\n */\nexport interface JwtValidationActionAdditionalClaim {\n/**\n * The format of the claim value.\n */\nFormat: string\n/**\n * The claim value. The maximum size of the list is 10. Each value can be up to 256 characters in length. If the format is ``space-separated-values``, the values can't include spaces.\n */\nValues: string[]\n/**\n * The name of the claim. You can't specify ``exp``, ``iss``, ``nbf``, or ``iat`` because we validate them by default.\n */\nName: string\n}\n/**\n * Information for creating an action that distributes requests among multiple target groups. Specify only when ``Type`` is ``forward``.\n *  If you specify both ``ForwardConfig`` and ``TargetGroupArn``, you can specify only one target group using ``ForwardConfig`` and it must be the same target group specified in ``TargetGroupArn``.\n */\nexport interface ForwardConfig {\nTargetGroupStickinessConfig?: TargetGroupStickinessConfig\n/**\n * Information about how traffic will be distributed between multiple target groups in a forward rule.\n */\nTargetGroups?: TargetGroupTuple[]\n}\n/**\n * Information about the target group stickiness for a rule.\n */\nexport interface TargetGroupStickinessConfig {\n/**\n * Indicates whether target group stickiness is enabled.\n */\nEnabled?: boolean\n/**\n * [Application Load Balancers] The time period, in seconds, during which requests from a client should be routed to the same target group. The range is 1-604800 seconds (7 days). You must specify this value when enabling target group stickiness.\n */\nDurationSeconds?: number\n}\n/**\n * Information about how traffic will be distributed between multiple target groups in a forward rule.\n */\nexport interface TargetGroupTuple {\n/**\n * The Amazon Resource Name (ARN) of the target group.\n */\nTargetGroupArn?: string\n/**\n * The weight. The range is 0 to 999.\n */\nWeight?: number\n}\n/**\n * Specifies an SSL server certificate to use as the default certificate for a secure listener.\n */\nexport interface Certificate {\n/**\n * The Amazon Resource Name (ARN) of the certificate.\n */\nCertificateArn?: ({\n[k: string]: unknown\n} & string)\n}\n"]}
@@ -298,14 +298,29 @@ export interface TargetGroupTuple {
298
298
  */
299
299
  Weight?: number;
300
300
  }
301
+ /**
302
+ * [HTTPS listeners] Information for validating JWT access tokens in client requests. Specify only when ``Type`` is ``jwt-validation``.
303
+ */
301
304
  export interface JwtValidationConfig {
302
305
  JwksEndpoint: string;
303
306
  Issuer: string;
304
307
  AdditionalClaims?: JwtValidationActionAdditionalClaim[];
305
308
  }
309
+ /**
310
+ * Information about an additional claim to validate.
311
+ */
306
312
  export interface JwtValidationActionAdditionalClaim {
313
+ /**
314
+ * The format of the claim value.
315
+ */
307
316
  Format: string;
317
+ /**
318
+ * The name of the claim. You can't specify ``exp``, ``iss``, ``nbf``, or ``iat`` because we validate them by default.
319
+ */
308
320
  Name: string;
321
+ /**
322
+ * The claim value. The maximum size of the list is 10. Each value can be up to 256 characters in length. If the format is ``space-separated-values``, the values can't include spaces.
323
+ */
309
324
  Values: string[];
310
325
  }
311
326
  /**