@fintalk.ai/lambda-handlers 1.0.4 → 2.1.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.
Files changed (115) hide show
  1. package/README.md +62 -20
  2. package/lib/errors/bad-request-error.d.ts +1 -1
  3. package/lib/errors/bad-request-error.js +3 -2
  4. package/lib/errors/bad-request-error.js.map +1 -1
  5. package/lib/errors/conflict-error.d.ts +1 -1
  6. package/lib/errors/conflict-error.js +4 -2
  7. package/lib/errors/conflict-error.js.map +1 -1
  8. package/lib/errors/fintalk-error.d.ts +11 -6
  9. package/lib/errors/fintalk-error.js +3 -2
  10. package/lib/errors/fintalk-error.js.map +1 -1
  11. package/lib/errors/forbidden-error.d.ts +1 -1
  12. package/lib/errors/forbidden-error.js +4 -2
  13. package/lib/errors/forbidden-error.js.map +1 -1
  14. package/lib/errors/gone-error.d.ts +1 -1
  15. package/lib/errors/gone-error.js +4 -2
  16. package/lib/errors/gone-error.js.map +1 -1
  17. package/lib/errors/internal-server-error.d.ts +1 -1
  18. package/lib/errors/internal-server-error.js +4 -2
  19. package/lib/errors/internal-server-error.js.map +1 -1
  20. package/lib/errors/not-acceptable-error.d.ts +1 -1
  21. package/lib/errors/not-acceptable-error.js +4 -2
  22. package/lib/errors/not-acceptable-error.js.map +1 -1
  23. package/lib/errors/not-found-error.d.ts +1 -1
  24. package/lib/errors/not-found-error.js +4 -2
  25. package/lib/errors/not-found-error.js.map +1 -1
  26. package/lib/errors/payment-required-error.d.ts +1 -1
  27. package/lib/errors/payment-required-error.js +4 -2
  28. package/lib/errors/payment-required-error.js.map +1 -1
  29. package/lib/errors/precondition-failed-error.d.ts +1 -1
  30. package/lib/errors/precondition-failed-error.js +4 -2
  31. package/lib/errors/precondition-failed-error.js.map +1 -1
  32. package/lib/errors/service-unavailable-error.d.ts +1 -1
  33. package/lib/errors/service-unavailable-error.js +4 -2
  34. package/lib/errors/service-unavailable-error.js.map +1 -1
  35. package/lib/errors/teapot-error.d.ts +1 -1
  36. package/lib/errors/teapot-error.js +4 -2
  37. package/lib/errors/teapot-error.js.map +1 -1
  38. package/lib/errors/too-many-requests-error.d.ts +1 -1
  39. package/lib/errors/too-many-requests-error.js +4 -2
  40. package/lib/errors/too-many-requests-error.js.map +1 -1
  41. package/lib/errors/unauthorized-error.d.ts +1 -1
  42. package/lib/errors/unauthorized-error.js +4 -2
  43. package/lib/errors/unauthorized-error.js.map +1 -1
  44. package/lib/errors/unprocessable-entity-error.d.ts +1 -1
  45. package/lib/errors/unprocessable-entity-error.js +4 -3
  46. package/lib/errors/unprocessable-entity-error.js.map +1 -1
  47. package/lib/errors/websocket-error.d.ts +40 -0
  48. package/lib/errors/websocket-error.js +54 -0
  49. package/lib/errors/websocket-error.js.map +1 -0
  50. package/lib/handlers/api-proxy.js +150 -56
  51. package/lib/handlers/api-proxy.js.map +1 -1
  52. package/lib/handlers/api.d.ts +5 -1
  53. package/lib/handlers/api.js +130 -38
  54. package/lib/handlers/api.js.map +1 -1
  55. package/lib/handlers/authorizer.d.ts +7 -0
  56. package/lib/handlers/authorizer.js +181 -0
  57. package/lib/handlers/authorizer.js.map +1 -0
  58. package/lib/handlers/cloudwatch.d.ts +7 -0
  59. package/lib/handlers/cloudwatch.js +143 -0
  60. package/lib/handlers/cloudwatch.js.map +1 -0
  61. package/lib/handlers/invoke.d.ts +7 -1
  62. package/lib/handlers/invoke.js +101 -26
  63. package/lib/handlers/invoke.js.map +1 -1
  64. package/lib/handlers/kinesis.d.ts +13 -0
  65. package/lib/handlers/kinesis.js +193 -0
  66. package/lib/handlers/kinesis.js.map +1 -0
  67. package/lib/handlers/lambda-proxy/index.d.ts +8 -0
  68. package/lib/handlers/lambda-proxy/index.js +182 -0
  69. package/lib/handlers/lambda-proxy/index.js.map +1 -0
  70. package/lib/handlers/lambda-proxy/validate-event-data.d.ts +3 -0
  71. package/lib/handlers/lambda-proxy/validate-event-data.js +26 -0
  72. package/lib/handlers/lambda-proxy/validate-event-data.js.map +1 -0
  73. package/lib/handlers/sqs-v2.d.ts +5 -3
  74. package/lib/handlers/sqs-v2.js +109 -22
  75. package/lib/handlers/sqs-v2.js.map +1 -1
  76. package/lib/handlers/sqs.d.ts +11 -2
  77. package/lib/handlers/sqs.js +118 -16
  78. package/lib/handlers/sqs.js.map +1 -1
  79. package/lib/index.d.ts +4 -0
  80. package/lib/index.js +9 -1
  81. package/lib/index.js.map +1 -1
  82. package/lib/models.d.ts +8 -2
  83. package/lib/utils/check-envs.d.ts +3 -0
  84. package/lib/utils/check-envs.js +14 -0
  85. package/lib/utils/check-envs.js.map +1 -0
  86. package/lib/utils/convert-query-string.d.ts +3 -0
  87. package/lib/utils/convert-query-string.js +18 -0
  88. package/lib/utils/convert-query-string.js.map +1 -0
  89. package/lib/utils/extract-queue-name.d.ts +2 -0
  90. package/lib/utils/extract-queue-name.js +9 -0
  91. package/lib/utils/extract-queue-name.js.map +1 -0
  92. package/lib/utils/find-path.d.ts +2 -0
  93. package/lib/utils/find-path.js +14 -0
  94. package/lib/utils/find-path.js.map +1 -0
  95. package/lib/utils/kinesis-parse.d.ts +2 -0
  96. package/lib/utils/kinesis-parse.js +14 -0
  97. package/lib/utils/kinesis-parse.js.map +1 -0
  98. package/lib/utils/lower-case-headers.d.ts +2 -2
  99. package/lib/utils/lower-case-headers.js.map +1 -1
  100. package/lib/utils/parse-authorizer-request.d.ts +4 -0
  101. package/lib/utils/parse-authorizer-request.js +32 -0
  102. package/lib/utils/parse-authorizer-request.js.map +1 -0
  103. package/lib/utils/parse-path-params.d.ts +2 -0
  104. package/lib/utils/parse-path-params.js +14 -0
  105. package/lib/utils/parse-path-params.js.map +1 -0
  106. package/lib/utils/parse-request.d.ts +0 -1
  107. package/lib/utils/parse-request.js +3 -12
  108. package/lib/utils/parse-request.js.map +1 -1
  109. package/lib/utils/provider-flush.d.ts +4 -0
  110. package/lib/utils/provider-flush.js +81 -0
  111. package/lib/utils/provider-flush.js.map +1 -0
  112. package/lib/utils/sleep.d.ts +2 -0
  113. package/lib/utils/sleep.js +7 -0
  114. package/lib/utils/sleep.js.map +1 -0
  115. package/package.json +26 -34
@@ -0,0 +1,193 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
18
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.LambdaKinesisHandler = void 0;
43
+ var api_1 = require("@opentelemetry/api");
44
+ var core_1 = require("@opentelemetry/core");
45
+ var semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
46
+ var otlp_1 = require("@stone-ton/otlp");
47
+ var buffer_1 = require("buffer");
48
+ var logger_1 = __importDefault(require("fintalk-logger/lib/logger"));
49
+ var check_envs_1 = __importDefault(require("../utils/check-envs"));
50
+ var extract_queue_name_1 = __importDefault(require("../utils/extract-queue-name"));
51
+ var kinesis_parse_1 = __importDefault(require("../utils/kinesis-parse"));
52
+ var provider_flush_1 = __importDefault(require("../utils/provider-flush"));
53
+ var LambdaKinesisHandler = (function () {
54
+ function LambdaKinesisHandler(options) {
55
+ this.options = options;
56
+ }
57
+ LambdaKinesisHandler.prototype.executeWorker = function (record, context) {
58
+ return __awaiter(this, void 0, void 0, function () {
59
+ var logger, parseResult;
60
+ var _this = this;
61
+ return __generator(this, function (_a) {
62
+ logger = new logger_1.default();
63
+ logger.resetConfig();
64
+ logger.setService(this.options.service);
65
+ (0, check_envs_1.default)(logger);
66
+ parseResult = (0, kinesis_parse_1.default)(record.kinesis.data);
67
+ return [2, otlp_1.tracer.startActiveSpan('handler', {
68
+ kind: api_1.SpanKind.CONSUMER,
69
+ startTime: (0, core_1.hrTime)(),
70
+ }, function (span) { return __awaiter(_this, void 0, void 0, function () {
71
+ var spanContext, remainingTimeInMillis, timeout, error_1;
72
+ var _a;
73
+ return __generator(this, function (_b) {
74
+ switch (_b.label) {
75
+ case 0:
76
+ spanContext = span.spanContext();
77
+ logger.setCustomArgs({
78
+ dd: {
79
+ trace_id: spanContext.traceId,
80
+ span_id: spanContext.spanId,
81
+ },
82
+ });
83
+ remainingTimeInMillis = context.getRemainingTimeInMillis();
84
+ timeout = setTimeout(function () {
85
+ span.setStatus({
86
+ code: api_1.SpanStatusCode.ERROR,
87
+ message: 'Detected an impending timeout',
88
+ });
89
+ span.end((0, core_1.hrTime)());
90
+ (0, provider_flush_1.default)(otlp_1.tracerProvider);
91
+ }, remainingTimeInMillis - 100);
92
+ _b.label = 1;
93
+ case 1:
94
+ _b.trys.push([1, 3, 4, 6]);
95
+ if (process.env.OTLP_LAMBDA_DEBUG === 'true') {
96
+ span.setAttributes({
97
+ 'messaging.message.payload': JSON.parse(buffer_1.Buffer.from(record.kinesis.data, 'base64').toString()),
98
+ });
99
+ }
100
+ span.setAttributes((_a = {},
101
+ _a[semantic_conventions_1.SemanticResourceAttributes.CLOUD_REGION] = process.env.AWS_REGION,
102
+ _a[semantic_conventions_1.SemanticResourceAttributes.CLOUD_PLATFORM] = semantic_conventions_1.CloudPlatformValues.AWS_LAMBDA,
103
+ _a['faas.version'] = process.env.AWS_EXECUTION_ENV,
104
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_MAX_MEMORY] = process.env.AWS_LAMBDA_FUNCTION_MEMORY_SIZE,
105
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_NAME] = context.functionName,
106
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_ID] = context.invokedFunctionArn,
107
+ _a[semantic_conventions_1.SemanticAttributes.FAAS_TRIGGER] = semantic_conventions_1.FaasTriggerValues.OTHER,
108
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_SYSTEM] = 'KINESIS',
109
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_OPERATION] = 'receive',
110
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_URL] = record.eventSourceARN,
111
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_DESTINATION] = (0, extract_queue_name_1.default)(record.eventSourceARN),
112
+ _a));
113
+ return [4, this.options.worker({
114
+ id: record.eventID,
115
+ body: parseResult,
116
+ }, logger)];
117
+ case 2:
118
+ _b.sent();
119
+ span.setStatus({ code: api_1.SpanStatusCode.OK });
120
+ return [2, null];
121
+ case 3:
122
+ error_1 = _b.sent();
123
+ span.setStatus({
124
+ code: api_1.SpanStatusCode.ERROR,
125
+ message: error_1.message,
126
+ });
127
+ if (!error_1.isTreated) {
128
+ logger.error(error_1);
129
+ }
130
+ return [2, record.eventID];
131
+ case 4:
132
+ clearTimeout(timeout);
133
+ span.end((0, core_1.hrTime)());
134
+ return [4, (0, provider_flush_1.default)(otlp_1.tracerProvider)];
135
+ case 5:
136
+ _b.sent();
137
+ return [7];
138
+ case 6: return [2];
139
+ }
140
+ });
141
+ }); })];
142
+ });
143
+ });
144
+ };
145
+ LambdaKinesisHandler.prototype.handler = function (event, context) {
146
+ return __awaiter(this, void 0, void 0, function () {
147
+ var failures, results, _i, _a, record, result;
148
+ var _this = this;
149
+ return __generator(this, function (_b) {
150
+ switch (_b.label) {
151
+ case 0:
152
+ failures = [];
153
+ if (!this.options.parallel) return [3, 2];
154
+ return [4, Promise.all(event.Records.map(function (record) {
155
+ return _this.executeWorker(record, context);
156
+ }))];
157
+ case 1:
158
+ results = _b.sent();
159
+ results.forEach(function (result) {
160
+ if (result !== null) {
161
+ failures.push(result);
162
+ }
163
+ });
164
+ return [3, 6];
165
+ case 2:
166
+ _i = 0, _a = event.Records;
167
+ _b.label = 3;
168
+ case 3:
169
+ if (!(_i < _a.length)) return [3, 6];
170
+ record = _a[_i];
171
+ return [4, this.executeWorker(record, context)];
172
+ case 4:
173
+ result = _b.sent();
174
+ if (result !== null) {
175
+ failures.push(result);
176
+ }
177
+ _b.label = 5;
178
+ case 5:
179
+ _i++;
180
+ return [3, 3];
181
+ case 6: return [2, {
182
+ batchItemFailures: failures.map(function (result) { return ({
183
+ itemIdentifier: result,
184
+ }); }),
185
+ }];
186
+ }
187
+ });
188
+ });
189
+ };
190
+ return LambdaKinesisHandler;
191
+ }());
192
+ exports.LambdaKinesisHandler = LambdaKinesisHandler;
193
+ //# sourceMappingURL=kinesis.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kinesis.js","sourceRoot":"","sources":["../../src/handlers/kinesis.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import { Context } from 'aws-lambda';
2
+ import { Request, Route } from '../../models';
3
+ export declare class LambdaProxyHandler {
4
+ readonly routes: Route[];
5
+ addRoute(route: Route): void;
6
+ findRoute(eventPath: string, eventMethod: string): Route | undefined;
7
+ handler(event: Request, context: Context): Promise<any>;
8
+ }
@@ -0,0 +1,182 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
18
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.LambdaProxyHandler = void 0;
43
+ var api_1 = require("@opentelemetry/api");
44
+ var core_1 = require("@opentelemetry/core");
45
+ var semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
46
+ var otlp_1 = require("@stone-ton/otlp");
47
+ var fintalk_logger_1 = __importDefault(require("fintalk-logger"));
48
+ var not_found_error_1 = __importDefault(require("../../errors/not-found-error"));
49
+ var check_envs_1 = __importDefault(require("../../utils/check-envs"));
50
+ var find_path_1 = __importDefault(require("../../utils/find-path"));
51
+ var provider_flush_1 = __importDefault(require("../../utils/provider-flush"));
52
+ var validate_event_data_1 = __importDefault(require("./validate-event-data"));
53
+ var LambdaProxyHandler = (function () {
54
+ function LambdaProxyHandler() {
55
+ this.routes = [];
56
+ }
57
+ LambdaProxyHandler.prototype.addRoute = function (route) {
58
+ this.routes.push(route);
59
+ };
60
+ LambdaProxyHandler.prototype.findRoute = function (eventPath, eventMethod) {
61
+ return this.routes.find(function (_a) {
62
+ var path = _a.path, method = _a.method;
63
+ return (0, find_path_1.default)(path, method, eventPath, eventMethod);
64
+ });
65
+ };
66
+ LambdaProxyHandler.prototype.handler = function (event, context) {
67
+ return __awaiter(this, void 0, void 0, function () {
68
+ var activeContext;
69
+ var _this = this;
70
+ return __generator(this, function (_a) {
71
+ (0, check_envs_1.default)(fintalk_logger_1.default);
72
+ activeContext = api_1.propagation.extract(api_1.context.active(), {
73
+ traceparent: event.traceparent,
74
+ });
75
+ return [2, otlp_1.tracer.startActiveSpan('handler', {
76
+ kind: api_1.SpanKind.SERVER,
77
+ startTime: (0, core_1.hrTime)(),
78
+ }, activeContext, function (span) { return __awaiter(_this, void 0, void 0, function () {
79
+ var remainingTimeInMillis, timeout, spanContext, eventData, route, response, error_1;
80
+ var _a;
81
+ var _b;
82
+ return __generator(this, function (_c) {
83
+ switch (_c.label) {
84
+ case 0:
85
+ remainingTimeInMillis = context.getRemainingTimeInMillis();
86
+ timeout = setTimeout(function () {
87
+ span.setStatus({
88
+ code: api_1.SpanStatusCode.ERROR,
89
+ message: 'Detected an impending timeout',
90
+ });
91
+ span.end((0, core_1.hrTime)());
92
+ (0, provider_flush_1.default)(otlp_1.tracerProvider);
93
+ }, remainingTimeInMillis - 100);
94
+ _c.label = 1;
95
+ case 1:
96
+ _c.trys.push([1, 3, 4, 6]);
97
+ spanContext = span.spanContext();
98
+ fintalk_logger_1.default.setCustomArgs({
99
+ dd: {
100
+ trace_id: spanContext.traceId,
101
+ span_id: spanContext.spanId,
102
+ },
103
+ });
104
+ span.setAttributes((_a = {},
105
+ _a[semantic_conventions_1.SemanticResourceAttributes.CLOUD_REGION] = process.env.AWS_REGION,
106
+ _a[semantic_conventions_1.SemanticResourceAttributes.CLOUD_PLATFORM] = semantic_conventions_1.CloudPlatformValues.AWS_LAMBDA,
107
+ _a['faas.version'] = process.env.AWS_EXECUTION_ENV,
108
+ _a[semantic_conventions_1.SemanticAttributes.FAAS_EXECUTION] = event.id,
109
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_MAX_MEMORY] = process.env.AWS_LAMBDA_FUNCTION_MEMORY_SIZE,
110
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_NAME] = context.functionName,
111
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_ID] = context.invokedFunctionArn,
112
+ _a[semantic_conventions_1.SemanticAttributes.FAAS_TRIGGER] = semantic_conventions_1.FaasTriggerValues.OTHER,
113
+ _a[semantic_conventions_1.SemanticAttributes.HTTP_ROUTE] = event.path,
114
+ _a.user_id = (_b = event.user) === null || _b === void 0 ? void 0 : _b.id,
115
+ _a));
116
+ if (process.env.OTLP_LAMBDA_DEBUG === 'true') {
117
+ span.setAttributes({
118
+ 'http.request.body': JSON.stringify(event.body),
119
+ 'http.request.headers': JSON.stringify(event.headers),
120
+ });
121
+ }
122
+ eventData = (0, validate_event_data_1.default)(event);
123
+ route = this.findRoute(eventData.path, eventData.method);
124
+ if (!route) {
125
+ fintalk_logger_1.default.warn({
126
+ message: 'Route not found',
127
+ path: event.path,
128
+ });
129
+ throw new not_found_error_1.default('Route not found');
130
+ }
131
+ return [4, route.run(eventData, context)];
132
+ case 2:
133
+ response = _c.sent();
134
+ if (process.env.OTLP_LAMBDA_DEBUG === 'true') {
135
+ span.setAttributes({
136
+ 'http.response.body': JSON.stringify(response),
137
+ });
138
+ }
139
+ span.setStatus({ code: api_1.SpanStatusCode.OK });
140
+ return [2, response];
141
+ case 3:
142
+ error_1 = _c.sent();
143
+ span.setAttributes({
144
+ 'exception.message': error_1.message,
145
+ 'exception.stacktrace': error_1.trace,
146
+ });
147
+ span.setStatus({
148
+ code: api_1.SpanStatusCode.ERROR,
149
+ message: error_1.message,
150
+ });
151
+ if (error_1.isTreated) {
152
+ return [2, {
153
+ success: false,
154
+ error: error_1.toObject(),
155
+ }];
156
+ }
157
+ fintalk_logger_1.default.error(error_1);
158
+ return [2, {
159
+ success: false,
160
+ error: {
161
+ message: error_1.message,
162
+ code: error_1.code,
163
+ },
164
+ }];
165
+ case 4:
166
+ clearTimeout(timeout);
167
+ span.end((0, core_1.hrTime)());
168
+ return [4, (0, provider_flush_1.default)(otlp_1.tracerProvider)];
169
+ case 5:
170
+ _c.sent();
171
+ return [7];
172
+ case 6: return [2];
173
+ }
174
+ });
175
+ }); })];
176
+ });
177
+ });
178
+ };
179
+ return LambdaProxyHandler;
180
+ }());
181
+ exports.LambdaProxyHandler = LambdaProxyHandler;
182
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/handlers/lambda-proxy/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Request } from '../../models';
2
+ declare const validateEventData: (data: Request) => Request;
3
+ export default validateEventData;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ var fintalk_logger_1 = __importDefault(require("fintalk-logger"));
7
+ var bad_request_error_1 = __importDefault(require("../../errors/bad-request-error"));
8
+ var validateEventData = function (data) {
9
+ if (!data.path) {
10
+ fintalk_logger_1.default.warn({
11
+ message: 'missing field "path"',
12
+ data: data,
13
+ });
14
+ throw new bad_request_error_1.default('missing field "path"');
15
+ }
16
+ if (!data.method) {
17
+ fintalk_logger_1.default.warn({
18
+ message: 'missing field "method"',
19
+ data: data,
20
+ });
21
+ throw new bad_request_error_1.default('missing field "method"');
22
+ }
23
+ return data;
24
+ };
25
+ exports.default = validateEventData;
26
+ //# sourceMappingURL=validate-event-data.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate-event-data.js","sourceRoot":"","sources":["../../../src/handlers/lambda-proxy/validate-event-data.ts"],"names":[],"mappings":";;;;;AAAA,kEAAmC;AAEnC,qFAA4D;AAG5D,IAAM,iBAAiB,GAAG,UACxB,IAAa;IAEb,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;QACd,wBAAM,CAAC,IAAI,CAAC;YACV,OAAO,EAAE,sBAAsB;YAC/B,IAAI,MAAA;SACL,CAAC,CAAA;QACF,MAAM,IAAI,2BAAe,CAAC,sBAAsB,CAAC,CAAA;KAClD;IAED,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;QAChB,wBAAM,CAAC,IAAI,CAAC;YACV,OAAO,EAAE,wBAAwB;YACjC,IAAI,MAAA;SACL,CAAC,CAAA;QACF,MAAM,IAAI,2BAAe,CAAC,wBAAwB,CAAC,CAAA;KACpD;IAED,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAED,kBAAe,iBAAiB,CAAA"}
@@ -1,4 +1,4 @@
1
- import { SQSBatchResponse, SQSEvent, SQSRecord } from 'aws-lambda';
1
+ import { Context, SQSBatchResponse, SQSEvent, SQSRecord } from 'aws-lambda';
2
2
  import Logger from 'fintalk-logger/lib/logger';
3
3
  import { WorkerV2 } from '../models';
4
4
  export interface LambdaSqsHandlerV2Options {
@@ -12,10 +12,12 @@ export declare class LambdaSqsHandlerV2 {
12
12
  parseBody(body: string, logger: Logger): {
13
13
  success: boolean;
14
14
  data: any;
15
+ error?: undefined;
15
16
  } | {
16
17
  success: boolean;
18
+ error: any;
17
19
  data?: undefined;
18
20
  };
19
- executeWorker(record: SQSRecord): Promise<string | null>;
20
- handler(event: SQSEvent): Promise<SQSBatchResponse>;
21
+ executeWorker(record: SQSRecord, context: Context): Promise<string | null>;
22
+ handler(event: SQSEvent, context: Context): Promise<SQSBatchResponse>;
21
23
  }
@@ -40,7 +40,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
40
40
  };
41
41
  Object.defineProperty(exports, "__esModule", { value: true });
42
42
  exports.LambdaSqsHandlerV2 = void 0;
43
+ var api_1 = require("@opentelemetry/api");
44
+ var core_1 = require("@opentelemetry/core");
45
+ var semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
46
+ var otlp_1 = require("@stone-ton/otlp");
43
47
  var logger_1 = __importDefault(require("fintalk-logger/lib/logger"));
48
+ var check_envs_1 = __importDefault(require("../utils/check-envs"));
49
+ var extract_queue_name_1 = __importDefault(require("../utils/extract-queue-name"));
50
+ var provider_flush_1 = __importDefault(require("../utils/provider-flush"));
44
51
  var LambdaSqsHandlerV2 = (function () {
45
52
  function LambdaSqsHandlerV2(options) {
46
53
  this.options = options;
@@ -56,40 +63,120 @@ var LambdaSqsHandlerV2 = (function () {
56
63
  logger.error(error);
57
64
  return {
58
65
  success: false,
66
+ error: error,
59
67
  };
60
68
  }
61
69
  };
62
- LambdaSqsHandlerV2.prototype.executeWorker = function (record) {
70
+ LambdaSqsHandlerV2.prototype.executeWorker = function (record, context) {
63
71
  return __awaiter(this, void 0, void 0, function () {
64
- var logger, parseResult, body;
72
+ var logger, parseResult, traceparent, activeContext;
73
+ var _this = this;
65
74
  return __generator(this, function (_a) {
66
75
  logger = new logger_1.default();
67
76
  logger.resetConfig();
68
77
  logger.setService(this.options.service);
78
+ (0, check_envs_1.default)(logger);
69
79
  parseResult = this.parseBody(record.body, logger);
70
- if (!parseResult.success) {
71
- return [2, record.messageId];
80
+ if (parseResult.success) {
81
+ traceparent = parseResult.data.traceparent;
72
82
  }
73
- body = parseResult.data;
74
- logger.setRequestId(body.request_id);
75
- logger.setUser({
76
- id: body.user_id,
83
+ activeContext = api_1.propagation.extract(api_1.context.active(), {
84
+ traceparent: traceparent,
77
85
  });
78
- return [2, this.options.worker({
79
- id: record.messageId,
80
- body: body,
81
- }, logger)
82
- .then(function () { return null; })
83
- .catch(function (error) {
84
- if (!error.isTreated) {
85
- logger.error(error);
86
- }
87
- return record.messageId;
88
- })];
86
+ return [2, otlp_1.tracer.startActiveSpan('handler', {
87
+ kind: api_1.SpanKind.CONSUMER,
88
+ startTime: (0, core_1.hrTime)(),
89
+ }, activeContext, function (span) { return __awaiter(_this, void 0, void 0, function () {
90
+ var spanContext, remainingTimeInMillis, timeout, body, error_1;
91
+ var _a;
92
+ var _b, _c;
93
+ return __generator(this, function (_d) {
94
+ switch (_d.label) {
95
+ case 0:
96
+ spanContext = span.spanContext();
97
+ logger.setCustomArgs({
98
+ dd: {
99
+ trace_id: spanContext.traceId,
100
+ span_id: spanContext.spanId,
101
+ },
102
+ });
103
+ remainingTimeInMillis = context.getRemainingTimeInMillis();
104
+ timeout = setTimeout(function () {
105
+ span.setStatus({
106
+ code: api_1.SpanStatusCode.ERROR,
107
+ message: 'Detected an impending timeout',
108
+ });
109
+ span.end((0, core_1.hrTime)());
110
+ (0, provider_flush_1.default)(otlp_1.tracerProvider);
111
+ }, remainingTimeInMillis - 100);
112
+ _d.label = 1;
113
+ case 1:
114
+ _d.trys.push([1, 3, 4, 6]);
115
+ if (process.env.OTLP_LAMBDA_DEBUG === 'true') {
116
+ span.setAttributes({
117
+ 'messaging.message.payload': JSON.stringify(record.body),
118
+ });
119
+ }
120
+ span.setAttributes((_a = {},
121
+ _a[semantic_conventions_1.SemanticResourceAttributes.CLOUD_REGION] = process.env.AWS_REGION,
122
+ _a[semantic_conventions_1.SemanticResourceAttributes.CLOUD_PLATFORM] = semantic_conventions_1.CloudPlatformValues.AWS_LAMBDA,
123
+ _a['faas.version'] = process.env.AWS_EXECUTION_ENV,
124
+ _a[semantic_conventions_1.SemanticAttributes.FAAS_EXECUTION] = (_b = parseResult.data) === null || _b === void 0 ? void 0 : _b.request_id,
125
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_MAX_MEMORY] = process.env.AWS_LAMBDA_FUNCTION_MEMORY_SIZE,
126
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_NAME] = context.functionName,
127
+ _a[semantic_conventions_1.SemanticResourceAttributes.FAAS_ID] = context.invokedFunctionArn,
128
+ _a[semantic_conventions_1.SemanticAttributes.FAAS_TRIGGER] = semantic_conventions_1.FaasTriggerValues.OTHER,
129
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_SYSTEM] = 'SQS',
130
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_OPERATION] = 'receive',
131
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_URL] = record.eventSourceARN,
132
+ _a[semantic_conventions_1.SemanticAttributes.MESSAGING_DESTINATION] = (0, extract_queue_name_1.default)(record.eventSourceARN),
133
+ _a.user_id = (_c = parseResult.data) === null || _c === void 0 ? void 0 : _c.user_id,
134
+ _a));
135
+ if (!parseResult.success) {
136
+ span.setStatus({
137
+ code: api_1.SpanStatusCode.ERROR,
138
+ message: parseResult.error.message,
139
+ });
140
+ return [2, record.messageId];
141
+ }
142
+ body = parseResult.data;
143
+ logger.setRequestId(body.request_id);
144
+ logger.setUser({
145
+ id: body.user_id,
146
+ });
147
+ return [4, this.options.worker({
148
+ id: record.messageId,
149
+ body: body,
150
+ }, logger)];
151
+ case 2:
152
+ _d.sent();
153
+ span.setStatus({ code: api_1.SpanStatusCode.OK });
154
+ return [2, null];
155
+ case 3:
156
+ error_1 = _d.sent();
157
+ span.setStatus({
158
+ code: api_1.SpanStatusCode.ERROR,
159
+ message: error_1.message,
160
+ });
161
+ if (!error_1.isTreated) {
162
+ logger.error(error_1);
163
+ }
164
+ return [2, record.messageId];
165
+ case 4:
166
+ clearTimeout(timeout);
167
+ span.end((0, core_1.hrTime)());
168
+ return [4, (0, provider_flush_1.default)(otlp_1.tracerProvider)];
169
+ case 5:
170
+ _d.sent();
171
+ return [7];
172
+ case 6: return [2];
173
+ }
174
+ });
175
+ }); })];
89
176
  });
90
177
  });
91
178
  };
92
- LambdaSqsHandlerV2.prototype.handler = function (event) {
179
+ LambdaSqsHandlerV2.prototype.handler = function (event, context) {
93
180
  return __awaiter(this, void 0, void 0, function () {
94
181
  var failures, results, _i, _a, record, result;
95
182
  var _this = this;
@@ -99,7 +186,7 @@ var LambdaSqsHandlerV2 = (function () {
99
186
  failures = [];
100
187
  if (!this.options.parallel) return [3, 2];
101
188
  return [4, Promise.all(event.Records.map(function (record) {
102
- return _this.executeWorker(record);
189
+ return _this.executeWorker(record, context);
103
190
  }))];
104
191
  case 1:
105
192
  results = _b.sent();
@@ -115,7 +202,7 @@ var LambdaSqsHandlerV2 = (function () {
115
202
  case 3:
116
203
  if (!(_i < _a.length)) return [3, 6];
117
204
  record = _a[_i];
118
- return [4, this.executeWorker(record)];
205
+ return [4, this.executeWorker(record, context)];
119
206
  case 4:
120
207
  result = _b.sent();
121
208
  if (result !== null) {