@aws-cdk/aws-certificatemanager
Advanced tools
Comparing version 1.140.0 to 1.141.0
@@ -113,22 +113,10 @@ 'use strict'; | ||
let records; | ||
for (let attempt = 0; attempt < maxAttempts && !records; attempt++) { | ||
let records = []; | ||
for (let attempt = 0; attempt < maxAttempts && !records.length; attempt++) { | ||
const { Certificate } = await acm.describeCertificate({ | ||
CertificateArn: reqCertResponse.CertificateArn | ||
}).promise(); | ||
const options = Certificate.DomainValidationOptions || []; | ||
// Ensure all records are ready; there is (at least a theory there's) a chance of a partial response here in rare cases. | ||
if (options.length > 0 && options.every(opt => opt && !!opt.ResourceRecord)) { | ||
// some alternative names will produce the same validation record | ||
// as the main domain (eg. example.com + *.example.com) | ||
// filtering duplicates to avoid errors with adding the same record | ||
// to the route53 zone twice | ||
const unique = options | ||
.map((val) => val.ResourceRecord) | ||
.reduce((acc, cur) => { | ||
acc[cur.Name] = cur; | ||
return acc; | ||
}, {}); | ||
records = Object.keys(unique).sort().map(key => unique[key]); | ||
} else { | ||
records = getDomainValidationRecords(Certificate); | ||
if (!records.length) { | ||
// Exponential backoff with jitter based on 200ms base | ||
@@ -141,39 +129,10 @@ // component of backoff fixed to ensure minimum total wait time on | ||
} | ||
if (!records) { | ||
if (!records.length) { | ||
throw new Error(`Response from describeCertificate did not contain DomainValidationOptions after ${maxAttempts} attempts.`) | ||
} | ||
console.log(`Upserting ${records.length} DNS records into zone ${hostedZoneId}:`); | ||
const changeBatch = await route53.changeResourceRecordSets({ | ||
ChangeBatch: { | ||
Changes: records.map((record) => { | ||
console.log(`${record.Name} ${record.Type} ${record.Value}`) | ||
return { | ||
Action: 'UPSERT', | ||
ResourceRecordSet: { | ||
Name: record.Name, | ||
Type: record.Type, | ||
TTL: 60, | ||
ResourceRecords: [{ | ||
Value: record.Value | ||
}] | ||
} | ||
}; | ||
}), | ||
}, | ||
HostedZoneId: hostedZoneId | ||
}).promise(); | ||
await commitRoute53Records(route53, records, hostedZoneId); | ||
console.log('Waiting for DNS records to commit...'); | ||
await route53.waitFor('resourceRecordSetsChanged', { | ||
// Wait up to 5 minutes | ||
$waiter: { | ||
delay: 30, | ||
maxAttempts: 10 | ||
}, | ||
Id: changeBatch.ChangeInfo.Id | ||
}).promise(); | ||
console.log('Waiting for validation...'); | ||
@@ -198,4 +157,9 @@ await acm.waitFor('certificateValidated', { | ||
*/ | ||
const deleteCertificate = async function (arn, region) { | ||
const deleteCertificate = async function (arn, region, hostedZoneId, route53Endpoint, cleanupRecords) { | ||
const acm = new aws.ACM({ region }); | ||
const route53 = route53Endpoint ? new aws.Route53({ endpoint: route53Endpoint }) : new aws.Route53(); | ||
if (waiter) { | ||
// Used by the test suite, since waiters aren't mockable yet | ||
route53.waitFor = acm.waitFor = waiter; | ||
} | ||
@@ -206,2 +170,3 @@ try { | ||
let inUseByResources; | ||
let records = []; | ||
for (let attempt = 0; attempt < maxAttempts; attempt++) { | ||
@@ -212,5 +177,8 @@ const { Certificate } = await acm.describeCertificate({ | ||
if (cleanupRecords) { | ||
records = getDomainValidationRecords(Certificate); | ||
} | ||
inUseByResources = Certificate.InUseBy || []; | ||
if (inUseByResources.length) { | ||
if (inUseByResources.length || !records.length) { | ||
// Exponential backoff with jitter based on 200ms base | ||
@@ -222,3 +190,3 @@ // component of backoff fixed to ensure minimum total wait time on | ||
} else { | ||
break | ||
break; | ||
} | ||
@@ -230,2 +198,5 @@ } | ||
} | ||
if (cleanupRecords && !records.length) { | ||
throw new Error(`Response from describeCertificate did not contain DomainValidationOptions after ${maxAttempts} attempts.`) | ||
} | ||
@@ -237,2 +208,9 @@ console.log(`Deleting certificate ${arn}`); | ||
}).promise(); | ||
if (cleanupRecords) { | ||
console.log(`Deleting ${records.length} DNS records from zone ${hostedZoneId}:`); | ||
await commitRoute53Records(route53, records, hostedZoneId, 'DELETE'); | ||
} | ||
} catch (err) { | ||
@@ -246,2 +224,62 @@ if (err.name !== 'ResourceNotFoundException') { | ||
/** | ||
* Retrieve the unique domain validation options as records to be upserted (or deleted) from Route53. | ||
* | ||
* Returns an empty array ([]) if the domain validation options is empty or the records are not yet ready. | ||
*/ | ||
function getDomainValidationRecords(certificate) { | ||
const options = certificate.DomainValidationOptions || []; | ||
// Ensure all records are ready; there is (at least a theory there's) a chance of a partial response here in rare cases. | ||
if (options.length > 0 && options.every(opt => opt && !!opt.ResourceRecord)) { | ||
// some alternative names will produce the same validation record | ||
// as the main domain (eg. example.com + *.example.com) | ||
// filtering duplicates to avoid errors with adding the same record | ||
// to the route53 zone twice | ||
const unique = options | ||
.map((val) => val.ResourceRecord) | ||
.reduce((acc, cur) => { | ||
acc[cur.Name] = cur; | ||
return acc; | ||
}, {}); | ||
return Object.keys(unique).sort().map(key => unique[key]); | ||
} | ||
return []; | ||
} | ||
/** | ||
* Execute Route53 ChangeResourceRecordSets for a set of records within a Hosted Zone, | ||
* and wait for the records to commit. Defaults to an 'UPSERT' action. | ||
*/ | ||
async function commitRoute53Records(route53, records, hostedZoneId, action = 'UPSERT') { | ||
const changeBatch = await route53.changeResourceRecordSets({ | ||
ChangeBatch: { | ||
Changes: records.map((record) => { | ||
console.log(`${record.Name} ${record.Type} ${record.Value}`); | ||
return { | ||
Action: action, | ||
ResourceRecordSet: { | ||
Name: record.Name, | ||
Type: record.Type, | ||
TTL: 60, | ||
ResourceRecords: [{ | ||
Value: record.Value | ||
}] | ||
} | ||
}; | ||
}), | ||
}, | ||
HostedZoneId: hostedZoneId | ||
}).promise(); | ||
console.log('Waiting for DNS records to commit...'); | ||
await route53.waitFor('resourceRecordSetsChanged', { | ||
// Wait up to 5 minutes | ||
$waiter: { | ||
delay: 30, | ||
maxAttempts: 10 | ||
}, | ||
Id: changeBatch.ChangeInfo.Id | ||
}).promise(); | ||
} | ||
/** | ||
* Main handler, invoked by Lambda | ||
@@ -274,3 +312,9 @@ */ | ||
if (physicalResourceId.startsWith('arn:')) { | ||
await deleteCertificate(physicalResourceId, event.ResourceProperties.Region); | ||
await deleteCertificate( | ||
physicalResourceId, | ||
event.ResourceProperties.Region, | ||
event.ResourceProperties.HostedZoneId, | ||
event.ResourceProperties.Route53Endpoint, | ||
event.ResourceProperties.CleanupRecords === "true", | ||
); | ||
} | ||
@@ -277,0 +321,0 @@ break; |
{ | ||
"name": "@aws-cdk/dns_validated_certificate_handler", | ||
"private": true, | ||
"version": "1.140.0", | ||
"version": "1.141.0", | ||
"description": "This module is part of the [AWS Cloud Development Kit](https://github.com/aws/aws-cdk) project.", | ||
@@ -32,7 +32,7 @@ "main": "lib/index.js", | ||
"devDependencies": { | ||
"@types/aws-lambda": "^8.10.90", | ||
"@types/aws-lambda": "^8.10.92", | ||
"@types/sinon": "^9.0.11", | ||
"@aws-cdk/cdk-build-tools": "1.140.0", | ||
"@aws-cdk/cdk-build-tools": "1.141.0", | ||
"aws-sdk": "^2.596.0", | ||
"aws-sdk-mock": "^5.5.1", | ||
"aws-sdk-mock": "^5.6.0", | ||
"eslint": "^7.32.0", | ||
@@ -39,0 +39,0 @@ "eslint-config-standard": "^14.1.1", |
@@ -999,2 +999,170 @@ 'use strict'; | ||
}); | ||
describe('Delete option record cleanup', () => { | ||
let describeCertificateFake; | ||
let deleteCertificateFake; | ||
let changeResourceRecordSetsFake; | ||
beforeEach(() => { | ||
deleteCertificateFake = sinon.fake.resolves({}); | ||
AWS.mock('ACM', 'deleteCertificate', deleteCertificateFake); | ||
changeResourceRecordSetsFake = sinon.fake.resolves({ | ||
ChangeInfo: { | ||
Id: 'bogus' | ||
} | ||
}); | ||
AWS.mock('Route53', 'changeResourceRecordSets', changeResourceRecordSetsFake); | ||
describeCertificateFake = sinon.fake.resolves({ | ||
Certificate: { | ||
CertificateArn: testCertificateArn, | ||
DomainValidationOptions: [{ | ||
ValidationStatus: 'SUCCESS', | ||
ResourceRecord: { | ||
Name: testRRName, | ||
Type: 'CNAME', | ||
Value: testRRValue | ||
} | ||
}] | ||
} | ||
}); | ||
AWS.mock('ACM', 'describeCertificate', describeCertificateFake); | ||
}); | ||
test('ignores records if CleanupRecords is not set', () => { | ||
const request = nock(ResponseURL).put('/', body => { | ||
return body.Status === 'SUCCESS'; | ||
}).reply(200); | ||
return LambdaTester(handler.certificateRequestHandler) | ||
.event({ | ||
RequestType: 'Delete', | ||
RequestId: testRequestId, | ||
PhysicalResourceId: testCertificateArn, | ||
ResourceProperties: { | ||
Region: 'us-east-1', | ||
HostedZoneId: testHostedZoneId, | ||
} | ||
}) | ||
.expectResolve(() => { | ||
sinon.assert.calledWith(describeCertificateFake, sinon.match({ | ||
CertificateArn: testCertificateArn | ||
})); | ||
sinon.assert.calledWith(deleteCertificateFake, sinon.match({ | ||
CertificateArn: testCertificateArn | ||
})); | ||
sinon.assert.notCalled(changeResourceRecordSetsFake); | ||
expect(request.isDone()).toBe(true); | ||
}); | ||
}); | ||
test('ignores records if CleanupRecords is not set to "true"', () => { | ||
const request = nock(ResponseURL).put('/', body => { | ||
return body.Status === 'SUCCESS'; | ||
}).reply(200); | ||
return LambdaTester(handler.certificateRequestHandler) | ||
.event({ | ||
RequestType: 'Delete', | ||
RequestId: testRequestId, | ||
PhysicalResourceId: testCertificateArn, | ||
ResourceProperties: { | ||
Region: 'us-east-1', | ||
HostedZoneId: testHostedZoneId, | ||
CleanupRecords: 'TRUE', // Not "true" | ||
} | ||
}) | ||
.expectResolve(() => { | ||
sinon.assert.calledWith(describeCertificateFake, sinon.match({ | ||
CertificateArn: testCertificateArn | ||
})); | ||
sinon.assert.calledWith(deleteCertificateFake, sinon.match({ | ||
CertificateArn: testCertificateArn | ||
})); | ||
sinon.assert.notCalled(changeResourceRecordSetsFake); | ||
expect(request.isDone()).toBe(true); | ||
}); | ||
}); | ||
test('deletes records if CleanupRecords is set to true and records are present', () => { | ||
const request = nock(ResponseURL).put('/', body => { | ||
return body.Status === 'SUCCESS'; | ||
}).reply(200); | ||
AWS.mock('Route53', 'changeResourceRecordSets', changeResourceRecordSetsFake); | ||
return LambdaTester(handler.certificateRequestHandler) | ||
.event({ | ||
RequestType: 'Delete', | ||
RequestId: testRequestId, | ||
PhysicalResourceId: testCertificateArn, | ||
ResourceProperties: { | ||
Region: 'us-east-1', | ||
HostedZoneId: testHostedZoneId, | ||
CleanupRecords: 'true', | ||
}, | ||
}) | ||
.expectResolve(() => { | ||
sinon.assert.calledWith(describeCertificateFake, sinon.match({ | ||
CertificateArn: testCertificateArn | ||
})); | ||
sinon.assert.calledWith(deleteCertificateFake, sinon.match({ | ||
CertificateArn: testCertificateArn | ||
})); | ||
sinon.assert.calledWith(changeResourceRecordSetsFake, sinon.match({ | ||
ChangeBatch: { | ||
Changes: [{ | ||
Action: 'DELETE', | ||
ResourceRecordSet: { | ||
Name: testRRName, | ||
Type: 'CNAME', | ||
TTL: 60, | ||
ResourceRecords: [{ | ||
Value: testRRValue | ||
}] | ||
} | ||
}] | ||
}, | ||
HostedZoneId: testHostedZoneId | ||
})); | ||
expect(request.isDone()).toBe(true); | ||
}); | ||
}); | ||
test('fails if CleanupRecords is set to true and records are not present', () => { | ||
describeCertificateFake = sinon.fake.resolves({ | ||
Certificate: { | ||
CertificateArn: testCertificateArn, | ||
} | ||
}); | ||
AWS.remock('ACM', 'describeCertificate', describeCertificateFake); | ||
const request = nock(ResponseURL).put('/', body => { | ||
return body.Status === 'FAILED' && | ||
body.Reason.startsWith('Response from describeCertificate did not contain DomainValidationOptions'); | ||
}).reply(200); | ||
AWS.mock('Route53', 'changeResourceRecordSets', changeResourceRecordSetsFake); | ||
return LambdaTester(handler.certificateRequestHandler) | ||
.event({ | ||
RequestType: 'Delete', | ||
RequestId: testRequestId, | ||
PhysicalResourceId: testCertificateArn, | ||
ResourceProperties: { | ||
Region: 'us-east-1', | ||
HostedZoneId: testHostedZoneId, | ||
CleanupRecords: 'true', | ||
}, | ||
}) | ||
.expectResolve(() => { | ||
sinon.assert.calledWith(describeCertificateFake, sinon.match({ | ||
CertificateArn: testCertificateArn | ||
})); | ||
sinon.assert.notCalled(deleteCertificateFake); | ||
sinon.assert.notCalled(changeResourceRecordSetsFake); | ||
expect(request.isDone()).toBe(true); | ||
}); | ||
}); | ||
}); | ||
}); |
@@ -80,3 +80,3 @@ "use strict"; | ||
_a = JSII_RTTI_SYMBOL_1; | ||
CertificateValidation[_a] = { fqn: "@aws-cdk/aws-certificatemanager.CertificateValidation", version: "1.140.0" }; | ||
CertificateValidation[_a] = { fqn: "@aws-cdk/aws-certificatemanager.CertificateValidation", version: "1.141.0" }; | ||
/** | ||
@@ -132,3 +132,3 @@ * A certificate managed by AWS Certificate Manager. | ||
_b = JSII_RTTI_SYMBOL_1; | ||
Certificate[_b] = { fqn: "@aws-cdk/aws-certificatemanager.Certificate", version: "1.140.0" }; | ||
Certificate[_b] = { fqn: "@aws-cdk/aws-certificatemanager.Certificate", version: "1.141.0" }; | ||
/** | ||
@@ -135,0 +135,0 @@ * Method used to assert ownership of the domain. |
@@ -51,2 +51,13 @@ import * as iam from '@aws-cdk/aws-iam'; | ||
readonly customResourceRole?: iam.IRole; | ||
/** | ||
* When set to true, when the DnsValidatedCertificate is deleted, the associated Route53 validation records are removed. | ||
* | ||
* CAUTION: If multiple certificates share the same domains (and same validation records), | ||
* this can cause the other certificates to fail renewal and/or not validate. | ||
* Not recommended for production use. | ||
* | ||
* @default false | ||
* @stability stable | ||
*/ | ||
readonly cleanupRoute53Records?: boolean; | ||
} | ||
@@ -53,0 +64,0 @@ /** |
@@ -65,2 +65,4 @@ "use strict"; | ||
Route53Endpoint: props.route53Endpoint, | ||
// Custom resources properties are always converted to strings; might as well be explict here. | ||
CleanupRecords: props.cleanupRoute53Records ? 'true' : undefined, | ||
Tags: cdk.Lazy.list({ produce: () => this.tags.renderTags() }), | ||
@@ -92,3 +94,3 @@ }, | ||
_a = JSII_RTTI_SYMBOL_1; | ||
DnsValidatedCertificate[_a] = { fqn: "@aws-cdk/aws-certificatemanager.DnsValidatedCertificate", version: "1.140.0" }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-validated-certificate.js","sourceRoot":"","sources":["dns-validated-certificate.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as lambda from '@aws-cdk/aws-lambda';\nimport * as route53 from '@aws-cdk/aws-route53';\nimport * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CertificateProps, ICertificate } from './certificate';\nimport { CertificateBase } from './certificate-base';\n\n                                                                                                 \nexport interface DnsValidatedCertificateProps extends CertificateProps {\n                                                                                                                                                                                   \n  readonly hostedZone: route53.IHostedZone;\n                                                                                                                                                                                                                                                     \n  readonly region?: string;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         \n  readonly route53Endpoint?: string;\n\n                                                                                                                                           \n  readonly customResourceRole?: iam.IRole;\n\n}\n\n                                                                                                                                                                                                                      \nexport class DnsValidatedCertificate extends CertificateBase implements ICertificate, cdk.ITaggable {\n  public readonly certificateArn: string;\n\n                                                                                                                                                                                              \n\n  public readonly tags: cdk.TagManager;\n  protected readonly region?: string;\n  private normalizedZoneName: string;\n  private hostedZoneId: string;\n  private domainName: string;\n\n  constructor(scope: Construct, id: string, props: DnsValidatedCertificateProps) {\n    super(scope, id);\n\n    this.region = props.region;\n\n    this.domainName = props.domainName;\n    this.normalizedZoneName = props.hostedZone.zoneName;\n    // Remove trailing `.` from zone name\n    if (this.normalizedZoneName.endsWith('.')) {\n      this.normalizedZoneName = this.normalizedZoneName.substring(0, this.normalizedZoneName.length - 1);\n    }\n\n    // Remove any `/hostedzone/` prefix from the Hosted Zone ID\n    this.hostedZoneId = props.hostedZone.hostedZoneId.replace(/^\\/hostedzone\\//, '');\n    this.tags = new cdk.TagManager(cdk.TagType.MAP, 'AWS::CertificateManager::Certificate');\n\n    const requestorFunction = new lambda.Function(this, 'CertificateRequestorFunction', {\n      code: lambda.Code.fromAsset(path.resolve(__dirname, '..', 'lambda-packages', 'dns_validated_certificate_handler', 'lib')),\n      handler: 'index.certificateRequestHandler',\n      runtime: lambda.Runtime.NODEJS_12_X,\n      timeout: cdk.Duration.minutes(15),\n      role: props.customResourceRole,\n    });\n    requestorFunction.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['acm:RequestCertificate', 'acm:DescribeCertificate', 'acm:DeleteCertificate', 'acm:AddTagsToCertificate'],\n      resources: ['*'],\n    }));\n    requestorFunction.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['route53:GetChange'],\n      resources: ['*'],\n    }));\n    requestorFunction.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['route53:changeResourceRecordSets'],\n      resources: [`arn:${cdk.Stack.of(requestorFunction).partition}:route53:::hostedzone/${this.hostedZoneId}`],\n    }));\n\n    const certificate = new cdk.CustomResource(this, 'CertificateRequestorResource', {\n      serviceToken: requestorFunction.functionArn,\n      properties: {\n        DomainName: props.domainName,\n        SubjectAlternativeNames: cdk.Lazy.list({ produce: () => props.subjectAlternativeNames }, { omitEmpty: true }),\n        HostedZoneId: this.hostedZoneId,\n        Region: props.region,\n        Route53Endpoint: props.route53Endpoint,\n        Tags: cdk.Lazy.list({ produce: () => this.tags.renderTags() }),\n      },\n    });\n\n    this.certificateArn = certificate.getAtt('Arn').toString();\n  }\n\n  protected validate(): string[] {\n    const errors: string[] = [];\n    // Ensure the zone name is a parent zone of the certificate domain name\n    if (!cdk.Token.isUnresolved(this.normalizedZoneName) &&\n      this.domainName !== this.normalizedZoneName &&\n      !this.domainName.endsWith('.' + this.normalizedZoneName)) {\n      errors.push(`DNS zone ${this.normalizedZoneName} is not authoritative for certificate domain name ${this.domainName}`);\n    }\n    return errors;\n  }\n}\n"]} | ||
DnsValidatedCertificate[_a] = { fqn: "@aws-cdk/aws-certificatemanager.DnsValidatedCertificate", version: "1.141.0" }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-validated-certificate.js","sourceRoot":"","sources":["dns-validated-certificate.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as lambda from '@aws-cdk/aws-lambda';\nimport * as route53 from '@aws-cdk/aws-route53';\nimport * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CertificateProps, ICertificate } from './certificate';\nimport { CertificateBase } from './certificate-base';\n\n                                                                                                 \nexport interface DnsValidatedCertificateProps extends CertificateProps {\n                                                                                                                                                                                   \n  readonly hostedZone: route53.IHostedZone;\n                                                                                                                                                                                                                                                     \n  readonly region?: string;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         \n  readonly route53Endpoint?: string;\n\n                                                                                                                                           \n  readonly customResourceRole?: iam.IRole;\n\n                                                                                                                                                                                                                                                                                                                                                                                               \n  readonly cleanupRoute53Records?: boolean;\n}\n\n                                                                                                                                                                                                                      \nexport class DnsValidatedCertificate extends CertificateBase implements ICertificate, cdk.ITaggable {\n  public readonly certificateArn: string;\n\n                                                                                                                                                                                              \n\n  public readonly tags: cdk.TagManager;\n  protected readonly region?: string;\n  private normalizedZoneName: string;\n  private hostedZoneId: string;\n  private domainName: string;\n\n  constructor(scope: Construct, id: string, props: DnsValidatedCertificateProps) {\n    super(scope, id);\n\n    this.region = props.region;\n\n    this.domainName = props.domainName;\n    this.normalizedZoneName = props.hostedZone.zoneName;\n    // Remove trailing `.` from zone name\n    if (this.normalizedZoneName.endsWith('.')) {\n      this.normalizedZoneName = this.normalizedZoneName.substring(0, this.normalizedZoneName.length - 1);\n    }\n\n    // Remove any `/hostedzone/` prefix from the Hosted Zone ID\n    this.hostedZoneId = props.hostedZone.hostedZoneId.replace(/^\\/hostedzone\\//, '');\n    this.tags = new cdk.TagManager(cdk.TagType.MAP, 'AWS::CertificateManager::Certificate');\n\n    const requestorFunction = new lambda.Function(this, 'CertificateRequestorFunction', {\n      code: lambda.Code.fromAsset(path.resolve(__dirname, '..', 'lambda-packages', 'dns_validated_certificate_handler', 'lib')),\n      handler: 'index.certificateRequestHandler',\n      runtime: lambda.Runtime.NODEJS_12_X,\n      timeout: cdk.Duration.minutes(15),\n      role: props.customResourceRole,\n    });\n    requestorFunction.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['acm:RequestCertificate', 'acm:DescribeCertificate', 'acm:DeleteCertificate', 'acm:AddTagsToCertificate'],\n      resources: ['*'],\n    }));\n    requestorFunction.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['route53:GetChange'],\n      resources: ['*'],\n    }));\n    requestorFunction.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['route53:changeResourceRecordSets'],\n      resources: [`arn:${cdk.Stack.of(requestorFunction).partition}:route53:::hostedzone/${this.hostedZoneId}`],\n    }));\n\n    const certificate = new cdk.CustomResource(this, 'CertificateRequestorResource', {\n      serviceToken: requestorFunction.functionArn,\n      properties: {\n        DomainName: props.domainName,\n        SubjectAlternativeNames: cdk.Lazy.list({ produce: () => props.subjectAlternativeNames }, { omitEmpty: true }),\n        HostedZoneId: this.hostedZoneId,\n        Region: props.region,\n        Route53Endpoint: props.route53Endpoint,\n        // Custom resources properties are always converted to strings; might as well be explict here.\n        CleanupRecords: props.cleanupRoute53Records ? 'true' : undefined,\n        Tags: cdk.Lazy.list({ produce: () => this.tags.renderTags() }),\n      },\n    });\n\n    this.certificateArn = certificate.getAtt('Arn').toString();\n  }\n\n  protected validate(): string[] {\n    const errors: string[] = [];\n    // Ensure the zone name is a parent zone of the certificate domain name\n    if (!cdk.Token.isUnresolved(this.normalizedZoneName) &&\n      this.domainName !== this.normalizedZoneName &&\n      !this.domainName.endsWith('.' + this.normalizedZoneName)) {\n      errors.push(`DNS zone ${this.normalizedZoneName} is not authoritative for certificate domain name ${this.domainName}`);\n    }\n    return errors;\n  }\n}\n"]} |
@@ -46,3 +46,3 @@ "use strict"; | ||
_a = JSII_RTTI_SYMBOL_1; | ||
PrivateCertificate[_a] = { fqn: "@aws-cdk/aws-certificatemanager.PrivateCertificate", version: "1.140.0" }; | ||
PrivateCertificate[_a] = { fqn: "@aws-cdk/aws-certificatemanager.PrivateCertificate", version: "1.141.0" }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZS1jZXJ0aWZpY2F0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInByaXZhdGUtY2VydGlmaWNhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBR0EseURBQXFEO0FBQ3JELGlGQUFnRTs7Ozs7OztBQWVoRSxNQUFhLGtCQUFtQixTQUFRLGtDQUFlOzs7O0lBYXJELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBOEI7UUFDdEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQzs7UUFFakIsTUFBTSxJQUFJLEdBQUcsSUFBSSw2Q0FBYyxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDaEQsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVO1lBQzVCLHVCQUF1QixFQUFFLEtBQUssQ0FBQyx1QkFBdUI7WUFDdEQsdUJBQXVCLEVBQUUsS0FBSyxDQUFDLG9CQUFvQixDQUFDLHVCQUF1QjtTQUM1RSxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUM7S0FDaEM7Ozs7OztJQXJCTSxNQUFNLENBQUMsa0JBQWtCLENBQUMsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsY0FBc0I7UUFDbkYsTUFBTSxNQUFPLFNBQVEsa0NBQWU7WUFBcEM7O2dCQUNrQixtQkFBYyxHQUFHLGNBQWMsQ0FBQztZQUNsRCxDQUFDO1NBQUE7UUFFRCxPQUFPLElBQUksTUFBTSxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztLQUM5Qjs7QUFSSCxnREF3QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBhY21wY2EgZnJvbSAnQGF3cy1jZGsvYXdzLWFjbXBjYSc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IElDZXJ0aWZpY2F0ZSB9IGZyb20gJy4vY2VydGlmaWNhdGUnO1xuaW1wb3J0IHsgQ2VydGlmaWNhdGVCYXNlIH0gZnJvbSAnLi9jZXJ0aWZpY2F0ZS1iYXNlJztcbmltcG9ydCB7IENmbkNlcnRpZmljYXRlIH0gZnJvbSAnLi9jZXJ0aWZpY2F0ZW1hbmFnZXIuZ2VuZXJhdGVkJztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbmV4cG9ydCBpbnRlcmZhY2UgUHJpdmF0ZUNlcnRpZmljYXRlUHJvcHMge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGRvbWFpbk5hbWU6IHN0cmluZztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IHN1YmplY3RBbHRlcm5hdGl2ZU5hbWVzPzogc3RyaW5nW107XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGNlcnRpZmljYXRlQXV0aG9yaXR5OiBhY21wY2EuSUNlcnRpZmljYXRlQXV0aG9yaXR5O1xufVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbmV4cG9ydCBjbGFzcyBQcml2YXRlQ2VydGlmaWNhdGUgZXh0ZW5kcyBDZXJ0aWZpY2F0ZUJhc2UgaW1wbGVtZW50cyBJQ2VydGlmaWNhdGUge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICBwdWJsaWMgc3RhdGljIGZyb21DZXJ0aWZpY2F0ZUFybihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBjZXJ0aWZpY2F0ZUFybjogc3RyaW5nKTogSUNlcnRpZmljYXRlIHtcbiAgICBjbGFzcyBJbXBvcnQgZXh0ZW5kcyBDZXJ0aWZpY2F0ZUJhc2Uge1xuICAgICAgcHVibGljIHJlYWRvbmx5IGNlcnRpZmljYXRlQXJuID0gY2VydGlmaWNhdGVBcm47XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBJbXBvcnQoc2NvcGUsIGlkKTtcbiAgfVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICBwdWJsaWMgcmVhZG9ubHkgY2VydGlmaWNhdGVBcm46IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogUHJpdmF0ZUNlcnRpZmljYXRlUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgY2VydCA9IG5ldyBDZm5DZXJ0aWZpY2F0ZSh0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBkb21haW5OYW1lOiBwcm9wcy5kb21haW5OYW1lLFxuICAgICAgc3ViamVjdEFsdGVybmF0aXZlTmFtZXM6IHByb3BzLnN1YmplY3RBbHRlcm5hdGl2ZU5hbWVzLFxuICAgICAgY2VydGlmaWNhdGVBdXRob3JpdHlBcm46IHByb3BzLmNlcnRpZmljYXRlQXV0aG9yaXR5LmNlcnRpZmljYXRlQXV0aG9yaXR5QXJuLFxuICAgIH0pO1xuXG4gICAgdGhpcy5jZXJ0aWZpY2F0ZUFybiA9IGNlcnQucmVmO1xuICB9XG59XG4iXX0= |
{ | ||
"name": "@aws-cdk/aws-certificatemanager", | ||
"version": "1.140.0", | ||
"version": "1.141.0", | ||
"description": "The CDK Construct Library for AWS::CertificateManager", | ||
@@ -82,15 +82,15 @@ "main": "lib/index.js", | ||
"devDependencies": { | ||
"@aws-cdk/assertions": "1.140.0", | ||
"@aws-cdk/cdk-build-tools": "1.140.0", | ||
"@aws-cdk/cfn2ts": "1.140.0", | ||
"@aws-cdk/pkglint": "1.140.0", | ||
"@aws-cdk/assertions": "1.141.0", | ||
"@aws-cdk/cdk-build-tools": "1.141.0", | ||
"@aws-cdk/cfn2ts": "1.141.0", | ||
"@aws-cdk/pkglint": "1.141.0", | ||
"@types/jest": "^27.4.0" | ||
}, | ||
"dependencies": { | ||
"@aws-cdk/aws-acmpca": "1.140.0", | ||
"@aws-cdk/aws-cloudwatch": "1.140.0", | ||
"@aws-cdk/aws-iam": "1.140.0", | ||
"@aws-cdk/aws-lambda": "1.140.0", | ||
"@aws-cdk/aws-route53": "1.140.0", | ||
"@aws-cdk/core": "1.140.0", | ||
"@aws-cdk/aws-acmpca": "1.141.0", | ||
"@aws-cdk/aws-cloudwatch": "1.141.0", | ||
"@aws-cdk/aws-iam": "1.141.0", | ||
"@aws-cdk/aws-lambda": "1.141.0", | ||
"@aws-cdk/aws-route53": "1.141.0", | ||
"@aws-cdk/core": "1.141.0", | ||
"constructs": "^3.3.69" | ||
@@ -100,8 +100,8 @@ }, | ||
"peerDependencies": { | ||
"@aws-cdk/aws-acmpca": "1.140.0", | ||
"@aws-cdk/aws-cloudwatch": "1.140.0", | ||
"@aws-cdk/aws-iam": "1.140.0", | ||
"@aws-cdk/aws-lambda": "1.140.0", | ||
"@aws-cdk/aws-route53": "1.140.0", | ||
"@aws-cdk/core": "1.140.0", | ||
"@aws-cdk/aws-acmpca": "1.141.0", | ||
"@aws-cdk/aws-cloudwatch": "1.141.0", | ||
"@aws-cdk/aws-iam": "1.141.0", | ||
"@aws-cdk/aws-lambda": "1.141.0", | ||
"@aws-cdk/aws-route53": "1.141.0", | ||
"@aws-cdk/core": "1.141.0", | ||
"constructs": "^3.3.69" | ||
@@ -108,0 +108,0 @@ }, |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
1395020
20568
+ Added@aws-cdk/assets@1.141.0(transitive)
+ Added@aws-cdk/aws-acmpca@1.141.0(transitive)
+ Added@aws-cdk/aws-applicationautoscaling@1.141.0(transitive)
+ Added@aws-cdk/aws-autoscaling-common@1.141.0(transitive)
+ Added@aws-cdk/aws-cloudformation@1.141.0(transitive)
+ Added@aws-cdk/aws-cloudwatch@1.141.0(transitive)
+ Added@aws-cdk/aws-codeguruprofiler@1.141.0(transitive)
+ Added@aws-cdk/aws-codestarnotifications@1.141.0(transitive)
+ Added@aws-cdk/aws-ec2@1.141.0(transitive)
+ Added@aws-cdk/aws-ecr@1.141.0(transitive)
+ Added@aws-cdk/aws-ecr-assets@1.141.0(transitive)
+ Added@aws-cdk/aws-efs@1.141.0(transitive)
+ Added@aws-cdk/aws-events@1.141.0(transitive)
+ Added@aws-cdk/aws-iam@1.141.0(transitive)
+ Added@aws-cdk/aws-kms@1.141.0(transitive)
+ Added@aws-cdk/aws-lambda@1.141.0(transitive)
+ Added@aws-cdk/aws-logs@1.141.0(transitive)
+ Added@aws-cdk/aws-route53@1.141.0(transitive)
+ Added@aws-cdk/aws-s3@1.141.0(transitive)
+ Added@aws-cdk/aws-s3-assets@1.141.0(transitive)
+ Added@aws-cdk/aws-signer@1.141.0(transitive)
+ Added@aws-cdk/aws-sns@1.141.0(transitive)
+ Added@aws-cdk/aws-sqs@1.141.0(transitive)
+ Added@aws-cdk/aws-ssm@1.141.0(transitive)
+ Added@aws-cdk/cloud-assembly-schema@1.141.0(transitive)
+ Added@aws-cdk/core@1.141.0(transitive)
+ Added@aws-cdk/custom-resources@1.141.0(transitive)
+ Added@aws-cdk/cx-api@1.141.0(transitive)
+ Added@aws-cdk/region-info@1.141.0(transitive)
- Removed@aws-cdk/assets@1.140.0(transitive)
- Removed@aws-cdk/aws-acmpca@1.140.0(transitive)
- Removed@aws-cdk/aws-applicationautoscaling@1.140.0(transitive)
- Removed@aws-cdk/aws-autoscaling-common@1.140.0(transitive)
- Removed@aws-cdk/aws-cloudformation@1.140.0(transitive)
- Removed@aws-cdk/aws-cloudwatch@1.140.0(transitive)
- Removed@aws-cdk/aws-codeguruprofiler@1.140.0(transitive)
- Removed@aws-cdk/aws-codestarnotifications@1.140.0(transitive)
- Removed@aws-cdk/aws-ec2@1.140.0(transitive)
- Removed@aws-cdk/aws-ecr@1.140.0(transitive)
- Removed@aws-cdk/aws-ecr-assets@1.140.0(transitive)
- Removed@aws-cdk/aws-efs@1.140.0(transitive)
- Removed@aws-cdk/aws-events@1.140.0(transitive)
- Removed@aws-cdk/aws-iam@1.140.0(transitive)
- Removed@aws-cdk/aws-kms@1.140.0(transitive)
- Removed@aws-cdk/aws-lambda@1.140.0(transitive)
- Removed@aws-cdk/aws-logs@1.140.0(transitive)
- Removed@aws-cdk/aws-route53@1.140.0(transitive)
- Removed@aws-cdk/aws-s3@1.140.0(transitive)
- Removed@aws-cdk/aws-s3-assets@1.140.0(transitive)
- Removed@aws-cdk/aws-signer@1.140.0(transitive)
- Removed@aws-cdk/aws-sns@1.140.0(transitive)
- Removed@aws-cdk/aws-sqs@1.140.0(transitive)
- Removed@aws-cdk/aws-ssm@1.140.0(transitive)
- Removed@aws-cdk/cloud-assembly-schema@1.140.0(transitive)
- Removed@aws-cdk/core@1.140.0(transitive)
- Removed@aws-cdk/custom-resources@1.140.0(transitive)
- Removed@aws-cdk/cx-api@1.140.0(transitive)
- Removed@aws-cdk/region-info@1.140.0(transitive)
Updated@aws-cdk/aws-acmpca@1.141.0
Updated@aws-cdk/aws-iam@1.141.0
Updated@aws-cdk/aws-lambda@1.141.0
Updated@aws-cdk/aws-route53@1.141.0
Updated@aws-cdk/core@1.141.0