@servicevic-oss/cdk-cleanup-certificate-validation-records 0.0.4 → 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -3512,7 +3512,7 @@
3512
3512
  },
3513
3513
  "name": "@servicevic-oss/cdk-cleanup-certificate-validation-records",
3514
3514
  "readme": {
3515
- "markdown": "# cdk-cleanup-certificate-validation-records\n\nThis CDK construct takes care of cleaning up the orphaned Route53 CNAME validation records\nleft behind when deleting a certificate that had DNS validation enabled.\n\nThe issue is better explained here: https://github.com/aws/aws-cdk/issues/11201\n\n## Usage\n\n### Explicit instantiation\n\nThe construct can be instantiated explicitely to cleanup after a specific certificate\n\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { CertificateValidationRecordCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'\n\nexport class TestStack extends cdk.Stack {\n constructor(scope: Construct, id: string, props: TestStackProps) {\n super(scope, id, props);\n\n zone = new cdk.aws_route53.PublicHostedZone(this, 'Zone', {\n zoneName: 'my.zone.net',\n });\n\n const cert1 = new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `mydomain.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n subjectAlternativeNames: [\n `mydomain2.${zone.zoneName}`,\n `mydomain3.${zone.zoneName}`,\n ],\n });\n const cert2 = new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `another.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n });\n\n new CertificateValidationRecordCleanup(this, `cleanup-${cert1.node.id}`, {\n certificate: cert1,\n hostedZone: zone,\n });\n\n new CertificateValidationRecordCleanup(this, `cleanup-${cert2.node.id}`, {\n certificate: cert2,\n hostedZone: zone,\n });\n };\n}\n```\n\n### Implicit instantiation using Aspects with knowledge of the hosted zone\n\nThe construct can be instantiated automatically against any Certificate resource created within a stack\nthrough the use of Aspects\n\nIn this example, we have knowledge of the hosted zone\n\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { CertificateValidationRecordCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'\n\nexport class TestStack extends cdk.Stack {\n constructor(scope: Construct, id: string, props: TestStackProps) {\n super(scope, id, props);\n\n zone = new cdk.aws_route53.PublicHostedZone(this, 'Zone', {\n zoneName: 'my.zone.net',\n });\n\n new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `mydomain.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n subjectAlternativeNames: [\n `mydomain2.${zone.zoneName}`,\n `mydomain3.${zone.zoneName}`,\n ],\n });\n new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `another.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n });\n\n cdk.Aspects.of(this).add({\n visit: (c) => {\n if (c instanceof cdk.aws_certificatemanager.Certificate) {\n new CertificateValidationRecordCleanup(this, `cleanup-${c.node.id}`, {\n certificate: c,\n hostedZone: zone,\n });\n }\n },\n });\n };\n}\n```\n\n### Implicit instantiation using Aspects without knowledge of the hosted zone\n\nThe construct can be instantiated automatically against any Certificate resource created within a stack\nthrough the use of Aspects\n\nIn this example, we have no knowledge of the hosted zone used to validate the certificate so we use a bit of brute force to derive it from the Certificate L1 resource\n\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport { CertificateValidationRecordCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'\n\nconst app = new cdk.App();\n\nconst blackBoxStack = new BlackBoxStack(app, 'my-blackbox-stack');\n\ncdk.Aspects.of(blackBoxStack).add({\n visit: (c) => {\n if (c instanceof cdk.aws_certificatemanager.Certificate) {\n const cfnRes = c.node.defaultChild as cdk.aws_certificatemanager.CfnCertificate;\n const valOpts = (cfnRes.domainValidationOptions as cdk.aws_certificatemanager.CfnCertificate.DomainValidationOptionProperty[])[0];\n\n new CertificateValidationRecordCleanup(c, `cleanup-${c.node.id}`, {\n certificate: c,\n hostedZone: cdk.aws_route53.HostedZone.fromHostedZoneId(c, `lookup-${c.node.id}`, valOpts.hostedZoneId!),\n });\n }\n },\n});\n```"
3515
+ "markdown": "# cdk-cleanup-certificate-validation-records\n\nThis CDK construct takes care of cleaning up the orphaned Route53 CNAME validation records\nleft behind when deleting a certificate that had DNS validation enabled.\n\nThe issue is better explained here: https://github.com/aws/aws-cdk/issues/11201\n\n## Usage\n\n### With wrapper class\n\nThe simplest usage is via the wrapper class `CertificateWithCleanup`.\n\nThe class extends the standard `Certificate` construct and adds the cleanup automatically\n\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { CertificateWithCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'\n\nexport class TestStack extends cdk.Stack {\n constructor(scope: Construct, id: string, props: TestStackProps) {\n super(scope, id, props);\n\n zone = new cdk.aws_route53.PublicHostedZone(this, 'Zone', {\n zoneName: 'my.zone.net',\n });\n\n const cert1 = new CertificateWithCleanup(this, 'Cert', {\n domainName: `mydomain.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n subjectAlternativeNames: [\n `mydomain2.${zone.zoneName}`,\n `mydomain3.${zone.zoneName}`,\n ],\n });\n };\n}\n```\n\n### Explicit instantiation\n\nThe construct can be instantiated explicitely to cleanup after a specific certificate\n\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { CertificateValidationRecordCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'\n\nexport class TestStack extends cdk.Stack {\n constructor(scope: Construct, id: string, props: TestStackProps) {\n super(scope, id, props);\n\n zone = new cdk.aws_route53.PublicHostedZone(this, 'Zone', {\n zoneName: 'my.zone.net',\n });\n\n const cert1 = new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `mydomain.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n subjectAlternativeNames: [\n `mydomain2.${zone.zoneName}`,\n `mydomain3.${zone.zoneName}`,\n ],\n });\n const cert2 = new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `another.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n });\n\n new CertificateValidationRecordCleanup(this, `cleanup-${cert1.node.id}`, {\n certificate: cert1,\n hostedZone: zone,\n });\n\n new CertificateValidationRecordCleanup(this, `cleanup-${cert2.node.id}`, {\n certificate: cert2,\n hostedZone: zone,\n });\n };\n}\n```\n\n### Implicit instantiation using Aspects with knowledge of the hosted zone\n\nThe construct can be instantiated automatically against any Certificate resource created within a stack\nthrough the use of Aspects\n\nIn this example, we have knowledge of the hosted zone\n\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { CertificateValidationRecordCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'\n\nexport class TestStack extends cdk.Stack {\n constructor(scope: Construct, id: string, props: TestStackProps) {\n super(scope, id, props);\n\n zone = new cdk.aws_route53.PublicHostedZone(this, 'Zone', {\n zoneName: 'my.zone.net',\n });\n\n new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `mydomain.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n subjectAlternativeNames: [\n `mydomain2.${zone.zoneName}`,\n `mydomain3.${zone.zoneName}`,\n ],\n });\n new cdk.aws_certificatemanager.Certificate(this, 'Cert', {\n domainName: `another.${zone.zoneName}`,\n validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),\n });\n\n cdk.Aspects.of(this).add({\n visit: (c) => {\n if (c instanceof cdk.aws_certificatemanager.Certificate) {\n new CertificateValidationRecordCleanup(this, `cleanup-${c.node.id}`, {\n certificate: c,\n hostedZone: zone,\n });\n }\n },\n });\n };\n}\n```\n\n### Implicit instantiation using Aspects without knowledge of the hosted zone\n\nThe construct can be instantiated automatically against any Certificate resource created within a stack\nthrough the use of Aspects\n\nIn this example, we have no knowledge of the hosted zone used to validate the certificate so we use a bit of brute force to derive it from the Certificate L1 resource\n\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport { CertificateValidationRecordCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'\n\nconst app = new cdk.App();\n\nconst blackBoxStack = new BlackBoxStack(app, 'my-blackbox-stack');\n\ncdk.Aspects.of(blackBoxStack).add({\n visit: (c) => {\n if (c instanceof cdk.aws_certificatemanager.Certificate) {\n const cfnRes = c.node.defaultChild as cdk.aws_certificatemanager.CfnCertificate;\n const valOpts = (cfnRes.domainValidationOptions as cdk.aws_certificatemanager.CfnCertificate.DomainValidationOptionProperty[])[0];\n\n new CertificateValidationRecordCleanup(c, `cleanup-${c.node.id}`, {\n certificate: c,\n hostedZone: cdk.aws_route53.HostedZone.fromHostedZoneId(c, `lookup-${c.node.id}`, valOpts.hostedZoneId!),\n });\n }\n },\n});\n```"
3516
3516
  },
3517
3517
  "repository": {
3518
3518
  "type": "git",
@@ -3539,7 +3539,7 @@
3539
3539
  },
3540
3540
  "locationInModule": {
3541
3541
  "filename": "src/index.ts",
3542
- "line": 29
3542
+ "line": 28
3543
3543
  },
3544
3544
  "parameters": [
3545
3545
  {
@@ -3565,7 +3565,7 @@
3565
3565
  "kind": "class",
3566
3566
  "locationInModule": {
3567
3567
  "filename": "src/index.ts",
3568
- "line": 22
3568
+ "line": 21
3569
3569
  },
3570
3570
  "name": "CertificateValidationRecordCleanup",
3571
3571
  "properties": [
@@ -3577,7 +3577,7 @@
3577
3577
  "immutable": true,
3578
3578
  "locationInModule": {
3579
3579
  "filename": "src/index.ts",
3580
- "line": 23
3580
+ "line": 22
3581
3581
  },
3582
3582
  "name": "HANDLER_UID",
3583
3583
  "static": true,
@@ -3593,7 +3593,7 @@
3593
3593
  "immutable": true,
3594
3594
  "locationInModule": {
3595
3595
  "filename": "src/index.ts",
3596
- "line": 24
3596
+ "line": 23
3597
3597
  },
3598
3598
  "name": "PROVIDER_UID",
3599
3599
  "static": true,
@@ -3608,7 +3608,7 @@
3608
3608
  "immutable": true,
3609
3609
  "locationInModule": {
3610
3610
  "filename": "src/index.ts",
3611
- "line": 26
3611
+ "line": 25
3612
3612
  },
3613
3613
  "name": "handlerFunction",
3614
3614
  "type": {
@@ -3622,7 +3622,7 @@
3622
3622
  "immutable": true,
3623
3623
  "locationInModule": {
3624
3624
  "filename": "src/index.ts",
3625
- "line": 27
3625
+ "line": 26
3626
3626
  },
3627
3627
  "name": "provider",
3628
3628
  "type": {
@@ -3680,8 +3680,53 @@
3680
3680
  }
3681
3681
  ],
3682
3682
  "symbolId": "src/index:CertificateValidationRecordCleanupProps"
3683
+ },
3684
+ "@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup": {
3685
+ "assembly": "@servicevic-oss/cdk-cleanup-certificate-validation-records",
3686
+ "base": "aws-cdk-lib.aws_certificatemanager.Certificate",
3687
+ "docs": {
3688
+ "stability": "stable",
3689
+ "summary": "A wrapper class for a vanilla `Certificate` object with automatic cleanup attached."
3690
+ },
3691
+ "fqn": "@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup",
3692
+ "initializer": {
3693
+ "docs": {
3694
+ "stability": "stable"
3695
+ },
3696
+ "locationInModule": {
3697
+ "filename": "src/index.ts",
3698
+ "line": 83
3699
+ },
3700
+ "parameters": [
3701
+ {
3702
+ "name": "scope",
3703
+ "type": {
3704
+ "fqn": "constructs.Construct"
3705
+ }
3706
+ },
3707
+ {
3708
+ "name": "id",
3709
+ "type": {
3710
+ "primitive": "string"
3711
+ }
3712
+ },
3713
+ {
3714
+ "name": "props",
3715
+ "type": {
3716
+ "fqn": "aws-cdk-lib.aws_certificatemanager.CertificateProps"
3717
+ }
3718
+ }
3719
+ ]
3720
+ },
3721
+ "kind": "class",
3722
+ "locationInModule": {
3723
+ "filename": "src/index.ts",
3724
+ "line": 82
3725
+ },
3726
+ "name": "CertificateWithCleanup",
3727
+ "symbolId": "src/index:CertificateWithCleanup"
3683
3728
  }
3684
3729
  },
3685
- "version": "0.0.4",
3686
- "fingerprint": "YiU9qXtaSKZs464RgPVo+XkFxh3vAKX3c6H0TxzbFtE="
3730
+ "version": "0.0.6",
3731
+ "fingerprint": "n6UiUq4qsb5AbW9nTFPQt0cENJ0NL6n0pMZGcoNroVE="
3687
3732
  }
package/API.md CHANGED
@@ -153,6 +153,258 @@ public readonly PROVIDER_UID: string;
153
153
 
154
154
  ---
155
155
 
156
+ ### CertificateWithCleanup <a name="CertificateWithCleanup" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup"></a>
157
+
158
+ A wrapper class for a vanilla `Certificate` object with automatic cleanup attached.
159
+
160
+ #### Initializers <a name="Initializers" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.Initializer"></a>
161
+
162
+ ```typescript
163
+ import { CertificateWithCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'
164
+
165
+ new CertificateWithCleanup(scope: Construct, id: string, props: CertificateProps)
166
+ ```
167
+
168
+ | **Name** | **Type** | **Description** |
169
+ | --- | --- | --- |
170
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.Initializer.parameter.scope">scope</a></code> | <code>constructs.Construct</code> | *No description.* |
171
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.Initializer.parameter.id">id</a></code> | <code>string</code> | *No description.* |
172
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.Initializer.parameter.props">props</a></code> | <code>aws-cdk-lib.aws_certificatemanager.CertificateProps</code> | *No description.* |
173
+
174
+ ---
175
+
176
+ ##### `scope`<sup>Required</sup> <a name="scope" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.Initializer.parameter.scope"></a>
177
+
178
+ - *Type:* constructs.Construct
179
+
180
+ ---
181
+
182
+ ##### `id`<sup>Required</sup> <a name="id" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.Initializer.parameter.id"></a>
183
+
184
+ - *Type:* string
185
+
186
+ ---
187
+
188
+ ##### `props`<sup>Required</sup> <a name="props" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.Initializer.parameter.props"></a>
189
+
190
+ - *Type:* aws-cdk-lib.aws_certificatemanager.CertificateProps
191
+
192
+ ---
193
+
194
+ #### Methods <a name="Methods" id="Methods"></a>
195
+
196
+ | **Name** | **Description** |
197
+ | --- | --- |
198
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.toString">toString</a></code> | Returns a string representation of this construct. |
199
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.applyRemovalPolicy">applyRemovalPolicy</a></code> | Apply the given removal policy to this resource. |
200
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.metricDaysToExpiry">metricDaysToExpiry</a></code> | Return the DaysToExpiry metric for this AWS Certificate Manager Certificate. By default, this is the minimum value over 1 day. |
201
+
202
+ ---
203
+
204
+ ##### `toString` <a name="toString" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.toString"></a>
205
+
206
+ ```typescript
207
+ public toString(): string
208
+ ```
209
+
210
+ Returns a string representation of this construct.
211
+
212
+ ##### `applyRemovalPolicy` <a name="applyRemovalPolicy" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.applyRemovalPolicy"></a>
213
+
214
+ ```typescript
215
+ public applyRemovalPolicy(policy: RemovalPolicy): void
216
+ ```
217
+
218
+ Apply the given removal policy to this resource.
219
+
220
+ The Removal Policy controls what happens to this resource when it stops
221
+ being managed by CloudFormation, either because you've removed it from the
222
+ CDK application or because you've made a change that requires the resource
223
+ to be replaced.
224
+
225
+ The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
226
+ account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
227
+
228
+ ###### `policy`<sup>Required</sup> <a name="policy" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.applyRemovalPolicy.parameter.policy"></a>
229
+
230
+ - *Type:* aws-cdk-lib.RemovalPolicy
231
+
232
+ ---
233
+
234
+ ##### `metricDaysToExpiry` <a name="metricDaysToExpiry" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.metricDaysToExpiry"></a>
235
+
236
+ ```typescript
237
+ public metricDaysToExpiry(props?: MetricOptions): Metric
238
+ ```
239
+
240
+ Return the DaysToExpiry metric for this AWS Certificate Manager Certificate. By default, this is the minimum value over 1 day.
241
+
242
+ This metric is no longer emitted once the certificate has effectively
243
+ expired, so alarms configured on this metric should probably treat missing
244
+ data as "breaching".
245
+
246
+ ###### `props`<sup>Optional</sup> <a name="props" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.metricDaysToExpiry.parameter.props"></a>
247
+
248
+ - *Type:* aws-cdk-lib.aws_cloudwatch.MetricOptions
249
+
250
+ ---
251
+
252
+ #### Static Functions <a name="Static Functions" id="Static Functions"></a>
253
+
254
+ | **Name** | **Description** |
255
+ | --- | --- |
256
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
257
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isOwnedResource">isOwnedResource</a></code> | Returns true if the construct was created by CDK, and false otherwise. |
258
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isResource">isResource</a></code> | Check whether the given construct is a Resource. |
259
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.fromCertificateArn">fromCertificateArn</a></code> | Import a certificate. |
260
+
261
+ ---
262
+
263
+ ##### ~~`isConstruct`~~ <a name="isConstruct" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isConstruct"></a>
264
+
265
+ ```typescript
266
+ import { CertificateWithCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'
267
+
268
+ CertificateWithCleanup.isConstruct(x: any)
269
+ ```
270
+
271
+ Checks if `x` is a construct.
272
+
273
+ ###### `x`<sup>Required</sup> <a name="x" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isConstruct.parameter.x"></a>
274
+
275
+ - *Type:* any
276
+
277
+ Any object.
278
+
279
+ ---
280
+
281
+ ##### `isOwnedResource` <a name="isOwnedResource" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isOwnedResource"></a>
282
+
283
+ ```typescript
284
+ import { CertificateWithCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'
285
+
286
+ CertificateWithCleanup.isOwnedResource(construct: IConstruct)
287
+ ```
288
+
289
+ Returns true if the construct was created by CDK, and false otherwise.
290
+
291
+ ###### `construct`<sup>Required</sup> <a name="construct" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isOwnedResource.parameter.construct"></a>
292
+
293
+ - *Type:* constructs.IConstruct
294
+
295
+ ---
296
+
297
+ ##### `isResource` <a name="isResource" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isResource"></a>
298
+
299
+ ```typescript
300
+ import { CertificateWithCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'
301
+
302
+ CertificateWithCleanup.isResource(construct: IConstruct)
303
+ ```
304
+
305
+ Check whether the given construct is a Resource.
306
+
307
+ ###### `construct`<sup>Required</sup> <a name="construct" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.isResource.parameter.construct"></a>
308
+
309
+ - *Type:* constructs.IConstruct
310
+
311
+ ---
312
+
313
+ ##### `fromCertificateArn` <a name="fromCertificateArn" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.fromCertificateArn"></a>
314
+
315
+ ```typescript
316
+ import { CertificateWithCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'
317
+
318
+ CertificateWithCleanup.fromCertificateArn(scope: Construct, id: string, certificateArn: string)
319
+ ```
320
+
321
+ Import a certificate.
322
+
323
+ ###### `scope`<sup>Required</sup> <a name="scope" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.fromCertificateArn.parameter.scope"></a>
324
+
325
+ - *Type:* constructs.Construct
326
+
327
+ ---
328
+
329
+ ###### `id`<sup>Required</sup> <a name="id" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.fromCertificateArn.parameter.id"></a>
330
+
331
+ - *Type:* string
332
+
333
+ ---
334
+
335
+ ###### `certificateArn`<sup>Required</sup> <a name="certificateArn" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.fromCertificateArn.parameter.certificateArn"></a>
336
+
337
+ - *Type:* string
338
+
339
+ ---
340
+
341
+ #### Properties <a name="Properties" id="Properties"></a>
342
+
343
+ | **Name** | **Type** | **Description** |
344
+ | --- | --- | --- |
345
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
346
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.env">env</a></code> | <code>aws-cdk-lib.ResourceEnvironment</code> | The environment this resource belongs to. |
347
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.stack">stack</a></code> | <code>aws-cdk-lib.Stack</code> | The stack in which this resource is defined. |
348
+ | <code><a href="#@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.certificateArn">certificateArn</a></code> | <code>string</code> | The certificate's ARN. |
349
+
350
+ ---
351
+
352
+ ##### `node`<sup>Required</sup> <a name="node" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.node"></a>
353
+
354
+ ```typescript
355
+ public readonly node: Node;
356
+ ```
357
+
358
+ - *Type:* constructs.Node
359
+
360
+ The tree node.
361
+
362
+ ---
363
+
364
+ ##### `env`<sup>Required</sup> <a name="env" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.env"></a>
365
+
366
+ ```typescript
367
+ public readonly env: ResourceEnvironment;
368
+ ```
369
+
370
+ - *Type:* aws-cdk-lib.ResourceEnvironment
371
+
372
+ The environment this resource belongs to.
373
+
374
+ For resources that are created and managed by the CDK
375
+ (generally, those created by creating new class instances like Role, Bucket, etc.),
376
+ this is always the same as the environment of the stack they belong to;
377
+ however, for imported resources
378
+ (those obtained from static methods like fromRoleArn, fromBucketName, etc.),
379
+ that might be different than the stack they were imported into.
380
+
381
+ ---
382
+
383
+ ##### `stack`<sup>Required</sup> <a name="stack" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.stack"></a>
384
+
385
+ ```typescript
386
+ public readonly stack: Stack;
387
+ ```
388
+
389
+ - *Type:* aws-cdk-lib.Stack
390
+
391
+ The stack in which this resource is defined.
392
+
393
+ ---
394
+
395
+ ##### `certificateArn`<sup>Required</sup> <a name="certificateArn" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup.property.certificateArn"></a>
396
+
397
+ ```typescript
398
+ public readonly certificateArn: string;
399
+ ```
400
+
401
+ - *Type:* string
402
+
403
+ The certificate's ARN.
404
+
405
+ ---
406
+
407
+
156
408
  ## Structs <a name="Structs" id="Structs"></a>
157
409
 
158
410
  ### CertificateValidationRecordCleanupProps <a name="CertificateValidationRecordCleanupProps" id="@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateValidationRecordCleanupProps"></a>
package/README.md CHANGED
@@ -7,6 +7,37 @@ The issue is better explained here: https://github.com/aws/aws-cdk/issues/11201
7
7
 
8
8
  ## Usage
9
9
 
10
+ ### With wrapper class
11
+
12
+ The simplest usage is via the wrapper class `CertificateWithCleanup`.
13
+
14
+ The class extends the standard `Certificate` construct and adds the cleanup automatically
15
+
16
+ ```typescript
17
+ import * as cdk from 'aws-cdk-lib';
18
+ import { Construct } from 'constructs';
19
+ import { CertificateWithCleanup } from '@servicevic-oss/cdk-cleanup-certificate-validation-records'
20
+
21
+ export class TestStack extends cdk.Stack {
22
+ constructor(scope: Construct, id: string, props: TestStackProps) {
23
+ super(scope, id, props);
24
+
25
+ zone = new cdk.aws_route53.PublicHostedZone(this, 'Zone', {
26
+ zoneName: 'my.zone.net',
27
+ });
28
+
29
+ const cert1 = new CertificateWithCleanup(this, 'Cert', {
30
+ domainName: `mydomain.${zone.zoneName}`,
31
+ validation: cdk.aws_certificatemanager.CertificateValidation.fromDns(zone),
32
+ subjectAlternativeNames: [
33
+ `mydomain2.${zone.zoneName}`,
34
+ `mydomain3.${zone.zoneName}`,
35
+ ],
36
+ });
37
+ };
38
+ }
39
+ ```
40
+
10
41
  ### Explicit instantiation
11
42
 
12
43
  The construct can be instantiated explicitely to cleanup after a specific certificate
package/lib/index.d.ts CHANGED
@@ -23,3 +23,9 @@ export declare class CertificateValidationRecordCleanup extends Construct {
23
23
  private getOrCreateFunction;
24
24
  private getOrCreateProvider;
25
25
  }
26
+ /**
27
+ * A wrapper class for a vanilla `Certificate` object with automatic cleanup attached
28
+ */
29
+ export declare class CertificateWithCleanup extends cdk.aws_certificatemanager.Certificate {
30
+ constructor(scope: Construct, id: string, props: cdk.aws_certificatemanager.CertificateProps);
31
+ }
package/lib/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
- var _a;
2
+ var _a, _b;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.CertificateValidationRecordCleanup = void 0;
4
+ exports.CertificateWithCleanup = exports.CertificateValidationRecordCleanup = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const path_1 = require("path");
7
7
  const cdk = require("aws-cdk-lib");
@@ -57,7 +57,25 @@ class CertificateValidationRecordCleanup extends constructs_1.Construct {
57
57
  }
58
58
  exports.CertificateValidationRecordCleanup = CertificateValidationRecordCleanup;
59
59
  _a = JSII_RTTI_SYMBOL_1;
60
- CertificateValidationRecordCleanup[_a] = { fqn: "@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateValidationRecordCleanup", version: "0.0.4" };
60
+ CertificateValidationRecordCleanup[_a] = { fqn: "@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateValidationRecordCleanup", version: "0.0.6" };
61
61
  CertificateValidationRecordCleanup.HANDLER_UID = 'CertRecordsCleanupHandler-2B663BAB-7981';
62
62
  CertificateValidationRecordCleanup.PROVIDER_UID = 'CertRecordsCleanupProvider-57EBF059-2E26';
63
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrQkFBNEI7QUFDNUIsbUNBQW1DO0FBQ25DLDJDQUF1QztBQWV2Qzs7O0dBR0c7QUFDSCxNQUFhLGtDQUFtQyxTQUFRLHNCQUFTO0lBTy9ELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBOEM7UUFDdEYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQ2xELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7UUFFM0MsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsb0JBQW9CLENBQUMsSUFBSSxHQUFHLENBQUMsT0FBTyxDQUFDLGVBQWUsQ0FBQztZQUM5RSxPQUFPLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztZQUNwQyxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLGNBQWMsQ0FBQztTQUM5QyxDQUFDLENBQUMsQ0FBQztRQUNKLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLG9CQUFvQixDQUFDLElBQUksR0FBRyxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUM7WUFDOUUsT0FBTyxFQUFFO2dCQUNQLGtDQUFrQztnQkFDbEMsZ0NBQWdDO2FBQ2pDO1lBQ0QsU0FBUyxFQUFFLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUM7U0FDNUMsQ0FBQyxDQUFDLENBQUM7UUFFSixJQUFJLEdBQUcsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUN2QyxZQUFZLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZO1lBQ3hDLFlBQVksRUFBRSw0Q0FBNEM7WUFDMUQsVUFBVSxFQUFFO2dCQUNWLFlBQVksRUFBRSxLQUFLLENBQUMsVUFBVSxDQUFDLFlBQVk7Z0JBQzNDLGNBQWMsRUFBRSxLQUFLLENBQUMsV0FBVyxDQUFDLGNBQWM7YUFDakQ7U0FDRixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRU8sbUJBQW1CO1FBQ3pCLE1BQU0sRUFBRSxHQUFHLGtDQUFrQyxDQUFDLFdBQVcsQ0FBQztRQUMxRCxNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNqQyxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBeUMsSUFBSSxJQUFJLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNoSSxXQUFXLEVBQUUsdUVBQXVFO1lBQ3BGLEtBQUssRUFBRSxJQUFBLFdBQUksRUFBQyxTQUFTLEVBQUUsbURBQW1ELENBQUM7WUFDM0UsWUFBWSxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVE7WUFDakQsT0FBTyxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztTQUNqQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU8sbUJBQW1CO1FBQ3pCLE1BQU0sRUFBRSxHQUFHLGtDQUFrQyxDQUFDLFlBQVksQ0FBQztRQUMzRCxNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNqQyxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBa0MsSUFBSSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNsSCxjQUFjLEVBQUUsSUFBSSxDQUFDLGVBQWU7WUFDcEMsWUFBWSxFQUFFLEdBQUcsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVE7U0FDbEQsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUF2REgsZ0ZBd0RDOzs7QUF2RGlCLDhDQUFXLEdBQUcseUNBQXlDLENBQUM7QUFDeEQsK0NBQVksR0FBRywwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGpvaW4gfSBmcm9tICdwYXRoJztcbmltcG9ydCAqIGFzIGNkayBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuZXhwb3J0IGludGVyZmFjZSBDZXJ0aWZpY2F0ZVZhbGlkYXRpb25SZWNvcmRDbGVhbnVwUHJvcHMge1xuICAvKipcbiAgICogVGhlIFJvdXRlNTMgaG9zdGVkIHpvbmUgd2hlcmUgdGhlIGNlcnRpZmljYXRlIHZhbGlkYXRpb24gcmVjb3JkcyBoYXZlIGJlZW4gY3JlYXRlZCBmb3IgYSBjZXJ0aWZpY2F0ZVxuICAgKi9cbiAgcmVhZG9ubHkgaG9zdGVkWm9uZTogY2RrLmF3c19yb3V0ZTUzLklIb3N0ZWRab25lO1xuXG4gIC8qKlxuICAgKiBUaGUgQUNNIGNlcnRpZmljYXRlIHRoYXQgY3JlYXRlZCB0aGUgdmFsaWRhdGlvbiByZWNvcmRzXG4gICAqL1xuICByZWFkb25seSBjZXJ0aWZpY2F0ZTogY2RrLmF3c19jZXJ0aWZpY2F0ZW1hbmFnZXIuSUNlcnRpZmljYXRlO1xufVxuXG5cbi8qKlxuICogVGhpcyBjb25zdHJ1Y3RzIHdpbGwgdGFrZSBjYXJlIG9mIGRlbGV0aW5nIHRoZSBvcnBoYW5lZCByb3V0ZTUzIHJlY29yZHMgdGhhdCBBQ00gd2lsbFxuICogbGVhdmUgYmVoaW5kIHdoZW4gZGVsZXRpbmcgYSBETlMgdmFsaWRhdGVkIGNlcnRpZmljYXRlXG4gKi9cbmV4cG9ydCBjbGFzcyBDZXJ0aWZpY2F0ZVZhbGlkYXRpb25SZWNvcmRDbGVhbnVwIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgc3RhdGljIHJlYWRvbmx5IEhBTkRMRVJfVUlEID0gJ0NlcnRSZWNvcmRzQ2xlYW51cEhhbmRsZXItMkI2NjNCQUItNzk4MSc7XG4gIHN0YXRpYyByZWFkb25seSBQUk9WSURFUl9VSUQgPSAnQ2VydFJlY29yZHNDbGVhbnVwUHJvdmlkZXItNTdFQkYwNTktMkUyNic7XG5cbiAgcHVibGljIHJlYWRvbmx5IGhhbmRsZXJGdW5jdGlvbjogY2RrLmF3c19sYW1iZGFfbm9kZWpzLk5vZGVqc0Z1bmN0aW9uO1xuICBwdWJsaWMgcmVhZG9ubHkgcHJvdmlkZXI6IGNkay5jdXN0b21fcmVzb3VyY2VzLlByb3ZpZGVyO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBDZXJ0aWZpY2F0ZVZhbGlkYXRpb25SZWNvcmRDbGVhbnVwUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5oYW5kbGVyRnVuY3Rpb24gPSB0aGlzLmdldE9yQ3JlYXRlRnVuY3Rpb24oKTtcbiAgICB0aGlzLnByb3ZpZGVyID0gdGhpcy5nZXRPckNyZWF0ZVByb3ZpZGVyKCk7XG5cbiAgICB0aGlzLmhhbmRsZXJGdW5jdGlvbi5yb2xlPy5hZGRUb1ByaW5jaXBhbFBvbGljeShuZXcgY2RrLmF3c19pYW0uUG9saWN5U3RhdGVtZW50KHtcbiAgICAgIGFjdGlvbnM6IFsnYWNtOkRlc2NyaWJlQ2VydGlmaWNhdGUnXSxcbiAgICAgIHJlc291cmNlczogW3Byb3BzLmNlcnRpZmljYXRlLmNlcnRpZmljYXRlQXJuXSxcbiAgICB9KSk7XG4gICAgdGhpcy5oYW5kbGVyRnVuY3Rpb24ucm9sZT8uYWRkVG9QcmluY2lwYWxQb2xpY3kobmV3IGNkay5hd3NfaWFtLlBvbGljeVN0YXRlbWVudCh7XG4gICAgICBhY3Rpb25zOiBbXG4gICAgICAgICdyb3V0ZTUzOkNoYW5nZVJlc291cmNlUmVjb3JkU2V0cycsXG4gICAgICAgICdyb3V0ZTUzOkxpc3RSZXNvdXJjZVJlY29yZFNldHMnLFxuICAgICAgXSxcbiAgICAgIHJlc291cmNlczogW3Byb3BzLmhvc3RlZFpvbmUuaG9zdGVkWm9uZUFybl0sXG4gICAgfSkpO1xuXG4gICAgbmV3IGNkay5DdXN0b21SZXNvdXJjZSh0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBzZXJ2aWNlVG9rZW46IHRoaXMucHJvdmlkZXIuc2VydmljZVRva2VuLFxuICAgICAgcmVzb3VyY2VUeXBlOiAnQ3VzdG9tOjpDZXJ0aWZpY2F0ZVZhbGlkYXRpb25SZWNvcmRDbGVhbnVwJyxcbiAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAgICAgSG9zdGVkWm9uZUlkOiBwcm9wcy5ob3N0ZWRab25lLmhvc3RlZFpvbmVJZCxcbiAgICAgICAgQ2VydGlmaWNhdGVBcm46IHByb3BzLmNlcnRpZmljYXRlLmNlcnRpZmljYXRlQXJuLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIHRoaXMubm9kZS5hZGREZXBlbmRlbmN5KHByb3BzLmNlcnRpZmljYXRlLCBwcm9wcy5ob3N0ZWRab25lKTtcbiAgfVxuXG4gIHByaXZhdGUgZ2V0T3JDcmVhdGVGdW5jdGlvbigpOiBjZGsuYXdzX2xhbWJkYV9ub2RlanMuTm9kZWpzRnVuY3Rpb24ge1xuICAgIGNvbnN0IGlkID0gQ2VydGlmaWNhdGVWYWxpZGF0aW9uUmVjb3JkQ2xlYW51cC5IQU5ETEVSX1VJRDtcbiAgICBjb25zdCBzdGFjayA9IGNkay5TdGFjay5vZih0aGlzKTtcbiAgICByZXR1cm4gc3RhY2subm9kZS50cnlGaW5kQ2hpbGQoaWQpIGFzIGNkay5hd3NfbGFtYmRhX25vZGVqcy5Ob2RlanNGdW5jdGlvbiA/PyBuZXcgY2RrLmF3c19sYW1iZGFfbm9kZWpzLk5vZGVqc0Z1bmN0aW9uKHN0YWNrLCBpZCwge1xuICAgICAgZGVzY3JpcHRpb246ICdIYW5kbGVyIGZ1bmN0aW9uIGZvciB0aGUgQ2VydGlmaWNhdGVWYWxpZGF0aW9uUmVjb3JkQ2xlYW51cCBjb25zdHJ1Y3QnLFxuICAgICAgZW50cnk6IGpvaW4oX19kaXJuYW1lLCAnY2xlYW51cC1jZXJ0aWZpY2F0ZS12YWxpZGF0aW9uLXJlY29yZHMuaGFuZGxlci5qcycpLFxuICAgICAgbG9nUmV0ZW50aW9uOiBjZGsuYXdzX2xvZ3MuUmV0ZW50aW9uRGF5cy5PTkVfV0VFSyxcbiAgICAgIHRpbWVvdXQ6IGNkay5EdXJhdGlvbi5taW51dGVzKDIpLFxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRPckNyZWF0ZVByb3ZpZGVyKCk6IGNkay5jdXN0b21fcmVzb3VyY2VzLlByb3ZpZGVyIHtcbiAgICBjb25zdCBpZCA9IENlcnRpZmljYXRlVmFsaWRhdGlvblJlY29yZENsZWFudXAuUFJPVklERVJfVUlEO1xuICAgIGNvbnN0IHN0YWNrID0gY2RrLlN0YWNrLm9mKHRoaXMpO1xuICAgIHJldHVybiBzdGFjay5ub2RlLnRyeUZpbmRDaGlsZChpZCkgYXMgY2RrLmN1c3RvbV9yZXNvdXJjZXMuUHJvdmlkZXIgPz8gbmV3IGNkay5jdXN0b21fcmVzb3VyY2VzLlByb3ZpZGVyKHN0YWNrLCBpZCwge1xuICAgICAgb25FdmVudEhhbmRsZXI6IHRoaXMuaGFuZGxlckZ1bmN0aW9uLFxuICAgICAgbG9nUmV0ZW50aW9uOiBjZGsuYXdzX2xvZ3MuUmV0ZW50aW9uRGF5cy5PTkVfV0VFSyxcbiAgICB9KTtcbiAgfVxufVxuIl19
63
+ /**
64
+ * A wrapper class for a vanilla `Certificate` object with automatic cleanup attached
65
+ */
66
+ class CertificateWithCleanup extends cdk.aws_certificatemanager.Certificate {
67
+ constructor(scope, id, props) {
68
+ super(scope, id, props);
69
+ if (props.validation && props.validation.props.hostedZone && props.validation?.method == cdk.aws_certificatemanager.ValidationMethod.DNS) {
70
+ // Attach a cleanup construct
71
+ new CertificateValidationRecordCleanup(this, `cleanup-${id}`, {
72
+ certificate: this,
73
+ hostedZone: props.validation.props.hostedZone,
74
+ });
75
+ }
76
+ }
77
+ }
78
+ exports.CertificateWithCleanup = CertificateWithCleanup;
79
+ _b = JSII_RTTI_SYMBOL_1;
80
+ CertificateWithCleanup[_b] = { fqn: "@servicevic-oss/cdk-cleanup-certificate-validation-records.CertificateWithCleanup", version: "0.0.6" };
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;AAAA,+BAA4B;AAC5B,mCAAmC;AACnC,2CAAuC;AAcvC;;;GAGG;AACH,MAAa,kCAAmC,SAAQ,sBAAS;IAO/D,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA8C;QACtF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAClD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3C,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,oBAAoB,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC;YAC9E,OAAO,EAAE,CAAC,yBAAyB,CAAC;YACpC,SAAS,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,cAAc,CAAC;SAC9C,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,oBAAoB,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC;YAC9E,OAAO,EAAE;gBACP,kCAAkC;gBAClC,gCAAgC;aACjC;YACD,SAAS,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC;SAC5C,CAAC,CAAC,CAAC;QAEJ,IAAI,GAAG,CAAC,cAAc,CAAC,IAAI,EAAE,UAAU,EAAE;YACvC,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,YAAY;YACxC,YAAY,EAAE,4CAA4C;YAC1D,UAAU,EAAE;gBACV,YAAY,EAAE,KAAK,CAAC,UAAU,CAAC,YAAY;gBAC3C,cAAc,EAAE,KAAK,CAAC,WAAW,CAAC,cAAc;aACjD;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAC/D,CAAC;IAEO,mBAAmB;QACzB,MAAM,EAAE,GAAG,kCAAkC,CAAC,WAAW,CAAC;QAC1D,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QACjC,OAAO,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAyC,IAAI,IAAI,GAAG,CAAC,iBAAiB,CAAC,cAAc,CAAC,KAAK,EAAE,EAAE,EAAE;YAChI,WAAW,EAAE,uEAAuE;YACpF,KAAK,EAAE,IAAA,WAAI,EAAC,SAAS,EAAE,mDAAmD,CAAC;YAC3E,YAAY,EAAE,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ;YACjD,OAAO,EAAE,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;SACjC,CAAC,CAAC;IACL,CAAC;IAEO,mBAAmB;QACzB,MAAM,EAAE,GAAG,kCAAkC,CAAC,YAAY,CAAC;QAC3D,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QACjC,OAAO,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAkC,IAAI,IAAI,GAAG,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,EAAE;YAClH,cAAc,EAAE,IAAI,CAAC,eAAe;YACpC,YAAY,EAAE,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ;SAClD,CAAC,CAAC;IACL,CAAC;;AAvDH,gFAwDC;;;AAvDiB,8CAAW,GAAG,yCAAyC,CAAC;AACxD,+CAAY,GAAG,0CAA0C,CAAC;AAwD5E;;GAEG;AACH,MAAa,sBAAuB,SAAQ,GAAG,CAAC,sBAAsB,CAAC,WAAW;IAChF,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAkD;QAC1F,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,EAAE,MAAM,IAAI,GAAG,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC;YACzI,6BAA6B;YAC7B,IAAI,kCAAkC,CAAC,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE;gBAC5D,WAAW,EAAE,IAAI;gBACjB,UAAU,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,UAAU;aAC9C,CAAC,CAAC;QACL,CAAC;IACH,CAAC;;AAXH,wDAYC","sourcesContent":["import { join } from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\n\nexport interface CertificateValidationRecordCleanupProps {\n  /**\n   * The Route53 hosted zone where the certificate validation records have been created for a certificate\n   */\n  readonly hostedZone: cdk.aws_route53.IHostedZone;\n\n  /**\n   * The ACM certificate that created the validation records\n   */\n  readonly certificate: cdk.aws_certificatemanager.ICertificate;\n}\n\n/**\n * This constructs will take care of deleting the orphaned route53 records that ACM will\n * leave behind when deleting a DNS validated certificate\n */\nexport class CertificateValidationRecordCleanup extends Construct {\n  static readonly HANDLER_UID = 'CertRecordsCleanupHandler-2B663BAB-7981';\n  static readonly PROVIDER_UID = 'CertRecordsCleanupProvider-57EBF059-2E26';\n\n  public readonly handlerFunction: cdk.aws_lambda_nodejs.NodejsFunction;\n  public readonly provider: cdk.custom_resources.Provider;\n\n  constructor(scope: Construct, id: string, props: CertificateValidationRecordCleanupProps) {\n    super(scope, id);\n\n    this.handlerFunction = this.getOrCreateFunction();\n    this.provider = this.getOrCreateProvider();\n\n    this.handlerFunction.role?.addToPrincipalPolicy(new cdk.aws_iam.PolicyStatement({\n      actions: ['acm:DescribeCertificate'],\n      resources: [props.certificate.certificateArn],\n    }));\n    this.handlerFunction.role?.addToPrincipalPolicy(new cdk.aws_iam.PolicyStatement({\n      actions: [\n        'route53:ChangeResourceRecordSets',\n        'route53:ListResourceRecordSets',\n      ],\n      resources: [props.hostedZone.hostedZoneArn],\n    }));\n\n    new cdk.CustomResource(this, 'Resource', {\n      serviceToken: this.provider.serviceToken,\n      resourceType: 'Custom::CertificateValidationRecordCleanup',\n      properties: {\n        HostedZoneId: props.hostedZone.hostedZoneId,\n        CertificateArn: props.certificate.certificateArn,\n      },\n    });\n\n    this.node.addDependency(props.certificate, props.hostedZone);\n  }\n\n  private getOrCreateFunction(): cdk.aws_lambda_nodejs.NodejsFunction {\n    const id = CertificateValidationRecordCleanup.HANDLER_UID;\n    const stack = cdk.Stack.of(this);\n    return stack.node.tryFindChild(id) as cdk.aws_lambda_nodejs.NodejsFunction ?? new cdk.aws_lambda_nodejs.NodejsFunction(stack, id, {\n      description: 'Handler function for the CertificateValidationRecordCleanup construct',\n      entry: join(__dirname, 'cleanup-certificate-validation-records.handler.js'),\n      logRetention: cdk.aws_logs.RetentionDays.ONE_WEEK,\n      timeout: cdk.Duration.minutes(2),\n    });\n  }\n\n  private getOrCreateProvider(): cdk.custom_resources.Provider {\n    const id = CertificateValidationRecordCleanup.PROVIDER_UID;\n    const stack = cdk.Stack.of(this);\n    return stack.node.tryFindChild(id) as cdk.custom_resources.Provider ?? new cdk.custom_resources.Provider(stack, id, {\n      onEventHandler: this.handlerFunction,\n      logRetention: cdk.aws_logs.RetentionDays.ONE_WEEK,\n    });\n  }\n}\n\n/**\n * A wrapper class for a vanilla `Certificate` object with automatic cleanup attached\n */\nexport class CertificateWithCleanup extends cdk.aws_certificatemanager.Certificate {\n  constructor(scope: Construct, id: string, props: cdk.aws_certificatemanager.CertificateProps) {\n    super(scope, id, props);\n\n    if (props.validation && props.validation.props.hostedZone && props.validation?.method == cdk.aws_certificatemanager.ValidationMethod.DNS) {\n      // Attach a cleanup construct\n      new CertificateValidationRecordCleanup(this, `cleanup-${id}`, {\n        certificate: this,\n        hostedZone: props.validation.props.hostedZone,\n      });\n    }\n  }\n}"]}
package/package.json CHANGED
@@ -81,7 +81,7 @@
81
81
  "publishConfig": {
82
82
  "access": "public"
83
83
  },
84
- "version": "0.0.4",
84
+ "version": "0.0.6",
85
85
  "jest": {
86
86
  "testMatch": [
87
87
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",