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,3 @@
1
+ declare function onInit(): Promise<void>;
2
+
3
+ export { onInit as default };
@@ -0,0 +1,68 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/cli/scripts/on-init.ts
5
+ import inquirer from "inquirer";
6
+ import { existsSync } from "fs";
7
+ import path from "path";
8
+ import degit from "degit";
9
+ import ora from "ora";
10
+ import pc from "picocolors";
11
+ import { execSync } from "child_process";
12
+ async function onInit() {
13
+ const repo = "bintvn/typeorm-dto-generator";
14
+ const answers = await inquirer.prompt([
15
+ {
16
+ type: "input",
17
+ name: "projectName",
18
+ message: "Enter your project name:",
19
+ default: "my-awesome-project",
20
+ validate: /* @__PURE__ */ __name((input) => {
21
+ if (/^([A-Za-z\-_\d])+$/.test(input)) return true;
22
+ return "Project name may only contain letters, numbers, underscores, or dashes.";
23
+ }, "validate")
24
+ }
25
+ ]);
26
+ const targetDir = path.join(process.cwd(), answers.projectName);
27
+ if (existsSync(targetDir)) {
28
+ console.log(pc.red(`
29
+ Error: Folder ${answers.projectName} already exists!`));
30
+ process.exit(1);
31
+ }
32
+ const emitter = degit(repo, {
33
+ cache: false,
34
+ force: true
35
+ });
36
+ const downloadSpinner = ora("Downloading template from GitHub...").start();
37
+ try {
38
+ await emitter.clone(targetDir);
39
+ downloadSpinner.succeed(pc.green("Template downloaded successfully!"));
40
+ } catch (err) {
41
+ downloadSpinner.fail(pc.red("Failed to download template."));
42
+ console.error(err);
43
+ process.exit(1);
44
+ }
45
+ const installSpinner = ora("Installing dependencies (npm install)...").start();
46
+ try {
47
+ execSync("npm install", {
48
+ cwd: targetDir,
49
+ stdio: "ignore"
50
+ });
51
+ installSpinner.succeed(pc.green("Dependencies installed successfully!"));
52
+ } catch (err) {
53
+ installSpinner.fail(pc.red("Failed to install dependencies."));
54
+ console.log(pc.yellow('\nPlease enter the folder and run "npm install" manually.'));
55
+ }
56
+ console.log("\n---");
57
+ console.log(pc.cyan(`Project ${pc.bold(answers.projectName)} was created successfully!`));
58
+ console.log(`
59
+ To get started, run the following commands:`);
60
+ console.log(pc.yellow(` cd ${answers.projectName}`));
61
+ console.log(pc.yellow(` npm run dev (or your preferred start command)`));
62
+ console.log("---\n");
63
+ }
64
+ __name(onInit, "onInit");
65
+ export {
66
+ onInit as default
67
+ };
68
+ //# sourceMappingURL=on-init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/cli/scripts/on-init.ts"],"sourcesContent":["import inquirer from \"inquirer\";\r\nimport { existsSync } from \"node:fs\";\r\nimport path from \"node:path\";\r\nimport degit from 'degit';\r\nimport ora from 'ora';\r\nimport pc from 'picocolors';\r\nimport { execSync } from \"node:child_process\";\r\n\r\nexport default async function onInit() {\r\n const repo = 'bintvn/typeorm-dto-generator';\r\n const answers = await inquirer.prompt([\r\n {\r\n type: 'input',\r\n name: 'projectName',\r\n message: 'Enter your project name:',\r\n default: 'my-awesome-project',\r\n validate: (input) => {\r\n if (/^([A-Za-z\\-_\\d])+$/.test(input)) return true;\r\n return 'Project name may only contain letters, numbers, underscores, or dashes.';\r\n }\r\n }\r\n ]);\r\n\r\n const targetDir = path.join(process.cwd(), answers.projectName);\r\n\r\n if (existsSync(targetDir)) {\r\n console.log(pc.red(`\\nError: Folder ${answers.projectName} already exists!`));\r\n process.exit(1);\r\n }\r\n\r\n const emitter = degit(repo, {\r\n cache: false,\r\n force: true,\r\n });\r\n\r\n const downloadSpinner = ora('Downloading template from GitHub...').start();\r\n\r\n try {\r\n await emitter.clone(targetDir);\r\n downloadSpinner.succeed(pc.green('Template downloaded successfully!'));\r\n } catch (err) {\r\n downloadSpinner.fail(pc.red('Failed to download template.'));\r\n console.error(err);\r\n process.exit(1);\r\n }\r\n\r\n const installSpinner = ora('Installing dependencies (npm install)...').start();\r\n\r\n try {\r\n execSync('npm install', { cwd: targetDir, stdio: 'ignore' });\r\n installSpinner.succeed(pc.green('Dependencies installed successfully!'));\r\n } catch (err) {\r\n installSpinner.fail(pc.red('Failed to install dependencies.'));\r\n console.log(pc.yellow('\\nPlease enter the folder and run \"npm install\" manually.'));\r\n }\r\n\r\n console.log('\\n---');\r\n console.log(pc.cyan(`Project ${pc.bold(answers.projectName)} was created successfully!`));\r\n console.log(`\\nTo get started, run the following commands:`);\r\n console.log(pc.yellow(` cd ${answers.projectName}`));\r\n console.log(pc.yellow(` npm run dev (or your preferred start command)`));\r\n console.log('---\\n');\r\n}"],"mappings":";;;;AAAA,OAAOA,cAAc;AACrB,SAASC,kBAAkB;AAC3B,OAAOC,UAAU;AACjB,OAAOC,WAAW;AAClB,OAAOC,SAAS;AAChB,OAAOC,QAAQ;AACf,SAASC,gBAAgB;AAEzB,eAAA,SAA8BC;AAC1B,QAAMC,OAAO;AACb,QAAMC,UAAU,MAAMC,SAASC,OAAO;IAClC;MACIC,MAAM;MACNC,MAAM;MACNC,SAAS;MACTC,SAAS;MACTC,UAAU,wBAACC,UAAAA;AACP,YAAI,qBAAqBC,KAAKD,KAAAA,EAAQ,QAAO;AAC7C,eAAO;MACX,GAHU;IAId;GACH;AAED,QAAME,YAAYC,KAAKC,KAAKC,QAAQC,IAAG,GAAId,QAAQe,WAAW;AAE9D,MAAIC,WAAWN,SAAAA,GAAY;AACvBO,YAAQC,IAAIC,GAAGC,IAAI;gBAAmBpB,QAAQe,WAAW,kBAAkB,CAAA;AAC3EF,YAAQQ,KAAK,CAAA;EACjB;AAEA,QAAMC,UAAUC,MAAMxB,MAAM;IACxByB,OAAO;IACPC,OAAO;EACX,CAAA;AAEA,QAAMC,kBAAkBC,IAAI,qCAAA,EAAuCC,MAAK;AAExE,MAAI;AACA,UAAMN,QAAQO,MAAMnB,SAAAA;AACpBgB,oBAAgBI,QAAQX,GAAGY,MAAM,mCAAA,CAAA;EACrC,SAASC,KAAK;AACVN,oBAAgBO,KAAKd,GAAGC,IAAI,8BAAA,CAAA;AAC5BH,YAAQiB,MAAMF,GAAAA;AACdnB,YAAQQ,KAAK,CAAA;EACjB;AAEA,QAAMc,iBAAiBR,IAAI,0CAAA,EAA4CC,MAAK;AAE5E,MAAI;AACAQ,aAAS,eAAe;MAAEtB,KAAKJ;MAAW2B,OAAO;IAAS,CAAA;AAC1DF,mBAAeL,QAAQX,GAAGY,MAAM,sCAAA,CAAA;EACpC,SAASC,KAAK;AACVG,mBAAeF,KAAKd,GAAGC,IAAI,iCAAA,CAAA;AAC3BH,YAAQC,IAAIC,GAAGmB,OAAO,2DAAA,CAAA;EAC1B;AAEArB,UAAQC,IAAI,OAAA;AACZD,UAAQC,IAAIC,GAAGoB,KAAK,WAAWpB,GAAGqB,KAAKxC,QAAQe,WAAW,CAAA,4BAA6B,CAAA;AACvFE,UAAQC,IAAI;4CAA+C;AAC3DD,UAAQC,IAAIC,GAAGmB,OAAO,SAAStC,QAAQe,WAAW,EAAE,CAAA;AACpDE,UAAQC,IAAIC,GAAGmB,OAAO,kDAAkD,CAAA;AACxErB,UAAQC,IAAI,OAAA;AAChB;AAtD8BpB;","names":["inquirer","existsSync","path","degit","ora","pc","execSync","onInit","repo","answers","inquirer","prompt","type","name","message","default","validate","input","test","targetDir","path","join","process","cwd","projectName","existsSync","console","log","pc","red","exit","emitter","degit","cache","force","downloadSpinner","ora","start","clone","succeed","green","err","fail","error","installSpinner","execSync","stdio","yellow","cyan","bold"]}
@@ -0,0 +1,55 @@
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/cli/scripts/on-start.ts
31
+ var on_start_exports = {};
32
+ __export(on_start_exports, {
33
+ default: () => onStart
34
+ });
35
+ module.exports = __toCommonJS(on_start_exports);
36
+ var import_node_child_process = require("child_process");
37
+ var import_node_path = __toESM(require("path"), 1);
38
+ async function onStart() {
39
+ console.log("\x1B[36m%s\x1B[0m", "\u25B2 Mahameru - Starting production server...");
40
+ const distPath = import_node_path.default.join(process.cwd(), ".mahameru", "index.js");
41
+ const child = (0, import_node_child_process.spawn)("node", [
42
+ distPath
43
+ ], {
44
+ stdio: "inherit",
45
+ env: {
46
+ ...process.env,
47
+ NODE_ENV: "production"
48
+ }
49
+ });
50
+ child.on("close", (code) => {
51
+ process.exit(code ?? 0);
52
+ });
53
+ }
54
+ __name(onStart, "onStart");
55
+ //# sourceMappingURL=on-start.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/cli/scripts/on-start.ts"],"sourcesContent":["import { spawn } from \"node:child_process\";\r\nimport path from \"node:path\";\r\n\r\nexport default async function onStart() {\r\n console.log('\\x1b[36m%s\\x1b[0m', '▲ Mahameru - Starting production server...');\r\n\r\n const distPath = path.join(process.cwd(), '.mahameru', 'index.js');\r\n\r\n const child = spawn('node', [distPath], {\r\n stdio: 'inherit',\r\n env: { ...process.env, NODE_ENV: 'production' }\r\n });\r\n\r\n child.on('close', (code) => {\r\n process.exit(code ?? 0);\r\n });\r\n}\r\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;AAAA,gCAAsB;AACtB,uBAAiB;AAEjB,eAAA,UAA8BA;AAC1BC,UAAQC,IAAI,qBAAqB,iDAAA;AAEjC,QAAMC,WAAWC,iBAAAA,QAAKC,KAAKC,QAAQC,IAAG,GAAI,aAAa,UAAA;AAEvD,QAAMC,YAAQC,iCAAM,QAAQ;IAACN;KAAW;IACpCO,OAAO;IACPC,KAAK;MAAE,GAAGL,QAAQK;MAAKC,UAAU;IAAa;EAClD,CAAA;AAEAJ,QAAMK,GAAG,SAAS,CAACC,SAAAA;AACfR,YAAQS,KAAKD,QAAQ,CAAA;EACzB,CAAA;AACJ;AAb8Bd;","names":["onStart","console","log","distPath","path","join","process","cwd","child","spawn","stdio","env","NODE_ENV","on","code","exit"]}
@@ -0,0 +1,3 @@
1
+ declare function onStart(): Promise<void>;
2
+
3
+ export { onStart as default };
@@ -0,0 +1,3 @@
1
+ declare function onStart(): Promise<void>;
2
+
3
+ export { onStart as default };
@@ -0,0 +1,27 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/cli/scripts/on-start.ts
5
+ import { spawn } from "child_process";
6
+ import path from "path";
7
+ async function onStart() {
8
+ console.log("\x1B[36m%s\x1B[0m", "\u25B2 Mahameru - Starting production server...");
9
+ const distPath = path.join(process.cwd(), ".mahameru", "index.js");
10
+ const child = spawn("node", [
11
+ distPath
12
+ ], {
13
+ stdio: "inherit",
14
+ env: {
15
+ ...process.env,
16
+ NODE_ENV: "production"
17
+ }
18
+ });
19
+ child.on("close", (code) => {
20
+ process.exit(code ?? 0);
21
+ });
22
+ }
23
+ __name(onStart, "onStart");
24
+ export {
25
+ onStart as default
26
+ };
27
+ //# sourceMappingURL=on-start.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/cli/scripts/on-start.ts"],"sourcesContent":["import { spawn } from \"node:child_process\";\r\nimport path from \"node:path\";\r\n\r\nexport default async function onStart() {\r\n console.log('\\x1b[36m%s\\x1b[0m', '▲ Mahameru - Starting production server...');\r\n\r\n const distPath = path.join(process.cwd(), '.mahameru', 'index.js');\r\n\r\n const child = spawn('node', [distPath], {\r\n stdio: 'inherit',\r\n env: { ...process.env, NODE_ENV: 'production' }\r\n });\r\n\r\n child.on('close', (code) => {\r\n process.exit(code ?? 0);\r\n });\r\n}\r\n"],"mappings":";;;;AAAA,SAASA,aAAa;AACtB,OAAOC,UAAU;AAEjB,eAAA,UAA8BC;AAC1BC,UAAQC,IAAI,qBAAqB,iDAAA;AAEjC,QAAMC,WAAWC,KAAKC,KAAKC,QAAQC,IAAG,GAAI,aAAa,UAAA;AAEvD,QAAMC,QAAQC,MAAM,QAAQ;IAACN;KAAW;IACpCO,OAAO;IACPC,KAAK;MAAE,GAAGL,QAAQK;MAAKC,UAAU;IAAa;EAClD,CAAA;AAEAJ,QAAMK,GAAG,SAAS,CAACC,SAAAA;AACfR,YAAQS,KAAKD,QAAQ,CAAA;EACzB,CAAA;AACJ;AAb8Bd;","names":["spawn","path","onStart","console","log","distPath","path","join","process","cwd","child","spawn","stdio","env","NODE_ENV","on","code","exit"]}
@@ -0,0 +1,405 @@
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/client.ts
31
+ var client_exports = {};
32
+ __export(client_exports, {
33
+ default: () => client_default
34
+ });
35
+ module.exports = __toCommonJS(client_exports);
36
+
37
+ // node_modules/tsup/assets/cjs_shims.js
38
+ var getImportMetaUrl = /* @__PURE__ */ __name(() => typeof document === "undefined" ? new URL(`file:${__filename}`).href : document.currentScript && document.currentScript.tagName.toUpperCase() === "SCRIPT" ? document.currentScript.src : new URL("main.js", document.baseURI).href, "getImportMetaUrl");
39
+ var importMetaUrl = /* @__PURE__ */ getImportMetaUrl();
40
+
41
+ // src/error.ts
42
+ var MahameruError = class extends Error {
43
+ static {
44
+ __name(this, "MahameruError");
45
+ }
46
+ constructor(message) {
47
+ super(message);
48
+ this.name = "MahameruError";
49
+ this.message = message;
50
+ Error.captureStackTrace(this, this.constructor);
51
+ }
52
+ toString() {
53
+ return `${this.name}: ${this.message}`;
54
+ }
55
+ toJSON() {
56
+ return {
57
+ name: this.name,
58
+ message: this.message
59
+ };
60
+ }
61
+ };
62
+
63
+ // src/mahameru.ts
64
+ var import_promises = require("fs/promises");
65
+ var import_path = __toESM(require("path"), 1);
66
+ var import_fs = require("fs");
67
+ var import_child_process = require("child_process");
68
+
69
+ // src/constants.ts
70
+ var import_node_path = require("path");
71
+ var import_node_url = require("url");
72
+ var root = process.cwd();
73
+ var __filename2 = (0, import_node_url.fileURLToPath)(importMetaUrl);
74
+ var __dirname = (0, import_node_path.dirname)(__filename2);
75
+ var isCommonJS = typeof module !== "undefined" && !!module.exports;
76
+
77
+ // src/express/app.ts
78
+ var import_express = __toESM(require("express"), 1);
79
+ var import_helmet = __toESM(require("helmet"), 1);
80
+
81
+ // src/express/middleware/cors.middleware.ts
82
+ var import_cors = __toESM(require("cors"), 1);
83
+ var createCorsMiddleware = /* @__PURE__ */ __name((allowedOrigins) => {
84
+ return (0, import_cors.default)((req, callback) => {
85
+ let origin = req.headers["origin"];
86
+ if (!origin || allowedOrigins.indexOf(origin) !== -1) {
87
+ callback(null, {
88
+ origin: true,
89
+ methods: "GET,HEAD,PUT,PATCH,POST,DELETE",
90
+ credentials: true
91
+ });
92
+ } else {
93
+ callback(null, {
94
+ origin: false
95
+ });
96
+ }
97
+ });
98
+ }, "createCorsMiddleware");
99
+ var cors_middleware_default = createCorsMiddleware;
100
+
101
+ // src/express/middleware/filter.middleware.ts
102
+ async function filterMiddleware(request, response, next) {
103
+ if (!request.ip || !request.headers["user-agent"]) throw new Error("Access denied");
104
+ request.ipAddress = request.ip;
105
+ request.userAgent = request.headers["user-agent"];
106
+ if (request.path.length > 1 && request.path.endsWith("/")) {
107
+ const newPath = request.path.slice(0, -1);
108
+ const query = request.url.slice(request.path.length);
109
+ return response.redirect(301, newPath + query);
110
+ }
111
+ return next();
112
+ }
113
+ __name(filterMiddleware, "filterMiddleware");
114
+
115
+ // src/api.error.ts
116
+ var API_ERROR_STATUS = {
117
+ BAD_REQUEST: 400,
118
+ UNAUTHORIZED: 401,
119
+ FORBIDDEN: 403,
120
+ NOT_FOUND: 404,
121
+ ROUTE_NOT_FOUND: 404,
122
+ TOO_MANY_REQUESTS: 429,
123
+ CONFLICT: 409,
124
+ INTERNAL_SERVER_ERROR: 500,
125
+ TOKEN_EXPIRED: 401,
126
+ REFRESH_TOKEN_EXPIRED: 401,
127
+ ACCESS_TOKEN_EXPIRED: 401,
128
+ ACCESS_TOKEN_REQUIRED: 401,
129
+ TOKEN_REFRESH_TOO_EARLY: 403,
130
+ EMAIL_NOT_VERIFIED: 401,
131
+ PHONE_NOT_VERIFIED: 401,
132
+ TOKEN_NOT_FOUND: 404,
133
+ INVALID_TOKEN: 401,
134
+ RESET_PASSWORD_TOKEN_USED: 401,
135
+ RESET_PASSWORD_NEEDED: 400,
136
+ ROLE_DISABLED: 403,
137
+ SESSION_NOT_FOUND: 404,
138
+ SESSION_DISABLED: 401,
139
+ INVALID_RESPONSE: 500,
140
+ UNKNOWN_CLIENT_ERROR: 400,
141
+ INVALID_CREDENTIALS: 400,
142
+ VALIDATION_ERROR: 400
143
+ };
144
+ var APIError = class _APIError extends Error {
145
+ static {
146
+ __name(this, "APIError");
147
+ }
148
+ code;
149
+ status;
150
+ details;
151
+ constructor(...args) {
152
+ const [code, message, details] = args;
153
+ super(message);
154
+ this.name = "APIError";
155
+ this.code = code;
156
+ this.status = API_ERROR_STATUS[code];
157
+ this.details = details;
158
+ Object.setPrototypeOf(this, _APIError.prototype);
159
+ }
160
+ };
161
+
162
+ // src/express/middleware/not-found.middleware.ts
163
+ async function notFoundMiddleware(request) {
164
+ throw new APIError("ROUTE_NOT_FOUND", `Route ${request.path} is not found!`);
165
+ }
166
+ __name(notFoundMiddleware, "notFoundMiddleware");
167
+
168
+ // src/express/middleware/error.middleware.ts
169
+ function isPlainObject(value) {
170
+ return typeof value === "object" && value !== null && Object.getPrototypeOf(value) === Object.prototype;
171
+ }
172
+ __name(isPlainObject, "isPlainObject");
173
+ var createErrorMiddleware = /* @__PURE__ */ __name((cookieTokenOptions) => (error, req, res, _) => {
174
+ try {
175
+ res.setHeader("Cache-Control", "no-store");
176
+ if (error instanceof APIError) {
177
+ if (error.code === "INTERNAL_SERVER_ERROR") {
178
+ console.error(error);
179
+ return res.status(error.status).json({
180
+ success: false,
181
+ error: error.code,
182
+ message: "An internal error is happening. Please contact developer as soon as possible!"
183
+ });
184
+ }
185
+ if (error.code === "TOKEN_NOT_FOUND") {
186
+ if (req.cookies.token) res.clearCookie("token", cookieTokenOptions);
187
+ }
188
+ if (isPlainObject(error.details) && "retryIn" in error.details && typeof error.details.retryIn === "number") res.setHeader("Retry-After", error.details.retryIn);
189
+ const responseBody = {
190
+ success: false,
191
+ error: error.code,
192
+ ...error.message ? {
193
+ message: error.message
194
+ } : {},
195
+ ...isPlainObject(error.details) ? error.details : {}
196
+ };
197
+ return res.status(error.status).json(responseBody);
198
+ }
199
+ if (error instanceof SyntaxError) {
200
+ return res.status(error.statusCode).json({
201
+ success: false,
202
+ error: "JSON_PARSE_ERROR",
203
+ message: error.message
204
+ });
205
+ }
206
+ if (error instanceof Error) {
207
+ console.error(error);
208
+ return res.status(500).json({
209
+ success: false,
210
+ error: "UNKNOWN_ERROR",
211
+ message: "An unknown error is happening. Please contact developer as soon as possible!"
212
+ });
213
+ }
214
+ console.error("errorHandlerMiddleware", error);
215
+ return res.status(500).json({
216
+ success: false,
217
+ error: "INTERNAL_SERVER_ERROR",
218
+ message: "An internal error is happening. Please contact developer as soon as possible!"
219
+ });
220
+ } catch (error2) {
221
+ console.error("errorHandlerMiddleware", error2);
222
+ return res.status(500).json({
223
+ success: false,
224
+ error: "INTERNAL_SERVER_ERROR",
225
+ message: "An internal error is happening. Please contact developer as soon as possible!"
226
+ });
227
+ }
228
+ }, "createErrorMiddleware");
229
+ var error_middleware_default = createErrorMiddleware;
230
+
231
+ // src/express/app.ts
232
+ var import_cookie_parser = __toESM(require("cookie-parser"), 1);
233
+ var createExpressApp = /* @__PURE__ */ __name((options) => {
234
+ const app = (0, import_express.default)();
235
+ app.set("trust proxy", 1);
236
+ app.disable("x-powered-by");
237
+ app.use((0, import_helmet.default)());
238
+ app.use(cors_middleware_default(options.allowedOrigins));
239
+ app.use(filterMiddleware);
240
+ app.use(import_express.default.json({
241
+ limit: "1mb"
242
+ }));
243
+ app.use((0, import_cookie_parser.default)(options.cookieSecret));
244
+ app.use(import_express.default.urlencoded({
245
+ extended: true,
246
+ limit: "1mb"
247
+ }));
248
+ app.use(import_express.default.static("public", {
249
+ dotfiles: "deny",
250
+ etag: true,
251
+ immutable: false,
252
+ index: false,
253
+ lastModified: true,
254
+ maxAge: "1h"
255
+ }));
256
+ app.get("/", (request, response) => {
257
+ return response.status(200).json({
258
+ success: true,
259
+ message: `Welcome to ${options.appName}`,
260
+ data: {
261
+ userAgent: request.userAgent,
262
+ ipAddress: request.ipAddress
263
+ }
264
+ });
265
+ });
266
+ if (options.routes) {
267
+ app.use(options.routes.public);
268
+ app.use(options.routes.private);
269
+ }
270
+ app.use(notFoundMiddleware);
271
+ app.use(error_middleware_default(options.cookieOptions));
272
+ return app;
273
+ }, "createExpressApp");
274
+ var app_default = createExpressApp;
275
+
276
+ // src/http.ts
277
+ var import_node_http = require("http");
278
+ function createHttpServer(app, existingHttpServer, options = {}) {
279
+ return new Promise((resolve, reject) => {
280
+ const httpServer = (0, import_node_http.createServer)(app);
281
+ const PORT = options.port || 3e3;
282
+ const HOST = options.host || "localhost";
283
+ if (existingHttpServer) return resolve(existingHttpServer);
284
+ httpServer.listen(PORT, HOST, void 0, async () => {
285
+ const address = httpServer.address();
286
+ if (address && typeof address !== "string") {
287
+ console.log("HTTP Server", `Listening on http://${HOST} ${PORT} ${address.family}`);
288
+ } else {
289
+ console.log("HTTP Server", `Listening on ${address}`);
290
+ }
291
+ resolve(httpServer);
292
+ });
293
+ httpServer.on("close", () => {
294
+ console.log("HTTP Server", "Server closed");
295
+ process.exit(0);
296
+ });
297
+ httpServer.on("error", (err) => {
298
+ if (err.code === "EADDRINUSE") {
299
+ reject(new MahameruError(`Port ${PORT} is already in use`));
300
+ return;
301
+ } else {
302
+ console.error("System", err);
303
+ }
304
+ reject(err);
305
+ });
306
+ });
307
+ }
308
+ __name(createHttpServer, "createHttpServer");
309
+
310
+ // src/mahameru.ts
311
+ var Mahameru = class {
312
+ static {
313
+ __name(this, "Mahameru");
314
+ }
315
+ config;
316
+ rootDir = process.cwd();
317
+ databasesDir = import_path.default.join(this.rootDir, "src", "databases");
318
+ isCommonJS = typeof module !== "undefined" && !!module.exports;
319
+ isBuild = __dirname.includes("dist");
320
+ shouldInitDB = true;
321
+ constructor(config) {
322
+ this.config = config;
323
+ if (!this.config) throw new MahameruError("Mahameru config is not provided");
324
+ if (!this.config.options) throw new MahameruError("Mahameru config.options is not provided");
325
+ if (!(0, import_fs.existsSync)(this.rootDir)) throw new MahameruError("Root directory does not exist");
326
+ if (!(0, import_fs.existsSync)(import_path.default.join(this.rootDir, "src"))) throw new MahameruError("src directory does not exist");
327
+ if (typeof this.config.options.dev === "undefined") this.config.options.dev = false;
328
+ if (!(0, import_fs.existsSync)(this.databasesDir)) this.shouldInitDB = false;
329
+ }
330
+ async initialize() {
331
+ console.log("Preparing mahameru...");
332
+ if (this.config.options.dev) await this.preInitDevelopment(this.shouldInitDB);
333
+ console.log(`Starting mahameru on port ${this.config.options.port} in ${this.config.options.dev ? "development" : "production"} mode...`);
334
+ const app = app_default({
335
+ allowedOrigins: this.config.httpAllowedOrigins || [],
336
+ cookieSecret: this.config.cookieSecret || "secret",
337
+ cookieOptions: this.config.cookieOptions || {},
338
+ appName: this.config.options.appName || "Mahameru"
339
+ });
340
+ const httpServer = await createHttpServer(app, this.config.httpServer, {
341
+ port: this.config.options.port,
342
+ host: this.config.options.host
343
+ });
344
+ console.log("Mahameru is ready!");
345
+ const shutdown = /* @__PURE__ */ __name(async (signal) => {
346
+ if (signal) console.log("shutdown", `Received signal ${signal}`);
347
+ httpServer.close();
348
+ console.log("shutdown", `Shutdown complete.`);
349
+ }, "shutdown");
350
+ process.on("SIGINT", this.config.onSigint || shutdown);
351
+ process.on("SIGTERM", this.config.onSigterm || shutdown);
352
+ }
353
+ async preInitDevelopment(shouldInitDB = false) {
354
+ await this.createRequiredEnvFile();
355
+ const tsxPath = import_path.default.join(process.cwd(), "node_modules", "tsx", "dist", this.isCommonJS ? "cli.cjs" : "cli.mjs");
356
+ const preInitScriptPath = `node_modules${import_path.default.sep}mahameru${import_path.default.sep}${this.isBuild ? "dist" : "src"}${import_path.default.sep}lib${import_path.default.sep}pre-init-dev-script.${this.isCommonJS ? "cjs" : "js"}`;
357
+ const args = [
358
+ tsxPath,
359
+ "--tsconfig",
360
+ "tsconfig.json",
361
+ preInitScriptPath,
362
+ shouldInitDB ? "--init-db" : null
363
+ ].filter(Boolean);
364
+ return await new Promise((resolve, reject) => {
365
+ const child = (0, import_child_process.spawn)("node", args, {
366
+ stdio: "inherit",
367
+ env: {
368
+ ...process.env,
369
+ NODE_ENV: "development"
370
+ }
371
+ });
372
+ child.on("close", (code) => {
373
+ resolve(code);
374
+ });
375
+ child.on("error", (err) => {
376
+ reject(err);
377
+ });
378
+ });
379
+ }
380
+ async createRequiredEnvFile() {
381
+ const envDefaultPath = import_path.default.join(this.rootDir, ".env");
382
+ const envDevelopmentPath = import_path.default.join(this.rootDir, ".env.development");
383
+ if (!(0, import_fs.existsSync)(envDefaultPath)) await (0, import_promises.writeFile)(envDefaultPath, "APP_NAME=Mahameru Node.js Framework", "utf-8");
384
+ if (!(0, import_fs.existsSync)(envDevelopmentPath)) {
385
+ const devEnv = ``;
386
+ await (0, import_promises.writeFile)(envDevelopmentPath, devEnv, "utf-8");
387
+ }
388
+ }
389
+ isClass(v) {
390
+ return typeof v === "function" && /^\s*class\s+/.test(v.toString());
391
+ }
392
+ };
393
+
394
+ // src/client.ts
395
+ var mahameru = /* @__PURE__ */ __name((config) => {
396
+ try {
397
+ const mahameru2 = new Mahameru(config);
398
+ return mahameru2;
399
+ } catch (err) {
400
+ console.error(err);
401
+ process.exit(1);
402
+ }
403
+ }, "mahameru");
404
+ var client_default = mahameru;
405
+ //# sourceMappingURL=client.cjs.map