@keshavsoft/kschema-cli 1.7.2 → 1.8.1

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 (58) hide show
  1. package/bin/v8/commands/generateSamples.js +25 -0
  2. package/bin/v8/commands/init.js +23 -0
  3. package/bin/v8/commands/steps/announce.js +3 -0
  4. package/bin/v8/commands/steps/createProject.js +6 -0
  5. package/bin/v8/commands/steps/decideTemplate.js +3 -0
  6. package/bin/v8/commands/steps/locateDestination.js +5 -0
  7. package/bin/v8/commands/steps/locateSource.js +14 -0
  8. package/bin/v8/commands/template/baseTemplate.js +11 -0
  9. package/bin/v8/commands/template/basic/.vscode/launch.json +12 -0
  10. package/bin/v8/commands/template/basic/Config/Schemas/BillsTable.json +165 -0
  11. package/bin/v8/commands/template/basic/Config/Schemas/ItemsTable.json +200 -0
  12. package/bin/v8/commands/template/basic/Config/Schemas/LedgerNames.json +50 -0
  13. package/bin/v8/commands/template/basic/Config/Schemas/StockItems.json +45 -0
  14. package/bin/v8/commands/template/basic/Config/api.json +8 -0
  15. package/bin/v8/commands/template/basic/Config/schema.json +8 -0
  16. package/bin/v8/commands/template/basic/Config/ui.json +8 -0
  17. package/bin/v8/commands/template/basic/Data/BillsTable.json +165 -0
  18. package/bin/v8/commands/template/basic/Data/ItemsTable.json +200 -0
  19. package/bin/v8/commands/template/basic/Data/LedgerNames.json +6 -0
  20. package/bin/v8/commands/template/basic/Data/StockItems.json +45 -0
  21. package/bin/v8/commands/template/basic/app.js +4 -0
  22. package/bin/v8/commands/template/basic/config.json +4 -0
  23. package/bin/v8/commands/template/basic/package-lock.json +21 -0
  24. package/bin/v8/commands/template/basic/package.json +13 -0
  25. package/bin/v8/commands/template/basic/read.js +8 -0
  26. package/bin/v8/commands/template/basic/write.js +8 -0
  27. package/bin/v8/commands/template/express/.env +8 -0
  28. package/bin/v8/commands/template/express/.env.local +7 -0
  29. package/bin/v8/commands/template/express/.vscode/launch.json +12 -0
  30. package/bin/v8/commands/template/express/Config/Schemas/BillsTable.json +166 -0
  31. package/bin/v8/commands/template/express/Config/Schemas/ItemsTable.json +206 -0
  32. package/bin/v8/commands/template/express/Config/Schemas/LedgerNames.json +50 -0
  33. package/bin/v8/commands/template/express/Config/Schemas/StockItems.json +45 -0
  34. package/bin/v8/commands/template/express/Config/api.json +8 -0
  35. package/bin/v8/commands/template/express/Config/schema.json +8 -0
  36. package/bin/v8/commands/template/express/Config/ui.json +8 -0
  37. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/build.js +6 -0
  38. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/config.js +12 -0
  39. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/main.js +29 -0
  40. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/publish.js +22 -0
  41. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/repo.js +20 -0
  42. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/schema.js +16 -0
  43. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/utils.js +26 -0
  44. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/Builder/version.js +25 -0
  45. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/buildAndCopy.js +166 -0
  46. package/bin/v8/commands/template/express/ForFrontEnd/NonSecured/latestVersion.js +38 -0
  47. package/bin/v8/commands/template/express/ForFrontEnd/Secured/buildProtected.js +108 -0
  48. package/bin/v8/commands/template/express/ForFrontEnd/Secured/latestVersion.js +38 -0
  49. package/bin/v8/commands/template/express/app.js +33 -0
  50. package/bin/v8/commands/template/express/config.json +4 -0
  51. package/bin/v8/commands/template/express/package.json +18 -0
  52. package/bin/v8/commands/test.js +36 -0
  53. package/bin/v8/core/parseInput.js +10 -0
  54. package/bin/v8/core/resolveCommand.js +12 -0
  55. package/bin/v8/core/resolveFolderName.js +17 -0
  56. package/bin/v8/start.js +23 -0
  57. package/package.json +2 -2
  58. package/read.js +29 -0
@@ -0,0 +1,38 @@
1
+ import fs from "fs";
2
+
3
+ const PREFIX = "V";
4
+ const ENV_FILE = ".env";
5
+
6
+ /* -------- STEP 1: GET NEXT VERSION -------- */
7
+ const dirs = fs.readdirSync("./", { withFileTypes: true })
8
+ .filter(d => d.isDirectory() && d.name.startsWith(PREFIX));
9
+
10
+ let max = 0;
11
+
12
+ dirs.forEach(d => {
13
+ const num = parseInt(d.name.replace(PREFIX, ""), 10);
14
+ if (!isNaN(num) && num > max) max = num;
15
+ });
16
+
17
+ const latestVersion = `${PREFIX}${max}`;
18
+ console.log("Next Version:", latestVersion);
19
+
20
+ /* -------- STEP 2: UPDATE .env -------- */
21
+ let envContent = "";
22
+
23
+ if (fs.existsSync(ENV_FILE)) {
24
+ envContent = fs.readFileSync(ENV_FILE, "utf8")
25
+ .split("\n")
26
+ .map(line =>
27
+ line.startsWith("VERSION=")
28
+ ? `VERSION=${latestVersion}`
29
+ : line
30
+ )
31
+ .join("\n");
32
+ } else {
33
+ envContent = `VERSION=${latestVersion}\n`;
34
+ };
35
+
36
+ fs.writeFileSync(ENV_FILE, envContent);
37
+
38
+ console.log(".env updated successfully ✔");
@@ -0,0 +1,108 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+
4
+ import { execSync } from "child_process";
5
+
6
+ /* ================= CONFIG ================= */
7
+ const PUBLIC_DIR = "Public";
8
+ const VERSION_PREFIX = "V";
9
+ const SCHEMA_DIR = "ui.json";
10
+ const COMMON_REPO = "VoltUiGulpV1";
11
+ const COMMON_REPO_GIT = `https://github.com/keshavsoft/${COMMON_REPO}`;
12
+ const COMMON_REPO_PATH = path.join("..", COMMON_REPO);
13
+ /* ========================================== */
14
+
15
+ function run(cmd, cwd = process.cwd()) {
16
+ console.log(`> ${cmd}`);
17
+ execSync(cmd, { stdio: "inherit", cwd });
18
+ }
19
+
20
+ /* ---------- STEP 1: GET NEXT VERSION ---------- */
21
+ let max = 0;
22
+
23
+ if (fs.existsSync(PUBLIC_DIR)) {
24
+ fs.readdirSync(PUBLIC_DIR, { withFileTypes: true })
25
+ .filter(d => d.isDirectory() && d.name.startsWith(VERSION_PREFIX))
26
+ .forEach(d => {
27
+ const n = parseInt(d.name.replace(VERSION_PREFIX, ""), 10);
28
+ if (!isNaN(n) && n > max) max = n;
29
+ });
30
+ };
31
+
32
+ const nextVersion = `${VERSION_PREFIX}${max + 1}`;
33
+ console.log("Next Version:", nextVersion);
34
+
35
+ const versionPath = path.join(PUBLIC_DIR, nextVersion);
36
+ fs.mkdirSync(versionPath, { recursive: true });
37
+
38
+ /* ---------- STEP 2: CLONE COMMON REPO ---------- */
39
+ if (!fs.existsSync(COMMON_REPO_PATH)) {
40
+ console.log(`${COMMON_REPO} not found. Cloning...`);
41
+ run(`git clone ${COMMON_REPO_GIT} ${COMMON_REPO_PATH}`);
42
+ }
43
+
44
+ /* ---------- STEP 3: INSTALL DEPENDENCIES ---------- */
45
+ if (!fs.existsSync(path.join(COMMON_REPO_PATH, "node_modules"))) {
46
+ console.log("node_modules not found. Running npm install...");
47
+ run("npm install", COMMON_REPO_PATH);
48
+ }
49
+
50
+ /* ---------- STEP 4: COPY .env ---------- */
51
+ if (fs.existsSync(".env")) {
52
+ fs.copyFileSync(".env", path.join(COMMON_REPO_PATH, ".env"));
53
+ }
54
+
55
+ /* ---------- STEP 5: PROCESS SCHEMAS ---------- */
56
+ const uiJson = fs.readFileSync(SCHEMA_DIR);
57
+ const uiJsonParsed = JSON.parse(uiJson);
58
+
59
+ uiJsonParsed.Tables.forEach(schemaFile => {
60
+ const schemaName = path.parse(schemaFile).name;
61
+ console.log(`\nProcessing ${schemaFile}`);
62
+
63
+ /* Copy schema */
64
+ fs.copyFileSync(
65
+ path.join("Schemas", `${schemaFile}.json`),
66
+ path.join(COMMON_REPO_PATH, "schema.json")
67
+ );
68
+
69
+ /* Build */
70
+ run("npm run NonSec", COMMON_REPO_PATH);
71
+
72
+ /* Target dirs */
73
+ const targetDir = path.join(versionPath, schemaName);
74
+ const protectedDir = path.join(targetDir, "UnProtected");
75
+
76
+ fs.mkdirSync(protectedDir, { recursive: true });
77
+
78
+ /* Copy dist */
79
+ copyRecursive(
80
+ path.join(COMMON_REPO_PATH, "dist"),
81
+ protectedDir
82
+ );
83
+
84
+ /* Copy menu */
85
+ fs.copyFileSync(
86
+ path.join(COMMON_REPO_PATH, "Menu", "index.html"),
87
+ path.join(targetDir, "index.html")
88
+ );
89
+
90
+ console.log(`Done with ${schemaFile}`);
91
+ });
92
+
93
+ console.log("\n✔ All schemas processed successfully");
94
+
95
+ /* ---------- UTIL ---------- */
96
+ function copyRecursive(src, dest) {
97
+ fs.readdirSync(src, { withFileTypes: true }).forEach(entry => {
98
+ const srcPath = path.join(src, entry.name);
99
+ const destPath = path.join(dest, entry.name);
100
+
101
+ if (entry.isDirectory()) {
102
+ fs.mkdirSync(destPath, { recursive: true });
103
+ copyRecursive(srcPath, destPath);
104
+ } else {
105
+ fs.copyFileSync(srcPath, destPath);
106
+ }
107
+ });
108
+ };
@@ -0,0 +1,38 @@
1
+ import fs from "fs";
2
+
3
+ const PREFIX = "V";
4
+ const ENV_FILE = ".env";
5
+
6
+ /* -------- STEP 1: GET NEXT VERSION -------- */
7
+ const dirs = fs.readdirSync("./", { withFileTypes: true })
8
+ .filter(d => d.isDirectory() && d.name.startsWith(PREFIX));
9
+
10
+ let max = 0;
11
+
12
+ dirs.forEach(d => {
13
+ const num = parseInt(d.name.replace(PREFIX, ""), 10);
14
+ if (!isNaN(num) && num > max) max = num;
15
+ });
16
+
17
+ const latestVersion = `${PREFIX}${max}`;
18
+ console.log("Next Version:", latestVersion);
19
+
20
+ /* -------- STEP 2: UPDATE .env -------- */
21
+ let envContent = "";
22
+
23
+ if (fs.existsSync(ENV_FILE)) {
24
+ envContent = fs.readFileSync(ENV_FILE, "utf8")
25
+ .split("\n")
26
+ .map(line =>
27
+ line.startsWith("VERSION=")
28
+ ? `VERSION=${latestVersion}`
29
+ : line
30
+ )
31
+ .join("\n");
32
+ } else {
33
+ envContent = `VERSION=${latestVersion}\n`;
34
+ };
35
+
36
+ fs.writeFileSync(ENV_FILE, envContent);
37
+
38
+ console.log(".env updated successfully ✔");
@@ -0,0 +1,33 @@
1
+ import { kschema } from "@keshavsoft/kschema";
2
+ import consfigJson from './config.json' with { type: 'json' };
3
+
4
+ kschema.loadConfig(consfigJson);
5
+
6
+ import express from 'express';
7
+ import http from 'http';
8
+
9
+ const app = express();
10
+ const server = http.createServer(app);
11
+
12
+ var port = normalizePort(process.env.PORT || 3000);
13
+
14
+ app.use(express.static('Public'));
15
+
16
+ function normalizePort(val) {
17
+ var port = parseInt(val, 10);
18
+
19
+ if (isNaN(port)) {
20
+ return val;
21
+ }
22
+
23
+ if (port >= 0) {
24
+ return port;
25
+ }
26
+
27
+ return false;
28
+ };
29
+
30
+ server.listen(port, () => {
31
+ console.log(`Example app listening on port ${port}`);
32
+ console.log(`Open here http://localhost:${port}`);
33
+ });
@@ -0,0 +1,4 @@
1
+ {
2
+ "DataPath": "Data",
3
+ "SchemaPath": "Config/Schemas"
4
+ }
@@ -0,0 +1,18 @@
1
+ {
2
+ "name": "KeshavSoft",
3
+ "version": "1.7.1",
4
+ "description": "",
5
+ "main": "app.js",
6
+ "type": "module",
7
+ "scripts": {
8
+ "test": "echo \"Error: no test specified\" && exit 1",
9
+ "start": "node --env-file=.env app.js"
10
+ },
11
+ "author": "",
12
+ "license": "ISC",
13
+ "dependencies": {
14
+ "@keshavsoft/kschema": "^1.6.1",
15
+ "body-parser": "^2.2.0",
16
+ "express": "^5.1.0"
17
+ }
18
+ }
@@ -0,0 +1,36 @@
1
+ // commands/test.js
2
+
3
+ import fs from "fs";
4
+ import path from "path";
5
+
6
+ export default (arg) => {
7
+ const projectPath = arg
8
+ ? path.resolve(process.cwd(), arg)
9
+ : process.cwd();
10
+
11
+ // 1. Check folder exists
12
+ if (!fs.existsSync(projectPath)) {
13
+ console.log("Invalid path");
14
+ return;
15
+ }
16
+
17
+ // 2. Check required structure
18
+ const hasConfigJson = fs.existsSync(
19
+ path.join(projectPath, "config.json")
20
+ );
21
+
22
+ const hasConfigFolder = fs.existsSync(
23
+ path.join(projectPath, "Config")
24
+ );
25
+
26
+ const hasSchemasFolder = fs.existsSync(
27
+ path.join(projectPath, "Config", "Schemas")
28
+ );
29
+
30
+ // 3. Final decision
31
+ if (hasConfigJson && hasConfigFolder && hasSchemasFolder) {
32
+ console.log("Already initialized");
33
+ } else {
34
+ console.log("Not initialized");
35
+ }
36
+ };
@@ -0,0 +1,10 @@
1
+ export default function parseInput() {
2
+ const [cmd, ...args] = process.argv.slice(2);
3
+
4
+ return {
5
+ cmd: cmd || null,
6
+ args,
7
+ template: cmd || null,
8
+ folderName: args[0] || null,
9
+ };
10
+ };
@@ -0,0 +1,12 @@
1
+ import init from "../commands/init.js";
2
+ import test from "../commands/test.js";
3
+ // import generateSamples from "../commands/generateSamples.js";
4
+
5
+ const map = {
6
+ init,
7
+ test
8
+ };
9
+
10
+ export default function resolveCommand(cmd) {
11
+ return map[cmd] || null;
12
+ };
@@ -0,0 +1,17 @@
1
+ import fs from "fs";
2
+
3
+ export default function resolveFolderName({ name }) {
4
+ const defaultFolerName = `keshavsoft-basic-${Date.now()}`;
5
+
6
+ // case 1: force new → timestamp
7
+ if (name === null) {
8
+ name = defaultFolerName;
9
+ };
10
+
11
+ // case 2: user provided → strict
12
+ if (fs.existsSync(name)) {
13
+ throw new Error(`Folder already exists: ${name}`);
14
+ };
15
+
16
+ return name;
17
+ };
@@ -0,0 +1,23 @@
1
+ import parseInput from "./core/parseInput.js";
2
+ import resolveCommand from "./core/resolveCommand.js";
3
+
4
+ const run = async () => {
5
+ const input = parseInput();
6
+
7
+ if (!input.cmd) {
8
+ console.log("Usage: kschema <init|test> [args]");
9
+ return;
10
+ }
11
+
12
+ const command = resolveCommand(input.cmd);
13
+
14
+ if (!command) {
15
+ console.log(`Unknown command: ${input.cmd}`);
16
+ console.log("Usage: kschema <init|test> [args]");
17
+ return;
18
+ };
19
+
20
+ await command(input);
21
+ };
22
+
23
+ export default run;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@keshavsoft/kschema-cli",
3
- "version": "1.7.2",
3
+ "version": "1.8.1",
4
4
  "description": "CLI to scaffold projects using templates",
5
5
  "keywords": [
6
6
  "cli",
@@ -10,7 +10,7 @@
10
10
  "project-generator"
11
11
  ],
12
12
  "dependencies": {
13
- "@keshavsoft/kschema": "^1.12.3"
13
+ "@keshavsoft/kschema": "^1.16.1"
14
14
  },
15
15
  "type": "module",
16
16
  "bin": {
package/read.js ADDED
@@ -0,0 +1,29 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+
4
+ import { exampleSchema } from "@keshavsoft/kschema";
5
+ import { baseTemplate } from "./template/baseTemplate.js";
6
+
7
+ // console.log("aaaaaaaaa : ", exampleSchema);
8
+
9
+ const runQuery = () => {
10
+ const OUTPUT_DIR = path.resolve(process.cwd(), "samples");
11
+
12
+ if (!fs.existsSync(OUTPUT_DIR)) {
13
+ fs.mkdirSync(OUTPUT_DIR, { recursive: true });
14
+ };
15
+
16
+ Object.entries(exampleSchema).forEach(([intent, methods]) => {
17
+ Object.entries(methods).forEach(([key, meta]) => {
18
+
19
+ const finalCode = baseTemplate({ body: meta.body });
20
+
21
+ fs.writeFileSync(path.join(OUTPUT_DIR, `${intent}_${key}.js`), finalCode);
22
+
23
+ });
24
+
25
+ });
26
+
27
+ };
28
+
29
+ runQuery();