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,239 @@
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/index.ts
31
+ var express_exports = {};
32
+ __export(express_exports, {
33
+ createExpressApp: () => app_default
34
+ });
35
+ module.exports = __toCommonJS(express_exports);
36
+
37
+ // src/express/app.ts
38
+ var import_express = __toESM(require("express"), 1);
39
+ var import_helmet = __toESM(require("helmet"), 1);
40
+
41
+ // src/express/middleware/cors.middleware.ts
42
+ var import_cors = __toESM(require("cors"), 1);
43
+ var createCorsMiddleware = /* @__PURE__ */ __name((allowedOrigins) => {
44
+ return (0, import_cors.default)((req, callback) => {
45
+ let origin = req.headers["origin"];
46
+ if (!origin || allowedOrigins.indexOf(origin) !== -1) {
47
+ callback(null, {
48
+ origin: true,
49
+ methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
50
+ credentials: true
51
+ });
52
+ } else {
53
+ callback(null, {
54
+ origin: false
55
+ });
56
+ }
57
+ });
58
+ }, "createCorsMiddleware");
59
+ var cors_middleware_default = createCorsMiddleware;
60
+
61
+ // src/express/middleware/filter.middleware.ts
62
+ async function filterMiddleware(request, response, next) {
63
+ if (!request.ip || !request.headers["user-agent"]) throw new Error("Access denied");
64
+ request.ipAddress = request.ip;
65
+ request.userAgent = request.headers["user-agent"];
66
+ if (request.path.length > 1 && request.path.endsWith("/")) {
67
+ const newPath = request.path.slice(0, -1);
68
+ const query = request.url.slice(request.path.length);
69
+ return response.redirect(301, newPath + query);
70
+ }
71
+ return next();
72
+ }
73
+ __name(filterMiddleware, "filterMiddleware");
74
+
75
+ // src/api.error.ts
76
+ var API_ERROR_STATUS = {
77
+ BAD_REQUEST: 400,
78
+ UNAUTHORIZED: 401,
79
+ FORBIDDEN: 403,
80
+ NOT_FOUND: 404,
81
+ ROUTE_NOT_FOUND: 404,
82
+ TOO_MANY_REQUESTS: 429,
83
+ CONFLICT: 409,
84
+ INTERNAL_SERVER_ERROR: 500,
85
+ TOKEN_EXPIRED: 401,
86
+ REFRESH_TOKEN_EXPIRED: 401,
87
+ ACCESS_TOKEN_EXPIRED: 401,
88
+ ACCESS_TOKEN_REQUIRED: 401,
89
+ TOKEN_REFRESH_TOO_EARLY: 403,
90
+ EMAIL_NOT_VERIFIED: 401,
91
+ PHONE_NOT_VERIFIED: 401,
92
+ TOKEN_NOT_FOUND: 404,
93
+ INVALID_TOKEN: 401,
94
+ RESET_PASSWORD_TOKEN_USED: 401,
95
+ RESET_PASSWORD_NEEDED: 400,
96
+ ROLE_DISABLED: 403,
97
+ SESSION_NOT_FOUND: 404,
98
+ SESSION_DISABLED: 401,
99
+ INVALID_RESPONSE: 500,
100
+ UNKNOWN_CLIENT_ERROR: 400,
101
+ INVALID_CREDENTIALS: 400,
102
+ VALIDATION_ERROR: 400
103
+ };
104
+ var APIError = class _APIError extends Error {
105
+ static {
106
+ __name(this, "APIError");
107
+ }
108
+ code;
109
+ status;
110
+ details;
111
+ constructor(...args) {
112
+ const [code, message, details] = args;
113
+ super(message);
114
+ this.name = "APIError";
115
+ this.code = code;
116
+ this.status = API_ERROR_STATUS[code];
117
+ this.details = details;
118
+ Object.setPrototypeOf(this, _APIError.prototype);
119
+ }
120
+ };
121
+
122
+ // src/express/middleware/not-found.middleware.ts
123
+ async function notFoundMiddleware(request) {
124
+ throw new APIError("ROUTE_NOT_FOUND", `Route ${request.path} is not found!`);
125
+ }
126
+ __name(notFoundMiddleware, "notFoundMiddleware");
127
+
128
+ // src/express/middleware/error.middleware.ts
129
+ function isPlainObject(value) {
130
+ return typeof value === "object" && value !== null && Object.getPrototypeOf(value) === Object.prototype;
131
+ }
132
+ __name(isPlainObject, "isPlainObject");
133
+ var createErrorMiddleware = /* @__PURE__ */ __name((cookieTokenOptions) => (error, req, res, _) => {
134
+ try {
135
+ res.setHeader("Cache-Control", "no-store");
136
+ if (error instanceof APIError) {
137
+ if (error.code === "INTERNAL_SERVER_ERROR") {
138
+ console.error(error);
139
+ return res.status(error.status).json({
140
+ success: false,
141
+ error: error.code,
142
+ message: "An internal error is happening. Please contact developer as soon as possible!"
143
+ });
144
+ }
145
+ if (error.code === "TOKEN_NOT_FOUND") {
146
+ if (req.cookies.token) res.clearCookie("token", cookieTokenOptions);
147
+ }
148
+ if (isPlainObject(error.details) && "retryIn" in error.details && typeof error.details.retryIn === "number") res.setHeader("Retry-After", error.details.retryIn);
149
+ const responseBody = {
150
+ success: false,
151
+ error: error.code,
152
+ ...error.message ? {
153
+ message: error.message
154
+ } : {},
155
+ ...isPlainObject(error.details) ? error.details : {}
156
+ };
157
+ return res.status(error.status).json(responseBody);
158
+ }
159
+ if (error instanceof SyntaxError) {
160
+ return res.status(error.statusCode).json({
161
+ success: false,
162
+ error: "JSON_PARSE_ERROR",
163
+ message: error.message
164
+ });
165
+ }
166
+ if (error instanceof Error) {
167
+ console.error(error);
168
+ return res.status(500).json({
169
+ success: false,
170
+ error: "UNKNOWN_ERROR",
171
+ message: "An unknown error is happening. Please contact developer as soon as possible!"
172
+ });
173
+ }
174
+ console.error("errorHandlerMiddleware", error);
175
+ return res.status(500).json({
176
+ success: false,
177
+ error: "INTERNAL_SERVER_ERROR",
178
+ message: "An internal error is happening. Please contact developer as soon as possible!"
179
+ });
180
+ } catch (error2) {
181
+ console.error("errorHandlerMiddleware", error2);
182
+ return res.status(500).json({
183
+ success: false,
184
+ error: "INTERNAL_SERVER_ERROR",
185
+ message: "An internal error is happening. Please contact developer as soon as possible!"
186
+ });
187
+ }
188
+ }, "createErrorMiddleware");
189
+ var error_middleware_default = createErrorMiddleware;
190
+
191
+ // src/express/app.ts
192
+ var import_cookie_parser = __toESM(require("cookie-parser"), 1);
193
+ var createExpressApp = /* @__PURE__ */ __name((options) => {
194
+ const app = (0, import_express.default)();
195
+ app.set("trust proxy", 1);
196
+ app.disable("x-powered-by");
197
+ app.use((0, import_helmet.default)());
198
+ app.use(cors_middleware_default(options.allowedOrigins));
199
+ app.use(filterMiddleware);
200
+ app.use(import_express.default.json({
201
+ limit: "1mb"
202
+ }));
203
+ app.use((0, import_cookie_parser.default)(options.cookieSecret));
204
+ app.use(import_express.default.urlencoded({
205
+ extended: true,
206
+ limit: "1mb"
207
+ }));
208
+ app.use(import_express.default.static("public", {
209
+ dotfiles: "deny",
210
+ etag: true,
211
+ immutable: false,
212
+ index: false,
213
+ lastModified: true,
214
+ maxAge: "1h"
215
+ }));
216
+ app.get("/", (request, response) => {
217
+ return response.status(200).json({
218
+ success: true,
219
+ message: `Welcome to ${options.appName}`,
220
+ data: {
221
+ userAgent: request.userAgent,
222
+ ipAddress: request.ipAddress
223
+ }
224
+ });
225
+ });
226
+ if (options.routes) {
227
+ app.use(options.routes.public);
228
+ app.use(options.routes.private);
229
+ }
230
+ app.use(notFoundMiddleware);
231
+ app.use(error_middleware_default(options.cookieOptions));
232
+ return app;
233
+ }, "createExpressApp");
234
+ var app_default = createExpressApp;
235
+ // Annotate the CommonJS export names for ESM import in node:
236
+ 0 && (module.exports = {
237
+ createExpressApp
238
+ });
239
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/express/index.ts","../../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 createExpressApp from \"./app.js\";\r\n\r\nexport {\r\n createExpressApp\r\n}\r\n","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,3 @@
1
+ export { default as createExpressApp } from './app.cjs';
2
+ import 'express-serve-static-core';
3
+ import 'express';
@@ -0,0 +1,3 @@
1
+ export { default as createExpressApp } from './app.js';
2
+ import 'express-serve-static-core';
3
+ import 'express';
@@ -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 createExpressApp
204
+ };
205
+ //# sourceMappingURL=index.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"]}
@@ -0,0 +1,54 @@
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/middleware/cors.middleware.ts
31
+ var cors_middleware_exports = {};
32
+ __export(cors_middleware_exports, {
33
+ default: () => cors_middleware_default
34
+ });
35
+ module.exports = __toCommonJS(cors_middleware_exports);
36
+ var import_cors = __toESM(require("cors"), 1);
37
+ var createCorsMiddleware = /* @__PURE__ */ __name((allowedOrigins) => {
38
+ return (0, import_cors.default)((req, callback) => {
39
+ let origin = req.headers["origin"];
40
+ if (!origin || allowedOrigins.indexOf(origin) !== -1) {
41
+ callback(null, {
42
+ origin: true,
43
+ methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
44
+ credentials: true
45
+ });
46
+ } else {
47
+ callback(null, {
48
+ origin: false
49
+ });
50
+ }
51
+ });
52
+ }, "createCorsMiddleware");
53
+ var cors_middleware_default = createCorsMiddleware;
54
+ //# sourceMappingURL=cors.middleware.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/express/middleware/cors.middleware.ts"],"sourcesContent":["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"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;AAAA,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;","names":["createCorsMiddleware","allowedOrigins","cors","req","callback","origin","headers","indexOf","methods","credentials"]}
@@ -0,0 +1,9 @@
1
+ import cors__default from 'cors';
2
+
3
+ declare const createCorsMiddleware: (allowedOrigins: string[]) => (req: cors__default.CorsRequest, res: {
4
+ statusCode?: number | undefined;
5
+ setHeader(key: string, value: string): any;
6
+ end(): any;
7
+ }, next: (err?: any) => any) => void;
8
+
9
+ export { createCorsMiddleware as default };
@@ -0,0 +1,9 @@
1
+ import cors__default from 'cors';
2
+
3
+ declare const createCorsMiddleware: (allowedOrigins: string[]) => (req: cors__default.CorsRequest, res: {
4
+ statusCode?: number | undefined;
5
+ setHeader(key: string, value: string): any;
6
+ end(): any;
7
+ }, next: (err?: any) => any) => void;
8
+
9
+ export { createCorsMiddleware as default };
@@ -0,0 +1,26 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/express/middleware/cors.middleware.ts
5
+ import cors from "cors";
6
+ var createCorsMiddleware = /* @__PURE__ */ __name((allowedOrigins) => {
7
+ return cors((req, callback) => {
8
+ let origin = req.headers["origin"];
9
+ if (!origin || allowedOrigins.indexOf(origin) !== -1) {
10
+ callback(null, {
11
+ origin: true,
12
+ methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
13
+ credentials: true
14
+ });
15
+ } else {
16
+ callback(null, {
17
+ origin: false
18
+ });
19
+ }
20
+ });
21
+ }, "createCorsMiddleware");
22
+ var cors_middleware_default = createCorsMiddleware;
23
+ export {
24
+ cors_middleware_default as default
25
+ };
26
+ //# sourceMappingURL=cors.middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/express/middleware/cors.middleware.ts"],"sourcesContent":["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"],"mappings":";;;;AAAA,OAAOA,UAAwC;AAG/C,IAAMC,uBAAuB,wBAACC,mBAAAA;AAC1B,SAAOC,KAAK,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;","names":["cors","createCorsMiddleware","allowedOrigins","cors","req","callback","origin","headers","indexOf","methods","credentials"]}