@btc-embedded/cdk-extensions 0.9.4 → 0.9.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/.backstage/catalog-info.yaml +23 -0
- package/.jsii +2332 -1370
- package/API.md +1070 -323
- package/CHANGELOG.md +24 -0
- package/docs/RFC003-referencing-platform-components.md +125 -0
- package/docs/adrs/0001-use-adrs.md +36 -0
- package/docs/index.md +20 -0
- package/lib/constructs/EventPipe.js +1 -1
- package/lib/constructs/S3Bucket.js +1 -1
- package/lib/constructs/SecureRestApi.js +7 -6
- package/lib/constructs/SecureRestApiV2.d.ts +6 -7
- package/lib/constructs/SecureRestApiV2.js +17 -25
- package/lib/extensions/ApiGatewayExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtensionV2.d.ts +4 -4
- package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +9 -15
- package/lib/extensions/CloudMapExtension.d.ts +0 -6
- package/lib/extensions/CloudMapExtension.js +5 -13
- package/lib/extensions/DeactivatableServiceExtension.js +1 -1
- package/lib/extensions/DocumentDbAccessExtension.d.ts +2 -1
- package/lib/extensions/DocumentDbAccessExtension.js +9 -13
- package/lib/extensions/DomainEventMessagingExtension.js +1 -1
- package/lib/extensions/ExtraContainerExtension.js +1 -1
- package/lib/extensions/HTTPApiExtension.js +15 -24
- package/lib/extensions/LogExtension.js +1 -1
- package/lib/extensions/ModifyContainerDefinitionExtension.js +1 -1
- package/lib/extensions/ModifyTaskDefinitionExtension.js +1 -1
- package/lib/extensions/OpenTelemetryExtension.js +1 -1
- package/lib/extensions/PostgresDbAccessExtension.js +1 -1
- package/lib/extensions/SharedVolumeExtension.js +1 -1
- package/lib/extensions/TcpKeepAliveExtension.js +1 -1
- package/lib/platform/ApiGateway.js +1 -1
- package/lib/platform/ApiGatewayV2.d.ts +16 -6
- package/lib/platform/ApiGatewayV2.js +34 -18
- package/lib/platform/ApplicationLoadBalancer.js +1 -1
- package/lib/platform/ApplicationLoadBalancerV2.d.ts +21 -8
- package/lib/platform/ApplicationLoadBalancerV2.js +47 -33
- package/lib/platform/CognitoUserPool.d.ts +52 -5
- package/lib/platform/CognitoUserPool.js +98 -15
- package/lib/platform/DefaultUserPoolClients.d.ts +1 -1
- package/lib/platform/DefaultUserPoolClients.js +3 -3
- package/lib/platform/DocumentDB.d.ts +15 -1
- package/lib/platform/DocumentDB.js +36 -17
- package/lib/platform/PrivateDnsNamespace.d.ts +10 -3
- package/lib/platform/PrivateDnsNamespace.js +33 -18
- package/lib/platform/ResourceServer.js +1 -1
- package/lib/platform/Vpc.d.ts +17 -3
- package/lib/platform/Vpc.js +32 -13
- package/lib/platform/index.d.ts +0 -2
- package/lib/platform/index.js +1 -3
- package/lib/utils/ImportValue.d.ts +10 -3
- package/lib/utils/ImportValue.js +12 -15
- package/lib/utils/StackParameter.d.ts +35 -0
- package/lib/utils/StackParameter.js +65 -0
- package/lib/utils/exportStackInfo.d.ts +28 -0
- package/lib/utils/exportStackInfo.js +29 -0
- package/lib/utils/functions.js +3 -3
- package/lib/utils/index.d.ts +2 -0
- package/lib/utils/index.js +3 -1
- package/mkdocs.yml +8 -0
- package/package.json +1 -1
- package/lib/platform/ApiUserPoolClient.d.ts +0 -32
- package/lib/platform/ApiUserPoolClient.js +0 -47
- package/lib/platform/ApplicationUserPoolClient.d.ts +0 -51
- package/lib/platform/ApplicationUserPoolClient.js +0 -66
- /package/{rfcs/001-api-gateway.md → docs/RFC001-api-gateway.md} +0 -0
- /package/{rfcs/002-developer-stacks.md → docs/RFC002-developer-stacks.md} +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,4 +1,28 @@
|
|
|
1
1
|
|
|
2
|
+
## [0.9.5](https://github.com/btc-embedded/cdk-extensions/compare/v0.9.4...v0.9.5) (2025-04-10)
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
### Features
|
|
6
|
+
|
|
7
|
+
* introduce proper base platform resource access from app CDKs ([a2d4b1a](https://github.com/btc-embedded/cdk-extensions/commit/a2d4b1a9c436aa7b4752286486f07ec9027a8180))
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
### Bug Fixes
|
|
11
|
+
|
|
12
|
+
* add index.md ([4f045e2](https://github.com/btc-embedded/cdk-extensions/commit/4f045e25dd9948dbf9ea9ccee0f9d9b982e9c60a))
|
|
13
|
+
* doc name ([2942e77](https://github.com/btc-embedded/cdk-extensions/commit/2942e77f31d331e039fd2e7ec27bf676f3ccc465))
|
|
14
|
+
* modify docs and add adrs ([894e8d4](https://github.com/btc-embedded/cdk-extensions/commit/894e8d4cd98dc463f7a3376d89c8decc9d49018a))
|
|
15
|
+
* modify index.md file ([6f31572](https://github.com/btc-embedded/cdk-extensions/commit/6f31572be0e4d6ec5f692bce515e1ded4fbdb25c))
|
|
16
|
+
* remove endoflife and coder due to no use case in this porject ([303fccb](https://github.com/btc-embedded/cdk-extensions/commit/303fccb2155672a9d98f4c03e1c79e47bdd0652a))
|
|
17
|
+
* remove the dependency to cat backstage template ([5835100](https://github.com/btc-embedded/cdk-extensions/commit/58351004a312709bc8de40d6d6724d62473de8e2))
|
|
18
|
+
|
|
19
|
+
## [0.9.4](https://github.com/btc-embedded/cdk-extensions/compare/v0.9.3...v0.9.4) (2025-04-09)
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
### Bug Fixes
|
|
23
|
+
|
|
24
|
+
* omit empty filters and input templates for event pipes ([763d7cc](https://github.com/btc-embedded/cdk-extensions/commit/763d7cc5e8d5377975e429f6a2efcc602d592678))
|
|
25
|
+
|
|
2
26
|
## [0.9.3](https://github.com/btc-embedded/cdk-extensions/compare/v0.9.2...v0.9.3) (2025-04-08)
|
|
3
27
|
|
|
4
28
|
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
# Referencing platform components in application-level stacks
|
|
2
|
+
|
|
3
|
+
The CDK extensions library provides components which are intended to be
|
|
4
|
+
instantiated in a _base platform_ stack as well as an _application-level_ stack.
|
|
5
|
+
Such resources (and their functionality) should then be accessible to services
|
|
6
|
+
developed and maintained in independently deployed, _application-level_ CDK
|
|
7
|
+
apps. This document describes the platform component interface to provide this
|
|
8
|
+
functionality.
|
|
9
|
+
|
|
10
|
+
## Platform component interface
|
|
11
|
+
|
|
12
|
+
Technically, the application-level stack references base platform components
|
|
13
|
+
with the help of stack output parameters. To encapsulate this aspect, every base
|
|
14
|
+
platform component has a static method `fromBasePlatform(scope: Construct, id:
|
|
15
|
+
string, name: string)` which, given the base platform stack name, returns an
|
|
16
|
+
instance of the platform component where the required lookup has been performed.
|
|
17
|
+
|
|
18
|
+
The resulting component instance then supports access to base platform component
|
|
19
|
+
properties or can even provide operations to the application-level stack (i.e.
|
|
20
|
+
registering a target group to an ALB). Example:
|
|
21
|
+
|
|
22
|
+
```typescript
|
|
23
|
+
export interface IPlatformComponent {
|
|
24
|
+
readonly property: IVpcLink;
|
|
25
|
+
readonly securityGroup: ISecurityGroup;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export class PlatformComponent extends Construct implements IPlatformComponent {
|
|
29
|
+
public static fromBasePlatform(
|
|
30
|
+
scope: Construct,
|
|
31
|
+
id: string,
|
|
32
|
+
name: string,
|
|
33
|
+
): IPlatformComponent {
|
|
34
|
+
// ... code requird to look up the output parameters ...
|
|
35
|
+
|
|
36
|
+
class Import extends Construct implements IApiGatewayV2 {
|
|
37
|
+
public readonly securityGroup: ISecurityGroup = /* ... */;
|
|
38
|
+
public readonly vpcLink: IVpcLink = /* ... */;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// create an instance satisfying the interface defined above
|
|
42
|
+
return new Import(scope, id);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
readonly property: IVpcLink;
|
|
46
|
+
readonly securityGroup: ISecurityGroup;
|
|
47
|
+
|
|
48
|
+
// ... further component code, constructor, ...
|
|
49
|
+
}
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
In more complex scenarios where functionality should be provided to the
|
|
53
|
+
application-level stack, we can use a base class in order to provide
|
|
54
|
+
functionality in the interface, such that it is also available at the platform
|
|
55
|
+
component instance.
|
|
56
|
+
|
|
57
|
+
```typescript
|
|
58
|
+
|
|
59
|
+
export interface IPlatformComponent {
|
|
60
|
+
readonly property: IVpcLink;
|
|
61
|
+
readonly securityGroup: ISecurityGroup;
|
|
62
|
+
|
|
63
|
+
doSomething(target: IConnectable): void;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
export abstract class PlatformComponentBase extends Construct implements IPlatformComponent {
|
|
67
|
+
abstract readonly property: IVpcLink;
|
|
68
|
+
abstract readonly securityGroup: ISecurityGroup;
|
|
69
|
+
|
|
70
|
+
doSomething(target: IConnectable) {
|
|
71
|
+
securityGroup.allowFrom(target);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
export class PlatformComponent extends PlatformComponentBase {
|
|
76
|
+
public static fromBasePlatform(
|
|
77
|
+
scope: Construct,
|
|
78
|
+
id: string,
|
|
79
|
+
name: string,
|
|
80
|
+
): IPlatformComponent {
|
|
81
|
+
// ... code requird to look up the output parameters ...
|
|
82
|
+
|
|
83
|
+
class Import extends PlatformComponentBase {
|
|
84
|
+
readonly securityGroup: ISecurityGroup = /* ... */;
|
|
85
|
+
readonly vpcLink: IVpcLink = /* ... */;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
// create an instance satisfying the interface defined above
|
|
89
|
+
return new Import(scope, id);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
readonly property: IVpcLink;
|
|
93
|
+
readonly securityGroup: ISecurityGroup;
|
|
94
|
+
|
|
95
|
+
// ... further component code, constructor, ...
|
|
96
|
+
}
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
This approach provides means to encapsulate component-specific handling of stack
|
|
100
|
+
parameters for transporting the information necessary to instantiate the
|
|
101
|
+
component interface in the application.
|
|
102
|
+
|
|
103
|
+
## Usage in the application-level stack
|
|
104
|
+
|
|
105
|
+
The example below shows how to use a base platform component in the
|
|
106
|
+
application-level stack:
|
|
107
|
+
|
|
108
|
+
```typescript
|
|
109
|
+
// ...
|
|
110
|
+
|
|
111
|
+
const component = PlatformComponent.fromBasePlatform(
|
|
112
|
+
this.scope,
|
|
113
|
+
"PlatformComponent",
|
|
114
|
+
this.props.basePlatformStackName, // must be specified in the stack config
|
|
115
|
+
);
|
|
116
|
+
|
|
117
|
+
component.doSomething(service);
|
|
118
|
+
|
|
119
|
+
// ...
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
During CDK synthesis, this code will instantiate the necessary lookups to the
|
|
123
|
+
parameters exposed by the base platform. The interface returned by the static
|
|
124
|
+
lookup method allows us to explicitly state the base platform component
|
|
125
|
+
capabilities in the context of the application-level CDK.
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
---
|
|
2
|
+
status: Accepted
|
|
3
|
+
date: 2025-04-07
|
|
4
|
+
deciders: Cloud Architecture & Technololgy
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# AD: Use ADRs to Document Architecture decision
|
|
8
|
+
|
|
9
|
+
## Context and Problem Statement
|
|
10
|
+
|
|
11
|
+
Architecture decisions are not visibile from the code strucutre itself. These decisions are therefor prone to be reiteratied on multiple times.
|
|
12
|
+
|
|
13
|
+
## Decision Drivers
|
|
14
|
+
|
|
15
|
+
* Desire to have a comprehensive documentation of the system
|
|
16
|
+
* Have a industrie standard for documentation of architecture decisions
|
|
17
|
+
*
|
|
18
|
+
|
|
19
|
+
## Considered Options
|
|
20
|
+
|
|
21
|
+
1. Ad hoc documents
|
|
22
|
+
2. Architecture Decision Records (ADRs)
|
|
23
|
+
|
|
24
|
+
## Decision Outcome
|
|
25
|
+
|
|
26
|
+
We decided on using ADRs since it is the only of the two options satisfying all decision drivers.
|
|
27
|
+
|
|
28
|
+
### Consequences
|
|
29
|
+
|
|
30
|
+
* Good, architecture decisions are documented.
|
|
31
|
+
* Bad, you have to write an ADR for every decision.
|
|
32
|
+
|
|
33
|
+
## More Information
|
|
34
|
+
|
|
35
|
+
* See the link to the definiton of Architecture Decision Records [https://adr.github.io/](https://adr.github.io/)
|
|
36
|
+
* See the link to the MADR Desicion tempates for more information on the temaplate [https://github.com/adr/madr/tree/3.0.0](https://github.com/adr/madr/tree/3.0.0)
|
package/docs/index.md
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
# Project Structure Documentation
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
The project is organized into the following directories and files:
|
|
5
|
+
|
|
6
|
+
```
|
|
7
|
+
/src
|
|
8
|
+
├── constructs
|
|
9
|
+
├── extensions
|
|
10
|
+
├── platform
|
|
11
|
+
├── utils
|
|
12
|
+
/docs
|
|
13
|
+
/test
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
# To Install it run
|
|
17
|
+
|
|
18
|
+
```bash
|
|
19
|
+
npm i @btc-embedded/cdk-extensions
|
|
20
|
+
```
|
|
@@ -104,5 +104,5 @@ class EventPipe extends construct_1.Construct {
|
|
|
104
104
|
}
|
|
105
105
|
exports.EventPipe = EventPipe;
|
|
106
106
|
_a = JSII_RTTI_SYMBOL_1;
|
|
107
|
-
EventPipe[_a] = { fqn: "@btc-embedded/cdk-extensions.EventPipe", version: "0.9.
|
|
107
|
+
EventPipe[_a] = { fqn: "@btc-embedded/cdk-extensions.EventPipe", version: "0.9.6" };
|
|
108
108
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventPipe.js","sourceRoot":"","sources":["../../src/constructs/EventPipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Annotations } from \"aws-cdk-lib\";\nimport { Role, ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { CfnPipe } from \"aws-cdk-lib/aws-pipes\";\nimport { IQueue } from \"aws-cdk-lib/aws-sqs\";\nimport { IStateMachine } from \"aws-cdk-lib/aws-stepfunctions\";\nimport { Construct } from \"constructs/lib/construct\";\nimport { isDeactivatedConstruct } from \"../utils/deactivatedConstruct\";\n\n/**\n * Properties for pipe construction.\n */\nexport interface EventPipeProps {\n  /**\n   * The source SQS queue. No other source types are supported at the moment.\n   */\n  readonly source: IQueue;\n\n  /**\n   * The target SQS queue or target step function.\n   */\n  readonly target: TargetQueue | TargetStepFunction;\n\n  /**\n   * The role used by the event pipe. If omitted, a new role is created.\n   */\n  readonly role?: Role;\n\n  /**\n   * An optional filter for the pipe.\n   */\n  readonly filter?: PipeFilter;\n}\n\n/**\n * The invocation type of the step function.\n */\nexport enum InvocationType {\n  /**\n   * (default) - Invoke synchronously. For more information, see\n   * [StartSyncExecution](https://docs.aws.amazon.com/step-functions/latest/apireference/API_StartSyncExecution.html)\n   * in the *AWS Step Functions API Reference*.\n   * > `REQUEST_RESPONSE` is not supported for `STANDARD` state machine workflows.\n   */\n  REQUEST_RESPONSE,\n  /**\n   * Invoke asynchronously. For more information, see\n   * [StartExecution](https://docs.aws.amazon.com/step-functions/latest/apireference/API_StartExecution.html)\n   * in the *AWS Step Functions API Reference*.\n   */\n  FIRE_AND_FORGET,\n}\n\nexport interface InputTemplate {\n  /**\n   * @jsii ignore\n   */\n  readonly [key: string]: string;\n}\n\n/**\n * SQS queue as pipe target.\n */\nexport interface TargetQueue {\n  readonly queue: IQueue;\n}\n\n/**\n * StepFunction as pipe target.\n */\nexport interface TargetStepFunction {\n  readonly stepFunction: IStateMachine;\n  readonly parameters?: TargetStepFunctionParameters;\n}\n\n/**\n * Parameters for a step function target.\n */\nexport interface TargetStepFunctionParameters {\n  readonly inputTemplate?: InputTemplate;\n  readonly invocationType?: InvocationType;\n}\n\n/**\n * Base type for filter rules. Not all available rules are currently implemented.\n */\nexport type FilterRule =\n  | PrefixFilterRule\n  | SuffixFilterRule\n  | AnythingButFilterRule\n  | FilterEqualsIgnoreCase;\n\n/**\n * Rule that a property has to start with a prefix.\n */\nexport interface PrefixFilterRule {\n  readonly prefix: string | FilterEqualsIgnoreCase;\n}\n\n/**\n * Rule that a property has to end with a suffix.\n */\nexport interface SuffixFilterRule {\n  readonly suffix: string | FilterEqualsIgnoreCase;\n}\n\n/**\n * Rule that allows all values except the given ones.\n */\nexport interface AnythingButFilterRule {\n  /**\n   * @jsii ignore\n   */\n  readonly \"anything-but\": string[] | FilterRule;\n}\n\n/**\n * Rule that matches a string, ignoring the case.\n */\nexport interface FilterEqualsIgnoreCase {\n  /**\n   * @jsii ignore\n   */\n  readonly \"equals-ignore-case\": string | string[];\n}\n\n/**\n * A filter for messages in the pipe.\n */\nexport interface PipeFilter {\n  /**\n   * The rules for each attribute of the body.\n   * @jsii ignore\n   */\n  readonly [key: string]: FilterRule[];\n}\n\n/**\n * A wrapper for the L1 event pipe with the ability to deactivate it within the stack.\n */\nexport class EventPipe extends Construct {\n  public readonly role: Role;\n\n  constructor(scope: Construct, id: string, props: EventPipeProps) {\n    super(scope, id);\n\n    let targetStepFunction =\n      \"stepFunction\" in props.target ? props.target.stepFunction : undefined;\n    let targetStepFunctionParameters =\n      \"parameters\" in props.target ? props.target.parameters : undefined;\n\n    let targetQueue = \"queue\" in props.target ? props.target.queue : undefined;\n\n    let sqsTarget = targetQueue !== undefined;\n\n    let targetArn = sqsTarget\n      ? targetQueue!.queueArn\n      : targetStepFunction!.stateMachineArn;\n\n    let desiredState = \"RUNNING\";\n    if (isDeactivatedConstruct(id)) {\n      Annotations.of(this).addInfo(`${id} is set do be deactivated.`);\n      desiredState = \"STOPPED\";\n    }\n\n    this.role =\n      props.role ||\n      new Role(this, \"EventPipeRole\", {\n        assumedBy: new ServicePrincipal(\"pipes.amazonaws.com\"),\n      });\n\n    let filterCriteria = props.filter\n      ? {\n          filters: [\n            {\n              pattern: JSON.stringify({\n                body: {\n                  ...props.filter,\n                },\n              }),\n            },\n          ],\n        }\n      : undefined;\n\n    let targetParameters: CfnPipe.PipeTargetParametersProperty = {};\n    if (targetQueue) {\n      targetParameters = {\n        sqsQueueParameters: {\n          messageGroupId: \"default\",\n        },\n      };\n    } else {\n      targetParameters = {\n        stepFunctionStateMachineParameters: {\n          invocationType: targetStepFunctionParameters?.invocationType\n            ? InvocationType[targetStepFunctionParameters.invocationType]\n            : InvocationType[InvocationType.REQUEST_RESPONSE],\n        },\n        ...(targetStepFunctionParameters?.inputTemplate && {\n          inputTemplate: JSON.stringify(\n            targetStepFunctionParameters.inputTemplate,\n          ),\n        }),\n      };\n    }\n\n    let sourceParameters = {\n      sqsQueueParameters: {\n        batchSize: 1,\n      },\n      ...(filterCriteria && { filterCriteria: filterCriteria }),\n    };\n\n    new CfnPipe(this, \"EventPipe\", {\n      roleArn: this.role.roleArn,\n      source: props.source.queueArn,\n      target: targetArn,\n      sourceParameters: sourceParameters,\n      targetParameters: targetParameters,\n      desiredState: desiredState,\n    });\n\n    props.source.grantConsumeMessages(this.role);\n    targetQueue?.grantSendMessages(this.role);\n    targetStepFunction?.grantStartExecution(this.role);\n  }\n}\n"]}
|
|
@@ -35,5 +35,5 @@ class S3Bucket extends aws_s3_1.Bucket {
|
|
|
35
35
|
}
|
|
36
36
|
exports.S3Bucket = S3Bucket;
|
|
37
37
|
_a = JSII_RTTI_SYMBOL_1;
|
|
38
|
-
S3Bucket[_a] = { fqn: "@btc-embedded/cdk-extensions.S3Bucket", version: "0.9.
|
|
38
|
+
S3Bucket[_a] = { fqn: "@btc-embedded/cdk-extensions.S3Bucket", version: "0.9.6" };
|
|
39
39
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUzNCdWNrZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29uc3RydWN0cy9TM0J1Y2tldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUFtRTtBQUNuRSwrQ0FBeUQ7QUFFekQsb0NBQTRDO0FBRTVDLFNBQVMsV0FBVyxDQUNsQixLQUFnQixFQUNoQixFQUFVLEVBQ1YsS0FBbUI7SUFFbkIsSUFBSSxJQUFBLHdCQUFnQixHQUFFLEVBQUUsQ0FBQztRQUN2Qix5QkFBVyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxPQUFPLENBQzNCLEdBQUcsRUFBRSx5RUFBeUUsQ0FDL0UsQ0FBQztRQUNGLE9BQU87WUFDTCxHQUFHLEtBQUs7WUFDUixhQUFhLEVBQUUsMkJBQWEsQ0FBQyxPQUFPO1lBQ3BDLGlCQUFpQixFQUFFLElBQUk7WUFDdkIsY0FBYyxFQUFFO2dCQUNkO29CQUNFLFVBQVUsRUFBRSxzQkFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7b0JBQzVCLG1DQUFtQyxFQUFFLHNCQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDdEQ7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0lBQ0QsT0FBTyxFQUFFLEdBQUcsS0FBSyxFQUFFLENBQUM7QUFDdEIsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxNQUFhLFFBQVMsU0FBUSxlQUFNO0lBQ2xDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBbUI7UUFDM0QsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsV0FBVyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNsRCxDQUFDOztBQUhILDRCQUlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQW5ub3RhdGlvbnMsIER1cmF0aW9uLCBSZW1vdmFsUG9saWN5IH0gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBCdWNrZXQsIEJ1Y2tldFByb3BzIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1zM1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IGlzRGV2ZWxvcGVyU3RhY2sgfSBmcm9tIFwiLi4vdXRpbHNcIjtcblxuZnVuY3Rpb24gYWRqdXN0UHJvcHMoXG4gIHNjb3BlOiBDb25zdHJ1Y3QsXG4gIGlkOiBzdHJpbmcsXG4gIHByb3BzPzogQnVja2V0UHJvcHMsXG4pOiBCdWNrZXRQcm9wcyB7XG4gIGlmIChpc0RldmVsb3BlclN0YWNrKCkpIHtcbiAgICBBbm5vdGF0aW9ucy5vZihzY29wZSkuYWRkSW5mbyhcbiAgICAgIGAke2lkfSBpcyBkZXBsb3llZCBpbiBhIGRldmVsb3BlciB2YXJpYW50LiBGaWxlcyB3aWxsIGJlIHJldGFpbmVkIGZvciAzIGRheXMuYCxcbiAgICApO1xuICAgIHJldHVybiB7XG4gICAgICAuLi5wcm9wcyxcbiAgICAgIHJlbW92YWxQb2xpY3k6IFJlbW92YWxQb2xpY3kuREVTVFJPWSxcbiAgICAgIGF1dG9EZWxldGVPYmplY3RzOiB0cnVlLFxuICAgICAgbGlmZWN5Y2xlUnVsZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgIGV4cGlyYXRpb246IER1cmF0aW9uLmRheXMoMyksXG4gICAgICAgICAgYWJvcnRJbmNvbXBsZXRlTXVsdGlwYXJ0VXBsb2FkQWZ0ZXI6IER1cmF0aW9uLmRheXMoMSksXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHsgLi4ucHJvcHMgfTtcbn1cblxuLyoqXG4gKiBXcmFwcGVyIGZvciB0aGUge0BsaW5rIEJ1Y2tldH0gY29uc3RydWN0cyB0aGF0IGFkZHMgYWRkaXRpb25hbCBwcm9wZXJ0aWVzLCBpZiBhIGRldmVsb3BlclxuICogc3RhY2sgaXMgZGV0ZWN0ZWQuIFdpbGwgY2F1c2UgZmlsZXMgdG8gZXhwaXJlIGFmdGVyIHRyZWUgZGF5cyBhbmQgYWxsb3dzIHRvIGRlbGV0ZSB0aGVcbiAqIGJ1Y2tldCBhbmQgYWxsIGl0cyBjb250ZW50cywgaWYgdGhlIHN0YWNrIGlzIGRlbGV0ZWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBTM0J1Y2tldCBleHRlbmRzIEJ1Y2tldCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogQnVja2V0UHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQsIGFkanVzdFByb3BzKHNjb3BlLCBpZCwgcHJvcHMpKTtcbiAgfVxufVxuIl19
|
|
@@ -8,7 +8,8 @@ const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
|
|
|
8
8
|
const aws_cognito_1 = require("aws-cdk-lib/aws-cognito");
|
|
9
9
|
const aws_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
10
10
|
const construct_1 = require("constructs/lib/construct");
|
|
11
|
-
const
|
|
11
|
+
const platform_1 = require("../platform");
|
|
12
|
+
const utils_1 = require("../utils");
|
|
12
13
|
/**
|
|
13
14
|
* @deprecated Use {@link SecureRestApiV2} instead
|
|
14
15
|
*/
|
|
@@ -19,12 +20,12 @@ class SecureRestApi extends construct_1.Construct {
|
|
|
19
20
|
if (!props.basePlatformStackName && !props.apiSubDomain) {
|
|
20
21
|
throw new Error("platformStackName and ApiSubDomain is required");
|
|
21
22
|
}
|
|
22
|
-
const cognitoUserPoolId = (0,
|
|
23
|
+
const cognitoUserPoolId = (0, utils_1.importValue)(props.basePlatformStackName, "cognito", "user-pool-id");
|
|
23
24
|
const userPoolRef = aws_cognito_1.UserPool.fromUserPoolId(this, "UserPoolRef", cognitoUserPoolId);
|
|
24
|
-
const
|
|
25
|
+
const { fqdn } = platform_1.Vpc.fromBasePlatform(this, "VpcRef", props.basePlatformStackName);
|
|
25
26
|
const hostedZone = props.hostedZone ??
|
|
26
27
|
aws_route53_1.HostedZone.fromLookup(this, "HostedZone", {
|
|
27
|
-
domainName:
|
|
28
|
+
domainName: fqdn,
|
|
28
29
|
});
|
|
29
30
|
this.domainName = `${props.apiSubDomain}.${hostedZone.zoneName}`;
|
|
30
31
|
this.certificate = new aws_certificatemanager_1.Certificate(this, "Certificate", {
|
|
@@ -50,5 +51,5 @@ class SecureRestApi extends construct_1.Construct {
|
|
|
50
51
|
}
|
|
51
52
|
exports.SecureRestApi = SecureRestApi;
|
|
52
53
|
_a = JSII_RTTI_SYMBOL_1;
|
|
53
|
-
SecureRestApi[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApi", version: "0.9.
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
SecureRestApi[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApi", version: "0.9.6" };
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdHJ1Y3RzL1NlY3VyZVJlc3RBcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrREFJb0M7QUFDcEMsK0VBRzRDO0FBQzVDLHlEQUFtRDtBQUNuRCx5REFBa0U7QUFDbEUsd0RBQXFEO0FBQ3JELDBDQUFrQztBQUNsQyxvQ0FBdUM7QUF1QnZDOztHQUVHO0FBQ0gsTUFBYSxhQUFjLFNBQVEscUJBQVM7SUFRMUMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUF5QjtRQUNqRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLG9CQUFvQjtRQUNwQixJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3hELE1BQU0sSUFBSSxLQUFLLENBQUMsZ0RBQWdELENBQUMsQ0FBQztRQUNwRSxDQUFDO1FBRUQsTUFBTSxpQkFBaUIsR0FBRyxJQUFBLG1CQUFXLEVBQ25DLEtBQUssQ0FBQyxxQkFBcUIsRUFDM0IsU0FBUyxFQUNULGNBQWMsQ0FDZixDQUFDO1FBQ0YsTUFBTSxXQUFXLEdBQUcsc0JBQVEsQ0FBQyxjQUFjLENBQ3pDLElBQUksRUFDSixhQUFhLEVBQ2IsaUJBQWlCLENBQ2xCLENBQUM7UUFFRixNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsY0FBRyxDQUFDLGdCQUFnQixDQUNuQyxJQUFJLEVBQ0osUUFBUSxFQUNSLEtBQUssQ0FBQyxxQkFBcUIsQ0FDNUIsQ0FBQztRQUNGLE1BQU0sVUFBVSxHQUNkLEtBQUssQ0FBQyxVQUFVO1lBQ2hCLHdCQUFVLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUU7Z0JBQ3hDLFVBQVUsRUFBRSxJQUFJO2FBQ2pCLENBQUMsQ0FBQztRQUNMLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxLQUFLLENBQUMsWUFBWSxJQUFJLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUVqRSxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksb0NBQVcsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQ3RELFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixVQUFVLEVBQUUsOENBQXFCLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQztTQUN0RCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSwyQ0FBMEIsQ0FDckQsSUFBSSxFQUNKLG1CQUFtQixFQUNuQjtZQUNFLGdCQUFnQixFQUFFLENBQUMsV0FBVyxDQUFDO1NBQ2hDLENBQ0YsQ0FBQztRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSx3QkFBTyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDMUMsR0FBRyxLQUFLLENBQUMsWUFBWTtZQUNyQixvQkFBb0IsRUFBRTtnQkFDcEIsR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDLG9CQUFvQjtnQkFDMUMsVUFBVSxFQUFFLElBQUksQ0FBQyxpQkFBaUI7YUFDbkM7WUFDRCxVQUFVLEVBQUU7Z0JBQ1YsR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDLFVBQVU7Z0JBQ2hDLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtnQkFDM0IsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO2FBQzlCO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUEvREgsc0NBZ0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIsXG4gIFJlc3RBcGksXG4gIFJlc3RBcGlQcm9wcyxcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1hcGlnYXRld2F5XCI7XG5pbXBvcnQge1xuICBDZXJ0aWZpY2F0ZSxcbiAgQ2VydGlmaWNhdGVWYWxpZGF0aW9uLFxufSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWNlcnRpZmljYXRlbWFuYWdlclwiO1xuaW1wb3J0IHsgVXNlclBvb2wgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWNvZ25pdG9cIjtcbmltcG9ydCB7IEhvc3RlZFpvbmUsIElIb3N0ZWRab25lIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1yb3V0ZTUzXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0cy9saWIvY29uc3RydWN0XCI7XG5pbXBvcnQgeyBWcGMgfSBmcm9tIFwiLi4vcGxhdGZvcm1cIjtcbmltcG9ydCB7IGltcG9ydFZhbHVlIH0gZnJvbSBcIi4uL3V0aWxzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VjdXJlUmVzdEFwaVByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBCYXNlIHBsYXRmb3JtIFN0YWNrXG4gICAqL1xuICByZWFkb25seSBiYXNlUGxhdGZvcm1TdGFja05hbWU6IHN0cmluZztcbiAgLyoqXG4gICAqIFN1YmRvbWFpbiB0aGF0IGlzIHVzZWQgZm9yIFJFU1QgQVBJIHByb3BzXG4gICAqL1xuICByZWFkb25seSBhcGlTdWJEb21haW46IHN0cmluZztcbiAgLyoqXG4gICAqIGhvc3RlZCB6b25lIGZvciB0aGUgc3ViZG9tYWluXG4gICAqIEFuIG9wdGlvbmFsIHBhcmFtZXRlclxuICAgKiBAZGVmYXVsdCAtIGZxZG4gb3V0cHV0IG9mIGJhc2UgcGxhdGZvcm0gc3RhY2sgaXMgdXNlZCB0byBpbXBvcnQgdGhlIGhvc3RlZCB6b25lXG4gICAqL1xuICByZWFkb25seSBob3N0ZWRab25lPzogSUhvc3RlZFpvbmU7XG5cbiAgLyoqXG4gICAqIFByb3BzIGZvcndhcmRlZCB0byB0aGUgUmVzdEFwaSBjb25zdHJ1Y3QuXG4gICAqL1xuICByZWFkb25seSByZXN0QXBpUHJvcHM6IFJlc3RBcGlQcm9wcztcbn1cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIHtAbGluayBTZWN1cmVSZXN0QXBpVjJ9IGluc3RlYWRcbiAqL1xuZXhwb3J0IGNsYXNzIFNlY3VyZVJlc3RBcGkgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAvL3B1YmxpYyByZXN0QXBpRG9tYWluTmFtZTogRG9tYWluTmFtZTtcbiAgcHVibGljIGRvbWFpbk5hbWU6IHN0cmluZztcbiAgcHVibGljIGRlZmF1bHRBdXRob3JpemVyOiBDb2duaXRvVXNlclBvb2xzQXV0aG9yaXplcjtcbiAgcHJpdmF0ZSBjZXJ0aWZpY2F0ZTogQ2VydGlmaWNhdGU7XG5cbiAgcHVibGljIHJlc3RBcGk6IFJlc3RBcGk7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFNlY3VyZVJlc3RBcGlQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG4gICAgLy92YWxpZGF0ZSB0aGUgcHJvcHNcbiAgICBpZiAoIXByb3BzLmJhc2VQbGF0Zm9ybVN0YWNrTmFtZSAmJiAhcHJvcHMuYXBpU3ViRG9tYWluKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJwbGF0Zm9ybVN0YWNrTmFtZSBhbmQgQXBpU3ViRG9tYWluIGlzIHJlcXVpcmVkXCIpO1xuICAgIH1cblxuICAgIGNvbnN0IGNvZ25pdG9Vc2VyUG9vbElkID0gaW1wb3J0VmFsdWUoXG4gICAgICBwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsXG4gICAgICBcImNvZ25pdG9cIixcbiAgICAgIFwidXNlci1wb29sLWlkXCIsXG4gICAgKTtcbiAgICBjb25zdCB1c2VyUG9vbFJlZiA9IFVzZXJQb29sLmZyb21Vc2VyUG9vbElkKFxuICAgICAgdGhpcyxcbiAgICAgIFwiVXNlclBvb2xSZWZcIixcbiAgICAgIGNvZ25pdG9Vc2VyUG9vbElkLFxuICAgICk7XG5cbiAgICBjb25zdCB7IGZxZG4gfSA9IFZwYy5mcm9tQmFzZVBsYXRmb3JtKFxuICAgICAgdGhpcyxcbiAgICAgIFwiVnBjUmVmXCIsXG4gICAgICBwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsXG4gICAgKTtcbiAgICBjb25zdCBob3N0ZWRab25lID1cbiAgICAgIHByb3BzLmhvc3RlZFpvbmUgPz9cbiAgICAgIEhvc3RlZFpvbmUuZnJvbUxvb2t1cCh0aGlzLCBcIkhvc3RlZFpvbmVcIiwge1xuICAgICAgICBkb21haW5OYW1lOiBmcWRuLFxuICAgICAgfSk7XG4gICAgdGhpcy5kb21haW5OYW1lID0gYCR7cHJvcHMuYXBpU3ViRG9tYWlufS4ke2hvc3RlZFpvbmUuem9uZU5hbWV9YDtcblxuICAgIHRoaXMuY2VydGlmaWNhdGUgPSBuZXcgQ2VydGlmaWNhdGUodGhpcywgXCJDZXJ0aWZpY2F0ZVwiLCB7XG4gICAgICBkb21haW5OYW1lOiB0aGlzLmRvbWFpbk5hbWUsXG4gICAgICB2YWxpZGF0aW9uOiBDZXJ0aWZpY2F0ZVZhbGlkYXRpb24uZnJvbURucyhob3N0ZWRab25lKSxcbiAgICB9KTtcblxuICAgIHRoaXMuZGVmYXVsdEF1dGhvcml6ZXIgPSBuZXcgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIoXG4gICAgICB0aGlzLFxuICAgICAgXCJkZWZhdWx0QXV0aG9yaXplclwiLFxuICAgICAge1xuICAgICAgICBjb2duaXRvVXNlclBvb2xzOiBbdXNlclBvb2xSZWZdLFxuICAgICAgfSxcbiAgICApO1xuXG4gICAgdGhpcy5yZXN0QXBpID0gbmV3IFJlc3RBcGkodGhpcywgXCJSZXN0QXBpXCIsIHtcbiAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcyxcbiAgICAgIGRlZmF1bHRNZXRob2RPcHRpb25zOiB7XG4gICAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcy5kZWZhdWx0TWV0aG9kT3B0aW9ucyxcbiAgICAgICAgYXV0aG9yaXplcjogdGhpcy5kZWZhdWx0QXV0aG9yaXplcixcbiAgICAgIH0sXG4gICAgICBkb21haW5OYW1lOiB7XG4gICAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcy5kb21haW5OYW1lLFxuICAgICAgICBkb21haW5OYW1lOiB0aGlzLmRvbWFpbk5hbWUsXG4gICAgICAgIGNlcnRpZmljYXRlOiB0aGlzLmNlcnRpZmljYXRlLFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxufVxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Integration, MethodOptions, RestApiProps } from "aws-cdk-lib/aws-apigateway";
|
|
2
2
|
import { IHostedZone } from "aws-cdk-lib/aws-route53";
|
|
3
3
|
import { Construct } from "constructs/lib/construct";
|
|
4
4
|
export interface SecureRestApiPropsV2 {
|
|
@@ -11,8 +11,9 @@ export interface SecureRestApiPropsV2 {
|
|
|
11
11
|
*/
|
|
12
12
|
readonly apiSubDomain: string;
|
|
13
13
|
/**
|
|
14
|
-
* hosted zone for the subdomain
|
|
14
|
+
* hosted zone for the subdomain.
|
|
15
15
|
* An optional parameter
|
|
16
|
+
*
|
|
16
17
|
* @default - fqdn output of base platform stack is used to import the hosted zone
|
|
17
18
|
*/
|
|
18
19
|
readonly hostedZone?: IHostedZone;
|
|
@@ -22,11 +23,9 @@ export interface SecureRestApiPropsV2 {
|
|
|
22
23
|
readonly restApiProps: RestApiProps;
|
|
23
24
|
}
|
|
24
25
|
export declare class SecureRestApiV2 extends Construct {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
private
|
|
28
|
-
private basePlatformFqdn;
|
|
29
|
-
private restApi;
|
|
26
|
+
private readonly authorizer;
|
|
27
|
+
private readonly fqdn;
|
|
28
|
+
private readonly restApi;
|
|
30
29
|
constructor(scope: Construct, id: string, props: SecureRestApiPropsV2);
|
|
31
30
|
addMethod(httpMethod: string, target?: Integration, options?: MethodOptions): import("aws-cdk-lib/aws-apigateway").Method;
|
|
32
31
|
}
|
|
@@ -5,54 +5,46 @@ exports.SecureRestApiV2 = void 0;
|
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const aws_apigateway_1 = require("aws-cdk-lib/aws-apigateway");
|
|
7
7
|
const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
|
|
8
|
-
const aws_cognito_1 = require("aws-cdk-lib/aws-cognito");
|
|
9
8
|
const aws_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
10
9
|
const construct_1 = require("constructs/lib/construct");
|
|
11
|
-
const
|
|
10
|
+
const platform_1 = require("../platform");
|
|
12
11
|
class SecureRestApiV2 extends construct_1.Construct {
|
|
13
12
|
constructor(scope, id, props) {
|
|
14
13
|
super(scope, id);
|
|
15
|
-
|
|
16
|
-
if (!props.basePlatformStackName && !props.apiSubDomain) {
|
|
17
|
-
throw new Error("platformStackName and ApiSubDomain is required");
|
|
18
|
-
}
|
|
19
|
-
const cognitoUserPoolId = (0, ImportValue_1.importValue)(props.basePlatformStackName, "cognito-v2", "user-pool-id");
|
|
20
|
-
const userPoolRef = aws_cognito_1.UserPool.fromUserPoolId(this, "UserPoolRef", cognitoUserPoolId);
|
|
21
|
-
this.basePlatformFqdn = (0, ImportValue_1.importValue)(props.basePlatformStackName, "fqdn");
|
|
14
|
+
this.fqdn = platform_1.Vpc.fromBasePlatform(this, "VpcRef", props.basePlatformStackName).fqdn;
|
|
22
15
|
const hostedZone = props.hostedZone ??
|
|
23
16
|
aws_route53_1.HostedZone.fromLookup(this, "HostedZone", {
|
|
24
|
-
domainName: this.
|
|
17
|
+
domainName: this.fqdn,
|
|
25
18
|
});
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
domainName
|
|
19
|
+
const domainName = `${props.apiSubDomain}.${hostedZone.zoneName}`;
|
|
20
|
+
const certificate = new aws_certificatemanager_1.Certificate(this, "Certificate", {
|
|
21
|
+
domainName,
|
|
29
22
|
validation: aws_certificatemanager_1.CertificateValidation.fromDns(hostedZone),
|
|
30
23
|
});
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
});
|
|
24
|
+
const cognito = platform_1.CognitoUserPool.fromBasePlatform(this, "Cognito", props.basePlatformStackName);
|
|
25
|
+
this.authorizer = cognito.createCognitoUserPoolsAuthorizer();
|
|
34
26
|
this.restApi = new aws_apigateway_1.RestApi(this, "RestApi", {
|
|
35
27
|
...props.restApiProps,
|
|
36
28
|
defaultMethodOptions: {
|
|
37
29
|
...props.restApiProps.defaultMethodOptions,
|
|
38
|
-
authorizer: this.
|
|
30
|
+
authorizer: this.authorizer,
|
|
39
31
|
},
|
|
40
32
|
domainName: {
|
|
41
33
|
...props.restApiProps.domainName,
|
|
42
|
-
domainName
|
|
43
|
-
certificate
|
|
34
|
+
domainName,
|
|
35
|
+
certificate,
|
|
44
36
|
},
|
|
45
37
|
});
|
|
46
38
|
}
|
|
47
39
|
addMethod(httpMethod, target, options) {
|
|
48
40
|
const authorizationScopes = [`GET`, `HEAD`, `OPTIONS`].includes(httpMethod)
|
|
49
41
|
? [
|
|
50
|
-
`https://api.${this.
|
|
51
|
-
`https://api.${this.
|
|
42
|
+
`https://api.${this.fqdn}/read_api`,
|
|
43
|
+
`https://api.${this.fqdn}/write_api`,
|
|
52
44
|
]
|
|
53
|
-
: [`https://api.${this.
|
|
45
|
+
: [`https://api.${this.fqdn}/write_api`];
|
|
54
46
|
return this.restApi.root.addMethod(httpMethod, target, {
|
|
55
|
-
authorizer: this.
|
|
47
|
+
authorizer: this.authorizer,
|
|
56
48
|
authorizationScopes,
|
|
57
49
|
...options,
|
|
58
50
|
});
|
|
@@ -60,5 +52,5 @@ class SecureRestApiV2 extends construct_1.Construct {
|
|
|
60
52
|
}
|
|
61
53
|
exports.SecureRestApiV2 = SecureRestApiV2;
|
|
62
54
|
_a = JSII_RTTI_SYMBOL_1;
|
|
63
|
-
SecureRestApiV2[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApiV2", version: "0.9.
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
SecureRestApiV2[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApiV2", version: "0.9.6" };
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaVYyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0cnVjdHMvU2VjdXJlUmVzdEFwaVYyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsK0RBTW9DO0FBQ3BDLCtFQUc0QztBQUM1Qyx5REFBa0U7QUFDbEUsd0RBQXFEO0FBQ3JELDBDQUFtRDtBQTJCbkQsTUFBYSxlQUFnQixTQUFRLHFCQUFTO0lBSzVDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMkI7UUFDbkUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsSUFBSSxHQUFHLGNBQUcsQ0FBQyxnQkFBZ0IsQ0FDOUIsSUFBSSxFQUNKLFFBQVEsRUFDUixLQUFLLENBQUMscUJBQXFCLENBQzVCLENBQUMsSUFBSSxDQUFDO1FBRVAsTUFBTSxVQUFVLEdBQ2QsS0FBSyxDQUFDLFVBQVU7WUFDaEIsd0JBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRTtnQkFDeEMsVUFBVSxFQUFFLElBQUksQ0FBQyxJQUFJO2FBQ3RCLENBQUMsQ0FBQztRQUVMLE1BQU0sVUFBVSxHQUFHLEdBQUcsS0FBSyxDQUFDLFlBQVksSUFBSSxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFbEUsTUFBTSxXQUFXLEdBQUcsSUFBSSxvQ0FBVyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUU7WUFDdkQsVUFBVTtZQUNWLFVBQVUsRUFBRSw4Q0FBcUIsQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDO1NBQ3RELENBQUMsQ0FBQztRQUVILE1BQU0sT0FBTyxHQUFHLDBCQUFlLENBQUMsZ0JBQWdCLENBQzlDLElBQUksRUFDSixTQUFTLEVBQ1QsS0FBSyxDQUFDLHFCQUFxQixDQUM1QixDQUFDO1FBRUYsSUFBSSxDQUFDLFVBQVUsR0FBRyxPQUFPLENBQUMsZ0NBQWdDLEVBQUUsQ0FBQztRQUU3RCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksd0JBQU8sQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQzFDLEdBQUcsS0FBSyxDQUFDLFlBQVk7WUFDckIsb0JBQW9CLEVBQUU7Z0JBQ3BCLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxvQkFBb0I7Z0JBQzFDLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTthQUM1QjtZQUNELFVBQVUsRUFBRTtnQkFDVixHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUMsVUFBVTtnQkFDaEMsVUFBVTtnQkFDVixXQUFXO2FBQ1o7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU0sU0FBUyxDQUNkLFVBQWtCLEVBQ2xCLE1BQW9CLEVBQ3BCLE9BQXVCO1FBRXZCLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLFNBQVMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUM7WUFDekUsQ0FBQyxDQUFDO2dCQUNFLGVBQWUsSUFBSSxDQUFDLElBQUksV0FBVztnQkFDbkMsZUFBZSxJQUFJLENBQUMsSUFBSSxZQUFZO2FBQ3JDO1lBQ0gsQ0FBQyxDQUFDLENBQUMsZUFBZSxJQUFJLENBQUMsSUFBSSxZQUFZLENBQUMsQ0FBQztRQUUzQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsTUFBTSxFQUFFO1lBQ3JELFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixtQkFBbUI7WUFDbkIsR0FBRyxPQUFPO1NBQ1gsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUFsRUgsMENBbUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIsXG4gIEludGVncmF0aW9uLFxuICBNZXRob2RPcHRpb25zLFxuICBSZXN0QXBpLFxuICBSZXN0QXBpUHJvcHMsXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7IEhvc3RlZFpvbmUsIElIb3N0ZWRab25lIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1yb3V0ZTUzXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0cy9saWIvY29uc3RydWN0XCI7XG5pbXBvcnQgeyBDb2duaXRvVXNlclBvb2wsIFZwYyB9IGZyb20gXCIuLi9wbGF0Zm9ybVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNlY3VyZVJlc3RBcGlQcm9wc1YyIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBCYXNlIHBsYXRmb3JtIFN0YWNrXG4gICAqL1xuICByZWFkb25seSBiYXNlUGxhdGZvcm1TdGFja05hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogU3ViZG9tYWluIHRoYXQgaXMgdXNlZCBmb3IgUkVTVCBBUEkgcHJvcHNcbiAgICovXG4gIHJlYWRvbmx5IGFwaVN1YkRvbWFpbjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBob3N0ZWQgem9uZSBmb3IgdGhlIHN1YmRvbWFpbi5cbiAgICogQW4gb3B0aW9uYWwgcGFyYW1ldGVyXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gZnFkbiBvdXRwdXQgb2YgYmFzZSBwbGF0Zm9ybSBzdGFjayBpcyB1c2VkIHRvIGltcG9ydCB0aGUgaG9zdGVkIHpvbmVcbiAgICovXG4gIHJlYWRvbmx5IGhvc3RlZFpvbmU/OiBJSG9zdGVkWm9uZTtcblxuICAvKipcbiAgICogUHJvcHMgZm9yd2FyZGVkIHRvIHRoZSBSZXN0QXBpIGNvbnN0cnVjdC5cbiAgICovXG4gIHJlYWRvbmx5IHJlc3RBcGlQcm9wczogUmVzdEFwaVByb3BzO1xufVxuXG5leHBvcnQgY2xhc3MgU2VjdXJlUmVzdEFwaVYyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgcHJpdmF0ZSByZWFkb25seSBhdXRob3JpemVyOiBDb2duaXRvVXNlclBvb2xzQXV0aG9yaXplcjtcbiAgcHJpdmF0ZSByZWFkb25seSBmcWRuOiBzdHJpbmc7XG4gIHByaXZhdGUgcmVhZG9ubHkgcmVzdEFwaTogUmVzdEFwaTtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU2VjdXJlUmVzdEFwaVByb3BzVjIpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5mcWRuID0gVnBjLmZyb21CYXNlUGxhdGZvcm0oXG4gICAgICB0aGlzLFxuICAgICAgXCJWcGNSZWZcIixcbiAgICAgIHByb3BzLmJhc2VQbGF0Zm9ybVN0YWNrTmFtZSxcbiAgICApLmZxZG47XG5cbiAgICBjb25zdCBob3N0ZWRab25lID1cbiAgICAgIHByb3BzLmhvc3RlZFpvbmUgPz9cbiAgICAgIEhvc3RlZFpvbmUuZnJvbUxvb2t1cCh0aGlzLCBcIkhvc3RlZFpvbmVcIiwge1xuICAgICAgICBkb21haW5OYW1lOiB0aGlzLmZxZG4sXG4gICAgICB9KTtcblxuICAgIGNvbnN0IGRvbWFpbk5hbWUgPSBgJHtwcm9wcy5hcGlTdWJEb21haW59LiR7aG9zdGVkWm9uZS56b25lTmFtZX1gO1xuXG4gICAgY29uc3QgY2VydGlmaWNhdGUgPSBuZXcgQ2VydGlmaWNhdGUodGhpcywgXCJDZXJ0aWZpY2F0ZVwiLCB7XG4gICAgICBkb21haW5OYW1lLFxuICAgICAgdmFsaWRhdGlvbjogQ2VydGlmaWNhdGVWYWxpZGF0aW9uLmZyb21EbnMoaG9zdGVkWm9uZSksXG4gICAgfSk7XG5cbiAgICBjb25zdCBjb2duaXRvID0gQ29nbml0b1VzZXJQb29sLmZyb21CYXNlUGxhdGZvcm0oXG4gICAgICB0aGlzLFxuICAgICAgXCJDb2duaXRvXCIsXG4gICAgICBwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsXG4gICAgKTtcblxuICAgIHRoaXMuYXV0aG9yaXplciA9IGNvZ25pdG8uY3JlYXRlQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIoKTtcblxuICAgIHRoaXMucmVzdEFwaSA9IG5ldyBSZXN0QXBpKHRoaXMsIFwiUmVzdEFwaVwiLCB7XG4gICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMsXG4gICAgICBkZWZhdWx0TWV0aG9kT3B0aW9uczoge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZGVmYXVsdE1ldGhvZE9wdGlvbnMsXG4gICAgICAgIGF1dGhvcml6ZXI6IHRoaXMuYXV0aG9yaXplcixcbiAgICAgIH0sXG4gICAgICBkb21haW5OYW1lOiB7XG4gICAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcy5kb21haW5OYW1lLFxuICAgICAgICBkb21haW5OYW1lLFxuICAgICAgICBjZXJ0aWZpY2F0ZSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgYWRkTWV0aG9kKFxuICAgIGh0dHBNZXRob2Q6IHN0cmluZyxcbiAgICB0YXJnZXQ/OiBJbnRlZ3JhdGlvbixcbiAgICBvcHRpb25zPzogTWV0aG9kT3B0aW9ucyxcbiAgKSB7XG4gICAgY29uc3QgYXV0aG9yaXphdGlvblNjb3BlcyA9IFtgR0VUYCwgYEhFQURgLCBgT1BUSU9OU2BdLmluY2x1ZGVzKGh0dHBNZXRob2QpXG4gICAgICA/IFtcbiAgICAgICAgICBgaHR0cHM6Ly9hcGkuJHt0aGlzLmZxZG59L3JlYWRfYXBpYCxcbiAgICAgICAgICBgaHR0cHM6Ly9hcGkuJHt0aGlzLmZxZG59L3dyaXRlX2FwaWAsXG4gICAgICAgIF1cbiAgICAgIDogW2BodHRwczovL2FwaS4ke3RoaXMuZnFkbn0vd3JpdGVfYXBpYF07XG5cbiAgICByZXR1cm4gdGhpcy5yZXN0QXBpLnJvb3QuYWRkTWV0aG9kKGh0dHBNZXRob2QsIHRhcmdldCwge1xuICAgICAgYXV0aG9yaXplcjogdGhpcy5hdXRob3JpemVyLFxuICAgICAgYXV0aG9yaXphdGlvblNjb3BlcyxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -65,5 +65,5 @@ class ApiGatewayExtension extends ecs_service_extensions_1.ServiceExtension {
|
|
|
65
65
|
}
|
|
66
66
|
exports.ApiGatewayExtension = ApiGatewayExtension;
|
|
67
67
|
_a = JSII_RTTI_SYMBOL_1;
|
|
68
|
-
ApiGatewayExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayExtension", version: "0.9.
|
|
68
|
+
ApiGatewayExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayExtension", version: "0.9.6" };
|
|
69
69
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApiGatewayExtension.js","sourceRoot":"","sources":["../../src/extensions/ApiGatewayExtension.ts"],"names":[],"mappings":";;;;;AAAA,uFAGoD;AACpD,mEAQsC;AACtC,2FAAkF;AAClF,6FAA4F;AAC5F,yDAAmE;AACnE,iDAA0D;AAE1D,sDAAsD;AAmBtD;;;GAGG;AACH,MAAa,mBAAoB,SAAQ,yCAAgB;IAGvD;;;OAGG;IACH,YAAY,KAA+B;QACzC,KAAK,CAAC,uBAAuB,CAAC,CAAC;QAC/B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,UAAU,CAAC,OAAoC;QAC7C,MAAM,WAAW,GAAG,IAAA,4BAAc,EAChC,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAC5B,aAAa,CACd,CAAC;QAEF,MAAM,aAAa,GAAG,IAAA,4BAAc,EAClC,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAC5B,SAAS,CACV,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,CAAC;YAC7B,MAAM,IAAI,KAAK,CACb,4DAA4D,CAC7D,CAAC;QACJ,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,CACzD,mBAAmB,CACP,CAAC;QACf,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CACb,iEAAiE,CAClE,CAAC;QACJ,CAAC;QAED,MAAM,OAAO,GAAG,0BAAO,CAAC,qBAAqB,CAC3C,IAAI,CAAC,KAAK,EACV,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,SAAS,EACjC;YACE,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG;YAC3B,SAAS,EAAE,WAAW,CAAC,aAAa,CAAC;SACtC,CACF,CAAC;QAEF,MAAM,OAAO,GAAG,0BAAO,CAAC,qBAAqB,CAC3C,IAAI,CAAC,KAAK,EACV,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,SAAS,EACjC;YACE,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC;SAC7B,CACF,CAAC;QAEF,MAAM,WAAW,GAAG,IAAI,+DAA+B,CACrD,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,6BAA6B,EACrD,OAAO,CAAC,eAAe,EACvB;YACE,MAAM,EAAE,6BAAU,CAAC,GAAG;YACtB,OAAO;YACP,gBAAgB,EAAE,IAAI,mCAAgB,EAAE,CAAC,aAAa,CACpD,+BAAY,CAAC,MAAM,CAAC,sBAAsB,CAAC,CAC5C;SACF,CACF,CAAC;QAEF,MAAM,cAAc,GAAG,4BAAc,CAAC,oBAAoB,CACxD,IAAI,CAAC,KAAK,EACV,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,mBAAmB,EAC3C,aAAa,CAAC,uBAAuB,CAAC,CACvC,CAAC;QAEF,MAAM,iBAAiB,GAAG,4BAAc,CAAC,oBAAoB,CAC3D,IAAI,CAAC,KAAK,EACV,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,mBAAmB,EAC3C,aAAa,CAAC,qBAAqB,CAAC,CACrC,CAAC;QAEF,MAAM,QAAQ,GAAG,sBAAQ,CAAC,cAAc,CACtC,IAAI,CAAC,KAAK,EACV,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,eAAe,EACvC,aAAa,CAAC,cAAc,CAAC,CAC9B,CAAC;QAEF,MAAM,UAAU,GAAG,IAAI,qDAAsB,CAC3C,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,YAAY,EACpC,QAAQ,EACR;YACE,eAAe,EAAE,CAAC,cAAc,EAAE,iBAAiB,CAAC;SACrD,CACF,CAAC;QAEF,IAAI,4BAAS,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,WAAW,EAAE;YAC7D,OAAO;YACP,WAAW;YACX,QAAQ,EAAE,+BAAY,CAAC,IAAI,CACzB,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,WAAW,EAC/B,6BAAU,CAAC,GAAG,CACf;YACD,UAAU;SACX,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,uBAAa,CAAC,cAAc,CACrD,IAAI,CAAC,KAAK,EACV,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,yBAAyB,EACjD,IAAI,CAAC,KAAK,CAAC,eAAe,CAC3B,CAAC;QAEF,kBAAkB,CAAC,WAAW,CAAC,OAAO,CACpC,OAAO,EACP,cAAI,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,EAC/B,gCAAgC,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,CACxD,CAAC;QAEF,MAAM,IAAI,GAAG,IAAA,4BAAc,EAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,CAAC;QAElE,IAAI,CAAC,aAAa,CAAC,MAAM,CACvB,QAAQ,EACR,eAAe,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAC1C,CAAC;IACJ,CAAC;;AAzHH,kDA0HC","sourcesContent":["import {\n  Container,\n  ServiceExtension,\n} from \"@aws-cdk-containers/ecs-service-extensions\";\nimport {\n  HttpApi,\n  HttpMethod,\n  HttpRoute,\n  HttpRouteKey,\n  MappingValue,\n  ParameterMapping,\n  VpcLink,\n} from \"aws-cdk-lib/aws-apigatewayv2\";\nimport { HttpUserPoolAuthorizer } from \"aws-cdk-lib/aws-apigatewayv2-authorizers\";\nimport { HttpServiceDiscoveryIntegration } from \"aws-cdk-lib/aws-apigatewayv2-integrations\";\nimport { UserPool, UserPoolClient } from \"aws-cdk-lib/aws-cognito\";\nimport { Port, SecurityGroup } from \"aws-cdk-lib/aws-ec2\";\nimport { Ec2Service, FargateService } from \"aws-cdk-lib/aws-ecs\";\nimport { createImporter } from \"../utils/ImportValue\";\n\nexport interface ApiGatewayExtensionProps {\n  /**\n   * The prefix for the API Gateway endpoint.\n   */\n  readonly prefix: string;\n\n  /**\n   * The name of the base platform stack.\n   */\n  readonly platformStackName: string;\n\n  /**\n   * The security group ID of the API Gateway which should be allowed to connect to the service.\n   */\n  readonly securityGroupId: string;\n}\n\n/**\n * Configures the service to be reachable via an API Gateway.\n * @deprecated Use {@link HTTPApiExtension} instead\n */\nexport class ApiGatewayExtension extends ServiceExtension {\n  readonly props: ApiGatewayExtensionProps;\n\n  /**\n   *\n   * @param props\n   */\n  constructor(props: ApiGatewayExtensionProps) {\n    super(\"api-gateway-extension\");\n    this.props = props;\n  }\n\n  useService(service: Ec2Service | FargateService): void {\n    const importValue = createImporter(\n      this.props.platformStackName,\n      \"api-gateway\",\n    );\n\n    const importCognito = createImporter(\n      this.props.platformStackName,\n      \"cognito\",\n    );\n\n    if (!service.cloudMapService) {\n      throw new Error(\n        \"This extension requires the CloudMap extension to be added\",\n      );\n    }\n\n    const container = this.parentService.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n    if (!container || !container.trafficPort) {\n      throw new Error(\n        \"Cannot apply API Gateway Extension, no main app container found\",\n      );\n    }\n\n    const vpcLink = VpcLink.fromVpcLinkAttributes(\n      this.scope,\n      `${this.parentService.id}VpcLink`,\n      {\n        vpc: this.parentService.vpc,\n        vpcLinkId: importValue(\"vpc-link-id\"),\n      },\n    );\n\n    const httpApi = HttpApi.fromHttpApiAttributes(\n      this.scope,\n      `${this.parentService.id}HttpApi`,\n      {\n        httpApiId: importValue(\"id\"),\n      },\n    );\n\n    const integration = new HttpServiceDiscoveryIntegration(\n      `${this.parentService.id}ServiceDiscoveryIntegration`,\n      service.cloudMapService,\n      {\n        method: HttpMethod.ANY,\n        vpcLink,\n        parameterMapping: new ParameterMapping().overwritePath(\n          MappingValue.custom(\"/$request.path.proxy\"),\n        ),\n      },\n    );\n\n    const userPoolClient = UserPoolClient.fromUserPoolClientId(\n      this.scope,\n      `${this.parentService.id}ApiUserPoolClient`,\n      importCognito(\"full-access-client-id\"),\n    );\n\n    const appUserPoolClient = UserPoolClient.fromUserPoolClientId(\n      this.scope,\n      `${this.parentService.id}AppUserPoolClient`,\n      importCognito(\"user-pool-client-id\"),\n    );\n\n    const userPool = UserPool.fromUserPoolId(\n      this.scope,\n      `${this.parentService.id}ApiGWUserPool`,\n      importCognito(\"user-pool-id\"),\n    );\n\n    const authorizer = new HttpUserPoolAuthorizer(\n      `${this.parentService.id}Authorizer`,\n      userPool,\n      {\n        userPoolClients: [userPoolClient, appUserPoolClient],\n      },\n    );\n\n    new HttpRoute(this.scope, `${this.parentService.id}HttpRoute`, {\n      httpApi,\n      integration,\n      routeKey: HttpRouteKey.with(\n        `${this.props.prefix}/{proxy+}`,\n        HttpMethod.ANY,\n      ),\n      authorizer,\n    });\n\n    const apiGwSecurityGroup = SecurityGroup.fromLookupById(\n      this.scope,\n      `${this.parentService.id}ApiGatewaySecurityGroup`,\n      this.props.securityGroupId,\n    );\n\n    apiGwSecurityGroup.connections.allowTo(\n      service,\n      Port.tcp(container.trafficPort),\n      `Allow traffic from API GW to ${this.parentService.id}`,\n    );\n\n    const fqdn = createImporter(this.props.platformStackName)(\"fqdn\");\n\n    this.parentService.addURL(\n      \"public\",\n      `https://api.${fqdn}${this.props.prefix}`,\n    );\n  }\n}\n"]}
|
|
@@ -102,5 +102,5 @@ class ApplicationLoadBalancerExtension extends ecs_service_extensions_1.ServiceE
|
|
|
102
102
|
}
|
|
103
103
|
exports.ApplicationLoadBalancerExtension = ApplicationLoadBalancerExtension;
|
|
104
104
|
_a = JSII_RTTI_SYMBOL_1;
|
|
105
|
-
ApplicationLoadBalancerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerExtension", version: "0.9.
|
|
105
|
+
ApplicationLoadBalancerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerExtension", version: "0.9.6" };
|
|
106
106
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApplicationLoadBalancerExtension.js","sourceRoot":"","sources":["../../src/extensions/ApplicationLoadBalancerExtension.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Container,\n  ContainerMutatingHook,\n  Service,\n  ServiceBuild,\n  ServiceExtension,\n} from \"@aws-cdk-containers/ecs-service-extensions\";\nimport { Aws, Duration } from \"aws-cdk-lib\";\nimport {\n  IUserPool,\n  IUserPoolClient,\n  IUserPoolDomain,\n  UserPool,\n  UserPoolClient,\n  UserPoolDomain,\n} from \"aws-cdk-lib/aws-cognito\";\nimport { SecurityGroup } from \"aws-cdk-lib/aws-ec2\";\nimport {\n  ContainerDefinitionOptions,\n  Ec2Service,\n  FargateService,\n} from \"aws-cdk-lib/aws-ecs\";\nimport {\n  ApplicationListener,\n  ApplicationProtocol,\n  ApplicationTargetGroup,\n  IApplicationListener,\n  ListenerAction,\n  ListenerCondition,\n  UnauthenticatedAction,\n} from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\nimport { AuthenticateCognitoAction } from \"aws-cdk-lib/aws-elasticloadbalancingv2-actions\";\nimport { Construct } from \"constructs\";\nimport { createImporter, importValue } from \"../utils/ImportValue\";\n\nexport interface ApplicationLoadBalancerExtensionProps {\n  readonly platformStackName: string;\n  readonly userPoolClientSecret: string;\n  readonly securityGroupId: string;\n  readonly clientScope: string;\n  readonly healtCheckPath?: string;\n  readonly path?: string; // path to redirect the client after successful authentication\n}\n\ninterface OidcVarsHookProps {\n  readonly issuerUrl: string;\n  readonly clientId: string;\n  readonly clientSecret: string;\n  readonly clientScope: string;\n  readonly redirectUri: string;\n}\n\nclass AddOidcVarsHook extends ContainerMutatingHook {\n  readonly props: OidcVarsHookProps;\n  constructor(props: OidcVarsHookProps) {\n    super();\n    this.props = props;\n  }\n\n  mutateContainerDefinition(\n    props: ContainerDefinitionOptions,\n  ): ContainerDefinitionOptions {\n    return {\n      ...props,\n      environment: {\n        ...props.environment,\n        OIDC_ISSUER_URL: this.props.issuerUrl,\n        OIDC_CLIENT_ID: this.props.clientId,\n        OIDC_CLIENT_SECRET: this.props.clientSecret,\n        OIDC_POST_LOGOUT_REDIRECT_URI: this.props.redirectUri,\n        OIDC_SCOPE: this.props.clientScope,\n      },\n    };\n  }\n}\n/**\n * @deprecated Use {@link ApplicationLoadBalancerExtensionV2} instead\n */\nexport class ApplicationLoadBalancerExtension extends ServiceExtension {\n  private listener!: IApplicationListener;\n  private readonly props: ApplicationLoadBalancerExtensionProps;\n\n  userPool!: IUserPool;\n  userPoolClient!: IUserPoolClient;\n  userPoolDomain!: IUserPoolDomain;\n\n  readonly fqdn: string;\n\n  constructor(props: ApplicationLoadBalancerExtensionProps) {\n    super(\"application-load-balancer\");\n    this.props = props;\n    this.fqdn = importValue(this.props.platformStackName, \"fqdn\");\n  }\n\n  addHooks(): void {\n    const container = this.parentService.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n\n    if (!container || !container.trafficPort) {\n      throw new Error(\n        \"Cannot apply ALB Extension, no main app container found\",\n      );\n    }\n\n    container.addContainerMutatingHook(\n      new AddOidcVarsHook({\n        clientId: this.userPoolClient.userPoolClientId,\n        clientSecret: this.props.userPoolClientSecret,\n        clientScope: this.props.clientScope,\n        issuerUrl: `https://cognito-idp.${Aws.REGION}.amazonaws.com/${this.userPool.userPoolId}`,\n        redirectUri: `https://${this.fqdn}${this.props.path ?? \"\"}`,\n      }),\n    );\n  }\n\n  prehook(service: Service, scope: Construct): void {\n    this.parentService = service;\n    this.scope = scope;\n\n    const importCognitoValue = createImporter(\n      this.props.platformStackName,\n      \"cognito\",\n    );\n\n    const albListenerArn = importValue(\n      this.props.platformStackName,\n      \"alb\",\n      \"listener-arn\",\n    );\n\n    this.listener = ApplicationListener.fromApplicationListenerAttributes(\n      scope,\n      `${this.parentService.id}Listener`,\n      {\n        listenerArn: albListenerArn,\n        securityGroup: SecurityGroup.fromLookupById(\n          scope,\n          `${this.parentService.id}ALBSecurityGroup`,\n          this.props.securityGroupId,\n        ),\n      },\n    );\n\n    this.userPool = UserPool.fromUserPoolId(\n      this.scope,\n      `${this.parentService.id}ALBUserPool`,\n      importCognitoValue(\"user-pool-id\"),\n    );\n\n    this.userPoolClient = UserPoolClient.fromUserPoolClientId(\n      this.scope,\n      `${this.parentService.id}UserPoolClient`,\n      importCognitoValue(\"user-pool-client-id\"),\n    );\n\n    this.userPoolDomain = UserPoolDomain.fromDomainName(\n      this.scope,\n      `${this.parentService.id}UserPoolDomain`,\n      importCognitoValue(\"domain-prefix\"),\n    );\n  }\n\n  modifyServiceProps(props: ServiceBuild): ServiceBuild {\n    return {\n      ...props,\n      healthCheckGracePeriod: Duration.minutes(1),\n    } satisfies ServiceBuild;\n  }\n\n  public useService(service: Ec2Service | FargateService): void {\n    const container = this.parentService.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n    if (!container || !container.trafficPort) {\n      throw new Error(\n        \"Cannot apply ALB Extension, no main app container found\",\n      );\n    }\n\n    const targetGroup = new ApplicationTargetGroup(\n      this.parentService,\n      `${this.parentService.id}TargetGroup`,\n      {\n        vpc: this.parentService.vpc,\n        port: container.trafficPort,\n        protocol: ApplicationProtocol.HTTP,\n        deregistrationDelay: Duration.seconds(10),\n        targets: [service],\n        healthCheck: {\n          path: this.props.healtCheckPath,\n        },\n      },\n    );\n\n    this.listener.addAction(`${this.parentService.id}Action`, {\n      priority: 55,\n      conditions: [ListenerCondition.hostHeaders([this.fqdn])],\n      action: new AuthenticateCognitoAction({\n        userPool: this.userPool,\n        userPoolClient: this.userPoolClient,\n        userPoolDomain: this.userPoolDomain,\n        next: ListenerAction.forward([targetGroup]),\n        onUnauthenticatedRequest: UnauthenticatedAction.AUTHENTICATE,\n      }),\n    });\n\n    this.parentService.targetGroup = targetGroup;\n    this.parentService.addURL(\"public\", `https://${this.fqdn}`);\n  }\n}\n"]}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { Service, ServiceBuild, ServiceExtension } from "@aws-cdk-containers/ecs-service-extensions";
|
|
2
|
-
import {
|
|
2
|
+
import { IUserPoolClient } from "aws-cdk-lib/aws-cognito";
|
|
3
3
|
import { Ec2Service, FargateService } from "aws-cdk-lib/aws-ecs";
|
|
4
4
|
import { Construct } from "constructs";
|
|
5
|
+
import { ICognitoUserPool } from "../platform";
|
|
5
6
|
export interface ApplicationLoadBalancerExtensionPropsV2 {
|
|
6
7
|
readonly platformStackName: string;
|
|
7
8
|
readonly userPoolClientSecret: string;
|
|
@@ -12,10 +13,9 @@ export interface ApplicationLoadBalancerExtensionPropsV2 {
|
|
|
12
13
|
}
|
|
13
14
|
export declare class ApplicationLoadBalancerExtensionV2 extends ServiceExtension {
|
|
14
15
|
private readonly props;
|
|
15
|
-
|
|
16
|
+
cognitoUserPool: ICognitoUserPool;
|
|
16
17
|
userPoolClient: IUserPoolClient;
|
|
17
|
-
|
|
18
|
-
readonly fqdn: string;
|
|
18
|
+
fqdn: string;
|
|
19
19
|
constructor(props: ApplicationLoadBalancerExtensionPropsV2);
|
|
20
20
|
addHooks(): void;
|
|
21
21
|
prehook(service: Service, scope: Construct): void;
|