@btc-embedded/cdk-extensions 0.14.13 → 0.14.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +464 -19
- package/API.md +399 -6
- package/CHANGELOG.md +18 -0
- package/lib/constructs/EventPipe.js +1 -1
- package/lib/constructs/S3Bucket.js +1 -1
- package/lib/constructs/SecureRestApi.js +1 -1
- package/lib/constructs/SecureRestApiV2.js +1 -1
- package/lib/extensions/ApiGatewayExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +1 -1
- package/lib/extensions/CloudMapExtension.js +1 -1
- package/lib/extensions/DeactivatableServiceExtension.js +1 -1
- package/lib/extensions/DocumentDbAccessExtension.js +1 -1
- package/lib/extensions/DomainEventMessagingExtension.js +1 -1
- package/lib/extensions/EfsMountExtension.d.ts +3 -21
- package/lib/extensions/EfsMountExtension.js +8 -41
- package/lib/extensions/ExtraContainerExtension.js +1 -1
- package/lib/extensions/HTTPApiExtension.js +1 -1
- 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.js +2 -2
- package/lib/platform/ApplicationLoadBalancer.js +1 -1
- package/lib/platform/ApplicationLoadBalancerV2.js +2 -2
- package/lib/platform/BTCLogGroup.js +1 -1
- package/lib/platform/CognitoUserPool.js +2 -2
- package/lib/platform/DefaultUserPoolClients.js +1 -1
- package/lib/platform/DocumentDB.js +2 -2
- package/lib/platform/EfsFileSystem.d.ts +105 -0
- package/lib/platform/EfsFileSystem.js +146 -0
- package/lib/platform/PrivateDnsNamespace.js +1 -1
- package/lib/platform/ResourceServer.js +1 -1
- package/lib/platform/Vpc.js +1 -1
- package/lib/platform/index.d.ts +4 -3
- package/lib/platform/index.js +5 -4
- package/lib/utils/StackParameter.js +1 -1
- package/package.json +1 -1
|
@@ -82,5 +82,5 @@ class DefaultUserPoolClients extends constructs_1.Construct {
|
|
|
82
82
|
}
|
|
83
83
|
exports.DefaultUserPoolClients = DefaultUserPoolClients;
|
|
84
84
|
_a = JSII_RTTI_SYMBOL_1;
|
|
85
|
-
DefaultUserPoolClients[_a] = { fqn: "@btc-embedded/cdk-extensions.DefaultUserPoolClients", version: "0.14.
|
|
85
|
+
DefaultUserPoolClients[_a] = { fqn: "@btc-embedded/cdk-extensions.DefaultUserPoolClients", version: "0.14.15" };
|
|
86
86
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DefaultUserPoolClients.js","sourceRoot":"","sources":["../../src/platform/DefaultUserPoolClients.ts"],"names":[],"mappings":";;;;;AAAA,yDAQiC;AACjC,2CAAuC;AACvC,oCAA0C;AAiD1C;;;GAGG;AACH,MAAa,sBAAuB,SAAQ,sBAAS;IAInD,YACE,KAAgB,EAChB,EAAU,EACV,KAAkC;QAElC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,cAAc,GAAG,IAAI,iCAAmB,CAAC;YAC7C,SAAS,EAAE,YAAY;YACvB,gBAAgB,EAAE,4BAA4B;SAC/C,CAAC,CAAC;QAEH,MAAM,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC,iBAAiB,CAAC,uBAAuB,EAAE;YACvE,UAAU,EAAE,GAAG,EAAE,SAAS;YAC1B,MAAM,EAAE,CAAC,cAAc,CAAC;SACzB,CAAC,CAAC;QAEH,MAAM,aAAa,GACjB,KAAK,CAAC,kCAAkC,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CACrD,4CAA8B,CAAC,MAAM,CAAC,IAAI,CAAC,CAC5C,IAAI,EAAE,CAAC;QAEV,MAAM,YAAY,GAAG,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC;QAE9C,IAAI,CAAC,SAAS,GAAG,IAAI,4BAAc,CAAC,IAAI,EAAE,uBAAuB,EAAE;YACjE,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,cAAc,EAAE,IAAI;YACpB,KAAK,EAAE;gBACL,KAAK,EAAE;oBACL,iBAAiB,EAAE,IAAI;iBACxB;gBACD,MAAM,EAAE,CAAC,wBAAU,CAAC,cAAc,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;aAC5D;YACD,0BAA0B,EAAE;gBAC1B,4CAA8B,CAAC,OAAO;gBACtC,GAAG,aAAa;aACjB;YACD,GAAG,KAAK,CAAC,gBAAgB;SAC1B,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,GAAG,IAAI,4BAAc,CAAC,IAAI,EAAE,wBAAwB,EAAE;YACvE,QAAQ,EAAE,KAAK,CAAC,QAAQ;YAExB,qDAAqD;YACrD,cAAc,EAAE,IAAI;YACpB,SAAS,EAAE;gBACT,YAAY,EAAE,IAAI;aACnB;YAED,KAAK,EAAE;gBACL,KAAK,EAAE;oBACL,sBAAsB,EAAE,IAAI;iBAC7B;gBACD,MAAM,EAAE;oBACN,wBAAU,CAAC,MAAM;oBACjB,wBAAU,CAAC,OAAO;oBAClB,GAAG,CAAC,KAAK,CAAC,mBAAmB,IAAI,EAAE,CAAC;iBACrC;gBACD,YAAY,EAAE;oBACZ,2BAA2B;oBAC3B,WAAW,KAAK,CAAC,IAAI,qBAAqB;oBAC1C,GAAG,YAAY;iBAChB;gBACD,UAAU,EAAE,KAAK,CAAC,UAAU;aAC7B;YACD,0BAA0B,EAAE;gBAC1B,4CAA8B,CAAC,OAAO;gBACtC,GAAG,aAAa;aACjB;YACD,GAAG,KAAK,CAAC,qBAAqB;SAC/B,CAAC,CAAC;QAEH,MAAM,WAAW,GAAG,IAAA,sBAAc,EAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QAEpD,WAAW,CAAC;YACV,IAAI,EAAE,+BAA+B;YACrC,GAAG,EAAE,uBAAuB;YAC5B,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,gBAAgB;SACvC,CAAC,CAAC;QAEH,WAAW,CAAC;YACV,IAAI,EAAE,6BAA6B;YACnC,GAAG,EAAE,qBAAqB;YAC1B,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,gBAAgB;SAC5C,CAAC,CAAC;IACL,CAAC;;AAzFH,wDA0FC","sourcesContent":["import {\n  IUserPool,\n  IUserPoolClient,\n  OAuthScope,\n  ResourceServerScope,\n  UserPoolClient,\n  UserPoolClientIdentityProvider,\n  UserPoolClientOptions,\n} from \"aws-cdk-lib/aws-cognito\";\nimport { Construct } from \"constructs\";\nimport { createExporter } from \"../utils\";\n\nexport interface DefaultUserPoolClientsProps {\n  /**\n   * The user pool which should be attached to the clients.\n   */\n  readonly userPool: IUserPool;\n\n  /**\n   * The fully qualified domain name which the ALB will listen to.\n   *\n   * This setting is used to configure the correct callback URL for user pool\n   * client such that the ALB can perform authentication.\n   *\n   */\n  readonly fqdn: string;\n\n  /**\n   * Specify valid logout URLs which should be added to the frontend user pool client.\n   */\n  readonly logoutUrls?: string[];\n\n  /**\n   * Specify additional callback URLs which the frontend uses for OIDC authentication.\n   *\n   */\n  readonly callbackUrls?: string[];\n\n  /**\n   * Specify additional user pool identity providers to enable federated login.\n   */\n  readonly additonalUserPoolIdentityProviders?: string[];\n\n  /**\n   * Client options for the API client, extending and overwriting the defaults.\n   */\n  readonly apiClientOptions?: UserPoolClientOptions;\n\n  /**\n   * Client options for the frontend client, extending and overwriting the defaults.\n   */\n  readonly frontendClientOptions?: UserPoolClientOptions;\n\n  /**\n   * Additional OAuth scopes for the frontend.\n   */\n  readonly frontendOAuthScopes?: OAuthScope[];\n}\n\n/**\n * Create default user pool clients for the frontend and API access.\n * @deprecated Use {@link CognitoUserPool}  instead\n */\nexport class DefaultUserPoolClients extends Construct {\n  public frontendClient: IUserPoolClient;\n  public apiClient: IUserPoolClient;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: DefaultUserPoolClientsProps,\n  ) {\n    super(scope, id);\n\n    const apiAccessScope = new ResourceServerScope({\n      scopeName: \"api_access\",\n      scopeDescription: \"REST API full access scope\",\n    });\n\n    const server = props.userPool.addResourceServer(\"RESTAPIResourceServer\", {\n      identifier: `${id}RESTAPI`,\n      scopes: [apiAccessScope],\n    });\n\n    const providerNames =\n      props.additonalUserPoolIdentityProviders?.map((name) =>\n        UserPoolClientIdentityProvider.custom(name),\n      ) ?? [];\n\n    const callbackUrls = props.callbackUrls ?? [];\n\n    this.apiClient = new UserPoolClient(this, \"RESTAPIUserPoolClient\", {\n      userPool: props.userPool,\n      generateSecret: true,\n      oAuth: {\n        flows: {\n          clientCredentials: true,\n        },\n        scopes: [OAuthScope.resourceServer(server, apiAccessScope)],\n      },\n      supportedIdentityProviders: [\n        UserPoolClientIdentityProvider.COGNITO,\n        ...providerNames,\n      ],\n      ...props.apiClientOptions,\n    });\n\n    this.frontendClient = new UserPoolClient(this, \"FrontendUserPoolClient\", {\n      userPool: props.userPool,\n\n      // Required minimal configuration for use with an ELB\n      generateSecret: true,\n      authFlows: {\n        userPassword: true,\n      },\n\n      oAuth: {\n        flows: {\n          authorizationCodeGrant: true,\n        },\n        scopes: [\n          OAuthScope.OPENID,\n          OAuthScope.PROFILE,\n          ...(props.frontendOAuthScopes ?? []),\n        ],\n        callbackUrls: [\n          // add callback URL for ALB\n          `https://${props.fqdn}/oauth2/idpresponse`,\n          ...callbackUrls,\n        ],\n        logoutUrls: props.logoutUrls,\n      },\n      supportedIdentityProviders: [\n        UserPoolClientIdentityProvider.COGNITO,\n        ...providerNames,\n      ],\n      ...props.frontendClientOptions,\n    });\n\n    const exportValue = createExporter(this, \"cognito\");\n\n    exportValue({\n      name: \"Cognito Full Access Client Id\",\n      key: \"full-access-client-id\",\n      value: this.apiClient.userPoolClientId,\n    });\n\n    exportValue({\n      name: \"Cognito User Pool Client Id\",\n      key: \"user-pool-client-id\",\n      value: this.frontendClient.userPoolClientId,\n    });\n  }\n}\n"]}
|
|
@@ -16,7 +16,7 @@ class DocumentDBBase extends constructs_1.Construct {
|
|
|
16
16
|
}
|
|
17
17
|
exports.DocumentDBBase = DocumentDBBase;
|
|
18
18
|
_a = JSII_RTTI_SYMBOL_1;
|
|
19
|
-
DocumentDBBase[_a] = { fqn: "@btc-embedded/cdk-extensions.DocumentDBBase", version: "0.14.
|
|
19
|
+
DocumentDBBase[_a] = { fqn: "@btc-embedded/cdk-extensions.DocumentDBBase", version: "0.14.15" };
|
|
20
20
|
class DocumentDB extends constructs_1.Construct {
|
|
21
21
|
static fromBasePlatform(scope, id, name) {
|
|
22
22
|
class Import extends DocumentDBBase {
|
|
@@ -52,7 +52,7 @@ class DocumentDB extends constructs_1.Construct {
|
|
|
52
52
|
}
|
|
53
53
|
exports.DocumentDB = DocumentDB;
|
|
54
54
|
_b = JSII_RTTI_SYMBOL_1;
|
|
55
|
-
DocumentDB[_b] = { fqn: "@btc-embedded/cdk-extensions.DocumentDB", version: "0.14.
|
|
55
|
+
DocumentDB[_b] = { fqn: "@btc-embedded/cdk-extensions.DocumentDB", version: "0.14.15" };
|
|
56
56
|
DocumentDB.securityGroupIdParameter = new utils_1.StackParameter({
|
|
57
57
|
prefix: "document-db",
|
|
58
58
|
name: "DocumentDB Security Group Id",
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { RemovalPolicy } from "aws-cdk-lib";
|
|
2
|
+
import { IConnectable, ISecurityGroup, IVpc } from "aws-cdk-lib/aws-ec2";
|
|
3
|
+
import { IFileSystem } from "aws-cdk-lib/aws-efs";
|
|
4
|
+
import { IRole } from "aws-cdk-lib/aws-iam";
|
|
5
|
+
import { Construct } from "constructs";
|
|
6
|
+
export interface EfsFileSystemProps {
|
|
7
|
+
/**
|
|
8
|
+
* The VPC to be used.
|
|
9
|
+
*/
|
|
10
|
+
readonly vpc: IVpc;
|
|
11
|
+
/**
|
|
12
|
+
* The name to be used for the filesystem. Has to be unique in the stack.
|
|
13
|
+
* Is also used for importing the filesystem from another stack.
|
|
14
|
+
*/
|
|
15
|
+
readonly name: string;
|
|
16
|
+
/**
|
|
17
|
+
* Enable automatic backups. Default: `false`.
|
|
18
|
+
*/
|
|
19
|
+
readonly automaticBackups?: boolean;
|
|
20
|
+
/**
|
|
21
|
+
* Removal policy. Default: {@link RemovalPolicy.DESTROY}.
|
|
22
|
+
*/
|
|
23
|
+
readonly removalPolicy?: RemovalPolicy;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Access modes for the Efs.
|
|
27
|
+
*/
|
|
28
|
+
export declare enum EfsAccessMode {
|
|
29
|
+
/**
|
|
30
|
+
* Access is read-only.
|
|
31
|
+
*/
|
|
32
|
+
READ_ONLY = 0,
|
|
33
|
+
/**
|
|
34
|
+
* Read-write access.
|
|
35
|
+
*/
|
|
36
|
+
READ_WRITE = 1,
|
|
37
|
+
/**
|
|
38
|
+
* Root access is granted (includes read-write access).
|
|
39
|
+
*/
|
|
40
|
+
ROOT_ACCESS = 2
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Implementation fo the base functions for the {@link EfsFileSystem}.
|
|
44
|
+
*/
|
|
45
|
+
declare abstract class EfsFileSystemBase extends Construct {
|
|
46
|
+
protected filesystem: IFileSystem;
|
|
47
|
+
protected securityGroup: ISecurityGroup;
|
|
48
|
+
grantAccess(grantee: IRole, accessMode: EfsAccessMode): void;
|
|
49
|
+
fileSystemId(): string;
|
|
50
|
+
fileSystem(): IFileSystem;
|
|
51
|
+
allowConnection(grantee: IConnectable): void;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Lookup options for importing a filesystem from the base stack.
|
|
55
|
+
*/
|
|
56
|
+
export interface EfsFileSystemLookupOptions {
|
|
57
|
+
/**
|
|
58
|
+
* The name of the base platform.
|
|
59
|
+
*/
|
|
60
|
+
readonly basePlatformName: string;
|
|
61
|
+
/**
|
|
62
|
+
* The name of the filesystem to be imported.
|
|
63
|
+
*/
|
|
64
|
+
readonly filesystemName: string;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Interface for the {@link EfsFileSystem}.
|
|
68
|
+
*/
|
|
69
|
+
export interface IEfsFileSystem {
|
|
70
|
+
/**
|
|
71
|
+
* Grant access to a role for the filesystem.
|
|
72
|
+
* @param grantee The role to grant access for.
|
|
73
|
+
* @param accessMode The access mode for the grantee.
|
|
74
|
+
*/
|
|
75
|
+
grantAccess(grantee: IRole, accessMode: EfsAccessMode): void;
|
|
76
|
+
/**
|
|
77
|
+
* Allow connection to the filesystem.
|
|
78
|
+
* @param grantee The component to allow connections for.
|
|
79
|
+
*/
|
|
80
|
+
allowConnection(grantee: IConnectable): void;
|
|
81
|
+
/**
|
|
82
|
+
* Get the ID of the underlying EFS filesystem.
|
|
83
|
+
*/
|
|
84
|
+
fileSystemId(): string;
|
|
85
|
+
/**
|
|
86
|
+
* Get the underlying EFS filesystem.
|
|
87
|
+
*/
|
|
88
|
+
fileSystem(): IFileSystem;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* An EFS filesystem implementation that wraps the filesystem and the security group
|
|
92
|
+
* and allows to import an EFS from a different stack.
|
|
93
|
+
*/
|
|
94
|
+
export declare class EfsFileSystem extends EfsFileSystemBase implements IEfsFileSystem {
|
|
95
|
+
/**
|
|
96
|
+
* Import an existing filesystem from the base platform stack.
|
|
97
|
+
* @param scope The scope of the element.
|
|
98
|
+
* @param id The id of the imported component.
|
|
99
|
+
* @param basePlatformLookup Lookup parameters to find the filesystem.
|
|
100
|
+
* @returns An instance of the {@link IEfsFileSystem}.
|
|
101
|
+
*/
|
|
102
|
+
static fromBasePlatform(scope: Construct, id: string, basePlatformLookup: EfsFileSystemLookupOptions): IEfsFileSystem;
|
|
103
|
+
constructor(scope: Construct, id: string, props: EfsFileSystemProps);
|
|
104
|
+
}
|
|
105
|
+
export {};
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.EfsFileSystem = exports.EfsAccessMode = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
|
+
const aws_ec2_1 = require("aws-cdk-lib/aws-ec2");
|
|
8
|
+
const aws_efs_1 = require("aws-cdk-lib/aws-efs");
|
|
9
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
10
|
+
const constructs_1 = require("constructs");
|
|
11
|
+
const utils_1 = require("../utils");
|
|
12
|
+
const common_1 = require("../utils/common");
|
|
13
|
+
/**
|
|
14
|
+
* Access modes for the Efs.
|
|
15
|
+
*/
|
|
16
|
+
var EfsAccessMode;
|
|
17
|
+
(function (EfsAccessMode) {
|
|
18
|
+
/**
|
|
19
|
+
* Access is read-only.
|
|
20
|
+
*/
|
|
21
|
+
EfsAccessMode[EfsAccessMode["READ_ONLY"] = 0] = "READ_ONLY";
|
|
22
|
+
/**
|
|
23
|
+
* Read-write access.
|
|
24
|
+
*/
|
|
25
|
+
EfsAccessMode[EfsAccessMode["READ_WRITE"] = 1] = "READ_WRITE";
|
|
26
|
+
/**
|
|
27
|
+
* Root access is granted (includes read-write access).
|
|
28
|
+
*/
|
|
29
|
+
EfsAccessMode[EfsAccessMode["ROOT_ACCESS"] = 2] = "ROOT_ACCESS";
|
|
30
|
+
})(EfsAccessMode || (exports.EfsAccessMode = EfsAccessMode = {}));
|
|
31
|
+
/**
|
|
32
|
+
* Implementation fo the base functions for the {@link EfsFileSystem}.
|
|
33
|
+
*/
|
|
34
|
+
class EfsFileSystemBase extends constructs_1.Construct {
|
|
35
|
+
grantAccess(grantee, accessMode) {
|
|
36
|
+
const actions = ["elasticfilesystem:ClientMount"];
|
|
37
|
+
switch (accessMode) {
|
|
38
|
+
case EfsAccessMode.READ_ONLY:
|
|
39
|
+
this.filesystem.grantRead(grantee);
|
|
40
|
+
break;
|
|
41
|
+
case EfsAccessMode.READ_WRITE:
|
|
42
|
+
this.filesystem.grantReadWrite(grantee);
|
|
43
|
+
actions.push("elasticfilesystem:ClientWrite");
|
|
44
|
+
break;
|
|
45
|
+
case EfsAccessMode.ROOT_ACCESS:
|
|
46
|
+
this.filesystem.grantRootAccess(grantee);
|
|
47
|
+
actions.push("elasticfilesystem:ClientWrite");
|
|
48
|
+
actions.push("elasticfilesystem:ClientRootAccess");
|
|
49
|
+
break;
|
|
50
|
+
}
|
|
51
|
+
this.filesystem.addToResourcePolicy(new aws_iam_1.PolicyStatement({
|
|
52
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
53
|
+
actions: actions,
|
|
54
|
+
principals: [new aws_iam_1.ArnPrincipal(grantee.roleArn)],
|
|
55
|
+
conditions: {
|
|
56
|
+
Bool: {
|
|
57
|
+
"elasticfilesystem:AccessedViaMountTarget": "true",
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
}));
|
|
61
|
+
}
|
|
62
|
+
fileSystemId() {
|
|
63
|
+
return this.filesystem.fileSystemId;
|
|
64
|
+
}
|
|
65
|
+
fileSystem() {
|
|
66
|
+
return this.filesystem;
|
|
67
|
+
}
|
|
68
|
+
allowConnection(grantee) {
|
|
69
|
+
this.filesystem.connections.allowDefaultPortFrom(grantee);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* An EFS filesystem implementation that wraps the filesystem and the security group
|
|
74
|
+
* and allows to import an EFS from a different stack.
|
|
75
|
+
*/
|
|
76
|
+
class EfsFileSystem extends EfsFileSystemBase {
|
|
77
|
+
/**
|
|
78
|
+
* Import an existing filesystem from the base platform stack.
|
|
79
|
+
* @param scope The scope of the element.
|
|
80
|
+
* @param id The id of the imported component.
|
|
81
|
+
* @param basePlatformLookup Lookup parameters to find the filesystem.
|
|
82
|
+
* @returns An instance of the {@link IEfsFileSystem}.
|
|
83
|
+
*/
|
|
84
|
+
static fromBasePlatform(scope, id, basePlatformLookup) {
|
|
85
|
+
const stackPrefix = `efs-filesystem-${(0, common_1.kebabCase)(basePlatformLookup.filesystemName)}`;
|
|
86
|
+
const filesystemFsId = new utils_1.StackParameter({
|
|
87
|
+
prefix: stackPrefix,
|
|
88
|
+
key: "filesystem",
|
|
89
|
+
name: "EFS FileSystem",
|
|
90
|
+
}).import(basePlatformLookup.basePlatformName);
|
|
91
|
+
const filesystemSgId = new utils_1.StackParameter({
|
|
92
|
+
prefix: stackPrefix,
|
|
93
|
+
key: "security-group",
|
|
94
|
+
name: "EFS Security Group",
|
|
95
|
+
}).import(basePlatformLookup.basePlatformName);
|
|
96
|
+
const securityGroup = aws_ec2_1.SecurityGroup.fromSecurityGroupId(scope, `${id}SecurityGroup`, filesystemSgId);
|
|
97
|
+
const filesystem = aws_efs_1.FileSystem.fromFileSystemAttributes(scope, `${id}FileSystem`, {
|
|
98
|
+
securityGroup: securityGroup,
|
|
99
|
+
fileSystemId: filesystemFsId,
|
|
100
|
+
});
|
|
101
|
+
class Import extends EfsFileSystemBase {
|
|
102
|
+
constructor(parentScope, constructId) {
|
|
103
|
+
super(parentScope, constructId);
|
|
104
|
+
this.securityGroup = securityGroup;
|
|
105
|
+
this.filesystem = filesystem;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return new Import(scope, id);
|
|
109
|
+
}
|
|
110
|
+
constructor(scope, id, props) {
|
|
111
|
+
super(scope, id);
|
|
112
|
+
this.securityGroup = new aws_ec2_1.SecurityGroup(this, "ResourceEfsSg", {
|
|
113
|
+
vpc: props.vpc,
|
|
114
|
+
});
|
|
115
|
+
/*
|
|
116
|
+
* The security group is mandatory, if we want to import the filesystem from a
|
|
117
|
+
* different stack. We allow all incoming NFS connections, the access will be
|
|
118
|
+
* managed via {@link allowConnection}.
|
|
119
|
+
*/
|
|
120
|
+
this.securityGroup.addIngressRule(aws_ec2_1.Peer.anyIpv4(), aws_ec2_1.Port.NFS, "Allow NFS Access");
|
|
121
|
+
this.filesystem = new aws_efs_1.FileSystem(this, "ResourceEfs", {
|
|
122
|
+
vpc: props.vpc,
|
|
123
|
+
enableAutomaticBackups: props.automaticBackups ?? false,
|
|
124
|
+
removalPolicy: props.removalPolicy ?? aws_cdk_lib_1.RemovalPolicy.DESTROY,
|
|
125
|
+
encrypted: true,
|
|
126
|
+
fileSystemName: props.name,
|
|
127
|
+
securityGroup: this.securityGroup,
|
|
128
|
+
fileSystemPolicy: new aws_iam_1.PolicyDocument(),
|
|
129
|
+
});
|
|
130
|
+
const stackPrefix = `efs-filesystem-${(0, common_1.kebabCase)(props.name)}`;
|
|
131
|
+
new utils_1.StackParameter({
|
|
132
|
+
prefix: stackPrefix,
|
|
133
|
+
key: "filesystem",
|
|
134
|
+
name: "EFS FileSystem",
|
|
135
|
+
}).export(this, this.filesystem.fileSystemId);
|
|
136
|
+
new utils_1.StackParameter({
|
|
137
|
+
prefix: stackPrefix,
|
|
138
|
+
key: "security-group",
|
|
139
|
+
name: "EFS Security Group",
|
|
140
|
+
}).export(this, this.securityGroup.securityGroupId);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
exports.EfsFileSystem = EfsFileSystem;
|
|
144
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
145
|
+
EfsFileSystem[_a] = { fqn: "@btc-embedded/cdk-extensions.EfsFileSystem", version: "0.14.15" };
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EfsFileSystem.js","sourceRoot":"","sources":["../../src/platform/EfsFileSystem.ts"],"names":[],"mappings":"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","sourcesContent":["import { RemovalPolicy } from \"aws-cdk-lib\";\nimport {\n  IConnectable,\n  ISecurityGroup,\n  IVpc,\n  Peer,\n  Port,\n  SecurityGroup,\n} from \"aws-cdk-lib/aws-ec2\";\nimport { FileSystem, IFileSystem } from \"aws-cdk-lib/aws-efs\";\nimport {\n  ArnPrincipal,\n  Effect,\n  IRole,\n  PolicyDocument,\n  PolicyStatement,\n} from \"aws-cdk-lib/aws-iam\";\nimport { Construct } from \"constructs\";\nimport { StackParameter } from \"../utils\";\nimport { kebabCase } from \"../utils/common\";\n\nexport interface EfsFileSystemProps {\n  /**\n   * The VPC to be used.\n   */\n  readonly vpc: IVpc;\n  /**\n   * The name to be used for the filesystem. Has to be unique in the stack.\n   * Is also used for importing the filesystem from another stack.\n   */\n  readonly name: string;\n  /**\n   * Enable automatic backups. Default: `false`.\n   */\n  readonly automaticBackups?: boolean;\n  /**\n   * Removal policy. Default: {@link RemovalPolicy.DESTROY}.\n   */\n  readonly removalPolicy?: RemovalPolicy;\n}\n\n/**\n * Access modes for the Efs.\n */\nexport enum EfsAccessMode {\n  /**\n   * Access is read-only.\n   */\n  READ_ONLY,\n  /**\n   * Read-write access.\n   */\n  READ_WRITE,\n  /**\n   * Root access is granted (includes read-write access).\n   */\n  ROOT_ACCESS,\n}\n\n/**\n * Implementation fo the base functions for the {@link EfsFileSystem}.\n */\nabstract class EfsFileSystemBase extends Construct {\n  protected filesystem!: IFileSystem;\n  protected securityGroup!: ISecurityGroup;\n\n  public grantAccess(grantee: IRole, accessMode: EfsAccessMode): void {\n    const actions = [\"elasticfilesystem:ClientMount\"];\n    switch (accessMode) {\n      case EfsAccessMode.READ_ONLY:\n        this.filesystem.grantRead(grantee);\n        break;\n      case EfsAccessMode.READ_WRITE:\n        this.filesystem.grantReadWrite(grantee);\n        actions.push(\"elasticfilesystem:ClientWrite\");\n        break;\n      case EfsAccessMode.ROOT_ACCESS:\n        this.filesystem.grantRootAccess(grantee);\n        actions.push(\"elasticfilesystem:ClientWrite\");\n        actions.push(\"elasticfilesystem:ClientRootAccess\");\n        break;\n    }\n    this.filesystem.addToResourcePolicy(\n      new PolicyStatement({\n        effect: Effect.ALLOW,\n        actions: actions,\n        principals: [new ArnPrincipal(grantee.roleArn)],\n        conditions: {\n          Bool: {\n            \"elasticfilesystem:AccessedViaMountTarget\": \"true\",\n          },\n        },\n      }),\n    );\n  }\n\n  public fileSystemId(): string {\n    return this.filesystem.fileSystemId;\n  }\n\n  public fileSystem(): IFileSystem {\n    return this.filesystem;\n  }\n\n  public allowConnection(grantee: IConnectable): void {\n    this.filesystem.connections.allowDefaultPortFrom(grantee);\n  }\n}\n\n/**\n * Lookup options for importing a filesystem from the base stack.\n */\nexport interface EfsFileSystemLookupOptions {\n  /**\n   * The name of the base platform.\n   */\n  readonly basePlatformName: string;\n\n  /**\n   * The name of the filesystem to be imported.\n   */\n  readonly filesystemName: string;\n}\n\n/**\n * Interface for the {@link EfsFileSystem}.\n */\nexport interface IEfsFileSystem {\n  /**\n   * Grant access to a role for the filesystem.\n   * @param grantee The role to grant access for.\n   * @param accessMode The access mode for the grantee.\n   */\n  grantAccess(grantee: IRole, accessMode: EfsAccessMode): void;\n\n  /**\n   * Allow connection to the filesystem.\n   * @param grantee The component to allow connections for.\n   */\n  allowConnection(grantee: IConnectable): void;\n\n  /**\n   * Get the ID of the underlying EFS filesystem.\n   */\n  fileSystemId(): string;\n\n  /**\n   * Get the underlying EFS filesystem.\n   */\n  fileSystem(): IFileSystem;\n}\n\n/**\n * An EFS filesystem implementation that wraps the filesystem and the security group\n * and allows to import an EFS from a different stack.\n */\nexport class EfsFileSystem extends EfsFileSystemBase implements IEfsFileSystem {\n  /**\n   * Import an existing filesystem from the base platform stack.\n   * @param scope The scope of the element.\n   * @param id The id of the imported component.\n   * @param basePlatformLookup Lookup parameters to find the filesystem.\n   * @returns An instance of the {@link IEfsFileSystem}.\n   */\n  public static fromBasePlatform(\n    scope: Construct,\n    id: string,\n    basePlatformLookup: EfsFileSystemLookupOptions,\n  ): IEfsFileSystem {\n    const stackPrefix = `efs-filesystem-${kebabCase(basePlatformLookup.filesystemName)}`;\n\n    const filesystemFsId = new StackParameter({\n      prefix: stackPrefix,\n      key: \"filesystem\",\n      name: \"EFS FileSystem\",\n    }).import(basePlatformLookup.basePlatformName);\n\n    const filesystemSgId = new StackParameter({\n      prefix: stackPrefix,\n      key: \"security-group\",\n      name: \"EFS Security Group\",\n    }).import(basePlatformLookup.basePlatformName);\n\n    const securityGroup = SecurityGroup.fromSecurityGroupId(\n      scope,\n      `${id}SecurityGroup`,\n      filesystemSgId,\n    );\n    const filesystem = FileSystem.fromFileSystemAttributes(\n      scope,\n      `${id}FileSystem`,\n      {\n        securityGroup: securityGroup,\n        fileSystemId: filesystemFsId,\n      },\n    );\n\n    class Import extends EfsFileSystemBase implements IEfsFileSystem {\n      constructor(parentScope: Construct, constructId: string) {\n        super(parentScope, constructId);\n\n        this.securityGroup = securityGroup;\n        this.filesystem = filesystem;\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  constructor(scope: Construct, id: string, props: EfsFileSystemProps) {\n    super(scope, id);\n\n    this.securityGroup = new SecurityGroup(this, \"ResourceEfsSg\", {\n      vpc: props.vpc,\n    });\n\n    /*\n     * The security group is mandatory, if we want to import the filesystem from a\n     * different stack. We allow all incoming NFS connections, the access will be\n     * managed via {@link allowConnection}.\n     */\n    this.securityGroup.addIngressRule(\n      Peer.anyIpv4(),\n      Port.NFS,\n      \"Allow NFS Access\",\n    );\n\n    this.filesystem = new FileSystem(this, \"ResourceEfs\", {\n      vpc: props.vpc,\n      enableAutomaticBackups: props.automaticBackups ?? false,\n      removalPolicy: props.removalPolicy ?? RemovalPolicy.DESTROY,\n      encrypted: true,\n      fileSystemName: props.name,\n      securityGroup: this.securityGroup,\n      fileSystemPolicy: new PolicyDocument(),\n    });\n\n    const stackPrefix = `efs-filesystem-${kebabCase(props.name)}`;\n\n    new StackParameter({\n      prefix: stackPrefix,\n      key: \"filesystem\",\n      name: \"EFS FileSystem\",\n    }).export(this, this.filesystem.fileSystemId);\n\n    new StackParameter({\n      prefix: stackPrefix,\n      key: \"security-group\",\n      name: \"EFS Security Group\",\n    }).export(this, this.securityGroup.securityGroupId);\n  }\n}\n"]}
|
|
@@ -46,7 +46,7 @@ class PrivateDnsNamespace extends constructs_1.Construct {
|
|
|
46
46
|
}
|
|
47
47
|
exports.PrivateDnsNamespace = PrivateDnsNamespace;
|
|
48
48
|
_a = JSII_RTTI_SYMBOL_1;
|
|
49
|
-
PrivateDnsNamespace[_a] = { fqn: "@btc-embedded/cdk-extensions.PrivateDnsNamespace", version: "0.14.
|
|
49
|
+
PrivateDnsNamespace[_a] = { fqn: "@btc-embedded/cdk-extensions.PrivateDnsNamespace", version: "0.14.15" };
|
|
50
50
|
PrivateDnsNamespace.nsArnParameter = new utils_1.StackParameter({
|
|
51
51
|
prefix: "namespace",
|
|
52
52
|
name: "Namespace ARN",
|
|
@@ -39,5 +39,5 @@ class ResourceServer extends constructs_1.Construct {
|
|
|
39
39
|
}
|
|
40
40
|
exports.ResourceServer = ResourceServer;
|
|
41
41
|
_a = JSII_RTTI_SYMBOL_1;
|
|
42
|
-
ResourceServer[_a] = { fqn: "@btc-embedded/cdk-extensions.ResourceServer", version: "0.14.
|
|
42
|
+
ResourceServer[_a] = { fqn: "@btc-embedded/cdk-extensions.ResourceServer", version: "0.14.15" };
|
|
43
43
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVzb3VyY2VTZXJ2ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGxhdGZvcm0vUmVzb3VyY2VTZXJ2ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSx5REFLaUM7QUFDakMsMkNBQXVDO0FBc0J2Qzs7Ozs7Ozs7R0FRRztBQUNILE1BQWEsY0FBZSxTQUFRLHNCQUFTO0lBRzNDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMEI7UUFDbEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUFNLElBQUk7WUFDNUIsSUFBSSxpQ0FBbUIsQ0FBQztnQkFDdEIsU0FBUyxFQUFFLFVBQVU7Z0JBQ3JCLGdCQUFnQixFQUFFLDRCQUE0QjthQUMvQyxDQUFDO1lBQ0YsSUFBSSxpQ0FBbUIsQ0FBQztnQkFDdEIsU0FBUyxFQUFFLFdBQVc7Z0JBQ3RCLGdCQUFnQixFQUFFLDZCQUE2QjthQUNoRCxDQUFDO1NBQ0gsQ0FBQztRQUVGLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDLGlCQUFpQixDQUM1RCx1QkFBdUIsRUFDdkI7WUFDRSwwQkFBMEIsRUFBRSxHQUFHLEVBQUUsa0JBQWtCO1lBQ25ELFVBQVUsRUFBRSxlQUFlLEtBQUssQ0FBQyxJQUFJLEVBQUU7WUFDdkMsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNO1NBQ3BCLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTSxpQkFBaUI7UUFDdEIsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQy9CLHdCQUFVLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxLQUFLLENBQUMsQ0FDOUQsQ0FBQztJQUNKLENBQUM7O0FBOUJILHdDQStCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIElVc2VyUG9vbCxcbiAgSVVzZXJQb29sUmVzb3VyY2VTZXJ2ZXIsXG4gIE9BdXRoU2NvcGUsXG4gIFJlc291cmNlU2VydmVyU2NvcGUsXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtY29nbml0b1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSZXNvdXJjZVNlcnZlclByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBDb2duaXRvIFVzZXIgUG9vbCB0byB3aGljaCB0aGUgcmVzb3VyY2Ugc2VydmVyIHdpbGwgYmUgYWRkZWQuXG4gICAqL1xuICByZWFkb25seSB1c2VyUG9vbDogSVVzZXJQb29sO1xuXG4gIC8qKlxuICAgKiBUaGUgZnVsbHkgcXVhbGlmaWVkIGRvbWFpbiBuYW1lIChGUUROKSB1c2VkIGFzIHRoZSBpZGVudGlmaWVyIGZvciB0aGUgcmVzb3VyY2Ugc2VydmVyLlxuICAgKi9cbiAgcmVhZG9ubHkgZnFkbjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBPcHRpb25hbCBjdXN0b20gc2NvcGVzIHRvIGRlZmluZSBmb3IgdGhlIHJlc291cmNlIHNlcnZlci5cbiAgICogSWYgbm90IHByb3ZpZGVkLCBkZWZhdWx0IHNjb3BlcyBmb3IgXCJyZWFkX2FwaVwiIGFuZCBcIndyaXRlX2FwaVwiIHdpbGwgYmUgY3JlYXRlZC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBEZWZhdWx0IHNjb3BlcyBmb3IgXCJyZWFkX2FwaVwiIGFuZCBcIndyaXRlX2FwaVwiIGFyZSB1c2VkLlxuICAgKi9cbiAgcmVhZG9ubHkgc2NvcGVzPzogQXJyYXk8UmVzb3VyY2VTZXJ2ZXJTY29wZT47XG59XG5cbi8qKlxuICogQSBjb25zdHJ1Y3QgdGhhdCBjcmVhdGVzIGEgQ29nbml0byBSZXNvdXJjZSBTZXJ2ZXIgZm9yIG1hbmFnaW5nIE9BdXRoIHNjb3Blcy5cbiAqXG4gKiBUaGlzIGNvbnN0cnVjdDpcbiAqIC0gQWRkcyBhIHJlc291cmNlIHNlcnZlciB0byB0aGUgc3BlY2lmaWVkIENvZ25pdG8gVXNlciBQb29sLlxuICogLSBEZWZpbmVzIE9BdXRoIHNjb3BlcyBmb3IgdGhlIHJlc291cmNlIHNlcnZlciwgZWl0aGVyIHVzaW5nIHByb3ZpZGVkIGN1c3RvbSBzY29wZXNcbiAqICAgb3IgZGVmYXVsdGluZyB0byBcInJlYWRfYXBpXCIgYW5kIFwid3JpdGVfYXBpXCIgc2NvcGVzLlxuICogLSBQcm92aWRlcyBhIG1ldGhvZCB0byBnZW5lcmF0ZSBPQXV0aFNjb3BlIG9iamVjdHMgZm9yIHVzZSBpbiBBUEkgR2F0ZXdheS5cbiAqL1xuZXhwb3J0IGNsYXNzIFJlc291cmNlU2VydmVyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgcHVibGljIHJlc291cmNlU2VydmVySW5zdGFuY2U6IElVc2VyUG9vbFJlc291cmNlU2VydmVyO1xuICBwcml2YXRlIHNjb3BlczogQXJyYXk8UmVzb3VyY2VTZXJ2ZXJTY29wZT47XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBSZXNvdXJjZVNlcnZlclByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcbiAgICB0aGlzLnNjb3BlcyA9IHByb3BzLnNjb3BlcyA/PyBbXG4gICAgICBuZXcgUmVzb3VyY2VTZXJ2ZXJTY29wZSh7XG4gICAgICAgIHNjb3BlTmFtZTogXCJyZWFkX2FwaVwiLFxuICAgICAgICBzY29wZURlc2NyaXB0aW9uOiBcIlJFU1QgQVBJIHJlYWQgYWNjZXNzIHNjb3BlXCIsXG4gICAgICB9KSxcbiAgICAgIG5ldyBSZXNvdXJjZVNlcnZlclNjb3BlKHtcbiAgICAgICAgc2NvcGVOYW1lOiBcIndyaXRlX2FwaVwiLFxuICAgICAgICBzY29wZURlc2NyaXB0aW9uOiBcIlJFU1QgQVBJIHdyaXRlIGFjY2VzcyBzY29wZVwiLFxuICAgICAgfSksXG4gICAgXTtcblxuICAgIHRoaXMucmVzb3VyY2VTZXJ2ZXJJbnN0YW5jZSA9IHByb3BzLnVzZXJQb29sLmFkZFJlc291cmNlU2VydmVyKFxuICAgICAgXCJSRVNUQVBJUmVzb3VyY2VTZXJ2ZXJcIixcbiAgICAgIHtcbiAgICAgICAgdXNlclBvb2xSZXNvdXJjZVNlcnZlck5hbWU6IGAke2lkfS1yZXNvdXJjZS1zZXJ2ZXJgLFxuICAgICAgICBpZGVudGlmaWVyOiBgaHR0cHM6Ly9hcGkuJHtwcm9wcy5mcWRufWAsXG4gICAgICAgIHNjb3BlczogdGhpcy5zY29wZXMsXG4gICAgICB9LFxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgY3JlYXRlT0F1dGhTY29wZXMoKTogT0F1dGhTY29wZVtdIHtcbiAgICByZXR1cm4gdGhpcy5zY29wZXMubWFwKChzY29wZSkgPT5cbiAgICAgIE9BdXRoU2NvcGUucmVzb3VyY2VTZXJ2ZXIodGhpcy5yZXNvdXJjZVNlcnZlckluc3RhbmNlLCBzY29wZSksXG4gICAgKTtcbiAgfVxufVxuIl19
|
package/lib/platform/Vpc.js
CHANGED
|
@@ -71,7 +71,7 @@ class Vpc extends constructs_1.Construct {
|
|
|
71
71
|
}
|
|
72
72
|
exports.Vpc = Vpc;
|
|
73
73
|
_a = JSII_RTTI_SYMBOL_1;
|
|
74
|
-
Vpc[_a] = { fqn: "@btc-embedded/cdk-extensions.Vpc", version: "0.14.
|
|
74
|
+
Vpc[_a] = { fqn: "@btc-embedded/cdk-extensions.Vpc", version: "0.14.15" };
|
|
75
75
|
Vpc.clusterVpcIdParameter = new utils_1.StackParameter({
|
|
76
76
|
prefix: "cluster",
|
|
77
77
|
name: "Cluster VPC ID",
|
package/lib/platform/index.d.ts
CHANGED
|
@@ -2,10 +2,11 @@ export * from "./ApiGateway";
|
|
|
2
2
|
export * from "./ApiGatewayV2";
|
|
3
3
|
export * from "./ApplicationLoadBalancer";
|
|
4
4
|
export * from "./ApplicationLoadBalancerV2";
|
|
5
|
+
export * from "./BTCLogGroup";
|
|
6
|
+
export * from "./CognitoUserPool";
|
|
5
7
|
export * from "./DefaultUserPoolClients";
|
|
6
|
-
export * from "./ResourceServer";
|
|
7
8
|
export * from "./DocumentDB";
|
|
9
|
+
export * from "./EfsFileSystem";
|
|
8
10
|
export * from "./PrivateDnsNamespace";
|
|
11
|
+
export * from "./ResourceServer";
|
|
9
12
|
export * from "./Vpc";
|
|
10
|
-
export * from "./CognitoUserPool";
|
|
11
|
-
export * from "./BTCLogGroup";
|
package/lib/platform/index.js
CHANGED
|
@@ -18,11 +18,12 @@ __exportStar(require("./ApiGateway"), exports);
|
|
|
18
18
|
__exportStar(require("./ApiGatewayV2"), exports);
|
|
19
19
|
__exportStar(require("./ApplicationLoadBalancer"), exports);
|
|
20
20
|
__exportStar(require("./ApplicationLoadBalancerV2"), exports);
|
|
21
|
+
__exportStar(require("./BTCLogGroup"), exports);
|
|
22
|
+
__exportStar(require("./CognitoUserPool"), exports);
|
|
21
23
|
__exportStar(require("./DefaultUserPoolClients"), exports);
|
|
22
|
-
__exportStar(require("./ResourceServer"), exports);
|
|
23
24
|
__exportStar(require("./DocumentDB"), exports);
|
|
25
|
+
__exportStar(require("./EfsFileSystem"), exports);
|
|
24
26
|
__exportStar(require("./PrivateDnsNamespace"), exports);
|
|
27
|
+
__exportStar(require("./ResourceServer"), exports);
|
|
25
28
|
__exportStar(require("./Vpc"), exports);
|
|
26
|
-
|
|
27
|
-
__exportStar(require("./BTCLogGroup"), exports);
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGxhdGZvcm0vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLCtDQUE2QjtBQUM3QixpREFBK0I7QUFDL0IsNERBQTBDO0FBQzFDLDhEQUE0QztBQUM1QywyREFBeUM7QUFDekMsbURBQWlDO0FBQ2pDLCtDQUE2QjtBQUM3Qix3REFBc0M7QUFDdEMsd0NBQXNCO0FBQ3RCLG9EQUFrQztBQUNsQyxnREFBOEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9BcGlHYXRld2F5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9BcGlHYXRld2F5VjJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0FwcGxpY2F0aW9uTG9hZEJhbGFuY2VyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9BcHBsaWNhdGlvbkxvYWRCYWxhbmNlclYyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9EZWZhdWx0VXNlclBvb2xDbGllbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9SZXNvdXJjZVNlcnZlclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vRG9jdW1lbnREQlwiO1xuZXhwb3J0ICogZnJvbSBcIi4vUHJpdmF0ZURuc05hbWVzcGFjZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vVnBjXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9Db2duaXRvVXNlclBvb2xcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0JUQ0xvZ0dyb3VwXCI7XG4iXX0=
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGxhdGZvcm0vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLCtDQUE2QjtBQUM3QixpREFBK0I7QUFDL0IsNERBQTBDO0FBQzFDLDhEQUE0QztBQUM1QyxnREFBOEI7QUFDOUIsb0RBQWtDO0FBQ2xDLDJEQUF5QztBQUN6QywrQ0FBNkI7QUFDN0Isa0RBQWdDO0FBQ2hDLHdEQUFzQztBQUN0QyxtREFBaUM7QUFDakMsd0NBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vQXBpR2F0ZXdheVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vQXBpR2F0ZXdheVYyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9BcHBsaWNhdGlvbkxvYWRCYWxhbmNlclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJWMlwiO1xuZXhwb3J0ICogZnJvbSBcIi4vQlRDTG9nR3JvdXBcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0NvZ25pdG9Vc2VyUG9vbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vRGVmYXVsdFVzZXJQb29sQ2xpZW50c1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vRG9jdW1lbnREQlwiO1xuZXhwb3J0ICogZnJvbSBcIi4vRWZzRmlsZVN5c3RlbVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vUHJpdmF0ZURuc05hbWVzcGFjZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vUmVzb3VyY2VTZXJ2ZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL1ZwY1wiO1xuIl19
|
|
@@ -64,5 +64,5 @@ class StackParameter {
|
|
|
64
64
|
}
|
|
65
65
|
exports.StackParameter = StackParameter;
|
|
66
66
|
_a = JSII_RTTI_SYMBOL_1;
|
|
67
|
-
StackParameter[_a] = { fqn: "@btc-embedded/cdk-extensions.StackParameter", version: "0.14.
|
|
67
|
+
StackParameter[_a] = { fqn: "@btc-embedded/cdk-extensions.StackParameter", version: "0.14.15" };
|
|
68
68
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RhY2tQYXJhbWV0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvU3RhY2tQYXJhbWV0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2Q0FBbUQ7QUFFbkQscUNBQThDO0FBRTlDLFNBQVMsbUJBQW1CLENBQzFCLE9BQTJCLEVBQzNCLEdBQUcsUUFBa0I7SUFFckIsTUFBTSxpQkFBaUIsR0FBRyxRQUFRO1NBQy9CLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7U0FDM0IsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxFQUFFO1FBQ2QsSUFBSSxHQUFHLEdBQUcsQ0FBQyxJQUFJLElBQUEsa0JBQVMsRUFBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUNsQyxNQUFNLElBQUksS0FBSyxDQUNiLFdBQVcsQ0FBQywrQkFBK0IsSUFBQSxrQkFBUyxFQUFDLENBQUMsQ0FBQyxJQUFJLENBQzVELENBQUM7UUFDSixDQUFDO1FBQ0QsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDLENBQUMsQ0FBQztJQUVMLElBQUksaUJBQWlCLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ2pDLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBRUQsK0VBQStFO0lBQy9FLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxHQUFXLEVBQUUsRUFBRSxDQUN2QyxPQUFPLElBQUksT0FBTyxHQUFHLENBQUMsSUFBSSxHQUFHLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUVyRSxPQUFPLFFBQVE7U0FDWixHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDakUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ2YsQ0FBQztBQXNDRDs7O0dBR0c7QUFDSCxNQUFhLGNBQWM7SUFJekI7Ozs7T0FJRztJQUNILFlBQVksT0FBOEI7UUFDeEMsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFDaEMsTUFBTSxDQUFDLEdBQUcsSUFBQSxnQkFBTyxFQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDOUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBRTVCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO0lBQ3pCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLFNBQWlCO1FBQzdCLE9BQU8sZ0JBQUUsQ0FBQyxXQUFXLENBQ25CLG1CQUFtQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FDdkUsQ0FBQztJQUNKLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLEtBQWdCLEVBQUUsS0FBYTtRQUMzQyxNQUFNLFVBQVUsR0FBRyxtQkFBbUIsQ0FDcEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQ3BCLG1CQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLFNBQVMsRUFDekIsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUNqQixDQUFDO1FBRUYsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUksR0FBRyxVQUFVLFFBQVEsQ0FBQztRQUU3RCxPQUFPLElBQUksdUJBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFO1lBQ3JDLFVBQVU7WUFDVixLQUFLO1lBQ0wsV0FBVyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVztTQUN0QyxDQUFDLENBQUM7SUFDTCxDQUFDOztBQS9DSCx3Q0FnREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZm5PdXRwdXQsIEZuLCBTdGFjayB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IGlzQXJyYXksIGtlYmFiQ2FzZSB9IGZyb20gXCIuL2NvbW1vblwiO1xuXG5mdW5jdGlvbiBjcmVhdGVLZXlJZGVudGlmaWVyKFxuICB2ZXJzaW9uOiBudW1iZXIgfCB1bmRlZmluZWQsXG4gIC4uLnByZWZpeGVzOiBzdHJpbmdbXVxuKSB7XG4gIGNvbnN0IHZhbGlkYXRlZFByZWZpeGVzID0gcHJlZml4ZXNcbiAgICAuZmlsdGVyKChwKSA9PiBwLmxlbmd0aCA+IDApXG4gICAgLm1hcCgocCwgaWR4KSA9PiB7XG4gICAgICBpZiAoaWR4ID4gMCAmJiBrZWJhYkNhc2UocCkgIT09IHApIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgIGBwcmVmaXggJyR7cH0nIG11c3QgYmUga2ViYWItY2FzZSAobGlrZSAnJHtrZWJhYkNhc2UocCl9JylgLFxuICAgICAgICApO1xuICAgICAgfVxuICAgICAgcmV0dXJuIHA7XG4gICAgfSk7XG5cbiAgaWYgKHZhbGlkYXRlZFByZWZpeGVzLmxlbmd0aCA8IDEpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGtleSBtdXN0IGNvbnNpc3Qgb2YgYXQgbGVhc3Qgb25lIG5vbi1lbXB0eSBwcmVmaXhgKTtcbiAgfVxuXG4gIC8vIHRoZSB2ZXJzaW9uIHN1ZmZpeCBzaG91bGQgYmUgZWl0aGVyIGF0IGZpcnN0IG9yIDJuZCBwcmVmaXggYW5kIG9ubHkgaWYgdiA+IDFcbiAgY29uc3Qgc2hvdWxkR2V0VmVyc2lvbiA9IChpZHg6IG51bWJlcikgPT5cbiAgICB2ZXJzaW9uICYmIHZlcnNpb24gPiAxICYmIGlkeCA9PT0gTWF0aC5taW4ocHJlZml4ZXMubGVuZ3RoLCAyKSAtIDE7XG5cbiAgcmV0dXJuIHByZWZpeGVzXG4gICAgLm1hcCgocCwgaWR4KSA9PiAoc2hvdWxkR2V0VmVyc2lvbihpZHgpID8gYCR7cH0tdiR7dmVyc2lvbn1gIDogcCkpXG4gICAgLmpvaW4oXCI6XCIpO1xufVxuXG4vKipcbiAqIE9wdGlvbnMgZm9yIGNyZWF0aW5nIGEgU3RhY2tQYXJhbWV0ZXIuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3RhY2tQYXJhbWV0ZXJPcHRpb25zIHtcbiAgLyoqXG4gICAqIFRoZSBwcmVmaXgoZXMpIGZvciB0aGUgc3RhY2sgcGFyYW1ldGVyLlxuICAgKlxuICAgKiBQcmVmaXhlcyBtdXN0IGJlIGtlYmFiLWNhc2UgKGxvd2VyY2FzZSBsZXR0ZXJzLCBudW1iZXJzLCBhbmQgaHlwaGVucykuIElmXG4gICAqIG11bHRpcGxlIHByZWZpeGVzIGFyZSBwcm92aWRlZCwgdGhleSB3aWxsIGJlIGpvaW5lZCB3aXRoIGNvbG9ucy5cbiAgICovXG4gIHJlYWRvbmx5IHByZWZpeDogc3RyaW5nIHwgc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIFRoZSBrZXkgZm9yIHRoZSBzdGFjayBwYXJhbWV0ZXIuXG4gICAqL1xuICByZWFkb25seSBrZXk6IHN0cmluZztcblxuICAvKipcbiAgICogTmFtZSB1c2VkIGZvciB0aGUgZXhwb3J0IGNvbnN0cnVjdCBsb2dpY2FsIElELlxuICAgKi9cbiAgcmVhZG9ubHkgbmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogVmVyc2lvbiBmb3IgdGhlIHN0YWNrIHBhcmFtZXRlci5cbiAgICpcbiAgICogSWYgcHJvdmlkZWQgYW5kIGdyZWF0ZXIgdGhhbiAxLCB0aGUgdmVyc2lvbiB3aWxsIGJlIGFwcGVuZGVkIHRvIHRoZVxuICAgKiBwYXJhbWV0ZXIgbmFtZSBkdXJpbmcgZXhwb3J0IGFuZCBpbXBvcnQgYXMgYC12e3ZlcnNpb259YC5cbiAgICovXG4gIHJlYWRvbmx5IHZlcnNpb24/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIERlc2NyaXB0aW9uIGZvciB0aGUgZXhwb3J0ZWQgcGFyYW1ldGVyLlxuICAgKi9cbiAgcmVhZG9ubHkgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogUHJvdmlkZXMgbWVhbnMgdG8gZXhwb3J0IGFuZCBpbXBvcnQgc3RhY2sgcGFyYW1ldGVycy5cbiAqXG4gKi9cbmV4cG9ydCBjbGFzcyBTdGFja1BhcmFtZXRlciB7XG4gIHByaXZhdGUgcmVhZG9ubHkgb3B0aW9uczogU3RhY2tQYXJhbWV0ZXJPcHRpb25zO1xuICBwcml2YXRlIHJlYWRvbmx5IHByZWZpeGVzOiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogQ29uc3RydWN0IGEgc3RhY2sgcGFyYW1ldGVyLlxuICAgKlxuICAgKiBUaGUgc3RhY2sgcGFyYW1ldGVyIGlzIGNoYXJhY3Rlcml6ZWQgYnkgYSBwcmVmaXgsIGEga2V5LCBhIGRlc2NyaXB0aXZlIG5hbWUsIGFuZCBhbiBvcHRpb25hbCB2ZXJzaW9uLlxuICAgKi9cbiAgY29uc3RydWN0b3Iob3B0aW9uczogU3RhY2tQYXJhbWV0ZXJPcHRpb25zKSB7XG4gICAgY29uc3QgeyBwcmVmaXgsIGtleSB9ID0gb3B0aW9ucztcbiAgICBjb25zdCBwID0gaXNBcnJheShwcmVmaXgpID8gcHJlZml4IDogW3ByZWZpeF07XG4gICAgdGhpcy5wcmVmaXhlcyA9IFsuLi5wLCBrZXldO1xuXG4gICAgdGhpcy5vcHRpb25zID0gb3B0aW9ucztcbiAgfVxuXG4gIC8qKlxuICAgKiBJbXBvcnQgdGhlIHBhcmFtZXRlciBhcyB7c3RhY2tOYW1lfTp7cHJlZml4fS12e3ZlcnNpb259OntrZXl9LlxuICAgKlxuICAgKiAtdnt2ZXJzaW9ufSBpcyBvbmx5IGVtaXR0ZWQgd2hlbiB0aGUgdmVyc2lvbiBpcyBncmVhdGVyIHRoYW4gMS5cbiAgICovXG4gIHB1YmxpYyBpbXBvcnQoc3RhY2tOYW1lOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gRm4uaW1wb3J0VmFsdWUoXG4gICAgICBjcmVhdGVLZXlJZGVudGlmaWVyKHRoaXMub3B0aW9ucy52ZXJzaW9uLCBzdGFja05hbWUsIC4uLnRoaXMucHJlZml4ZXMpLFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogRXhwb3J0IHRoZSBwYXJhbWV0ZXIgYXMge3N0YWNrTmFtZX06e3ByZWZpeH0tdnt2ZXJzaW9ufTp7a2V5fS5cbiAgICpcbiAgICogLXZ7dmVyc2lvbn0gaXMgb25seSBlbWl0dGVkIHdoZW4gdGhlIHZlcnNpb24gaXMgZ3JlYXRlciB0aGFuIDEuXG4gICAqL1xuICBwdWJsaWMgZXhwb3J0KHNjb3BlOiBDb25zdHJ1Y3QsIHZhbHVlOiBzdHJpbmcpIHtcbiAgICBjb25zdCBleHBvcnROYW1lID0gY3JlYXRlS2V5SWRlbnRpZmllcihcbiAgICAgIHRoaXMub3B0aW9ucy52ZXJzaW9uLFxuICAgICAgU3RhY2sub2Yoc2NvcGUpLnN0YWNrTmFtZSxcbiAgICAgIC4uLnRoaXMucHJlZml4ZXMsXG4gICAgKTtcblxuICAgIGNvbnN0IGxvZ2ljYWxJZCA9IHRoaXMub3B0aW9ucy5uYW1lID8/IGAke2V4cG9ydE5hbWV9T3V0cHV0YDtcblxuICAgIHJldHVybiBuZXcgQ2ZuT3V0cHV0KHNjb3BlLCBsb2dpY2FsSWQsIHtcbiAgICAgIGV4cG9ydE5hbWUsXG4gICAgICB2YWx1ZSxcbiAgICAgIGRlc2NyaXB0aW9uOiB0aGlzLm9wdGlvbnMuZGVzY3JpcHRpb24sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|