mahameru 0.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +28 -0
- package/dist/api.error.cjs +107 -0
- package/dist/api.error.cjs.map +1 -0
- package/dist/api.error.d.cts +65 -0
- package/dist/api.error.d.ts +65 -0
- package/dist/api.error.js +83 -0
- package/dist/api.error.js.map +1 -0
- package/dist/base-class/base.controller.cjs +148 -0
- package/dist/base-class/base.controller.cjs.map +1 -0
- package/dist/base-class/base.controller.d.cts +38 -0
- package/dist/base-class/base.controller.d.ts +38 -0
- package/dist/base-class/base.controller.js +126 -0
- package/dist/base-class/base.controller.js.map +1 -0
- package/dist/base-class/base.entity.cjs +79 -0
- package/dist/base-class/base.entity.cjs.map +1 -0
- package/dist/base-class/base.entity.d.cts +8 -0
- package/dist/base-class/base.entity.d.ts +8 -0
- package/dist/base-class/base.entity.js +57 -0
- package/dist/base-class/base.entity.js.map +1 -0
- package/dist/base-class/base.model.cjs +204 -0
- package/dist/base-class/base.model.cjs.map +1 -0
- package/dist/base-class/base.model.d.cts +68 -0
- package/dist/base-class/base.model.d.ts +68 -0
- package/dist/base-class/base.model.js +182 -0
- package/dist/base-class/base.model.js.map +1 -0
- package/dist/base-class/base.service.cjs +37 -0
- package/dist/base-class/base.service.cjs.map +1 -0
- package/dist/base-class/base.service.d.cts +5 -0
- package/dist/base-class/base.service.d.ts +5 -0
- package/dist/base-class/base.service.js +15 -0
- package/dist/base-class/base.service.js.map +1 -0
- package/dist/base-class/index.cjs +392 -0
- package/dist/base-class/index.cjs.map +1 -0
- package/dist/base-class/index.d.cts +6 -0
- package/dist/base-class/index.d.ts +6 -0
- package/dist/base-class/index.js +365 -0
- package/dist/base-class/index.js.map +1 -0
- package/dist/cli/index.cjs +706 -0
- package/dist/cli/index.cjs.map +1 -0
- package/dist/cli/index.d.cts +3 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.js +681 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/scripts/on-build.cjs +56 -0
- package/dist/cli/scripts/on-build.cjs.map +1 -0
- package/dist/cli/scripts/on-build.d.cts +3 -0
- package/dist/cli/scripts/on-build.d.ts +3 -0
- package/dist/cli/scripts/on-build.js +28 -0
- package/dist/cli/scripts/on-build.js.map +1 -0
- package/dist/cli/scripts/on-dev.cjs +483 -0
- package/dist/cli/scripts/on-dev.cjs.map +1 -0
- package/dist/cli/scripts/on-dev.d.cts +5 -0
- package/dist/cli/scripts/on-dev.d.ts +5 -0
- package/dist/cli/scripts/on-dev.js +449 -0
- package/dist/cli/scripts/on-dev.js.map +1 -0
- package/dist/cli/scripts/on-init.cjs +96 -0
- package/dist/cli/scripts/on-init.cjs.map +1 -0
- package/dist/cli/scripts/on-init.d.cts +3 -0
- package/dist/cli/scripts/on-init.d.ts +3 -0
- package/dist/cli/scripts/on-init.js +68 -0
- package/dist/cli/scripts/on-init.js.map +1 -0
- package/dist/cli/scripts/on-start.cjs +55 -0
- package/dist/cli/scripts/on-start.cjs.map +1 -0
- package/dist/cli/scripts/on-start.d.cts +3 -0
- package/dist/cli/scripts/on-start.d.ts +3 -0
- package/dist/cli/scripts/on-start.js +27 -0
- package/dist/cli/scripts/on-start.js.map +1 -0
- package/dist/client.cjs +405 -0
- package/dist/client.cjs.map +1 -0
- package/dist/client.d.cts +7 -0
- package/dist/client.d.ts +7 -0
- package/dist/client.js +371 -0
- package/dist/client.js.map +1 -0
- package/dist/constants.cjs +51 -0
- package/dist/constants.cjs.map +1 -0
- package/dist/constants.d.cts +7 -0
- package/dist/constants.d.ts +7 -0
- package/dist/constants.js +16 -0
- package/dist/constants.js.map +1 -0
- package/dist/database/column/index.cjs +34 -0
- package/dist/database/column/index.cjs.map +1 -0
- package/dist/database/column/index.d.cts +2 -0
- package/dist/database/column/index.d.ts +2 -0
- package/dist/database/column/index.js +8 -0
- package/dist/database/column/index.js.map +1 -0
- package/dist/database/index.cjs +83 -0
- package/dist/database/index.cjs.map +1 -0
- package/dist/database/index.d.cts +2 -0
- package/dist/database/index.d.ts +2 -0
- package/dist/database/index.js +60 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/snake-naming-strategy.class.cjs +78 -0
- package/dist/database/snake-naming-strategy.class.cjs.map +1 -0
- package/dist/database/snake-naming-strategy.class.d.cts +16 -0
- package/dist/database/snake-naming-strategy.class.d.ts +16 -0
- package/dist/database/snake-naming-strategy.class.js +56 -0
- package/dist/database/snake-naming-strategy.class.js.map +1 -0
- package/dist/error.cjs +46 -0
- package/dist/error.cjs.map +1 -0
- package/dist/error.d.cts +10 -0
- package/dist/error.d.ts +10 -0
- package/dist/error.js +28 -0
- package/dist/error.js.map +1 -0
- package/dist/express/app.cjs +233 -0
- package/dist/express/app.cjs.map +1 -0
- package/dist/express/app.d.cts +16 -0
- package/dist/express/app.d.ts +16 -0
- package/dist/express/app.js +205 -0
- package/dist/express/app.js.map +1 -0
- package/dist/express/index.cjs +239 -0
- package/dist/express/index.cjs.map +1 -0
- package/dist/express/index.d.cts +3 -0
- package/dist/express/index.d.ts +3 -0
- package/dist/express/index.js +205 -0
- package/dist/express/index.js.map +1 -0
- package/dist/express/middleware/cors.middleware.cjs +54 -0
- package/dist/express/middleware/cors.middleware.cjs.map +1 -0
- package/dist/express/middleware/cors.middleware.d.cts +9 -0
- package/dist/express/middleware/cors.middleware.d.ts +9 -0
- package/dist/express/middleware/cors.middleware.js +26 -0
- package/dist/express/middleware/cors.middleware.js.map +1 -0
- package/dist/express/middleware/error.middleware.cjs +136 -0
- package/dist/express/middleware/error.middleware.cjs.map +1 -0
- package/dist/express/middleware/error.middleware.d.cts +5 -0
- package/dist/express/middleware/error.middleware.d.ts +5 -0
- package/dist/express/middleware/error.middleware.js +116 -0
- package/dist/express/middleware/error.middleware.js.map +1 -0
- package/dist/express/middleware/filter.middleware.cjs +38 -0
- package/dist/express/middleware/filter.middleware.cjs.map +1 -0
- package/dist/express/middleware/filter.middleware.d.cts +5 -0
- package/dist/express/middleware/filter.middleware.d.ts +5 -0
- package/dist/express/middleware/filter.middleware.js +20 -0
- package/dist/express/middleware/filter.middleware.js.map +1 -0
- package/dist/express/middleware/index.cjs +206 -0
- package/dist/express/middleware/index.cjs.map +1 -0
- package/dist/express/middleware/index.d.cts +19 -0
- package/dist/express/middleware/index.d.ts +19 -0
- package/dist/express/middleware/index.js +169 -0
- package/dist/express/middleware/index.js.map +1 -0
- package/dist/express/middleware/not-found.middleware.cjs +79 -0
- package/dist/express/middleware/not-found.middleware.cjs.map +1 -0
- package/dist/express/middleware/not-found.middleware.d.cts +5 -0
- package/dist/express/middleware/not-found.middleware.d.ts +5 -0
- package/dist/express/middleware/not-found.middleware.js +59 -0
- package/dist/express/middleware/not-found.middleware.js.map +1 -0
- package/dist/generator.cjs +258 -0
- package/dist/generator.cjs.map +1 -0
- package/dist/generator.d.cts +10 -0
- package/dist/generator.d.ts +10 -0
- package/dist/generator.js +220 -0
- package/dist/generator.js.map +1 -0
- package/dist/http.cjs +82 -0
- package/dist/http.cjs.map +1 -0
- package/dist/http.d.cts +11 -0
- package/dist/http.d.ts +11 -0
- package/dist/http.js +64 -0
- package/dist/http.js.map +1 -0
- package/dist/index.cjs +831 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +19 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.js +783 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/create-env-file.cjs +69 -0
- package/dist/lib/create-env-file.cjs.map +1 -0
- package/dist/lib/create-env-file.d.cts +3 -0
- package/dist/lib/create-env-file.d.ts +3 -0
- package/dist/lib/create-env-file.js +31 -0
- package/dist/lib/create-env-file.js.map +1 -0
- package/dist/lib/helper.cjs +94 -0
- package/dist/lib/helper.cjs.map +1 -0
- package/dist/lib/helper.d.cts +13 -0
- package/dist/lib/helper.d.ts +13 -0
- package/dist/lib/helper.js +62 -0
- package/dist/lib/helper.js.map +1 -0
- package/dist/lib/model.generator.cjs +212 -0
- package/dist/lib/model.generator.cjs.map +1 -0
- package/dist/lib/model.generator.d.cts +29 -0
- package/dist/lib/model.generator.d.ts +29 -0
- package/dist/lib/model.generator.js +174 -0
- package/dist/lib/model.generator.js.map +1 -0
- package/dist/lib/pre-init-dev-script.cjs +336 -0
- package/dist/lib/pre-init-dev-script.cjs.map +1 -0
- package/dist/lib/pre-init-dev-script.d.cts +2 -0
- package/dist/lib/pre-init-dev-script.d.ts +2 -0
- package/dist/lib/pre-init-dev-script.js +311 -0
- package/dist/lib/pre-init-dev-script.js.map +1 -0
- package/dist/mahameru.cjs +397 -0
- package/dist/mahameru.cjs.map +1 -0
- package/dist/mahameru.d.cts +78 -0
- package/dist/mahameru.d.ts +78 -0
- package/dist/mahameru.js +359 -0
- package/dist/mahameru.js.map +1 -0
- package/dist/request.cjs +35 -0
- package/dist/request.cjs.map +1 -0
- package/dist/request.d.cts +4 -0
- package/dist/request.d.ts +4 -0
- package/dist/request.js +13 -0
- package/dist/request.js.map +1 -0
- package/dist/response.cjs +35 -0
- package/dist/response.cjs.map +1 -0
- package/dist/response.d.cts +4 -0
- package/dist/response.d.ts +4 -0
- package/dist/response.js +13 -0
- package/dist/response.js.map +1 -0
- package/dist/types.cjs +1 -0
- package/dist/types.cjs.map +1 -0
- package/dist/types.d.cts +2 -0
- package/dist/types.d.ts +2 -0
- package/dist/types.js +1 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/import-dynamic-module.cjs +34 -0
- package/dist/utils/import-dynamic-module.cjs.map +1 -0
- package/dist/utils/import-dynamic-module.d.cts +3 -0
- package/dist/utils/import-dynamic-module.d.ts +3 -0
- package/dist/utils/import-dynamic-module.js +12 -0
- package/dist/utils/import-dynamic-module.js.map +1 -0
- package/package.json +70 -0
package/dist/mahameru.js
ADDED
|
@@ -0,0 +1,359 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/error.ts
|
|
5
|
+
var MahameruError = class extends Error {
|
|
6
|
+
static {
|
|
7
|
+
__name(this, "MahameruError");
|
|
8
|
+
}
|
|
9
|
+
constructor(message) {
|
|
10
|
+
super(message);
|
|
11
|
+
this.name = "MahameruError";
|
|
12
|
+
this.message = message;
|
|
13
|
+
Error.captureStackTrace(this, this.constructor);
|
|
14
|
+
}
|
|
15
|
+
toString() {
|
|
16
|
+
return `${this.name}: ${this.message}`;
|
|
17
|
+
}
|
|
18
|
+
toJSON() {
|
|
19
|
+
return {
|
|
20
|
+
name: this.name,
|
|
21
|
+
message: this.message
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
// src/mahameru.ts
|
|
27
|
+
import { writeFile } from "fs/promises";
|
|
28
|
+
import path from "path";
|
|
29
|
+
import { existsSync } from "fs";
|
|
30
|
+
import { spawn } from "child_process";
|
|
31
|
+
|
|
32
|
+
// src/constants.ts
|
|
33
|
+
import { dirname } from "path";
|
|
34
|
+
import { fileURLToPath } from "url";
|
|
35
|
+
var root = process.cwd();
|
|
36
|
+
var __filename2 = fileURLToPath(import.meta.url);
|
|
37
|
+
var __dirname2 = dirname(__filename2);
|
|
38
|
+
var isCommonJS = typeof module !== "undefined" && !!module.exports;
|
|
39
|
+
|
|
40
|
+
// src/express/app.ts
|
|
41
|
+
import express from "express";
|
|
42
|
+
import helmet from "helmet";
|
|
43
|
+
|
|
44
|
+
// src/express/middleware/cors.middleware.ts
|
|
45
|
+
import cors from "cors";
|
|
46
|
+
var createCorsMiddleware = /* @__PURE__ */ __name((allowedOrigins) => {
|
|
47
|
+
return cors((req, callback) => {
|
|
48
|
+
let origin = req.headers["origin"];
|
|
49
|
+
if (!origin || allowedOrigins.indexOf(origin) !== -1) {
|
|
50
|
+
callback(null, {
|
|
51
|
+
origin: true,
|
|
52
|
+
methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
|
|
53
|
+
credentials: true
|
|
54
|
+
});
|
|
55
|
+
} else {
|
|
56
|
+
callback(null, {
|
|
57
|
+
origin: false
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}, "createCorsMiddleware");
|
|
62
|
+
var cors_middleware_default = createCorsMiddleware;
|
|
63
|
+
|
|
64
|
+
// src/express/middleware/filter.middleware.ts
|
|
65
|
+
async function filterMiddleware(request, response, next) {
|
|
66
|
+
if (!request.ip || !request.headers["user-agent"]) throw new Error("Access denied");
|
|
67
|
+
request.ipAddress = request.ip;
|
|
68
|
+
request.userAgent = request.headers["user-agent"];
|
|
69
|
+
if (request.path.length > 1 && request.path.endsWith("/")) {
|
|
70
|
+
const newPath = request.path.slice(0, -1);
|
|
71
|
+
const query = request.url.slice(request.path.length);
|
|
72
|
+
return response.redirect(301, newPath + query);
|
|
73
|
+
}
|
|
74
|
+
return next();
|
|
75
|
+
}
|
|
76
|
+
__name(filterMiddleware, "filterMiddleware");
|
|
77
|
+
|
|
78
|
+
// src/api.error.ts
|
|
79
|
+
var API_ERROR_STATUS = {
|
|
80
|
+
BAD_REQUEST: 400,
|
|
81
|
+
UNAUTHORIZED: 401,
|
|
82
|
+
FORBIDDEN: 403,
|
|
83
|
+
NOT_FOUND: 404,
|
|
84
|
+
ROUTE_NOT_FOUND: 404,
|
|
85
|
+
TOO_MANY_REQUESTS: 429,
|
|
86
|
+
CONFLICT: 409,
|
|
87
|
+
INTERNAL_SERVER_ERROR: 500,
|
|
88
|
+
TOKEN_EXPIRED: 401,
|
|
89
|
+
REFRESH_TOKEN_EXPIRED: 401,
|
|
90
|
+
ACCESS_TOKEN_EXPIRED: 401,
|
|
91
|
+
ACCESS_TOKEN_REQUIRED: 401,
|
|
92
|
+
TOKEN_REFRESH_TOO_EARLY: 403,
|
|
93
|
+
EMAIL_NOT_VERIFIED: 401,
|
|
94
|
+
PHONE_NOT_VERIFIED: 401,
|
|
95
|
+
TOKEN_NOT_FOUND: 404,
|
|
96
|
+
INVALID_TOKEN: 401,
|
|
97
|
+
RESET_PASSWORD_TOKEN_USED: 401,
|
|
98
|
+
RESET_PASSWORD_NEEDED: 400,
|
|
99
|
+
ROLE_DISABLED: 403,
|
|
100
|
+
SESSION_NOT_FOUND: 404,
|
|
101
|
+
SESSION_DISABLED: 401,
|
|
102
|
+
INVALID_RESPONSE: 500,
|
|
103
|
+
UNKNOWN_CLIENT_ERROR: 400,
|
|
104
|
+
INVALID_CREDENTIALS: 400,
|
|
105
|
+
VALIDATION_ERROR: 400
|
|
106
|
+
};
|
|
107
|
+
var APIError = class _APIError extends Error {
|
|
108
|
+
static {
|
|
109
|
+
__name(this, "APIError");
|
|
110
|
+
}
|
|
111
|
+
code;
|
|
112
|
+
status;
|
|
113
|
+
details;
|
|
114
|
+
constructor(...args) {
|
|
115
|
+
const [code, message, details] = args;
|
|
116
|
+
super(message);
|
|
117
|
+
this.name = "APIError";
|
|
118
|
+
this.code = code;
|
|
119
|
+
this.status = API_ERROR_STATUS[code];
|
|
120
|
+
this.details = details;
|
|
121
|
+
Object.setPrototypeOf(this, _APIError.prototype);
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
// src/express/middleware/not-found.middleware.ts
|
|
126
|
+
async function notFoundMiddleware(request) {
|
|
127
|
+
throw new APIError("ROUTE_NOT_FOUND", `Route ${request.path} is not found!`);
|
|
128
|
+
}
|
|
129
|
+
__name(notFoundMiddleware, "notFoundMiddleware");
|
|
130
|
+
|
|
131
|
+
// src/express/middleware/error.middleware.ts
|
|
132
|
+
function isPlainObject(value) {
|
|
133
|
+
return typeof value === "object" && value !== null && Object.getPrototypeOf(value) === Object.prototype;
|
|
134
|
+
}
|
|
135
|
+
__name(isPlainObject, "isPlainObject");
|
|
136
|
+
var createErrorMiddleware = /* @__PURE__ */ __name((cookieTokenOptions) => (error, req, res, _) => {
|
|
137
|
+
try {
|
|
138
|
+
res.setHeader("Cache-Control", "no-store");
|
|
139
|
+
if (error instanceof APIError) {
|
|
140
|
+
if (error.code === "INTERNAL_SERVER_ERROR") {
|
|
141
|
+
console.error(error);
|
|
142
|
+
return res.status(error.status).json({
|
|
143
|
+
success: false,
|
|
144
|
+
error: error.code,
|
|
145
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
if (error.code === "TOKEN_NOT_FOUND") {
|
|
149
|
+
if (req.cookies.token) res.clearCookie("token", cookieTokenOptions);
|
|
150
|
+
}
|
|
151
|
+
if (isPlainObject(error.details) && "retryIn" in error.details && typeof error.details.retryIn === "number") res.setHeader("Retry-After", error.details.retryIn);
|
|
152
|
+
const responseBody = {
|
|
153
|
+
success: false,
|
|
154
|
+
error: error.code,
|
|
155
|
+
...error.message ? {
|
|
156
|
+
message: error.message
|
|
157
|
+
} : {},
|
|
158
|
+
...isPlainObject(error.details) ? error.details : {}
|
|
159
|
+
};
|
|
160
|
+
return res.status(error.status).json(responseBody);
|
|
161
|
+
}
|
|
162
|
+
if (error instanceof SyntaxError) {
|
|
163
|
+
return res.status(error.statusCode).json({
|
|
164
|
+
success: false,
|
|
165
|
+
error: "JSON_PARSE_ERROR",
|
|
166
|
+
message: error.message
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
if (error instanceof Error) {
|
|
170
|
+
console.error(error);
|
|
171
|
+
return res.status(500).json({
|
|
172
|
+
success: false,
|
|
173
|
+
error: "UNKNOWN_ERROR",
|
|
174
|
+
message: "An unknown error is happening. Please contact developer as soon as possible!"
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
console.error("errorHandlerMiddleware", error);
|
|
178
|
+
return res.status(500).json({
|
|
179
|
+
success: false,
|
|
180
|
+
error: "INTERNAL_SERVER_ERROR",
|
|
181
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
182
|
+
});
|
|
183
|
+
} catch (error2) {
|
|
184
|
+
console.error("errorHandlerMiddleware", error2);
|
|
185
|
+
return res.status(500).json({
|
|
186
|
+
success: false,
|
|
187
|
+
error: "INTERNAL_SERVER_ERROR",
|
|
188
|
+
message: "An internal error is happening. Please contact developer as soon as possible!"
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
}, "createErrorMiddleware");
|
|
192
|
+
var error_middleware_default = createErrorMiddleware;
|
|
193
|
+
|
|
194
|
+
// src/express/app.ts
|
|
195
|
+
import cookieParser from "cookie-parser";
|
|
196
|
+
var createExpressApp = /* @__PURE__ */ __name((options) => {
|
|
197
|
+
const app = express();
|
|
198
|
+
app.set("trust proxy", 1);
|
|
199
|
+
app.disable("x-powered-by");
|
|
200
|
+
app.use(helmet());
|
|
201
|
+
app.use(cors_middleware_default(options.allowedOrigins));
|
|
202
|
+
app.use(filterMiddleware);
|
|
203
|
+
app.use(express.json({
|
|
204
|
+
limit: "1mb"
|
|
205
|
+
}));
|
|
206
|
+
app.use(cookieParser(options.cookieSecret));
|
|
207
|
+
app.use(express.urlencoded({
|
|
208
|
+
extended: true,
|
|
209
|
+
limit: "1mb"
|
|
210
|
+
}));
|
|
211
|
+
app.use(express.static("public", {
|
|
212
|
+
dotfiles: "deny",
|
|
213
|
+
etag: true,
|
|
214
|
+
immutable: false,
|
|
215
|
+
index: false,
|
|
216
|
+
lastModified: true,
|
|
217
|
+
maxAge: "1h"
|
|
218
|
+
}));
|
|
219
|
+
app.get("/", (request, response) => {
|
|
220
|
+
return response.status(200).json({
|
|
221
|
+
success: true,
|
|
222
|
+
message: `Welcome to ${options.appName}`,
|
|
223
|
+
data: {
|
|
224
|
+
userAgent: request.userAgent,
|
|
225
|
+
ipAddress: request.ipAddress
|
|
226
|
+
}
|
|
227
|
+
});
|
|
228
|
+
});
|
|
229
|
+
if (options.routes) {
|
|
230
|
+
app.use(options.routes.public);
|
|
231
|
+
app.use(options.routes.private);
|
|
232
|
+
}
|
|
233
|
+
app.use(notFoundMiddleware);
|
|
234
|
+
app.use(error_middleware_default(options.cookieOptions));
|
|
235
|
+
return app;
|
|
236
|
+
}, "createExpressApp");
|
|
237
|
+
var app_default = createExpressApp;
|
|
238
|
+
|
|
239
|
+
// src/http.ts
|
|
240
|
+
import { createServer } from "http";
|
|
241
|
+
function createHttpServer(app, existingHttpServer, options = {}) {
|
|
242
|
+
return new Promise((resolve, reject) => {
|
|
243
|
+
const httpServer = createServer(app);
|
|
244
|
+
const PORT = options.port || 3e3;
|
|
245
|
+
const HOST = options.host || "localhost";
|
|
246
|
+
if (existingHttpServer) return resolve(existingHttpServer);
|
|
247
|
+
httpServer.listen(PORT, HOST, void 0, async () => {
|
|
248
|
+
const address = httpServer.address();
|
|
249
|
+
if (address && typeof address !== "string") {
|
|
250
|
+
console.log("HTTP Server", `Listening on http://${HOST} ${PORT} ${address.family}`);
|
|
251
|
+
} else {
|
|
252
|
+
console.log("HTTP Server", `Listening on ${address}`);
|
|
253
|
+
}
|
|
254
|
+
resolve(httpServer);
|
|
255
|
+
});
|
|
256
|
+
httpServer.on("close", () => {
|
|
257
|
+
console.log("HTTP Server", "Server closed");
|
|
258
|
+
process.exit(0);
|
|
259
|
+
});
|
|
260
|
+
httpServer.on("error", (err) => {
|
|
261
|
+
if (err.code === "EADDRINUSE") {
|
|
262
|
+
reject(new MahameruError(`Port ${PORT} is already in use`));
|
|
263
|
+
return;
|
|
264
|
+
} else {
|
|
265
|
+
console.error("System", err);
|
|
266
|
+
}
|
|
267
|
+
reject(err);
|
|
268
|
+
});
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
__name(createHttpServer, "createHttpServer");
|
|
272
|
+
|
|
273
|
+
// src/mahameru.ts
|
|
274
|
+
var Mahameru = class {
|
|
275
|
+
static {
|
|
276
|
+
__name(this, "Mahameru");
|
|
277
|
+
}
|
|
278
|
+
config;
|
|
279
|
+
rootDir = process.cwd();
|
|
280
|
+
databasesDir = path.join(this.rootDir, "src", "databases");
|
|
281
|
+
isCommonJS = typeof module !== "undefined" && !!module.exports;
|
|
282
|
+
isBuild = __dirname2.includes("dist");
|
|
283
|
+
shouldInitDB = true;
|
|
284
|
+
constructor(config) {
|
|
285
|
+
this.config = config;
|
|
286
|
+
if (!this.config) throw new MahameruError("Mahameru config is not provided");
|
|
287
|
+
if (!this.config.options) throw new MahameruError("Mahameru config.options is not provided");
|
|
288
|
+
if (!existsSync(this.rootDir)) throw new MahameruError("Root directory does not exist");
|
|
289
|
+
if (!existsSync(path.join(this.rootDir, "src"))) throw new MahameruError("src directory does not exist");
|
|
290
|
+
if (typeof this.config.options.dev === "undefined") this.config.options.dev = false;
|
|
291
|
+
if (!existsSync(this.databasesDir)) this.shouldInitDB = false;
|
|
292
|
+
}
|
|
293
|
+
async initialize() {
|
|
294
|
+
console.log("Preparing mahameru...");
|
|
295
|
+
if (this.config.options.dev) await this.preInitDevelopment(this.shouldInitDB);
|
|
296
|
+
console.log(`Starting mahameru on port ${this.config.options.port} in ${this.config.options.dev ? "development" : "production"} mode...`);
|
|
297
|
+
const app = app_default({
|
|
298
|
+
allowedOrigins: this.config.httpAllowedOrigins || [],
|
|
299
|
+
cookieSecret: this.config.cookieSecret || "secret",
|
|
300
|
+
cookieOptions: this.config.cookieOptions || {},
|
|
301
|
+
appName: this.config.options.appName || "Mahameru"
|
|
302
|
+
});
|
|
303
|
+
const httpServer = await createHttpServer(app, this.config.httpServer, {
|
|
304
|
+
port: this.config.options.port,
|
|
305
|
+
host: this.config.options.host
|
|
306
|
+
});
|
|
307
|
+
console.log("Mahameru is ready!");
|
|
308
|
+
const shutdown = /* @__PURE__ */ __name(async (signal) => {
|
|
309
|
+
if (signal) console.log("shutdown", `Received signal ${signal}`);
|
|
310
|
+
httpServer.close();
|
|
311
|
+
console.log("shutdown", `Shutdown complete.`);
|
|
312
|
+
}, "shutdown");
|
|
313
|
+
process.on("SIGINT", this.config.onSigint || shutdown);
|
|
314
|
+
process.on("SIGTERM", this.config.onSigterm || shutdown);
|
|
315
|
+
}
|
|
316
|
+
async preInitDevelopment(shouldInitDB = false) {
|
|
317
|
+
await this.createRequiredEnvFile();
|
|
318
|
+
const tsxPath = path.join(process.cwd(), "node_modules", "tsx", "dist", this.isCommonJS ? "cli.cjs" : "cli.mjs");
|
|
319
|
+
const preInitScriptPath = `node_modules${path.sep}mahameru${path.sep}${this.isBuild ? "dist" : "src"}${path.sep}lib${path.sep}pre-init-dev-script.${this.isCommonJS ? "cjs" : "js"}`;
|
|
320
|
+
const args = [
|
|
321
|
+
tsxPath,
|
|
322
|
+
"--tsconfig",
|
|
323
|
+
"tsconfig.json",
|
|
324
|
+
preInitScriptPath,
|
|
325
|
+
shouldInitDB ? "--init-db" : null
|
|
326
|
+
].filter(Boolean);
|
|
327
|
+
return await new Promise((resolve, reject) => {
|
|
328
|
+
const child = spawn("node", args, {
|
|
329
|
+
stdio: "inherit",
|
|
330
|
+
env: {
|
|
331
|
+
...process.env,
|
|
332
|
+
NODE_ENV: "development"
|
|
333
|
+
}
|
|
334
|
+
});
|
|
335
|
+
child.on("close", (code) => {
|
|
336
|
+
resolve(code);
|
|
337
|
+
});
|
|
338
|
+
child.on("error", (err) => {
|
|
339
|
+
reject(err);
|
|
340
|
+
});
|
|
341
|
+
});
|
|
342
|
+
}
|
|
343
|
+
async createRequiredEnvFile() {
|
|
344
|
+
const envDefaultPath = path.join(this.rootDir, ".env");
|
|
345
|
+
const envDevelopmentPath = path.join(this.rootDir, ".env.development");
|
|
346
|
+
if (!existsSync(envDefaultPath)) await writeFile(envDefaultPath, "APP_NAME=Mahameru Node.js Framework", "utf-8");
|
|
347
|
+
if (!existsSync(envDevelopmentPath)) {
|
|
348
|
+
const devEnv = ``;
|
|
349
|
+
await writeFile(envDevelopmentPath, devEnv, "utf-8");
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
isClass(v) {
|
|
353
|
+
return typeof v === "function" && /^\s*class\s+/.test(v.toString());
|
|
354
|
+
}
|
|
355
|
+
};
|
|
356
|
+
export {
|
|
357
|
+
Mahameru
|
|
358
|
+
};
|
|
359
|
+
//# sourceMappingURL=mahameru.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/error.ts","../src/mahameru.ts","../src/constants.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","../src/http.ts"],"sourcesContent":["export default class MahameruError extends Error {\r\n constructor(message: string) {\r\n super(message);\r\n this.name = \"MahameruError\";\r\n this.message = message;\r\n Error.captureStackTrace(this, this.constructor);\r\n }\r\n\r\n toString() {\r\n return `${this.name}: ${this.message}`;\r\n }\r\n\r\n toJSON() {\r\n return {\r\n name: this.name,\r\n message: this.message\r\n };\r\n }\r\n}\r\n","import MahameruError from \"./error.js\"\r\nimport { writeFile } from 'fs/promises'\r\nimport path from \"path\"\r\nimport type { Server } from \"http\"\r\nimport { existsSync } from \"fs\"\r\nimport { spawn } from \"child_process\"\r\nimport { __dirname } from \"./constants.js\"\r\nimport createExpressApp from \"./express/app.js\"\r\nimport type { CookieOptions } from \"express\"\r\nimport createHttpServer from \"./http.js\"\r\n\r\ntype MahameruOptions = {\r\n /**\r\n * App name\r\n * @default 'Mahameru'\r\n */\r\n appName?: string\r\n /**\r\n * Development mode\r\n */\r\n dev?: boolean\r\n /**\r\n * HTTP Listen port\r\n * @default 3000\r\n */\r\n port?: number\r\n /**\r\n * HTTP Listen host\r\n * @default localhost\r\n */\r\n host?: string\r\n}\r\n\r\nexport type MahameruConfig = {\r\n /**\r\n * Cookie secret\r\n * @default 'secret'\r\n */\r\n cookieSecret?: string\r\n /**\r\n * Cookie options\r\n * @default {}\r\n */\r\n cookieOptions?: CookieOptions\r\n /**\r\n * Mahameru options\r\n */\r\n options: MahameruOptions\r\n /**\r\n * HTTP Server\r\n * note: if set, will be used instead of creating a new one. options.port and options.host will be ignored.\r\n * @default undefined\r\n */\r\n httpServer?: Server\r\n /**\r\n * HTTP Allowed origins\r\n * @default undefined\r\n */\r\n httpAllowedOrigins?: string[]\r\n /**\r\n * Override default SIGINT handlers\r\n * @param signal \r\n * @returns void\r\n */\r\n onSigint?: (signal?: NodeJS.Signals) => void\r\n /**\r\n * Override default SIGTERM handlers\r\n * @param signal \r\n * @returns void\r\n */\r\n onSigterm?: (signal?: NodeJS.Signals) => void\r\n}\r\n\r\nexport class Mahameru {\r\n private readonly config: MahameruConfig\r\n private rootDir: string = process.cwd()\r\n private databasesDir = path.join(this.rootDir, 'src', 'databases')\r\n private readonly isCommonJS = typeof module !== 'undefined' && !!module.exports;\r\n private readonly isBuild = __dirname.includes('dist')\r\n protected shouldInitDB = true\r\n\r\n constructor(config: MahameruConfig) {\r\n this.config = config\r\n\r\n if (!this.config)\r\n throw new MahameruError('Mahameru config is not provided')\r\n\r\n if (!this.config.options)\r\n throw new MahameruError('Mahameru config.options is not provided')\r\n\r\n if (!existsSync(this.rootDir))\r\n throw new MahameruError('Root directory does not exist')\r\n\r\n if (!existsSync(path.join(this.rootDir, 'src')))\r\n throw new MahameruError('src directory does not exist')\r\n\r\n if (typeof this.config.options.dev === 'undefined')\r\n this.config.options.dev = false\r\n\r\n if (!existsSync(this.databasesDir))\r\n this.shouldInitDB = false\r\n }\r\n\r\n async initialize() {\r\n console.log('Preparing mahameru...')\r\n\r\n if (this.config.options.dev)\r\n await this.preInitDevelopment(this.shouldInitDB)\r\n\r\n console.log(`Starting mahameru on port ${this.config.options.port} in ${this.config.options.dev ? 'development' : 'production'} mode...`)\r\n\r\n const app = createExpressApp({\r\n allowedOrigins: this.config.httpAllowedOrigins || [],\r\n cookieSecret: this.config.cookieSecret || 'secret',\r\n cookieOptions: this.config.cookieOptions || {},\r\n appName: this.config.options.appName || 'Mahameru'\r\n })\r\n\r\n const httpServer = await createHttpServer(app, this.config.httpServer, {\r\n port: this.config.options.port,\r\n host: this.config.options.host\r\n })\r\n\r\n console.log('Mahameru is ready!')\r\n\r\n const shutdown = async (signal?: NodeJS.Signals) => {\r\n if (signal)\r\n console.log('shutdown', `Received signal ${signal}`)\r\n\r\n httpServer.close()\r\n\r\n console.log('shutdown', `Shutdown complete.`)\r\n }\r\n\r\n process.on('SIGINT', this.config.onSigint || shutdown)\r\n process.on('SIGTERM', this.config.onSigterm || shutdown)\r\n }\r\n\r\n protected async preInitDevelopment(shouldInitDB = false) {\r\n await this.createRequiredEnvFile()\r\n\r\n const tsxPath = path.join(process.cwd(), 'node_modules', 'tsx', 'dist', this.isCommonJS ? 'cli.cjs' : 'cli.mjs');\r\n const preInitScriptPath = `node_modules${path.sep}mahameru${path.sep}${this.isBuild ? 'dist' : 'src'}${path.sep}lib${path.sep}pre-init-dev-script.${this.isCommonJS ? 'cjs' : 'js'}`\r\n\r\n const args = [\r\n tsxPath,\r\n '--tsconfig', 'tsconfig.json',\r\n preInitScriptPath,\r\n shouldInitDB ? '--init-db' : null,\r\n ].filter(Boolean) as string[];\r\n\r\n return await new Promise<number | null>((resolve, reject) => {\r\n const child = spawn(\r\n 'node',\r\n args,\r\n {\r\n stdio: 'inherit',\r\n env: { ...process.env, NODE_ENV: 'development' }\r\n }\r\n );\r\n\r\n child.on('close', (code) => {\r\n resolve(code)\r\n });\r\n\r\n child.on('error', (err) => {\r\n reject(err)\r\n });\r\n })\r\n\r\n }\r\n\r\n protected async createRequiredEnvFile() {\r\n const envDefaultPath = path.join(this.rootDir, '.env')\r\n const envDevelopmentPath = path.join(this.rootDir, '.env.development')\r\n\r\n if (!existsSync(envDefaultPath))\r\n await writeFile(envDefaultPath, 'APP_NAME=Mahameru Node.js Framework', 'utf-8')\r\n\r\n if (!existsSync(envDevelopmentPath)) {\r\n const devEnv = ``\r\n\r\n await writeFile(envDevelopmentPath, devEnv, 'utf-8')\r\n }\r\n }\r\n\r\n protected isClass(v: unknown): boolean {\r\n return typeof v === 'function' && /^\\s*class\\s+/.test(v.toString());\r\n }\r\n}\r\n","import { dirname } from \"node:path\";\r\nimport { fileURLToPath } from \"node:url\";\r\n\r\nexport const root = process.cwd();\r\nexport const __filename = fileURLToPath(import.meta.url);\r\nexport const __dirname = dirname(__filename);\r\nexport const isCommonJS = typeof module !== 'undefined' && !!module.exports;\r\nexport const isESModule = !isCommonJS;\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","\r\nimport { createServer, Server } from 'node:http'\r\nimport { Express } from 'express'\r\nimport MahameruError from './error.js'\r\n\r\ntype CreateHttpServerOptions = {\r\n port?: number\r\n host?: string\r\n}\r\n\r\nexport default function createHttpServer(app: Express, existingHttpServer?: Server, options: CreateHttpServerOptions = {}) {\r\n return new Promise<Server>((resolve, reject) => {\r\n const httpServer = createServer(app)\r\n const PORT = options.port || 3000\r\n const HOST = options.host || 'localhost'\r\n\r\n if (existingHttpServer)\r\n return resolve(existingHttpServer)\r\n\r\n httpServer.listen(PORT, HOST, undefined, async () => {\r\n const address = httpServer.address()\r\n\r\n if (address && typeof address !== 'string') {\r\n console.log('HTTP Server', `Listening on http://${HOST} ${PORT} ${address.family}`)\r\n } else {\r\n console.log('HTTP Server', `Listening on ${address}`)\r\n }\r\n\r\n resolve(httpServer)\r\n })\r\n\r\n httpServer.on('close', () => {\r\n console.log('HTTP Server', 'Server closed')\r\n\r\n process.exit(0)\r\n })\r\n\r\n httpServer.on('error', (err: NodeJS.ErrnoException) => {\r\n if (err.code === 'EADDRINUSE') {\r\n reject(new MahameruError(`Port ${PORT} is already in use`))\r\n\r\n return\r\n } else {\r\n console.error('System', err)\r\n }\r\n\r\n reject(err)\r\n })\r\n })\r\n}\r\n"],"mappings":"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","names":["MahameruError","Error","message","name","captureStackTrace","toString","toJSON","writeFile","path","existsSync","spawn","dirname","fileURLToPath","root","process","cwd","__filename","url","__dirname","isCommonJS","module","exports","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","createServer","app","existingHttpServer","options","Promise","resolve","reject","httpServer","createServer","PORT","port","HOST","host","listen","undefined","address","console","log","family","on","process","exit","err","code","MahameruError","error","createHttpServer","Mahameru","config","rootDir","process","cwd","databasesDir","path","join","isCommonJS","module","exports","isBuild","__dirname","includes","shouldInitDB","MahameruError","options","existsSync","dev","initialize","console","log","preInitDevelopment","port","app","createExpressApp","allowedOrigins","httpAllowedOrigins","cookieSecret","cookieOptions","appName","httpServer","createHttpServer","host","shutdown","signal","close","on","onSigint","onSigterm","createRequiredEnvFile","tsxPath","preInitScriptPath","sep","args","filter","Boolean","Promise","resolve","reject","child","spawn","stdio","env","NODE_ENV","code","err","envDefaultPath","envDevelopmentPath","writeFile","devEnv","isClass","v","test","toString"]}
|
package/dist/request.cjs
ADDED
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/request.ts
|
|
21
|
+
var request_exports = {};
|
|
22
|
+
__export(request_exports, {
|
|
23
|
+
MahameruRequest: () => MahameruRequest
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(request_exports);
|
|
26
|
+
var MahameruRequest = class extends Request {
|
|
27
|
+
static {
|
|
28
|
+
__name(this, "MahameruRequest");
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
32
|
+
0 && (module.exports = {
|
|
33
|
+
MahameruRequest
|
|
34
|
+
});
|
|
35
|
+
//# sourceMappingURL=request.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/request.ts"],"sourcesContent":["import type { Request } from \"express\";\r\n\r\nexport class MahameruRequest extends Request {\r\n\r\n}\r\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAEA;;;;;AAAO,IAAMA,kBAAN,cAA8BC,QAAAA;EAArC,OAAqCA;;;AAErC;","names":["MahameruRequest","Request"]}
|
package/dist/request.js
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/request.ts
|
|
5
|
+
var MahameruRequest = class extends Request {
|
|
6
|
+
static {
|
|
7
|
+
__name(this, "MahameruRequest");
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
export {
|
|
11
|
+
MahameruRequest
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=request.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/request.ts"],"sourcesContent":["import type { Request } from \"express\";\r\n\r\nexport class MahameruRequest extends Request {\r\n\r\n}\r\n"],"mappings":";;;;AAEO,IAAMA,kBAAN,cAA8BC,QAAAA;EAArC,OAAqCA;;;AAErC;","names":["MahameruRequest","Request"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/response.ts
|
|
21
|
+
var response_exports = {};
|
|
22
|
+
__export(response_exports, {
|
|
23
|
+
MahameruResponse: () => MahameruResponse
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(response_exports);
|
|
26
|
+
var MahameruResponse = class extends Response {
|
|
27
|
+
static {
|
|
28
|
+
__name(this, "MahameruResponse");
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
32
|
+
0 && (module.exports = {
|
|
33
|
+
MahameruResponse
|
|
34
|
+
});
|
|
35
|
+
//# sourceMappingURL=response.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/response.ts"],"sourcesContent":["import type { Response } from \"express\";\r\n\r\nexport class MahameruResponse extends Response {\r\n\r\n}\r\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAEA;;;;;AAAO,IAAMA,mBAAN,cAA+BC,SAAAA;EAAtC,OAAsCA;;;AAEtC;","names":["MahameruResponse","Response"]}
|
package/dist/response.js
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/response.ts
|
|
5
|
+
var MahameruResponse = class extends Response {
|
|
6
|
+
static {
|
|
7
|
+
__name(this, "MahameruResponse");
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
export {
|
|
11
|
+
MahameruResponse
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=response.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/response.ts"],"sourcesContent":["import type { Response } from \"express\";\r\n\r\nexport class MahameruResponse extends Response {\r\n\r\n}\r\n"],"mappings":";;;;AAEO,IAAMA,mBAAN,cAA+BC,SAAAA;EAAtC,OAAsCA;;;AAEtC;","names":["MahameruResponse","Response"]}
|
package/dist/types.cjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=types.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/dist/types.d.cts
ADDED
package/dist/types.d.ts
ADDED
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/utils/import-dynamic-module.ts
|
|
21
|
+
var import_dynamic_module_exports = {};
|
|
22
|
+
__export(import_dynamic_module_exports, {
|
|
23
|
+
importDynamicModule: () => importDynamicModule
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(import_dynamic_module_exports);
|
|
26
|
+
async function importDynamicModule(modulePath) {
|
|
27
|
+
return await import(modulePath);
|
|
28
|
+
}
|
|
29
|
+
__name(importDynamicModule, "importDynamicModule");
|
|
30
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
31
|
+
0 && (module.exports = {
|
|
32
|
+
importDynamicModule
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=import-dynamic-module.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/utils/import-dynamic-module.ts"],"sourcesContent":["export async function importDynamicModule(modulePath: string) {\r\n return await import(modulePath)\r\n}\r\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;;;;;AAAA,eAAsBA,oBAAoBC,YAAkB;AACxD,SAAO,MAAM,OAAOA;AACxB;AAFsBD;","names":["importDynamicModule","modulePath"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/utils/import-dynamic-module.ts
|
|
5
|
+
async function importDynamicModule(modulePath) {
|
|
6
|
+
return await import(modulePath);
|
|
7
|
+
}
|
|
8
|
+
__name(importDynamicModule, "importDynamicModule");
|
|
9
|
+
export {
|
|
10
|
+
importDynamicModule
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=import-dynamic-module.js.map
|