@horietakehiro/aws-cdk-utul 0.41.10 → 0.41.12

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 (31) hide show
  1. package/lib/types/cfn-resource-types/aws-arcregionswitch-plan.d.ts +286 -0
  2. package/lib/types/cfn-resource-types/aws-arcregionswitch-plan.js +3 -0
  3. package/lib/types/cfn-resource-types/aws-batch-jobqueue.d.ts +13 -5
  4. package/lib/types/cfn-resource-types/aws-batch-jobqueue.js +1 -1
  5. package/lib/types/cfn-resource-types/aws-ec2-instance.d.ts +3 -3
  6. package/lib/types/cfn-resource-types/aws-ec2-instance.js +1 -1
  7. package/lib/types/cfn-resource-types/aws-ec2-transitgatewayconnectpeer.d.ts +83 -0
  8. package/lib/types/cfn-resource-types/aws-ec2-transitgatewayconnectpeer.js +3 -0
  9. package/lib/types/cfn-resource-types/aws-ecr-repository.d.ts +18 -1
  10. package/lib/types/cfn-resource-types/aws-ecr-repository.js +1 -1
  11. package/lib/types/cfn-resource-types/aws-eks-cluster.d.ts +112 -112
  12. package/lib/types/cfn-resource-types/aws-eks-cluster.js +1 -1
  13. package/lib/types/cfn-resource-types/aws-logs-destination.d.ts +17 -0
  14. package/lib/types/cfn-resource-types/aws-logs-destination.js +1 -1
  15. package/lib/types/cfn-resource-types/aws-logs-loggroup.d.ts +3 -0
  16. package/lib/types/cfn-resource-types/aws-logs-loggroup.js +1 -1
  17. package/lib/types/cfn-resource-types/aws-rds-dbcluster.d.ts +1 -0
  18. package/lib/types/cfn-resource-types/aws-rds-dbcluster.js +1 -1
  19. package/lib/types/cfn-resource-types/aws-s3-accesspoint.d.ts +8 -0
  20. package/lib/types/cfn-resource-types/aws-s3-accesspoint.js +1 -1
  21. package/lib/types/cfn-resource-types/aws-s3-bucket.d.ts +24 -17
  22. package/lib/types/cfn-resource-types/aws-s3-bucket.js +1 -1
  23. package/lib/types/cfn-resource-types/aws-s3express-accesspoint.d.ts +5 -0
  24. package/lib/types/cfn-resource-types/aws-s3express-accesspoint.js +1 -1
  25. package/lib/types/cfn-resource-types/aws-sagemaker-cluster.d.ts +59 -1
  26. package/lib/types/cfn-resource-types/aws-sagemaker-cluster.js +1 -1
  27. package/lib/types/cfn-resource-types/aws-ssm-parameter.d.ts +5 -3
  28. package/lib/types/cfn-resource-types/aws-ssm-parameter.js +1 -1
  29. package/lib/types/cfn-resource-types.d.ts +4 -0
  30. package/lib/types/cfn-resource-types.js +32 -28
  31. package/package.json +1 -1
@@ -0,0 +1,286 @@
1
+ export type AlarmType = ("applicationHealth" | "trigger");
2
+ export type RecoveryApproach = ("activeActive" | "activePassive");
3
+ export type WorkflowTargetAction = ("activate" | "deactivate");
4
+ export type AlarmCondition = ("red" | "green");
5
+ export type ExecutionBlockConfiguration = (CustomActionLambdaConfig | Ec2AsgCapacityIncreaseConfig | ExecutionApprovalConfig | ArcRoutingControlConfig | GlobalAuroraConfig | ParallelConfig | RegionSwitchPlanConfig | EcsCapacityIncreaseConfig | EksResourceScalingConfig | Route53HealthCheckConfig);
6
+ export type RegionToRunIn = ("activatingRegion" | "deactivatingRegion");
7
+ export type LambdaUngracefulBehavior = "skip";
8
+ export type Ec2AsgCapacityMonitoringApproach = ("sampledMaxInLast24Hours" | "autoscalingMaxInLast24Hours");
9
+ export type RoutingControlStateChange = ("On" | "Off");
10
+ export type GlobalAuroraDefaultBehavior = ("switchoverOnly" | "failover");
11
+ export type GlobalAuroraUngracefulBehavior = "failover";
12
+ export type EcsCapacityMonitoringApproach = ("sampledMaxInLast24Hours" | "containerInsightsMaxInLast24Hours");
13
+ export type EksCapacityMonitoringApproach = "sampledMaxInLast24Hours";
14
+ export type ExecutionBlockType = ("CustomActionLambda" | "ManualApproval" | "AuroraGlobalDatabase" | "EC2AutoScaling" | "ARCRoutingControl" | "ARCRegionSwitchPlan" | "Parallel" | "ECSServiceScaling" | "EKSResourceScaling" | "Route53HealthCheck");
15
+ /**
16
+ * @minItems 2
17
+ * @maxItems 2
18
+ *
19
+ * This interface was referenced by `undefined`'s JSON-Schema definition
20
+ * via the `patternProperty` ".+".
21
+ */
22
+ export type Route53HealthChecks = HealthCheckState[];
23
+ /**
24
+ * Represents a plan that specifies Regions, IAM roles, and workflows of logic required to perform the desired change to your multi-Region application
25
+ */
26
+ export interface _AWS_ARCREGIONSWITCH_PLAN {
27
+ Arn?: string;
28
+ AssociatedAlarms?: AssociatedAlarmMap;
29
+ Description?: string;
30
+ ExecutionRole: string;
31
+ Name: string;
32
+ Owner?: string;
33
+ PrimaryRegion?: string;
34
+ RecoveryApproach: RecoveryApproach;
35
+ RecoveryTimeObjectiveMinutes?: number;
36
+ /**
37
+ * @minItems 2
38
+ * @maxItems 2
39
+ */
40
+ Regions: string[];
41
+ Tags?: Tags;
42
+ Triggers?: Trigger[];
43
+ Version?: string;
44
+ Workflows: Workflow[];
45
+ HealthChecksForPlan?: {
46
+ [k: string]: Route53HealthChecks;
47
+ };
48
+ }
49
+ export interface AssociatedAlarmMap {
50
+ [k: string]: AssociatedAlarm;
51
+ }
52
+ /**
53
+ * This interface was referenced by `AssociatedAlarmMap`'s JSON-Schema definition
54
+ * via the `patternProperty` ".+".
55
+ */
56
+ export interface AssociatedAlarm {
57
+ CrossAccountRole?: string;
58
+ ExternalId?: string;
59
+ ResourceIdentifier: string;
60
+ AlarmType: AlarmType;
61
+ }
62
+ export interface Tags {
63
+ /**
64
+ * This interface was referenced by `Tags`'s JSON-Schema definition
65
+ * via the `patternProperty` ".+".
66
+ */
67
+ [k: string]: string;
68
+ }
69
+ export interface Trigger {
70
+ Description?: string;
71
+ TargetRegion: string;
72
+ Action: WorkflowTargetAction;
73
+ /**
74
+ * @minItems 1
75
+ * @maxItems 10
76
+ */
77
+ Conditions: TriggerCondition[];
78
+ MinDelayMinutesBetweenExecutions: number;
79
+ }
80
+ export interface TriggerCondition {
81
+ AssociatedAlarmName: string;
82
+ Condition: AlarmCondition;
83
+ }
84
+ export interface Workflow {
85
+ Steps?: Step[];
86
+ WorkflowTargetAction: WorkflowTargetAction;
87
+ WorkflowTargetRegion?: string;
88
+ WorkflowDescription?: string;
89
+ }
90
+ export interface Step {
91
+ Name: string;
92
+ Description?: string;
93
+ ExecutionBlockConfiguration: ExecutionBlockConfiguration;
94
+ ExecutionBlockType: ExecutionBlockType;
95
+ }
96
+ export interface CustomActionLambdaConfig {
97
+ CustomActionLambdaConfig: CustomActionLambdaConfiguration;
98
+ }
99
+ export interface CustomActionLambdaConfiguration {
100
+ TimeoutMinutes?: number;
101
+ /**
102
+ * @minItems 1
103
+ * @maxItems 2
104
+ */
105
+ Lambdas: Lambdas[];
106
+ RetryIntervalMinutes: number;
107
+ RegionToRun: RegionToRunIn;
108
+ Ungraceful?: LambdaUngraceful;
109
+ }
110
+ export interface Lambdas {
111
+ CrossAccountRole?: string;
112
+ ExternalId?: string;
113
+ Arn?: string;
114
+ }
115
+ export interface LambdaUngraceful {
116
+ Behavior?: (LambdaUngracefulBehavior & string);
117
+ }
118
+ export interface Ec2AsgCapacityIncreaseConfig {
119
+ Ec2AsgCapacityIncreaseConfig: Ec2AsgCapacityIncreaseConfiguration;
120
+ }
121
+ export interface Ec2AsgCapacityIncreaseConfiguration {
122
+ TimeoutMinutes?: number;
123
+ /**
124
+ * @minItems 2
125
+ * @maxItems 2
126
+ */
127
+ Asgs: Asg[];
128
+ Ungraceful?: Ec2Ungraceful;
129
+ TargetPercent?: number;
130
+ CapacityMonitoringApproach?: (Ec2AsgCapacityMonitoringApproach & string);
131
+ }
132
+ export interface Asg {
133
+ CrossAccountRole?: string;
134
+ ExternalId?: string;
135
+ Arn?: string;
136
+ }
137
+ export interface Ec2Ungraceful {
138
+ MinimumSuccessPercentage: number;
139
+ }
140
+ export interface ExecutionApprovalConfig {
141
+ ExecutionApprovalConfig: ExecutionApprovalConfiguration;
142
+ }
143
+ export interface ExecutionApprovalConfiguration {
144
+ TimeoutMinutes?: number;
145
+ ApprovalRole: string;
146
+ }
147
+ export interface ArcRoutingControlConfig {
148
+ ArcRoutingControlConfig: ArcRoutingControlConfiguration;
149
+ }
150
+ export interface ArcRoutingControlConfiguration {
151
+ TimeoutMinutes?: number;
152
+ CrossAccountRole?: string;
153
+ ExternalId?: string;
154
+ RegionAndRoutingControls: RegionAndRoutingControls;
155
+ }
156
+ export interface RegionAndRoutingControls {
157
+ /**
158
+ * This interface was referenced by `RegionAndRoutingControls`'s JSON-Schema definition
159
+ * via the `patternProperty` ".+".
160
+ */
161
+ [k: string]: ArcRoutingControlState[];
162
+ }
163
+ export interface ArcRoutingControlState {
164
+ RoutingControlArn: string;
165
+ State: RoutingControlStateChange;
166
+ }
167
+ export interface GlobalAuroraConfig {
168
+ GlobalAuroraConfig: GlobalAuroraConfiguration;
169
+ }
170
+ export interface GlobalAuroraConfiguration {
171
+ TimeoutMinutes?: number;
172
+ CrossAccountRole?: string;
173
+ ExternalId?: string;
174
+ Behavior: (GlobalAuroraDefaultBehavior & string);
175
+ Ungraceful?: GlobalAuroraUngraceful;
176
+ GlobalClusterIdentifier: string;
177
+ DatabaseClusterArns: string[];
178
+ }
179
+ export interface GlobalAuroraUngraceful {
180
+ Ungraceful?: GlobalAuroraUngracefulBehavior;
181
+ }
182
+ export interface ParallelConfig {
183
+ ParallelConfig: ParallelExecutionBlockConfiguration;
184
+ }
185
+ export interface ParallelExecutionBlockConfiguration {
186
+ Steps: Step[];
187
+ }
188
+ export interface RegionSwitchPlanConfig {
189
+ RegionSwitchPlanConfig: RegionSwitchPlanConfiguration;
190
+ }
191
+ export interface RegionSwitchPlanConfiguration {
192
+ CrossAccountRole?: string;
193
+ ExternalId?: string;
194
+ Arn: string;
195
+ }
196
+ export interface EcsCapacityIncreaseConfig {
197
+ EcsCapacityIncreaseConfig: EcsCapacityIncreaseConfiguration;
198
+ }
199
+ export interface EcsCapacityIncreaseConfiguration {
200
+ TimeoutMinutes?: number;
201
+ /**
202
+ * @minItems 2
203
+ * @maxItems 2
204
+ */
205
+ Services: Service[];
206
+ Ungraceful?: EcsUngraceful;
207
+ TargetPercent?: number;
208
+ CapacityMonitoringApproach?: (EcsCapacityMonitoringApproach & string);
209
+ }
210
+ export interface Service {
211
+ CrossAccountRole?: string;
212
+ ExternalId?: string;
213
+ ClusterArn?: string;
214
+ ServiceArn?: string;
215
+ }
216
+ export interface EcsUngraceful {
217
+ MinimumSuccessPercentage: number;
218
+ }
219
+ export interface EksResourceScalingConfig {
220
+ EksResourceScalingConfig: EksResourceScalingConfiguration;
221
+ }
222
+ export interface EksResourceScalingConfiguration {
223
+ TimeoutMinutes?: number;
224
+ KubernetesResourceType: KubernetesResourceType;
225
+ /**
226
+ * @minItems 1
227
+ */
228
+ ScalingResources?: KubernetesScalingApplication[];
229
+ /**
230
+ * @minItems 2
231
+ */
232
+ EksClusters?: EksCluster[];
233
+ Ungraceful?: EksResourceScalingUngraceful;
234
+ TargetPercent?: number;
235
+ CapacityMonitoringApproach?: (EksCapacityMonitoringApproach & string);
236
+ }
237
+ export interface KubernetesResourceType {
238
+ ApiVersion: string;
239
+ Kind: string;
240
+ }
241
+ export interface KubernetesScalingApplication {
242
+ [k: string]: RegionalScalingResource;
243
+ }
244
+ /**
245
+ * This interface was referenced by `KubernetesScalingApplication`'s JSON-Schema definition
246
+ * via the `patternProperty` ".+".
247
+ */
248
+ export interface RegionalScalingResource {
249
+ [k: string]: KubernetesScalingResource;
250
+ }
251
+ /**
252
+ * This interface was referenced by `RegionalScalingResource`'s JSON-Schema definition
253
+ * via the `patternProperty` "^[a-z]{2}-[a-z-]+-\d+$".
254
+ */
255
+ export interface KubernetesScalingResource {
256
+ Namespace: string;
257
+ Name: string;
258
+ HpaName?: string;
259
+ }
260
+ export interface EksCluster {
261
+ CrossAccountRole?: string;
262
+ ExternalId?: string;
263
+ ClusterArn: string;
264
+ }
265
+ export interface EksResourceScalingUngraceful {
266
+ MinimumSuccessPercentage: number;
267
+ }
268
+ export interface Route53HealthCheckConfig {
269
+ Route53HealthCheckConfig: Route53HealthCheckConfiguration;
270
+ }
271
+ export interface Route53HealthCheckConfiguration {
272
+ TimeoutMinutes?: number;
273
+ CrossAccountRole?: string;
274
+ ExternalId?: string;
275
+ HostedZoneId: string;
276
+ RecordName: string;
277
+ RecordSets?: Route53ResourceRecordSet[];
278
+ }
279
+ export interface Route53ResourceRecordSet {
280
+ RecordSetIdentifier?: string;
281
+ Region?: string;
282
+ }
283
+ export interface HealthCheckState {
284
+ HealthCheckId?: string;
285
+ Region?: string;
286
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-arcregionswitch-plan.js","sourceRoot":"","sources":["aws-arcregionswitch-plan.ts"],"names":[],"mappings":"","sourcesContent":["export type AlarmType = (\"applicationHealth\" | \"trigger\")\nexport type RecoveryApproach = (\"activeActive\" | \"activePassive\")\nexport type WorkflowTargetAction = (\"activate\" | \"deactivate\")\nexport type AlarmCondition = (\"red\" | \"green\")\nexport type ExecutionBlockConfiguration = (CustomActionLambdaConfig | Ec2AsgCapacityIncreaseConfig | ExecutionApprovalConfig | ArcRoutingControlConfig | GlobalAuroraConfig | ParallelConfig | RegionSwitchPlanConfig | EcsCapacityIncreaseConfig | EksResourceScalingConfig | Route53HealthCheckConfig)\nexport type RegionToRunIn = (\"activatingRegion\" | \"deactivatingRegion\")\nexport type LambdaUngracefulBehavior = \"skip\"\nexport type Ec2AsgCapacityMonitoringApproach = (\"sampledMaxInLast24Hours\" | \"autoscalingMaxInLast24Hours\")\nexport type RoutingControlStateChange = (\"On\" | \"Off\")\nexport type GlobalAuroraDefaultBehavior = (\"switchoverOnly\" | \"failover\")\nexport type GlobalAuroraUngracefulBehavior = \"failover\"\nexport type EcsCapacityMonitoringApproach = (\"sampledMaxInLast24Hours\" | \"containerInsightsMaxInLast24Hours\")\nexport type EksCapacityMonitoringApproach = \"sampledMaxInLast24Hours\"\nexport type ExecutionBlockType = (\"CustomActionLambda\" | \"ManualApproval\" | \"AuroraGlobalDatabase\" | \"EC2AutoScaling\" | \"ARCRoutingControl\" | \"ARCRegionSwitchPlan\" | \"Parallel\" | \"ECSServiceScaling\" | \"EKSResourceScaling\" | \"Route53HealthCheck\")\n/**\n * @minItems 2\n * @maxItems 2\n * \n * This interface was referenced by `undefined`'s JSON-Schema definition\n * via the `patternProperty` \".+\".\n */\nexport type Route53HealthChecks = HealthCheckState[]\n\n/**\n * Represents a plan that specifies Regions, IAM roles, and workflows of logic required to perform the desired change to your multi-Region application\n */\nexport interface _AWS_ARCREGIONSWITCH_PLAN {\nArn?: string\nAssociatedAlarms?: AssociatedAlarmMap\nDescription?: string\nExecutionRole: string\nName: string\nOwner?: string\nPrimaryRegion?: string\nRecoveryApproach: RecoveryApproach\nRecoveryTimeObjectiveMinutes?: number\n/**\n * @minItems 2\n * @maxItems 2\n */\nRegions: string[]\nTags?: Tags\nTriggers?: Trigger[]\nVersion?: string\nWorkflows: Workflow[]\nHealthChecksForPlan?: {\n[k: string]: Route53HealthChecks\n}\n}\nexport interface AssociatedAlarmMap {\n[k: string]: AssociatedAlarm\n}\n/**\n * This interface was referenced by `AssociatedAlarmMap`'s JSON-Schema definition\n * via the `patternProperty` \".+\".\n */\nexport interface AssociatedAlarm {\nCrossAccountRole?: string\nExternalId?: string\nResourceIdentifier: string\nAlarmType: AlarmType\n}\nexport interface Tags {\n/**\n * This interface was referenced by `Tags`'s JSON-Schema definition\n * via the `patternProperty` \".+\".\n */\n[k: string]: string\n}\nexport interface Trigger {\nDescription?: string\nTargetRegion: string\nAction: WorkflowTargetAction\n/**\n * @minItems 1\n * @maxItems 10\n */\nConditions: TriggerCondition[]\nMinDelayMinutesBetweenExecutions: number\n}\nexport interface TriggerCondition {\nAssociatedAlarmName: string\nCondition: AlarmCondition\n}\nexport interface Workflow {\nSteps?: Step[]\nWorkflowTargetAction: WorkflowTargetAction\nWorkflowTargetRegion?: string\nWorkflowDescription?: string\n}\nexport interface Step {\nName: string\nDescription?: string\nExecutionBlockConfiguration: ExecutionBlockConfiguration\nExecutionBlockType: ExecutionBlockType\n}\nexport interface CustomActionLambdaConfig {\nCustomActionLambdaConfig: CustomActionLambdaConfiguration\n}\nexport interface CustomActionLambdaConfiguration {\nTimeoutMinutes?: number\n/**\n * @minItems 1\n * @maxItems 2\n */\nLambdas: Lambdas[]\nRetryIntervalMinutes: number\nRegionToRun: RegionToRunIn\nUngraceful?: LambdaUngraceful\n}\nexport interface Lambdas {\nCrossAccountRole?: string\nExternalId?: string\nArn?: string\n}\nexport interface LambdaUngraceful {\nBehavior?: (LambdaUngracefulBehavior & string)\n}\nexport interface Ec2AsgCapacityIncreaseConfig {\nEc2AsgCapacityIncreaseConfig: Ec2AsgCapacityIncreaseConfiguration\n}\nexport interface Ec2AsgCapacityIncreaseConfiguration {\nTimeoutMinutes?: number\n/**\n * @minItems 2\n * @maxItems 2\n */\nAsgs: Asg[]\nUngraceful?: Ec2Ungraceful\nTargetPercent?: number\nCapacityMonitoringApproach?: (Ec2AsgCapacityMonitoringApproach & string)\n}\nexport interface Asg {\nCrossAccountRole?: string\nExternalId?: string\nArn?: string\n}\nexport interface Ec2Ungraceful {\nMinimumSuccessPercentage: number\n}\nexport interface ExecutionApprovalConfig {\nExecutionApprovalConfig: ExecutionApprovalConfiguration\n}\nexport interface ExecutionApprovalConfiguration {\nTimeoutMinutes?: number\nApprovalRole: string\n}\nexport interface ArcRoutingControlConfig {\nArcRoutingControlConfig: ArcRoutingControlConfiguration\n}\nexport interface ArcRoutingControlConfiguration {\nTimeoutMinutes?: number\nCrossAccountRole?: string\nExternalId?: string\nRegionAndRoutingControls: RegionAndRoutingControls\n}\nexport interface RegionAndRoutingControls {\n/**\n * This interface was referenced by `RegionAndRoutingControls`'s JSON-Schema definition\n * via the `patternProperty` \".+\".\n */\n[k: string]: ArcRoutingControlState[]\n}\nexport interface ArcRoutingControlState {\nRoutingControlArn: string\nState: RoutingControlStateChange\n}\nexport interface GlobalAuroraConfig {\nGlobalAuroraConfig: GlobalAuroraConfiguration\n}\nexport interface GlobalAuroraConfiguration {\nTimeoutMinutes?: number\nCrossAccountRole?: string\nExternalId?: string\nBehavior: (GlobalAuroraDefaultBehavior & string)\nUngraceful?: GlobalAuroraUngraceful\nGlobalClusterIdentifier: string\nDatabaseClusterArns: string[]\n}\nexport interface GlobalAuroraUngraceful {\nUngraceful?: GlobalAuroraUngracefulBehavior\n}\nexport interface ParallelConfig {\nParallelConfig: ParallelExecutionBlockConfiguration\n}\nexport interface ParallelExecutionBlockConfiguration {\nSteps: Step[]\n}\nexport interface RegionSwitchPlanConfig {\nRegionSwitchPlanConfig: RegionSwitchPlanConfiguration\n}\nexport interface RegionSwitchPlanConfiguration {\nCrossAccountRole?: string\nExternalId?: string\nArn: string\n}\nexport interface EcsCapacityIncreaseConfig {\nEcsCapacityIncreaseConfig: EcsCapacityIncreaseConfiguration\n}\nexport interface EcsCapacityIncreaseConfiguration {\nTimeoutMinutes?: number\n/**\n * @minItems 2\n * @maxItems 2\n */\nServices: Service[]\nUngraceful?: EcsUngraceful\nTargetPercent?: number\nCapacityMonitoringApproach?: (EcsCapacityMonitoringApproach & string)\n}\nexport interface Service {\nCrossAccountRole?: string\nExternalId?: string\nClusterArn?: string\nServiceArn?: string\n}\nexport interface EcsUngraceful {\nMinimumSuccessPercentage: number\n}\nexport interface EksResourceScalingConfig {\nEksResourceScalingConfig: EksResourceScalingConfiguration\n}\nexport interface EksResourceScalingConfiguration {\nTimeoutMinutes?: number\nKubernetesResourceType: KubernetesResourceType\n/**\n * @minItems 1\n */\nScalingResources?: KubernetesScalingApplication[]\n/**\n * @minItems 2\n */\nEksClusters?: EksCluster[]\nUngraceful?: EksResourceScalingUngraceful\nTargetPercent?: number\nCapacityMonitoringApproach?: (EksCapacityMonitoringApproach & string)\n}\nexport interface KubernetesResourceType {\nApiVersion: string\nKind: string\n}\nexport interface KubernetesScalingApplication {\n[k: string]: RegionalScalingResource\n}\n/**\n * This interface was referenced by `KubernetesScalingApplication`'s JSON-Schema definition\n * via the `patternProperty` \".+\".\n */\nexport interface RegionalScalingResource {\n[k: string]: KubernetesScalingResource\n}\n/**\n * This interface was referenced by `RegionalScalingResource`'s JSON-Schema definition\n * via the `patternProperty` \"^[a-z]{2}-[a-z-]+-\\d+$\".\n */\nexport interface KubernetesScalingResource {\nNamespace: string\nName: string\nHpaName?: string\n}\nexport interface EksCluster {\nCrossAccountRole?: string\nExternalId?: string\nClusterArn: string\n}\nexport interface EksResourceScalingUngraceful {\nMinimumSuccessPercentage: number\n}\nexport interface Route53HealthCheckConfig {\nRoute53HealthCheckConfig: Route53HealthCheckConfiguration\n}\nexport interface Route53HealthCheckConfiguration {\nTimeoutMinutes?: number\nCrossAccountRole?: string\nExternalId?: string\nHostedZoneId: string\nRecordName: string\nRecordSets?: Route53ResourceRecordSet[]\n}\nexport interface Route53ResourceRecordSet {\nRecordSetIdentifier?: string\nRegion?: string\n}\nexport interface HealthCheckState {\nHealthCheckId?: string\nRegion?: string\n}\n"]}
@@ -1,11 +1,12 @@
1
- export type ResourceArn = string;
2
1
  /**
3
2
  * Resource Type definition for AWS::Batch::JobQueue
4
3
  */
5
- export interface _AWS_BATCH_JOBQUEUE {
4
+ export type _AWS_BATCH_JOBQUEUE = ({
6
5
  JobQueueName?: string;
7
6
  JobQueueArn?: ResourceArn;
8
- ComputeEnvironmentOrder: ComputeEnvironmentOrder[];
7
+ JobQueueType?: string;
8
+ ComputeEnvironmentOrder?: ComputeEnvironmentOrder[];
9
+ ServiceEnvironmentOrder?: ServiceEnvironmentOrder[];
9
10
  JobStateTimeLimitActions?: JobStateTimeLimitAction[];
10
11
  Priority: number;
11
12
  State?: ("DISABLED" | "ENABLED");
@@ -20,13 +21,20 @@ export interface _AWS_BATCH_JOBQUEUE {
20
21
  */
21
22
  [k: string]: string;
22
23
  };
23
- }
24
+ } & {
25
+ [k: string]: unknown;
26
+ });
27
+ export type ResourceArn = string;
24
28
  export interface ComputeEnvironmentOrder {
25
29
  ComputeEnvironment: string;
26
30
  Order: number;
27
31
  }
32
+ export interface ServiceEnvironmentOrder {
33
+ ServiceEnvironment: string;
34
+ Order: number;
35
+ }
28
36
  export interface JobStateTimeLimitAction {
29
- Action: "CANCEL";
37
+ Action: ("CANCEL" | "TERMINATE");
30
38
  MaxTimeSeconds: number;
31
39
  Reason: string;
32
40
  State: "RUNNABLE";
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWJhdGNoLWpvYnF1ZXVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWJhdGNoLWpvYnF1ZXVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBSZXNvdXJjZUFybiA9IHN0cmluZ1xuXG4vKipcbiAqIFJlc291cmNlIFR5cGUgZGVmaW5pdGlvbiBmb3IgQVdTOjpCYXRjaDo6Sm9iUXVldWVcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBfQVdTX0JBVENIX0pPQlFVRVVFIHtcbkpvYlF1ZXVlTmFtZT86IHN0cmluZ1xuSm9iUXVldWVBcm4/OiBSZXNvdXJjZUFyblxuQ29tcHV0ZUVudmlyb25tZW50T3JkZXI6IENvbXB1dGVFbnZpcm9ubWVudE9yZGVyW11cbkpvYlN0YXRlVGltZUxpbWl0QWN0aW9ucz86IEpvYlN0YXRlVGltZUxpbWl0QWN0aW9uW11cblByaW9yaXR5OiBudW1iZXJcblN0YXRlPzogKFwiRElTQUJMRURcIiB8IFwiRU5BQkxFRFwiKVxuU2NoZWR1bGluZ1BvbGljeUFybj86IFJlc291cmNlQXJuXG4vKipcbiAqIEEga2V5LXZhbHVlIHBhaXIgdG8gYXNzb2NpYXRlIHdpdGggYSByZXNvdXJjZS5cbiAqL1xuVGFncz86IHtcbi8qKlxuICogVGhpcyBpbnRlcmZhY2Ugd2FzIHJlZmVyZW5jZWQgYnkgYHVuZGVmaW5lZGAncyBKU09OLVNjaGVtYSBkZWZpbml0aW9uXG4gKiB2aWEgdGhlIGBwYXR0ZXJuUHJvcGVydHlgIFwiLipcIi5cbiAqL1xuW2s6IHN0cmluZ106IHN0cmluZ1xufVxufVxuZXhwb3J0IGludGVyZmFjZSBDb21wdXRlRW52aXJvbm1lbnRPcmRlciB7XG5Db21wdXRlRW52aXJvbm1lbnQ6IHN0cmluZ1xuT3JkZXI6IG51bWJlclxufVxuZXhwb3J0IGludGVyZmFjZSBKb2JTdGF0ZVRpbWVMaW1pdEFjdGlvbiB7XG5BY3Rpb246IFwiQ0FOQ0VMXCJcbk1heFRpbWVTZWNvbmRzOiBudW1iZXJcblJlYXNvbjogc3RyaW5nXG5TdGF0ZTogXCJSVU5OQUJMRVwiXG59XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWJhdGNoLWpvYnF1ZXVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWJhdGNoLWpvYnF1ZXVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJlc291cmNlIFR5cGUgZGVmaW5pdGlvbiBmb3IgQVdTOjpCYXRjaDo6Sm9iUXVldWVcbiAqL1xuZXhwb3J0IHR5cGUgX0FXU19CQVRDSF9KT0JRVUVVRSA9ICh7XG5Kb2JRdWV1ZU5hbWU/OiBzdHJpbmdcbkpvYlF1ZXVlQXJuPzogUmVzb3VyY2VBcm5cbkpvYlF1ZXVlVHlwZT86IHN0cmluZ1xuQ29tcHV0ZUVudmlyb25tZW50T3JkZXI/OiBDb21wdXRlRW52aXJvbm1lbnRPcmRlcltdXG5TZXJ2aWNlRW52aXJvbm1lbnRPcmRlcj86IFNlcnZpY2VFbnZpcm9ubWVudE9yZGVyW11cbkpvYlN0YXRlVGltZUxpbWl0QWN0aW9ucz86IEpvYlN0YXRlVGltZUxpbWl0QWN0aW9uW11cblByaW9yaXR5OiBudW1iZXJcblN0YXRlPzogKFwiRElTQUJMRURcIiB8IFwiRU5BQkxFRFwiKVxuU2NoZWR1bGluZ1BvbGljeUFybj86IFJlc291cmNlQXJuXG4vKipcbiAqIEEga2V5LXZhbHVlIHBhaXIgdG8gYXNzb2NpYXRlIHdpdGggYSByZXNvdXJjZS5cbiAqL1xuVGFncz86IHtcbi8qKlxuICogVGhpcyBpbnRlcmZhY2Ugd2FzIHJlZmVyZW5jZWQgYnkgYHVuZGVmaW5lZGAncyBKU09OLVNjaGVtYSBkZWZpbml0aW9uXG4gKiB2aWEgdGhlIGBwYXR0ZXJuUHJvcGVydHlgIFwiLipcIi5cbiAqL1xuW2s6IHN0cmluZ106IHN0cmluZ1xufVxufSAmIHtcbltrOiBzdHJpbmddOiB1bmtub3duXG59KVxuZXhwb3J0IHR5cGUgUmVzb3VyY2VBcm4gPSBzdHJpbmdcblxuZXhwb3J0IGludGVyZmFjZSBDb21wdXRlRW52aXJvbm1lbnRPcmRlciB7XG5Db21wdXRlRW52aXJvbm1lbnQ6IHN0cmluZ1xuT3JkZXI6IG51bWJlclxufVxuZXhwb3J0IGludGVyZmFjZSBTZXJ2aWNlRW52aXJvbm1lbnRPcmRlciB7XG5TZXJ2aWNlRW52aXJvbm1lbnQ6IHN0cmluZ1xuT3JkZXI6IG51bWJlclxufVxuZXhwb3J0IGludGVyZmFjZSBKb2JTdGF0ZVRpbWVMaW1pdEFjdGlvbiB7XG5BY3Rpb246IChcIkNBTkNFTFwiIHwgXCJURVJNSU5BVEVcIilcbk1heFRpbWVTZWNvbmRzOiBudW1iZXJcblJlYXNvbjogc3RyaW5nXG5TdGF0ZTogXCJSVU5OQUJMRVwiXG59XG4iXX0=
@@ -364,17 +364,17 @@ export interface InstanceIpv6Address {
364
364
  }
365
365
  export interface ElasticGpuSpecification {
366
366
  /**
367
- * The type of Elastic Graphics accelerator.
367
+ * The type of Elastic Graphics accelerator. Amazon Elastic Graphics is no longer available.
368
368
  */
369
369
  Type: string;
370
370
  }
371
371
  export interface ElasticInferenceAccelerator {
372
372
  /**
373
- * The type of elastic inference accelerator.
373
+ * The type of elastic inference accelerator. Amazon Elastic Inference is no longer available.
374
374
  */
375
375
  Type: string;
376
376
  /**
377
- * The number of elastic inference accelerators to attach to the instance.
377
+ * The number of elastic inference accelerators to attach to the instance. Amazon Elastic Inference is no longer available.
378
378
  */
379
379
  Count?: number;
380
380
  }
@@ -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-ec2-instance.js","sourceRoot":"","sources":["aws-ec2-instance.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * The launch template to use to launch the instances.\n */\nexport type LaunchTemplateSpecification = ({\n/**\n * The name of the launch template. You must specify the LaunchTemplateName or the LaunchTemplateId, but not both.\n */\nLaunchTemplateName?: string\n/**\n * The version number of the launch template.\n */\nVersion?: string\n/**\n * The ID of the launch template. You must specify the LaunchTemplateName or the LaunchTemplateId, but not both.\n */\nLaunchTemplateId?: string\n} & {\n[k: string]: unknown\n})\n\n/**\n * Resource Type definition for AWS::EC2::Instance\n */\nexport interface _AWS_EC2_INSTANCE {\n/**\n * The private DNS name of the specified instance. For example: ip-10-24-34-0.ec2.internal.\n */\nPrivateDnsName?: string\n/**\n * The volumes to attach to the instance.\n */\nVolumes?: Volume[]\n/**\n * The private IP address of the specified instance. For example: 10.24.34.0.\n */\nPrivateIp?: string\n/**\n * Indicates whether the instance is enabled for AWS Nitro Enclaves.\n */\nEnclaveOptions?: {\n/**\n * If this parameter is set to true, the instance is enabled for AWS Nitro Enclaves; otherwise, it is not enabled for AWS Nitro Enclaves.\n */\nEnabled?: boolean\n}\n/**\n * The ID of the AMI. An AMI ID is required to launch an instance and must be specified here or in a launch template.\n */\nImageId?: string\n/**\n * The tags to add to the instance.\n */\nTags?: Tag[]\n/**\n * This property is reserved for internal use. If you use it, the stack fails with this error: Bad property set: [Testing this property] (Service: AmazonEC2; Status Code: 400; Error Code: InvalidParameterCombination; Request ID: 0XXXXXX-49c7-4b40-8bcc-76885dcXXXXX).\n */\nAdditionalInfo?: string\n/**\n * Indicates whether an instance is enabled for hibernation.\n */\nHibernationOptions?: {\n/**\n * If you set this parameter to true, your instance is enabled for hibernation.\n */\nConfigured?: boolean\n}\n/**\n * The license configurations.\n */\nLicenseSpecifications?: LicenseSpecification[]\nMetadataOptions?: MetadataOptions\n/**\n * The EC2 Instance ID.\n */\nInstanceId?: string\n/**\n * The CPU options for the instance.\n */\nCpuOptions?: {\nThreadsPerCore?: number\nCoreCount?: number\n}\n/**\n * The Availability Zone of the instance.\n */\nAvailabilityZone?: string\nPrivateDnsNameOptions?: PrivateDnsNameOptions\n/**\n * If you specify host for the Affinity property, the ID of a dedicated host that the instance is associated with. If you don't specify an ID, Amazon EC2 launches the instance onto any available, compatible dedicated host in your account.\n */\nHostId?: string\n/**\n * The public DNS name of the specified instance. For example: ec2-107-20-50-45.compute-1.amazonaws.com.\n */\nPublicDnsName?: string\n/**\n * The IDs of the security groups.\n */\nSecurityGroupIds?: string[]\n/**\n * The name of an existing placement group that you want to launch the instance into (cluster | partition | spread).\n */\nPlacementGroupName?: string\n/**\n * The SSM document and parameter values in AWS Systems Manager to associate with this instance.\n */\nSsmAssociations?: SsmAssociation[]\n/**\n * The ID of the VPC that the instance is running in.\n */\nVpcId?: string\nState?: State\n/**\n * Indicates whether the instance is associated with a dedicated host. If you want the instance to always restart on the same host on which it was launched, specify host. If you want the instance to restart on any available host, but try to launch onto the last host it ran on (on a best-effort basis), specify default.\n */\nAffinity?: (\"default\" | \"host\")\n/**\n * The tenancy of the instance (if the instance is running in a VPC). An instance with a tenancy of dedicated runs on single-tenant hardware.\n */\nTenancy?: string\n/**\n * the names of the security groups. For a nondefault VPC, you must use security group IDs instead.\n */\nSecurityGroups?: string[]\n/**\n * [EC2-VPC] The primary IPv4 address. You must specify a value from the IPv4 address range of the subnet.\n */\nPrivateIpAddress?: string\n/**\n * The user data to make available to the instance.\n */\nUserData?: string\n/**\n * The block device mapping entries that defines the block devices to attach to the instance at launch.\n */\nBlockDeviceMappings?: BlockDeviceMapping[]\n/**\n * The IAM instance profile.\n */\nIamInstanceProfile?: string\n/**\n * [EC2-VPC] The IPv6 addresses from the range of the subnet to associate with the primary network interface.\n */\nIpv6Addresses?: InstanceIpv6Address[]\n/**\n * The ID of the kernel.\n */\nKernelId?: string\n/**\n * [EC2-VPC] The ID of the subnet to launch the instance into.\n * \n * \n */\nSubnetId?: string\n/**\n * Indicates whether the instance is optimized for Amazon EBS I/O.\n */\nEbsOptimized?: boolean\n/**\n * Indicates whether to assign the tags from the instance to all of the volumes attached to the instance at launch. If you specify true and you assign tags to the instance, those tags are automatically assigned to all of the volumes that you attach to the instance at launch. If you specify false, those tags are not assigned to the attached volumes.\n */\nPropagateTagsToVolumeOnCreation?: boolean\n/**\n * An elastic GPU to associate with the instance.\n */\nElasticGpuSpecifications?: ElasticGpuSpecification[]\n/**\n * An elastic inference accelerator to associate with the instance.\n */\nElasticInferenceAccelerators?: ElasticInferenceAccelerator[]\n/**\n * [EC2-VPC] The number of IPv6 addresses to associate with the primary network interface. Amazon EC2 chooses the IPv6 addresses from the range of your subnet.\n */\nIpv6AddressCount?: number\nLaunchTemplate?: LaunchTemplateSpecification\n/**\n * The network interfaces to associate with the instance.\n */\nNetworkInterfaces?: NetworkInterface[]\n/**\n * The instance type.\n */\nInstanceType?: string\n/**\n * Specifies whether detailed monitoring is enabled for the instance.\n */\nMonitoring?: boolean\n/**\n * The public IP address of the specified instance. For example: 192.0.2.0.\n */\nPublicIp?: string\n/**\n * Indicates whether an instance stops or terminates when you initiate shutdown from the instance (using the operating system command for system shutdown).\n */\nInstanceInitiatedShutdownBehavior?: string\n/**\n * The ARN of the host resource group in which to launch the instances. If you specify a host resource group ARN, omit the Tenancy parameter or set it to host.\n */\nHostResourceGroupArn?: string\n/**\n * If you set this parameter to true, you can't terminate the instance using the Amazon EC2 console, CLI, or API; otherwise, you can.\n */\nDisableApiTermination?: boolean\n/**\n * The name of the key pair.\n */\nKeyName?: string\n/**\n * The ID of the RAM disk to select.\n */\nRamdiskId?: string\n/**\n * Specifies whether to enable an instance launched in a VPC to perform NAT.\n */\nSourceDestCheck?: boolean\n/**\n * The credit option for CPU usage of the burstable performance instance. Valid values are standard and unlimited.\n */\nCreditSpecification?: {\nCPUCredits?: string\n}\n}\nexport interface Volume {\n/**\n * The ID of the EBS volume. The volume and instance must be within the same Availability Zone.\n */\nVolumeId: string\n/**\n * The device name (for example, /dev/sdh or xvdh).\n */\nDevice: string\n}\nexport interface Tag {\nValue: string\nKey: string\n}\nexport interface LicenseSpecification {\n/**\n * The Amazon Resource Name (ARN) of the license configuration.\n */\nLicenseConfigurationArn: string\n}\n/**\n * The metadata options for the instance\n */\nexport interface MetadataOptions {\n/**\n * The number of network hops that the metadata token can travel. Maximum is 64.\n */\nHttpPutResponseHopLimit?: number\n/**\n * Enables or disables the IPv6 endpoint for the instance metadata service. To use this option, the instance must be a Nitro-based instance launched in a subnet that supports IPv6.\n */\nHttpProtocolIpv6?: (\"disabled\" | \"enabled\")\n/**\n * Indicates whether IMDSv2 is required.\n */\nHttpTokens?: (\"optional\" | \"required\")\n/**\n * Indicates whether tags from the instance are propagated to the EBS volumes.\n */\nInstanceMetadataTags?: (\"disabled\" | \"enabled\")\n/**\n * Enables or disables the HTTP metadata endpoint on your instances. If you specify a value of disabled, you cannot access your instance metadata.\n */\nHttpEndpoint?: (\"disabled\" | \"enabled\")\n}\n/**\n * The options for the instance hostname.\n */\nexport interface PrivateDnsNameOptions {\n/**\n * Indicates whether to respond to DNS queries for instance hostnames with DNS A records. For more information, see Amazon EC2 instance hostname types in the Amazon Elastic Compute Cloud User Guide.\n */\nEnableResourceNameDnsARecord?: boolean\n/**\n * The type of hostnames to assign to instances in the subnet at launch. For IPv4 only subnets, an instance DNS name must be based on the instance IPv4 address. For IPv6 only subnets, an instance DNS name must be based on the instance ID. For dual-stack subnets, you can specify whether DNS names use the instance IPv4 address or the instance ID. For more information, see Amazon EC2 instance hostname types in the Amazon Elastic Compute Cloud User Guide.\n */\nHostnameType?: (\"ip-name\" | \"resource-name\")\n/**\n * Indicates whether to respond to DNS queries for instance hostnames with DNS AAAA records. For more information, see Amazon EC2 instance hostname types in the Amazon Elastic Compute Cloud User Guide.\n */\nEnableResourceNameDnsAAAARecord?: boolean\n}\nexport interface SsmAssociation {\n/**\n * The input parameter values to use with the associated SSM document.\n */\nAssociationParameters?: AssociationParameter[]\n/**\n * The name of an SSM document to associate with the instance.\n */\nDocumentName: string\n}\nexport interface AssociationParameter {\n/**\n * The value of an input parameter.\n */\nValue: string[]\n/**\n * The name of an input parameter that is in the associated SSM document.\n */\nKey: string\n}\n/**\n * The current state of the instance.\n */\nexport interface State {\n/**\n * The state of the instance as a 16-bit unsigned integer.\n */\nCode?: string\n/**\n * The current state of the instance.\n */\nName?: string\n}\nexport interface BlockDeviceMapping {\nEbs?: Ebs\nNoDevice?: {\n\n}\nVirtualName?: string\n/**\n * The device name (for example, /dev/sdh or xvdh).\n */\nDeviceName: string\n}\n/**\n * Parameters used to automatically set up EBS volumes when the instance is launched.\n */\nexport interface Ebs {\n/**\n * The ID of the snapshot.\n */\nSnapshotId?: string\n/**\n * The volume type.\n */\nVolumeType?: string\n/**\n * The identifier of the AWS Key Management Service (AWS KMS) customer managed CMK to use for Amazon EBS encryption. If KmsKeyId is specified, the encrypted state must be true. If the encrypted state is true but you do not specify KmsKeyId, your AWS managed CMK for EBS is used.\n */\nKmsKeyId?: string\n/**\n * Indicates whether the volume should be encrypted.\n */\nEncrypted?: boolean\n/**\n * The number of I/O operations per second (IOPS). For gp3, io1, and io2 volumes, this represents the number of IOPS that are provisioned for the volume. For gp2 volumes, this represents the baseline performance of the volume and the rate at which the volume accumulates I/O credits for bursting.\n */\nIops?: number\n/**\n * The size of the volume, in GiBs. You must specify either a snapshot ID or a volume size. If you specify a snapshot, the default is the snapshot size. You can specify a volume size that is equal to or larger than the snapshot size.\n */\nVolumeSize?: number\n/**\n * Indicates whether the EBS volume is deleted on instance termination.\n */\nDeleteOnTermination?: boolean\n}\nexport interface InstanceIpv6Address {\n/**\n * The IPv6 address.\n */\nIpv6Address: string\n}\nexport interface ElasticGpuSpecification {\n/**\n * The type of Elastic Graphics accelerator.\n */\nType: string\n}\nexport interface ElasticInferenceAccelerator {\n/**\n * The type of elastic inference accelerator.\n */\nType: string\n/**\n * The number of elastic inference accelerators to attach to the instance.\n */\nCount?: number\n}\nexport interface NetworkInterface {\n/**\n * The description of the network interface.\n */\nDescription?: string\n/**\n * The private IPv4 address of the network interface.\n */\nPrivateIpAddress?: string\n/**\n * One or more private IPv4 addresses to assign to the network interface.\n */\nPrivateIpAddresses?: PrivateIpAddressSpecification[]\n/**\n * The number of secondary private IPv4 addresses.\n */\nSecondaryPrivateIpAddressCount?: number\n/**\n * The position of the network interface in the attachment order. A primary network interface has a device index of 0.\n */\nDeviceIndex: string\n/**\n * The IDs of the security groups for the network interface.\n */\nGroupSet?: string[]\n/**\n * The IPv6 addresses associated with the network interface.\n */\nIpv6Addresses?: InstanceIpv6Address[]\n/**\n * The ID of the subnet.\n */\nSubnetId?: string\n/**\n * Indicates whether to assign a public IPv4 address to an instance you launch in a VPC.\n */\nAssociatePublicIpAddress?: boolean\n/**\n * The ID of the network interface.\n */\nNetworkInterfaceId?: string\n/**\n * Not currently supported by AWS CloudFormation.\n */\nAssociateCarrierIpAddress?: boolean\nEnaSrdSpecification?: EnaSrdSpecification\n/**\n * A number of IPv6 addresses to assign to the network interface.\n */\nIpv6AddressCount?: number\n/**\n * If set to true, the interface is deleted when the instance is terminated.\n */\nDeleteOnTermination?: boolean\n}\nexport interface PrivateIpAddressSpecification {\n/**\n * The private IPv4 addresses.\n */\nPrivateIpAddress: string\n/**\n * Indicates whether the private IPv4 address is the primary private IPv4 address. Only one IPv4 address can be designated as primary.\n */\nPrimary: boolean\n}\n/**\n * Specifies the ENA Express settings for the network interface that's attached to the instance.\n */\nexport interface EnaSrdSpecification {\n/**\n * Specifies whether ENA Express is enabled for the network interface when you launch an instance.\n */\nEnaSrdEnabled?: boolean\nEnaSrdUdpSpecification?: EnaSrdUdpSpecification\n}\n/**\n * Contains ENA Express settings for UDP network traffic for the network interface that's attached to the instance.\n */\nexport interface EnaSrdUdpSpecification {\n/**\n * Indicates whether UDP traffic uses ENA Express for your instance.\n */\nEnaSrdUdpEnabled?: boolean\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-ec2-instance.js","sourceRoot":"","sources":["aws-ec2-instance.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * The launch template to use to launch the instances.\n */\nexport type LaunchTemplateSpecification = ({\n/**\n * The name of the launch template. You must specify the LaunchTemplateName or the LaunchTemplateId, but not both.\n */\nLaunchTemplateName?: string\n/**\n * The version number of the launch template.\n */\nVersion?: string\n/**\n * The ID of the launch template. You must specify the LaunchTemplateName or the LaunchTemplateId, but not both.\n */\nLaunchTemplateId?: string\n} & {\n[k: string]: unknown\n})\n\n/**\n * Resource Type definition for AWS::EC2::Instance\n */\nexport interface _AWS_EC2_INSTANCE {\n/**\n * The private DNS name of the specified instance. For example: ip-10-24-34-0.ec2.internal.\n */\nPrivateDnsName?: string\n/**\n * The volumes to attach to the instance.\n */\nVolumes?: Volume[]\n/**\n * The private IP address of the specified instance. For example: 10.24.34.0.\n */\nPrivateIp?: string\n/**\n * Indicates whether the instance is enabled for AWS Nitro Enclaves.\n */\nEnclaveOptions?: {\n/**\n * If this parameter is set to true, the instance is enabled for AWS Nitro Enclaves; otherwise, it is not enabled for AWS Nitro Enclaves.\n */\nEnabled?: boolean\n}\n/**\n * The ID of the AMI. An AMI ID is required to launch an instance and must be specified here or in a launch template.\n */\nImageId?: string\n/**\n * The tags to add to the instance.\n */\nTags?: Tag[]\n/**\n * This property is reserved for internal use. If you use it, the stack fails with this error: Bad property set: [Testing this property] (Service: AmazonEC2; Status Code: 400; Error Code: InvalidParameterCombination; Request ID: 0XXXXXX-49c7-4b40-8bcc-76885dcXXXXX).\n */\nAdditionalInfo?: string\n/**\n * Indicates whether an instance is enabled for hibernation.\n */\nHibernationOptions?: {\n/**\n * If you set this parameter to true, your instance is enabled for hibernation.\n */\nConfigured?: boolean\n}\n/**\n * The license configurations.\n */\nLicenseSpecifications?: LicenseSpecification[]\nMetadataOptions?: MetadataOptions\n/**\n * The EC2 Instance ID.\n */\nInstanceId?: string\n/**\n * The CPU options for the instance.\n */\nCpuOptions?: {\nThreadsPerCore?: number\nCoreCount?: number\n}\n/**\n * The Availability Zone of the instance.\n */\nAvailabilityZone?: string\nPrivateDnsNameOptions?: PrivateDnsNameOptions\n/**\n * If you specify host for the Affinity property, the ID of a dedicated host that the instance is associated with. If you don't specify an ID, Amazon EC2 launches the instance onto any available, compatible dedicated host in your account.\n */\nHostId?: string\n/**\n * The public DNS name of the specified instance. For example: ec2-107-20-50-45.compute-1.amazonaws.com.\n */\nPublicDnsName?: string\n/**\n * The IDs of the security groups.\n */\nSecurityGroupIds?: string[]\n/**\n * The name of an existing placement group that you want to launch the instance into (cluster | partition | spread).\n */\nPlacementGroupName?: string\n/**\n * The SSM document and parameter values in AWS Systems Manager to associate with this instance.\n */\nSsmAssociations?: SsmAssociation[]\n/**\n * The ID of the VPC that the instance is running in.\n */\nVpcId?: string\nState?: State\n/**\n * Indicates whether the instance is associated with a dedicated host. If you want the instance to always restart on the same host on which it was launched, specify host. If you want the instance to restart on any available host, but try to launch onto the last host it ran on (on a best-effort basis), specify default.\n */\nAffinity?: (\"default\" | \"host\")\n/**\n * The tenancy of the instance (if the instance is running in a VPC). An instance with a tenancy of dedicated runs on single-tenant hardware.\n */\nTenancy?: string\n/**\n * the names of the security groups. For a nondefault VPC, you must use security group IDs instead.\n */\nSecurityGroups?: string[]\n/**\n * [EC2-VPC] The primary IPv4 address. You must specify a value from the IPv4 address range of the subnet.\n */\nPrivateIpAddress?: string\n/**\n * The user data to make available to the instance.\n */\nUserData?: string\n/**\n * The block device mapping entries that defines the block devices to attach to the instance at launch.\n */\nBlockDeviceMappings?: BlockDeviceMapping[]\n/**\n * The IAM instance profile.\n */\nIamInstanceProfile?: string\n/**\n * [EC2-VPC] The IPv6 addresses from the range of the subnet to associate with the primary network interface.\n */\nIpv6Addresses?: InstanceIpv6Address[]\n/**\n * The ID of the kernel.\n */\nKernelId?: string\n/**\n * [EC2-VPC] The ID of the subnet to launch the instance into.\n * \n * \n */\nSubnetId?: string\n/**\n * Indicates whether the instance is optimized for Amazon EBS I/O.\n */\nEbsOptimized?: boolean\n/**\n * Indicates whether to assign the tags from the instance to all of the volumes attached to the instance at launch. If you specify true and you assign tags to the instance, those tags are automatically assigned to all of the volumes that you attach to the instance at launch. If you specify false, those tags are not assigned to the attached volumes.\n */\nPropagateTagsToVolumeOnCreation?: boolean\n/**\n * An elastic GPU to associate with the instance.\n */\nElasticGpuSpecifications?: ElasticGpuSpecification[]\n/**\n * An elastic inference accelerator to associate with the instance.\n */\nElasticInferenceAccelerators?: ElasticInferenceAccelerator[]\n/**\n * [EC2-VPC] The number of IPv6 addresses to associate with the primary network interface. Amazon EC2 chooses the IPv6 addresses from the range of your subnet.\n */\nIpv6AddressCount?: number\nLaunchTemplate?: LaunchTemplateSpecification\n/**\n * The network interfaces to associate with the instance.\n */\nNetworkInterfaces?: NetworkInterface[]\n/**\n * The instance type.\n */\nInstanceType?: string\n/**\n * Specifies whether detailed monitoring is enabled for the instance.\n */\nMonitoring?: boolean\n/**\n * The public IP address of the specified instance. For example: 192.0.2.0.\n */\nPublicIp?: string\n/**\n * Indicates whether an instance stops or terminates when you initiate shutdown from the instance (using the operating system command for system shutdown).\n */\nInstanceInitiatedShutdownBehavior?: string\n/**\n * The ARN of the host resource group in which to launch the instances. If you specify a host resource group ARN, omit the Tenancy parameter or set it to host.\n */\nHostResourceGroupArn?: string\n/**\n * If you set this parameter to true, you can't terminate the instance using the Amazon EC2 console, CLI, or API; otherwise, you can.\n */\nDisableApiTermination?: boolean\n/**\n * The name of the key pair.\n */\nKeyName?: string\n/**\n * The ID of the RAM disk to select.\n */\nRamdiskId?: string\n/**\n * Specifies whether to enable an instance launched in a VPC to perform NAT.\n */\nSourceDestCheck?: boolean\n/**\n * The credit option for CPU usage of the burstable performance instance. Valid values are standard and unlimited.\n */\nCreditSpecification?: {\nCPUCredits?: string\n}\n}\nexport interface Volume {\n/**\n * The ID of the EBS volume. The volume and instance must be within the same Availability Zone.\n */\nVolumeId: string\n/**\n * The device name (for example, /dev/sdh or xvdh).\n */\nDevice: string\n}\nexport interface Tag {\nValue: string\nKey: string\n}\nexport interface LicenseSpecification {\n/**\n * The Amazon Resource Name (ARN) of the license configuration.\n */\nLicenseConfigurationArn: string\n}\n/**\n * The metadata options for the instance\n */\nexport interface MetadataOptions {\n/**\n * The number of network hops that the metadata token can travel. Maximum is 64.\n */\nHttpPutResponseHopLimit?: number\n/**\n * Enables or disables the IPv6 endpoint for the instance metadata service. To use this option, the instance must be a Nitro-based instance launched in a subnet that supports IPv6.\n */\nHttpProtocolIpv6?: (\"disabled\" | \"enabled\")\n/**\n * Indicates whether IMDSv2 is required.\n */\nHttpTokens?: (\"optional\" | \"required\")\n/**\n * Indicates whether tags from the instance are propagated to the EBS volumes.\n */\nInstanceMetadataTags?: (\"disabled\" | \"enabled\")\n/**\n * Enables or disables the HTTP metadata endpoint on your instances. If you specify a value of disabled, you cannot access your instance metadata.\n */\nHttpEndpoint?: (\"disabled\" | \"enabled\")\n}\n/**\n * The options for the instance hostname.\n */\nexport interface PrivateDnsNameOptions {\n/**\n * Indicates whether to respond to DNS queries for instance hostnames with DNS A records. For more information, see Amazon EC2 instance hostname types in the Amazon Elastic Compute Cloud User Guide.\n */\nEnableResourceNameDnsARecord?: boolean\n/**\n * The type of hostnames to assign to instances in the subnet at launch. For IPv4 only subnets, an instance DNS name must be based on the instance IPv4 address. For IPv6 only subnets, an instance DNS name must be based on the instance ID. For dual-stack subnets, you can specify whether DNS names use the instance IPv4 address or the instance ID. For more information, see Amazon EC2 instance hostname types in the Amazon Elastic Compute Cloud User Guide.\n */\nHostnameType?: (\"ip-name\" | \"resource-name\")\n/**\n * Indicates whether to respond to DNS queries for instance hostnames with DNS AAAA records. For more information, see Amazon EC2 instance hostname types in the Amazon Elastic Compute Cloud User Guide.\n */\nEnableResourceNameDnsAAAARecord?: boolean\n}\nexport interface SsmAssociation {\n/**\n * The input parameter values to use with the associated SSM document.\n */\nAssociationParameters?: AssociationParameter[]\n/**\n * The name of an SSM document to associate with the instance.\n */\nDocumentName: string\n}\nexport interface AssociationParameter {\n/**\n * The value of an input parameter.\n */\nValue: string[]\n/**\n * The name of an input parameter that is in the associated SSM document.\n */\nKey: string\n}\n/**\n * The current state of the instance.\n */\nexport interface State {\n/**\n * The state of the instance as a 16-bit unsigned integer.\n */\nCode?: string\n/**\n * The current state of the instance.\n */\nName?: string\n}\nexport interface BlockDeviceMapping {\nEbs?: Ebs\nNoDevice?: {\n\n}\nVirtualName?: string\n/**\n * The device name (for example, /dev/sdh or xvdh).\n */\nDeviceName: string\n}\n/**\n * Parameters used to automatically set up EBS volumes when the instance is launched.\n */\nexport interface Ebs {\n/**\n * The ID of the snapshot.\n */\nSnapshotId?: string\n/**\n * The volume type.\n */\nVolumeType?: string\n/**\n * The identifier of the AWS Key Management Service (AWS KMS) customer managed CMK to use for Amazon EBS encryption. If KmsKeyId is specified, the encrypted state must be true. If the encrypted state is true but you do not specify KmsKeyId, your AWS managed CMK for EBS is used.\n */\nKmsKeyId?: string\n/**\n * Indicates whether the volume should be encrypted.\n */\nEncrypted?: boolean\n/**\n * The number of I/O operations per second (IOPS). For gp3, io1, and io2 volumes, this represents the number of IOPS that are provisioned for the volume. For gp2 volumes, this represents the baseline performance of the volume and the rate at which the volume accumulates I/O credits for bursting.\n */\nIops?: number\n/**\n * The size of the volume, in GiBs. You must specify either a snapshot ID or a volume size. If you specify a snapshot, the default is the snapshot size. You can specify a volume size that is equal to or larger than the snapshot size.\n */\nVolumeSize?: number\n/**\n * Indicates whether the EBS volume is deleted on instance termination.\n */\nDeleteOnTermination?: boolean\n}\nexport interface InstanceIpv6Address {\n/**\n * The IPv6 address.\n */\nIpv6Address: string\n}\nexport interface ElasticGpuSpecification {\n/**\n * The type of Elastic Graphics accelerator. Amazon Elastic Graphics is no longer available.\n */\nType: string\n}\nexport interface ElasticInferenceAccelerator {\n/**\n * The type of elastic inference accelerator. Amazon Elastic Inference is no longer available.\n */\nType: string\n/**\n * The number of elastic inference accelerators to attach to the instance. Amazon Elastic Inference is no longer available.\n */\nCount?: number\n}\nexport interface NetworkInterface {\n/**\n * The description of the network interface.\n */\nDescription?: string\n/**\n * The private IPv4 address of the network interface.\n */\nPrivateIpAddress?: string\n/**\n * One or more private IPv4 addresses to assign to the network interface.\n */\nPrivateIpAddresses?: PrivateIpAddressSpecification[]\n/**\n * The number of secondary private IPv4 addresses.\n */\nSecondaryPrivateIpAddressCount?: number\n/**\n * The position of the network interface in the attachment order. A primary network interface has a device index of 0.\n */\nDeviceIndex: string\n/**\n * The IDs of the security groups for the network interface.\n */\nGroupSet?: string[]\n/**\n * The IPv6 addresses associated with the network interface.\n */\nIpv6Addresses?: InstanceIpv6Address[]\n/**\n * The ID of the subnet.\n */\nSubnetId?: string\n/**\n * Indicates whether to assign a public IPv4 address to an instance you launch in a VPC.\n */\nAssociatePublicIpAddress?: boolean\n/**\n * The ID of the network interface.\n */\nNetworkInterfaceId?: string\n/**\n * Not currently supported by AWS CloudFormation.\n */\nAssociateCarrierIpAddress?: boolean\nEnaSrdSpecification?: EnaSrdSpecification\n/**\n * A number of IPv6 addresses to assign to the network interface.\n */\nIpv6AddressCount?: number\n/**\n * If set to true, the interface is deleted when the instance is terminated.\n */\nDeleteOnTermination?: boolean\n}\nexport interface PrivateIpAddressSpecification {\n/**\n * The private IPv4 addresses.\n */\nPrivateIpAddress: string\n/**\n * Indicates whether the private IPv4 address is the primary private IPv4 address. Only one IPv4 address can be designated as primary.\n */\nPrimary: boolean\n}\n/**\n * Specifies the ENA Express settings for the network interface that's attached to the instance.\n */\nexport interface EnaSrdSpecification {\n/**\n * Specifies whether ENA Express is enabled for the network interface when you launch an instance.\n */\nEnaSrdEnabled?: boolean\nEnaSrdUdpSpecification?: EnaSrdUdpSpecification\n}\n/**\n * Contains ENA Express settings for UDP network traffic for the network interface that's attached to the instance.\n */\nexport interface EnaSrdUdpSpecification {\n/**\n * Indicates whether UDP traffic uses ENA Express for your instance.\n */\nEnaSrdUdpEnabled?: boolean\n}\n"]}
@@ -0,0 +1,83 @@
1
+ /**
2
+ * Resource Type definition for AWS::EC2::TransitGatewayConnectPeer
3
+ */
4
+ export interface _AWS_EC2_TRANSITGATEWAYCONNECTPEER {
5
+ /**
6
+ * The ID of the Connect attachment.
7
+ */
8
+ TransitGatewayAttachmentId: string;
9
+ /**
10
+ * The ID of the Connect peer.
11
+ */
12
+ TransitGatewayConnectPeerId?: string;
13
+ /**
14
+ * The state of the Connect peer.
15
+ */
16
+ State?: string;
17
+ /**
18
+ * The creation time.
19
+ */
20
+ CreationTime?: string;
21
+ ConnectPeerConfiguration: TransitGatewayConnectPeerConfiguration;
22
+ /**
23
+ * The tags for the Connect Peer.
24
+ */
25
+ Tags?: Tag[];
26
+ }
27
+ /**
28
+ * The Connect peer details.
29
+ */
30
+ export interface TransitGatewayConnectPeerConfiguration {
31
+ /**
32
+ * The Connect peer IP address on the transit gateway side of the tunnel.
33
+ */
34
+ TransitGatewayAddress?: string;
35
+ /**
36
+ * The peer IP address (GRE outer IP address) on the appliance side of the Connect peer.
37
+ */
38
+ PeerAddress: string;
39
+ /**
40
+ * The range of interior BGP peer IP addresses.
41
+ */
42
+ InsideCidrBlocks: string[];
43
+ /**
44
+ * The tunnel protocol.
45
+ */
46
+ Protocol?: string;
47
+ /**
48
+ * The BGP configuration details.
49
+ */
50
+ BgpConfigurations?: TransitGatewayAttachmentBgpConfiguration[];
51
+ }
52
+ export interface TransitGatewayAttachmentBgpConfiguration {
53
+ /**
54
+ * The transit gateway Autonomous System Number (ASN).
55
+ */
56
+ TransitGatewayAsn?: number;
57
+ /**
58
+ * The peer Autonomous System Number (ASN).
59
+ */
60
+ PeerAsn?: number;
61
+ /**
62
+ * The interior BGP peer IP address for the transit gateway.
63
+ */
64
+ TransitGatewayAddress?: string;
65
+ /**
66
+ * The interior BGP peer IP address for the appliance.
67
+ */
68
+ PeerAddress?: string;
69
+ /**
70
+ * The BGP status.
71
+ */
72
+ BgpStatus?: string;
73
+ }
74
+ export interface Tag {
75
+ /**
76
+ * The value of the tag. Constraints: Tag values are case-sensitive and accept a maximum of 256 Unicode characters.
77
+ */
78
+ Value?: string;
79
+ /**
80
+ * The key of the tag. Constraints: Tag keys are case-sensitive and accept a maximum of 127 Unicode characters. May not begin with aws: .
81
+ */
82
+ Key?: string;
83
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWVjMi10cmFuc2l0Z2F0ZXdheWNvbm5lY3RwZWVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWVjMi10cmFuc2l0Z2F0ZXdheWNvbm5lY3RwZWVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJlc291cmNlIFR5cGUgZGVmaW5pdGlvbiBmb3IgQVdTOjpFQzI6OlRyYW5zaXRHYXRld2F5Q29ubmVjdFBlZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBfQVdTX0VDMl9UUkFOU0lUR0FURVdBWUNPTk5FQ1RQRUVSIHtcbi8qKlxuICogVGhlIElEIG9mIHRoZSBDb25uZWN0IGF0dGFjaG1lbnQuXG4gKi9cblRyYW5zaXRHYXRld2F5QXR0YWNobWVudElkOiBzdHJpbmdcbi8qKlxuICogVGhlIElEIG9mIHRoZSBDb25uZWN0IHBlZXIuXG4gKi9cblRyYW5zaXRHYXRld2F5Q29ubmVjdFBlZXJJZD86IHN0cmluZ1xuLyoqXG4gKiBUaGUgc3RhdGUgb2YgdGhlIENvbm5lY3QgcGVlci5cbiAqL1xuU3RhdGU/OiBzdHJpbmdcbi8qKlxuICogVGhlIGNyZWF0aW9uIHRpbWUuXG4gKi9cbkNyZWF0aW9uVGltZT86IHN0cmluZ1xuQ29ubmVjdFBlZXJDb25maWd1cmF0aW9uOiBUcmFuc2l0R2F0ZXdheUNvbm5lY3RQZWVyQ29uZmlndXJhdGlvblxuLyoqXG4gKiBUaGUgdGFncyBmb3IgdGhlIENvbm5lY3QgUGVlci5cbiAqL1xuVGFncz86IFRhZ1tdXG59XG4vKipcbiAqIFRoZSBDb25uZWN0IHBlZXIgZGV0YWlscy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmFuc2l0R2F0ZXdheUNvbm5lY3RQZWVyQ29uZmlndXJhdGlvbiB7XG4vKipcbiAqIFRoZSBDb25uZWN0IHBlZXIgSVAgYWRkcmVzcyBvbiB0aGUgdHJhbnNpdCBnYXRld2F5IHNpZGUgb2YgdGhlIHR1bm5lbC5cbiAqL1xuVHJhbnNpdEdhdGV3YXlBZGRyZXNzPzogc3RyaW5nXG4vKipcbiAqIFRoZSBwZWVyIElQIGFkZHJlc3MgKEdSRSBvdXRlciBJUCBhZGRyZXNzKSBvbiB0aGUgYXBwbGlhbmNlIHNpZGUgb2YgdGhlIENvbm5lY3QgcGVlci5cbiAqL1xuUGVlckFkZHJlc3M6IHN0cmluZ1xuLyoqXG4gKiBUaGUgcmFuZ2Ugb2YgaW50ZXJpb3IgQkdQIHBlZXIgSVAgYWRkcmVzc2VzLlxuICovXG5JbnNpZGVDaWRyQmxvY2tzOiBzdHJpbmdbXVxuLyoqXG4gKiBUaGUgdHVubmVsIHByb3RvY29sLlxuICovXG5Qcm90b2NvbD86IHN0cmluZ1xuLyoqXG4gKiBUaGUgQkdQIGNvbmZpZ3VyYXRpb24gZGV0YWlscy5cbiAqL1xuQmdwQ29uZmlndXJhdGlvbnM/OiBUcmFuc2l0R2F0ZXdheUF0dGFjaG1lbnRCZ3BDb25maWd1cmF0aW9uW11cbn1cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNpdEdhdGV3YXlBdHRhY2htZW50QmdwQ29uZmlndXJhdGlvbiB7XG4vKipcbiAqIFRoZSB0cmFuc2l0IGdhdGV3YXkgQXV0b25vbW91cyBTeXN0ZW0gTnVtYmVyIChBU04pLlxuICovXG5UcmFuc2l0R2F0ZXdheUFzbj86IG51bWJlclxuLyoqXG4gKiBUaGUgcGVlciBBdXRvbm9tb3VzIFN5c3RlbSBOdW1iZXIgKEFTTikuXG4gKi9cblBlZXJBc24/OiBudW1iZXJcbi8qKlxuICogVGhlIGludGVyaW9yIEJHUCBwZWVyIElQIGFkZHJlc3MgZm9yIHRoZSB0cmFuc2l0IGdhdGV3YXkuXG4gKi9cblRyYW5zaXRHYXRld2F5QWRkcmVzcz86IHN0cmluZ1xuLyoqXG4gKiBUaGUgaW50ZXJpb3IgQkdQIHBlZXIgSVAgYWRkcmVzcyBmb3IgdGhlIGFwcGxpYW5jZS5cbiAqL1xuUGVlckFkZHJlc3M/OiBzdHJpbmdcbi8qKlxuICogVGhlIEJHUCBzdGF0dXMuXG4gKi9cbkJncFN0YXR1cz86IHN0cmluZ1xufVxuZXhwb3J0IGludGVyZmFjZSBUYWcge1xuLyoqXG4gKiBUaGUgdmFsdWUgb2YgdGhlIHRhZy4gQ29uc3RyYWludHM6IFRhZyB2YWx1ZXMgYXJlIGNhc2Utc2Vuc2l0aXZlIGFuZCBhY2NlcHQgYSBtYXhpbXVtIG9mIDI1NiBVbmljb2RlIGNoYXJhY3RlcnMuXG4gKi9cblZhbHVlPzogc3RyaW5nXG4vKipcbiAqIFRoZSBrZXkgb2YgdGhlIHRhZy4gQ29uc3RyYWludHM6IFRhZyBrZXlzIGFyZSBjYXNlLXNlbnNpdGl2ZSBhbmQgYWNjZXB0IGEgbWF4aW11bSBvZiAxMjcgVW5pY29kZSBjaGFyYWN0ZXJzLiBNYXkgbm90IGJlZ2luIHdpdGggYXdzOiAuXG4gKi9cbktleT86IHN0cmluZ1xufVxuIl19
@@ -1,3 +1,11 @@
1
+ /**
2
+ * Specifies the type of filter to use for excluding image tags from the repository's mutability setting.
3
+ */
4
+ export type ImageTagMutabilityExclusionFilterType = "WILDCARD";
5
+ /**
6
+ * The value to use when filtering image tags.
7
+ */
8
+ export type ImageTagMutabilityExclusionFilterValue = string;
1
9
  /**
2
10
  * The ``AWS::ECR::Repository`` resource specifies an Amazon Elastic Container Registry (Amazon ECR) repository, where users can push and pull Docker images, Open Container Initiative (OCI) images, and OCI compatible artifacts. For more information, see [Amazon ECR private repositories](https://docs.aws.amazon.com/AmazonECR/latest/userguide/Repositories.html) in the *Amazon ECR User Guide*.
3
11
  */
@@ -30,7 +38,12 @@ export interface _AWS_ECR_REPOSITORY {
30
38
  /**
31
39
  * The tag mutability setting for the repository. If this parameter is omitted, the default setting of ``MUTABLE`` will be used which will allow image tags to be overwritten. If ``IMMUTABLE`` is specified, all image tags within the repository will be immutable which will prevent them from being overwritten.
32
40
  */
33
- ImageTagMutability?: ("MUTABLE" | "IMMUTABLE");
41
+ ImageTagMutability?: ("MUTABLE" | "IMMUTABLE" | "MUTABLE_WITH_EXCLUSION" | "IMMUTABLE_WITH_EXCLUSION");
42
+ /**
43
+ * @minItems 1
44
+ * @maxItems 5
45
+ */
46
+ ImageTagMutabilityExclusionFilters?: ImageTagMutabilityExclusionFilter[];
34
47
  ImageScanningConfiguration?: ImageScanningConfiguration;
35
48
  EncryptionConfiguration?: EncryptionConfiguration;
36
49
  }
@@ -61,6 +74,10 @@ export interface Tag {
61
74
  */
62
75
  Value: string;
63
76
  }
77
+ export interface ImageTagMutabilityExclusionFilter {
78
+ ImageTagMutabilityExclusionFilterType: ImageTagMutabilityExclusionFilterType;
79
+ ImageTagMutabilityExclusionFilterValue: ImageTagMutabilityExclusionFilterValue;
80
+ }
64
81
  /**
65
82
  * The image scanning configuration for the repository. This determines whether images are scanned for known vulnerabilities after being pushed to the repository.
66
83
  */
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWVjci1yZXBvc2l0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWVjci1yZXBvc2l0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoZSBgYEFXUzo6RUNSOjpSZXBvc2l0b3J5YGAgcmVzb3VyY2Ugc3BlY2lmaWVzIGFuIEFtYXpvbiBFbGFzdGljIENvbnRhaW5lciBSZWdpc3RyeSAoQW1hem9uIEVDUikgcmVwb3NpdG9yeSwgd2hlcmUgdXNlcnMgY2FuIHB1c2ggYW5kIHB1bGwgRG9ja2VyIGltYWdlcywgT3BlbiBDb250YWluZXIgSW5pdGlhdGl2ZSAoT0NJKSBpbWFnZXMsIGFuZCBPQ0kgY29tcGF0aWJsZSBhcnRpZmFjdHMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0FtYXpvbiBFQ1IgcHJpdmF0ZSByZXBvc2l0b3JpZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BbWF6b25FQ1IvbGF0ZXN0L3VzZXJndWlkZS9SZXBvc2l0b3JpZXMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUNSIFVzZXIgR3VpZGUqLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIF9BV1NfRUNSX1JFUE9TSVRPUlkge1xuLyoqXG4gKiBJZiB0cnVlLCBkZWxldGluZyB0aGUgcmVwb3NpdG9yeSBmb3JjZSBkZWxldGVzIHRoZSBjb250ZW50cyBvZiB0aGUgcmVwb3NpdG9yeS4gSWYgZmFsc2UsIHRoZSByZXBvc2l0b3J5IG11c3QgYmUgZW1wdHkgYmVmb3JlIGF0dGVtcHRpbmcgdG8gZGVsZXRlIGl0LlxuICovXG5FbXB0eU9uRGVsZXRlPzogYm9vbGVhblxuTGlmZWN5Y2xlUG9saWN5PzogTGlmZWN5Y2xlUG9saWN5XG4vKipcbiAqIFRoZSBuYW1lIHRvIHVzZSBmb3IgdGhlIHJlcG9zaXRvcnkuIFRoZSByZXBvc2l0b3J5IG5hbWUgbWF5IGJlIHNwZWNpZmllZCBvbiBpdHMgb3duIChzdWNoIGFzIGBgbmdpbngtd2ViLWFwcGBgKSBvciBpdCBjYW4gYmUgcHJlcGVuZGVkIHdpdGggYSBuYW1lc3BhY2UgdG8gZ3JvdXAgdGhlIHJlcG9zaXRvcnkgaW50byBhIGNhdGVnb3J5IChzdWNoIGFzIGBgcHJvamVjdC1hL25naW54LXdlYi1hcHBgYCkuIElmIHlvdSBkb24ndCBzcGVjaWZ5IGEgbmFtZSwgQ0ZObG9uZyBnZW5lcmF0ZXMgYSB1bmlxdWUgcGh5c2ljYWwgSUQgYW5kIHVzZXMgdGhhdCBJRCBmb3IgdGhlIHJlcG9zaXRvcnkgbmFtZS4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbTmFtZSB0eXBlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcHJvcGVydGllcy1uYW1lLmh0bWwpLlxuICogIFRoZSByZXBvc2l0b3J5IG5hbWUgbXVzdCBzdGFydCB3aXRoIGEgbGV0dGVyIGFuZCBjYW4gb25seSBjb250YWluIGxvd2VyY2FzZSBsZXR0ZXJzLCBudW1iZXJzLCBoeXBoZW5zLCB1bmRlcnNjb3JlcywgYW5kIGZvcndhcmQgc2xhc2hlcy5cbiAqICAgSWYgeW91IHNwZWNpZnkgYSBuYW1lLCB5b3UgY2Fubm90IHBlcmZvcm0gdXBkYXRlcyB0aGF0IHJlcXVpcmUgcmVwbGFjZW1lbnQgb2YgdGhpcyByZXNvdXJjZS4gWW91IGNhbiBwZXJmb3JtIHVwZGF0ZXMgdGhhdCByZXF1aXJlIG5vIG9yIHNvbWUgaW50ZXJydXB0aW9uLiBJZiB5b3UgbXVzdCByZXBsYWNlIHRoZSByZXNvdXJjZSwgc3BlY2lmeSBhIG5ldyBuYW1lLlxuICovXG5SZXBvc2l0b3J5TmFtZT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgSlNPTiByZXBvc2l0b3J5IHBvbGljeSB0ZXh0IHRvIGFwcGx5IHRvIHRoZSByZXBvc2l0b3J5LiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBbWF6b24gRUNSIHJlcG9zaXRvcnkgcG9saWNpZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BbWF6b25FQ1IvbGF0ZXN0L3VzZXJndWlkZS9yZXBvc2l0b3J5LXBvbGljeS1leGFtcGxlcy5odG1sKSBpbiB0aGUgKkFtYXpvbiBFbGFzdGljIENvbnRhaW5lciBSZWdpc3RyeSBVc2VyIEd1aWRlKi5cbiAqL1xuUmVwb3NpdG9yeVBvbGljeVRleHQ/OiAoe1xuW2s6IHN0cmluZ106IHVua25vd25cbn0gfCBzdHJpbmcpXG4vKipcbiAqIEFuIGFycmF5IG9mIGtleS12YWx1ZSBwYWlycyB0byBhcHBseSB0byB0aGlzIHJlc291cmNlLlxuICogXG4gKiBAbWF4SXRlbXMgNTBcbiAqL1xuVGFncz86IFRhZ1tdXG5Bcm4/OiBzdHJpbmdcblJlcG9zaXRvcnlVcmk/OiBzdHJpbmdcbi8qKlxuICogVGhlIHRhZyBtdXRhYmlsaXR5IHNldHRpbmcgZm9yIHRoZSByZXBvc2l0b3J5LiBJZiB0aGlzIHBhcmFtZXRlciBpcyBvbWl0dGVkLCB0aGUgZGVmYXVsdCBzZXR0aW5nIG9mIGBgTVVUQUJMRWBgIHdpbGwgYmUgdXNlZCB3aGljaCB3aWxsIGFsbG93IGltYWdlIHRhZ3MgdG8gYmUgb3ZlcndyaXR0ZW4uIElmIGBgSU1NVVRBQkxFYGAgaXMgc3BlY2lmaWVkLCBhbGwgaW1hZ2UgdGFncyB3aXRoaW4gdGhlIHJlcG9zaXRvcnkgd2lsbCBiZSBpbW11dGFibGUgd2hpY2ggd2lsbCBwcmV2ZW50IHRoZW0gZnJvbSBiZWluZyBvdmVyd3JpdHRlbi5cbiAqL1xuSW1hZ2VUYWdNdXRhYmlsaXR5PzogKFwiTVVUQUJMRVwiIHwgXCJJTU1VVEFCTEVcIilcbkltYWdlU2Nhbm5pbmdDb25maWd1cmF0aW9uPzogSW1hZ2VTY2FubmluZ0NvbmZpZ3VyYXRpb25cbkVuY3J5cHRpb25Db25maWd1cmF0aW9uPzogRW5jcnlwdGlvbkNvbmZpZ3VyYXRpb25cbn1cbi8qKlxuICogQ3JlYXRlcyBvciB1cGRhdGVzIGEgbGlmZWN5Y2xlIHBvbGljeS4gRm9yIGluZm9ybWF0aW9uIGFib3V0IGxpZmVjeWNsZSBwb2xpY3kgc3ludGF4LCBzZWUgW0xpZmVjeWNsZSBwb2xpY3kgdGVtcGxhdGVdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BbWF6b25FQ1IvbGF0ZXN0L3VzZXJndWlkZS9MaWZlY3ljbGVQb2xpY2llcy5odG1sKS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMaWZlY3ljbGVQb2xpY3kge1xuLyoqXG4gKiBUaGUgSlNPTiByZXBvc2l0b3J5IHBvbGljeSB0ZXh0IHRvIGFwcGx5IHRvIHRoZSByZXBvc2l0b3J5LlxuICovXG5MaWZlY3ljbGVQb2xpY3lUZXh0Pzogc3RyaW5nXG4vKipcbiAqIFRoZSBBV1MgYWNjb3VudCBJRCBhc3NvY2lhdGVkIHdpdGggdGhlIHJlZ2lzdHJ5IHRoYXQgY29udGFpbnMgdGhlIHJlcG9zaXRvcnkuIElmIHlvdSBkb+KAqCBub3Qgc3BlY2lmeSBhIHJlZ2lzdHJ5LCB0aGUgZGVmYXVsdCByZWdpc3RyeSBpcyBhc3N1bWVkLlxuICovXG5SZWdpc3RyeUlkPzogc3RyaW5nXG59XG4vKipcbiAqIFRoZSBtZXRhZGF0YSB0byBhcHBseSB0byBhIHJlc291cmNlIHRvIGhlbHAgeW91IGNhdGVnb3JpemUgYW5kIG9yZ2FuaXplIHRoZW0uIEVhY2ggdGFnIGNvbnNpc3RzIG9mIGEga2V5IGFuZCBhIHZhbHVlLCBib3RoIG9mIHdoaWNoIHlvdSBkZWZpbmUuIFRhZyBrZXlzIGNhbiBoYXZlIGEgbWF4aW11bSBjaGFyYWN0ZXIgbGVuZ3RoIG9mIDEyOCBjaGFyYWN0ZXJzLCBhbmQgdGFnIHZhbHVlcyBjYW4gaGF2ZSBhIG1heGltdW0gbGVuZ3RoIG9mIDI1NiBjaGFyYWN0ZXJzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRhZyB7XG4vKipcbiAqIE9uZSBwYXJ0IG9mIGEga2V5LXZhbHVlIHBhaXIgdGhhdCBtYWtlIHVwIGEgdGFnLiBBIGBga2V5YGAgaXMgYSBnZW5lcmFsIGxhYmVsIHRoYXQgYWN0cyBsaWtlIGEgY2F0ZWdvcnkgZm9yIG1vcmUgc3BlY2lmaWMgdGFnIHZhbHVlcy5cbiAqL1xuS2V5OiBzdHJpbmdcbi8qKlxuICogQSBgYHZhbHVlYGAgYWN0cyBhcyBhIGRlc2NyaXB0b3Igd2l0aGluIGEgdGFnIGNhdGVnb3J5IChrZXkpLlxuICovXG5WYWx1ZTogc3RyaW5nXG59XG4vKipcbiAqIFRoZSBpbWFnZSBzY2FubmluZyBjb25maWd1cmF0aW9uIGZvciB0aGUgcmVwb3NpdG9yeS4gVGhpcyBkZXRlcm1pbmVzIHdoZXRoZXIgaW1hZ2VzIGFyZSBzY2FubmVkIGZvciBrbm93biB2dWxuZXJhYmlsaXRpZXMgYWZ0ZXIgYmVpbmcgcHVzaGVkIHRvIHRoZSByZXBvc2l0b3J5LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEltYWdlU2Nhbm5pbmdDb25maWd1cmF0aW9uIHtcbi8qKlxuICogVGhlIHNldHRpbmcgdGhhdCBkZXRlcm1pbmVzIHdoZXRoZXIgaW1hZ2VzIGFyZSBzY2FubmVkIGFmdGVyIGJlaW5nIHB1c2hlZCB0byBhIHJlcG9zaXRvcnkuIElmIHNldCB0byBgYHRydWVgYCwgaW1hZ2VzIHdpbGwgYmUgc2Nhbm5lZCBhZnRlciBiZWluZyBwdXNoZWQuIElmIHRoaXMgcGFyYW1ldGVyIGlzIG5vdCBzcGVjaWZpZWQsIGl0IHdpbGwgZGVmYXVsdCB0byBgYGZhbHNlYGAgYW5kIGltYWdlcyB3aWxsIG5vdCBiZSBzY2FubmVkIHVubGVzcyBhIHNjYW4gaXMgbWFudWFsbHkgc3RhcnRlZC5cbiAqL1xuU2Nhbk9uUHVzaD86IGJvb2xlYW5cbn1cbi8qKlxuICogVGhlIGVuY3J5cHRpb24gY29uZmlndXJhdGlvbiBmb3IgdGhlIHJlcG9zaXRvcnkuIFRoaXMgZGV0ZXJtaW5lcyBob3cgdGhlIGNvbnRlbnRzIG9mIHlvdXIgcmVwb3NpdG9yeSBhcmUgZW5jcnlwdGVkIGF0IHJlc3QuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5jcnlwdGlvbkNvbmZpZ3VyYXRpb24ge1xuLyoqXG4gKiBUaGUgZW5jcnlwdGlvbiB0eXBlIHRvIHVzZS5cbiAqICBJZiB5b3UgdXNlIHRoZSBgYEtNU2BgIGVuY3J5cHRpb24gdHlwZSwgdGhlIGNvbnRlbnRzIG9mIHRoZSByZXBvc2l0b3J5IHdpbGwgYmUgZW5jcnlwdGVkIHVzaW5nIHNlcnZlci1zaWRlIGVuY3J5cHRpb24gd2l0aCBLTVNsb25nIGtleSBzdG9yZWQgaW4gS01TLiBXaGVuIHlvdSB1c2UgS01TIHRvIGVuY3J5cHQgeW91ciBkYXRhLCB5b3UgY2FuIGVpdGhlciB1c2UgdGhlIGRlZmF1bHQgQVdTIG1hbmFnZWQgS01TIGtleSBmb3IgQW1hem9uIEVDUiwgb3Igc3BlY2lmeSB5b3VyIG93biBLTVMga2V5LCB3aGljaCB5b3UgYWxyZWFkeSBjcmVhdGVkLlxuICogIElmIHlvdSB1c2UgdGhlIGBgS01TX0RTU0VgYCBlbmNyeXB0aW9uIHR5cGUsIHRoZSBjb250ZW50cyBvZiB0aGUgcmVwb3NpdG9yeSB3aWxsIGJlIGVuY3J5cHRlZCB3aXRoIHR3byBsYXllcnMgb2YgZW5jcnlwdGlvbiB1c2luZyBzZXJ2ZXItc2lkZSBlbmNyeXB0aW9uIHdpdGggdGhlIEtNUyBNYW5hZ2VtZW50IFNlcnZpY2Uga2V5IHN0b3JlZCBpbiBLTVMuIFNpbWlsYXIgdG8gdGhlIGBgS01TYGAgZW5jcnlwdGlvbiB0eXBlLCB5b3UgY2FuIGVpdGhlciB1c2UgdGhlIGRlZmF1bHQgQVdTIG1hbmFnZWQgS01TIGtleSBmb3IgQW1hem9uIEVDUiwgb3Igc3BlY2lmeSB5b3VyIG93biBLTVMga2V5LCB3aGljaCB5b3UndmUgYWxyZWFkeSBjcmVhdGVkLiBcbiAqICBJZiB5b3UgdXNlIHRoZSBgYEFFUzI1NmBgIGVuY3J5cHRpb24gdHlwZSwgQW1hem9uIEVDUiB1c2VzIHNlcnZlci1zaWRlIGVuY3J5cHRpb24gd2l0aCBBbWF6b24gUzMtbWFuYWdlZCBlbmNyeXB0aW9uIGtleXMgd2hpY2ggZW5jcnlwdHMgdGhlIGltYWdlcyBpbiB0aGUgcmVwb3NpdG9yeSB1c2luZyBhbiBBRVMyNTYgZW5jcnlwdGlvbiBhbGdvcml0aG0uXG4gKiAgRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbQW1hem9uIEVDUiBlbmNyeXB0aW9uIGF0IHJlc3RdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BbWF6b25FQ1IvbGF0ZXN0L3VzZXJndWlkZS9lbmNyeXB0aW9uLWF0LXJlc3QuaHRtbCkgaW4gdGhlICpBbWF6b24gRWxhc3RpYyBDb250YWluZXIgUmVnaXN0cnkgVXNlciBHdWlkZSouXG4gKi9cbkVuY3J5cHRpb25UeXBlOiAoXCJBRVMyNTZcIiB8IFwiS01TXCIgfCBcIktNU19EU1NFXCIpXG4vKipcbiAqIElmIHlvdSB1c2UgdGhlIGBgS01TYGAgZW5jcnlwdGlvbiB0eXBlLCBzcGVjaWZ5IHRoZSBLTVMga2V5IHRvIHVzZSBmb3IgZW5jcnlwdGlvbi4gVGhlIGFsaWFzLCBrZXkgSUQsIG9yIGZ1bGwgQVJOIG9mIHRoZSBLTVMga2V5IGNhbiBiZSBzcGVjaWZpZWQuIFRoZSBrZXkgbXVzdCBleGlzdCBpbiB0aGUgc2FtZSBSZWdpb24gYXMgdGhlIHJlcG9zaXRvcnkuIElmIG5vIGtleSBpcyBzcGVjaWZpZWQsIHRoZSBkZWZhdWx0IEFXUyBtYW5hZ2VkIEtNUyBrZXkgZm9yIEFtYXpvbiBFQ1Igd2lsbCBiZSB1c2VkLlxuICovXG5LbXNLZXk/OiBzdHJpbmdcbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-ecr-repository.js","sourceRoot":"","sources":["aws-ecr-repository.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * Specifies the type of filter to use for excluding image tags from the repository's mutability setting.\n */\nexport type ImageTagMutabilityExclusionFilterType = \"WILDCARD\"\n/**\n * The value to use when filtering image tags.\n */\nexport type ImageTagMutabilityExclusionFilterValue = string\n\n/**\n * The ``AWS::ECR::Repository`` resource specifies an Amazon Elastic Container Registry (Amazon ECR) repository, where users can push and pull Docker images, Open Container Initiative (OCI) images, and OCI compatible artifacts. For more information, see [Amazon ECR private repositories](https://docs.aws.amazon.com/AmazonECR/latest/userguide/Repositories.html) in the *Amazon ECR User Guide*.\n */\nexport interface _AWS_ECR_REPOSITORY {\n/**\n * If true, deleting the repository force deletes the contents of the repository. If false, the repository must be empty before attempting to delete it.\n */\nEmptyOnDelete?: boolean\nLifecyclePolicy?: LifecyclePolicy\n/**\n * The name to use for the repository. The repository name may be specified on its own (such as ``nginx-web-app``) or it can be prepended with a namespace to group the repository into a category (such as ``project-a/nginx-web-app``). If you don't specify a name, CFNlong generates a unique physical ID and uses that ID for the repository name. For more information, see [Name type](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html).\n *  The repository name must start with a letter and can only contain lowercase letters, numbers, hyphens, underscores, and forward slashes.\n *   If you specify a name, you cannot perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name.\n */\nRepositoryName?: string\n/**\n * The JSON repository policy text to apply to the repository. For more information, see [Amazon ECR repository policies](https://docs.aws.amazon.com/AmazonECR/latest/userguide/repository-policy-examples.html) in the *Amazon Elastic Container Registry User Guide*.\n */\nRepositoryPolicyText?: ({\n[k: string]: unknown\n} | string)\n/**\n * An array of key-value pairs to apply to this resource.\n * \n * @maxItems 50\n */\nTags?: Tag[]\nArn?: string\nRepositoryUri?: string\n/**\n * The tag mutability setting for the repository. If this parameter is omitted, the default setting of ``MUTABLE`` will be used which will allow image tags to be overwritten. If ``IMMUTABLE`` is specified, all image tags within the repository will be immutable which will prevent them from being overwritten.\n */\nImageTagMutability?: (\"MUTABLE\" | \"IMMUTABLE\" | \"MUTABLE_WITH_EXCLUSION\" | \"IMMUTABLE_WITH_EXCLUSION\")\n/**\n * @minItems 1\n * @maxItems 5\n */\nImageTagMutabilityExclusionFilters?: ImageTagMutabilityExclusionFilter[]\nImageScanningConfiguration?: ImageScanningConfiguration\nEncryptionConfiguration?: EncryptionConfiguration\n}\n/**\n * Creates or updates a lifecycle policy. For information about lifecycle policy syntax, see [Lifecycle policy template](https://docs.aws.amazon.com/AmazonECR/latest/userguide/LifecyclePolicies.html).\n */\nexport interface LifecyclePolicy {\n/**\n * The JSON repository policy text to apply to the repository.\n */\nLifecyclePolicyText?: string\n/**\n * The AWS account ID associated with the registry that contains the repository. If you do  not specify a registry, the default registry is assumed.\n */\nRegistryId?: string\n}\n/**\n * The metadata to apply to a resource to help you categorize and organize them. Each tag consists of a key and a value, both of which you define. Tag keys can have a maximum character length of 128 characters, and tag values can have a maximum length of 256 characters.\n */\nexport interface Tag {\n/**\n * One part of a key-value pair that make up a tag. A ``key`` is a general label that acts like a category for more specific tag values.\n */\nKey: string\n/**\n * A ``value`` acts as a descriptor within a tag category (key).\n */\nValue: string\n}\nexport interface ImageTagMutabilityExclusionFilter {\nImageTagMutabilityExclusionFilterType: ImageTagMutabilityExclusionFilterType\nImageTagMutabilityExclusionFilterValue: ImageTagMutabilityExclusionFilterValue\n}\n/**\n * The image scanning configuration for the repository. This determines whether images are scanned for known vulnerabilities after being pushed to the repository.\n */\nexport interface ImageScanningConfiguration {\n/**\n * The setting that determines whether images are scanned after being pushed to a repository. If set to ``true``, images will be scanned after being pushed. If this parameter is not specified, it will default to ``false`` and images will not be scanned unless a scan is manually started.\n */\nScanOnPush?: boolean\n}\n/**\n * The encryption configuration for the repository. This determines how the contents of your repository are encrypted at rest.\n */\nexport interface EncryptionConfiguration {\n/**\n * The encryption type to use.\n *  If you use the ``KMS`` encryption type, the contents of the repository will be encrypted using server-side encryption with KMSlong key stored in KMS. When you use KMS to encrypt your data, you can either use the default AWS managed KMS key for Amazon ECR, or specify your own KMS key, which you already created.\n *  If you use the ``KMS_DSSE`` encryption type, the contents of the repository will be encrypted with two layers of encryption using server-side encryption with the KMS Management Service key stored in KMS. Similar to the ``KMS`` encryption type, you can either use the default AWS managed KMS key for Amazon ECR, or specify your own KMS key, which you've already created. \n *  If you use the ``AES256`` encryption type, Amazon ECR uses server-side encryption with Amazon S3-managed encryption keys which encrypts the images in the repository using an AES256 encryption algorithm.\n *  For more information, see [Amazon ECR encryption at rest](https://docs.aws.amazon.com/AmazonECR/latest/userguide/encryption-at-rest.html) in the *Amazon Elastic Container Registry User Guide*.\n */\nEncryptionType: (\"AES256\" | \"KMS\" | \"KMS_DSSE\")\n/**\n * If you use the ``KMS`` encryption type, specify the KMS key to use for encryption. The alias, key ID, or full ARN of the KMS key can be specified. The key must exist in the same Region as the repository. If no key is specified, the default AWS managed KMS key for Amazon ECR will be used.\n */\nKmsKey?: string\n}\n"]}