kschema-fs-api-gen-post-actions 1.6.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.
Files changed (192) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +323 -0
  3. package/bin/cli.js +12 -0
  4. package/bin/core/getLatestVersion.js +13 -0
  5. package/bin/core/loadRunner.js +9 -0
  6. package/bin/v5/core/createFolder.js +34 -0
  7. package/bin/v5/core/parseInput.js +9 -0
  8. package/bin/v5/core/resolveCommand.js +11 -0
  9. package/bin/v5/core/showUsage.js +49 -0
  10. package/bin/v5/start.js +22 -0
  11. package/bin/v5/tasks/actions/WithMail/actions.json +26 -0
  12. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/common/readFile.js +8 -0
  13. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/common/writeFile.js +10 -0
  14. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/buildImport.js +9 -0
  15. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/checkDuplicate.js +8 -0
  16. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/findInsertIndex.js +10 -0
  17. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/index.js +47 -0
  18. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/buildUseLine.js +5 -0
  19. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/checkDuplicate.js +9 -0
  20. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/findInsertIndex.js +10 -0
  21. package/bin/v5/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/index.js +56 -0
  22. package/bin/v5/tasks/actions/WithMail/steps/announce.js +9 -0
  23. package/bin/v5/tasks/actions/WithMail/steps/createFolder.js +7 -0
  24. package/bin/v5/tasks/actions/WithMail/steps/createHttpFile.js +12 -0
  25. package/bin/v5/tasks/actions/WithMail/steps/decideTemplate.js +3 -0
  26. package/bin/v5/tasks/actions/WithMail/steps/locateDestination.js +7 -0
  27. package/bin/v5/tasks/actions/WithMail/steps/locateSource.js +18 -0
  28. package/bin/v5/tasks/actions/WithMail/steps/resolveFolderName.js +20 -0
  29. package/bin/v5/tasks/actions/WithMail/steps/updateAppJs.js +7 -0
  30. package/bin/v5/tasks/actions/WithMail/steps/updateEndPointsFile.js +30 -0
  31. package/bin/v5/tasks/actions/WithMail/steps/updateEndPointsJs.js +16 -0
  32. package/bin/v5/tasks/actions/WithMail/template/v1/controller.js +28 -0
  33. package/bin/v5/tasks/actions/WithMail/template/v1/errors.js +11 -0
  34. package/bin/v5/tasks/actions/WithMail/template/v1/middleware.js +19 -0
  35. package/bin/v5/tasks/actions/WithMail/template/v1/service.js +44 -0
  36. package/bin/v5/tasks/actions/WithMail/template/v2/Mail/sendMailCC.js +45 -0
  37. package/bin/v5/tasks/actions/WithMail/template/v2/Mail/welcome.html +213 -0
  38. package/bin/v5/tasks/actions/WithMail/template/v2/controller.js +24 -0
  39. package/bin/v5/tasks/actions/WithMail/template/v2/errors.js +11 -0
  40. package/bin/v5/tasks/actions/WithMail/template/v2/middleware.js +19 -0
  41. package/bin/v5/tasks/actions/WithMail/template/v2/rest.http +7 -0
  42. package/bin/v5/tasks/actions/WithMail/template/v2/service.js +18 -0
  43. package/bin/v5/tasks/actions/WithMail/template/v3/Mail/sendMailCC.js +45 -0
  44. package/bin/v5/tasks/actions/WithMail/template/v3/Mail/welcome.html +213 -0
  45. package/bin/v5/tasks/actions/WithMail/template/v3/config/getSchema.js +20 -0
  46. package/bin/v5/tasks/actions/WithMail/template/v3/controller.js +27 -0
  47. package/bin/v5/tasks/actions/WithMail/template/v3/errors.js +11 -0
  48. package/bin/v5/tasks/actions/WithMail/template/v3/getData.js +11 -0
  49. package/bin/v5/tasks/actions/WithMail/template/v3/getSchema.js +11 -0
  50. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/buildMutate.js +32 -0
  51. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/buildQuery.js +32 -0
  52. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/file/read.js +7 -0
  53. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/file/write.js +5 -0
  54. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/pkHelper.js +19 -0
  55. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validate.js +27 -0
  56. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validateHelper.js +27 -0
  57. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/default.js +5 -0
  58. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/enum.js +7 -0
  59. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/length.js +11 -0
  60. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/minMax.js +11 -0
  61. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/pattern.js +8 -0
  62. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/required.js +5 -0
  63. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/type.js +15 -0
  64. package/bin/v5/tasks/actions/WithMail/template/v3/helpers/validators/unique.js +8 -0
  65. package/bin/v5/tasks/actions/WithMail/template/v3/insertBase.js +9 -0
  66. package/bin/v5/tasks/actions/WithMail/template/v3/insertGenPk.js +31 -0
  67. package/bin/v5/tasks/actions/WithMail/template/v3/middleware.js +19 -0
  68. package/bin/v5/tasks/actions/WithMail/template/v3/rest.http +7 -0
  69. package/bin/v5/tasks/actions/WithMail/template/v3/service.js +16 -0
  70. package/bin/v5/tasks/actions/withMail.js +60 -0
  71. package/bin/v5/tasks/core/createFolder.js +34 -0
  72. package/bin/v5/tasks/core/parseInput.js +12 -0
  73. package/bin/v5/tasks/core/resolveCommand.js +24 -0
  74. package/bin/v5/tasks/core/showUsage.js +43 -0
  75. package/bin/v6/core/createFolder.js +34 -0
  76. package/bin/v6/core/parseInput.js +9 -0
  77. package/bin/v6/core/resolveCommand.js +11 -0
  78. package/bin/v6/core/showUsage.js +49 -0
  79. package/bin/v6/start.js +22 -0
  80. package/bin/v6/tasks/actions/InsertGenPk/actions.json +26 -0
  81. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/common/readFile.js +8 -0
  82. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/common/writeFile.js +10 -0
  83. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateImports/buildImport.js +9 -0
  84. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateImports/checkDuplicate.js +8 -0
  85. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateImports/findInsertIndex.js +10 -0
  86. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateImports/index.js +47 -0
  87. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateUse/buildUseLine.js +5 -0
  88. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateUse/checkDuplicate.js +9 -0
  89. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateUse/findInsertIndex.js +10 -0
  90. package/bin/v6/tasks/actions/InsertGenPk/steps/UpdateRoutesJs/updateUse/index.js +56 -0
  91. package/bin/v6/tasks/actions/InsertGenPk/steps/announce.js +9 -0
  92. package/bin/v6/tasks/actions/InsertGenPk/steps/createFolder.js +7 -0
  93. package/bin/v6/tasks/actions/InsertGenPk/steps/createHttpFile.js +12 -0
  94. package/bin/v6/tasks/actions/InsertGenPk/steps/decideTemplate.js +3 -0
  95. package/bin/v6/tasks/actions/InsertGenPk/steps/locateDestination.js +7 -0
  96. package/bin/v6/tasks/actions/InsertGenPk/steps/locateSource.js +18 -0
  97. package/bin/v6/tasks/actions/InsertGenPk/steps/resolveFolderName.js +20 -0
  98. package/bin/v6/tasks/actions/InsertGenPk/steps/updateAppJs.js +7 -0
  99. package/bin/v6/tasks/actions/InsertGenPk/steps/updateEndPointsFile.js +30 -0
  100. package/bin/v6/tasks/actions/InsertGenPk/steps/updateEndPointsJs.js +16 -0
  101. package/bin/v6/tasks/actions/InsertGenPk/template/v1/config/getSchema.js +20 -0
  102. package/bin/v6/tasks/actions/InsertGenPk/template/v1/controller.js +27 -0
  103. package/bin/v6/tasks/actions/InsertGenPk/template/v1/errors.js +11 -0
  104. package/bin/v6/tasks/actions/InsertGenPk/template/v1/getData.js +11 -0
  105. package/bin/v6/tasks/actions/InsertGenPk/template/v1/getSchema.js +11 -0
  106. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/buildMutate.js +32 -0
  107. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/buildQuery.js +32 -0
  108. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/file/read.js +7 -0
  109. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/file/write.js +5 -0
  110. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/pkHelper.js +19 -0
  111. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validate.js +27 -0
  112. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validateHelper.js +27 -0
  113. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/default.js +5 -0
  114. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/enum.js +7 -0
  115. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/length.js +11 -0
  116. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/minMax.js +11 -0
  117. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/pattern.js +8 -0
  118. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/required.js +5 -0
  119. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/type.js +15 -0
  120. package/bin/v6/tasks/actions/InsertGenPk/template/v1/helpers/validators/unique.js +8 -0
  121. package/bin/v6/tasks/actions/InsertGenPk/template/v1/insertBase.js +9 -0
  122. package/bin/v6/tasks/actions/InsertGenPk/template/v1/insertGenPk.js +31 -0
  123. package/bin/v6/tasks/actions/InsertGenPk/template/v1/middleware.js +19 -0
  124. package/bin/v6/tasks/actions/InsertGenPk/template/v1/rest.http +7 -0
  125. package/bin/v6/tasks/actions/InsertGenPk/template/v1/service.js +16 -0
  126. package/bin/v6/tasks/actions/WithMail/actions.json +26 -0
  127. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/common/readFile.js +8 -0
  128. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/common/writeFile.js +10 -0
  129. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/buildImport.js +9 -0
  130. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/checkDuplicate.js +8 -0
  131. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/findInsertIndex.js +10 -0
  132. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateImports/index.js +47 -0
  133. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/buildUseLine.js +5 -0
  134. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/checkDuplicate.js +9 -0
  135. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/findInsertIndex.js +10 -0
  136. package/bin/v6/tasks/actions/WithMail/steps/UpdateRoutesJs/updateUse/index.js +56 -0
  137. package/bin/v6/tasks/actions/WithMail/steps/announce.js +9 -0
  138. package/bin/v6/tasks/actions/WithMail/steps/createFolder.js +7 -0
  139. package/bin/v6/tasks/actions/WithMail/steps/createHttpFile.js +12 -0
  140. package/bin/v6/tasks/actions/WithMail/steps/decideTemplate.js +3 -0
  141. package/bin/v6/tasks/actions/WithMail/steps/locateDestination.js +7 -0
  142. package/bin/v6/tasks/actions/WithMail/steps/locateSource.js +18 -0
  143. package/bin/v6/tasks/actions/WithMail/steps/resolveFolderName.js +20 -0
  144. package/bin/v6/tasks/actions/WithMail/steps/updateAppJs.js +7 -0
  145. package/bin/v6/tasks/actions/WithMail/steps/updateEndPointsFile.js +30 -0
  146. package/bin/v6/tasks/actions/WithMail/steps/updateEndPointsJs.js +16 -0
  147. package/bin/v6/tasks/actions/WithMail/template/v1/controller.js +28 -0
  148. package/bin/v6/tasks/actions/WithMail/template/v1/errors.js +11 -0
  149. package/bin/v6/tasks/actions/WithMail/template/v1/middleware.js +19 -0
  150. package/bin/v6/tasks/actions/WithMail/template/v1/service.js +44 -0
  151. package/bin/v6/tasks/actions/WithMail/template/v2/Mail/sendMailCC.js +45 -0
  152. package/bin/v6/tasks/actions/WithMail/template/v2/Mail/welcome.html +213 -0
  153. package/bin/v6/tasks/actions/WithMail/template/v2/controller.js +24 -0
  154. package/bin/v6/tasks/actions/WithMail/template/v2/errors.js +11 -0
  155. package/bin/v6/tasks/actions/WithMail/template/v2/middleware.js +19 -0
  156. package/bin/v6/tasks/actions/WithMail/template/v2/rest.http +7 -0
  157. package/bin/v6/tasks/actions/WithMail/template/v2/service.js +18 -0
  158. package/bin/v6/tasks/actions/WithMail/template/v3/Mail/sendMailCC.js +45 -0
  159. package/bin/v6/tasks/actions/WithMail/template/v3/Mail/welcome.html +213 -0
  160. package/bin/v6/tasks/actions/WithMail/template/v3/config/getSchema.js +20 -0
  161. package/bin/v6/tasks/actions/WithMail/template/v3/controller.js +27 -0
  162. package/bin/v6/tasks/actions/WithMail/template/v3/errors.js +11 -0
  163. package/bin/v6/tasks/actions/WithMail/template/v3/getData.js +11 -0
  164. package/bin/v6/tasks/actions/WithMail/template/v3/getSchema.js +11 -0
  165. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/buildMutate.js +32 -0
  166. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/buildQuery.js +32 -0
  167. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/file/read.js +7 -0
  168. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/file/write.js +5 -0
  169. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/pkHelper.js +19 -0
  170. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validate.js +27 -0
  171. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validateHelper.js +27 -0
  172. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/default.js +5 -0
  173. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/enum.js +7 -0
  174. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/length.js +11 -0
  175. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/minMax.js +11 -0
  176. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/pattern.js +8 -0
  177. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/required.js +5 -0
  178. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/type.js +15 -0
  179. package/bin/v6/tasks/actions/WithMail/template/v3/helpers/validators/unique.js +8 -0
  180. package/bin/v6/tasks/actions/WithMail/template/v3/insertBase.js +9 -0
  181. package/bin/v6/tasks/actions/WithMail/template/v3/insertGenPk.js +31 -0
  182. package/bin/v6/tasks/actions/WithMail/template/v3/middleware.js +19 -0
  183. package/bin/v6/tasks/actions/WithMail/template/v3/rest.http +7 -0
  184. package/bin/v6/tasks/actions/WithMail/template/v3/service.js +16 -0
  185. package/bin/v6/tasks/actions/insertGenPk.js +68 -0
  186. package/bin/v6/tasks/actions/withMail.js +60 -0
  187. package/bin/v6/tasks/core/createFolder.js +34 -0
  188. package/bin/v6/tasks/core/parseInput.js +12 -0
  189. package/bin/v6/tasks/core/resolveCommand.js +24 -0
  190. package/bin/v6/tasks/core/showUsage.js +43 -0
  191. package/index.js +34 -0
  192. package/package.json +37 -0
@@ -0,0 +1,16 @@
1
+ import updateImports from "./UpdateRoutesJs/updateImports/index.js";
2
+ import updateAppUse from "./UpdateRoutesJs/updateUse/index.js";
3
+
4
+ const funcName = "getFunc";
5
+
6
+ export default ({ appJsPath, endpoint }) => {
7
+ updateImports({
8
+ appJsPath, endpoint,
9
+ inFuncName: funcName
10
+ });
11
+
12
+ updateAppUse({
13
+ appJsPath, endpoint,
14
+ inFuncName: funcName
15
+ });
16
+ };
@@ -0,0 +1,20 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+ import { getConfig } from "../../core/configStore.js";
4
+
5
+ export const getSchema = (table) => {
6
+ const config = getConfig();
7
+
8
+ const schemaPath = path.join(config.SchemaPath, `${table}.json`);
9
+
10
+ if (!fs.existsSync(schemaPath)) {
11
+ throw new Error(`Schema not found for table "${table}" at ${schemaPath}`);
12
+ }
13
+
14
+ try {
15
+ const schema = fs.readFileSync(schemaPath, "utf-8");
16
+ return JSON.parse(schema);
17
+ } catch (err) {
18
+ throw new Error(`Invalid schema JSON for "${table}": ${err.message}`);
19
+ };
20
+ };
@@ -0,0 +1,27 @@
1
+ import { startFunc as Service } from "./service.js";
2
+ import { ConflictError, StorageError } from "./errors.js";
3
+
4
+ const postFunc = async ({ req, res, inTablePath, inConfigPath }) => {
5
+ try {
6
+ const inRequestBody = req.body;
7
+
8
+ const fromService = await Service({
9
+ inRequestBody, inTablePath,
10
+ inConfigPath
11
+ });
12
+
13
+ res.type("application/json").send(fromService);
14
+ } catch (err) {
15
+
16
+ if (err instanceof ConflictError)
17
+ return res.status(409).send(err.message);
18
+
19
+ if (err instanceof StorageError)
20
+ return res.status(500).send("Failed to persist data");
21
+
22
+ console.error(err);
23
+ res.status(500).send("Unexpected error");
24
+ }
25
+ };
26
+
27
+ export default postFunc;
@@ -0,0 +1,11 @@
1
+ class AppError extends Error {
2
+ constructor(message) {
3
+ super(message);
4
+ this.name = this.constructor.name;
5
+ }
6
+ }
7
+
8
+ class ConflictError extends AppError { }
9
+ class StorageError extends AppError { }
10
+
11
+ export { AppError, ConflictError, StorageError };
@@ -0,0 +1,11 @@
1
+ import { JSONFilePreset } from 'lowdb/node'
2
+
3
+ const startFunc = async ({ inTablePath }) => {
4
+ const db = await JSONFilePreset(inTablePath, []);
5
+
6
+ await db.read();
7
+
8
+ return await db.data;
9
+ };
10
+
11
+ export default startFunc;
@@ -0,0 +1,11 @@
1
+ import { JSONFilePreset } from 'lowdb/node'
2
+
3
+ const startFunc = async ({ inConfigPath }) => {
4
+ const db = await JSONFilePreset(inConfigPath, {});
5
+
6
+ await db.read();
7
+
8
+ return await db.data;
9
+ };
10
+
11
+ export default startFunc;
@@ -0,0 +1,32 @@
1
+ const insertAsIs = (mutate, tableName) => (record) =>
2
+ mutate.insertAsIs({ table: tableName, record });
3
+
4
+ const insertFlat = (mutate, tableName) => (record) =>
5
+ mutate.insertFlat({ table: tableName, record });
6
+
7
+ const insertGenPk = (mutate, tableName) => (record) =>
8
+ mutate.insertGenPk({ table: tableName, record });
9
+
10
+ const insertWithChecks = (mutate, tableName) => (record) =>
11
+ mutate.insertWithChecks({ table: tableName, record });
12
+
13
+ const deleteWithChecks = (mutate, tableName) => (pk) =>
14
+ mutate.deleteWithChecks({ table: tableName, pk });
15
+
16
+ const deleteWhere = (mutate, tableName) => (where) =>
17
+ mutate.deleteWhere({ table: tableName, where });
18
+
19
+ const updateWithChecks = (mutate, tableName) => (pk, record) =>
20
+ mutate.updateWithChecks({ table: tableName, pk, record });
21
+
22
+ const buildMutate = (mutate, tableName) => ({
23
+ insertAsIs: insertAsIs(mutate, tableName),
24
+ insertFlat: insertFlat(mutate, tableName),
25
+ insertGenPk: insertGenPk(mutate, tableName),
26
+ insertWithChecks: insertWithChecks(mutate, tableName),
27
+ deleteWithChecks: deleteWithChecks(mutate, tableName),
28
+ deleteWhere: deleteWhere(mutate, tableName),
29
+ updateWithChecks: updateWithChecks(mutate, tableName)
30
+ });
31
+
32
+ export default buildMutate;
@@ -0,0 +1,32 @@
1
+ import * as aggregate from "../engine/query/aggregate/index.js";
2
+
3
+ const findAll = (query, tableName) => () =>
4
+ query.findAll({ table: tableName });
5
+
6
+ const findByPk = (query, tableName) => (id) =>
7
+ query.findByPk({ table: tableName, id });
8
+
9
+ const filterByPk = (query, tableName) => (id) =>
10
+ query.filterByPk({ table: tableName, id });
11
+
12
+ const filterByColumns = (query, tableName) => (where) =>
13
+ query.filterByColumns({ table: tableName, where });
14
+
15
+ const buildQuery = (query, tableName) => ({
16
+ findAll: findAll(query, tableName),
17
+ findByPk: findByPk(query, tableName),
18
+ filterByPk: filterByPk(query, tableName),
19
+ filterByColumns: filterByColumns(query, tableName),
20
+
21
+ aggregate: {
22
+ count: () =>
23
+ query.aggregate.count({ table: tableName }),
24
+ distinct: (column) =>
25
+ query.aggregate.distinct({
26
+ table: tableName,
27
+ column
28
+ })
29
+ }
30
+ });
31
+
32
+ export default buildQuery;
@@ -0,0 +1,7 @@
1
+ import fs from "fs";
2
+
3
+ export const readData = (path) => {
4
+ if (!fs.existsSync(path)) return [];
5
+
6
+ return JSON.parse(fs.readFileSync(path, "utf-8"));
7
+ };
@@ -0,0 +1,5 @@
1
+ import fs from "fs";
2
+
3
+ export const writeData = (path, data) => {
4
+ fs.writeFileSync(path, JSON.stringify(data, null, 2));
5
+ };
@@ -0,0 +1,19 @@
1
+ export const getPrimaryKey = (columns) => {
2
+ const pkColumn = columns.find(c => c.primary);
3
+ if (!pkColumn) throw new Error("Primary key not defined");
4
+ return pkColumn.field;
5
+ };
6
+
7
+ export const attachPrimaryKey = (record, pk, data) => {
8
+ let maxId = 0;
9
+
10
+ for (const row of data) {
11
+ const val = Number(row[pk]) || 0;
12
+ if (val > maxId) maxId = val;
13
+ }
14
+
15
+ return {
16
+ ...record,
17
+ [pk]: maxId + 1
18
+ };
19
+ };
@@ -0,0 +1,27 @@
1
+ import required from "./validators/required.js";
2
+ import type from "./validators/type.js";
3
+ import minMax from "./validators/minMax.js";
4
+ import length from "./validators/length.js";
5
+ import enumCheck from "./validators/enum.js";
6
+ import pattern from "./validators/pattern.js";
7
+ import setDefault from "./validators/default.js";
8
+
9
+ const validators = [required, type, minMax, length, enumCheck, pattern];
10
+
11
+ const validate = (schema, record) => {
12
+ if (!schema?.columns) throw new Error("Invalid schema");
13
+
14
+ for (const col of schema.columns) {
15
+ if (!col.isConsider) continue;
16
+
17
+ setDefault(col, record); // 🔥 mutate first
18
+
19
+ const value = record[col.field];
20
+
21
+ for (const fn of validators) {
22
+ fn(col, value, record);
23
+ }
24
+ }
25
+ };
26
+
27
+ export default validate;
@@ -0,0 +1,27 @@
1
+ export const validateRecord = (record, columns, data) => {
2
+ columns.forEach(col => {
3
+ const value = record[col.field];
4
+
5
+ if (col.required && (value === undefined || value === null || value === "")) {
6
+ throw new Error(`${col.field} is required`);
7
+ }
8
+
9
+ if (value === undefined) return;
10
+
11
+ if (col.unique && data.some(r => r[col.field] === value)) {
12
+ throw new Error(`${col.field} must be unique`);
13
+ }
14
+ });
15
+ };
16
+
17
+ export const validateFilterKeys = (filter, columns) => {
18
+ const validColumns = columns.map(col => col.field);
19
+
20
+ const invalidKeys = Object.keys(filter).filter(
21
+ key => !validColumns.includes(key)
22
+ );
23
+
24
+ if (invalidKeys.length > 0) {
25
+ throw new Error(`Invalid columns: ${invalidKeys.join(", ")}`);
26
+ };
27
+ };
@@ -0,0 +1,5 @@
1
+ export default (col, record) => {
2
+ if (record[col.field] == null && col.defaultValue !== undefined) {
3
+ record[col.field] = col.defaultValue;
4
+ }
5
+ };
@@ -0,0 +1,7 @@
1
+ export default (col, value) => {
2
+ if (value == null || !col.enum) return;
3
+
4
+ if (!col.enum.includes(value)) {
5
+ throw new Error(`${col.field} must be one of ${col.enum.join(", ")}`);
6
+ }
7
+ };
@@ -0,0 +1,11 @@
1
+ export default (col, value) => {
2
+ if (value == null || typeof value !== "string") return;
3
+
4
+ if (col.minLength != null && value.length < col.minLength) {
5
+ throw new Error(`${col.field} min length ${col.minLength}`);
6
+ }
7
+
8
+ if (col.maxLength != null && value.length > col.maxLength) {
9
+ throw new Error(`${col.field} max length ${col.maxLength}`);
10
+ }
11
+ };
@@ -0,0 +1,11 @@
1
+ export default (col, value) => {
2
+ if (value == null) return;
3
+
4
+ if (col.min != null && value < col.min) {
5
+ throw new Error(`${col.field} must be >= ${col.min}`);
6
+ }
7
+
8
+ if (col.max != null && value > col.max) {
9
+ throw new Error(`${col.field} must be <= ${col.max}`);
10
+ }
11
+ };
@@ -0,0 +1,8 @@
1
+ export default (col, value) => {
2
+ if (value == null || !col.pattern) return;
3
+
4
+ const regex = new RegExp(col.pattern);
5
+ if (!regex.test(value)) {
6
+ throw new Error(`${col.field} format invalid`);
7
+ }
8
+ };
@@ -0,0 +1,5 @@
1
+ export default (col, value) => {
2
+ if ((col.isInput || col.primary) && (value === undefined || value === null || value === "")) {
3
+ throw new Error(`${col.field} is required`);
4
+ }
5
+ };
@@ -0,0 +1,15 @@
1
+ export default (col, value) => {
2
+ if (value == null) return;
3
+
4
+ if (col.type === "text" && typeof value !== "string") {
5
+ throw new Error(`${col.field} must be string`);
6
+ }
7
+
8
+ if (col.type === "number" && typeof value !== "number") {
9
+ throw new Error(`${col.field} must be number`);
10
+ }
11
+
12
+ if (col.type === "boolean" && typeof value !== "boolean") {
13
+ throw new Error(`${col.field} must be boolean`);
14
+ }
15
+ };
@@ -0,0 +1,8 @@
1
+ export default (col, value, tableData) => {
2
+ if (!col.unique || value == null) return;
3
+
4
+ const exists = tableData?.some(r => r[col.field] === value);
5
+ if (exists) {
6
+ throw new Error(`${col.field} must be unique`);
7
+ }
8
+ };
@@ -0,0 +1,9 @@
1
+ import { JSONFilePreset } from 'lowdb/node'
2
+
3
+ const insertBase = async ({ inRequestBody, inTablePath }) => {
4
+ const db = await JSONFilePreset(inTablePath, []);
5
+
6
+ await db.update((posts) => posts.push(inRequestBody))
7
+ };
8
+
9
+ export default insertBase;
@@ -0,0 +1,31 @@
1
+ import insertBase from "./insertBase.js";
2
+ import getData from "./getData.js";
3
+ import getSchema from "./getSchema.js";
4
+ import { getPrimaryKey, attachPrimaryKey } from "./helpers/pkHelper.js";
5
+
6
+ const validateInput = ({ record }) => {
7
+ if (!record || typeof record !== "object") throw new Error("record must be object");
8
+ };
9
+
10
+ const insertGenPk = async ({ inRequestBody, inTablePath, inConfigPath }) => {
11
+ validateInput({ record: inRequestBody });
12
+
13
+ const schema = await getSchema({ inConfigPath });
14
+ const pk = getPrimaryKey(schema.columnsConfig);
15
+
16
+ if (inRequestBody[pk] !== undefined) {
17
+ return insertBase({ inRequestBody, inTablePath });
18
+ };
19
+
20
+ const data = await getData({ inTablePath });
21
+ const newRecord = attachPrimaryKey(inRequestBody, pk, data);
22
+
23
+ await insertBase({
24
+ inRequestBody: newRecord,
25
+ inTablePath
26
+ });
27
+
28
+ return newRecord[pk];
29
+ };
30
+
31
+ export default insertGenPk;
@@ -0,0 +1,19 @@
1
+ const StartFunc = (req, res, next) => {
2
+ const LocalBody = req.body;
3
+
4
+ if (!LocalBody || Object.keys(LocalBody).length === 0) {
5
+ return res.status(400).send("Request body should not be empty.");
6
+ }
7
+
8
+ if (Array.isArray(LocalBody)) {
9
+ return res.status(400).send("Remove The Array From The Body.");
10
+ }
11
+
12
+ if (typeof LocalBody === 'object' && Object.keys(LocalBody).length === 0) {
13
+ return res.status(400).send("Request body should not be an empty object.");
14
+ }
15
+
16
+ next();
17
+ };
18
+
19
+ export { StartFunc };
@@ -0,0 +1,7 @@
1
+
2
+ POST http://localhost:3001/Api/v1/StockItems/WithMail
3
+ Content-Type: application/json
4
+
5
+ {
6
+ "StockItemName":"Rope 1 kg"
7
+ }
@@ -0,0 +1,16 @@
1
+ import insertGenPk from "./insertGenPk.js";
2
+ import sendMail from "./Mail/sendMailCC.js";
3
+
4
+ const startFunc = async ({ inRequestBody, inTablePath, inConfigPath }) => {
5
+ const insertedPk = await insertGenPk({ inRequestBody, inTablePath, inConfigPath });
6
+
7
+ const info = await sendMail();
8
+
9
+ return await {
10
+ insertedPk,
11
+ isMailSent: info.accepted.length > 0 &&
12
+ info.rejected.length === 0
13
+ };
14
+ };
15
+
16
+ export { startFunc };
@@ -0,0 +1,26 @@
1
+ {
2
+ "cmd": "WithMail",
3
+ "file": "withMail",
4
+ "exportFile": "WithMail",
5
+ "group": "PostMethods",
6
+ "description": "Generate WithMail POST action",
7
+ "endPointsJs": {
8
+ "importLines": {
9
+ "toInsertLine": "import funcFromWithMail from './WithMail/controller.js';",
10
+ "duplicationCheck": "from './WithMail/controller.js'",
11
+ "insertAfter": [
12
+ "import funcFrom",
13
+ "import express"
14
+ ]
15
+ },
16
+ "useLines": {
17
+ "toInsertLine1": "router.get('/WithMail', (req, res) => funcFromWithMail({ res, inTablePath: tablePath }));",
18
+ "toInsertLine": "router.post('/WithMail', express.json(), (req, res) => funcFromWithMail({ req, res, inTablePath: tablePath, inConfigPath: configPath }));",
19
+ "duplicationCheck": "router.use('/WithMail'",
20
+ "insertAfter": [
21
+ "router.",
22
+ "const router = "
23
+ ]
24
+ }
25
+ }
26
+ }
@@ -0,0 +1,8 @@
1
+ import fs from "fs";
2
+
3
+ const readFile = (inAppJsPath) => {
4
+ const localPath = inAppJsPath;
5
+ return fs.readFileSync(localPath, "utf-8");
6
+ };
7
+
8
+ export default readFile;
@@ -0,0 +1,10 @@
1
+ import fs from "fs";
2
+
3
+ const writeFile = (inAppJsPath, inContent) => {
4
+ const localPath = inAppJsPath;
5
+ const localContent = inContent;
6
+
7
+ fs.writeFileSync(localPath, localContent);
8
+ };
9
+
10
+ export default writeFile;
@@ -0,0 +1,9 @@
1
+ const buildImport = ({ inFuncName, inEndpoint }) => {
2
+ const localEndpoint = inEndpoint;
3
+
4
+ const safeName = localEndpoint.replace(/[^a-zA-Z0-9]/g, "_");
5
+
6
+ return `import { ${inFuncName} } from "./${localEndpoint}/controller.js";`;
7
+ };
8
+
9
+ export default buildImport;
@@ -0,0 +1,8 @@
1
+ const checkUseDuplicate = ({ inContent, inFuncName }) => {
2
+ const localContent = inContent;
3
+ const toCheckLine = `import { ${inFuncName} } from`;
4
+
5
+ return localContent.includes(toCheckLine);
6
+ };
7
+
8
+ export default checkUseDuplicate;
@@ -0,0 +1,10 @@
1
+ const findInsertIndex = (inContent) => {
2
+ const localContent = inContent;
3
+
4
+ const matches = [...localContent.matchAll(/^\s*import.*$/gm)];
5
+ const last = matches.at(-1);
6
+
7
+ return last ? last.index + last[0].length : 0;
8
+ };
9
+
10
+ export default findInsertIndex;
@@ -0,0 +1,47 @@
1
+ import readFile from "../common/readFile.js";
2
+ import buildImport from "./buildImport.js";
3
+ import checkDuplicate from "./checkDuplicate.js";
4
+ import findInsertIndex from "./findInsertIndex.js";
5
+ import writeFile from "../common/writeFile.js";
6
+
7
+ const updateImports = ({ appJsPath, endpoint, showLog, inFuncName }) => {
8
+ const summary = {
9
+ import: { added: false, line: null },
10
+ };
11
+
12
+ const content = readFile(appJsPath);
13
+
14
+ const importLine = buildImport({
15
+ inEndpoint: endpoint,
16
+ inFuncName
17
+ });
18
+
19
+ const fromCheckDuplicate = checkDuplicate({ inContent: content, inFuncName });
20
+
21
+ if (fromCheckDuplicate) {
22
+ summary.import.skipped = true;
23
+
24
+ if (showLog) console.log(summary);
25
+
26
+ return summary;
27
+ };
28
+
29
+ const index = findInsertIndex(content);
30
+
31
+ const before = content.slice(0, index);
32
+ const lineNumber = before.split("\n").length + 1;
33
+
34
+ const updated =
35
+ before + "\n" + importLine + content.slice(index);
36
+
37
+ writeFile(appJsPath, updated);
38
+
39
+ summary.import.added = true;
40
+ summary.import.line = lineNumber;
41
+
42
+ if (showLog) console.log(summary);
43
+
44
+ return summary;
45
+ };
46
+
47
+ export default updateImports;
@@ -0,0 +1,5 @@
1
+ const buildUseLine = ({ inAppOrRouter, inEndpoint, inFuncName }) => {
2
+ return `${inAppOrRouter}.get('/${inEndpoint}', (req, res) => ${inFuncName}({ res, inTableName : tableName}));`;
3
+ };
4
+
5
+ export default buildUseLine;
@@ -0,0 +1,9 @@
1
+ const checkDuplicate = ({ inContent, inEndpoint, inAppOrRouter }) => {
2
+ const localContent = inContent;
3
+ const localEndpoint = inEndpoint;
4
+ const stringToSearch = `${inAppOrRouter}.get('/${localEndpoint}'`;
5
+
6
+ return localContent.includes(stringToSearch);
7
+ };
8
+
9
+ export default checkDuplicate;
@@ -0,0 +1,10 @@
1
+ const findUseInsertIndex = (inContent) => {
2
+ const localContent = inContent;
3
+
4
+ const matches = [...localContent.matchAll(/const\s+router\s*=\s*express\.Router\(\)/g)];
5
+ const match = matches.at(0);
6
+
7
+ return match ? match.index + match[0].length : localContent.length;
8
+ };
9
+
10
+ export default findUseInsertIndex;
@@ -0,0 +1,56 @@
1
+ import readFile from "../common/readFile.js";
2
+ import writeFile from "../common/writeFile.js";
3
+
4
+ import buildUseLine from "./buildUseLine.js";
5
+ import checkDuplicate from "./checkDuplicate.js";
6
+ import findUseInsertIndex from "./findInsertIndex.js";
7
+
8
+ const appOrRouter = "router";
9
+
10
+ const updateAppUse = ({ appJsPath, endpoint, showLog, inFuncName }) => {
11
+ const summary = {
12
+ use: { added: false, skipped: false, line: null }
13
+ };
14
+
15
+ const content = readFile(appJsPath);
16
+
17
+ const useLine = buildUseLine({
18
+ inAppOrRouter: appOrRouter,
19
+ inEndpoint: endpoint,
20
+ inFuncName
21
+ });
22
+
23
+ const fromCheckDuplicate = checkDuplicate({
24
+ inContent: content,
25
+ inEndpoint: endpoint,
26
+ inAppOrRouter: appOrRouter
27
+ });
28
+ console.log("fromCheckDuplicate : ", fromCheckDuplicate);
29
+
30
+ if (fromCheckDuplicate) {
31
+ summary.use.skipped = true;
32
+
33
+ if (showLog) console.log(summary);
34
+
35
+ return summary;
36
+ };
37
+
38
+ const index = findUseInsertIndex(content);
39
+
40
+ const before = content.slice(0, index);
41
+ const lineNumber = before.split("\n").length + 1;
42
+
43
+ const updated =
44
+ before + "\n" + useLine + content.slice(index);
45
+
46
+ writeFile(appJsPath, updated);
47
+
48
+ summary.use.added = true;
49
+ summary.use.line = lineNumber;
50
+
51
+ if (showLog) console.log(summary);
52
+
53
+ return summary;
54
+ };
55
+
56
+ export default updateAppUse;
@@ -0,0 +1,9 @@
1
+ export const announce = ({ inResolvedFolderName }) => {
2
+ console.log(`[keshavsoft] Folder created: ${inResolvedFolderName}`);
3
+
4
+ console.log("");
5
+ console.log("Next:");
6
+ console.log("");
7
+ console.log(`cd ${inResolvedFolderName}`);
8
+ console.log(`npx kschema-api-gen AddSubRoute`);
9
+ };