@aws-solutions-constructs/aws-route53-apigateway
Advanced tools
Comparing version 2.5.0 to 2.6.0
@@ -77,3 +77,3 @@ "use strict"; | ||
_a = JSII_RTTI_SYMBOL_1; | ||
Route53ToApiGateway[_a] = { fqn: "@aws-solutions-constructs/aws-route53-apigateway.Route53ToApiGateway", version: "2.5.0" }; | ||
Route53ToApiGateway[_a] = { fqn: "@aws-solutions-constructs/aws-route53-apigateway.Route53ToApiGateway", version: "2.6.0" }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAeA,mDAAmD;AACnD,2DAA2D;AAE3D,2DAA2D;AAE3D,wFAAwF;AACxF,2CAAuC;AAiDvC;;GAEG;AACH,MAAa,mBAAoB,SAAQ,sBAAS;IAKhD;;;;;;;OAOG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA+B;QACvE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAE3B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,4BAA4B,CAAC;QAEtD,IAAI,KAAK,CAAC,WAAW,EAAE;YACrB,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC,WAAW,CAAC;SAC9B;QAED,yCAAyC;QACzC,IAAI,KAAK,CAAC,2BAA2B,EAAE;YACrC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,2BAA2B,CAAC;YAEpD,IAAI,KAAK,CAAC,WAAW,EAAE;gBACrB,MAAM,IAAI,KAAK,CAAC,oEAAoE,CAAC,CAAC;aACvF;YACD,IAAI,KAAK,CAAC,sBAAsB,EAAE;gBAChC,MAAM,IAAI,KAAK,CAAC,0FAA0F,CAAC,CAAC;aAC7G;SACF;aAAM,EAAE,iCAAiC;YACxC,IAAI,KAAK,CAAC,SAAS,EAAE;gBACnB,MAAM,IAAI,KAAK,CAAC,0EAA0E,CAAC,CAAC;aAC7F;iBAAM;gBACL,IAAI,CAAC,KAAK,CAAC,sBAAsB,EAAE;oBACjC,MAAM,IAAI,KAAK,CAAC,4EAA4E,CAAC,CAAC;iBAC/F;gBACD,IAAI,KAAK,CAAC,sBAAsB,CAAC,GAAG,EAAE;oBACpC,MAAM,IAAI,KAAK,CAAC,oFAAoF,CAAC,CAAC;iBACvG;gBACD,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,QAAQ,EAAE;oBAC1C,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;iBACxE;gBACD,IAAK,CAAC,IAAI,CAAC,GAAG,EAAG;oBACf,MAAM,IAAI,KAAK,CAAC,iFAAiF,CAAC,CAAC;iBACpG;gBACD,MAAM,iBAAiB,GAAmC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,sBAAsB,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;gBAClI,IAAI,CAAC,UAAU,GAAG,IAAI,OAAO,CAAC,iBAAiB,CAAC,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,iBAAiB,CAAC,CAAC;aACxF;SACF;QAED,8BAA8B;QAC9B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,2BAA0C,CAAC;QAEnE,wCAAwC;QACxC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,kBAAkB,EAAE;YAChD,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ;YACpC,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;QAEH,mEAAmE;QACnE,IAAI,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,yBAAyB,EAAE;YACnD,IAAI,EAAE,IAAI,CAAC,UAAU;YACrB,MAAM,EAAE,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAChF,CAAC,CAAC;IACL,CAAC;;AApEH,kDAqEC","sourcesContent":["/**\n *  Copyright 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n// Imports\nimport * as api from 'aws-cdk-lib/aws-apigateway';\nimport * as route53 from \"aws-cdk-lib/aws-route53\";\nimport * as targets from 'aws-cdk-lib/aws-route53-targets';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as defaults from '@aws-solutions-constructs/core';\nimport * as certificatemanager from 'aws-cdk-lib/aws-certificatemanager';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\n\n/**\n * The properties for the Route53ToApiGateway class.\n */\nexport interface Route53ToApiGatewayProps {\n  /**\n   * Whether to create a public or private API. This value has implications\n   * for the VPC, the type of Hosted Zone and the Application Load Balancer\n   *\n   * @default - None\n   */\n  readonly publicApi: boolean\n  /**\n   * Optional custom properties for a new Private Hosted Zone. Cannot be specified for a\n   * public API. Cannot specify a VPC, it will use the VPC in existingVpc or the VPC created by the construct.\n   * Providing both this and existingHostedZoneInterface is an error.\n   *\n   * @default - None\n   */\n  readonly privateHostedZoneProps?: route53.PrivateHostedZoneProps | any,\n  /**\n   * Existing Public or Private Hosted Zone. If a Private Hosted Zone, must\n   * exist in the same VPC specified in existingVpc\n   *\n   * @default - None\n   */\n  readonly existingHostedZoneInterface?: route53.IHostedZone,\n  /**\n   * An existing VPC. If an existing Private Hosted Zone is provided,\n   * this value must be the VPC associated with those resources.\n   *\n   * @default - None\n   */\n  readonly existingVpc?: ec2.IVpc,\n  /**\n   * The existing API Gateway instance that will be protected with the Route 53 hosted zone.\n   *\n   * @default - None\n   */\n  readonly existingApiGatewayInterface: api.IRestApi,\n  /**\n   * An existing AWS Certificate Manager certificate for your custom domain name.\n   *\n   * @defualt - None\n   */\n  readonly existingCertificateInterface: certificatemanager.ICertificate;\n}\n\n/**\n * @summary The Route53ToApiGateway class.\n */\nexport class Route53ToApiGateway extends Construct {\n  public readonly hostedZone: route53.IHostedZone;\n  public readonly vpc?: ec2.IVpc;\n  public readonly apiGateway: api.RestApi;\n  public readonly certificate: certificatemanager.ICertificate;\n  /**\n   * @summary Constructs a new instance of the Route53ToApiGateway class.\n   * @param {cdk.App} scope - represents the scope for all the resources.\n   * @param {string} id - this is a a scope-unique id.\n   * @param {Route53ToApiGatewayProps} props - user provided props for the construct\n   * @since 0.8.0\n   * @access public\n   */\n  constructor(scope: Construct, id: string, props: Route53ToApiGatewayProps) {\n    super(scope, id);\n    defaults.CheckProps(props);\n\n    this.certificate = props.existingCertificateInterface;\n\n    if (props.existingVpc) {\n      this.vpc = props.existingVpc;\n    }\n\n    // Existing Public or Private Hosted Zone\n    if (props.existingHostedZoneInterface) {\n      this.hostedZone = props.existingHostedZoneInterface;\n\n      if (props.existingVpc) {\n        throw new Error('Cannot provide an existing VPC to an existing Private Hosted Zone.');\n      }\n      if (props.privateHostedZoneProps) {\n        throw new Error('Must provide either existingHostedZoneInterface or privateHostedZoneProps, but not both.');\n      }\n    } else { // Creating a Private Hosted Zone\n      if (props.publicApi) {\n        throw new Error('Public APIs require an existingHostedZone be passed in the Props object.');\n      } else {\n        if (!props.privateHostedZoneProps) {\n          throw new Error('Must provide either existingHostedZoneInterface or privateHostedZoneProps.');\n        }\n        if (props.privateHostedZoneProps.vpc) {\n          throw new Error('All VPC specs must be provided at the Construct level in Route53ToApiGatewayProps.');\n        }\n        if (!props.privateHostedZoneProps.zoneName) {\n          throw new Error('Must supply zoneName for Private Hosted Zone Props.');\n        }\n        if ( !this.vpc ) {\n          throw new Error('Must specify an existingVPC for the Private Hosted Zone in the construct props.');\n        }\n        const manufacturedProps: route53.PrivateHostedZoneProps = defaults.overrideProps(props.privateHostedZoneProps, { vpc: this.vpc });\n        this.hostedZone = new route53.PrivateHostedZone(this, `${id}-zone`, manufacturedProps);\n      }\n    }\n\n    // Convert IRestApi to RestApi\n    this.apiGateway = props.existingApiGatewayInterface as api.RestApi;\n\n    // Add custom domain name in API Gateway\n    this.apiGateway.addDomainName('CustomDomainName', {\n      domainName: this.hostedZone.zoneName,\n      certificate: this.certificate\n    });\n\n    // Create A Record in custom domain to route traffic to API Gateway\n    new route53.ARecord(this, 'CustomDomainAliasRecord', {\n      zone: this.hostedZone,\n      target: route53.RecordTarget.fromAlias(new targets.ApiGateway(this.apiGateway))\n    });\n  }\n}"]} |
{ | ||
"name": "@aws-solutions-constructs/aws-route53-apigateway", | ||
"version": "2.5.0", | ||
"version": "2.6.0", | ||
"description": "CDK constructs for connecting an Amazon Route53 domain to an API Gateway.", | ||
@@ -56,10 +56,10 @@ "main": "lib/index.js", | ||
"dependencies": { | ||
"@aws-solutions-constructs/core": "2.5.0" | ||
"@aws-solutions-constructs/core": "2.6.0" | ||
}, | ||
"devDependencies": { | ||
"@aws-cdk/assert": "2.15.0", | ||
"@aws-cdk/assert": "2.20.0", | ||
"@types/jest": "^26.0.22", | ||
"@types/node": "^10.3.0", | ||
"prettier": "^2.5.1", | ||
"aws-cdk-lib": "2.15.0", | ||
"aws-cdk-lib": "2.20.0", | ||
"constructs": "^10.0.0" | ||
@@ -82,4 +82,4 @@ }, | ||
"peerDependencies": { | ||
"@aws-solutions-constructs/core": "2.5.0", | ||
"aws-cdk-lib": "^2.15.0", | ||
"@aws-solutions-constructs/core": "2.6.0", | ||
"aws-cdk-lib": "^2.20.0", | ||
"constructs": "^10.0.0" | ||
@@ -86,0 +86,0 @@ }, |
100
README.md
@@ -29,9 +29,11 @@ # aws-route53-apigateway module | ||
Here is a minimal deployable pattern definition in Typescript: | ||
Here is a minimal deployable pattern definition: | ||
Typescript | ||
``` typescript | ||
import * as api from '@aws-cdk/aws-apigateway'; | ||
import * as lambda from "@aws-cdk/aws-lambda"; | ||
import * as route53 from "@aws-cdk/aws-route53"; | ||
import { Route53ToApigateway } from '@aws-solutions-constructs/aws-route53-apigateway'; | ||
import { Construct } from 'constructs'; | ||
import { Stack, StackProps } from 'aws-cdk-lib'; | ||
import * as route53 from "aws-cdk-lib/aws-route53"; | ||
import * as acm from "aws-cdk-lib/aws-certificatemanager"; | ||
import { Route53ToApiGateway } from '@aws-solutions-constructs/aws-route53-apigateway'; | ||
@@ -42,15 +44,16 @@ // The construct requires an existing REST API, this can be created in raw CDK or extracted | ||
// domainName must match existing hosted zone in your account and the existing certificate | ||
const ourHostedZone = route53.HostedZone.fromLookup(this, 'HostedZone', { | ||
domainName: "example.com", | ||
}); | ||
}); | ||
const certificate = acm.Certificate.fromCertificateArn( | ||
stack, | ||
this, | ||
"fake-cert", | ||
"arn:aws:acm:us-east-1:123456789012:certificate/11112222-3333-1234-1234-123456789012" | ||
); | ||
); | ||
// This construct can only be attached to a configured API Gateway. | ||
new Route53ToApigateway(this, 'Route53ToApigatewayPattern', { | ||
existingApiGatewayObj: existingRestApi, | ||
new Route53ToApiGateway(this, 'Route53ToApiGatewayPattern', { | ||
existingApiGatewayInterface: existingRestApi, | ||
existingHostedZoneInterface: ourHostedZone, | ||
@@ -60,17 +63,78 @@ publicApi: true, | ||
}); | ||
``` | ||
## Initializer | ||
Python | ||
```python | ||
from aws_solutions_constructs.aws_route53_apigateway import Route53ToApiGateway | ||
from aws_cdk import ( | ||
aws_route53 as route53, | ||
aws_certificatemanager as acm, | ||
Stack | ||
) | ||
from constructs import Construct | ||
``` text | ||
new Route53ToApigateway(scope: Construct, id: string, props: Route53ToApigatewayProps); | ||
# The construct requires an existing REST API, this can be created in raw CDK or extracted | ||
# from a previously instantiated construct that created an API Gateway REST API | ||
existingRestApi = previouslyCreatedApigatewayToLambdaConstruct.apiGateway | ||
# domain_name must match existing hosted zone in your account and the existing certificate | ||
ourHostedZone = route53.HostedZone.from_lookup(self, 'HostedZone', | ||
domain_name="example.com", | ||
) | ||
# Obtain a pre-existing certificate from your account | ||
certificate = acm.Certificate.from_certificate_arn( | ||
self, | ||
'existing-cert', | ||
"arn:aws:acm:us-east-1:123456789012:certificate/11112222-3333-1234-1234-123456789012" | ||
) | ||
# This construct can only be attached to a configured API Gateway. | ||
Route53ToApiGateway(self, 'Route53ToApigatewayPattern', | ||
existing_api_gateway_interface=existingRestApi, | ||
existing_hosted_zone_interface=ourHostedZone, | ||
public_api=True, | ||
existing_certificate_interface=certificate | ||
) | ||
``` | ||
_Parameters_ | ||
Java | ||
``` java | ||
import software.constructs.Construct; | ||
* scope [`Construct`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_core.Construct.html) | ||
* id `string` | ||
* props [`Route53ToApigatewayProps`](#pattern-construct-props) | ||
import software.amazon.awscdk.Stack; | ||
import software.amazon.awscdk.StackProps; | ||
import software.amazon.awscdk.services.route53.*; | ||
import software.amazon.awscdk.services.apigateway.*; | ||
import software.amazon.awscdk.services.certificatemanager.*; | ||
import software.amazon.awsconstructs.services.route53apigateway.*; | ||
// The construct requires an existing REST API, this can be created in raw CDK | ||
// or extracted from a previously instantiated construct that created an API | ||
// Gateway REST API | ||
final IRestApi existingRestApi = previouslyCreatedApigatewayToLambdaConstruct.getApiGateway(); | ||
// domainName must match existing hosted zone in your account and the existing certificate | ||
final IHostedZone ourHostedZone = HostedZone.fromLookup(this, "HostedZone", | ||
new HostedZoneProviderProps.Builder() | ||
.domainName("example.com") | ||
.build()); | ||
// Obtain a pre-existing certificate from your account | ||
final ICertificate certificate = Certificate.fromCertificateArn( | ||
this, | ||
"existing-cert", | ||
"arn:aws:acm:us-east-1:123456789012:certificate/11112222-3333-1234-1234-123456789012"); | ||
// This construct can only be attached to a configured API Gateway. | ||
new Route53ToApiGateway(this, "Route53ToApiGatewayPattern", | ||
new Route53ToApiGatewayProps.Builder() | ||
.existingApiGatewayInterface(existingRestApi) | ||
.existingHostedZoneInterface(ourHostedZone) | ||
.publicApi(true) | ||
.existingCertificateInterface(certificate) | ||
.build()); | ||
``` | ||
## Pattern Construct Props | ||
@@ -77,0 +141,0 @@ |
Sorry, the diff of this file is not supported yet
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
266480
177
364
+ Added@aws-solutions-constructs/core@2.6.0(transitive)
- Removed@aws-solutions-constructs/core@2.5.0(transitive)