@spytecgps/lambda-utils 1.0.19 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -1
- package/dist/errors/index.d.ts +2 -2
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -19
- package/dist/logger/index.d.ts +4 -0
- package/dist/middleware/index.d.ts +1 -1
- package/dist/middleware/types.d.ts +2 -2
- package/dist/types.d.ts +12 -12
- package/dist/validation/custom.d.ts +1 -0
- package/dist/validation/index.d.ts +2 -1
- package/dist/validation/requestContext.d.ts +1 -1
- package/dist/wrappers/sqsEventWrapper.d.ts +2 -2
- package/package.json +33 -33
- package/dist/errors/BadRequestError.js +0 -28
- package/dist/errors/ConflictError.js +0 -28
- package/dist/errors/ForbiddenError.js +0 -28
- package/dist/errors/HttpError.js +0 -32
- package/dist/errors/NotFoundError.js +0 -28
- package/dist/errors/UnauthorizedError.js +0 -28
- package/dist/errors/index.js +0 -16
- package/dist/logger/logger.d.ts +0 -3
- package/dist/logger/logger.js +0 -51
- package/dist/middleware/contextualLogger.js +0 -87
- package/dist/middleware/index.js +0 -62
- package/dist/middleware/ioLogger.js +0 -14
- package/dist/middleware/middleware.test.js +0 -167
- package/dist/middleware/responseWrapper.js +0 -12
- package/dist/middleware/types.js +0 -2
- package/dist/middleware/validation.js +0 -27
- package/dist/types.js +0 -2
- package/dist/utils/cache.js +0 -58
- package/dist/utils/cacheWrapper.js +0 -55
- package/dist/utils/index.js +0 -17
- package/dist/utils/timeOut.js +0 -15
- package/dist/validation/custom.js +0 -143
- package/dist/validation/index.js +0 -25
- package/dist/validation/requestContext.js +0 -54
- package/dist/validation/validateEvent.js +0 -25
- package/dist/wrappers/apiGatewayEventWrapper.js +0 -79
- package/dist/wrappers/index.js +0 -21
- package/dist/wrappers/response.js +0 -36
- package/dist/wrappers/sqsEventWrapper.js +0 -120
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
var errors_1 = require("../errors");
|
|
4
|
-
var sdk_1 = require("@spytecgps/sdk");
|
|
5
|
-
var validateEvent = function (event, schema, validateOptions) {
|
|
6
|
-
if (!schema) {
|
|
7
|
-
sdk_1.logger.warn("skipping validation");
|
|
8
|
-
return event;
|
|
9
|
-
}
|
|
10
|
-
var _a = schema.validate(event, {
|
|
11
|
-
allowUnknown: (validateOptions === null || validateOptions === void 0 ? void 0 : validateOptions.allowUnknown) || true,
|
|
12
|
-
errors: {
|
|
13
|
-
label: 'key',
|
|
14
|
-
wrap: {
|
|
15
|
-
label: false,
|
|
16
|
-
},
|
|
17
|
-
},
|
|
18
|
-
}), error = _a.error, value = _a.value;
|
|
19
|
-
if (error) {
|
|
20
|
-
sdk_1.logger.error({ error: error }, 'Validation error');
|
|
21
|
-
throw error.isJoi ? new errors_1.BadRequestError(error.message) : error;
|
|
22
|
-
}
|
|
23
|
-
return value;
|
|
24
|
-
};
|
|
25
|
-
exports.default = validateEvent;
|
|
@@ -1,79 +0,0 @@
|
|
|
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 (_) 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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
var validation_1 = require("../validation");
|
|
40
|
-
var response_1 = require("./response");
|
|
41
|
-
var sdk_1 = require("@spytecgps/sdk");
|
|
42
|
-
var logEvent = function (e) { return ({
|
|
43
|
-
resource: e.resource,
|
|
44
|
-
httpMethod: e.httpMethod,
|
|
45
|
-
queryStringParameters: e.queryStringParameters,
|
|
46
|
-
pathParameters: e.pathParameters,
|
|
47
|
-
body: e.body,
|
|
48
|
-
}); };
|
|
49
|
-
var apiGatewayEventWrapper = function (_a) {
|
|
50
|
-
var event = _a.event, context = _a.context, schema = _a.schema, handler = _a.handler;
|
|
51
|
-
return __awaiter(void 0, void 0, void 0, function () {
|
|
52
|
-
var validatedEvent, result, err_1;
|
|
53
|
-
return __generator(this, function (_b) {
|
|
54
|
-
switch (_b.label) {
|
|
55
|
-
case 0:
|
|
56
|
-
if (event && context) {
|
|
57
|
-
sdk_1.logger.withRequest(event, context);
|
|
58
|
-
}
|
|
59
|
-
_b.label = 1;
|
|
60
|
-
case 1:
|
|
61
|
-
_b.trys.push([1, 3, , 4]);
|
|
62
|
-
validatedEvent = validation_1.validateEvent(event, schema);
|
|
63
|
-
return [4 /*yield*/, handler(validatedEvent)];
|
|
64
|
-
case 2:
|
|
65
|
-
result = _b.sent();
|
|
66
|
-
return [2 /*return*/, response_1.buildProxyResult(result)];
|
|
67
|
-
case 3:
|
|
68
|
-
err_1 = _b.sent();
|
|
69
|
-
sdk_1.logger.error({ err: err_1, event: logEvent(event) }, "apiGatewayWrapper - caught error");
|
|
70
|
-
return [2 /*return*/, response_1.buildProxyResult({
|
|
71
|
-
statusCode: err_1.code || 500,
|
|
72
|
-
message: err_1.message || 'Error',
|
|
73
|
-
})];
|
|
74
|
-
case 4: return [2 /*return*/];
|
|
75
|
-
}
|
|
76
|
-
});
|
|
77
|
-
});
|
|
78
|
-
};
|
|
79
|
-
exports.default = apiGatewayEventWrapper;
|
package/dist/wrappers/index.js
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
-
for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);
|
|
11
|
-
};
|
|
12
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
13
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
14
|
-
};
|
|
15
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
-
exports.sqsEventWrapper = exports.apiGatewayEventWrapper = void 0;
|
|
17
|
-
var apiGatewayEventWrapper_1 = __importDefault(require("./apiGatewayEventWrapper"));
|
|
18
|
-
exports.apiGatewayEventWrapper = apiGatewayEventWrapper_1.default;
|
|
19
|
-
var sqsEventWrapper_1 = __importDefault(require("./sqsEventWrapper"));
|
|
20
|
-
exports.sqsEventWrapper = sqsEventWrapper_1.default;
|
|
21
|
-
__exportStar(require("./response"), exports);
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __assign = (this && this.__assign) || function () {
|
|
3
|
-
__assign = Object.assign || function(t) {
|
|
4
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
-
s = arguments[i];
|
|
6
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
-
t[p] = s[p];
|
|
8
|
-
}
|
|
9
|
-
return t;
|
|
10
|
-
};
|
|
11
|
-
return __assign.apply(this, arguments);
|
|
12
|
-
};
|
|
13
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
-
exports.buildProxyResult = exports.buildResponseBody = void 0;
|
|
15
|
-
var baseHeaders = {
|
|
16
|
-
'Content-Type': 'application/json',
|
|
17
|
-
'Access-Control-Allow-Origin': '*',
|
|
18
|
-
'Access-Control-Allow-Credentials': true,
|
|
19
|
-
};
|
|
20
|
-
exports.buildResponseBody = function (statusCode, message, data) {
|
|
21
|
-
return {
|
|
22
|
-
success: statusCode < 400,
|
|
23
|
-
message: message,
|
|
24
|
-
result: data ? data : undefined,
|
|
25
|
-
};
|
|
26
|
-
};
|
|
27
|
-
exports.buildProxyResult = function (_a) {
|
|
28
|
-
var _b = _a.statusCode, statusCode = _b === void 0 ? 200 : _b, _c = _a.message, message = _c === void 0 ? 'ok' : _c, data = _a.data, _d = _a.headers, headers = _d === void 0 ? {} : _d, _e = _a.rawResult, rawResult = _e === void 0 ? false : _e, _f = _a.stringifyBody, stringifyBody = _f === void 0 ? true : _f;
|
|
29
|
-
var resp = rawResult ? data : exports.buildResponseBody(statusCode, message, data);
|
|
30
|
-
var body = stringifyBody ? resp && JSON.stringify(resp) : data;
|
|
31
|
-
return {
|
|
32
|
-
headers: __assign(__assign({}, baseHeaders), headers),
|
|
33
|
-
statusCode: statusCode,
|
|
34
|
-
body: body,
|
|
35
|
-
};
|
|
36
|
-
};
|
|
@@ -1,120 +0,0 @@
|
|
|
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 (_) 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
|
-
var validateEvent_1 = __importDefault(require("../validation/validateEvent"));
|
|
43
|
-
var sdk_1 = require("@spytecgps/sdk");
|
|
44
|
-
var logEvent = function (e) {
|
|
45
|
-
return (e.Records || []).map(function (record) { return ({
|
|
46
|
-
messageId: record.messageId,
|
|
47
|
-
body: record.body,
|
|
48
|
-
messageAttributes: record.messageAttributes,
|
|
49
|
-
}); });
|
|
50
|
-
};
|
|
51
|
-
function processEvent(validatedEvent, handler, singleHandler, mode) {
|
|
52
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
53
|
-
var records, _i, records_1, record;
|
|
54
|
-
return __generator(this, function (_a) {
|
|
55
|
-
switch (_a.label) {
|
|
56
|
-
case 0:
|
|
57
|
-
if (!(handler || singleHandler)) {
|
|
58
|
-
throw new Error("handler or singleHandler not defined");
|
|
59
|
-
}
|
|
60
|
-
if (!handler) return [3 /*break*/, 2];
|
|
61
|
-
return [4 /*yield*/, handler(validatedEvent)];
|
|
62
|
-
case 1:
|
|
63
|
-
_a.sent();
|
|
64
|
-
return [3 /*break*/, 9];
|
|
65
|
-
case 2:
|
|
66
|
-
if (!singleHandler) return [3 /*break*/, 9];
|
|
67
|
-
records = validatedEvent.Records;
|
|
68
|
-
if (!(mode === 'serial')) return [3 /*break*/, 7];
|
|
69
|
-
_i = 0, records_1 = records;
|
|
70
|
-
_a.label = 3;
|
|
71
|
-
case 3:
|
|
72
|
-
if (!(_i < records_1.length)) return [3 /*break*/, 6];
|
|
73
|
-
record = records_1[_i];
|
|
74
|
-
return [4 /*yield*/, singleHandler(record)];
|
|
75
|
-
case 4:
|
|
76
|
-
_a.sent();
|
|
77
|
-
_a.label = 5;
|
|
78
|
-
case 5:
|
|
79
|
-
_i++;
|
|
80
|
-
return [3 /*break*/, 3];
|
|
81
|
-
case 6: return [3 /*break*/, 9];
|
|
82
|
-
case 7:
|
|
83
|
-
if (!(mode === 'parallel')) return [3 /*break*/, 9];
|
|
84
|
-
return [4 /*yield*/, Promise.all(records.map(function (record) { return singleHandler(record); }))];
|
|
85
|
-
case 8:
|
|
86
|
-
_a.sent();
|
|
87
|
-
_a.label = 9;
|
|
88
|
-
case 9: return [2 /*return*/];
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
var sqsEventWrapper = function (_a) {
|
|
94
|
-
var event = _a.event, context = _a.context, schema = _a.schema, handler = _a.handler, singleHandler = _a.singleHandler, _b = _a.mode, mode = _b === void 0 ? 'serial' : _b;
|
|
95
|
-
return __awaiter(void 0, void 0, void 0, function () {
|
|
96
|
-
var validatedEvent, err_1;
|
|
97
|
-
return __generator(this, function (_c) {
|
|
98
|
-
switch (_c.label) {
|
|
99
|
-
case 0:
|
|
100
|
-
if (event && context) {
|
|
101
|
-
sdk_1.logger.withRequest(event, context);
|
|
102
|
-
}
|
|
103
|
-
_c.label = 1;
|
|
104
|
-
case 1:
|
|
105
|
-
_c.trys.push([1, 3, , 4]);
|
|
106
|
-
validatedEvent = validateEvent_1.default(event, schema);
|
|
107
|
-
return [4 /*yield*/, processEvent(validatedEvent, handler, singleHandler, mode)];
|
|
108
|
-
case 2:
|
|
109
|
-
_c.sent();
|
|
110
|
-
return [3 /*break*/, 4];
|
|
111
|
-
case 3:
|
|
112
|
-
err_1 = _c.sent();
|
|
113
|
-
sdk_1.logger.error({ err: err_1, event: logEvent(event) }, "sqsEventWrapper - caught error");
|
|
114
|
-
throw err_1;
|
|
115
|
-
case 4: return [2 /*return*/];
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
};
|
|
120
|
-
exports.default = sqsEventWrapper;
|