truemark-cdk-lib 1.19.3 → 1.19.4-alpha.1754300585
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/aws-lambda/lib/extended-nodejs-function.d.ts +5 -0
- package/aws-lambda/lib/extended-nodejs-function.js +63 -6
- package/aws-lambda/lib/otel-collector-layer-utils.d.ts +7 -0
- package/aws-lambda/lib/otel-collector-layer-utils.js +63 -0
- package/aws-lambda/lib/otel-types.d.ts +43 -0
- package/aws-lambda/lib/otel-types.js +3 -0
- package/aws-sqs/lib/standard-queue.d.ts +7 -1
- package/aws-sqs/lib/standard-queue.js +11 -10
- package/package.json +5 -2
|
@@ -3,6 +3,7 @@ import { FunctionAlarms, FunctionAlarmsOptions } from './function-alarms';
|
|
|
3
3
|
import { FunctionDeployment } from './function-deployment';
|
|
4
4
|
import { DeployedFunctionOptions } from './extended-function';
|
|
5
5
|
import { NodejsFunction, NodejsFunctionProps } from 'aws-cdk-lib/aws-lambda-nodejs';
|
|
6
|
+
import { OtelLambdaConfig } from './otel-types';
|
|
6
7
|
/**
|
|
7
8
|
* Properties for ExtendedNodejsFunction.
|
|
8
9
|
*/
|
|
@@ -11,6 +12,10 @@ export interface ExtendedNodejsFunctionProps extends NodejsFunctionProps, Functi
|
|
|
11
12
|
* Whether to use ESM (ECMAScript Modules) for bundling. This will add ESM options to the bundling configuration and allows for functionality such as top level awaits.
|
|
12
13
|
*/
|
|
13
14
|
readonly esm?: boolean;
|
|
15
|
+
/**
|
|
16
|
+
* The OpenTelemetry configuration for the function.
|
|
17
|
+
*/
|
|
18
|
+
readonly otel?: OtelLambdaConfig;
|
|
14
19
|
}
|
|
15
20
|
export declare class ExtendedNodejsFunction extends NodejsFunction {
|
|
16
21
|
readonly alarms: FunctionAlarms;
|
|
@@ -6,9 +6,11 @@ const function_deployment_1 = require("./function-deployment");
|
|
|
6
6
|
const aws_logs_1 = require("aws-cdk-lib/aws-logs");
|
|
7
7
|
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
|
8
8
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
9
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
9
10
|
const fs = require("fs");
|
|
10
11
|
const path = require("path");
|
|
11
12
|
const aws_lambda_nodejs_1 = require("aws-cdk-lib/aws-lambda-nodejs");
|
|
13
|
+
const otel_collector_layer_utils_1 = require("./otel-collector-layer-utils");
|
|
12
14
|
class ExtendedNodejsFunction extends aws_lambda_nodejs_1.NodejsFunction {
|
|
13
15
|
static findDepsLockFile(entry) {
|
|
14
16
|
if (entry !== undefined) {
|
|
@@ -20,7 +22,24 @@ class ExtendedNodejsFunction extends aws_lambda_nodejs_1.NodejsFunction {
|
|
|
20
22
|
return undefined;
|
|
21
23
|
}
|
|
22
24
|
constructor(scope, id, props) {
|
|
23
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
25
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
|
26
|
+
const stack = aws_cdk_lib_1.Stack.of(scope);
|
|
27
|
+
const region = stack.region;
|
|
28
|
+
const otelConfig = props.otel;
|
|
29
|
+
const otelLayerVersionArn = otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.layerVersionArn;
|
|
30
|
+
const isOtelEnabled = otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.enabled;
|
|
31
|
+
let telemetryLayers;
|
|
32
|
+
let prometheusWorkspaceId;
|
|
33
|
+
if (isOtelEnabled) {
|
|
34
|
+
const collectorInstanceLayer = aws_lambda_1.LayerVersion.fromLayerVersionArn(scope, 'OpenTelemetry', otelLayerVersionArn !== null && otelLayerVersionArn !== void 0 ? otelLayerVersionArn : `arn:aws:lambda:${region}:901920570463:layer:aws-otel-nodejs-arm64-ver-1-30-2:1`);
|
|
35
|
+
const { otelSsmCollectorConfigLayer, workspaceId } = (otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.ssmConfigContentParam)
|
|
36
|
+
? (0, otel_collector_layer_utils_1.initializeOtelConfigDataFromSSM)(scope, 'Otel', otelConfig.ssmConfigContentParam, otelConfig.serviceName, otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.applicationMetricsNamespace)
|
|
37
|
+
: { otelSsmCollectorConfigLayer: undefined, workspaceId: undefined };
|
|
38
|
+
prometheusWorkspaceId = workspaceId;
|
|
39
|
+
telemetryLayers = otelSsmCollectorConfigLayer
|
|
40
|
+
? [otelSsmCollectorConfigLayer, collectorInstanceLayer]
|
|
41
|
+
: [collectorInstanceLayer];
|
|
42
|
+
}
|
|
24
43
|
super(scope, id, {
|
|
25
44
|
logRetention: aws_logs_1.RetentionDays.THREE_DAYS, // change default from INFINITE
|
|
26
45
|
architecture: aws_lambda_1.Architecture.ARM_64, // change default from X86_64
|
|
@@ -30,12 +49,24 @@ class ExtendedNodejsFunction extends aws_lambda_nodejs_1.NodejsFunction {
|
|
|
30
49
|
depsLockFilePath: ExtendedNodejsFunction.findDepsLockFile(props.entry),
|
|
31
50
|
...props,
|
|
32
51
|
loggingFormat: (_a = props.loggingFormat) !== null && _a !== void 0 ? _a : aws_lambda_1.LoggingFormat.JSON,
|
|
52
|
+
...(telemetryLayers && { layers: telemetryLayers }),
|
|
33
53
|
environment: {
|
|
34
54
|
NODE_OPTIONS: '--enable-source-maps',
|
|
55
|
+
...(isOtelEnabled && {
|
|
56
|
+
AWS_LAMBDA_EXEC_WRAPPER: '/opt/otel-handler',
|
|
57
|
+
OTEL_RESOURCE_ATTRIBUTES: `service.name=${otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.serviceName}-${otelConfig.environmentName}`,
|
|
58
|
+
OTEL_METRICS_EXPORTER: 'otlp',
|
|
59
|
+
OPENTELEMETRY_EXTENSION_LOG_LEVEL: (_b = otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.logLevel) !== null && _b !== void 0 ? _b : 'info',
|
|
60
|
+
OPENTELEMETRY_COLLECTOR_CONFIG_URI: (otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.ssmConfigContentParam)
|
|
61
|
+
? '/opt/collector.yaml'
|
|
62
|
+
: '/var/task/collector.yaml',
|
|
63
|
+
METRICS_SERVICE_NAME: `${otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.serviceName}-${otelConfig.environmentName}`,
|
|
64
|
+
}),
|
|
35
65
|
...props.environment,
|
|
66
|
+
...((_c = otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.environmentVariables) !== null && _c !== void 0 ? _c : {}),
|
|
36
67
|
},
|
|
37
68
|
bundling: {
|
|
38
|
-
sourceMap: (
|
|
69
|
+
sourceMap: (_e = (_d = props.bundling) === null || _d === void 0 ? void 0 : _d.sourceMap) !== null && _e !== void 0 ? _e : true,
|
|
39
70
|
minify: true,
|
|
40
71
|
...(props.esm
|
|
41
72
|
? {
|
|
@@ -49,24 +80,50 @@ class ExtendedNodejsFunction extends aws_lambda_nodejs_1.NodejsFunction {
|
|
|
49
80
|
...props.bundling,
|
|
50
81
|
},
|
|
51
82
|
});
|
|
83
|
+
if (isOtelEnabled) {
|
|
84
|
+
const cloudWatchMetricsPolicy = new aws_iam_1.PolicyStatement({
|
|
85
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
86
|
+
actions: ['cloudwatch:PutMetricData'],
|
|
87
|
+
resources: ['*'],
|
|
88
|
+
conditions: {
|
|
89
|
+
StringEquals: {
|
|
90
|
+
'cloudwatch:namespace': (_f = otelConfig === null || otelConfig === void 0 ? void 0 : otelConfig.applicationMetricsNamespace) !== null && _f !== void 0 ? _f : otel_collector_layer_utils_1.DEFAULT_APPLICATION_METRICS_NAMESPACE,
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
});
|
|
94
|
+
this.addToRolePolicy(cloudWatchMetricsPolicy);
|
|
95
|
+
}
|
|
96
|
+
if (prometheusWorkspaceId) {
|
|
97
|
+
this.addToRolePolicy(new aws_iam_1.PolicyStatement({
|
|
98
|
+
resources: [
|
|
99
|
+
`arn:aws:aps:${region}:${stack.account}:workspace/${prometheusWorkspaceId}`,
|
|
100
|
+
],
|
|
101
|
+
actions: [
|
|
102
|
+
'aps:RemoteWrite',
|
|
103
|
+
'aps:GetSeries',
|
|
104
|
+
'aps:GetLabels',
|
|
105
|
+
'aps:GetMetricMetadata',
|
|
106
|
+
],
|
|
107
|
+
}));
|
|
108
|
+
}
|
|
52
109
|
this.alarms = new function_alarms_1.FunctionAlarms(this, 'Alarms', {
|
|
53
110
|
function: this,
|
|
54
111
|
logGroup: this.logGroup,
|
|
55
112
|
...props,
|
|
56
113
|
});
|
|
57
|
-
if ((
|
|
114
|
+
if ((_h = (_g = props.deploymentOptions) === null || _g === void 0 ? void 0 : _g.createDeployment) !== null && _h !== void 0 ? _h : true) {
|
|
58
115
|
this.deployment = new function_deployment_1.FunctionDeployment(this, 'Deployment', {
|
|
59
116
|
...props.deploymentOptions,
|
|
60
117
|
function: this,
|
|
61
118
|
});
|
|
62
|
-
if ((
|
|
119
|
+
if ((_k = (_j = props.deploymentOptions) === null || _j === void 0 ? void 0 : _j.includeCriticalAlarms) !== null && _k !== void 0 ? _k : true) {
|
|
63
120
|
this.deployment.addAlarms(...this.alarms.getCriticalAlarms());
|
|
64
121
|
}
|
|
65
|
-
if ((
|
|
122
|
+
if ((_m = (_l = props.deploymentOptions) === null || _l === void 0 ? void 0 : _l.includeWarningAlarms) !== null && _m !== void 0 ? _m : false) {
|
|
66
123
|
this.deployment.addAlarms(...this.alarms.getWarningAlarms());
|
|
67
124
|
}
|
|
68
125
|
}
|
|
69
126
|
}
|
|
70
127
|
}
|
|
71
128
|
exports.ExtendedNodejsFunction = ExtendedNodejsFunction;
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0ZW5kZWQtbm9kZWpzLWZ1bmN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXh0ZW5kZWQtbm9kZWpzLWZ1bmN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHVEQUF3RTtBQUN4RSwrREFBeUQ7QUFFekQsbURBQW1EO0FBQ25ELHVEQUE0RTtBQUM1RSw2Q0FBcUM7QUFDckMseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUM3QixxRUFJdUM7QUFldkMsTUFBYSxzQkFBdUIsU0FBUSxrQ0FBYztJQUloRCxNQUFNLENBQUMsZ0JBQWdCLENBQzdCLEtBQXlCO1FBRXpCLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ3hCLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFDbkIsbUJBQW1CLENBQ3BCLENBQUM7WUFDRixJQUFJLEVBQUUsQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxDQUFDO2dCQUNwQyxPQUFPLGdCQUFnQixDQUFDO1lBQzFCLENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELFlBQ0UsS0FBZ0IsRUFDaEIsRUFBVSxFQUNWLEtBQWtDOztRQUVsQyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLFlBQVksRUFBRSx3QkFBYSxDQUFDLFVBQVUsRUFBRSwrQkFBK0I7WUFDdkUsWUFBWSxFQUFFLHlCQUFZLENBQUMsTUFBTSxFQUFFLDZCQUE2QjtZQUNoRSxVQUFVLEVBQUUsR0FBRyxFQUFFLDBCQUEwQjtZQUMzQyxPQUFPLEVBQUUsc0JBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLEVBQUUsd0JBQXdCO1lBQ3ZELE9BQU8sRUFBRSxvQkFBTyxDQUFDLFdBQVc7WUFDNUIsZ0JBQWdCLEVBQUUsc0JBQXNCLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQztZQUN0RSxHQUFHLEtBQUs7WUFDUixhQUFhLEVBQUUsTUFBQSxLQUFLLENBQUMsYUFBYSxtQ0FBSSwwQkFBYSxDQUFDLElBQUk7WUFDeEQsV0FBVyxFQUFFO2dCQUNYLFlBQVksRUFBRSxzQkFBc0I7Z0JBQ3BDLEdBQUcsS0FBSyxDQUFDLFdBQVc7YUFDckI7WUFDRCxRQUFRLEVBQUU7Z0JBQ1IsU0FBUyxFQUFFLE1BQUEsTUFBQSxLQUFLLENBQUMsUUFBUSwwQ0FBRSxTQUFTLG1DQUFJLElBQUk7Z0JBQzVDLE1BQU0sRUFBRSxJQUFJO2dCQUNaLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRztvQkFDWCxDQUFDLENBQUM7d0JBQ0UsTUFBTSxFQUFFLGdDQUFZLENBQUMsR0FBRzt3QkFDeEIsVUFBVSxFQUFFLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQzt3QkFDOUIsV0FBVyxFQUFFOzRCQUNYLGNBQWMsRUFBRSxRQUFRO3lCQUN6QjtxQkFDRjtvQkFDSCxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUNQLEdBQUcsS0FBSyxDQUFDLFFBQVE7YUFDbEI7U0FDRixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksZ0NBQWMsQ0FBQyxJQUFJLEVBQUUsUUFBUSxFQUFFO1lBQy9DLFFBQVEsRUFBRSxJQUFJO1lBQ2QsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLEdBQUcsS0FBSztTQUNULENBQUMsQ0FBQztRQUVILElBQUksTUFBQSxNQUFBLEtBQUssQ0FBQyxpQkFBaUIsMENBQUUsZ0JBQWdCLG1DQUFJLElBQUksRUFBRSxDQUFDO1lBQ3RELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSx3Q0FBa0IsQ0FBQyxJQUFJLEVBQUUsWUFBWSxFQUFFO2dCQUMzRCxHQUFHLEtBQUssQ0FBQyxpQkFBaUI7Z0JBQzFCLFFBQVEsRUFBRSxJQUFJO2FBQ2YsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxNQUFBLE1BQUEsS0FBSyxDQUFDLGlCQUFpQiwwQ0FBRSxxQkFBcUIsbUNBQUksSUFBSSxFQUFFLENBQUM7Z0JBQzNELElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLENBQUM7WUFDaEUsQ0FBQztZQUNELElBQUksTUFBQSxNQUFBLEtBQUssQ0FBQyxpQkFBaUIsMENBQUUsb0JBQW9CLG1DQUFJLEtBQUssRUFBRSxDQUFDO2dCQUMzRCxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1lBQy9ELENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBeEVELHdEQXdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29uc3RydWN0fSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7RnVuY3Rpb25BbGFybXMsIEZ1bmN0aW9uQWxhcm1zT3B0aW9uc30gZnJvbSAnLi9mdW5jdGlvbi1hbGFybXMnO1xuaW1wb3J0IHtGdW5jdGlvbkRlcGxveW1lbnR9IGZyb20gJy4vZnVuY3Rpb24tZGVwbG95bWVudCc7XG5pbXBvcnQge0RlcGxveWVkRnVuY3Rpb25PcHRpb25zfSBmcm9tICcuL2V4dGVuZGVkLWZ1bmN0aW9uJztcbmltcG9ydCB7UmV0ZW50aW9uRGF5c30gZnJvbSAnYXdzLWNkay1saWIvYXdzLWxvZ3MnO1xuaW1wb3J0IHtBcmNoaXRlY3R1cmUsIExvZ2dpbmdGb3JtYXQsIFJ1bnRpbWV9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0IHtEdXJhdGlvbn0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7XG4gIE5vZGVqc0Z1bmN0aW9uLFxuICBOb2RlanNGdW5jdGlvblByb3BzLFxuICBPdXRwdXRGb3JtYXQsXG59IGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEtbm9kZWpzJztcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBFeHRlbmRlZE5vZGVqc0Z1bmN0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV4dGVuZGVkTm9kZWpzRnVuY3Rpb25Qcm9wc1xuICBleHRlbmRzIE5vZGVqc0Z1bmN0aW9uUHJvcHMsXG4gICAgRnVuY3Rpb25BbGFybXNPcHRpb25zLFxuICAgIERlcGxveWVkRnVuY3Rpb25PcHRpb25zIHtcbiAgLyoqXG4gICAqIFdoZXRoZXIgdG8gdXNlIEVTTSAoRUNNQVNjcmlwdCBNb2R1bGVzKSBmb3IgYnVuZGxpbmcuIFRoaXMgd2lsbCBhZGQgRVNNIG9wdGlvbnMgdG8gdGhlIGJ1bmRsaW5nIGNvbmZpZ3VyYXRpb24gYW5kIGFsbG93cyBmb3IgZnVuY3Rpb25hbGl0eSBzdWNoIGFzIHRvcCBsZXZlbCBhd2FpdHMuXG4gICAqL1xuICByZWFkb25seSBlc20/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY2xhc3MgRXh0ZW5kZWROb2RlanNGdW5jdGlvbiBleHRlbmRzIE5vZGVqc0Z1bmN0aW9uIHtcbiAgcmVhZG9ubHkgYWxhcm1zOiBGdW5jdGlvbkFsYXJtcztcbiAgcmVhZG9ubHkgZGVwbG95bWVudD86IEZ1bmN0aW9uRGVwbG95bWVudDtcblxuICBwcml2YXRlIHN0YXRpYyBmaW5kRGVwc0xvY2tGaWxlKFxuICAgIGVudHJ5OiBzdHJpbmcgfCB1bmRlZmluZWQsXG4gICk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKGVudHJ5ICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIGNvbnN0IGRlcHNMb2NrRmlsZVBhdGggPSBwYXRoLmpvaW4oXG4gICAgICAgIHBhdGguZGlybmFtZShlbnRyeSksXG4gICAgICAgICdwYWNrYWdlLWxvY2suanNvbicsXG4gICAgICApO1xuICAgICAgaWYgKGZzLmV4aXN0c1N5bmMoZGVwc0xvY2tGaWxlUGF0aCkpIHtcbiAgICAgICAgcmV0dXJuIGRlcHNMb2NrRmlsZVBhdGg7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IEV4dGVuZGVkTm9kZWpzRnVuY3Rpb25Qcm9wcyxcbiAgKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICBsb2dSZXRlbnRpb246IFJldGVudGlvbkRheXMuVEhSRUVfREFZUywgLy8gY2hhbmdlIGRlZmF1bHQgZnJvbSBJTkZJTklURVxuICAgICAgYXJjaGl0ZWN0dXJlOiBBcmNoaXRlY3R1cmUuQVJNXzY0LCAvLyBjaGFuZ2UgZGVmYXVsdCBmcm9tIFg4Nl82NFxuICAgICAgbWVtb3J5U2l6ZTogNzY4LCAvLyBjaGFuZ2UgZGVmYXVsdCBmcm9tIDEyOFxuICAgICAgdGltZW91dDogRHVyYXRpb24uc2Vjb25kcygzMCksIC8vIGNoYW5nZSBkZWZhdWx0IGZyb20gM1xuICAgICAgcnVudGltZTogUnVudGltZS5OT0RFSlNfMjJfWCxcbiAgICAgIGRlcHNMb2NrRmlsZVBhdGg6IEV4dGVuZGVkTm9kZWpzRnVuY3Rpb24uZmluZERlcHNMb2NrRmlsZShwcm9wcy5lbnRyeSksXG4gICAgICAuLi5wcm9wcyxcbiAgICAgIGxvZ2dpbmdGb3JtYXQ6IHByb3BzLmxvZ2dpbmdGb3JtYXQgPz8gTG9nZ2luZ0Zvcm1hdC5KU09OLFxuICAgICAgZW52aXJvbm1lbnQ6IHtcbiAgICAgICAgTk9ERV9PUFRJT05TOiAnLS1lbmFibGUtc291cmNlLW1hcHMnLFxuICAgICAgICAuLi5wcm9wcy5lbnZpcm9ubWVudCxcbiAgICAgIH0sXG4gICAgICBidW5kbGluZzoge1xuICAgICAgICBzb3VyY2VNYXA6IHByb3BzLmJ1bmRsaW5nPy5zb3VyY2VNYXAgPz8gdHJ1ZSxcbiAgICAgICAgbWluaWZ5OiB0cnVlLFxuICAgICAgICAuLi4ocHJvcHMuZXNtXG4gICAgICAgICAgPyB7XG4gICAgICAgICAgICAgIGZvcm1hdDogT3V0cHV0Rm9ybWF0LkVTTSxcbiAgICAgICAgICAgICAgbWFpbkZpZWxkczogWydtb2R1bGUnLCAnbWFpbiddLFxuICAgICAgICAgICAgICBlc2J1aWxkQXJnczoge1xuICAgICAgICAgICAgICAgICctLWNvbmRpdGlvbnMnOiAnbW9kdWxlJyxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHt9KSxcbiAgICAgICAgLi4ucHJvcHMuYnVuZGxpbmcsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgdGhpcy5hbGFybXMgPSBuZXcgRnVuY3Rpb25BbGFybXModGhpcywgJ0FsYXJtcycsIHtcbiAgICAgIGZ1bmN0aW9uOiB0aGlzLFxuICAgICAgbG9nR3JvdXA6IHRoaXMubG9nR3JvdXAsXG4gICAgICAuLi5wcm9wcyxcbiAgICB9KTtcblxuICAgIGlmIChwcm9wcy5kZXBsb3ltZW50T3B0aW9ucz8uY3JlYXRlRGVwbG95bWVudCA/PyB0cnVlKSB7XG4gICAgICB0aGlzLmRlcGxveW1lbnQgPSBuZXcgRnVuY3Rpb25EZXBsb3ltZW50KHRoaXMsICdEZXBsb3ltZW50Jywge1xuICAgICAgICAuLi5wcm9wcy5kZXBsb3ltZW50T3B0aW9ucyxcbiAgICAgICAgZnVuY3Rpb246IHRoaXMsXG4gICAgICB9KTtcbiAgICAgIGlmIChwcm9wcy5kZXBsb3ltZW50T3B0aW9ucz8uaW5jbHVkZUNyaXRpY2FsQWxhcm1zID8/IHRydWUpIHtcbiAgICAgICAgdGhpcy5kZXBsb3ltZW50LmFkZEFsYXJtcyguLi50aGlzLmFsYXJtcy5nZXRDcml0aWNhbEFsYXJtcygpKTtcbiAgICAgIH1cbiAgICAgIGlmIChwcm9wcy5kZXBsb3ltZW50T3B0aW9ucz8uaW5jbHVkZVdhcm5pbmdBbGFybXMgPz8gZmFsc2UpIHtcbiAgICAgICAgdGhpcy5kZXBsb3ltZW50LmFkZEFsYXJtcyguLi50aGlzLmFsYXJtcy5nZXRXYXJuaW5nQWxhcm1zKCkpO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extended-nodejs-function.js","sourceRoot":"","sources":["extended-nodejs-function.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from 'constructs';\nimport {FunctionAlarms, FunctionAlarmsOptions} from './function-alarms';\nimport {FunctionDeployment} from './function-deployment';\nimport {DeployedFunctionOptions} from './extended-function';\nimport {RetentionDays} from 'aws-cdk-lib/aws-logs';\nimport {\n  Architecture,\n  LayerVersion,\n  LoggingFormat,\n  Runtime,\n} from 'aws-cdk-lib/aws-lambda';\nimport {Duration, Stack} from 'aws-cdk-lib';\nimport {Effect, PolicyStatement} from 'aws-cdk-lib/aws-iam';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport {\n  NodejsFunction,\n  NodejsFunctionProps,\n  OutputFormat,\n} from 'aws-cdk-lib/aws-lambda-nodejs';\nimport {OtelLambdaConfig} from './otel-types';\nimport {\n  DEFAULT_APPLICATION_METRICS_NAMESPACE,\n  initializeOtelConfigDataFromSSM,\n} from './otel-collector-layer-utils';\n\n/**\n * Properties for ExtendedNodejsFunction.\n */\nexport interface ExtendedNodejsFunctionProps\n  extends NodejsFunctionProps,\n    FunctionAlarmsOptions,\n    DeployedFunctionOptions {\n  /**\n   * Whether to use ESM (ECMAScript Modules) for bundling. This will add ESM options to the bundling configuration and allows for functionality such as top level awaits.\n   */\n  readonly esm?: boolean;\n  /**\n   * The OpenTelemetry configuration for the function.\n   */\n  readonly otel?: OtelLambdaConfig;\n}\n\nexport class ExtendedNodejsFunction extends NodejsFunction {\n  readonly alarms: FunctionAlarms;\n  readonly deployment?: FunctionDeployment;\n\n  private static findDepsLockFile(\n    entry: string | undefined,\n  ): string | undefined {\n    if (entry !== undefined) {\n      const depsLockFilePath = path.join(\n        path.dirname(entry),\n        'package-lock.json',\n      );\n      if (fs.existsSync(depsLockFilePath)) {\n        return depsLockFilePath;\n      }\n    }\n    return undefined;\n  }\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: ExtendedNodejsFunctionProps,\n  ) {\n    const stack = Stack.of(scope);\n    const region = stack.region;\n    const otelConfig = props.otel;\n    const otelLayerVersionArn = otelConfig?.layerVersionArn;\n    const isOtelEnabled = otelConfig?.enabled;\n    let telemetryLayers;\n    let prometheusWorkspaceId;\n\n    if (isOtelEnabled) {\n      const collectorInstanceLayer = LayerVersion.fromLayerVersionArn(\n        scope,\n        'OpenTelemetry',\n        otelLayerVersionArn ??\n          `arn:aws:lambda:${region}:901920570463:layer:aws-otel-nodejs-arm64-ver-1-30-2:1`,\n      );\n      const {otelSsmCollectorConfigLayer, workspaceId} =\n        otelConfig?.ssmConfigContentParam\n          ? initializeOtelConfigDataFromSSM(\n              scope,\n              'Otel',\n              otelConfig.ssmConfigContentParam,\n              otelConfig.serviceName,\n              otelConfig?.applicationMetricsNamespace,\n            )\n          : {otelSsmCollectorConfigLayer: undefined, workspaceId: undefined};\n      prometheusWorkspaceId = workspaceId;\n      telemetryLayers = otelSsmCollectorConfigLayer\n        ? [otelSsmCollectorConfigLayer, collectorInstanceLayer]\n        : [collectorInstanceLayer];\n    }\n\n    super(scope, id, {\n      logRetention: RetentionDays.THREE_DAYS, // change default from INFINITE\n      architecture: Architecture.ARM_64, // change default from X86_64\n      memorySize: 768, // change default from 128\n      timeout: Duration.seconds(30), // change default from 3\n      runtime: Runtime.NODEJS_22_X,\n      depsLockFilePath: ExtendedNodejsFunction.findDepsLockFile(props.entry),\n      ...props,\n      loggingFormat: props.loggingFormat ?? LoggingFormat.JSON,\n      ...(telemetryLayers && {layers: telemetryLayers}),\n      environment: {\n        NODE_OPTIONS: '--enable-source-maps',\n        ...(isOtelEnabled && {\n          AWS_LAMBDA_EXEC_WRAPPER: '/opt/otel-handler',\n          OTEL_RESOURCE_ATTRIBUTES: `service.name=${otelConfig?.serviceName}-${otelConfig.environmentName}`,\n          OTEL_METRICS_EXPORTER: 'otlp',\n          OPENTELEMETRY_EXTENSION_LOG_LEVEL: otelConfig?.logLevel ?? 'info',\n          OPENTELEMETRY_COLLECTOR_CONFIG_URI: otelConfig?.ssmConfigContentParam\n            ? '/opt/collector.yaml'\n            : '/var/task/collector.yaml',\n          METRICS_SERVICE_NAME: `${otelConfig?.serviceName}-${otelConfig.environmentName}`,\n        }),\n        ...props.environment,\n        ...(otelConfig?.environmentVariables ?? {}),\n      },\n      bundling: {\n        sourceMap: props.bundling?.sourceMap ?? true,\n        minify: true,\n        ...(props.esm\n          ? {\n              format: OutputFormat.ESM,\n              mainFields: ['module', 'main'],\n              esbuildArgs: {\n                '--conditions': 'module',\n              },\n            }\n          : {}),\n        ...props.bundling,\n      },\n    });\n\n    if (isOtelEnabled) {\n      const cloudWatchMetricsPolicy = new PolicyStatement({\n        effect: Effect.ALLOW,\n        actions: ['cloudwatch:PutMetricData'],\n        resources: ['*'],\n        conditions: {\n          StringEquals: {\n            'cloudwatch:namespace':\n              otelConfig?.applicationMetricsNamespace ??\n              DEFAULT_APPLICATION_METRICS_NAMESPACE,\n          },\n        },\n      });\n      this.addToRolePolicy(cloudWatchMetricsPolicy);\n    }\n\n    if (prometheusWorkspaceId) {\n      this.addToRolePolicy(\n        new PolicyStatement({\n          resources: [\n            `arn:aws:aps:${region}:${\n              stack.account\n            }:workspace/${prometheusWorkspaceId}`,\n          ],\n          actions: [\n            'aps:RemoteWrite',\n            'aps:GetSeries',\n            'aps:GetLabels',\n            'aps:GetMetricMetadata',\n          ],\n        }),\n      );\n    }\n    this.alarms = new FunctionAlarms(this, 'Alarms', {\n      function: this,\n      logGroup: this.logGroup,\n      ...props,\n    });\n\n    if (props.deploymentOptions?.createDeployment ?? true) {\n      this.deployment = new FunctionDeployment(this, 'Deployment', {\n        ...props.deploymentOptions,\n        function: this,\n      });\n      if (props.deploymentOptions?.includeCriticalAlarms ?? true) {\n        this.deployment.addAlarms(...this.alarms.getCriticalAlarms());\n      }\n      if (props.deploymentOptions?.includeWarningAlarms ?? false) {\n        this.deployment.addAlarms(...this.alarms.getWarningAlarms());\n      }\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Construct } from 'constructs';
|
|
2
|
+
import { ILayerVersion } from 'aws-cdk-lib/aws-lambda';
|
|
3
|
+
export declare const DEFAULT_APPLICATION_METRICS_NAMESPACE = "TrueMark/Otel";
|
|
4
|
+
export declare function initializeOtelConfigDataFromSSM(scope: Construct, id: string, parameterName: string, serviceName: string, applicationMetricsNamespace?: string): {
|
|
5
|
+
otelSsmCollectorConfigLayer: ILayerVersion;
|
|
6
|
+
workspaceId?: string;
|
|
7
|
+
};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DEFAULT_APPLICATION_METRICS_NAMESPACE = void 0;
|
|
4
|
+
exports.initializeOtelConfigDataFromSSM = initializeOtelConfigDataFromSSM;
|
|
5
|
+
const fs_1 = require("fs");
|
|
6
|
+
const path_1 = require("path");
|
|
7
|
+
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
|
8
|
+
const aws_ssm_1 = require("aws-cdk-lib/aws-ssm");
|
|
9
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
10
|
+
exports.DEFAULT_APPLICATION_METRICS_NAMESPACE = 'TrueMark/Otel';
|
|
11
|
+
function replacePlaceholders(yamlContent, values) {
|
|
12
|
+
return yamlContent.replace(/\$\{([^}]+)\}/g, (_, key) => {
|
|
13
|
+
if (key in values) {
|
|
14
|
+
return values[key];
|
|
15
|
+
}
|
|
16
|
+
return `$\{${key}}`;
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
function removeUnwantedExporter(exporterName, yamlContent) {
|
|
20
|
+
return yamlContent.replace(/^(\s*exporters:\s*\[)([^\]]*)(\])/gm, (_match, prefix, listContent, suffix) => {
|
|
21
|
+
const entries = listContent
|
|
22
|
+
.split(',')
|
|
23
|
+
.map((exporterEntry) => exporterEntry.trim());
|
|
24
|
+
const filtered = entries.filter((entryToFilter) => !entryToFilter.startsWith(exporterName));
|
|
25
|
+
return `${prefix}${filtered.join(', ')}${suffix}`;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
function initializeOtelConfigDataFromSSM(scope, id, parameterName, serviceName, applicationMetricsNamespace) {
|
|
29
|
+
const stack = aws_cdk_lib_1.Stack.of(scope);
|
|
30
|
+
const ssmValue = aws_ssm_1.StringParameter.valueFromLookup(stack, parameterName);
|
|
31
|
+
let workspaceId;
|
|
32
|
+
const match = ssmValue.match(/endpoint:\s*(https?:\/\/[^\s]+)/);
|
|
33
|
+
if (match) {
|
|
34
|
+
const endpoint = match[1];
|
|
35
|
+
const workspaceIdMatch = endpoint.match(/\/workspaces\/(ws-[\w-]+)/);
|
|
36
|
+
if (workspaceIdMatch) {
|
|
37
|
+
workspaceId = workspaceIdMatch[1];
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
// Replace placeholders in the YAML content
|
|
41
|
+
const replacements = {
|
|
42
|
+
APPLICATION_METRICS_NAMESPACE: applicationMetricsNamespace !== null && applicationMetricsNamespace !== void 0 ? applicationMetricsNamespace : exports.DEFAULT_APPLICATION_METRICS_NAMESPACE,
|
|
43
|
+
SERVICE_NAME: serviceName,
|
|
44
|
+
};
|
|
45
|
+
const collectorYmlContent = replacePlaceholders(ssmValue, replacements);
|
|
46
|
+
// Prepare temp layer folder
|
|
47
|
+
const layerRoot = (0, path_1.join)(__dirname, `.layer-${id}`);
|
|
48
|
+
const layerPath = (0, path_1.join)(layerRoot, 'collector-layer', 'collector.yaml');
|
|
49
|
+
const layerNodejsPath = (0, path_1.join)(layerRoot, 'collector-layer');
|
|
50
|
+
const updatedCollectorYmlContent = applicationMetricsNamespace
|
|
51
|
+
? collectorYmlContent
|
|
52
|
+
: removeUnwantedExporter('awsemf', collectorYmlContent);
|
|
53
|
+
(0, fs_1.mkdirSync)(layerNodejsPath, { recursive: true });
|
|
54
|
+
(0, fs_1.writeFileSync)(layerPath, updatedCollectorYmlContent);
|
|
55
|
+
const otelSsmCollectorConfigLayer = new aws_lambda_1.LayerVersion(scope, `${id}CollectorLayer`, {
|
|
56
|
+
compatibleArchitectures: [aws_lambda_1.Architecture.ARM_64],
|
|
57
|
+
code: aws_lambda_1.Code.fromAsset(layerNodejsPath),
|
|
58
|
+
description: `Collector.yaml layer from SSM param: ${parameterName}`,
|
|
59
|
+
removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY,
|
|
60
|
+
});
|
|
61
|
+
return { otelSsmCollectorConfigLayer, workspaceId };
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3RlbC1jb2xsZWN0b3ItbGF5ZXItdXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJvdGVsLWNvbGxlY3Rvci1sYXllci11dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUE0Q0EsMEVBb0RDO0FBaEdELDJCQUE0QztBQUM1QywrQkFBMEI7QUFFMUIsdURBS2dDO0FBQ2hDLGlEQUFvRDtBQUNwRCw2Q0FBaUQ7QUFFcEMsUUFBQSxxQ0FBcUMsR0FBRyxlQUFlLENBQUM7QUFFckUsU0FBUyxtQkFBbUIsQ0FDMUIsV0FBbUIsRUFDbkIsTUFBOEI7SUFFOUIsT0FBTyxXQUFXLENBQUMsT0FBTyxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxFQUFFO1FBQ3RELElBQUksR0FBRyxJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ2xCLE9BQU8sTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3JCLENBQUM7UUFDRCxPQUFPLE1BQU0sR0FBRyxHQUFHLENBQUM7SUFDdEIsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBUyxzQkFBc0IsQ0FDN0IsWUFBb0IsRUFDcEIsV0FBbUI7SUFFbkIsT0FBTyxXQUFXLENBQUMsT0FBTyxDQUN4QixxQ0FBcUMsRUFDckMsQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUN0QyxNQUFNLE9BQU8sR0FBRyxXQUFXO2FBQ3hCLEtBQUssQ0FBQyxHQUFHLENBQUM7YUFDVixHQUFHLENBQUMsQ0FBQyxhQUFxQixFQUFFLEVBQUUsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUN4RCxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUM3QixDQUFDLGFBQXFCLEVBQUUsRUFBRSxDQUFDLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsQ0FDbkUsQ0FBQztRQUNGLE9BQU8sR0FBRyxNQUFNLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxNQUFNLEVBQUUsQ0FBQztJQUNwRCxDQUFDLENBQ0YsQ0FBQztBQUNKLENBQUM7QUFFRCxTQUFnQiwrQkFBK0IsQ0FDN0MsS0FBZ0IsRUFDaEIsRUFBVSxFQUNWLGFBQXFCLEVBQ3JCLFdBQW1CLEVBQ25CLDJCQUFvQztJQUVwQyxNQUFNLEtBQUssR0FBRyxtQkFBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QixNQUFNLFFBQVEsR0FBRyx5QkFBZSxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFFdkUsSUFBSSxXQUErQixDQUFDO0lBQ3BDLE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxLQUFLLENBQUMsaUNBQWlDLENBQUMsQ0FBQztJQUNoRSxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQ1YsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzFCLE1BQU0sZ0JBQWdCLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO1FBQ3JFLElBQUksZ0JBQWdCLEVBQUUsQ0FBQztZQUNyQixXQUFXLEdBQUcsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDcEMsQ0FBQztJQUNILENBQUM7SUFFRCwyQ0FBMkM7SUFDM0MsTUFBTSxZQUFZLEdBQUc7UUFDbkIsNkJBQTZCLEVBQzNCLDJCQUEyQixhQUEzQiwyQkFBMkIsY0FBM0IsMkJBQTJCLEdBQUksNkNBQXFDO1FBQ3RFLFlBQVksRUFBRSxXQUFXO0tBQzFCLENBQUM7SUFDRixNQUFNLG1CQUFtQixHQUFHLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUV4RSw0QkFBNEI7SUFDNUIsTUFBTSxTQUFTLEdBQUcsSUFBQSxXQUFJLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNsRCxNQUFNLFNBQVMsR0FBRyxJQUFBLFdBQUksRUFBQyxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztJQUN2RSxNQUFNLGVBQWUsR0FBRyxJQUFBLFdBQUksRUFBQyxTQUFTLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztJQUUzRCxNQUFNLDBCQUEwQixHQUFHLDJCQUEyQjtRQUM1RCxDQUFDLENBQUMsbUJBQW1CO1FBQ3JCLENBQUMsQ0FBQyxzQkFBc0IsQ0FBQyxRQUFRLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztJQUUxRCxJQUFBLGNBQVMsRUFBQyxlQUFlLEVBQUUsRUFBQyxTQUFTLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztJQUM5QyxJQUFBLGtCQUFhLEVBQUMsU0FBUyxFQUFFLDBCQUEwQixDQUFDLENBQUM7SUFFckQsTUFBTSwyQkFBMkIsR0FBRyxJQUFJLHlCQUFZLENBQ2xELEtBQUssRUFDTCxHQUFHLEVBQUUsZ0JBQWdCLEVBQ3JCO1FBQ0UsdUJBQXVCLEVBQUUsQ0FBQyx5QkFBWSxDQUFDLE1BQU0sQ0FBQztRQUM5QyxJQUFJLEVBQUUsaUJBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDO1FBQ3JDLFdBQVcsRUFBRSx3Q0FBd0MsYUFBYSxFQUFFO1FBQ3BFLGFBQWEsRUFBRSwyQkFBYSxDQUFDLE9BQU87S0FDckMsQ0FDRixDQUFDO0lBRUYsT0FBTyxFQUFDLDJCQUEyQixFQUFFLFdBQVcsRUFBQyxDQUFDO0FBQ3BELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge21rZGlyU3luYywgd3JpdGVGaWxlU3luY30gZnJvbSAnZnMnO1xuaW1wb3J0IHtqb2lufSBmcm9tICdwYXRoJztcbmltcG9ydCB7Q29uc3RydWN0fSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7XG4gIExheWVyVmVyc2lvbixcbiAgSUxheWVyVmVyc2lvbixcbiAgQXJjaGl0ZWN0dXJlLFxuICBDb2RlLFxufSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCB7U3RyaW5nUGFyYW1ldGVyfSBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc3NtJztcbmltcG9ydCB7UmVtb3ZhbFBvbGljeSwgU3RhY2t9IGZyb20gJ2F3cy1jZGstbGliJztcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfQVBQTElDQVRJT05fTUVUUklDU19OQU1FU1BBQ0UgPSAnVHJ1ZU1hcmsvT3RlbCc7XG5cbmZ1bmN0aW9uIHJlcGxhY2VQbGFjZWhvbGRlcnMoXG4gIHlhbWxDb250ZW50OiBzdHJpbmcsXG4gIHZhbHVlczogUmVjb3JkPHN0cmluZywgc3RyaW5nPixcbik6IHN0cmluZyB7XG4gIHJldHVybiB5YW1sQ29udGVudC5yZXBsYWNlKC9cXCRcXHsoW159XSspXFx9L2csIChfLCBrZXkpID0+IHtcbiAgICBpZiAoa2V5IGluIHZhbHVlcykge1xuICAgICAgcmV0dXJuIHZhbHVlc1trZXldO1xuICAgIH1cbiAgICByZXR1cm4gYCRcXHske2tleX19YDtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIHJlbW92ZVVud2FudGVkRXhwb3J0ZXIoXG4gIGV4cG9ydGVyTmFtZTogc3RyaW5nLFxuICB5YW1sQ29udGVudDogc3RyaW5nLFxuKTogc3RyaW5nIHtcbiAgcmV0dXJuIHlhbWxDb250ZW50LnJlcGxhY2UoXG4gICAgL14oXFxzKmV4cG9ydGVyczpcXHMqXFxbKShbXlxcXV0qKShcXF0pL2dtLFxuICAgIChfbWF0Y2gsIHByZWZpeCwgbGlzdENvbnRlbnQsIHN1ZmZpeCkgPT4ge1xuICAgICAgY29uc3QgZW50cmllcyA9IGxpc3RDb250ZW50XG4gICAgICAgIC5zcGxpdCgnLCcpXG4gICAgICAgIC5tYXAoKGV4cG9ydGVyRW50cnk6IHN0cmluZykgPT4gZXhwb3J0ZXJFbnRyeS50cmltKCkpO1xuICAgICAgY29uc3QgZmlsdGVyZWQgPSBlbnRyaWVzLmZpbHRlcihcbiAgICAgICAgKGVudHJ5VG9GaWx0ZXI6IHN0cmluZykgPT4gIWVudHJ5VG9GaWx0ZXIuc3RhcnRzV2l0aChleHBvcnRlck5hbWUpLFxuICAgICAgKTtcbiAgICAgIHJldHVybiBgJHtwcmVmaXh9JHtmaWx0ZXJlZC5qb2luKCcsICcpfSR7c3VmZml4fWA7XG4gICAgfSxcbiAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluaXRpYWxpemVPdGVsQ29uZmlnRGF0YUZyb21TU00oXG4gIHNjb3BlOiBDb25zdHJ1Y3QsXG4gIGlkOiBzdHJpbmcsXG4gIHBhcmFtZXRlck5hbWU6IHN0cmluZyxcbiAgc2VydmljZU5hbWU6IHN0cmluZyxcbiAgYXBwbGljYXRpb25NZXRyaWNzTmFtZXNwYWNlPzogc3RyaW5nLFxuKToge290ZWxTc21Db2xsZWN0b3JDb25maWdMYXllcjogSUxheWVyVmVyc2lvbjsgd29ya3NwYWNlSWQ/OiBzdHJpbmd9IHtcbiAgY29uc3Qgc3RhY2sgPSBTdGFjay5vZihzY29wZSk7XG4gIGNvbnN0IHNzbVZhbHVlID0gU3RyaW5nUGFyYW1ldGVyLnZhbHVlRnJvbUxvb2t1cChzdGFjaywgcGFyYW1ldGVyTmFtZSk7XG5cbiAgbGV0IHdvcmtzcGFjZUlkOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIGNvbnN0IG1hdGNoID0gc3NtVmFsdWUubWF0Y2goL2VuZHBvaW50OlxccyooaHR0cHM/OlxcL1xcL1teXFxzXSspLyk7XG4gIGlmIChtYXRjaCkge1xuICAgIGNvbnN0IGVuZHBvaW50ID0gbWF0Y2hbMV07XG4gICAgY29uc3Qgd29ya3NwYWNlSWRNYXRjaCA9IGVuZHBvaW50Lm1hdGNoKC9cXC93b3Jrc3BhY2VzXFwvKHdzLVtcXHctXSspLyk7XG4gICAgaWYgKHdvcmtzcGFjZUlkTWF0Y2gpIHtcbiAgICAgIHdvcmtzcGFjZUlkID0gd29ya3NwYWNlSWRNYXRjaFsxXTtcbiAgICB9XG4gIH1cblxuICAvLyBSZXBsYWNlIHBsYWNlaG9sZGVycyBpbiB0aGUgWUFNTCBjb250ZW50XG4gIGNvbnN0IHJlcGxhY2VtZW50cyA9IHtcbiAgICBBUFBMSUNBVElPTl9NRVRSSUNTX05BTUVTUEFDRTpcbiAgICAgIGFwcGxpY2F0aW9uTWV0cmljc05hbWVzcGFjZSA/PyBERUZBVUxUX0FQUExJQ0FUSU9OX01FVFJJQ1NfTkFNRVNQQUNFLFxuICAgIFNFUlZJQ0VfTkFNRTogc2VydmljZU5hbWUsXG4gIH07XG4gIGNvbnN0IGNvbGxlY3RvclltbENvbnRlbnQgPSByZXBsYWNlUGxhY2Vob2xkZXJzKHNzbVZhbHVlLCByZXBsYWNlbWVudHMpO1xuXG4gIC8vIFByZXBhcmUgdGVtcCBsYXllciBmb2xkZXJcbiAgY29uc3QgbGF5ZXJSb290ID0gam9pbihfX2Rpcm5hbWUsIGAubGF5ZXItJHtpZH1gKTtcbiAgY29uc3QgbGF5ZXJQYXRoID0gam9pbihsYXllclJvb3QsICdjb2xsZWN0b3ItbGF5ZXInLCAnY29sbGVjdG9yLnlhbWwnKTtcbiAgY29uc3QgbGF5ZXJOb2RlanNQYXRoID0gam9pbihsYXllclJvb3QsICdjb2xsZWN0b3ItbGF5ZXInKTtcblxuICBjb25zdCB1cGRhdGVkQ29sbGVjdG9yWW1sQ29udGVudCA9IGFwcGxpY2F0aW9uTWV0cmljc05hbWVzcGFjZVxuICAgID8gY29sbGVjdG9yWW1sQ29udGVudFxuICAgIDogcmVtb3ZlVW53YW50ZWRFeHBvcnRlcignYXdzZW1mJywgY29sbGVjdG9yWW1sQ29udGVudCk7XG5cbiAgbWtkaXJTeW5jKGxheWVyTm9kZWpzUGF0aCwge3JlY3Vyc2l2ZTogdHJ1ZX0pO1xuICB3cml0ZUZpbGVTeW5jKGxheWVyUGF0aCwgdXBkYXRlZENvbGxlY3RvclltbENvbnRlbnQpO1xuXG4gIGNvbnN0IG90ZWxTc21Db2xsZWN0b3JDb25maWdMYXllciA9IG5ldyBMYXllclZlcnNpb24oXG4gICAgc2NvcGUsXG4gICAgYCR7aWR9Q29sbGVjdG9yTGF5ZXJgLFxuICAgIHtcbiAgICAgIGNvbXBhdGlibGVBcmNoaXRlY3R1cmVzOiBbQXJjaGl0ZWN0dXJlLkFSTV82NF0sXG4gICAgICBjb2RlOiBDb2RlLmZyb21Bc3NldChsYXllck5vZGVqc1BhdGgpLFxuICAgICAgZGVzY3JpcHRpb246IGBDb2xsZWN0b3IueWFtbCBsYXllciBmcm9tIFNTTSBwYXJhbTogJHtwYXJhbWV0ZXJOYW1lfWAsXG4gICAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1ksXG4gICAgfSxcbiAgKTtcblxuICByZXR1cm4ge290ZWxTc21Db2xsZWN0b3JDb25maWdMYXllciwgd29ya3NwYWNlSWR9O1xufVxuIl19
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Standard OpenTelemetry (OTel) configuration for Lambda.
|
|
3
|
+
*/
|
|
4
|
+
export interface OtelLambdaConfig {
|
|
5
|
+
/**
|
|
6
|
+
* OTel service name to be used for instrumentation.
|
|
7
|
+
*/
|
|
8
|
+
readonly serviceName: string;
|
|
9
|
+
/**
|
|
10
|
+
* OTel environment name to be used for instrumentation.
|
|
11
|
+
*/
|
|
12
|
+
readonly environmentName: string;
|
|
13
|
+
/**
|
|
14
|
+
* Optional: Enables or disables the OpenTelemetry (OTel) container for this service. Defaults to false.
|
|
15
|
+
*/
|
|
16
|
+
readonly enabled?: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* The collector or wrapper to use for the OTel (OpenTelemetry) lambda layer.
|
|
19
|
+
* This allows the user to override the default layer version.
|
|
20
|
+
* Defaults to the one set in the lambda implementation
|
|
21
|
+
*/
|
|
22
|
+
readonly layerVersionArn?: string;
|
|
23
|
+
/**
|
|
24
|
+
* SSM Parameter content path for OTel configuration. When set, this value takes precedence over configPath.
|
|
25
|
+
*/
|
|
26
|
+
readonly ssmConfigContentParam?: string;
|
|
27
|
+
/**
|
|
28
|
+
* The Cloud Watch Application Metrics Namespace.
|
|
29
|
+
* This allows the publishing of metrics to cloudwatch and only when this value is set.
|
|
30
|
+
* Defaults to the one set in the lambda implementation, just a placeholder and nothing is published.
|
|
31
|
+
*/
|
|
32
|
+
readonly applicationMetricsNamespace?: string;
|
|
33
|
+
/**
|
|
34
|
+
* Controls the logging level of the OpenTelemetry Lambda extension itself.
|
|
35
|
+
* Acceptable values are 'debug', 'info', 'warn', 'error', 'dpanic', 'panic', and 'fatal'.
|
|
36
|
+
* Defaults to 'info'
|
|
37
|
+
*/
|
|
38
|
+
readonly logLevel?: string;
|
|
39
|
+
/**
|
|
40
|
+
* Environment variables specific to the OTel layer when needed.
|
|
41
|
+
*/
|
|
42
|
+
readonly environmentVariables?: Record<string, string>;
|
|
43
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3RlbC10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm90ZWwtdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU3RhbmRhcmQgT3BlblRlbGVtZXRyeSAoT1RlbCkgY29uZmlndXJhdGlvbiBmb3IgTGFtYmRhLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE90ZWxMYW1iZGFDb25maWcge1xuICAvKipcbiAgICogT1RlbCBzZXJ2aWNlIG5hbWUgdG8gYmUgdXNlZCBmb3IgaW5zdHJ1bWVudGF0aW9uLlxuICAgKi9cbiAgcmVhZG9ubHkgc2VydmljZU5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogT1RlbCBlbnZpcm9ubWVudCBuYW1lIHRvIGJlIHVzZWQgZm9yIGluc3RydW1lbnRhdGlvbi5cbiAgICovXG4gIHJlYWRvbmx5IGVudmlyb25tZW50TmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBPcHRpb25hbDogRW5hYmxlcyBvciBkaXNhYmxlcyB0aGUgT3BlblRlbGVtZXRyeSAoT1RlbCkgY29udGFpbmVyIGZvciB0aGlzIHNlcnZpY2UuIERlZmF1bHRzIHRvIGZhbHNlLlxuICAgKi9cbiAgcmVhZG9ubHkgZW5hYmxlZD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBjb2xsZWN0b3Igb3Igd3JhcHBlciB0byB1c2UgZm9yIHRoZSBPVGVsIChPcGVuVGVsZW1ldHJ5KSBsYW1iZGEgbGF5ZXIuXG4gICAqIFRoaXMgYWxsb3dzIHRoZSB1c2VyIHRvIG92ZXJyaWRlIHRoZSBkZWZhdWx0IGxheWVyIHZlcnNpb24uXG4gICAqIERlZmF1bHRzIHRvIHRoZSBvbmUgc2V0IGluIHRoZSBsYW1iZGEgaW1wbGVtZW50YXRpb25cbiAgICovXG4gIHJlYWRvbmx5IGxheWVyVmVyc2lvbkFybj86IHN0cmluZztcblxuICAvKipcbiAgICogU1NNIFBhcmFtZXRlciBjb250ZW50IHBhdGggZm9yIE9UZWwgY29uZmlndXJhdGlvbi4gV2hlbiBzZXQsIHRoaXMgdmFsdWUgdGFrZXMgcHJlY2VkZW5jZSBvdmVyIGNvbmZpZ1BhdGguXG4gICAqL1xuICByZWFkb25seSBzc21Db25maWdDb250ZW50UGFyYW0/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBDbG91ZCBXYXRjaCBBcHBsaWNhdGlvbiBNZXRyaWNzIE5hbWVzcGFjZS5cbiAgICogVGhpcyBhbGxvd3MgdGhlIHB1Ymxpc2hpbmcgb2YgbWV0cmljcyB0byBjbG91ZHdhdGNoIGFuZCBvbmx5IHdoZW4gdGhpcyB2YWx1ZSBpcyBzZXQuXG4gICAqIERlZmF1bHRzIHRvIHRoZSBvbmUgc2V0IGluIHRoZSBsYW1iZGEgaW1wbGVtZW50YXRpb24sIGp1c3QgYSBwbGFjZWhvbGRlciBhbmQgbm90aGluZyBpcyBwdWJsaXNoZWQuXG4gICAqL1xuICByZWFkb25seSBhcHBsaWNhdGlvbk1ldHJpY3NOYW1lc3BhY2U/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIENvbnRyb2xzIHRoZSBsb2dnaW5nIGxldmVsIG9mIHRoZSBPcGVuVGVsZW1ldHJ5IExhbWJkYSBleHRlbnNpb24gaXRzZWxmLlxuICAgKiBBY2NlcHRhYmxlIHZhbHVlcyBhcmUgJ2RlYnVnJywgJ2luZm8nLCAnd2FybicsICdlcnJvcicsICdkcGFuaWMnLCAncGFuaWMnLCBhbmQgJ2ZhdGFsJy5cbiAgICogRGVmYXVsdHMgdG8gJ2luZm8nXG4gICAqL1xuICByZWFkb25seSBsb2dMZXZlbD86IHN0cmluZztcblxuICAvKipcbiAgICogRW52aXJvbm1lbnQgdmFyaWFibGVzIHNwZWNpZmljIHRvIHRoZSBPVGVsIGxheWVyIHdoZW4gbmVlZGVkLlxuICAgKi9cbiAgcmVhZG9ubHkgZW52aXJvbm1lbnRWYXJpYWJsZXM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xufVxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Construct } from 'constructs';
|
|
2
2
|
import { Duration, RemovalPolicy, ResourceEnvironment, Stack } from 'aws-cdk-lib';
|
|
3
|
-
import { IQueue } from 'aws-cdk-lib/aws-sqs';
|
|
3
|
+
import { IQueue, QueueEncryption } from 'aws-cdk-lib/aws-sqs';
|
|
4
4
|
import * as kms from 'aws-cdk-lib/aws-kms';
|
|
5
5
|
import { QueueAlarmsOptions } from './queue-alarms';
|
|
6
6
|
import { ExtendedQueue } from './extended-queue';
|
|
@@ -43,6 +43,11 @@ export interface StandardQueueProps extends QueueAlarmsOptions, ExtendedConstruc
|
|
|
43
43
|
* @default Duration.seconds(30)
|
|
44
44
|
*/
|
|
45
45
|
readonly visibilityTimeout?: Duration;
|
|
46
|
+
/**
|
|
47
|
+
* The encryption method to use for the queue. Default is QueueEncryption.KMS_MANAGED
|
|
48
|
+
* unless a master key is provided, this will use the AWS managed key for SQS.
|
|
49
|
+
*/
|
|
50
|
+
readonly encryption?: QueueEncryption;
|
|
46
51
|
/**
|
|
47
52
|
* The KMS key to use for encryption. If not set, the AWS master key for SQS
|
|
48
53
|
* will be used.
|
|
@@ -107,6 +112,7 @@ export declare class StandardQueue extends ExtendedConstruct implements IQueue {
|
|
|
107
112
|
readonly queueArn: string;
|
|
108
113
|
readonly queueUrl: string;
|
|
109
114
|
readonly queueName: string;
|
|
115
|
+
readonly encryption: QueueEncryption | undefined;
|
|
110
116
|
readonly encryptionMasterKey?: kms.IKey | undefined;
|
|
111
117
|
readonly fifo: boolean;
|
|
112
118
|
readonly stack: Stack;
|
|
@@ -9,16 +9,16 @@ const truemark_1 = require("../../truemark");
|
|
|
9
9
|
const standard_dead_letter_queue_1 = require("./standard-dead-letter-queue");
|
|
10
10
|
class StandardQueue extends aws_cdk_1.ExtendedConstruct {
|
|
11
11
|
constructor(scope, id, props) {
|
|
12
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
12
|
+
var _a, _b, _c, _d, _e, _f, _g, _h;
|
|
13
13
|
super(scope, id, {
|
|
14
14
|
standardTags: aws_cdk_1.StandardTags.merge(props === null || props === void 0 ? void 0 : props.standardTags, truemark_1.LibStandardTags),
|
|
15
15
|
});
|
|
16
16
|
const maxReceiveCount = (_a = props === null || props === void 0 ? void 0 : props.maxReceiveCount) !== null && _a !== void 0 ? _a : StandardQueue.DEFAULT_MAX_RECEIVE_COUNT;
|
|
17
|
-
const encryption = (props === null || props === void 0 ? void 0 : props.encryptionMasterKey) === undefined
|
|
17
|
+
const encryption = (_b = props === null || props === void 0 ? void 0 : props.encryption) !== null && _b !== void 0 ? _b : ((props === null || props === void 0 ? void 0 : props.encryptionMasterKey) === undefined
|
|
18
18
|
? aws_sqs_1.QueueEncryption.KMS_MANAGED
|
|
19
|
-
: aws_sqs_1.QueueEncryption.KMS;
|
|
19
|
+
: aws_sqs_1.QueueEncryption.KMS);
|
|
20
20
|
const encryptionMasterKey = props === null || props === void 0 ? void 0 : props.encryptionMasterKey;
|
|
21
|
-
const dataKeyReuse = (
|
|
21
|
+
const dataKeyReuse = (_c = props === null || props === void 0 ? void 0 : props.dataKeyReuse) !== null && _c !== void 0 ? _c : aws_cdk_lib_1.Duration.minutes(15);
|
|
22
22
|
const deadLetterQueue = maxReceiveCount <= 0
|
|
23
23
|
? undefined
|
|
24
24
|
: {
|
|
@@ -40,15 +40,16 @@ class StandardQueue extends aws_cdk_1.ExtendedConstruct {
|
|
|
40
40
|
encryptionMasterKey,
|
|
41
41
|
dataKeyReuse,
|
|
42
42
|
fifo: props === null || props === void 0 ? void 0 : props.fifo,
|
|
43
|
-
receiveMessageWaitTime: (
|
|
44
|
-
alarmFriendlyName: (
|
|
45
|
-
retentionPeriod: (
|
|
46
|
-
visibilityTimeout: (
|
|
47
|
-
alarmNamePrefix: (
|
|
43
|
+
receiveMessageWaitTime: (_d = props === null || props === void 0 ? void 0 : props.receiveMessageWaitTime) !== null && _d !== void 0 ? _d : aws_cdk_lib_1.Duration.seconds(20),
|
|
44
|
+
alarmFriendlyName: (_e = props === null || props === void 0 ? void 0 : props.alarmFriendlyName) !== null && _e !== void 0 ? _e : id,
|
|
45
|
+
retentionPeriod: (_f = props === null || props === void 0 ? void 0 : props.retentionPeriod) !== null && _f !== void 0 ? _f : StandardQueue.DEFAULT_RETENTION_PERIOD,
|
|
46
|
+
visibilityTimeout: (_g = props === null || props === void 0 ? void 0 : props.visibilityTimeout) !== null && _g !== void 0 ? _g : aws_cdk_lib_1.Duration.seconds(30),
|
|
47
|
+
alarmNamePrefix: (_h = props === null || props === void 0 ? void 0 : props.alarmNamePrefix) !== null && _h !== void 0 ? _h : aws_cdk_lib_1.Stack.of(this).stackName + '-' + id,
|
|
48
48
|
});
|
|
49
49
|
this.queueArn = this.queue.queueArn;
|
|
50
50
|
this.queueUrl = this.queue.queueUrl;
|
|
51
51
|
this.queueName = this.queue.queueName;
|
|
52
|
+
this.encryption = this.queue.encryptionType;
|
|
52
53
|
this.encryptionMasterKey = this.queue.encryptionMasterKey;
|
|
53
54
|
this.fifo = this.queue.fifo;
|
|
54
55
|
this.stack = this.queue.stack;
|
|
@@ -107,4 +108,4 @@ class StandardQueue extends aws_cdk_1.ExtendedConstruct {
|
|
|
107
108
|
exports.StandardQueue = StandardQueue;
|
|
108
109
|
StandardQueue.DEFAULT_MAX_RECEIVE_COUNT = 3;
|
|
109
110
|
StandardQueue.DEFAULT_RETENTION_PERIOD = aws_cdk_lib_1.Duration.seconds(1209600);
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"standard-queue.js","sourceRoot":"","sources":["standard-queue.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from 'constructs';\nimport {Duration, RemovalPolicy, ResourceEnvironment, Stack} from 'aws-cdk-lib';\nimport {DeadLetterQueue, IQueue, QueueEncryption} from 'aws-cdk-lib/aws-sqs';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport {QueueAlarmsOptions} from './queue-alarms';\nimport {ExtendedQueue} from './extended-queue';\nimport {MetricOptions, Metric} from 'aws-cdk-lib/aws-cloudwatch';\nimport {\n  PolicyStatement,\n  AddToResourcePolicyResult,\n  IGrantable,\n  Grant,\n} from 'aws-cdk-lib/aws-iam';\nimport {\n  ExtendedConstruct,\n  ExtendedConstructProps,\n  StandardTags,\n} from '../../aws-cdk';\nimport {LibStandardTags} from '../../truemark';\nimport {StandardDeadLetterQueue} from './standard-dead-letter-queue';\n\n/**\n * Properties for a StandardQueue\n */\nexport interface StandardQueueProps\n  extends QueueAlarmsOptions,\n    ExtendedConstructProps {\n  /**\n   * A name for the queue.\n   *\n   * If specified and this is a FIFO queue, must end in the string '.fifo'.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly queueName?: string;\n\n  /**\n   * A name for the dead letter queue.\n   *\n   * If specified and this is a FIFO queue, must end in the string '.fifo'.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly deadLetterQueueName?: string;\n\n  /**\n   * The number of seconds Amazon SQS retains a message. Value must be between\n   * 60 and 1209600 seconds (14 days).\n   *\n   * @default Duration.seconds(1209600)\n   *\n   */\n  readonly retentionPeriod?: Duration;\n\n  /**\n   * The number of seconds a consumer has to handle the message and delete it\n   * from the queue before it becomes visible again for another consumer. Value\n   * must be between 0 and 43200 seconds (12 hours).\n   *\n   * @default Duration.seconds(30)\n   */\n  readonly visibilityTimeout?: Duration;\n\n  /**\n   * The KMS key to use for encryption. If not set, the AWS master key for SQS\n   * will be used.\n   */\n  readonly encryptionMasterKey?: kms.IKey;\n\n  /**\n   * The length of time that Amazon SQS reuses a data key before calling KMS again.\n   * This value affects pricing as you are charged for KMS usage. Value must be\n   * between 60 and 86,400 seconds (24 hours).\n   *\n   * @default Duration.minutes(15)\n   */\n  readonly dataKeyReuse?: Duration;\n\n  /**\n   * The maximum number of times a message can be unsuccessful before being moved\n   * to the dead-letter queue. Set this value to -1 to disable the dead-letter queue.\n   *\n   * @default 3\n   */\n  readonly maxReceiveCount?: number;\n\n  /**\n   * Overrides the internal identifier used for the SQS Queue.\n   *\n   * @default \"Default\"\n   */\n  readonly queueIdentifier?: string;\n\n  /**\n   * Overrides the internal identifier used for the dead letter SQS Queue.\n   *\n   * @default \"Dlq\"\n   */\n  readonly deadLetterQueueIdentifier?: string;\n\n  /**\n   * Setting this to true will suppress the creation of default tags on resources\n   * created by this construct. Default is false.\n   *\n   * @default false\n   */\n  readonly suppressTagging?: boolean;\n\n  /**\n   * Sets the queue as a fifo queue. Default is false.\n   *\n   * @default false\n   */\n  readonly fifo?: boolean;\n\n  /**\n   * Default wait time for ReceiveMessage calls.\n   *\n   * Does not wait if set to 0, otherwise waits this amount of seconds\n   * by default for messages to arrive.\n   *\n   * For more information, see Amazon SQS Long Poll.\n   *\n   *  @default Duration.seconds(20)\n   */\n  readonly receiveMessageWaitTime?: Duration;\n}\n\nexport class StandardQueue extends ExtendedConstruct implements IQueue {\n  static readonly DEFAULT_MAX_RECEIVE_COUNT = 3;\n  static readonly DEFAULT_RETENTION_PERIOD = Duration.seconds(1209600);\n\n  readonly queue: ExtendedQueue;\n\n  // From IQueue\n  readonly queueArn: string;\n  readonly queueUrl: string;\n  readonly queueName: string;\n  readonly encryptionMasterKey?: kms.IKey | undefined;\n  readonly fifo: boolean;\n  readonly stack: Stack;\n  readonly env: ResourceEnvironment;\n\n  constructor(scope: Construct, id: string, props?: StandardQueueProps) {\n    super(scope, id, {\n      standardTags: StandardTags.merge(props?.standardTags, LibStandardTags),\n    });\n\n    const maxReceiveCount =\n      props?.maxReceiveCount ?? StandardQueue.DEFAULT_MAX_RECEIVE_COUNT;\n    const encryption =\n      props?.encryptionMasterKey === undefined\n        ? QueueEncryption.KMS_MANAGED\n        : QueueEncryption.KMS;\n    const encryptionMasterKey = props?.encryptionMasterKey;\n    const dataKeyReuse = props?.dataKeyReuse ?? Duration.minutes(15);\n\n    const deadLetterQueue: DeadLetterQueue | undefined =\n      maxReceiveCount <= 0\n        ? undefined\n        : {\n            queue: new StandardDeadLetterQueue(this, 'Dlq', {\n              queueName: props?.deadLetterQueueName,\n              encryption,\n              encryptionMasterKey,\n              dataKeyReuse,\n              receiveMessageWaitTime: props?.receiveMessageWaitTime,\n              retentionPeriod: props?.retentionPeriod,\n              fifo: props?.fifo,\n            }),\n            maxReceiveCount,\n          };\n\n    this.queue = new ExtendedQueue(this, 'Default', {\n      ...props,\n      deadLetterQueue,\n      encryption,\n      encryptionMasterKey,\n      dataKeyReuse,\n      fifo: props?.fifo,\n      receiveMessageWaitTime:\n        props?.receiveMessageWaitTime ?? Duration.seconds(20),\n      alarmFriendlyName: props?.alarmFriendlyName ?? id,\n      retentionPeriod:\n        props?.retentionPeriod ?? StandardQueue.DEFAULT_RETENTION_PERIOD,\n      visibilityTimeout: props?.visibilityTimeout ?? Duration.seconds(30),\n      alarmNamePrefix:\n        props?.alarmNamePrefix ?? Stack.of(this).stackName + '-' + id,\n    });\n\n    this.queueArn = this.queue.queueArn;\n    this.queueUrl = this.queue.queueUrl;\n    this.queueName = this.queue.queueName;\n    this.encryptionMasterKey = this.queue.encryptionMasterKey;\n    this.fifo = this.queue.fifo;\n    this.stack = this.queue.stack;\n    this.env = this.queue.env;\n  }\n\n  // From IQueue\n\n  addToResourcePolicy(statement: PolicyStatement): AddToResourcePolicyResult {\n    return this.queue.addToResourcePolicy(statement);\n  }\n\n  grantConsumeMessages(grantee: IGrantable): Grant {\n    return this.queue.grantConsumeMessages(grantee);\n  }\n\n  grantSendMessages(grantee: IGrantable): Grant {\n    return this.queue.grantSendMessages(grantee);\n  }\n\n  grantPurge(grantee: IGrantable): Grant {\n    return this.queue.grantPurge(grantee);\n  }\n\n  grant(grantee: IGrantable, ...queueActions: string[]): Grant {\n    return this.queue.grant(grantee, ...queueActions);\n  }\n\n  metric(metricName: string, props?: MetricOptions): Metric {\n    return this.queue.metric(metricName, props);\n  }\n\n  metricApproximateAgeOfOldestMessage(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateAgeOfOldestMessage(props);\n  }\n\n  metricApproximateNumberOfMessagesDelayed(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateNumberOfMessagesDelayed(props);\n  }\n\n  metricApproximateNumberOfMessagesNotVisible(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateNumberOfMessagesNotVisible(props);\n  }\n\n  metricApproximateNumberOfMessagesVisible(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateNumberOfMessagesVisible(props);\n  }\n\n  metricNumberOfEmptyReceives(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfEmptyReceives(props);\n  }\n\n  metricNumberOfMessagesDeleted(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfMessagesDeleted(props);\n  }\n\n  metricNumberOfMessagesReceived(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfMessagesReceived(props);\n  }\n\n  metricNumberOfMessagesSent(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfMessagesSent(props);\n  }\n\n  metricSentMessageSize(props?: MetricOptions): Metric {\n    return this.queue.metricSentMessageSize(props);\n  }\n\n  applyRemovalPolicy(policy: RemovalPolicy): void {\n    return this.queue.applyRemovalPolicy(policy);\n  }\n}\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"standard-queue.js","sourceRoot":"","sources":["standard-queue.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from 'constructs';\nimport {Duration, RemovalPolicy, ResourceEnvironment, Stack} from 'aws-cdk-lib';\nimport {DeadLetterQueue, IQueue, QueueEncryption} from 'aws-cdk-lib/aws-sqs';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport {QueueAlarmsOptions} from './queue-alarms';\nimport {ExtendedQueue} from './extended-queue';\nimport {MetricOptions, Metric} from 'aws-cdk-lib/aws-cloudwatch';\nimport {\n  PolicyStatement,\n  AddToResourcePolicyResult,\n  IGrantable,\n  Grant,\n} from 'aws-cdk-lib/aws-iam';\nimport {\n  ExtendedConstruct,\n  ExtendedConstructProps,\n  StandardTags,\n} from '../../aws-cdk';\nimport {LibStandardTags} from '../../truemark';\nimport {StandardDeadLetterQueue} from './standard-dead-letter-queue';\n\n/**\n * Properties for a StandardQueue\n */\nexport interface StandardQueueProps\n  extends QueueAlarmsOptions,\n    ExtendedConstructProps {\n  /**\n   * A name for the queue.\n   *\n   * If specified and this is a FIFO queue, must end in the string '.fifo'.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly queueName?: string;\n\n  /**\n   * A name for the dead letter queue.\n   *\n   * If specified and this is a FIFO queue, must end in the string '.fifo'.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly deadLetterQueueName?: string;\n\n  /**\n   * The number of seconds Amazon SQS retains a message. Value must be between\n   * 60 and 1209600 seconds (14 days).\n   *\n   * @default Duration.seconds(1209600)\n   *\n   */\n  readonly retentionPeriod?: Duration;\n\n  /**\n   * The number of seconds a consumer has to handle the message and delete it\n   * from the queue before it becomes visible again for another consumer. Value\n   * must be between 0 and 43200 seconds (12 hours).\n   *\n   * @default Duration.seconds(30)\n   */\n  readonly visibilityTimeout?: Duration;\n\n  /**\n   * The encryption method to use for the queue. Default is QueueEncryption.KMS_MANAGED\n   * unless a master key is provided, this will use the AWS managed key for SQS.\n   */\n  readonly encryption?: QueueEncryption;\n\n  /**\n   * The KMS key to use for encryption. If not set, the AWS master key for SQS\n   * will be used.\n   */\n  readonly encryptionMasterKey?: kms.IKey;\n\n  /**\n   * The length of time that Amazon SQS reuses a data key before calling KMS again.\n   * This value affects pricing as you are charged for KMS usage. Value must be\n   * between 60 and 86,400 seconds (24 hours).\n   *\n   * @default Duration.minutes(15)\n   */\n  readonly dataKeyReuse?: Duration;\n\n  /**\n   * The maximum number of times a message can be unsuccessful before being moved\n   * to the dead-letter queue. Set this value to -1 to disable the dead-letter queue.\n   *\n   * @default 3\n   */\n  readonly maxReceiveCount?: number;\n\n  /**\n   * Overrides the internal identifier used for the SQS Queue.\n   *\n   * @default \"Default\"\n   */\n  readonly queueIdentifier?: string;\n\n  /**\n   * Overrides the internal identifier used for the dead letter SQS Queue.\n   *\n   * @default \"Dlq\"\n   */\n  readonly deadLetterQueueIdentifier?: string;\n\n  /**\n   * Setting this to true will suppress the creation of default tags on resources\n   * created by this construct. Default is false.\n   *\n   * @default false\n   */\n  readonly suppressTagging?: boolean;\n\n  /**\n   * Sets the queue as a fifo queue. Default is false.\n   *\n   * @default false\n   */\n  readonly fifo?: boolean;\n\n  /**\n   * Default wait time for ReceiveMessage calls.\n   *\n   * Does not wait if set to 0, otherwise waits this amount of seconds\n   * by default for messages to arrive.\n   *\n   * For more information, see Amazon SQS Long Poll.\n   *\n   *  @default Duration.seconds(20)\n   */\n  readonly receiveMessageWaitTime?: Duration;\n}\n\nexport class StandardQueue extends ExtendedConstruct implements IQueue {\n  static readonly DEFAULT_MAX_RECEIVE_COUNT = 3;\n  static readonly DEFAULT_RETENTION_PERIOD = Duration.seconds(1209600);\n\n  readonly queue: ExtendedQueue;\n\n  // From IQueue\n  readonly queueArn: string;\n  readonly queueUrl: string;\n  readonly queueName: string;\n  readonly encryption: QueueEncryption | undefined;\n  readonly encryptionMasterKey?: kms.IKey | undefined;\n  readonly fifo: boolean;\n  readonly stack: Stack;\n  readonly env: ResourceEnvironment;\n\n  constructor(scope: Construct, id: string, props?: StandardQueueProps) {\n    super(scope, id, {\n      standardTags: StandardTags.merge(props?.standardTags, LibStandardTags),\n    });\n\n    const maxReceiveCount =\n      props?.maxReceiveCount ?? StandardQueue.DEFAULT_MAX_RECEIVE_COUNT;\n    const encryption =\n      props?.encryption ??\n      (props?.encryptionMasterKey === undefined\n        ? QueueEncryption.KMS_MANAGED\n        : QueueEncryption.KMS);\n    const encryptionMasterKey = props?.encryptionMasterKey;\n    const dataKeyReuse = props?.dataKeyReuse ?? Duration.minutes(15);\n\n    const deadLetterQueue: DeadLetterQueue | undefined =\n      maxReceiveCount <= 0\n        ? undefined\n        : {\n            queue: new StandardDeadLetterQueue(this, 'Dlq', {\n              queueName: props?.deadLetterQueueName,\n              encryption,\n              encryptionMasterKey,\n              dataKeyReuse,\n              receiveMessageWaitTime: props?.receiveMessageWaitTime,\n              retentionPeriod: props?.retentionPeriod,\n              fifo: props?.fifo,\n            }),\n            maxReceiveCount,\n          };\n\n    this.queue = new ExtendedQueue(this, 'Default', {\n      ...props,\n      deadLetterQueue,\n      encryption,\n      encryptionMasterKey,\n      dataKeyReuse,\n      fifo: props?.fifo,\n      receiveMessageWaitTime:\n        props?.receiveMessageWaitTime ?? Duration.seconds(20),\n      alarmFriendlyName: props?.alarmFriendlyName ?? id,\n      retentionPeriod:\n        props?.retentionPeriod ?? StandardQueue.DEFAULT_RETENTION_PERIOD,\n      visibilityTimeout: props?.visibilityTimeout ?? Duration.seconds(30),\n      alarmNamePrefix:\n        props?.alarmNamePrefix ?? Stack.of(this).stackName + '-' + id,\n    });\n\n    this.queueArn = this.queue.queueArn;\n    this.queueUrl = this.queue.queueUrl;\n    this.queueName = this.queue.queueName;\n    this.encryption = this.queue.encryptionType;\n    this.encryptionMasterKey = this.queue.encryptionMasterKey;\n    this.fifo = this.queue.fifo;\n    this.stack = this.queue.stack;\n    this.env = this.queue.env;\n  }\n\n  // From IQueue\n\n  addToResourcePolicy(statement: PolicyStatement): AddToResourcePolicyResult {\n    return this.queue.addToResourcePolicy(statement);\n  }\n\n  grantConsumeMessages(grantee: IGrantable): Grant {\n    return this.queue.grantConsumeMessages(grantee);\n  }\n\n  grantSendMessages(grantee: IGrantable): Grant {\n    return this.queue.grantSendMessages(grantee);\n  }\n\n  grantPurge(grantee: IGrantable): Grant {\n    return this.queue.grantPurge(grantee);\n  }\n\n  grant(grantee: IGrantable, ...queueActions: string[]): Grant {\n    return this.queue.grant(grantee, ...queueActions);\n  }\n\n  metric(metricName: string, props?: MetricOptions): Metric {\n    return this.queue.metric(metricName, props);\n  }\n\n  metricApproximateAgeOfOldestMessage(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateAgeOfOldestMessage(props);\n  }\n\n  metricApproximateNumberOfMessagesDelayed(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateNumberOfMessagesDelayed(props);\n  }\n\n  metricApproximateNumberOfMessagesNotVisible(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateNumberOfMessagesNotVisible(props);\n  }\n\n  metricApproximateNumberOfMessagesVisible(props?: MetricOptions): Metric {\n    return this.queue.metricApproximateNumberOfMessagesVisible(props);\n  }\n\n  metricNumberOfEmptyReceives(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfEmptyReceives(props);\n  }\n\n  metricNumberOfMessagesDeleted(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfMessagesDeleted(props);\n  }\n\n  metricNumberOfMessagesReceived(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfMessagesReceived(props);\n  }\n\n  metricNumberOfMessagesSent(props?: MetricOptions): Metric {\n    return this.queue.metricNumberOfMessagesSent(props);\n  }\n\n  metricSentMessageSize(props?: MetricOptions): Metric {\n    return this.queue.metricSentMessageSize(props);\n  }\n\n  applyRemovalPolicy(policy: RemovalPolicy): void {\n    return this.queue.applyRemovalPolicy(policy);\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "truemark-cdk-lib",
|
|
3
3
|
"description": "AWS CDK constructs created by TrueMark",
|
|
4
|
-
"version": "1.19.
|
|
4
|
+
"version": "1.19.4-alpha.1754300585",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"types": "index.d.ts",
|
|
7
7
|
"author": "TrueMark Technologies, Inc.",
|
|
@@ -45,7 +45,10 @@
|
|
|
45
45
|
"cdk-monitoring-constructs": "9.5.0",
|
|
46
46
|
"constructs": "10.4.2",
|
|
47
47
|
"typescript": "~5.8.2",
|
|
48
|
-
"typescript-eslint": "^8.28.0"
|
|
48
|
+
"typescript-eslint": "^8.28.0",
|
|
49
|
+
"@opentelemetry/api": "^1.8.0",
|
|
50
|
+
"@opentelemetry/resources": "^1.21.0",
|
|
51
|
+
"@opentelemetry/semantic-conventions": "^1.21.0"
|
|
49
52
|
},
|
|
50
53
|
"peerDependencies": {
|
|
51
54
|
"@aws-cdk/aws-lambda-go-alpha": "^2.186.0-alpha.0",
|