mahameru 0.0.0 → 0.0.2
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/dist/cli/index.cjs +11 -9
- package/dist/cli/index.cjs.map +1 -1
- package/dist/cli/index.js +11 -9
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/scripts/on-dev.cjs +1 -1
- package/dist/cli/scripts/on-dev.cjs.map +1 -1
- package/dist/cli/scripts/on-dev.js +1 -1
- package/dist/cli/scripts/on-dev.js.map +1 -1
- package/dist/cli/scripts/on-init.cjs +1 -1
- package/dist/cli/scripts/on-init.cjs.map +1 -1
- package/dist/cli/scripts/on-init.js +1 -1
- package/dist/cli/scripts/on-init.js.map +1 -1
- package/dist/client.cjs +1 -1
- package/dist/client.cjs.map +1 -1
- package/dist/client.js +1 -1
- package/dist/client.js.map +1 -1
- package/dist/http.cjs +1 -1
- package/dist/http.cjs.map +1 -1
- package/dist/http.js +1 -1
- package/dist/http.js.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/mahameru.cjs +1 -1
- package/dist/mahameru.cjs.map +1 -1
- package/dist/mahameru.js +1 -1
- package/dist/mahameru.js.map +1 -1
- package/package.json +10 -6
package/dist/cli/index.cjs
CHANGED
|
@@ -57,17 +57,19 @@ __export(package_exports, {
|
|
|
57
57
|
version: () => version
|
|
58
58
|
});
|
|
59
59
|
var name = "mahameru";
|
|
60
|
-
var version = "0.
|
|
61
|
-
var description = "";
|
|
60
|
+
var version = "0.0.2";
|
|
61
|
+
var description = "Mahameru is a minimal and fast Node.js framework for building HTTP servers";
|
|
62
62
|
var main = "./dist/index.cjs";
|
|
63
63
|
var module2 = "./dist/index.js";
|
|
64
64
|
var types = "./dist/index.d.ts";
|
|
65
|
-
var bin =
|
|
65
|
+
var bin = {
|
|
66
|
+
mahameru: "./dist/cli/index.js"
|
|
67
|
+
};
|
|
66
68
|
var scripts = {
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
69
|
+
build: "tsup --config tsup.config.ts",
|
|
70
|
+
pack: "npm run build && npm pack",
|
|
71
|
+
typecheck: "tsc --noEmit --project tsconfig.json",
|
|
72
|
+
prepare: "npm run typecheck && npm run build"
|
|
71
73
|
};
|
|
72
74
|
var exports2 = {
|
|
73
75
|
".": {
|
|
@@ -155,7 +157,7 @@ var import_ora = __toESM(require("ora"), 1);
|
|
|
155
157
|
var import_picocolors = __toESM(require("picocolors"), 1);
|
|
156
158
|
var import_node_child_process = require("child_process");
|
|
157
159
|
async function onInit() {
|
|
158
|
-
const repo = "bintvn/
|
|
160
|
+
const repo = "bintvn/mahameru-basic-template";
|
|
159
161
|
const answers = await import_inquirer.default.prompt([
|
|
160
162
|
{
|
|
161
163
|
type: "input",
|
|
@@ -287,7 +289,7 @@ function createHttpServer(app, existingHttpServer, options = {}) {
|
|
|
287
289
|
httpServer.listen(PORT, HOST, void 0, async () => {
|
|
288
290
|
const address = httpServer.address();
|
|
289
291
|
if (address && typeof address !== "string") {
|
|
290
|
-
console.log("HTTP Server", `Listening on http://${HOST}
|
|
292
|
+
console.log("HTTP Server", `Listening on http://${HOST}:${PORT} ${address.family}`);
|
|
291
293
|
} else {
|
|
292
294
|
console.log("HTTP Server", `Listening on ${address}`);
|
|
293
295
|
}
|
package/dist/cli/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../node_modules/tsup/assets/cjs_shims.js","../../src/cli/index.ts","../../package.json","../../src/cli/scripts/on-init.ts","../../src/cli/scripts/on-build.ts","../../src/cli/scripts/on-start.ts","../../src/cli/scripts/on-dev.ts","../../src/error.ts","../../src/http.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/client.ts","../../src/base-class/base.entity.ts","../../src/base-class/base.model.ts","../../src/index.ts"],"sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n typeof document === \"undefined\" \n ? new URL(`file:${__filename}`).href \n : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n ? document.currentScript.src \n : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","#!/usr/bin/env node\n\nimport { Command } from 'commander';\n\nimport * as pkg from '../../package.json' with { type: 'json' };\nimport onInit from './scripts/on-init.js';\nimport onBuild from './scripts/on-build.js';\nimport onStart from './scripts/on-start.js';\nimport onDev from './scripts/on-dev.js';\n\nconst { default: { version } } = pkg;\nconst program = new Command();\n\nprogram\n .name('mahameru')\n .version(version)\n .description('Mahameru - A minimal and fast Node.js framework for building HTTP servers');\n\nprogram\n .command('init')\n .description('Initialize a new project from a GitHub template')\n .action(onInit);\n\nprogram\n .command('dev')\n .description('Start the development server')\n .option('-p, --port <port>', 'Port to run the development server on', '3000')\n .action(onDev);\n\nprogram\n .command('build')\n .description('Build project')\n .action(onBuild);\n\nprogram\n .command('start')\n .description('Start the production server')\n .action(onStart);\n\nprogram.parse(process.argv);\n","{\n \"name\": \"mahameru\",\n \"version\": \"0.1.0\",\n \"description\": \"\",\n \"main\": \"./dist/index.cjs\",\n \"module\": \"./dist/index.js\",\n \"types\": \"./dist/index.d.ts\",\n \"bin\": \"./dist/cli/index.js\",\n \"scripts\": {\n \"dev\": \"set NODE_ENV=development && tsx watch --tsconfig tsconfig.json --conditions=development src/index.ts\",\n \"build\": \"tsup --config tsup.config.ts && npm pack\",\n \"start\": \"node dist/index.js\",\n \"typecheck\": \"tsc --noEmit --project tsconfig.json\"\n },\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.js\",\n \"require\": \"./dist/index.cjs\"\n },\n \"./database\": {\n \"types\": \"./dist/database/index.d.ts\",\n \"import\": \"./dist/database/index.js\",\n \"require\": \"./dist/database/index.cjs\"\n },\n \"./database/column\": {\n \"types\": \"./dist/database/column/index.d.ts\",\n \"import\": \"./dist/database/column/index.js\",\n \"require\": \"./dist/database/column/index.cjs\"\n }\n },\n \"files\": [\n \"dist\"\n ],\n \"keywords\": [],\n \"author\": \"Bintan <hello@bintvn.co>\",\n \"license\": \"ISC\",\n \"type\": \"module\",\n \"peerDependencies\": {\n \"@types/node\": \"^26.0.0\",\n \"tsc-alias\": \"^1.8.17\",\n \"tsx\": \"^4.22.4\",\n \"typeorm\": \"^1.0.0\",\n \"typescript\": \"^6.0.3\"\n },\n \"dependencies\": {\n \"commander\": \"^15.0.0\",\n \"cookie-parser\": \"^1.4.7\",\n \"cors\": \"^2.8.6\",\n \"degit\": \"^3.4.7\",\n \"express\": \"^5.2.1\",\n \"helmet\": \"^8.2.0\",\n \"inquirer\": \"^14.0.2\",\n \"lite-env\": \"^1.1.0\",\n \"ora\": \"^9.4.0\",\n \"picocolors\": \"^1.1.1\",\n \"typeorm-dto-generator\": \"^1.0.6\"\n },\n \"devDependencies\": {\n \"@swc/core\": \"^1.15.41\",\n \"@types/cookie-parser\": \"^1.4.10\",\n \"@types/cors\": \"^2.8.19\",\n \"@types/express\": \"^5.0.6\",\n \"@types/helmet\": \"^0.0.48\",\n \"@types/node\": \"^26.0.0\",\n \"tsc-alias\": \"^1.8.17\",\n \"tsup\": \"^8.5.1\",\n \"tsx\": \"^4.22.4\",\n \"typeorm\": \"^1.0.0\",\n \"typescript\": \"^6.0.3\"\n }\n}","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}","import { execSync } from \"node:child_process\";\r\nimport { renameSync } from \"node:fs\";\r\nimport path from \"node:path\";\r\n\r\nexport default async function onBuild() {\r\n console.log('\\x1b[32m%s\\x1b[0m', '▲ Mahameru - Compiling TypeScript with tsc...');\r\n\r\n try {\r\n const tscPath = path.join(process.cwd(), 'node_modules', 'typescript', 'bin', 'tsc');\r\n const tscAliasPath = path.join(process.cwd(), 'node_modules', 'tsc-alias', 'dist', 'bin', 'index.js');\r\n\r\n execSync(`node \"${tscPath}\" -p tsconfig.json && node \"${tscAliasPath}\" -p tsconfig.json`, {\r\n stdio: 'inherit',\r\n cwd: process.cwd()\r\n });\r\n\r\n renameSync(path.join(process.cwd(), 'dist'), path.join(process.cwd(), '.mahameru'));\r\n\r\n console.log('\\x1b[32m%s\\x1b[0m', '✔ Build berhasil selesai.');\r\n } catch (error) {\r\n console.error('\\x1b[31m%s\\x1b[0m', '✖ Build gagal.');\r\n process.exit(1);\r\n }\r\n}\r\n","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","import { pathToFileURL } from 'node:url';\r\nimport mahameru, { type MahameruConfig, MahameruError } from '../../index.js';\r\nimport path from 'node:path';\r\n\r\nexport default async function onDev(cliOptions: { port: string }) {\r\n try {\r\n console.log('\\x1b[36m%s\\x1b[0m', '▲ Mahameru - Starting development server...');\r\n\r\n const root = process.cwd();\r\n const configPath = pathToFileURL(path.join(root, 'mahameru.config.ts')).href;\r\n const module = await import(configPath);\r\n\r\n if (!module.default)\r\n throw new MahameruError('Mahameru config not found')\r\n\r\n const mahameruConfig = module.default as MahameruConfig;\r\n const app = mahameru(mahameruConfig);\r\n\r\n await app.initialize()\r\n } catch (error) {\r\n console.error(error)\r\n }\r\n}\r\n","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","\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","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","import { Mahameru, type MahameruConfig } from \"./mahameru.js\"\r\n\r\nconst mahameru = (config: MahameruConfig) => {\r\n try {\r\n const mahameru = new Mahameru(config)\r\n\r\n return mahameru\r\n } catch (err) {\r\n console.error(err)\r\n\r\n process.exit(1)\r\n }\r\n}\r\n\r\nexport default mahameru\r\n","import { Column, CreateDateColumn, PrimaryGeneratedColumn } from 'typeorm'\r\n\r\nexport abstract class BaseEntity {\r\n @PrimaryGeneratedColumn('uuid')\r\n id: string\r\n\r\n @CreateDateColumn({\r\n type: 'datetime',\r\n precision: 3,\r\n default: () => 'UTC_TIMESTAMP(3)',\r\n })\r\n createdAt: Date\r\n\r\n @Column({\r\n type: 'datetime',\r\n precision: 3,\r\n default: null,\r\n nullable: true\r\n })\r\n updatedAt: Date | null\r\n\r\n @Column({\r\n type: 'boolean',\r\n default: false\r\n })\r\n isDisabled: boolean\r\n}\r\n","import {\r\n DataSource,\r\n DeepPartial,\r\n EntityManager,\r\n EntityTarget,\r\n FindManyOptions,\r\n FindOneOptions,\r\n FindOptionsOrder,\r\n FindOptionsRelations,\r\n FindOptionsWhere,\r\n Like,\r\n ObjectLiteral,\r\n QueryDeepPartialEntity,\r\n Repository\r\n} from 'typeorm'\r\nimport type { ParsedListQuery } from './base.controller.js'\r\n\r\nexport type CreateBatchOptions = {\r\n chunkSize?: number\r\n}\r\n\r\nexport type CreateBatchResult<T extends ObjectLiteral> = {\r\n totalRecord: number\r\n totalAdded: number\r\n failed: {\r\n data: DeepPartial<T>\r\n error: unknown\r\n }[]\r\n}\r\n\r\nexport type TransactionHandler<TResult> = (manager: EntityManager) => Promise<TResult>\r\n\r\nexport type BaseModelListOptions<TEntity extends ObjectLiteral> = {\r\n parsedListQuery: ParsedListQuery<TEntity>\r\n searchFields?: (keyof TEntity)[]\r\n relations?: FindOptionsRelations<TEntity>\r\n where?: FindOptionsWhere<TEntity> | FindOptionsWhere<TEntity>[]\r\n defaultOrder?: FindOptionsOrder<TEntity>\r\n}\r\n\r\nexport abstract class BaseModel<TEntity extends ObjectLiteral & { id: string }> {\r\n private static readonly defaultChunkSize = 500\r\n\r\n constructor(\r\n protected readonly dataSource: DataSource,\r\n protected readonly entityTarget: EntityTarget<TEntity>\r\n ) { }\r\n\r\n protected getRepository(manager?: EntityManager): Repository<TEntity> {\r\n return (manager ?? this.dataSource.manager).getRepository(this.entityTarget)\r\n }\r\n\r\n transaction<TResult>(handler: TransactionHandler<TResult>): Promise<TResult> {\r\n return this.dataSource.transaction(handler)\r\n }\r\n\r\n async list(options: BaseModelListOptions<TEntity>, manager?: EntityManager) {\r\n let where = options.where\r\n\r\n if (\r\n typeof options.parsedListQuery.query === 'string' &&\r\n options.parsedListQuery.query.trim().length > 0 &&\r\n options.searchFields &&\r\n options.searchFields.length > 0\r\n ) {\r\n const search = `%${options.parsedListQuery.query.trim()}%`\r\n\r\n where = options.searchFields.map((field) => ({\r\n [field]: Like(search)\r\n })) as FindOptionsWhere<TEntity>[]\r\n }\r\n\r\n const order: FindOptionsOrder<TEntity> | undefined = options.parsedListQuery.sortBy\r\n ? {\r\n [options.parsedListQuery.sortBy]: options.parsedListQuery.sortDirection ?? 'ASC'\r\n } as FindOptionsOrder<TEntity>\r\n : options.defaultOrder\r\n\r\n const [data, total] = await this.getRepository(manager).findAndCount({\r\n where,\r\n take: options.parsedListQuery.limit,\r\n skip: options.parsedListQuery.offset,\r\n order,\r\n relations: options.relations\r\n })\r\n\r\n return {\r\n data,\r\n meta: {\r\n total,\r\n limit: options.parsedListQuery.limit,\r\n offset: options.parsedListQuery.offset,\r\n hasNext: options.parsedListQuery.offset + data.length < total\r\n }\r\n }\r\n }\r\n\r\n find(options?: FindManyOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).find(options)\r\n }\r\n\r\n findAndCount(options?: FindManyOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).findAndCount(options)\r\n }\r\n\r\n findOne(options: FindOneOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).findOne(options)\r\n }\r\n\r\n findOneBy(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).findOneBy(where)\r\n }\r\n\r\n findOneById(id: TEntity['id'], manager?: EntityManager) {\r\n return this.getRepository(manager).findOne({\r\n where: {\r\n id\r\n } as FindOptionsWhere<TEntity>\r\n })\r\n }\r\n\r\n count(options?: FindManyOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).count(options)\r\n }\r\n\r\n countBy(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).countBy(where)\r\n }\r\n\r\n async exists(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n const total = await this.countBy(where, manager)\r\n\r\n return total > 0\r\n }\r\n\r\n create(data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).create(data)\r\n }\r\n\r\n save(data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).save(data)\r\n }\r\n\r\n async createAndSave(data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n const entity = repository.create(data)\r\n\r\n return repository.save(entity)\r\n }\r\n\r\n async createBatch(data: DeepPartial<TEntity>[], options: CreateBatchOptions = {}, manager?: EntityManager): Promise<CreateBatchResult<TEntity>> {\r\n const chunkSize = this.normalizeChunkSize(options.chunkSize)\r\n const result: CreateBatchResult<TEntity> = {\r\n totalRecord: data.length,\r\n totalAdded: 0,\r\n failed: []\r\n }\r\n\r\n for (let index = 0; index < data.length; index += chunkSize) {\r\n const chunk = data.slice(index, index + chunkSize)\r\n\r\n try {\r\n const saved = await this.saveBatch(chunk, manager)\r\n result.totalAdded += saved.length\r\n } catch {\r\n await this.saveBatchOneByOne(chunk, result, manager)\r\n }\r\n }\r\n\r\n return result\r\n }\r\n\r\n async update(where: FindOptionsWhere<TEntity> | FindOptionsWhere<TEntity>[], data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n\r\n if (!data.updatedAt)\r\n (data as any).updatedAt = new Date()\r\n\r\n return repository.update(where, data)\r\n }\r\n\r\n updateById(\r\n id: TEntity['id'],\r\n data: DeepPartial<TEntity>,\r\n manager?: EntityManager\r\n ) {\r\n const repository = this.getRepository(manager)\r\n\r\n if (!data.updatedAt)\r\n (data as any).updatedAt = new Date()\r\n\r\n return repository.update(id, data)\r\n }\r\n\r\n async updateByIds(\r\n ids: string[],\r\n data: QueryDeepPartialEntity<TEntity>,\r\n manager?: EntityManager\r\n ) {\r\n const repository = this.getRepository(manager)\r\n\r\n if (!(data as any).updatedAt)\r\n (data as any).updatedAt = new Date()\r\n\r\n return repository.update(ids, { ...data })\r\n }\r\n\r\n async removeById(id: TEntity['id'], manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n\r\n const entity = await this.findOneById(id, manager)\r\n\r\n if (!entity) {\r\n return null\r\n }\r\n\r\n await repository.remove(entity)\r\n\r\n return entity\r\n }\r\n\r\n async softRemoveById(id: TEntity['id'], manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n\r\n const entity = await this.findOneById(id, manager)\r\n\r\n if (!entity) {\r\n return null\r\n }\r\n\r\n await repository.softRemove(entity)\r\n\r\n return entity\r\n }\r\n\r\n async restoreById(id: TEntity['id'], manager?: EntityManager) {\r\n const result = await this.getRepository(manager).restore(id)\r\n\r\n return Boolean(result.affected)\r\n }\r\n\r\n async delete(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n const result = await this.getRepository(manager).delete(where)\r\n\r\n return Boolean(result.affected)\r\n }\r\n\r\n private normalizeChunkSize(chunkSize?: number) {\r\n if (!chunkSize || chunkSize < 1) return BaseModel.defaultChunkSize\r\n\r\n return Math.floor(chunkSize)\r\n }\r\n\r\n async saveBatch(data: DeepPartial<TEntity>[], manager?: EntityManager) {\r\n const repo = this.getRepository(manager)\r\n const objects = repo.create(data)\r\n\r\n return repo.save(objects, {\r\n chunk: data.length\r\n })\r\n }\r\n\r\n private async saveBatchOneByOne(data: DeepPartial<TEntity>[], result: CreateBatchResult<TEntity>, manager?: EntityManager) {\r\n for (const item of data) {\r\n try {\r\n await this.saveBatch([item], manager)\r\n result.totalAdded += 1\r\n } catch (error) {\r\n result.failed.push({\r\n data: item,\r\n error\r\n })\r\n }\r\n }\r\n }\r\n}\r\n","import MahameruError from './error.js'\r\nimport createHttpServer from './http.js'\r\nimport { type MahameruConfig } from './mahameru.js'\r\nimport { MahameruRequest } from './request.js'\r\nimport { MahameruResponse } from './response.js'\r\nimport mahameru from './client.js'\r\n\r\nexport * from './api.error.js'\r\nexport * from './base-class/index.js'\r\n\r\nexport type { MahameruConfig }\r\nexport { createHttpServer }\r\nexport { MahameruError, MahameruRequest, MahameruResponse }\r\n\r\nexport default mahameru\r\n"],"mappings":"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","names":["getImportMetaUrl","document","URL","__filename","href","currentScript","tagName","toUpperCase","src","baseURI","importMetaUrl","exports","module","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","import_node_child_process","import_node_fs","import_node_path","onBuild","console","log","tscPath","path","join","process","cwd","tscAliasPath","execSync","stdio","renameSync","error","exit","import_node_child_process","import_node_path","onStart","console","log","distPath","path","join","process","cwd","child","spawn","stdio","env","NODE_ENV","on","code","exit","import_node_url","MahameruError","Error","message","name","captureStackTrace","toString","toJSON","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","import_node_path","root","process","cwd","__filename","fileURLToPath","__dirname","dirname","isCommonJS","module","exports","createCorsMiddleware","allowedOrigins","cors","req","callback","origin","headers","indexOf","methods","credentials","request","response","next","ip","headers","Error","ipAddress","userAgent","path","length","endsWith","newPath","slice","query","url","redirect","filterMiddleware","API_ERROR_STATUS","BAD_REQUEST","UNAUTHORIZED","FORBIDDEN","NOT_FOUND","ROUTE_NOT_FOUND","TOO_MANY_REQUESTS","CONFLICT","INTERNAL_SERVER_ERROR","TOKEN_EXPIRED","REFRESH_TOKEN_EXPIRED","ACCESS_TOKEN_EXPIRED","ACCESS_TOKEN_REQUIRED","TOKEN_REFRESH_TOO_EARLY","EMAIL_NOT_VERIFIED","PHONE_NOT_VERIFIED","TOKEN_NOT_FOUND","INVALID_TOKEN","RESET_PASSWORD_TOKEN_USED","RESET_PASSWORD_NEEDED","ROLE_DISABLED","SESSION_NOT_FOUND","SESSION_DISABLED","INVALID_RESPONSE","UNKNOWN_CLIENT_ERROR","INVALID_CREDENTIALS","VALIDATION_ERROR","APIError","Error","code","status","details","args","message","name","Object","setPrototypeOf","prototype","request","APIError","path","notFoundMiddleware","isPlainObject","value","Object","getPrototypeOf","prototype","createErrorMiddleware","cookieTokenOptions","error","req","res","_","setHeader","APIError","code","console","status","json","success","message","cookies","token","clearCookie","details","retryIn","responseBody","SyntaxError","statusCode","Error","createExpressApp","options","app","express","set","disable","use","helmet","createCorsMiddleware","allowedOrigins","filterMiddleware","json","limit","cookieParser","cookieSecret","urlencoded","extended","static","dotfiles","etag","immutable","index","lastModified","maxAge","get","request","response","status","success","message","appName","data","userAgent","ipAddress","routes","public","private","notFoundMiddleware","createErrorMiddleware","cookieOptions","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","mahameru","config","Mahameru","err","console","error","process","exit","BaseEntity","id","createdAt","updatedAt","isDisabled","type","precision","default","nullable","import_typeorm","mahameru","import_node_path","cliOptions","console","log","root","process","cwd","configPath","pathToFileURL","path","join","href","module","default","MahameruError","mahameruConfig","app","mahameru","initialize","error","onDev","default","version","pkg","program","Command","name","description","command","action","onInit","option","onDev","onBuild","onStart","parse","process","argv"]}
|
|
1
|
+
{"version":3,"sources":["../../node_modules/tsup/assets/cjs_shims.js","../../src/cli/index.ts","../../package.json","../../src/cli/scripts/on-init.ts","../../src/cli/scripts/on-build.ts","../../src/cli/scripts/on-start.ts","../../src/cli/scripts/on-dev.ts","../../src/error.ts","../../src/http.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/client.ts","../../src/base-class/base.entity.ts","../../src/base-class/base.model.ts","../../src/index.ts"],"sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n typeof document === \"undefined\" \n ? new URL(`file:${__filename}`).href \n : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n ? document.currentScript.src \n : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","#!/usr/bin/env node\n\nimport { Command } from 'commander';\n\nimport * as pkg from '../../package.json' with { type: 'json' };\nimport onInit from './scripts/on-init.js';\nimport onBuild from './scripts/on-build.js';\nimport onStart from './scripts/on-start.js';\nimport onDev from './scripts/on-dev.js';\n\nconst { default: { version } } = pkg;\nconst program = new Command();\n\nprogram\n .name('mahameru')\n .version(version)\n .description('Mahameru - A minimal and fast Node.js framework for building HTTP servers');\n\nprogram\n .command('init')\n .description('Initialize a new project from a GitHub template')\n .action(onInit);\n\nprogram\n .command('dev')\n .description('Start the development server')\n .option('-p, --port <port>', 'Port to run the development server on', '3000')\n .action(onDev);\n\nprogram\n .command('build')\n .description('Build project')\n .action(onBuild);\n\nprogram\n .command('start')\n .description('Start the production server')\n .action(onStart);\n\nprogram.parse(process.argv);\n","{\n \"name\": \"mahameru\",\n \"version\": \"0.0.2\",\n \"description\": \"Mahameru is a minimal and fast Node.js framework for building HTTP servers\",\n \"main\": \"./dist/index.cjs\",\n \"module\": \"./dist/index.js\",\n \"types\": \"./dist/index.d.ts\",\n \"bin\": {\n \"mahameru\": \"./dist/cli/index.js\"\n },\n \"scripts\": {\n \"build\": \"tsup --config tsup.config.ts\",\n \"pack\": \"npm run build && npm pack\",\n \"typecheck\": \"tsc --noEmit --project tsconfig.json\",\n \"prepare\": \"npm run typecheck && npm run build\"\n },\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.js\",\n \"require\": \"./dist/index.cjs\"\n },\n \"./database\": {\n \"types\": \"./dist/database/index.d.ts\",\n \"import\": \"./dist/database/index.js\",\n \"require\": \"./dist/database/index.cjs\"\n },\n \"./database/column\": {\n \"types\": \"./dist/database/column/index.d.ts\",\n \"import\": \"./dist/database/column/index.js\",\n \"require\": \"./dist/database/column/index.cjs\"\n }\n },\n \"files\": [\n \"dist\"\n ],\n \"keywords\": [],\n \"author\": \"Bintan <hello@bintvn.co>\",\n \"license\": \"ISC\",\n \"type\": \"module\",\n \"peerDependencies\": {\n \"@types/node\": \"^26.0.0\",\n \"tsc-alias\": \"^1.8.17\",\n \"tsx\": \"^4.22.4\",\n \"typeorm\": \"^1.0.0\",\n \"typescript\": \"^6.0.3\"\n },\n \"dependencies\": {\n \"commander\": \"^15.0.0\",\n \"cookie-parser\": \"^1.4.7\",\n \"cors\": \"^2.8.6\",\n \"degit\": \"^3.4.7\",\n \"express\": \"^5.2.1\",\n \"helmet\": \"^8.2.0\",\n \"inquirer\": \"^14.0.2\",\n \"lite-env\": \"^1.1.0\",\n \"ora\": \"^9.4.0\",\n \"picocolors\": \"^1.1.1\",\n \"typeorm-dto-generator\": \"^1.0.6\"\n },\n \"devDependencies\": {\n \"@swc/core\": \"^1.15.41\",\n \"@types/cookie-parser\": \"^1.4.10\",\n \"@types/cors\": \"^2.8.19\",\n \"@types/express\": \"^5.0.6\",\n \"@types/helmet\": \"^0.0.48\",\n \"@types/node\": \"^26.0.0\",\n \"tsc-alias\": \"^1.8.17\",\n \"tsup\": \"^8.5.1\",\n \"tsx\": \"^4.22.4\",\n \"typeorm\": \"^1.0.0\",\n \"typescript\": \"^6.0.3\"\n }\n}\n","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/mahameru-basic-template';\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}","import { execSync } from \"node:child_process\";\r\nimport { renameSync } from \"node:fs\";\r\nimport path from \"node:path\";\r\n\r\nexport default async function onBuild() {\r\n console.log('\\x1b[32m%s\\x1b[0m', '▲ Mahameru - Compiling TypeScript with tsc...');\r\n\r\n try {\r\n const tscPath = path.join(process.cwd(), 'node_modules', 'typescript', 'bin', 'tsc');\r\n const tscAliasPath = path.join(process.cwd(), 'node_modules', 'tsc-alias', 'dist', 'bin', 'index.js');\r\n\r\n execSync(`node \"${tscPath}\" -p tsconfig.json && node \"${tscAliasPath}\" -p tsconfig.json`, {\r\n stdio: 'inherit',\r\n cwd: process.cwd()\r\n });\r\n\r\n renameSync(path.join(process.cwd(), 'dist'), path.join(process.cwd(), '.mahameru'));\r\n\r\n console.log('\\x1b[32m%s\\x1b[0m', '✔ Build berhasil selesai.');\r\n } catch (error) {\r\n console.error('\\x1b[31m%s\\x1b[0m', '✖ Build gagal.');\r\n process.exit(1);\r\n }\r\n}\r\n","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","import { pathToFileURL } from 'node:url';\r\nimport mahameru, { type MahameruConfig, MahameruError } from '../../index.js';\r\nimport path from 'node:path';\r\n\r\nexport default async function onDev(cliOptions: { port: string }) {\r\n try {\r\n console.log('\\x1b[36m%s\\x1b[0m', '▲ Mahameru - Starting development server...');\r\n\r\n const root = process.cwd();\r\n const configPath = pathToFileURL(path.join(root, 'mahameru.config.ts')).href;\r\n const module = await import(configPath);\r\n\r\n if (!module.default)\r\n throw new MahameruError('Mahameru config not found')\r\n\r\n const mahameruConfig = module.default as MahameruConfig;\r\n const app = mahameru(mahameruConfig);\r\n\r\n await app.initialize()\r\n } catch (error) {\r\n console.error(error)\r\n }\r\n}\r\n","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","\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","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","import { Mahameru, type MahameruConfig } from \"./mahameru.js\"\r\n\r\nconst mahameru = (config: MahameruConfig) => {\r\n try {\r\n const mahameru = new Mahameru(config)\r\n\r\n return mahameru\r\n } catch (err) {\r\n console.error(err)\r\n\r\n process.exit(1)\r\n }\r\n}\r\n\r\nexport default mahameru\r\n","import { Column, CreateDateColumn, PrimaryGeneratedColumn } from 'typeorm'\r\n\r\nexport abstract class BaseEntity {\r\n @PrimaryGeneratedColumn('uuid')\r\n id: string\r\n\r\n @CreateDateColumn({\r\n type: 'datetime',\r\n precision: 3,\r\n default: () => 'UTC_TIMESTAMP(3)',\r\n })\r\n createdAt: Date\r\n\r\n @Column({\r\n type: 'datetime',\r\n precision: 3,\r\n default: null,\r\n nullable: true\r\n })\r\n updatedAt: Date | null\r\n\r\n @Column({\r\n type: 'boolean',\r\n default: false\r\n })\r\n isDisabled: boolean\r\n}\r\n","import {\r\n DataSource,\r\n DeepPartial,\r\n EntityManager,\r\n EntityTarget,\r\n FindManyOptions,\r\n FindOneOptions,\r\n FindOptionsOrder,\r\n FindOptionsRelations,\r\n FindOptionsWhere,\r\n Like,\r\n ObjectLiteral,\r\n QueryDeepPartialEntity,\r\n Repository\r\n} from 'typeorm'\r\nimport type { ParsedListQuery } from './base.controller.js'\r\n\r\nexport type CreateBatchOptions = {\r\n chunkSize?: number\r\n}\r\n\r\nexport type CreateBatchResult<T extends ObjectLiteral> = {\r\n totalRecord: number\r\n totalAdded: number\r\n failed: {\r\n data: DeepPartial<T>\r\n error: unknown\r\n }[]\r\n}\r\n\r\nexport type TransactionHandler<TResult> = (manager: EntityManager) => Promise<TResult>\r\n\r\nexport type BaseModelListOptions<TEntity extends ObjectLiteral> = {\r\n parsedListQuery: ParsedListQuery<TEntity>\r\n searchFields?: (keyof TEntity)[]\r\n relations?: FindOptionsRelations<TEntity>\r\n where?: FindOptionsWhere<TEntity> | FindOptionsWhere<TEntity>[]\r\n defaultOrder?: FindOptionsOrder<TEntity>\r\n}\r\n\r\nexport abstract class BaseModel<TEntity extends ObjectLiteral & { id: string }> {\r\n private static readonly defaultChunkSize = 500\r\n\r\n constructor(\r\n protected readonly dataSource: DataSource,\r\n protected readonly entityTarget: EntityTarget<TEntity>\r\n ) { }\r\n\r\n protected getRepository(manager?: EntityManager): Repository<TEntity> {\r\n return (manager ?? this.dataSource.manager).getRepository(this.entityTarget)\r\n }\r\n\r\n transaction<TResult>(handler: TransactionHandler<TResult>): Promise<TResult> {\r\n return this.dataSource.transaction(handler)\r\n }\r\n\r\n async list(options: BaseModelListOptions<TEntity>, manager?: EntityManager) {\r\n let where = options.where\r\n\r\n if (\r\n typeof options.parsedListQuery.query === 'string' &&\r\n options.parsedListQuery.query.trim().length > 0 &&\r\n options.searchFields &&\r\n options.searchFields.length > 0\r\n ) {\r\n const search = `%${options.parsedListQuery.query.trim()}%`\r\n\r\n where = options.searchFields.map((field) => ({\r\n [field]: Like(search)\r\n })) as FindOptionsWhere<TEntity>[]\r\n }\r\n\r\n const order: FindOptionsOrder<TEntity> | undefined = options.parsedListQuery.sortBy\r\n ? {\r\n [options.parsedListQuery.sortBy]: options.parsedListQuery.sortDirection ?? 'ASC'\r\n } as FindOptionsOrder<TEntity>\r\n : options.defaultOrder\r\n\r\n const [data, total] = await this.getRepository(manager).findAndCount({\r\n where,\r\n take: options.parsedListQuery.limit,\r\n skip: options.parsedListQuery.offset,\r\n order,\r\n relations: options.relations\r\n })\r\n\r\n return {\r\n data,\r\n meta: {\r\n total,\r\n limit: options.parsedListQuery.limit,\r\n offset: options.parsedListQuery.offset,\r\n hasNext: options.parsedListQuery.offset + data.length < total\r\n }\r\n }\r\n }\r\n\r\n find(options?: FindManyOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).find(options)\r\n }\r\n\r\n findAndCount(options?: FindManyOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).findAndCount(options)\r\n }\r\n\r\n findOne(options: FindOneOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).findOne(options)\r\n }\r\n\r\n findOneBy(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).findOneBy(where)\r\n }\r\n\r\n findOneById(id: TEntity['id'], manager?: EntityManager) {\r\n return this.getRepository(manager).findOne({\r\n where: {\r\n id\r\n } as FindOptionsWhere<TEntity>\r\n })\r\n }\r\n\r\n count(options?: FindManyOptions<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).count(options)\r\n }\r\n\r\n countBy(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).countBy(where)\r\n }\r\n\r\n async exists(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n const total = await this.countBy(where, manager)\r\n\r\n return total > 0\r\n }\r\n\r\n create(data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).create(data)\r\n }\r\n\r\n save(data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n return this.getRepository(manager).save(data)\r\n }\r\n\r\n async createAndSave(data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n const entity = repository.create(data)\r\n\r\n return repository.save(entity)\r\n }\r\n\r\n async createBatch(data: DeepPartial<TEntity>[], options: CreateBatchOptions = {}, manager?: EntityManager): Promise<CreateBatchResult<TEntity>> {\r\n const chunkSize = this.normalizeChunkSize(options.chunkSize)\r\n const result: CreateBatchResult<TEntity> = {\r\n totalRecord: data.length,\r\n totalAdded: 0,\r\n failed: []\r\n }\r\n\r\n for (let index = 0; index < data.length; index += chunkSize) {\r\n const chunk = data.slice(index, index + chunkSize)\r\n\r\n try {\r\n const saved = await this.saveBatch(chunk, manager)\r\n result.totalAdded += saved.length\r\n } catch {\r\n await this.saveBatchOneByOne(chunk, result, manager)\r\n }\r\n }\r\n\r\n return result\r\n }\r\n\r\n async update(where: FindOptionsWhere<TEntity> | FindOptionsWhere<TEntity>[], data: DeepPartial<TEntity>, manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n\r\n if (!data.updatedAt)\r\n (data as any).updatedAt = new Date()\r\n\r\n return repository.update(where, data)\r\n }\r\n\r\n updateById(\r\n id: TEntity['id'],\r\n data: DeepPartial<TEntity>,\r\n manager?: EntityManager\r\n ) {\r\n const repository = this.getRepository(manager)\r\n\r\n if (!data.updatedAt)\r\n (data as any).updatedAt = new Date()\r\n\r\n return repository.update(id, data)\r\n }\r\n\r\n async updateByIds(\r\n ids: string[],\r\n data: QueryDeepPartialEntity<TEntity>,\r\n manager?: EntityManager\r\n ) {\r\n const repository = this.getRepository(manager)\r\n\r\n if (!(data as any).updatedAt)\r\n (data as any).updatedAt = new Date()\r\n\r\n return repository.update(ids, { ...data })\r\n }\r\n\r\n async removeById(id: TEntity['id'], manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n\r\n const entity = await this.findOneById(id, manager)\r\n\r\n if (!entity) {\r\n return null\r\n }\r\n\r\n await repository.remove(entity)\r\n\r\n return entity\r\n }\r\n\r\n async softRemoveById(id: TEntity['id'], manager?: EntityManager) {\r\n const repository = this.getRepository(manager)\r\n\r\n const entity = await this.findOneById(id, manager)\r\n\r\n if (!entity) {\r\n return null\r\n }\r\n\r\n await repository.softRemove(entity)\r\n\r\n return entity\r\n }\r\n\r\n async restoreById(id: TEntity['id'], manager?: EntityManager) {\r\n const result = await this.getRepository(manager).restore(id)\r\n\r\n return Boolean(result.affected)\r\n }\r\n\r\n async delete(where: FindOptionsWhere<TEntity>, manager?: EntityManager) {\r\n const result = await this.getRepository(manager).delete(where)\r\n\r\n return Boolean(result.affected)\r\n }\r\n\r\n private normalizeChunkSize(chunkSize?: number) {\r\n if (!chunkSize || chunkSize < 1) return BaseModel.defaultChunkSize\r\n\r\n return Math.floor(chunkSize)\r\n }\r\n\r\n async saveBatch(data: DeepPartial<TEntity>[], manager?: EntityManager) {\r\n const repo = this.getRepository(manager)\r\n const objects = repo.create(data)\r\n\r\n return repo.save(objects, {\r\n chunk: data.length\r\n })\r\n }\r\n\r\n private async saveBatchOneByOne(data: DeepPartial<TEntity>[], result: CreateBatchResult<TEntity>, manager?: EntityManager) {\r\n for (const item of data) {\r\n try {\r\n await this.saveBatch([item], manager)\r\n result.totalAdded += 1\r\n } catch (error) {\r\n result.failed.push({\r\n data: item,\r\n error\r\n })\r\n }\r\n }\r\n }\r\n}\r\n","import MahameruError from './error.js'\r\nimport createHttpServer from './http.js'\r\nimport { type MahameruConfig } from './mahameru.js'\r\nimport { MahameruRequest } from './request.js'\r\nimport { MahameruResponse } from './response.js'\r\nimport mahameru from './client.js'\r\n\r\nexport * from './api.error.js'\r\nexport * from './base-class/index.js'\r\n\r\nexport type { MahameruConfig }\r\nexport { createHttpServer }\r\nexport { MahameruError, MahameruRequest, MahameruResponse }\r\n\r\nexport default mahameru\r\n"],"mappings":"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","names":["getImportMetaUrl","document","URL","__filename","href","currentScript","tagName","toUpperCase","src","baseURI","importMetaUrl","exports","module","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","import_node_child_process","import_node_fs","import_node_path","onBuild","console","log","tscPath","path","join","process","cwd","tscAliasPath","execSync","stdio","renameSync","error","exit","import_node_child_process","import_node_path","onStart","console","log","distPath","path","join","process","cwd","child","spawn","stdio","env","NODE_ENV","on","code","exit","import_node_url","MahameruError","Error","message","name","captureStackTrace","toString","toJSON","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","import_node_path","root","process","cwd","__filename","fileURLToPath","__dirname","dirname","isCommonJS","module","exports","createCorsMiddleware","allowedOrigins","cors","req","callback","origin","headers","indexOf","methods","credentials","request","response","next","ip","headers","Error","ipAddress","userAgent","path","length","endsWith","newPath","slice","query","url","redirect","filterMiddleware","API_ERROR_STATUS","BAD_REQUEST","UNAUTHORIZED","FORBIDDEN","NOT_FOUND","ROUTE_NOT_FOUND","TOO_MANY_REQUESTS","CONFLICT","INTERNAL_SERVER_ERROR","TOKEN_EXPIRED","REFRESH_TOKEN_EXPIRED","ACCESS_TOKEN_EXPIRED","ACCESS_TOKEN_REQUIRED","TOKEN_REFRESH_TOO_EARLY","EMAIL_NOT_VERIFIED","PHONE_NOT_VERIFIED","TOKEN_NOT_FOUND","INVALID_TOKEN","RESET_PASSWORD_TOKEN_USED","RESET_PASSWORD_NEEDED","ROLE_DISABLED","SESSION_NOT_FOUND","SESSION_DISABLED","INVALID_RESPONSE","UNKNOWN_CLIENT_ERROR","INVALID_CREDENTIALS","VALIDATION_ERROR","APIError","Error","code","status","details","args","message","name","Object","setPrototypeOf","prototype","request","APIError","path","notFoundMiddleware","isPlainObject","value","Object","getPrototypeOf","prototype","createErrorMiddleware","cookieTokenOptions","error","req","res","_","setHeader","APIError","code","console","status","json","success","message","cookies","token","clearCookie","details","retryIn","responseBody","SyntaxError","statusCode","Error","createExpressApp","options","app","express","set","disable","use","helmet","createCorsMiddleware","allowedOrigins","filterMiddleware","json","limit","cookieParser","cookieSecret","urlencoded","extended","static","dotfiles","etag","immutable","index","lastModified","maxAge","get","request","response","status","success","message","appName","data","userAgent","ipAddress","routes","public","private","notFoundMiddleware","createErrorMiddleware","cookieOptions","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","mahameru","config","Mahameru","err","console","error","process","exit","BaseEntity","id","createdAt","updatedAt","isDisabled","type","precision","default","nullable","import_typeorm","mahameru","import_node_path","cliOptions","console","log","root","process","cwd","configPath","pathToFileURL","path","join","href","module","default","MahameruError","mahameruConfig","app","mahameru","initialize","error","onDev","default","version","pkg","program","Command","name","description","command","action","onInit","option","onDev","onBuild","onStart","parse","process","argv"]}
|
package/dist/cli/index.js
CHANGED
|
@@ -32,17 +32,19 @@ __export(package_exports, {
|
|
|
32
32
|
version: () => version
|
|
33
33
|
});
|
|
34
34
|
var name = "mahameru";
|
|
35
|
-
var version = "0.
|
|
36
|
-
var description = "";
|
|
35
|
+
var version = "0.0.2";
|
|
36
|
+
var description = "Mahameru is a minimal and fast Node.js framework for building HTTP servers";
|
|
37
37
|
var main = "./dist/index.cjs";
|
|
38
38
|
var module2 = "./dist/index.js";
|
|
39
39
|
var types = "./dist/index.d.ts";
|
|
40
|
-
var bin =
|
|
40
|
+
var bin = {
|
|
41
|
+
mahameru: "./dist/cli/index.js"
|
|
42
|
+
};
|
|
41
43
|
var scripts = {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
build: "tsup --config tsup.config.ts",
|
|
45
|
+
pack: "npm run build && npm pack",
|
|
46
|
+
typecheck: "tsc --noEmit --project tsconfig.json",
|
|
47
|
+
prepare: "npm run typecheck && npm run build"
|
|
46
48
|
};
|
|
47
49
|
var exports = {
|
|
48
50
|
".": {
|
|
@@ -130,7 +132,7 @@ import ora from "ora";
|
|
|
130
132
|
import pc from "picocolors";
|
|
131
133
|
import { execSync } from "child_process";
|
|
132
134
|
async function onInit() {
|
|
133
|
-
const repo = "bintvn/
|
|
135
|
+
const repo = "bintvn/mahameru-basic-template";
|
|
134
136
|
const answers = await inquirer.prompt([
|
|
135
137
|
{
|
|
136
138
|
type: "input",
|
|
@@ -262,7 +264,7 @@ function createHttpServer(app, existingHttpServer, options = {}) {
|
|
|
262
264
|
httpServer.listen(PORT, HOST, void 0, async () => {
|
|
263
265
|
const address = httpServer.address();
|
|
264
266
|
if (address && typeof address !== "string") {
|
|
265
|
-
console.log("HTTP Server", `Listening on http://${HOST}
|
|
267
|
+
console.log("HTTP Server", `Listening on http://${HOST}:${PORT} ${address.family}`);
|
|
266
268
|
} else {
|
|
267
269
|
console.log("HTTP Server", `Listening on ${address}`);
|
|
268
270
|
}
|