mahameru 0.0.0
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 +28 -0
- package/dist/api.error.cjs +107 -0
- package/dist/api.error.cjs.map +1 -0
- package/dist/api.error.d.cts +65 -0
- package/dist/api.error.d.ts +65 -0
- package/dist/api.error.js +83 -0
- package/dist/api.error.js.map +1 -0
- package/dist/base-class/base.controller.cjs +148 -0
- package/dist/base-class/base.controller.cjs.map +1 -0
- package/dist/base-class/base.controller.d.cts +38 -0
- package/dist/base-class/base.controller.d.ts +38 -0
- package/dist/base-class/base.controller.js +126 -0
- package/dist/base-class/base.controller.js.map +1 -0
- package/dist/base-class/base.entity.cjs +79 -0
- package/dist/base-class/base.entity.cjs.map +1 -0
- package/dist/base-class/base.entity.d.cts +8 -0
- package/dist/base-class/base.entity.d.ts +8 -0
- package/dist/base-class/base.entity.js +57 -0
- package/dist/base-class/base.entity.js.map +1 -0
- package/dist/base-class/base.model.cjs +204 -0
- package/dist/base-class/base.model.cjs.map +1 -0
- package/dist/base-class/base.model.d.cts +68 -0
- package/dist/base-class/base.model.d.ts +68 -0
- package/dist/base-class/base.model.js +182 -0
- package/dist/base-class/base.model.js.map +1 -0
- package/dist/base-class/base.service.cjs +37 -0
- package/dist/base-class/base.service.cjs.map +1 -0
- package/dist/base-class/base.service.d.cts +5 -0
- package/dist/base-class/base.service.d.ts +5 -0
- package/dist/base-class/base.service.js +15 -0
- package/dist/base-class/base.service.js.map +1 -0
- package/dist/base-class/index.cjs +392 -0
- package/dist/base-class/index.cjs.map +1 -0
- package/dist/base-class/index.d.cts +6 -0
- package/dist/base-class/index.d.ts +6 -0
- package/dist/base-class/index.js +365 -0
- package/dist/base-class/index.js.map +1 -0
- package/dist/cli/index.cjs +706 -0
- package/dist/cli/index.cjs.map +1 -0
- package/dist/cli/index.d.cts +3 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.js +681 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/scripts/on-build.cjs +56 -0
- package/dist/cli/scripts/on-build.cjs.map +1 -0
- package/dist/cli/scripts/on-build.d.cts +3 -0
- package/dist/cli/scripts/on-build.d.ts +3 -0
- package/dist/cli/scripts/on-build.js +28 -0
- package/dist/cli/scripts/on-build.js.map +1 -0
- package/dist/cli/scripts/on-dev.cjs +483 -0
- package/dist/cli/scripts/on-dev.cjs.map +1 -0
- package/dist/cli/scripts/on-dev.d.cts +5 -0
- package/dist/cli/scripts/on-dev.d.ts +5 -0
- package/dist/cli/scripts/on-dev.js +449 -0
- package/dist/cli/scripts/on-dev.js.map +1 -0
- package/dist/cli/scripts/on-init.cjs +96 -0
- package/dist/cli/scripts/on-init.cjs.map +1 -0
- package/dist/cli/scripts/on-init.d.cts +3 -0
- package/dist/cli/scripts/on-init.d.ts +3 -0
- package/dist/cli/scripts/on-init.js +68 -0
- package/dist/cli/scripts/on-init.js.map +1 -0
- package/dist/cli/scripts/on-start.cjs +55 -0
- package/dist/cli/scripts/on-start.cjs.map +1 -0
- package/dist/cli/scripts/on-start.d.cts +3 -0
- package/dist/cli/scripts/on-start.d.ts +3 -0
- package/dist/cli/scripts/on-start.js +27 -0
- package/dist/cli/scripts/on-start.js.map +1 -0
- package/dist/client.cjs +405 -0
- package/dist/client.cjs.map +1 -0
- package/dist/client.d.cts +7 -0
- package/dist/client.d.ts +7 -0
- package/dist/client.js +371 -0
- package/dist/client.js.map +1 -0
- package/dist/constants.cjs +51 -0
- package/dist/constants.cjs.map +1 -0
- package/dist/constants.d.cts +7 -0
- package/dist/constants.d.ts +7 -0
- package/dist/constants.js +16 -0
- package/dist/constants.js.map +1 -0
- package/dist/database/column/index.cjs +34 -0
- package/dist/database/column/index.cjs.map +1 -0
- package/dist/database/column/index.d.cts +2 -0
- package/dist/database/column/index.d.ts +2 -0
- package/dist/database/column/index.js +8 -0
- package/dist/database/column/index.js.map +1 -0
- package/dist/database/index.cjs +83 -0
- package/dist/database/index.cjs.map +1 -0
- package/dist/database/index.d.cts +2 -0
- package/dist/database/index.d.ts +2 -0
- package/dist/database/index.js +60 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/snake-naming-strategy.class.cjs +78 -0
- package/dist/database/snake-naming-strategy.class.cjs.map +1 -0
- package/dist/database/snake-naming-strategy.class.d.cts +16 -0
- package/dist/database/snake-naming-strategy.class.d.ts +16 -0
- package/dist/database/snake-naming-strategy.class.js +56 -0
- package/dist/database/snake-naming-strategy.class.js.map +1 -0
- package/dist/error.cjs +46 -0
- package/dist/error.cjs.map +1 -0
- package/dist/error.d.cts +10 -0
- package/dist/error.d.ts +10 -0
- package/dist/error.js +28 -0
- package/dist/error.js.map +1 -0
- package/dist/express/app.cjs +233 -0
- package/dist/express/app.cjs.map +1 -0
- package/dist/express/app.d.cts +16 -0
- package/dist/express/app.d.ts +16 -0
- package/dist/express/app.js +205 -0
- package/dist/express/app.js.map +1 -0
- package/dist/express/index.cjs +239 -0
- package/dist/express/index.cjs.map +1 -0
- package/dist/express/index.d.cts +3 -0
- package/dist/express/index.d.ts +3 -0
- package/dist/express/index.js +205 -0
- package/dist/express/index.js.map +1 -0
- package/dist/express/middleware/cors.middleware.cjs +54 -0
- package/dist/express/middleware/cors.middleware.cjs.map +1 -0
- package/dist/express/middleware/cors.middleware.d.cts +9 -0
- package/dist/express/middleware/cors.middleware.d.ts +9 -0
- package/dist/express/middleware/cors.middleware.js +26 -0
- package/dist/express/middleware/cors.middleware.js.map +1 -0
- package/dist/express/middleware/error.middleware.cjs +136 -0
- package/dist/express/middleware/error.middleware.cjs.map +1 -0
- package/dist/express/middleware/error.middleware.d.cts +5 -0
- package/dist/express/middleware/error.middleware.d.ts +5 -0
- package/dist/express/middleware/error.middleware.js +116 -0
- package/dist/express/middleware/error.middleware.js.map +1 -0
- package/dist/express/middleware/filter.middleware.cjs +38 -0
- package/dist/express/middleware/filter.middleware.cjs.map +1 -0
- package/dist/express/middleware/filter.middleware.d.cts +5 -0
- package/dist/express/middleware/filter.middleware.d.ts +5 -0
- package/dist/express/middleware/filter.middleware.js +20 -0
- package/dist/express/middleware/filter.middleware.js.map +1 -0
- package/dist/express/middleware/index.cjs +206 -0
- package/dist/express/middleware/index.cjs.map +1 -0
- package/dist/express/middleware/index.d.cts +19 -0
- package/dist/express/middleware/index.d.ts +19 -0
- package/dist/express/middleware/index.js +169 -0
- package/dist/express/middleware/index.js.map +1 -0
- package/dist/express/middleware/not-found.middleware.cjs +79 -0
- package/dist/express/middleware/not-found.middleware.cjs.map +1 -0
- package/dist/express/middleware/not-found.middleware.d.cts +5 -0
- package/dist/express/middleware/not-found.middleware.d.ts +5 -0
- package/dist/express/middleware/not-found.middleware.js +59 -0
- package/dist/express/middleware/not-found.middleware.js.map +1 -0
- package/dist/generator.cjs +258 -0
- package/dist/generator.cjs.map +1 -0
- package/dist/generator.d.cts +10 -0
- package/dist/generator.d.ts +10 -0
- package/dist/generator.js +220 -0
- package/dist/generator.js.map +1 -0
- package/dist/http.cjs +82 -0
- package/dist/http.cjs.map +1 -0
- package/dist/http.d.cts +11 -0
- package/dist/http.d.ts +11 -0
- package/dist/http.js +64 -0
- package/dist/http.js.map +1 -0
- package/dist/index.cjs +831 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +19 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.js +783 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/create-env-file.cjs +69 -0
- package/dist/lib/create-env-file.cjs.map +1 -0
- package/dist/lib/create-env-file.d.cts +3 -0
- package/dist/lib/create-env-file.d.ts +3 -0
- package/dist/lib/create-env-file.js +31 -0
- package/dist/lib/create-env-file.js.map +1 -0
- package/dist/lib/helper.cjs +94 -0
- package/dist/lib/helper.cjs.map +1 -0
- package/dist/lib/helper.d.cts +13 -0
- package/dist/lib/helper.d.ts +13 -0
- package/dist/lib/helper.js +62 -0
- package/dist/lib/helper.js.map +1 -0
- package/dist/lib/model.generator.cjs +212 -0
- package/dist/lib/model.generator.cjs.map +1 -0
- package/dist/lib/model.generator.d.cts +29 -0
- package/dist/lib/model.generator.d.ts +29 -0
- package/dist/lib/model.generator.js +174 -0
- package/dist/lib/model.generator.js.map +1 -0
- package/dist/lib/pre-init-dev-script.cjs +336 -0
- package/dist/lib/pre-init-dev-script.cjs.map +1 -0
- package/dist/lib/pre-init-dev-script.d.cts +2 -0
- package/dist/lib/pre-init-dev-script.d.ts +2 -0
- package/dist/lib/pre-init-dev-script.js +311 -0
- package/dist/lib/pre-init-dev-script.js.map +1 -0
- package/dist/mahameru.cjs +397 -0
- package/dist/mahameru.cjs.map +1 -0
- package/dist/mahameru.d.cts +78 -0
- package/dist/mahameru.d.ts +78 -0
- package/dist/mahameru.js +359 -0
- package/dist/mahameru.js.map +1 -0
- package/dist/request.cjs +35 -0
- package/dist/request.cjs.map +1 -0
- package/dist/request.d.cts +4 -0
- package/dist/request.d.ts +4 -0
- package/dist/request.js +13 -0
- package/dist/request.js.map +1 -0
- package/dist/response.cjs +35 -0
- package/dist/response.cjs.map +1 -0
- package/dist/response.d.cts +4 -0
- package/dist/response.d.ts +4 -0
- package/dist/response.js +13 -0
- package/dist/response.js.map +1 -0
- package/dist/types.cjs +1 -0
- package/dist/types.cjs.map +1 -0
- package/dist/types.d.cts +2 -0
- package/dist/types.d.ts +2 -0
- package/dist/types.js +1 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/import-dynamic-module.cjs +34 -0
- package/dist/utils/import-dynamic-module.cjs.map +1 -0
- package/dist/utils/import-dynamic-module.d.cts +3 -0
- package/dist/utils/import-dynamic-module.d.ts +3 -0
- package/dist/utils/import-dynamic-module.js +12 -0
- package/dist/utils/import-dynamic-module.js.map +1 -0
- package/package.json +70 -0
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
|
|
30
|
+
// src/express/app.ts
|
|
31
|
+
var app_exports = {};
|
|
32
|
+
__export(app_exports, {
|
|
33
|
+
default: () => app_default
|
|
34
|
+
});
|
|
35
|
+
module.exports = __toCommonJS(app_exports);
|
|
36
|
+
var import_express = __toESM(require("express"), 1);
|
|
37
|
+
var import_helmet = __toESM(require("helmet"), 1);
|
|
38
|
+
|
|
39
|
+
// src/express/middleware/cors.middleware.ts
|
|
40
|
+
var import_cors = __toESM(require("cors"), 1);
|
|
41
|
+
var createCorsMiddleware = /* @__PURE__ */ __name((allowedOrigins) => {
|
|
42
|
+
return (0, import_cors.default)((req, callback) => {
|
|
43
|
+
let origin = req.headers["origin"];
|
|
44
|
+
if (!origin || allowedOrigins.indexOf(origin) !== -1) {
|
|
45
|
+
callback(null, {
|
|
46
|
+
origin: true,
|
|
47
|
+
methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
|
|
48
|
+
credentials: true
|
|
49
|
+
});
|
|
50
|
+
} else {
|
|
51
|
+
callback(null, {
|
|
52
|
+
origin: false
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
}, "createCorsMiddleware");
|
|
57
|
+
var cors_middleware_default = createCorsMiddleware;
|
|
58
|
+
|
|
59
|
+
// src/express/middleware/filter.middleware.ts
|
|
60
|
+
async function filterMiddleware(request, response, next) {
|
|
61
|
+
if (!request.ip || !request.headers["user-agent"]) throw new Error("Access denied");
|
|
62
|
+
request.ipAddress = request.ip;
|
|
63
|
+
request.userAgent = request.headers["user-agent"];
|
|
64
|
+
if (request.path.length > 1 && request.path.endsWith("/")) {
|
|
65
|
+
const newPath = request.path.slice(0, -1);
|
|
66
|
+
const query = request.url.slice(request.path.length);
|
|
67
|
+
return response.redirect(301, newPath + query);
|
|
68
|
+
}
|
|
69
|
+
return next();
|
|
70
|
+
}
|
|
71
|
+
__name(filterMiddleware, "filterMiddleware");
|
|
72
|
+
|
|
73
|
+
// src/api.error.ts
|
|
74
|
+
var API_ERROR_STATUS = {
|
|
75
|
+
BAD_REQUEST: 400,
|
|
76
|
+
UNAUTHORIZED: 401,
|
|
77
|
+
FORBIDDEN: 403,
|
|
78
|
+
NOT_FOUND: 404,
|
|
79
|
+
ROUTE_NOT_FOUND: 404,
|
|
80
|
+
TOO_MANY_REQUESTS: 429,
|
|
81
|
+
CONFLICT: 409,
|
|
82
|
+
INTERNAL_SERVER_ERROR: 500,
|
|
83
|
+
TOKEN_EXPIRED: 401,
|
|
84
|
+
REFRESH_TOKEN_EXPIRED: 401,
|
|
85
|
+
ACCESS_TOKEN_EXPIRED: 401,
|
|
86
|
+
ACCESS_TOKEN_REQUIRED: 401,
|
|
87
|
+
TOKEN_REFRESH_TOO_EARLY: 403,
|
|
88
|
+
EMAIL_NOT_VERIFIED: 401,
|
|
89
|
+
PHONE_NOT_VERIFIED: 401,
|
|
90
|
+
TOKEN_NOT_FOUND: 404,
|
|
91
|
+
INVALID_TOKEN: 401,
|
|
92
|
+
RESET_PASSWORD_TOKEN_USED: 401,
|
|
93
|
+
RESET_PASSWORD_NEEDED: 400,
|
|
94
|
+
ROLE_DISABLED: 403,
|
|
95
|
+
SESSION_NOT_FOUND: 404,
|
|
96
|
+
SESSION_DISABLED: 401,
|
|
97
|
+
INVALID_RESPONSE: 500,
|
|
98
|
+
UNKNOWN_CLIENT_ERROR: 400,
|
|
99
|
+
INVALID_CREDENTIALS: 400,
|
|
100
|
+
VALIDATION_ERROR: 400
|
|
101
|
+
};
|
|
102
|
+
var APIError = class _APIError extends Error {
|
|
103
|
+
static {
|
|
104
|
+
__name(this, "APIError");
|
|
105
|
+
}
|
|
106
|
+
code;
|
|
107
|
+
status;
|
|
108
|
+
details;
|
|
109
|
+
constructor(...args) {
|
|
110
|
+
const [code, message, details] = args;
|
|
111
|
+
super(message);
|
|
112
|
+
this.name = "APIError";
|
|
113
|
+
this.code = code;
|
|
114
|
+
this.status = API_ERROR_STATUS[code];
|
|
115
|
+
this.details = details;
|
|
116
|
+
Object.setPrototypeOf(this, _APIError.prototype);
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
// src/express/middleware/not-found.middleware.ts
|
|
121
|
+
async function notFoundMiddleware(request) {
|
|
122
|
+
throw new APIError("ROUTE_NOT_FOUND", `Route ${request.path} is not found!`);
|
|
123
|
+
}
|
|
124
|
+
__name(notFoundMiddleware, "notFoundMiddleware");
|
|
125
|
+
|
|
126
|
+
// src/express/middleware/error.middleware.ts
|
|
127
|
+
function isPlainObject(value) {
|
|
128
|
+
return typeof value === "object" && value !== null && Object.getPrototypeOf(value) === Object.prototype;
|
|
129
|
+
}
|
|
130
|
+
__name(isPlainObject, "isPlainObject");
|
|
131
|
+
var createErrorMiddleware = /* @__PURE__ */ __name((cookieTokenOptions) => (error, req, res, _) => {
|
|
132
|
+
try {
|
|
133
|
+
res.setHeader("Cache-Control", "no-store");
|
|
134
|
+
if (error instanceof APIError) {
|
|
135
|
+
if (error.code === "INTERNAL_SERVER_ERROR") {
|
|
136
|
+
console.error(error);
|
|
137
|
+
return res.status(error.status).json({
|
|
138
|
+
success: false,
|
|
139
|
+
error: error.code,
|
|
140
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
if (error.code === "TOKEN_NOT_FOUND") {
|
|
144
|
+
if (req.cookies.token) res.clearCookie("token", cookieTokenOptions);
|
|
145
|
+
}
|
|
146
|
+
if (isPlainObject(error.details) && "retryIn" in error.details && typeof error.details.retryIn === "number") res.setHeader("Retry-After", error.details.retryIn);
|
|
147
|
+
const responseBody = {
|
|
148
|
+
success: false,
|
|
149
|
+
error: error.code,
|
|
150
|
+
...error.message ? {
|
|
151
|
+
message: error.message
|
|
152
|
+
} : {},
|
|
153
|
+
...isPlainObject(error.details) ? error.details : {}
|
|
154
|
+
};
|
|
155
|
+
return res.status(error.status).json(responseBody);
|
|
156
|
+
}
|
|
157
|
+
if (error instanceof SyntaxError) {
|
|
158
|
+
return res.status(error.statusCode).json({
|
|
159
|
+
success: false,
|
|
160
|
+
error: "JSON_PARSE_ERROR",
|
|
161
|
+
message: error.message
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
if (error instanceof Error) {
|
|
165
|
+
console.error(error);
|
|
166
|
+
return res.status(500).json({
|
|
167
|
+
success: false,
|
|
168
|
+
error: "UNKNOWN_ERROR",
|
|
169
|
+
message: "An unknown error is happening. Please contact developer as soon as possible!"
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
console.error("errorHandlerMiddleware", error);
|
|
173
|
+
return res.status(500).json({
|
|
174
|
+
success: false,
|
|
175
|
+
error: "INTERNAL_SERVER_ERROR",
|
|
176
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
177
|
+
});
|
|
178
|
+
} catch (error2) {
|
|
179
|
+
console.error("errorHandlerMiddleware", error2);
|
|
180
|
+
return res.status(500).json({
|
|
181
|
+
success: false,
|
|
182
|
+
error: "INTERNAL_SERVER_ERROR",
|
|
183
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
}, "createErrorMiddleware");
|
|
187
|
+
var error_middleware_default = createErrorMiddleware;
|
|
188
|
+
|
|
189
|
+
// src/express/app.ts
|
|
190
|
+
var import_cookie_parser = __toESM(require("cookie-parser"), 1);
|
|
191
|
+
var createExpressApp = /* @__PURE__ */ __name((options) => {
|
|
192
|
+
const app = (0, import_express.default)();
|
|
193
|
+
app.set("trust proxy", 1);
|
|
194
|
+
app.disable("x-powered-by");
|
|
195
|
+
app.use((0, import_helmet.default)());
|
|
196
|
+
app.use(cors_middleware_default(options.allowedOrigins));
|
|
197
|
+
app.use(filterMiddleware);
|
|
198
|
+
app.use(import_express.default.json({
|
|
199
|
+
limit: "1mb"
|
|
200
|
+
}));
|
|
201
|
+
app.use((0, import_cookie_parser.default)(options.cookieSecret));
|
|
202
|
+
app.use(import_express.default.urlencoded({
|
|
203
|
+
extended: true,
|
|
204
|
+
limit: "1mb"
|
|
205
|
+
}));
|
|
206
|
+
app.use(import_express.default.static("public", {
|
|
207
|
+
dotfiles: "deny",
|
|
208
|
+
etag: true,
|
|
209
|
+
immutable: false,
|
|
210
|
+
index: false,
|
|
211
|
+
lastModified: true,
|
|
212
|
+
maxAge: "1h"
|
|
213
|
+
}));
|
|
214
|
+
app.get("/", (request, response) => {
|
|
215
|
+
return response.status(200).json({
|
|
216
|
+
success: true,
|
|
217
|
+
message: `Welcome to ${options.appName}`,
|
|
218
|
+
data: {
|
|
219
|
+
userAgent: request.userAgent,
|
|
220
|
+
ipAddress: request.ipAddress
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
});
|
|
224
|
+
if (options.routes) {
|
|
225
|
+
app.use(options.routes.public);
|
|
226
|
+
app.use(options.routes.private);
|
|
227
|
+
}
|
|
228
|
+
app.use(notFoundMiddleware);
|
|
229
|
+
app.use(error_middleware_default(options.cookieOptions));
|
|
230
|
+
return app;
|
|
231
|
+
}, "createExpressApp");
|
|
232
|
+
var app_default = createExpressApp;
|
|
233
|
+
//# sourceMappingURL=app.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/express/app.ts","../../src/express/middleware/cors.middleware.ts","../../src/express/middleware/filter.middleware.ts","../../src/api.error.ts","../../src/express/middleware/not-found.middleware.ts","../../src/express/middleware/error.middleware.ts"],"sourcesContent":["import express, { type Router, type CookieOptions } from 'express'\r\nimport helmet from 'helmet'\r\nimport { createCorsMiddleware, createErrorMiddleware, filterMiddleware, notFoundMiddleware } from './middleware/index.js'\r\nimport cookieParser from \"cookie-parser\";\r\n\r\ntype CreateExpressAppOptions = {\r\n appName: string\r\n allowedOrigins: string[]\r\n cookieSecret: string\r\n cookieOptions: CookieOptions\r\n routes?: {\r\n public: Router\r\n private: Router\r\n }\r\n}\r\n\r\nconst createExpressApp = (options: CreateExpressAppOptions) => {\r\n const app = express()\r\n\r\n app.set('trust proxy', 1)\r\n app.disable('x-powered-by')\r\n app.use(helmet())\r\n app.use(createCorsMiddleware(options.allowedOrigins))\r\n app.use(filterMiddleware)\r\n app.use(express.json({ limit: '1mb' }))\r\n app.use(cookieParser(options.cookieSecret))\r\n app.use(\r\n express.urlencoded({\r\n extended: true,\r\n limit: '1mb'\r\n })\r\n )\r\n\r\n app.use(\r\n express.static('public', {\r\n dotfiles: 'deny',\r\n etag: true,\r\n immutable: false,\r\n index: false,\r\n lastModified: true,\r\n maxAge: '1h'\r\n })\r\n )\r\n\r\n app.get('/', (request, response) => {\r\n return response.status(200).json({\r\n success: true,\r\n message: `Welcome to ${options.appName}`,\r\n data: {\r\n userAgent: request.userAgent,\r\n ipAddress: request.ipAddress\r\n }\r\n })\r\n })\r\n\r\n if (options.routes) {\r\n app.use(options.routes.public)\r\n app.use(options.routes.private)\r\n }\r\n\r\n app.use(notFoundMiddleware)\r\n app.use(createErrorMiddleware(options.cookieOptions))\r\n\r\n return app\r\n}\r\n\r\nexport default createExpressApp\r\n","import cors, { CorsOptions, CorsRequest } from 'cors'\n\n\nconst createCorsMiddleware = (allowedOrigins: string[]) => {\n return cors((req: CorsRequest, callback: (err: Error | null, options?: CorsOptions | undefined) => void) => {\n let origin = req.headers['origin']\n\n if (!origin || allowedOrigins.indexOf(origin) !== -1) {\n callback(null, {\n origin: true,\n methods: \"GET,HEAD,PUT,PATCH,POST,DELETE\",\n credentials: true\n })\n } else {\n callback(null, {\n origin: false\n })\n }\n })\n}\n\nexport default createCorsMiddleware\n","\nimport { Request, Response, NextFunction } from 'express'\n\nexport default async function filterMiddleware(request: Request, response: Response, next: NextFunction) {\n if (!request.ip || !request.headers['user-agent'])\n throw new Error('Access denied')\n\n request.ipAddress = request.ip\n request.userAgent = request.headers['user-agent']\n\n if (request.path.length > 1 && request.path.endsWith('/')) {\n const newPath = request.path.slice(0, -1)\n const query = request.url.slice(request.path.length)\n\n return response.redirect(301, newPath + query)\n }\n\n return next()\n}\n","export const APIErrorCode = {\r\n BAD_REQUEST: 'BAD_REQUEST',\r\n UNAUTHORIZED: 'UNAUTHORIZED',\r\n FORBIDDEN: 'FORBIDDEN',\r\n NOT_FOUND: 'NOT_FOUND',\r\n ROUTE_NOT_FOUND: 'ROUTE_NOT_FOUND',\r\n TOO_MANY_REQUESTS: 'TOO_MANY_REQUESTS',\r\n CONFLICT: 'CONFLICT',\r\n INTERNAL_SERVER_ERROR: 'INTERNAL_SERVER_ERROR',\r\n TOKEN_EXPIRED: 'TOKEN_EXPIRED',\r\n REFRESH_TOKEN_EXPIRED: 'REFRESH_TOKEN_EXPIRED',\r\n ACCESS_TOKEN_EXPIRED: 'ACCESS_TOKEN_EXPIRED',\r\n ACCESS_TOKEN_REQUIRED: 'ACCESS_TOKEN_REQUIRED',\r\n TOKEN_REFRESH_TOO_EARLY: 'TOKEN_REFRESH_TOO_EARLY',\r\n EMAIL_NOT_VERIFIED: 'EMAIL_NOT_VERIFIED',\r\n PHONE_NOT_VERIFIED: 'PHONE_NOT_VERIFIED',\r\n TOKEN_NOT_FOUND: 'TOKEN_NOT_FOUND',\r\n INVALID_TOKEN: 'INVALID_TOKEN',\r\n RESET_PASSWORD_TOKEN_USED: 'RESET_PASSWORD_TOKEN_USED',\r\n RESET_PASSWORD_NEEDED: 'RESET_PASSWORD_NEEDED',\r\n ROLE_DISABLED: 'ROLE_DISABLED',\r\n SESSION_NOT_FOUND: 'SESSION_NOT_FOUND',\r\n SESSION_DISABLED: 'SESSION_DISABLED',\r\n INVALID_RESPONSE: 'INVALID_RESPONSE',\r\n UNKNOWN_CLIENT_ERROR: 'UNKNOWN_CLIENT_ERROR',\r\n INVALID_CREDENTIALS: 'INVALID_CREDENTIALS',\r\n VALIDATION_ERROR: 'VALIDATION_ERROR'\r\n} as const\r\n\r\nexport type APIErrorCode = (typeof APIErrorCode)[keyof typeof APIErrorCode]\r\n\r\nexport const API_ERROR_STATUS: Record<APIErrorCode, number> = {\r\n BAD_REQUEST: 400,\r\n UNAUTHORIZED: 401,\r\n FORBIDDEN: 403,\r\n NOT_FOUND: 404,\r\n ROUTE_NOT_FOUND: 404,\r\n TOO_MANY_REQUESTS: 429,\r\n CONFLICT: 409,\r\n INTERNAL_SERVER_ERROR: 500,\r\n TOKEN_EXPIRED: 401,\r\n REFRESH_TOKEN_EXPIRED: 401,\r\n ACCESS_TOKEN_EXPIRED: 401,\r\n ACCESS_TOKEN_REQUIRED: 401,\r\n TOKEN_REFRESH_TOO_EARLY: 403,\r\n EMAIL_NOT_VERIFIED: 401,\r\n PHONE_NOT_VERIFIED: 401,\r\n TOKEN_NOT_FOUND: 404,\r\n INVALID_TOKEN: 401,\r\n RESET_PASSWORD_TOKEN_USED: 401,\r\n RESET_PASSWORD_NEEDED: 400,\r\n ROLE_DISABLED: 403,\r\n SESSION_NOT_FOUND: 404,\r\n SESSION_DISABLED: 401,\r\n INVALID_RESPONSE: 500,\r\n UNKNOWN_CLIENT_ERROR: 400,\r\n INVALID_CREDENTIALS: 400,\r\n VALIDATION_ERROR: 400\r\n}\r\n\r\nexport type APIErrorDetailsMap = {\r\n TOKEN_REFRESH_TOO_EARLY: {\r\n retryIn: number\r\n retryAt: number\r\n },\r\n TOO_MANY_REQUESTS: {\r\n retryIn: number\r\n retryAt: number\r\n },\r\n VALIDATION_ERROR: {\r\n details: {\r\n field: PropertyKey\r\n message: string\r\n }[]\r\n }\r\n}\r\n\r\nexport type APIErrorDetails<T extends APIErrorCode> = T extends keyof APIErrorDetailsMap ? APIErrorDetailsMap[T] : never\r\n\r\ntype APIErrorCodeWithDetails = keyof APIErrorDetailsMap\r\ntype APIErrorCodeWithoutDetails = Exclude<APIErrorCode, APIErrorCodeWithDetails>\r\ntype AnyAPIErrorDetails = APIErrorDetailsMap[APIErrorCodeWithDetails]\r\ntype APIErrorConstructorArgs =\r\n | [code: APIErrorCodeWithoutDetails, message?: string]\r\n | {\r\n [TCode in APIErrorCodeWithDetails]: [\r\n code: TCode,\r\n message: string | undefined,\r\n details: APIErrorDetails<TCode>\r\n ]\r\n }[APIErrorCodeWithDetails]\r\n\r\nexport class APIError extends Error {\r\n public code: APIErrorCode\r\n public readonly status: number\r\n public readonly details?: AnyAPIErrorDetails\r\n\r\n constructor(...args: APIErrorConstructorArgs) {\r\n const [code, message, details] = args\r\n\r\n super(message)\r\n this.name = 'APIError'\r\n this.code = code\r\n this.status = API_ERROR_STATUS[code]\r\n this.details = details\r\n\r\n Object.setPrototypeOf(this, APIError.prototype)\r\n }\r\n}\r\n","\nimport { Request } from 'express'\nimport { APIError } from '../../api.error.js'\n\nexport default async function notFoundMiddleware(request: Request) {\n throw new APIError('ROUTE_NOT_FOUND', `Route ${request.path} is not found!`)\n}\n","import { Request, Response, NextFunction, CookieOptions } from 'express'\nimport { APIError } from '../../api.error.js'\n\nfunction isPlainObject(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null && Object.getPrototypeOf(value) === Object.prototype\n}\n\nconst createErrorMiddleware = (cookieTokenOptions: CookieOptions) =>\n (error: unknown, req: Request, res: Response, _: NextFunction) => {\n try {\n res.setHeader('Cache-Control', 'no-store')\n\n if (error instanceof APIError) {\n if (error.code === 'INTERNAL_SERVER_ERROR') {\n console.error(error)\n\n return res.status(error.status).json({\n success: false,\n error: error.code,\n message: 'An internal error is happening. Please contact developer as soon as possible!'\n })\n }\n\n if (error.code === 'TOKEN_NOT_FOUND')\n if (req.cookies.token)\n res.clearCookie('token', cookieTokenOptions)\n\n if (isPlainObject(error.details) && 'retryIn' in error.details && typeof error.details.retryIn === 'number')\n res.setHeader('Retry-After', error.details.retryIn)\n\n const responseBody = {\n success: false,\n error: error.code,\n ...(error.message ? { message: error.message } : {}),\n ...(isPlainObject(error.details) ? error.details : {})\n }\n\n return res.status(error.status).json(responseBody)\n }\n\n if (error instanceof SyntaxError) {\n return res.status((error as any).statusCode).json({\n success: false,\n error: 'JSON_PARSE_ERROR',\n message: error.message\n })\n }\n\n if (error instanceof Error) {\n console.error(error)\n\n return res.status(500).json({\n success: false,\n error: 'UNKNOWN_ERROR',\n message: 'An unknown error is happening. Please contact developer as soon as possible!'\n })\n }\n\n console.error('errorHandlerMiddleware', error)\n\n return res.status(500).json({\n success: false,\n error: 'INTERNAL_SERVER_ERROR',\n message: 'An internal error is happening. Please contact developer as soon as possible!'\n })\n } catch (error) {\n console.error('errorHandlerMiddleware', error)\n\n return res.status(500).json({\n success: false,\n error: 'INTERNAL_SERVER_ERROR',\n message: 'An internal error is happening. Please contact developer as soon as possible!'\n })\n }\n }\n\nexport default createErrorMiddleware\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;AAAA,qBAAyD;AACzD,oBAAmB;;;ACDnB,kBAA+C;AAG/C,IAAMA,uBAAuB,wBAACC,mBAAAA;AAC1B,aAAOC,YAAAA,SAAK,CAACC,KAAkBC,aAAAA;AAC3B,QAAIC,SAASF,IAAIG,QAAQ,QAAA;AAEzB,QAAI,CAACD,UAAUJ,eAAeM,QAAQF,MAAAA,MAAY,IAAI;AAClDD,eAAS,MAAM;QACXC,QAAQ;QACRG,SAAS;QACTC,aAAa;MACjB,CAAA;IACJ,OAAO;AACHL,eAAS,MAAM;QACXC,QAAQ;MACZ,CAAA;IACJ;EACJ,CAAA;AACJ,GAhB6B;AAkB7B,IAAA,0BAAeL;;;AClBf,eAAA,iBAA+CU,SAAkBC,UAAoBC,MAAkB;AACnG,MAAI,CAACF,QAAQG,MAAM,CAACH,QAAQI,QAAQ,YAAA,EAChC,OAAM,IAAIC,MAAM,eAAA;AAEpBL,UAAQM,YAAYN,QAAQG;AAC5BH,UAAQO,YAAYP,QAAQI,QAAQ,YAAA;AAEpC,MAAIJ,QAAQQ,KAAKC,SAAS,KAAKT,QAAQQ,KAAKE,SAAS,GAAA,GAAM;AACvD,UAAMC,UAAUX,QAAQQ,KAAKI,MAAM,GAAG,EAAC;AACvC,UAAMC,QAAQb,QAAQc,IAAIF,MAAMZ,QAAQQ,KAAKC,MAAM;AAEnD,WAAOR,SAASc,SAAS,KAAKJ,UAAUE,KAAAA;EAC5C;AAEA,SAAOX,KAAAA;AACX;AAf8Bc;;;AC4BvB,IAAMC,mBAAiD;EAC1DC,aAAa;EACbC,cAAc;EACdC,WAAW;EACXC,WAAW;EACXC,iBAAiB;EACjBC,mBAAmB;EACnBC,UAAU;EACVC,uBAAuB;EACvBC,eAAe;EACfC,uBAAuB;EACvBC,sBAAsB;EACtBC,uBAAuB;EACvBC,yBAAyB;EACzBC,oBAAoB;EACpBC,oBAAoB;EACpBC,iBAAiB;EACjBC,eAAe;EACfC,2BAA2B;EAC3BC,uBAAuB;EACvBC,eAAe;EACfC,mBAAmB;EACnBC,kBAAkB;EAClBC,kBAAkB;EAClBC,sBAAsB;EACtBC,qBAAqB;EACrBC,kBAAkB;AACtB;AAkCO,IAAMC,WAAN,MAAMA,kBAAiBC,MAAAA;EA5F9B,OA4F8BA;;;EACnBC;EACSC;EACAC;EAEhB,eAAeC,MAA+B;AAC1C,UAAM,CAACH,MAAMI,SAASF,OAAAA,IAAWC;AAEjC,UAAMC,OAAAA;AACN,SAAKC,OAAO;AACZ,SAAKL,OAAOA;AACZ,SAAKC,SAAS9B,iBAAiB6B,IAAAA;AAC/B,SAAKE,UAAUA;AAEfI,WAAOC,eAAe,MAAMT,UAASU,SAAS;EAClD;AACJ;;;ACxGA,eAAA,mBAAiDC,SAAgB;AAC7D,QAAM,IAAIC,SAAS,mBAAmB,SAASD,QAAQE,IAAI,gBAAgB;AAC/E;AAF8BC;;;ACD9B,SAASC,cAAcC,OAAc;AACjC,SAAO,OAAOA,UAAU,YAAYA,UAAU,QAAQC,OAAOC,eAAeF,KAAAA,MAAWC,OAAOE;AAClG;AAFSJ;AAIT,IAAMK,wBAAwB,wBAACC,uBAC3B,CAACC,OAAgBC,KAAcC,KAAeC,MAAAA;AAC1C,MAAI;AACAD,QAAIE,UAAU,iBAAiB,UAAA;AAE/B,QAAIJ,iBAAiBK,UAAU;AAC3B,UAAIL,MAAMM,SAAS,yBAAyB;AACxCC,gBAAQP,MAAMA,KAAAA;AAEd,eAAOE,IAAIM,OAAOR,MAAMQ,MAAM,EAAEC,KAAK;UACjCC,SAAS;UACTV,OAAOA,MAAMM;UACbK,SAAS;QACb,CAAA;MACJ;AAEA,UAAIX,MAAMM,SAAS,mBACf;AAAA,YAAIL,IAAIW,QAAQC,MACZX,KAAIY,YAAY,SAASf,kBAAAA;MAAkB;AAEnD,UAAIN,cAAcO,MAAMe,OAAO,KAAK,aAAaf,MAAMe,WAAW,OAAOf,MAAMe,QAAQC,YAAY,SAC/Fd,KAAIE,UAAU,eAAeJ,MAAMe,QAAQC,OAAO;AAEtD,YAAMC,eAAe;QACjBP,SAAS;QACTV,OAAOA,MAAMM;QACb,GAAIN,MAAMW,UAAU;UAAEA,SAASX,MAAMW;QAAQ,IAAI,CAAC;QAClD,GAAIlB,cAAcO,MAAMe,OAAO,IAAIf,MAAMe,UAAU,CAAC;MACxD;AAEA,aAAOb,IAAIM,OAAOR,MAAMQ,MAAM,EAAEC,KAAKQ,YAAAA;IACzC;AAEA,QAAIjB,iBAAiBkB,aAAa;AAC9B,aAAOhB,IAAIM,OAAQR,MAAcmB,UAAU,EAAEV,KAAK;QAC9CC,SAAS;QACTV,OAAO;QACPW,SAASX,MAAMW;MACnB,CAAA;IACJ;AAEA,QAAIX,iBAAiBoB,OAAO;AACxBb,cAAQP,MAAMA,KAAAA;AAEd,aAAOE,IAAIM,OAAO,GAAA,EAAKC,KAAK;QACxBC,SAAS;QACTV,OAAO;QACPW,SAAS;MACb,CAAA;IACJ;AAEAJ,YAAQP,MAAM,0BAA0BA,KAAAA;AAExC,WAAOE,IAAIM,OAAO,GAAA,EAAKC,KAAK;MACxBC,SAAS;MACTV,OAAO;MACPW,SAAS;IACb,CAAA;EACJ,SAASX,QAAO;AACZO,YAAQP,MAAM,0BAA0BA,MAAAA;AAExC,WAAOE,IAAIM,OAAO,GAAA,EAAKC,KAAK;MACxBC,SAAS;MACTV,OAAO;MACPW,SAAS;IACb,CAAA;EACJ;AACJ,GAnE0B;AAqE9B,IAAA,2BAAeb;;;ALzEf,2BAAyB;AAazB,IAAMuB,mBAAmB,wBAACC,YAAAA;AACtB,QAAMC,UAAMC,eAAAA,SAAAA;AAEZD,MAAIE,IAAI,eAAe,CAAA;AACvBF,MAAIG,QAAQ,cAAA;AACZH,MAAII,QAAIC,cAAAA,SAAAA,CAAAA;AACRL,MAAII,IAAIE,wBAAqBP,QAAQQ,cAAc,CAAA;AACnDP,MAAII,IAAII,gBAAAA;AACRR,MAAII,IAAIH,eAAAA,QAAQQ,KAAK;IAAEC,OAAO;EAAM,CAAA,CAAA;AACpCV,MAAII,QAAIO,qBAAAA,SAAaZ,QAAQa,YAAY,CAAA;AACzCZ,MAAII,IACAH,eAAAA,QAAQY,WAAW;IACfC,UAAU;IACVJ,OAAO;EACX,CAAA,CAAA;AAGJV,MAAII,IACAH,eAAAA,QAAQc,OAAO,UAAU;IACrBC,UAAU;IACVC,MAAM;IACNC,WAAW;IACXC,OAAO;IACPC,cAAc;IACdC,QAAQ;EACZ,CAAA,CAAA;AAGJrB,MAAIsB,IAAI,KAAK,CAACC,SAASC,aAAAA;AACnB,WAAOA,SAASC,OAAO,GAAA,EAAKhB,KAAK;MAC7BiB,SAAS;MACTC,SAAS,cAAc5B,QAAQ6B,OAAO;MACtCC,MAAM;QACFC,WAAWP,QAAQO;QACnBC,WAAWR,QAAQQ;MACvB;IACJ,CAAA;EACJ,CAAA;AAEA,MAAIhC,QAAQiC,QAAQ;AAChBhC,QAAII,IAAIL,QAAQiC,OAAOC,MAAM;AAC7BjC,QAAII,IAAIL,QAAQiC,OAAOE,OAAO;EAClC;AAEAlC,MAAII,IAAI+B,kBAAAA;AACRnC,MAAII,IAAIgC,yBAAsBrC,QAAQsC,aAAa,CAAA;AAEnD,SAAOrC;AACX,GAhDyB;AAkDzB,IAAA,cAAeF;","names":["createCorsMiddleware","allowedOrigins","cors","req","callback","origin","headers","indexOf","methods","credentials","request","response","next","ip","headers","Error","ipAddress","userAgent","path","length","endsWith","newPath","slice","query","url","redirect","filterMiddleware","API_ERROR_STATUS","BAD_REQUEST","UNAUTHORIZED","FORBIDDEN","NOT_FOUND","ROUTE_NOT_FOUND","TOO_MANY_REQUESTS","CONFLICT","INTERNAL_SERVER_ERROR","TOKEN_EXPIRED","REFRESH_TOKEN_EXPIRED","ACCESS_TOKEN_EXPIRED","ACCESS_TOKEN_REQUIRED","TOKEN_REFRESH_TOO_EARLY","EMAIL_NOT_VERIFIED","PHONE_NOT_VERIFIED","TOKEN_NOT_FOUND","INVALID_TOKEN","RESET_PASSWORD_TOKEN_USED","RESET_PASSWORD_NEEDED","ROLE_DISABLED","SESSION_NOT_FOUND","SESSION_DISABLED","INVALID_RESPONSE","UNKNOWN_CLIENT_ERROR","INVALID_CREDENTIALS","VALIDATION_ERROR","APIError","Error","code","status","details","args","message","name","Object","setPrototypeOf","prototype","request","APIError","path","notFoundMiddleware","isPlainObject","value","Object","getPrototypeOf","prototype","createErrorMiddleware","cookieTokenOptions","error","req","res","_","setHeader","APIError","code","console","status","json","success","message","cookies","token","clearCookie","details","retryIn","responseBody","SyntaxError","statusCode","Error","createExpressApp","options","app","express","set","disable","use","helmet","createCorsMiddleware","allowedOrigins","filterMiddleware","json","limit","cookieParser","cookieSecret","urlencoded","extended","static","dotfiles","etag","immutable","index","lastModified","maxAge","get","request","response","status","success","message","appName","data","userAgent","ipAddress","routes","public","private","notFoundMiddleware","createErrorMiddleware","cookieOptions"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as express_serve_static_core from 'express-serve-static-core';
|
|
2
|
+
import { CookieOptions, Router } from 'express';
|
|
3
|
+
|
|
4
|
+
type CreateExpressAppOptions = {
|
|
5
|
+
appName: string;
|
|
6
|
+
allowedOrigins: string[];
|
|
7
|
+
cookieSecret: string;
|
|
8
|
+
cookieOptions: CookieOptions;
|
|
9
|
+
routes?: {
|
|
10
|
+
public: Router;
|
|
11
|
+
private: Router;
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
declare const createExpressApp: (options: CreateExpressAppOptions) => express_serve_static_core.Express;
|
|
15
|
+
|
|
16
|
+
export { createExpressApp as default };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as express_serve_static_core from 'express-serve-static-core';
|
|
2
|
+
import { CookieOptions, Router } from 'express';
|
|
3
|
+
|
|
4
|
+
type CreateExpressAppOptions = {
|
|
5
|
+
appName: string;
|
|
6
|
+
allowedOrigins: string[];
|
|
7
|
+
cookieSecret: string;
|
|
8
|
+
cookieOptions: CookieOptions;
|
|
9
|
+
routes?: {
|
|
10
|
+
public: Router;
|
|
11
|
+
private: Router;
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
declare const createExpressApp: (options: CreateExpressAppOptions) => express_serve_static_core.Express;
|
|
15
|
+
|
|
16
|
+
export { createExpressApp as default };
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/express/app.ts
|
|
5
|
+
import express from "express";
|
|
6
|
+
import helmet from "helmet";
|
|
7
|
+
|
|
8
|
+
// src/express/middleware/cors.middleware.ts
|
|
9
|
+
import cors from "cors";
|
|
10
|
+
var createCorsMiddleware = /* @__PURE__ */ __name((allowedOrigins) => {
|
|
11
|
+
return cors((req, callback) => {
|
|
12
|
+
let origin = req.headers["origin"];
|
|
13
|
+
if (!origin || allowedOrigins.indexOf(origin) !== -1) {
|
|
14
|
+
callback(null, {
|
|
15
|
+
origin: true,
|
|
16
|
+
methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
|
|
17
|
+
credentials: true
|
|
18
|
+
});
|
|
19
|
+
} else {
|
|
20
|
+
callback(null, {
|
|
21
|
+
origin: false
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}, "createCorsMiddleware");
|
|
26
|
+
var cors_middleware_default = createCorsMiddleware;
|
|
27
|
+
|
|
28
|
+
// src/express/middleware/filter.middleware.ts
|
|
29
|
+
async function filterMiddleware(request, response, next) {
|
|
30
|
+
if (!request.ip || !request.headers["user-agent"]) throw new Error("Access denied");
|
|
31
|
+
request.ipAddress = request.ip;
|
|
32
|
+
request.userAgent = request.headers["user-agent"];
|
|
33
|
+
if (request.path.length > 1 && request.path.endsWith("/")) {
|
|
34
|
+
const newPath = request.path.slice(0, -1);
|
|
35
|
+
const query = request.url.slice(request.path.length);
|
|
36
|
+
return response.redirect(301, newPath + query);
|
|
37
|
+
}
|
|
38
|
+
return next();
|
|
39
|
+
}
|
|
40
|
+
__name(filterMiddleware, "filterMiddleware");
|
|
41
|
+
|
|
42
|
+
// src/api.error.ts
|
|
43
|
+
var API_ERROR_STATUS = {
|
|
44
|
+
BAD_REQUEST: 400,
|
|
45
|
+
UNAUTHORIZED: 401,
|
|
46
|
+
FORBIDDEN: 403,
|
|
47
|
+
NOT_FOUND: 404,
|
|
48
|
+
ROUTE_NOT_FOUND: 404,
|
|
49
|
+
TOO_MANY_REQUESTS: 429,
|
|
50
|
+
CONFLICT: 409,
|
|
51
|
+
INTERNAL_SERVER_ERROR: 500,
|
|
52
|
+
TOKEN_EXPIRED: 401,
|
|
53
|
+
REFRESH_TOKEN_EXPIRED: 401,
|
|
54
|
+
ACCESS_TOKEN_EXPIRED: 401,
|
|
55
|
+
ACCESS_TOKEN_REQUIRED: 401,
|
|
56
|
+
TOKEN_REFRESH_TOO_EARLY: 403,
|
|
57
|
+
EMAIL_NOT_VERIFIED: 401,
|
|
58
|
+
PHONE_NOT_VERIFIED: 401,
|
|
59
|
+
TOKEN_NOT_FOUND: 404,
|
|
60
|
+
INVALID_TOKEN: 401,
|
|
61
|
+
RESET_PASSWORD_TOKEN_USED: 401,
|
|
62
|
+
RESET_PASSWORD_NEEDED: 400,
|
|
63
|
+
ROLE_DISABLED: 403,
|
|
64
|
+
SESSION_NOT_FOUND: 404,
|
|
65
|
+
SESSION_DISABLED: 401,
|
|
66
|
+
INVALID_RESPONSE: 500,
|
|
67
|
+
UNKNOWN_CLIENT_ERROR: 400,
|
|
68
|
+
INVALID_CREDENTIALS: 400,
|
|
69
|
+
VALIDATION_ERROR: 400
|
|
70
|
+
};
|
|
71
|
+
var APIError = class _APIError extends Error {
|
|
72
|
+
static {
|
|
73
|
+
__name(this, "APIError");
|
|
74
|
+
}
|
|
75
|
+
code;
|
|
76
|
+
status;
|
|
77
|
+
details;
|
|
78
|
+
constructor(...args) {
|
|
79
|
+
const [code, message, details] = args;
|
|
80
|
+
super(message);
|
|
81
|
+
this.name = "APIError";
|
|
82
|
+
this.code = code;
|
|
83
|
+
this.status = API_ERROR_STATUS[code];
|
|
84
|
+
this.details = details;
|
|
85
|
+
Object.setPrototypeOf(this, _APIError.prototype);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
// src/express/middleware/not-found.middleware.ts
|
|
90
|
+
async function notFoundMiddleware(request) {
|
|
91
|
+
throw new APIError("ROUTE_NOT_FOUND", `Route ${request.path} is not found!`);
|
|
92
|
+
}
|
|
93
|
+
__name(notFoundMiddleware, "notFoundMiddleware");
|
|
94
|
+
|
|
95
|
+
// src/express/middleware/error.middleware.ts
|
|
96
|
+
function isPlainObject(value) {
|
|
97
|
+
return typeof value === "object" && value !== null && Object.getPrototypeOf(value) === Object.prototype;
|
|
98
|
+
}
|
|
99
|
+
__name(isPlainObject, "isPlainObject");
|
|
100
|
+
var createErrorMiddleware = /* @__PURE__ */ __name((cookieTokenOptions) => (error, req, res, _) => {
|
|
101
|
+
try {
|
|
102
|
+
res.setHeader("Cache-Control", "no-store");
|
|
103
|
+
if (error instanceof APIError) {
|
|
104
|
+
if (error.code === "INTERNAL_SERVER_ERROR") {
|
|
105
|
+
console.error(error);
|
|
106
|
+
return res.status(error.status).json({
|
|
107
|
+
success: false,
|
|
108
|
+
error: error.code,
|
|
109
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
if (error.code === "TOKEN_NOT_FOUND") {
|
|
113
|
+
if (req.cookies.token) res.clearCookie("token", cookieTokenOptions);
|
|
114
|
+
}
|
|
115
|
+
if (isPlainObject(error.details) && "retryIn" in error.details && typeof error.details.retryIn === "number") res.setHeader("Retry-After", error.details.retryIn);
|
|
116
|
+
const responseBody = {
|
|
117
|
+
success: false,
|
|
118
|
+
error: error.code,
|
|
119
|
+
...error.message ? {
|
|
120
|
+
message: error.message
|
|
121
|
+
} : {},
|
|
122
|
+
...isPlainObject(error.details) ? error.details : {}
|
|
123
|
+
};
|
|
124
|
+
return res.status(error.status).json(responseBody);
|
|
125
|
+
}
|
|
126
|
+
if (error instanceof SyntaxError) {
|
|
127
|
+
return res.status(error.statusCode).json({
|
|
128
|
+
success: false,
|
|
129
|
+
error: "JSON_PARSE_ERROR",
|
|
130
|
+
message: error.message
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
if (error instanceof Error) {
|
|
134
|
+
console.error(error);
|
|
135
|
+
return res.status(500).json({
|
|
136
|
+
success: false,
|
|
137
|
+
error: "UNKNOWN_ERROR",
|
|
138
|
+
message: "An unknown error is happening. Please contact developer as soon as possible!"
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
console.error("errorHandlerMiddleware", error);
|
|
142
|
+
return res.status(500).json({
|
|
143
|
+
success: false,
|
|
144
|
+
error: "INTERNAL_SERVER_ERROR",
|
|
145
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
146
|
+
});
|
|
147
|
+
} catch (error2) {
|
|
148
|
+
console.error("errorHandlerMiddleware", error2);
|
|
149
|
+
return res.status(500).json({
|
|
150
|
+
success: false,
|
|
151
|
+
error: "INTERNAL_SERVER_ERROR",
|
|
152
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
}, "createErrorMiddleware");
|
|
156
|
+
var error_middleware_default = createErrorMiddleware;
|
|
157
|
+
|
|
158
|
+
// src/express/app.ts
|
|
159
|
+
import cookieParser from "cookie-parser";
|
|
160
|
+
var createExpressApp = /* @__PURE__ */ __name((options) => {
|
|
161
|
+
const app = express();
|
|
162
|
+
app.set("trust proxy", 1);
|
|
163
|
+
app.disable("x-powered-by");
|
|
164
|
+
app.use(helmet());
|
|
165
|
+
app.use(cors_middleware_default(options.allowedOrigins));
|
|
166
|
+
app.use(filterMiddleware);
|
|
167
|
+
app.use(express.json({
|
|
168
|
+
limit: "1mb"
|
|
169
|
+
}));
|
|
170
|
+
app.use(cookieParser(options.cookieSecret));
|
|
171
|
+
app.use(express.urlencoded({
|
|
172
|
+
extended: true,
|
|
173
|
+
limit: "1mb"
|
|
174
|
+
}));
|
|
175
|
+
app.use(express.static("public", {
|
|
176
|
+
dotfiles: "deny",
|
|
177
|
+
etag: true,
|
|
178
|
+
immutable: false,
|
|
179
|
+
index: false,
|
|
180
|
+
lastModified: true,
|
|
181
|
+
maxAge: "1h"
|
|
182
|
+
}));
|
|
183
|
+
app.get("/", (request, response) => {
|
|
184
|
+
return response.status(200).json({
|
|
185
|
+
success: true,
|
|
186
|
+
message: `Welcome to ${options.appName}`,
|
|
187
|
+
data: {
|
|
188
|
+
userAgent: request.userAgent,
|
|
189
|
+
ipAddress: request.ipAddress
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
if (options.routes) {
|
|
194
|
+
app.use(options.routes.public);
|
|
195
|
+
app.use(options.routes.private);
|
|
196
|
+
}
|
|
197
|
+
app.use(notFoundMiddleware);
|
|
198
|
+
app.use(error_middleware_default(options.cookieOptions));
|
|
199
|
+
return app;
|
|
200
|
+
}, "createExpressApp");
|
|
201
|
+
var app_default = createExpressApp;
|
|
202
|
+
export {
|
|
203
|
+
app_default as default
|
|
204
|
+
};
|
|
205
|
+
//# sourceMappingURL=app.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/express/app.ts","../../src/express/middleware/cors.middleware.ts","../../src/express/middleware/filter.middleware.ts","../../src/api.error.ts","../../src/express/middleware/not-found.middleware.ts","../../src/express/middleware/error.middleware.ts"],"sourcesContent":["import express, { type Router, type CookieOptions } from 'express'\r\nimport helmet from 'helmet'\r\nimport { createCorsMiddleware, createErrorMiddleware, filterMiddleware, notFoundMiddleware } from './middleware/index.js'\r\nimport cookieParser from \"cookie-parser\";\r\n\r\ntype CreateExpressAppOptions = {\r\n appName: string\r\n allowedOrigins: string[]\r\n cookieSecret: string\r\n cookieOptions: CookieOptions\r\n routes?: {\r\n public: Router\r\n private: Router\r\n }\r\n}\r\n\r\nconst createExpressApp = (options: CreateExpressAppOptions) => {\r\n const app = express()\r\n\r\n app.set('trust proxy', 1)\r\n app.disable('x-powered-by')\r\n app.use(helmet())\r\n app.use(createCorsMiddleware(options.allowedOrigins))\r\n app.use(filterMiddleware)\r\n app.use(express.json({ limit: '1mb' }))\r\n app.use(cookieParser(options.cookieSecret))\r\n app.use(\r\n express.urlencoded({\r\n extended: true,\r\n limit: '1mb'\r\n })\r\n )\r\n\r\n app.use(\r\n express.static('public', {\r\n dotfiles: 'deny',\r\n etag: true,\r\n immutable: false,\r\n index: false,\r\n lastModified: true,\r\n maxAge: '1h'\r\n })\r\n )\r\n\r\n app.get('/', (request, response) => {\r\n return response.status(200).json({\r\n success: true,\r\n message: `Welcome to ${options.appName}`,\r\n data: {\r\n userAgent: request.userAgent,\r\n ipAddress: request.ipAddress\r\n }\r\n })\r\n })\r\n\r\n if (options.routes) {\r\n app.use(options.routes.public)\r\n app.use(options.routes.private)\r\n }\r\n\r\n app.use(notFoundMiddleware)\r\n app.use(createErrorMiddleware(options.cookieOptions))\r\n\r\n return app\r\n}\r\n\r\nexport default createExpressApp\r\n","import cors, { CorsOptions, CorsRequest } from 'cors'\n\n\nconst createCorsMiddleware = (allowedOrigins: string[]) => {\n return cors((req: CorsRequest, callback: (err: Error | null, options?: CorsOptions | undefined) => void) => {\n let origin = req.headers['origin']\n\n if (!origin || allowedOrigins.indexOf(origin) !== -1) {\n callback(null, {\n origin: true,\n methods: \"GET,HEAD,PUT,PATCH,POST,DELETE\",\n credentials: true\n })\n } else {\n callback(null, {\n origin: false\n })\n }\n })\n}\n\nexport default createCorsMiddleware\n","\nimport { Request, Response, NextFunction } from 'express'\n\nexport default async function filterMiddleware(request: Request, response: Response, next: NextFunction) {\n if (!request.ip || !request.headers['user-agent'])\n throw new Error('Access denied')\n\n request.ipAddress = request.ip\n request.userAgent = request.headers['user-agent']\n\n if (request.path.length > 1 && request.path.endsWith('/')) {\n const newPath = request.path.slice(0, -1)\n const query = request.url.slice(request.path.length)\n\n return response.redirect(301, newPath + query)\n }\n\n return next()\n}\n","export const APIErrorCode = {\r\n BAD_REQUEST: 'BAD_REQUEST',\r\n UNAUTHORIZED: 'UNAUTHORIZED',\r\n FORBIDDEN: 'FORBIDDEN',\r\n NOT_FOUND: 'NOT_FOUND',\r\n ROUTE_NOT_FOUND: 'ROUTE_NOT_FOUND',\r\n TOO_MANY_REQUESTS: 'TOO_MANY_REQUESTS',\r\n CONFLICT: 'CONFLICT',\r\n INTERNAL_SERVER_ERROR: 'INTERNAL_SERVER_ERROR',\r\n TOKEN_EXPIRED: 'TOKEN_EXPIRED',\r\n REFRESH_TOKEN_EXPIRED: 'REFRESH_TOKEN_EXPIRED',\r\n ACCESS_TOKEN_EXPIRED: 'ACCESS_TOKEN_EXPIRED',\r\n ACCESS_TOKEN_REQUIRED: 'ACCESS_TOKEN_REQUIRED',\r\n TOKEN_REFRESH_TOO_EARLY: 'TOKEN_REFRESH_TOO_EARLY',\r\n EMAIL_NOT_VERIFIED: 'EMAIL_NOT_VERIFIED',\r\n PHONE_NOT_VERIFIED: 'PHONE_NOT_VERIFIED',\r\n TOKEN_NOT_FOUND: 'TOKEN_NOT_FOUND',\r\n INVALID_TOKEN: 'INVALID_TOKEN',\r\n RESET_PASSWORD_TOKEN_USED: 'RESET_PASSWORD_TOKEN_USED',\r\n RESET_PASSWORD_NEEDED: 'RESET_PASSWORD_NEEDED',\r\n ROLE_DISABLED: 'ROLE_DISABLED',\r\n SESSION_NOT_FOUND: 'SESSION_NOT_FOUND',\r\n SESSION_DISABLED: 'SESSION_DISABLED',\r\n INVALID_RESPONSE: 'INVALID_RESPONSE',\r\n UNKNOWN_CLIENT_ERROR: 'UNKNOWN_CLIENT_ERROR',\r\n INVALID_CREDENTIALS: 'INVALID_CREDENTIALS',\r\n VALIDATION_ERROR: 'VALIDATION_ERROR'\r\n} as const\r\n\r\nexport type APIErrorCode = (typeof APIErrorCode)[keyof typeof APIErrorCode]\r\n\r\nexport const API_ERROR_STATUS: Record<APIErrorCode, number> = {\r\n BAD_REQUEST: 400,\r\n UNAUTHORIZED: 401,\r\n FORBIDDEN: 403,\r\n NOT_FOUND: 404,\r\n ROUTE_NOT_FOUND: 404,\r\n TOO_MANY_REQUESTS: 429,\r\n CONFLICT: 409,\r\n INTERNAL_SERVER_ERROR: 500,\r\n TOKEN_EXPIRED: 401,\r\n REFRESH_TOKEN_EXPIRED: 401,\r\n ACCESS_TOKEN_EXPIRED: 401,\r\n ACCESS_TOKEN_REQUIRED: 401,\r\n TOKEN_REFRESH_TOO_EARLY: 403,\r\n EMAIL_NOT_VERIFIED: 401,\r\n PHONE_NOT_VERIFIED: 401,\r\n TOKEN_NOT_FOUND: 404,\r\n INVALID_TOKEN: 401,\r\n RESET_PASSWORD_TOKEN_USED: 401,\r\n RESET_PASSWORD_NEEDED: 400,\r\n ROLE_DISABLED: 403,\r\n SESSION_NOT_FOUND: 404,\r\n SESSION_DISABLED: 401,\r\n INVALID_RESPONSE: 500,\r\n UNKNOWN_CLIENT_ERROR: 400,\r\n INVALID_CREDENTIALS: 400,\r\n VALIDATION_ERROR: 400\r\n}\r\n\r\nexport type APIErrorDetailsMap = {\r\n TOKEN_REFRESH_TOO_EARLY: {\r\n retryIn: number\r\n retryAt: number\r\n },\r\n TOO_MANY_REQUESTS: {\r\n retryIn: number\r\n retryAt: number\r\n },\r\n VALIDATION_ERROR: {\r\n details: {\r\n field: PropertyKey\r\n message: string\r\n }[]\r\n }\r\n}\r\n\r\nexport type APIErrorDetails<T extends APIErrorCode> = T extends keyof APIErrorDetailsMap ? APIErrorDetailsMap[T] : never\r\n\r\ntype APIErrorCodeWithDetails = keyof APIErrorDetailsMap\r\ntype APIErrorCodeWithoutDetails = Exclude<APIErrorCode, APIErrorCodeWithDetails>\r\ntype AnyAPIErrorDetails = APIErrorDetailsMap[APIErrorCodeWithDetails]\r\ntype APIErrorConstructorArgs =\r\n | [code: APIErrorCodeWithoutDetails, message?: string]\r\n | {\r\n [TCode in APIErrorCodeWithDetails]: [\r\n code: TCode,\r\n message: string | undefined,\r\n details: APIErrorDetails<TCode>\r\n ]\r\n }[APIErrorCodeWithDetails]\r\n\r\nexport class APIError extends Error {\r\n public code: APIErrorCode\r\n public readonly status: number\r\n public readonly details?: AnyAPIErrorDetails\r\n\r\n constructor(...args: APIErrorConstructorArgs) {\r\n const [code, message, details] = args\r\n\r\n super(message)\r\n this.name = 'APIError'\r\n this.code = code\r\n this.status = API_ERROR_STATUS[code]\r\n this.details = details\r\n\r\n Object.setPrototypeOf(this, APIError.prototype)\r\n }\r\n}\r\n","\nimport { Request } from 'express'\nimport { APIError } from '../../api.error.js'\n\nexport default async function notFoundMiddleware(request: Request) {\n throw new APIError('ROUTE_NOT_FOUND', `Route ${request.path} is not found!`)\n}\n","import { Request, Response, NextFunction, CookieOptions } from 'express'\nimport { APIError } from '../../api.error.js'\n\nfunction isPlainObject(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null && Object.getPrototypeOf(value) === Object.prototype\n}\n\nconst createErrorMiddleware = (cookieTokenOptions: CookieOptions) =>\n (error: unknown, req: Request, res: Response, _: NextFunction) => {\n try {\n res.setHeader('Cache-Control', 'no-store')\n\n if (error instanceof APIError) {\n if (error.code === 'INTERNAL_SERVER_ERROR') {\n console.error(error)\n\n return res.status(error.status).json({\n success: false,\n error: error.code,\n message: 'An internal error is happening. Please contact developer as soon as possible!'\n })\n }\n\n if (error.code === 'TOKEN_NOT_FOUND')\n if (req.cookies.token)\n res.clearCookie('token', cookieTokenOptions)\n\n if (isPlainObject(error.details) && 'retryIn' in error.details && typeof error.details.retryIn === 'number')\n res.setHeader('Retry-After', error.details.retryIn)\n\n const responseBody = {\n success: false,\n error: error.code,\n ...(error.message ? { message: error.message } : {}),\n ...(isPlainObject(error.details) ? error.details : {})\n }\n\n return res.status(error.status).json(responseBody)\n }\n\n if (error instanceof SyntaxError) {\n return res.status((error as any).statusCode).json({\n success: false,\n error: 'JSON_PARSE_ERROR',\n message: error.message\n })\n }\n\n if (error instanceof Error) {\n console.error(error)\n\n return res.status(500).json({\n success: false,\n error: 'UNKNOWN_ERROR',\n message: 'An unknown error is happening. Please contact developer as soon as possible!'\n })\n }\n\n console.error('errorHandlerMiddleware', error)\n\n return res.status(500).json({\n success: false,\n error: 'INTERNAL_SERVER_ERROR',\n message: 'An internal error is happening. Please contact developer as soon as possible!'\n })\n } catch (error) {\n console.error('errorHandlerMiddleware', error)\n\n return res.status(500).json({\n success: false,\n error: 'INTERNAL_SERVER_ERROR',\n message: 'An internal error is happening. Please contact developer as soon as possible!'\n })\n }\n }\n\nexport default createErrorMiddleware\n"],"mappings":"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","names":["express","helmet","cors","createCorsMiddleware","allowedOrigins","cors","req","callback","origin","headers","indexOf","methods","credentials","request","response","next","ip","headers","Error","ipAddress","userAgent","path","length","endsWith","newPath","slice","query","url","redirect","filterMiddleware","API_ERROR_STATUS","BAD_REQUEST","UNAUTHORIZED","FORBIDDEN","NOT_FOUND","ROUTE_NOT_FOUND","TOO_MANY_REQUESTS","CONFLICT","INTERNAL_SERVER_ERROR","TOKEN_EXPIRED","REFRESH_TOKEN_EXPIRED","ACCESS_TOKEN_EXPIRED","ACCESS_TOKEN_REQUIRED","TOKEN_REFRESH_TOO_EARLY","EMAIL_NOT_VERIFIED","PHONE_NOT_VERIFIED","TOKEN_NOT_FOUND","INVALID_TOKEN","RESET_PASSWORD_TOKEN_USED","RESET_PASSWORD_NEEDED","ROLE_DISABLED","SESSION_NOT_FOUND","SESSION_DISABLED","INVALID_RESPONSE","UNKNOWN_CLIENT_ERROR","INVALID_CREDENTIALS","VALIDATION_ERROR","APIError","Error","code","status","details","args","message","name","Object","setPrototypeOf","prototype","request","APIError","path","notFoundMiddleware","isPlainObject","value","Object","getPrototypeOf","prototype","createErrorMiddleware","cookieTokenOptions","error","req","res","_","setHeader","APIError","code","console","status","json","success","message","cookies","token","clearCookie","details","retryIn","responseBody","SyntaxError","statusCode","Error","cookieParser","createExpressApp","options","app","express","set","disable","use","helmet","createCorsMiddleware","allowedOrigins","filterMiddleware","json","limit","cookieParser","cookieSecret","urlencoded","extended","static","dotfiles","etag","immutable","index","lastModified","maxAge","get","request","response","status","success","message","appName","data","userAgent","ipAddress","routes","public","private","notFoundMiddleware","createErrorMiddleware","cookieOptions"]}
|