envilder 0.7.12 → 0.9.1
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/README.md +284 -37
- package/ROADMAP.md +81 -16
- package/docs/CHANGELOG.md +43 -101
- package/docs/SECURITY.md +26 -2
- package/lib/apps/cli/Cli.d.ts.map +1 -1
- package/lib/apps/cli/Cli.js +68 -11
- package/lib/apps/cli/Cli.js.map +1 -1
- package/lib/apps/cli/Startup.d.ts +3 -9
- package/lib/apps/cli/Startup.d.ts.map +1 -1
- package/lib/apps/cli/Startup.js +4 -54
- package/lib/apps/cli/Startup.js.map +1 -1
- package/lib/apps/gha/Gha.d.ts.map +1 -1
- package/lib/apps/gha/Gha.js +36 -19
- package/lib/apps/gha/Gha.js.map +1 -1
- package/lib/apps/gha/Startup.d.ts +3 -9
- package/lib/apps/gha/Startup.d.ts.map +1 -1
- package/lib/apps/gha/Startup.js +4 -54
- package/lib/apps/gha/Startup.js.map +1 -1
- package/lib/apps/shared/ContainerConfiguration.d.ts +7 -0
- package/lib/apps/shared/ContainerConfiguration.d.ts.map +1 -0
- package/lib/apps/shared/ContainerConfiguration.js +62 -0
- package/lib/apps/shared/ContainerConfiguration.js.map +1 -0
- package/lib/envilder/application/dispatch/DispatchActionCommand.d.ts +2 -2
- package/lib/envilder/application/dispatch/DispatchActionCommand.d.ts.map +1 -1
- package/lib/envilder/application/dispatch/DispatchActionCommand.js +6 -6
- package/lib/envilder/application/dispatch/DispatchActionCommand.js.map +1 -1
- package/lib/envilder/application/dispatch/DispatchActionCommandHandler.d.ts +3 -3
- package/lib/envilder/application/dispatch/DispatchActionCommandHandler.d.ts.map +1 -1
- package/lib/envilder/application/dispatch/DispatchActionCommandHandler.js +13 -13
- package/lib/envilder/application/dispatch/DispatchActionCommandHandler.js.map +1 -1
- package/lib/envilder/application/pullSecretsToEnv/PullSecretsToEnvCommand.d.ts +7 -0
- package/lib/envilder/application/pullSecretsToEnv/PullSecretsToEnvCommand.d.ts.map +1 -0
- package/lib/envilder/application/{pullSsmToEnv/PullSsmToEnvCommand.js → pullSecretsToEnv/PullSecretsToEnvCommand.js} +3 -3
- package/lib/envilder/application/pullSecretsToEnv/PullSecretsToEnvCommand.js.map +1 -0
- package/lib/envilder/application/{pullSsmToEnv/PullSsmToEnvCommandHandler.d.ts → pullSecretsToEnv/PullSecretsToEnvCommandHandler.d.ts} +7 -7
- package/lib/envilder/application/pullSecretsToEnv/PullSecretsToEnvCommandHandler.d.ts.map +1 -0
- package/lib/envilder/application/{pullSsmToEnv/PullSsmToEnvCommandHandler.js → pullSecretsToEnv/PullSecretsToEnvCommandHandler.js} +18 -18
- package/lib/envilder/application/pullSecretsToEnv/PullSecretsToEnvCommandHandler.js.map +1 -0
- package/lib/envilder/application/{pushEnvToSsm/PushEnvToSsmCommand.d.ts → pushEnvToSecrets/PushEnvToSecretsCommand.d.ts} +3 -3
- package/lib/envilder/application/pushEnvToSecrets/PushEnvToSecretsCommand.d.ts.map +1 -0
- package/lib/envilder/application/{pushEnvToSsm/PushEnvToSsmCommand.js → pushEnvToSecrets/PushEnvToSecretsCommand.js} +3 -3
- package/lib/envilder/application/pushEnvToSecrets/PushEnvToSecretsCommand.js.map +1 -0
- package/lib/envilder/application/pushEnvToSecrets/PushEnvToSecretsCommandHandler.d.ts +34 -0
- package/lib/envilder/application/pushEnvToSecrets/PushEnvToSecretsCommandHandler.d.ts.map +1 -0
- package/lib/envilder/application/{pushEnvToSsm/PushEnvToSsmCommandHandler.js → pushEnvToSecrets/PushEnvToSecretsCommandHandler.js} +36 -32
- package/lib/envilder/application/pushEnvToSecrets/PushEnvToSecretsCommandHandler.js.map +1 -0
- package/lib/envilder/application/pushSingle/PushSingleCommand.d.ts +3 -3
- package/lib/envilder/application/pushSingle/PushSingleCommand.d.ts.map +1 -1
- package/lib/envilder/application/pushSingle/PushSingleCommand.js +4 -4
- package/lib/envilder/application/pushSingle/PushSingleCommand.js.map +1 -1
- package/lib/envilder/application/pushSingle/PushSingleCommandHandler.d.ts +2 -2
- package/lib/envilder/application/pushSingle/PushSingleCommandHandler.d.ts.map +1 -1
- package/lib/envilder/application/pushSingle/PushSingleCommandHandler.js +6 -6
- package/lib/envilder/application/pushSingle/PushSingleCommandHandler.js.map +1 -1
- package/lib/envilder/domain/CliOptions.d.ts +3 -3
- package/lib/envilder/domain/CliOptions.d.ts.map +1 -1
- package/lib/envilder/domain/EnvironmentVariable.d.ts +5 -0
- package/lib/envilder/domain/EnvironmentVariable.d.ts.map +1 -1
- package/lib/envilder/domain/EnvironmentVariable.js +12 -3
- package/lib/envilder/domain/EnvironmentVariable.js.map +1 -1
- package/lib/envilder/domain/MapFileConfig.d.ts +10 -0
- package/lib/envilder/domain/MapFileConfig.d.ts.map +1 -0
- package/lib/envilder/domain/MapFileConfig.js +2 -0
- package/lib/envilder/domain/MapFileConfig.js.map +1 -0
- package/lib/envilder/domain/OperationMode.d.ts +2 -2
- package/lib/envilder/domain/OperationMode.d.ts.map +1 -1
- package/lib/envilder/domain/OperationMode.js +2 -2
- package/lib/envilder/domain/OperationMode.js.map +1 -1
- package/lib/envilder/domain/ports/IVariableStore.d.ts +2 -0
- package/lib/envilder/domain/ports/IVariableStore.d.ts.map +1 -1
- package/lib/envilder/infrastructure/aws/AwsSecretProviderFactory.d.ts +4 -0
- package/lib/envilder/infrastructure/aws/AwsSecretProviderFactory.d.ts.map +1 -0
- package/lib/envilder/infrastructure/aws/AwsSecretProviderFactory.js +10 -0
- package/lib/envilder/infrastructure/aws/AwsSecretProviderFactory.js.map +1 -0
- package/lib/envilder/infrastructure/aws/AwsSsmSecretProvider.d.ts.map +1 -1
- package/lib/envilder/infrastructure/aws/AwsSsmSecretProvider.js +3 -1
- package/lib/envilder/infrastructure/aws/AwsSsmSecretProvider.js.map +1 -1
- package/lib/envilder/infrastructure/azure/AzureKeyVaultSecretProvider.d.ts +17 -0
- package/lib/envilder/infrastructure/azure/AzureKeyVaultSecretProvider.d.ts.map +1 -0
- package/lib/envilder/infrastructure/azure/AzureKeyVaultSecretProvider.js +113 -0
- package/lib/envilder/infrastructure/azure/AzureKeyVaultSecretProvider.js.map +1 -0
- package/lib/envilder/infrastructure/azure/AzureSecretProviderFactory.d.ts +9 -0
- package/lib/envilder/infrastructure/azure/AzureSecretProviderFactory.d.ts.map +1 -0
- package/lib/envilder/infrastructure/azure/AzureSecretProviderFactory.js +24 -0
- package/lib/envilder/infrastructure/azure/AzureSecretProviderFactory.js.map +1 -0
- package/lib/envilder/infrastructure/azure/AzureVaultUrlValidator.d.ts +3 -0
- package/lib/envilder/infrastructure/azure/AzureVaultUrlValidator.d.ts.map +1 -0
- package/lib/envilder/infrastructure/azure/AzureVaultUrlValidator.js +28 -0
- package/lib/envilder/infrastructure/azure/AzureVaultUrlValidator.js.map +1 -0
- package/lib/envilder/infrastructure/variableStore/FileVariableStore.d.ts +4 -0
- package/lib/envilder/infrastructure/variableStore/FileVariableStore.d.ts.map +1 -1
- package/lib/envilder/infrastructure/variableStore/FileVariableStore.js +46 -0
- package/lib/envilder/infrastructure/variableStore/FileVariableStore.js.map +1 -1
- package/lib/envilder/types.d.ts +4 -4
- package/lib/envilder/types.js +2 -2
- package/lib/envilder/types.js.map +1 -1
- package/lib/iac/bin/main.d.ts +28 -0
- package/lib/iac/bin/main.d.ts.map +1 -0
- package/lib/iac/bin/main.js +201 -0
- package/lib/iac/bin/main.js.map +1 -0
- package/lib/iac/lib/core/types.d.ts +5 -0
- package/lib/iac/lib/core/types.d.ts.map +1 -0
- package/lib/iac/lib/core/types.js +9 -0
- package/lib/iac/lib/core/types.js.map +1 -0
- package/lib/iac/lib/stacks/customStack.d.ts +23 -0
- package/lib/iac/lib/stacks/customStack.d.ts.map +1 -0
- package/lib/iac/lib/stacks/customStack.js +34 -0
- package/lib/iac/lib/stacks/customStack.js.map +1 -0
- package/lib/iac/lib/stacks/staticWebsiteStack.d.ts +10 -0
- package/lib/iac/lib/stacks/staticWebsiteStack.d.ts.map +1 -0
- package/lib/iac/lib/stacks/staticWebsiteStack.js +163 -0
- package/lib/iac/lib/stacks/staticWebsiteStack.js.map +1 -0
- package/lib/iac/lib/stacks/utils.d.ts +6 -0
- package/lib/iac/lib/stacks/utils.d.ts.map +1 -0
- package/lib/iac/lib/stacks/utils.js +18 -0
- package/lib/iac/lib/stacks/utils.js.map +1 -0
- package/package.json +33 -23
- package/lib/envilder/application/pullSsmToEnv/PullSsmToEnvCommand.d.ts +0 -7
- package/lib/envilder/application/pullSsmToEnv/PullSsmToEnvCommand.d.ts.map +0 -1
- package/lib/envilder/application/pullSsmToEnv/PullSsmToEnvCommand.js.map +0 -1
- package/lib/envilder/application/pullSsmToEnv/PullSsmToEnvCommandHandler.d.ts.map +0 -1
- package/lib/envilder/application/pullSsmToEnv/PullSsmToEnvCommandHandler.js.map +0 -1
- package/lib/envilder/application/pushEnvToSsm/PushEnvToSsmCommand.d.ts.map +0 -1
- package/lib/envilder/application/pushEnvToSsm/PushEnvToSsmCommand.js.map +0 -1
- package/lib/envilder/application/pushEnvToSsm/PushEnvToSsmCommandHandler.d.ts +0 -34
- package/lib/envilder/application/pushEnvToSsm/PushEnvToSsmCommandHandler.d.ts.map +0 -1
- package/lib/envilder/application/pushEnvToSsm/PushEnvToSsmCommandHandler.js.map +0 -1
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Stack, type StackProps } from "aws-cdk-lib";
|
|
2
|
+
import type { Construct } from "constructs";
|
|
3
|
+
import type { AppEnvironment } from "../core/types";
|
|
4
|
+
export interface DomainConfig {
|
|
5
|
+
subdomain?: string;
|
|
6
|
+
domainName: string;
|
|
7
|
+
hostedZoneId: string;
|
|
8
|
+
certificateId: string;
|
|
9
|
+
}
|
|
10
|
+
export interface CustomStackProps extends StackProps {
|
|
11
|
+
githubRepo: string;
|
|
12
|
+
envName: AppEnvironment;
|
|
13
|
+
name: string;
|
|
14
|
+
stackName: string;
|
|
15
|
+
}
|
|
16
|
+
export declare class CustomStack extends Stack {
|
|
17
|
+
props: CustomStackProps;
|
|
18
|
+
constructor(scope: Construct, props: CustomStackProps);
|
|
19
|
+
getStackId(): string;
|
|
20
|
+
private addProjectTags;
|
|
21
|
+
getCloudFormationRepoName(): string;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=customStack.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"customStack.d.ts","sourceRoot":"","sources":["../../../../src/iac/lib/stacks/customStack.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,KAAK,UAAU,EAAQ,MAAM,aAAa,CAAC;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAGpD,MAAM,WAAW,YAAY;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,gBAAiB,SAAQ,UAAU;IACnD,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,cAAc,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;CAClB;AAED,qBAAa,WAAY,SAAQ,KAAK;IACrC,KAAK,EAAE,gBAAgB,CAAC;gBAEZ,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,gBAAgB;IAQrD,UAAU,IAAI,MAAM;IAIpB,OAAO,CAAC,cAAc;IAcf,yBAAyB,IAAI,MAAM;CAG1C"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CustomStack = void 0;
|
|
4
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
5
|
+
const utils_1 = require("./utils");
|
|
6
|
+
class CustomStack extends aws_cdk_lib_1.Stack {
|
|
7
|
+
constructor(scope, props) {
|
|
8
|
+
super(scope, getStackName(props), props);
|
|
9
|
+
this.props = props;
|
|
10
|
+
this.addProjectTags();
|
|
11
|
+
}
|
|
12
|
+
getStackId() {
|
|
13
|
+
return getStackName(this.props);
|
|
14
|
+
}
|
|
15
|
+
addProjectTags() {
|
|
16
|
+
aws_cdk_lib_1.Tags.of(this).add("StackId", getStackName(this.props), {
|
|
17
|
+
priority: 300,
|
|
18
|
+
});
|
|
19
|
+
aws_cdk_lib_1.Tags.of(this).add("Environment", this.props.envName.valueOf(), {
|
|
20
|
+
priority: 300,
|
|
21
|
+
});
|
|
22
|
+
aws_cdk_lib_1.Tags.of(this).add("Project", this.props.githubRepo, {
|
|
23
|
+
priority: 300,
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
getCloudFormationRepoName() {
|
|
27
|
+
return (0, utils_1.formatRepoNameForCloudFormation)(this.props.githubRepo);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.CustomStack = CustomStack;
|
|
31
|
+
function getStackName(props) {
|
|
32
|
+
return `macalbert-${(0, utils_1.formatRepoNameForCloudFormation)(props.githubRepo)}-${props.name}-${props.envName}-stack`.toLowerCase();
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=customStack.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"customStack.js","sourceRoot":"","sources":["../../../../src/iac/lib/stacks/customStack.ts"],"names":[],"mappings":";;;AAAA,6CAA2D;AAG3D,mCAA0D;AAgB1D,MAAa,WAAY,SAAQ,mBAAK;IAGrC,YAAY,KAAgB,EAAE,KAAuB;QACpD,KAAK,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC;QAEzC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,cAAc,EAAE,CAAC;IACvB,CAAC;IAED,UAAU;QACT,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAEO,cAAc;QACrB,kBAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACtD,QAAQ,EAAE,GAAG;SACb,CAAC,CAAC;QAEH,kBAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE;YAC9D,QAAQ,EAAE,GAAG;SACb,CAAC,CAAC;QAEH,kBAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACnD,QAAQ,EAAE,GAAG;SACb,CAAC,CAAC;IACJ,CAAC;IAEM,yBAAyB;QAC/B,OAAO,IAAA,uCAA+B,EAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAC/D,CAAC;CACD;AAhCD,kCAgCC;AAED,SAAS,YAAY,CAAC,KAAuB;IAC5C,OAAO,aAAa,IAAA,uCAA+B,EAAC,KAAK,CAAC,UAAU,CAAC,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,OAAO,QAAQ,CAAC,WAAW,EAAE,CAAC;AAC5H,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Construct } from "constructs";
|
|
2
|
+
import { CustomStack, type CustomStackProps, type DomainConfig } from "./customStack";
|
|
3
|
+
export interface StaticWebsiteStackProps extends CustomStackProps {
|
|
4
|
+
domains: DomainConfig[];
|
|
5
|
+
distFolderPath: string;
|
|
6
|
+
}
|
|
7
|
+
export declare class StaticWebsiteStack extends CustomStack {
|
|
8
|
+
constructor(scope: Construct, props: StaticWebsiteStackProps);
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=staticWebsiteStack.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"staticWebsiteStack.d.ts","sourceRoot":"","sources":["../../../../src/iac/lib/stacks/staticWebsiteStack.ts"],"names":[],"mappings":"AA0BA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,EACN,WAAW,EACX,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,MAAM,eAAe,CAAC;AAEvB,MAAM,WAAW,uBAAwB,SAAQ,gBAAgB;IAChE,OAAO,EAAE,YAAY,EAAE,CAAC;IACxB,cAAc,EAAE,MAAM,CAAC;CACvB;AAED,qBAAa,kBAAmB,SAAQ,WAAW;gBACtC,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,uBAAuB;CAmM5D"}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StaticWebsiteStack = void 0;
|
|
4
|
+
const node_path_1 = require("node:path");
|
|
5
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
6
|
+
const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
|
|
7
|
+
const aws_cloudfront_1 = require("aws-cdk-lib/aws-cloudfront");
|
|
8
|
+
const aws_cloudfront_origins_1 = require("aws-cdk-lib/aws-cloudfront-origins");
|
|
9
|
+
const aws_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
10
|
+
const aws_route53_targets_1 = require("aws-cdk-lib/aws-route53-targets");
|
|
11
|
+
const aws_s3_1 = require("aws-cdk-lib/aws-s3");
|
|
12
|
+
const aws_s3_deployment_1 = require("aws-cdk-lib/aws-s3-deployment");
|
|
13
|
+
const customStack_1 = require("./customStack");
|
|
14
|
+
class StaticWebsiteStack extends customStack_1.CustomStack {
|
|
15
|
+
constructor(scope, props) {
|
|
16
|
+
var _a;
|
|
17
|
+
super(scope, props);
|
|
18
|
+
if (!props.domains || props.domains.length === 0) {
|
|
19
|
+
throw new Error("At least one domain configuration is required");
|
|
20
|
+
}
|
|
21
|
+
const primaryDomain = props.domains[0];
|
|
22
|
+
const primaryFullDomainName = primaryDomain.subdomain && primaryDomain.subdomain.length > 0
|
|
23
|
+
? [primaryDomain.subdomain, primaryDomain.domainName]
|
|
24
|
+
.join(".")
|
|
25
|
+
.toLowerCase()
|
|
26
|
+
: primaryDomain.domainName.toLowerCase();
|
|
27
|
+
const allDomainNames = props.domains.map((domain) => domain.subdomain && domain.subdomain.length > 0
|
|
28
|
+
? `${domain.subdomain}.${domain.domainName}`.toLowerCase()
|
|
29
|
+
: domain.domainName.toLowerCase());
|
|
30
|
+
const certificateMap = new Map();
|
|
31
|
+
for (const domain of props.domains) {
|
|
32
|
+
if (!certificateMap.has(domain.certificateId)) {
|
|
33
|
+
const certificateArn = `arn:aws:acm:us-east-1:${(_a = props.env) === null || _a === void 0 ? void 0 : _a.account}:certificate/${domain.certificateId}`;
|
|
34
|
+
certificateMap.set(domain.certificateId, aws_certificatemanager_1.Certificate.fromCertificateArn(this, `certificate-${domain.certificateId}`, certificateArn));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
const primaryCertificate = certificateMap.get(primaryDomain.certificateId);
|
|
38
|
+
if (!primaryCertificate) {
|
|
39
|
+
throw new Error(`Certificate not found for ${primaryDomain.certificateId}`);
|
|
40
|
+
}
|
|
41
|
+
const loggingBucket = new aws_s3_1.Bucket(this, "logging-bucket", {
|
|
42
|
+
accessControl: aws_s3_1.BucketAccessControl.LOG_DELIVERY_WRITE,
|
|
43
|
+
publicReadAccess: false,
|
|
44
|
+
versioned: false,
|
|
45
|
+
removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY,
|
|
46
|
+
bucketName: `${primaryFullDomainName}-logs`,
|
|
47
|
+
autoDeleteObjects: true,
|
|
48
|
+
blockPublicAccess: aws_s3_1.BlockPublicAccess.BLOCK_ALL,
|
|
49
|
+
encryption: aws_s3_1.BucketEncryption.S3_MANAGED,
|
|
50
|
+
enforceSSL: true,
|
|
51
|
+
lifecycleRules: [
|
|
52
|
+
{
|
|
53
|
+
id: "DeleteOldLogs",
|
|
54
|
+
expiration: aws_cdk_lib_1.Duration.days(90),
|
|
55
|
+
enabled: true,
|
|
56
|
+
},
|
|
57
|
+
],
|
|
58
|
+
});
|
|
59
|
+
const bucketWebsite = new aws_s3_1.Bucket(this, "static-website-bucket", {
|
|
60
|
+
accessControl: aws_s3_1.BucketAccessControl.PRIVATE,
|
|
61
|
+
publicReadAccess: false,
|
|
62
|
+
versioned: false,
|
|
63
|
+
removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY,
|
|
64
|
+
bucketName: primaryFullDomainName,
|
|
65
|
+
autoDeleteObjects: true,
|
|
66
|
+
blockPublicAccess: aws_s3_1.BlockPublicAccess.BLOCK_ALL,
|
|
67
|
+
encryption: aws_s3_1.BucketEncryption.S3_MANAGED,
|
|
68
|
+
cors: [
|
|
69
|
+
{
|
|
70
|
+
allowedMethods: [aws_s3_1.HttpMethods.GET, aws_s3_1.HttpMethods.HEAD],
|
|
71
|
+
allowedOrigins: ["*"],
|
|
72
|
+
allowedHeaders: ["*"],
|
|
73
|
+
},
|
|
74
|
+
],
|
|
75
|
+
enforceSSL: true,
|
|
76
|
+
serverAccessLogsBucket: loggingBucket,
|
|
77
|
+
serverAccessLogsPrefix: "s3-access-logs/",
|
|
78
|
+
});
|
|
79
|
+
const originAccessIdentity = new aws_cloudfront_1.OriginAccessIdentity(this, "originAccessIdentity", {
|
|
80
|
+
comment: `Setup access from CloudFront to the bucket ${primaryFullDomainName} (read)`,
|
|
81
|
+
});
|
|
82
|
+
bucketWebsite.grantRead(originAccessIdentity);
|
|
83
|
+
const errorResponses = [];
|
|
84
|
+
const errorResponse403 = {
|
|
85
|
+
httpStatus: 403,
|
|
86
|
+
responseHttpStatus: 200,
|
|
87
|
+
responsePagePath: "/index.html",
|
|
88
|
+
ttl: aws_cdk_lib_1.Duration.seconds(10),
|
|
89
|
+
};
|
|
90
|
+
const errorResponse404 = {
|
|
91
|
+
httpStatus: 404,
|
|
92
|
+
responseHttpStatus: 200,
|
|
93
|
+
responsePagePath: "/index.html",
|
|
94
|
+
ttl: aws_cdk_lib_1.Duration.seconds(10),
|
|
95
|
+
};
|
|
96
|
+
errorResponses.push(errorResponse403, errorResponse404);
|
|
97
|
+
const distribution = new aws_cloudfront_1.Distribution(this, "distribution", {
|
|
98
|
+
domainNames: allDomainNames,
|
|
99
|
+
defaultBehavior: {
|
|
100
|
+
origin: aws_cloudfront_origins_1.S3BucketOrigin.withOriginAccessIdentity(bucketWebsite, {
|
|
101
|
+
originAccessIdentity: originAccessIdentity,
|
|
102
|
+
}),
|
|
103
|
+
viewerProtocolPolicy: aws_cloudfront_1.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,
|
|
104
|
+
functionAssociations: [
|
|
105
|
+
{
|
|
106
|
+
eventType: aws_cloudfront_1.FunctionEventType.VIEWER_REQUEST,
|
|
107
|
+
function: new aws_cloudfront_1.Function(this, `${primaryFullDomainName}-url-rewrite`.toLowerCase(), {
|
|
108
|
+
code: aws_cloudfront_1.FunctionCode.fromFile({
|
|
109
|
+
filePath: (0, node_path_1.join)(__dirname, "cloudfront-url-rewrite.js"),
|
|
110
|
+
}),
|
|
111
|
+
}),
|
|
112
|
+
},
|
|
113
|
+
],
|
|
114
|
+
},
|
|
115
|
+
defaultRootObject: "index.html",
|
|
116
|
+
certificate: primaryCertificate,
|
|
117
|
+
errorResponses: errorResponses,
|
|
118
|
+
enableLogging: true,
|
|
119
|
+
logBucket: loggingBucket,
|
|
120
|
+
logFilePrefix: "cloudfront-logs/",
|
|
121
|
+
});
|
|
122
|
+
new aws_s3_deployment_1.BucketDeployment(this, "deploy-static-website", {
|
|
123
|
+
sources: [aws_s3_deployment_1.Source.asset(props.distFolderPath)],
|
|
124
|
+
destinationBucket: bucketWebsite,
|
|
125
|
+
distribution,
|
|
126
|
+
distributionPaths: ["/*"],
|
|
127
|
+
});
|
|
128
|
+
const aliasRecords = [];
|
|
129
|
+
for (const [index, domainConfig] of props.domains.entries()) {
|
|
130
|
+
const fullDomainName = domainConfig.subdomain && domainConfig.subdomain.length > 0
|
|
131
|
+
? `${domainConfig.subdomain}.${domainConfig.domainName}`.toLowerCase()
|
|
132
|
+
: domainConfig.domainName.toLowerCase();
|
|
133
|
+
const zoneLogicalId = index === 0
|
|
134
|
+
? "publicHostedZone-0"
|
|
135
|
+
: `hostedZone-${fullDomainName.replace(/[.-]/g, "")}`;
|
|
136
|
+
const zoneFromAttributes = aws_route53_1.HostedZone.fromHostedZoneAttributes(this, zoneLogicalId, {
|
|
137
|
+
zoneName: domainConfig.domainName,
|
|
138
|
+
hostedZoneId: domainConfig.hostedZoneId,
|
|
139
|
+
});
|
|
140
|
+
const recordLogicalId = index === 0
|
|
141
|
+
? "webDomainRecord-0"
|
|
142
|
+
: `webDomainRecord-${fullDomainName.replace(/[.-]/g, "")}`;
|
|
143
|
+
const aliasRecord = new aws_route53_1.ARecord(this, recordLogicalId, {
|
|
144
|
+
zone: zoneFromAttributes,
|
|
145
|
+
recordName: fullDomainName,
|
|
146
|
+
target: aws_route53_1.RecordTarget.fromAlias(new aws_route53_targets_1.CloudFrontTarget(distribution)),
|
|
147
|
+
});
|
|
148
|
+
aliasRecords.push(aliasRecord);
|
|
149
|
+
}
|
|
150
|
+
new aws_cdk_lib_1.CfnOutput(this, "CloudFrontDistributionDomainName", {
|
|
151
|
+
value: distribution.distributionDomainName,
|
|
152
|
+
description: "CloudFront distribution domain",
|
|
153
|
+
exportName: `${this.getCloudFormationRepoName()}-${props.envName}-CdnDomainName`,
|
|
154
|
+
});
|
|
155
|
+
new aws_cdk_lib_1.CfnOutput(this, "DnsRecordName", {
|
|
156
|
+
value: aliasRecords[0].domainName || allDomainNames[0],
|
|
157
|
+
description: "The DNS record name (primary)",
|
|
158
|
+
exportName: `${this.getCloudFormationRepoName()}-${props.envName}-AliasRecord`,
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
exports.StaticWebsiteStack = StaticWebsiteStack;
|
|
163
|
+
//# sourceMappingURL=staticWebsiteStack.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"staticWebsiteStack.js","sourceRoot":"","sources":["../../../../src/iac/lib/stacks/staticWebsiteStack.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns a formatted repository name that complies with AWS CloudFormation stack naming requirements.
|
|
3
|
+
* Stack names must match the regular expression: /^[A-Za-z][A-Za-z0-9-]*$/
|
|
4
|
+
*/
|
|
5
|
+
export declare function formatRepoNameForCloudFormation(repoName: string): string;
|
|
6
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/iac/lib/stacks/utils.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,+BAA+B,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAYxE"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.formatRepoNameForCloudFormation = formatRepoNameForCloudFormation;
|
|
4
|
+
/**
|
|
5
|
+
* Returns a formatted repository name that complies with AWS CloudFormation stack naming requirements.
|
|
6
|
+
* Stack names must match the regular expression: /^[A-Za-z][A-Za-z0-9-]*$/
|
|
7
|
+
*/
|
|
8
|
+
function formatRepoNameForCloudFormation(repoName) {
|
|
9
|
+
let formattedName = repoName.toLowerCase();
|
|
10
|
+
formattedName = formattedName.replace(/[^A-Za-z0-9]/g, "-");
|
|
11
|
+
formattedName = formattedName.replace(/-+/g, "-");
|
|
12
|
+
formattedName = formattedName.replace(/^-|-$/g, "");
|
|
13
|
+
if (!/^[A-Za-z]/.test(formattedName)) {
|
|
14
|
+
formattedName = `r-${formattedName}`;
|
|
15
|
+
}
|
|
16
|
+
return formattedName;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/iac/lib/stacks/utils.ts"],"names":[],"mappings":";;AAIA,0EAYC;AAhBD;;;GAGG;AACH,SAAgB,+BAA+B,CAAC,QAAgB;IAC/D,IAAI,aAAa,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;IAE3C,aAAa,GAAG,aAAa,CAAC,OAAO,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;IAC5D,aAAa,GAAG,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAClD,aAAa,GAAG,aAAa,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAEpD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;QACtC,aAAa,GAAG,KAAK,aAAa,EAAE,CAAC;IACtC,CAAC;IAED,OAAO,aAAa,CAAC;AACtB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "envilder",
|
|
3
|
-
"version": "0.
|
|
4
|
-
"description": "A CLI that securely centralizes your environment variables from AWS SSM as a single source of truth",
|
|
3
|
+
"version": "0.9.1",
|
|
4
|
+
"description": "A CLI and GitHub Action that securely centralizes your environment variables from AWS SSM or Azure Key Vault as a single source of truth",
|
|
5
|
+
"homepage": "https://envilder.com",
|
|
5
6
|
"author": {
|
|
6
7
|
"name": "Marçal Albert Castellví",
|
|
7
8
|
"email": "mac.albert@gmail.com",
|
|
@@ -29,14 +30,16 @@
|
|
|
29
30
|
"lint": "secretlint \"**/*\" && biome check --write && tsc --noEmit",
|
|
30
31
|
"lint:fix": "biome lint --fix",
|
|
31
32
|
"test": "vitest run --reporter=verbose --coverage",
|
|
32
|
-
"test:e2e": "vitest run --reporter=verbose e2e/",
|
|
33
33
|
"test:ci": "vitest run --reporter=verbose --reporter=junit --coverage --outputFile=coverage/junit/test-results.xml",
|
|
34
34
|
"release:publish": "npm pack --dry-run && npm publish --provenance",
|
|
35
35
|
"action-publish": "pnpm build:gha && pnpm verify:gha",
|
|
36
36
|
"release-patch": "pnpm version patch",
|
|
37
37
|
"release-minor": "pnpm version minor",
|
|
38
38
|
"release-major": "pnpm version major",
|
|
39
|
-
"release-prerelease": "pnpm version prerelease"
|
|
39
|
+
"release-prerelease": "pnpm version prerelease",
|
|
40
|
+
"dev:run": "node --env-file=dev.env --import tsx src/apps/cli/Index.ts",
|
|
41
|
+
"docker:up": "docker compose -f docker-compose.yml up -d",
|
|
42
|
+
"docker:down": "docker compose -f docker-compose.yml down"
|
|
40
43
|
},
|
|
41
44
|
"keywords": [
|
|
42
45
|
"env",
|
|
@@ -47,6 +50,7 @@
|
|
|
47
50
|
"cli",
|
|
48
51
|
"environment",
|
|
49
52
|
"secrets",
|
|
53
|
+
"secret-management",
|
|
50
54
|
"automation",
|
|
51
55
|
"config",
|
|
52
56
|
"aws-cli",
|
|
@@ -56,7 +60,11 @@
|
|
|
56
60
|
"envfile",
|
|
57
61
|
"github-actions",
|
|
58
62
|
"github-action",
|
|
59
|
-
"actions"
|
|
63
|
+
"actions",
|
|
64
|
+
"azure",
|
|
65
|
+
"key-vault",
|
|
66
|
+
"azure-key-vault",
|
|
67
|
+
"multi-cloud"
|
|
60
68
|
],
|
|
61
69
|
"bugs": {
|
|
62
70
|
"url": "https://github.com/macalbert/envilder/issues"
|
|
@@ -75,43 +83,45 @@
|
|
|
75
83
|
],
|
|
76
84
|
"type": "module",
|
|
77
85
|
"dependencies": {
|
|
78
|
-
"@aws-sdk/client-ssm": "^3.
|
|
79
|
-
"@aws-sdk/credential-providers": "^3.
|
|
80
|
-
"@
|
|
86
|
+
"@aws-sdk/client-ssm": "^3.1019.0",
|
|
87
|
+
"@aws-sdk/credential-providers": "^3.1019.0",
|
|
88
|
+
"@azure/core-rest-pipeline": "^1.23.0",
|
|
89
|
+
"@azure/identity": "^4.13.1",
|
|
90
|
+
"@azure/keyvault-secrets": "^4.10.0",
|
|
81
91
|
"commander": "^14.0.3",
|
|
82
92
|
"dotenv": "^17.3.1",
|
|
83
|
-
"inversify": "^
|
|
93
|
+
"inversify": "^8.1.0",
|
|
84
94
|
"picocolors": "^1.1.1",
|
|
85
95
|
"reflect-metadata": "^0.2.2"
|
|
86
96
|
},
|
|
87
97
|
"devDependencies": {
|
|
88
|
-
"@biomejs/biome": "
|
|
89
|
-
"@commitlint/cli": "^20.
|
|
90
|
-
"@commitlint/config-conventional": "^20.
|
|
91
|
-
"@secretlint/secretlint-rule-preset-recommend": "^11.
|
|
92
|
-
"@testcontainers/localstack": "^11.
|
|
98
|
+
"@biomejs/biome": "catalog:",
|
|
99
|
+
"@commitlint/cli": "^20.5.0",
|
|
100
|
+
"@commitlint/config-conventional": "^20.5.0",
|
|
101
|
+
"@secretlint/secretlint-rule-preset-recommend": "^11.4.0",
|
|
102
|
+
"@testcontainers/localstack": "^11.13.0",
|
|
103
|
+
"@types/node": "catalog:",
|
|
93
104
|
"@vercel/ncc": "^0.38.4",
|
|
94
|
-
"@vitest/coverage-v8": "
|
|
105
|
+
"@vitest/coverage-v8": "catalog:",
|
|
95
106
|
"glob": "^13.0.6",
|
|
96
107
|
"lefthook": "^2.1.4",
|
|
97
|
-
"secretlint": "^11.
|
|
98
|
-
"testcontainers": "^11.
|
|
99
|
-
"ts-node": "
|
|
100
|
-
"
|
|
101
|
-
"
|
|
108
|
+
"secretlint": "^11.4.0",
|
|
109
|
+
"testcontainers": "^11.13.0",
|
|
110
|
+
"ts-node": "catalog:",
|
|
111
|
+
"tsx": "^4.21.0",
|
|
112
|
+
"typescript": "catalog:",
|
|
113
|
+
"vitest": "catalog:"
|
|
102
114
|
},
|
|
103
115
|
"engines": {
|
|
104
116
|
"node": ">=20.0.0"
|
|
105
117
|
},
|
|
106
118
|
"pnpm": {
|
|
107
|
-
"overrides": {
|
|
108
|
-
"minimatch": "^10.2.2"
|
|
109
|
-
},
|
|
110
119
|
"onlyBuiltDependencies": [
|
|
111
120
|
"cpu-features",
|
|
112
121
|
"esbuild",
|
|
113
122
|
"lefthook",
|
|
114
123
|
"protobufjs",
|
|
124
|
+
"sharp",
|
|
115
125
|
"ssh2"
|
|
116
126
|
]
|
|
117
127
|
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
export declare class PullSsmToEnvCommand {
|
|
2
|
-
readonly mapPath: string;
|
|
3
|
-
readonly envFilePath: string;
|
|
4
|
-
constructor(mapPath: string, envFilePath: string);
|
|
5
|
-
static create(mapPath: string, envFilePath: string): PullSsmToEnvCommand;
|
|
6
|
-
}
|
|
7
|
-
//# sourceMappingURL=PullSsmToEnvCommand.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PullSsmToEnvCommand.d.ts","sourceRoot":"","sources":["../../../../src/envilder/application/pullSsmToEnv/PullSsmToEnvCommand.ts"],"names":[],"mappings":"AAAA,qBAAa,mBAAmB;aAEZ,OAAO,EAAE,MAAM;aACf,WAAW,EAAE,MAAM;gBADnB,OAAO,EAAE,MAAM,EACf,WAAW,EAAE,MAAM;IAGrC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,mBAAmB;CAGzE"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PullSsmToEnvCommand.js","sourceRoot":"","sources":["../../../../src/envilder/application/pullSsmToEnv/PullSsmToEnvCommand.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,mBAAmB;IAC9B,YACkB,OAAe,EACf,WAAmB;QADnB,YAAO,GAAP,OAAO,CAAQ;QACf,gBAAW,GAAX,WAAW,CAAQ;IAClC,CAAC;IAEJ,MAAM,CAAC,MAAM,CAAC,OAAe,EAAE,WAAmB;QAChD,OAAO,IAAI,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IACvD,CAAC;CACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PullSsmToEnvCommandHandler.d.ts","sourceRoot":"","sources":["../../../../src/envilder/application/pullSsmToEnv/PullSsmToEnvCommandHandler.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AAE3E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAEpE,qBACa,0BAA0B;IAcnC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,aAAa;IACP,OAAO,CAAC,QAAQ,CAAC,MAAM;IAhBhD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,cAAc,CAKpC;IAEF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAEtC;gBAIiB,cAAc,EAAE,eAAe,EAE/B,aAAa,EAAE,cAAc,EACN,MAAM,EAAE,OAAO;IAGzD;;;;;OAKG;IACG,MAAM,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC;YAoB3C,aAAa;YAcb,WAAW;YAOX,MAAM;YAsBN,aAAa;CA2B5B"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PullSsmToEnvCommandHandler.js","sourceRoot":"","sources":["../../../../src/envilder/application/pullSsmToEnv/PullSsmToEnvCommandHandler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PushEnvToSsmCommand.d.ts","sourceRoot":"","sources":["../../../../src/envilder/application/pushEnvToSsm/PushEnvToSsmCommand.ts"],"names":[],"mappings":"AAAA,qBAAa,mBAAmB;aAEZ,OAAO,EAAE,MAAM;aACf,WAAW,EAAE,MAAM;gBADnB,OAAO,EAAE,MAAM,EACf,WAAW,EAAE,MAAM;IAGrC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,mBAAmB;CAGzE"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PushEnvToSsmCommand.js","sourceRoot":"","sources":["../../../../src/envilder/application/pushEnvToSsm/PushEnvToSsmCommand.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,mBAAmB;IAC9B,YACkB,OAAe,EACf,WAAmB;QADnB,YAAO,GAAP,OAAO,CAAQ;QACf,gBAAW,GAAX,WAAW,CAAQ;IAClC,CAAC;IAEJ,MAAM,CAAC,MAAM,CAAC,OAAe,EAAE,WAAmB;QAChD,OAAO,IAAI,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IACvD,CAAC;CACF"}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import type { ILogger } from '../../domain/ports/ILogger.js';
|
|
2
|
-
import type { ISecretProvider } from '../../domain/ports/ISecretProvider.js';
|
|
3
|
-
import type { IVariableStore } from '../../domain/ports/IVariableStore.js';
|
|
4
|
-
import type { PushEnvToSsmCommand } from './PushEnvToSsmCommand.js';
|
|
5
|
-
export declare class PushEnvToSsmCommandHandler {
|
|
6
|
-
private readonly secretProvider;
|
|
7
|
-
private readonly variableStore;
|
|
8
|
-
private readonly logger;
|
|
9
|
-
constructor(secretProvider: ISecretProvider, variableStore: IVariableStore, logger: ILogger);
|
|
10
|
-
/**
|
|
11
|
-
* Handles the PushEnvToSsmCommand which imports environment variables
|
|
12
|
-
* from a local file and pushes them to AWS SSM.
|
|
13
|
-
* Uses a map file to determine the SSM parameter path for each environment variable.
|
|
14
|
-
*
|
|
15
|
-
* @param command - The PushEnvToSsmCommand containing mapPath and envFilePath
|
|
16
|
-
*/
|
|
17
|
-
handle(command: PushEnvToSsmCommand): Promise<void>;
|
|
18
|
-
private loadConfiguration;
|
|
19
|
-
/**
|
|
20
|
-
* Validates and groups environment variables by SSM path.
|
|
21
|
-
* Ensures that all variables pointing to the same SSM path have the same value.
|
|
22
|
-
* Returns a map of SSM path to value.
|
|
23
|
-
*/
|
|
24
|
-
private validateAndGroupByPath;
|
|
25
|
-
private pushParametersToSSM;
|
|
26
|
-
private pushParameter;
|
|
27
|
-
/**
|
|
28
|
-
* Retries an async operation with exponential backoff and jitter.
|
|
29
|
-
* Handles AWS SSM throttling errors (TooManyUpdates).
|
|
30
|
-
*/
|
|
31
|
-
private retryWithBackoff;
|
|
32
|
-
private getErrorMessage;
|
|
33
|
-
}
|
|
34
|
-
//# sourceMappingURL=PushEnvToSsmCommandHandler.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PushEnvToSsmCommandHandler.d.ts","sourceRoot":"","sources":["../../../../src/envilder/application/pushEnvToSsm/PushEnvToSsmCommandHandler.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AAE3E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAEpE,qBACa,0BAA0B;IAGnC,OAAO,CAAC,QAAQ,CAAC,cAAc;IAE/B,OAAO,CAAC,QAAQ,CAAC,aAAa;IACP,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAH7B,cAAc,EAAE,eAAe,EAE/B,aAAa,EAAE,cAAc,EACN,MAAM,EAAE,OAAO;IAGzD;;;;;;OAMG;IACG,MAAM,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC;YAmB3C,iBAAiB;IAwB/B;;;;OAIG;IACH,OAAO,CAAC,sBAAsB;YAmDhB,mBAAmB;YAoBnB,aAAa;IAgB3B;;;OAGG;YACW,gBAAgB;IAoC9B,OAAO,CAAC,eAAe;CA0CxB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PushEnvToSsmCommandHandler.js","sourceRoot":"","sources":["../../../../src/envilder/application/pushEnvToSsm/PushEnvToSsmCommandHandler.ts"],"names":[],"mappings":"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"}
|