From 57ff5da7609333480107aeb11592774b9955aec3 Mon Sep 17 00:00:00 2001 From: Aditya Date: Thu, 26 Dec 2019 13:33:31 +0100 Subject: [PATCH 1/2] fix(apigateway): allow adding custom domain later --- .../@aws-cdk/aws-apigateway/lib/restapi.ts | 20 +++- .../aws-apigateway/test/test.domains.ts | 106 ++++++++++++++++++ 2 files changed, 122 insertions(+), 4 deletions(-) diff --git a/packages/@aws-cdk/aws-apigateway/lib/restapi.ts b/packages/@aws-cdk/aws-apigateway/lib/restapi.ts index 25cf73991db69..3d3f3688a3c1a 100644 --- a/packages/@aws-cdk/aws-apigateway/lib/restapi.ts +++ b/packages/@aws-cdk/aws-apigateway/lib/restapi.ts @@ -214,9 +214,9 @@ export class RestApi extends Resource implements IRestApi { /** * The domain name mapped to this API, if defined through the `domainName` - * configuration prop. + * configuration prop, or added later via `addDomainName` */ - public readonly domainName?: DomainName; + private _domainName?: DomainName; private readonly methods = new Array(); private _latestDeployment: Deployment | undefined; @@ -253,10 +253,18 @@ export class RestApi extends Resource implements IRestApi { this.restApiRootResourceId = resource.attrRootResourceId; if (props.domainName) { - this.domainName = this.addDomainName('CustomDomain', props.domainName); + this.addDomainName('CustomDomain', props.domainName); } } + /** + * The first domain name mapped to this API, if defined through the `domainName` + * configuration prop, or added via `addDomainName` + */ + public get domainName() { + return this._domainName; + } + /** * API Gateway deployment that represents the latest changes of the API. * This resource will be automatically updated every time the REST API model changes. @@ -292,10 +300,14 @@ export class RestApi extends Resource implements IRestApi { * @param options custom domain options */ public addDomainName(id: string, options: DomainNameOptions): DomainName { - return new DomainName(this, id, { + const domainName = new DomainName(this, id, { ...options, mapping: this }); + if (!this._domainName) { + this._domainName = domainName; + } + return domainName; } /** diff --git a/packages/@aws-cdk/aws-apigateway/test/test.domains.ts b/packages/@aws-cdk/aws-apigateway/test/test.domains.ts index 3591cf9558717..a285b472f3dd9 100644 --- a/packages/@aws-cdk/aws-apigateway/test/test.domains.ts +++ b/packages/@aws-cdk/aws-apigateway/test/test.domains.ts @@ -177,6 +177,112 @@ export = { } })); + test.done(); + }, + + 'a domain name can be added later'(test: Test) { + // GIVEN + const domainName = 'my.domain.com'; + const stack = new Stack(); + const certificate = new acm.Certificate(stack, 'cert', { domainName: 'my.domain.com' }); + + // WHEN + const api = new apigw.RestApi(stack, 'api', {}); + + api.root.addMethod('GET'); + + api.addDomainName('domainId', { domainName, certificate }); + + // THEN + expect(stack).to(haveResource('AWS::ApiGateway::DomainName', { + "DomainName": domainName, + "EndpointConfiguration": { + "Types": [ + "REGIONAL" + ] + }, + "RegionalCertificateArn": { + "Ref": "cert56CA94EB" + } + })); + expect(stack).to(haveResource('AWS::ApiGateway::BasePathMapping', { + "DomainName": { + "Ref": "apidomainId102F8DAA" + }, + "RestApiId": { + "Ref": "apiC8550315" + }, + "Stage": { + "Ref": "apiDeploymentStageprod896C8101" + } + })); + + test.done(); + }, + + 'multiple domain names can be added'(test: Test) { + // GIVEN + const domainName = 'my.domain.com'; + const stack = new Stack(); + const certificate = new acm.Certificate(stack, 'cert', { domainName: 'my.domain.com' }); + + // WHEN + const api = new apigw.RestApi(stack, 'api', {}); + + api.root.addMethod('GET'); + + const domainName1 = api.addDomainName('domainId', { domainName, certificate }); + api.addDomainName('domainId1', { domainName: 'your.domain.com', certificate }); + api.addDomainName('domainId2', { domainName: 'our.domain.com', certificate }); + + test.deepEqual(api.domainName, domainName1); + + // THEN + expect(stack).to(haveResource('AWS::ApiGateway::DomainName', { + "DomainName": 'my.domain.com', + "EndpointConfiguration": { + "Types": [ + "REGIONAL" + ] + }, + "RegionalCertificateArn": { + "Ref": "cert56CA94EB" + } + })); + expect(stack).to(haveResource('AWS::ApiGateway::DomainName', { + "DomainName": 'your.domain.com', + "EndpointConfiguration": { + "Types": [ + "REGIONAL" + ] + }, + "RegionalCertificateArn": { + "Ref": "cert56CA94EB" + } + })); + expect(stack).to(haveResource('AWS::ApiGateway::DomainName', { + "DomainName": 'our.domain.com', + "EndpointConfiguration": { + "Types": [ + "REGIONAL" + ] + }, + "RegionalCertificateArn": { + "Ref": "cert56CA94EB" + } + })); + expect(stack).to(haveResource('AWS::ApiGateway::BasePathMapping', { + "DomainName": { + "Ref": "apidomainId102F8DAA" + }, + "RestApiId": { + "Ref": "apiC8550315" + }, + "Stage": { + "Ref": "apiDeploymentStageprod896C8101" + } + })); + test.done(); } }; From 6990b3ea42822d7d16aa895de6a515aef9e0c30c Mon Sep 17 00:00:00 2001 From: Niranjan Jayakar Date: Mon, 13 Jan 2020 12:04:04 +0000 Subject: [PATCH 2/2] remove documentation from private member --- packages/@aws-cdk/aws-apigateway/lib/restapi.ts | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/packages/@aws-cdk/aws-apigateway/lib/restapi.ts b/packages/@aws-cdk/aws-apigateway/lib/restapi.ts index 3d3f3688a3c1a..a66bba21fbd22 100644 --- a/packages/@aws-cdk/aws-apigateway/lib/restapi.ts +++ b/packages/@aws-cdk/aws-apigateway/lib/restapi.ts @@ -212,13 +212,8 @@ export class RestApi extends Resource implements IRestApi { */ public deploymentStage!: Stage; - /** - * The domain name mapped to this API, if defined through the `domainName` - * configuration prop, or added later via `addDomainName` - */ - private _domainName?: DomainName; - private readonly methods = new Array(); + private _domainName?: DomainName; private _latestDeployment: Deployment | undefined; constructor(scope: Construct, id: string, props: RestApiProps = { }) {