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.
Files changed (218) hide show
  1. package/README.md +28 -0
  2. package/dist/api.error.cjs +107 -0
  3. package/dist/api.error.cjs.map +1 -0
  4. package/dist/api.error.d.cts +65 -0
  5. package/dist/api.error.d.ts +65 -0
  6. package/dist/api.error.js +83 -0
  7. package/dist/api.error.js.map +1 -0
  8. package/dist/base-class/base.controller.cjs +148 -0
  9. package/dist/base-class/base.controller.cjs.map +1 -0
  10. package/dist/base-class/base.controller.d.cts +38 -0
  11. package/dist/base-class/base.controller.d.ts +38 -0
  12. package/dist/base-class/base.controller.js +126 -0
  13. package/dist/base-class/base.controller.js.map +1 -0
  14. package/dist/base-class/base.entity.cjs +79 -0
  15. package/dist/base-class/base.entity.cjs.map +1 -0
  16. package/dist/base-class/base.entity.d.cts +8 -0
  17. package/dist/base-class/base.entity.d.ts +8 -0
  18. package/dist/base-class/base.entity.js +57 -0
  19. package/dist/base-class/base.entity.js.map +1 -0
  20. package/dist/base-class/base.model.cjs +204 -0
  21. package/dist/base-class/base.model.cjs.map +1 -0
  22. package/dist/base-class/base.model.d.cts +68 -0
  23. package/dist/base-class/base.model.d.ts +68 -0
  24. package/dist/base-class/base.model.js +182 -0
  25. package/dist/base-class/base.model.js.map +1 -0
  26. package/dist/base-class/base.service.cjs +37 -0
  27. package/dist/base-class/base.service.cjs.map +1 -0
  28. package/dist/base-class/base.service.d.cts +5 -0
  29. package/dist/base-class/base.service.d.ts +5 -0
  30. package/dist/base-class/base.service.js +15 -0
  31. package/dist/base-class/base.service.js.map +1 -0
  32. package/dist/base-class/index.cjs +392 -0
  33. package/dist/base-class/index.cjs.map +1 -0
  34. package/dist/base-class/index.d.cts +6 -0
  35. package/dist/base-class/index.d.ts +6 -0
  36. package/dist/base-class/index.js +365 -0
  37. package/dist/base-class/index.js.map +1 -0
  38. package/dist/cli/index.cjs +706 -0
  39. package/dist/cli/index.cjs.map +1 -0
  40. package/dist/cli/index.d.cts +3 -0
  41. package/dist/cli/index.d.ts +3 -0
  42. package/dist/cli/index.js +681 -0
  43. package/dist/cli/index.js.map +1 -0
  44. package/dist/cli/scripts/on-build.cjs +56 -0
  45. package/dist/cli/scripts/on-build.cjs.map +1 -0
  46. package/dist/cli/scripts/on-build.d.cts +3 -0
  47. package/dist/cli/scripts/on-build.d.ts +3 -0
  48. package/dist/cli/scripts/on-build.js +28 -0
  49. package/dist/cli/scripts/on-build.js.map +1 -0
  50. package/dist/cli/scripts/on-dev.cjs +483 -0
  51. package/dist/cli/scripts/on-dev.cjs.map +1 -0
  52. package/dist/cli/scripts/on-dev.d.cts +5 -0
  53. package/dist/cli/scripts/on-dev.d.ts +5 -0
  54. package/dist/cli/scripts/on-dev.js +449 -0
  55. package/dist/cli/scripts/on-dev.js.map +1 -0
  56. package/dist/cli/scripts/on-init.cjs +96 -0
  57. package/dist/cli/scripts/on-init.cjs.map +1 -0
  58. package/dist/cli/scripts/on-init.d.cts +3 -0
  59. package/dist/cli/scripts/on-init.d.ts +3 -0
  60. package/dist/cli/scripts/on-init.js +68 -0
  61. package/dist/cli/scripts/on-init.js.map +1 -0
  62. package/dist/cli/scripts/on-start.cjs +55 -0
  63. package/dist/cli/scripts/on-start.cjs.map +1 -0
  64. package/dist/cli/scripts/on-start.d.cts +3 -0
  65. package/dist/cli/scripts/on-start.d.ts +3 -0
  66. package/dist/cli/scripts/on-start.js +27 -0
  67. package/dist/cli/scripts/on-start.js.map +1 -0
  68. package/dist/client.cjs +405 -0
  69. package/dist/client.cjs.map +1 -0
  70. package/dist/client.d.cts +7 -0
  71. package/dist/client.d.ts +7 -0
  72. package/dist/client.js +371 -0
  73. package/dist/client.js.map +1 -0
  74. package/dist/constants.cjs +51 -0
  75. package/dist/constants.cjs.map +1 -0
  76. package/dist/constants.d.cts +7 -0
  77. package/dist/constants.d.ts +7 -0
  78. package/dist/constants.js +16 -0
  79. package/dist/constants.js.map +1 -0
  80. package/dist/database/column/index.cjs +34 -0
  81. package/dist/database/column/index.cjs.map +1 -0
  82. package/dist/database/column/index.d.cts +2 -0
  83. package/dist/database/column/index.d.ts +2 -0
  84. package/dist/database/column/index.js +8 -0
  85. package/dist/database/column/index.js.map +1 -0
  86. package/dist/database/index.cjs +83 -0
  87. package/dist/database/index.cjs.map +1 -0
  88. package/dist/database/index.d.cts +2 -0
  89. package/dist/database/index.d.ts +2 -0
  90. package/dist/database/index.js +60 -0
  91. package/dist/database/index.js.map +1 -0
  92. package/dist/database/snake-naming-strategy.class.cjs +78 -0
  93. package/dist/database/snake-naming-strategy.class.cjs.map +1 -0
  94. package/dist/database/snake-naming-strategy.class.d.cts +16 -0
  95. package/dist/database/snake-naming-strategy.class.d.ts +16 -0
  96. package/dist/database/snake-naming-strategy.class.js +56 -0
  97. package/dist/database/snake-naming-strategy.class.js.map +1 -0
  98. package/dist/error.cjs +46 -0
  99. package/dist/error.cjs.map +1 -0
  100. package/dist/error.d.cts +10 -0
  101. package/dist/error.d.ts +10 -0
  102. package/dist/error.js +28 -0
  103. package/dist/error.js.map +1 -0
  104. package/dist/express/app.cjs +233 -0
  105. package/dist/express/app.cjs.map +1 -0
  106. package/dist/express/app.d.cts +16 -0
  107. package/dist/express/app.d.ts +16 -0
  108. package/dist/express/app.js +205 -0
  109. package/dist/express/app.js.map +1 -0
  110. package/dist/express/index.cjs +239 -0
  111. package/dist/express/index.cjs.map +1 -0
  112. package/dist/express/index.d.cts +3 -0
  113. package/dist/express/index.d.ts +3 -0
  114. package/dist/express/index.js +205 -0
  115. package/dist/express/index.js.map +1 -0
  116. package/dist/express/middleware/cors.middleware.cjs +54 -0
  117. package/dist/express/middleware/cors.middleware.cjs.map +1 -0
  118. package/dist/express/middleware/cors.middleware.d.cts +9 -0
  119. package/dist/express/middleware/cors.middleware.d.ts +9 -0
  120. package/dist/express/middleware/cors.middleware.js +26 -0
  121. package/dist/express/middleware/cors.middleware.js.map +1 -0
  122. package/dist/express/middleware/error.middleware.cjs +136 -0
  123. package/dist/express/middleware/error.middleware.cjs.map +1 -0
  124. package/dist/express/middleware/error.middleware.d.cts +5 -0
  125. package/dist/express/middleware/error.middleware.d.ts +5 -0
  126. package/dist/express/middleware/error.middleware.js +116 -0
  127. package/dist/express/middleware/error.middleware.js.map +1 -0
  128. package/dist/express/middleware/filter.middleware.cjs +38 -0
  129. package/dist/express/middleware/filter.middleware.cjs.map +1 -0
  130. package/dist/express/middleware/filter.middleware.d.cts +5 -0
  131. package/dist/express/middleware/filter.middleware.d.ts +5 -0
  132. package/dist/express/middleware/filter.middleware.js +20 -0
  133. package/dist/express/middleware/filter.middleware.js.map +1 -0
  134. package/dist/express/middleware/index.cjs +206 -0
  135. package/dist/express/middleware/index.cjs.map +1 -0
  136. package/dist/express/middleware/index.d.cts +19 -0
  137. package/dist/express/middleware/index.d.ts +19 -0
  138. package/dist/express/middleware/index.js +169 -0
  139. package/dist/express/middleware/index.js.map +1 -0
  140. package/dist/express/middleware/not-found.middleware.cjs +79 -0
  141. package/dist/express/middleware/not-found.middleware.cjs.map +1 -0
  142. package/dist/express/middleware/not-found.middleware.d.cts +5 -0
  143. package/dist/express/middleware/not-found.middleware.d.ts +5 -0
  144. package/dist/express/middleware/not-found.middleware.js +59 -0
  145. package/dist/express/middleware/not-found.middleware.js.map +1 -0
  146. package/dist/generator.cjs +258 -0
  147. package/dist/generator.cjs.map +1 -0
  148. package/dist/generator.d.cts +10 -0
  149. package/dist/generator.d.ts +10 -0
  150. package/dist/generator.js +220 -0
  151. package/dist/generator.js.map +1 -0
  152. package/dist/http.cjs +82 -0
  153. package/dist/http.cjs.map +1 -0
  154. package/dist/http.d.cts +11 -0
  155. package/dist/http.d.ts +11 -0
  156. package/dist/http.js +64 -0
  157. package/dist/http.js.map +1 -0
  158. package/dist/index.cjs +831 -0
  159. package/dist/index.cjs.map +1 -0
  160. package/dist/index.d.cts +19 -0
  161. package/dist/index.d.ts +19 -0
  162. package/dist/index.js +783 -0
  163. package/dist/index.js.map +1 -0
  164. package/dist/lib/create-env-file.cjs +69 -0
  165. package/dist/lib/create-env-file.cjs.map +1 -0
  166. package/dist/lib/create-env-file.d.cts +3 -0
  167. package/dist/lib/create-env-file.d.ts +3 -0
  168. package/dist/lib/create-env-file.js +31 -0
  169. package/dist/lib/create-env-file.js.map +1 -0
  170. package/dist/lib/helper.cjs +94 -0
  171. package/dist/lib/helper.cjs.map +1 -0
  172. package/dist/lib/helper.d.cts +13 -0
  173. package/dist/lib/helper.d.ts +13 -0
  174. package/dist/lib/helper.js +62 -0
  175. package/dist/lib/helper.js.map +1 -0
  176. package/dist/lib/model.generator.cjs +212 -0
  177. package/dist/lib/model.generator.cjs.map +1 -0
  178. package/dist/lib/model.generator.d.cts +29 -0
  179. package/dist/lib/model.generator.d.ts +29 -0
  180. package/dist/lib/model.generator.js +174 -0
  181. package/dist/lib/model.generator.js.map +1 -0
  182. package/dist/lib/pre-init-dev-script.cjs +336 -0
  183. package/dist/lib/pre-init-dev-script.cjs.map +1 -0
  184. package/dist/lib/pre-init-dev-script.d.cts +2 -0
  185. package/dist/lib/pre-init-dev-script.d.ts +2 -0
  186. package/dist/lib/pre-init-dev-script.js +311 -0
  187. package/dist/lib/pre-init-dev-script.js.map +1 -0
  188. package/dist/mahameru.cjs +397 -0
  189. package/dist/mahameru.cjs.map +1 -0
  190. package/dist/mahameru.d.cts +78 -0
  191. package/dist/mahameru.d.ts +78 -0
  192. package/dist/mahameru.js +359 -0
  193. package/dist/mahameru.js.map +1 -0
  194. package/dist/request.cjs +35 -0
  195. package/dist/request.cjs.map +1 -0
  196. package/dist/request.d.cts +4 -0
  197. package/dist/request.d.ts +4 -0
  198. package/dist/request.js +13 -0
  199. package/dist/request.js.map +1 -0
  200. package/dist/response.cjs +35 -0
  201. package/dist/response.cjs.map +1 -0
  202. package/dist/response.d.cts +4 -0
  203. package/dist/response.d.ts +4 -0
  204. package/dist/response.js +13 -0
  205. package/dist/response.js.map +1 -0
  206. package/dist/types.cjs +1 -0
  207. package/dist/types.cjs.map +1 -0
  208. package/dist/types.d.cts +2 -0
  209. package/dist/types.d.ts +2 -0
  210. package/dist/types.js +1 -0
  211. package/dist/types.js.map +1 -0
  212. package/dist/utils/import-dynamic-module.cjs +34 -0
  213. package/dist/utils/import-dynamic-module.cjs.map +1 -0
  214. package/dist/utils/import-dynamic-module.d.cts +3 -0
  215. package/dist/utils/import-dynamic-module.d.ts +3 -0
  216. package/dist/utils/import-dynamic-module.js +12 -0
  217. package/dist/utils/import-dynamic-module.js.map +1 -0
  218. 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":"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","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"]}