@syngrisi/syngrisi 2.2.2 → 2.2.6-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (613) hide show
  1. package/README.md +49 -27
  2. package/dist/server/api-docs/openAPIDocumentGenerator.js +6489 -0
  3. package/dist/server/api-docs/openAPIDocumentGenerator.js.map +1 -0
  4. package/dist/server/api-docs/openAPIResponseBuilders.js +89 -0
  5. package/dist/server/api-docs/openAPIResponseBuilders.js.map +1 -0
  6. package/dist/server/api-docs/openAPIRouter.js +6505 -0
  7. package/dist/server/api-docs/openAPIRouter.js.map +1 -0
  8. package/dist/server/api-docs/serviceResponse.js +39 -0
  9. package/dist/server/api-docs/serviceResponse.js.map +1 -0
  10. package/dist/server/app.js +6751 -0
  11. package/dist/server/app.js.map +1 -0
  12. package/dist/server/config.js +1055 -0
  13. package/dist/server/config.js.map +1 -0
  14. package/dist/server/controllers/app.controller.js +1949 -0
  15. package/dist/server/controllers/app.controller.js.map +1 -0
  16. package/dist/server/controllers/auth.controller.js +2079 -0
  17. package/dist/server/controllers/auth.controller.js.map +1 -0
  18. package/dist/server/controllers/baseline.controller.js +1976 -0
  19. package/dist/server/controllers/baseline.controller.js.map +1 -0
  20. package/dist/server/controllers/check.controller.js +2289 -0
  21. package/dist/server/controllers/check.controller.js.map +1 -0
  22. package/dist/server/controllers/client.controller.js +2994 -0
  23. package/dist/server/controllers/client.controller.js.map +1 -0
  24. package/dist/server/controllers/index.js +4289 -0
  25. package/dist/server/controllers/index.js.map +1 -0
  26. package/dist/server/controllers/logs.controller.js +1954 -0
  27. package/dist/server/controllers/logs.controller.js.map +1 -0
  28. package/dist/server/controllers/runs.controller.js +2293 -0
  29. package/dist/server/controllers/runs.controller.js.map +1 -0
  30. package/dist/server/controllers/settings.controller.js +843 -0
  31. package/dist/server/controllers/settings.controller.js.map +1 -0
  32. package/dist/server/controllers/snapshots.controller.js +1953 -0
  33. package/dist/server/controllers/snapshots.controller.js.map +1 -0
  34. package/dist/server/controllers/suite.controller.js +2288 -0
  35. package/dist/server/controllers/suite.controller.js.map +1 -0
  36. package/dist/server/controllers/tasks.controller.js +2378 -0
  37. package/dist/server/controllers/tasks.controller.js.map +1 -0
  38. package/dist/server/controllers/test.controller.js +2312 -0
  39. package/dist/server/controllers/test.controller.js.map +1 -0
  40. package/dist/server/controllers/users.controller.js +2056 -0
  41. package/dist/server/controllers/users.controller.js.map +1 -0
  42. package/dist/server/envConfig.js +70 -0
  43. package/dist/server/envConfig.js.map +1 -0
  44. package/dist/server/lib/AppSettings/AppSettings.js +814 -0
  45. package/dist/server/lib/AppSettings/AppSettings.js.map +1 -0
  46. package/dist/server/lib/AppSettings/index.js +814 -0
  47. package/dist/server/lib/AppSettings/index.js.map +1 -0
  48. package/dist/server/lib/connectDb.js +1873 -0
  49. package/dist/server/lib/connectDb.js.map +1 -0
  50. package/dist/server/lib/dbItems/createAppIfNotExist.js +1878 -0
  51. package/dist/server/lib/dbItems/createAppIfNotExist.js.map +1 -0
  52. package/dist/server/lib/dbItems/createItemIfNotExist.js +1883 -0
  53. package/dist/server/lib/dbItems/createItemIfNotExist.js.map +1 -0
  54. package/dist/server/lib/dbItems/createItemProm.js +1877 -0
  55. package/dist/server/lib/dbItems/createItemProm.js.map +1 -0
  56. package/dist/server/lib/dbItems/createRunIfNotExist.js +1898 -0
  57. package/dist/server/lib/dbItems/createRunIfNotExist.js.map +1 -0
  58. package/dist/server/lib/dbItems/createSuiteIfNotExist.js +1878 -0
  59. package/dist/server/lib/dbItems/createSuiteIfNotExist.js.map +1 -0
  60. package/dist/server/lib/dbItems/createTest.js +1884 -0
  61. package/dist/server/lib/dbItems/createTest.js.map +1 -0
  62. package/dist/server/lib/dbItems/createUser.js +1884 -0
  63. package/dist/server/lib/dbItems/createUser.js.map +1 -0
  64. package/dist/server/lib/dbItems/index.js +2043 -0
  65. package/dist/server/lib/dbItems/index.js.map +1 -0
  66. package/dist/server/lib/dbItems/updateItem.js +1873 -0
  67. package/dist/server/lib/dbItems/updateItem.js.map +1 -0
  68. package/dist/server/lib/dbItems/updateItemDate.js +1872 -0
  69. package/dist/server/lib/dbItems/updateItemDate.js.map +1 -0
  70. package/dist/server/lib/httpLogger.js +1066 -0
  71. package/dist/server/lib/httpLogger.js.map +1 -0
  72. package/dist/server/lib/logger.js +1852 -0
  73. package/dist/server/lib/logger.js.map +1 -0
  74. package/dist/server/lib/startup/createBasicUsers.js +1901 -0
  75. package/dist/server/lib/startup/createBasicUsers.js.map +1 -0
  76. package/dist/server/lib/startup/createInitialSettings.js +820 -0
  77. package/dist/server/lib/startup/createInitialSettings.js.map +1 -0
  78. package/dist/server/lib/startup/createTempDir.js +1066 -0
  79. package/dist/server/lib/startup/createTempDir.js.map +1 -0
  80. package/dist/server/lib/startup/createTestsUsers.js +1916 -0
  81. package/dist/server/lib/startup/createTestsUsers.js.map +1 -0
  82. package/dist/server/lib/startup/index.js +2071 -0
  83. package/dist/server/lib/startup/index.js.map +1 -0
  84. package/dist/server/lib//321/201omparison/comparator.js +1955 -0
  85. package/dist/server/lib//321/201omparison/comparator.js.map +1 -0
  86. package/dist/server/lib//321/201omparison/compareImagesNode.js +91 -0
  87. package/dist/server/lib//321/201omparison/compareImagesNode.js.map +1 -0
  88. package/dist/server/lib//321/201omparison/index.js +1955 -0
  89. package/dist/server/lib//321/201omparison/index.js.map +1 -0
  90. package/dist/server/middlewares/authorization.js +1994 -0
  91. package/dist/server/middlewares/authorization.js.map +1 -0
  92. package/dist/server/middlewares/compressionFilter.js +47 -0
  93. package/dist/server/middlewares/compressionFilter.js.map +1 -0
  94. package/dist/server/middlewares/disableCors.js +1073 -0
  95. package/dist/server/middlewares/disableCors.js.map +1 -0
  96. package/dist/server/middlewares/ensureLogin/ensureLoggedIn.js +2103 -0
  97. package/dist/server/middlewares/ensureLogin/ensureLoggedIn.js.map +1 -0
  98. package/dist/server/middlewares/ensureLogin/index.js +2087 -0
  99. package/dist/server/middlewares/ensureLogin/index.js.map +1 -0
  100. package/dist/server/middlewares/errorHandler.js +1886 -0
  101. package/dist/server/middlewares/errorHandler.js.map +1 -0
  102. package/dist/server/middlewares/index.js +2025 -0
  103. package/dist/server/middlewares/index.js.map +1 -0
  104. package/dist/server/models/App.model.js +145 -0
  105. package/dist/server/models/App.model.js.map +1 -0
  106. package/dist/server/models/AppSettings.model.js +105 -0
  107. package/dist/server/models/AppSettings.model.js.map +1 -0
  108. package/dist/server/models/Baseline.model.js +187 -0
  109. package/dist/server/models/Baseline.model.js.map +1 -0
  110. package/dist/server/models/Check.model.js +241 -0
  111. package/dist/server/models/Check.model.js.map +1 -0
  112. package/dist/server/models/Log.model.js +139 -0
  113. package/dist/server/models/Log.model.js.map +1 -0
  114. package/dist/server/models/Run.model.js +154 -0
  115. package/dist/server/models/Run.model.js.map +1 -0
  116. package/dist/server/models/Snapshot.model.js +148 -0
  117. package/dist/server/models/Snapshot.model.js.map +1 -0
  118. package/dist/server/models/Suite.model.js +151 -0
  119. package/dist/server/models/Suite.model.js.map +1 -0
  120. package/dist/server/models/Test.model.js +248 -0
  121. package/dist/server/models/Test.model.js.map +1 -0
  122. package/dist/server/models/User.model.js +169 -0
  123. package/dist/server/models/User.model.js.map +1 -0
  124. package/dist/server/models/index.js +720 -0
  125. package/dist/server/models/index.js.map +1 -0
  126. package/dist/server/models/plugins/index.js +159 -0
  127. package/dist/server/models/plugins/index.js.map +1 -0
  128. package/dist/server/models/plugins/paginate.plugin.js +68 -0
  129. package/dist/server/models/plugins/paginate.plugin.js.map +1 -0
  130. package/dist/server/models/plugins/paginateDistinct.plugin.js +73 -0
  131. package/dist/server/models/plugins/paginateDistinct.plugin.js.map +1 -0
  132. package/dist/server/models/plugins/toJSON.plugin.js +56 -0
  133. package/dist/server/models/plugins/toJSON.plugin.js.map +1 -0
  134. package/dist/server/models/plugins/utils.js +19 -0
  135. package/dist/server/models/plugins/utils.js.map +1 -0
  136. package/dist/server/routes/ui/admin.js +2082 -0
  137. package/dist/server/routes/ui/admin.js.map +1 -0
  138. package/dist/server/routes/ui/auth.js +711 -0
  139. package/dist/server/routes/ui/auth.js.map +1 -0
  140. package/dist/server/routes/ui/index.js +2036 -0
  141. package/dist/server/routes/ui/index.js.map +1 -0
  142. package/dist/server/routes/v1/app.route.js +4372 -0
  143. package/dist/server/routes/v1/app.route.js.map +1 -0
  144. package/dist/server/routes/v1/auth.route.js +2325 -0
  145. package/dist/server/routes/v1/auth.route.js.map +1 -0
  146. package/dist/server/routes/v1/baselines.route.js +2487 -0
  147. package/dist/server/routes/v1/baselines.route.js.map +1 -0
  148. package/dist/server/routes/v1/checks.route.js +2840 -0
  149. package/dist/server/routes/v1/checks.route.js.map +1 -0
  150. package/dist/server/routes/v1/client.route.js +3764 -0
  151. package/dist/server/routes/v1/client.route.js.map +1 -0
  152. package/dist/server/routes/v1/index.route.js +6536 -0
  153. package/dist/server/routes/v1/index.route.js.map +1 -0
  154. package/dist/server/routes/v1/logs.route.js +2426 -0
  155. package/dist/server/routes/v1/logs.route.js.map +1 -0
  156. package/dist/server/routes/v1/runs.route.js +2771 -0
  157. package/dist/server/routes/v1/runs.route.js.map +1 -0
  158. package/dist/server/routes/v1/settings.route.js +2349 -0
  159. package/dist/server/routes/v1/settings.route.js.map +1 -0
  160. package/dist/server/routes/v1/snapshots.route.js +2361 -0
  161. package/dist/server/routes/v1/snapshots.route.js.map +1 -0
  162. package/dist/server/routes/v1/suites.route.js +2713 -0
  163. package/dist/server/routes/v1/suites.route.js.map +1 -0
  164. package/dist/server/routes/v1/tasks.route.js +2761 -0
  165. package/dist/server/routes/v1/tasks.route.js.map +1 -0
  166. package/dist/server/routes/v1/test_distinct.route.js +2714 -0
  167. package/dist/server/routes/v1/test_distinct.route.js.map +1 -0
  168. package/dist/server/routes/v1/tests.route.js +2895 -0
  169. package/dist/server/routes/v1/tests.route.js.map +1 -0
  170. package/dist/server/routes/v1/users.route.js +4619 -0
  171. package/dist/server/routes/v1/users.route.js.map +1 -0
  172. package/dist/server/schemas/App.schema.js +102 -0
  173. package/dist/server/schemas/App.schema.js.map +1 -0
  174. package/dist/server/schemas/Auth.schema.js +116 -0
  175. package/dist/server/schemas/Auth.schema.js.map +1 -0
  176. package/dist/server/schemas/Baseline.schema.js +183 -0
  177. package/dist/server/schemas/Baseline.schema.js.map +1 -0
  178. package/dist/server/schemas/Check.schema.js +198 -0
  179. package/dist/server/schemas/Check.schema.js.map +1 -0
  180. package/dist/server/schemas/Client.schema.js +455 -0
  181. package/dist/server/schemas/Client.schema.js.map +1 -0
  182. package/dist/server/schemas/CreateCheck.shema.js +47 -0
  183. package/dist/server/schemas/CreateCheck.shema.js.map +1 -0
  184. package/dist/server/schemas/GetBaseline.shema.js +56 -0
  185. package/dist/server/schemas/GetBaseline.shema.js.map +1 -0
  186. package/dist/server/schemas/Logs.schema.js +140 -0
  187. package/dist/server/schemas/Logs.schema.js.map +1 -0
  188. package/dist/server/schemas/Runs.schema.js +128 -0
  189. package/dist/server/schemas/Runs.schema.js.map +1 -0
  190. package/dist/server/schemas/Settings.schema.js +156 -0
  191. package/dist/server/schemas/Settings.schema.js.map +1 -0
  192. package/dist/server/schemas/SkipValid.schema.js +32 -0
  193. package/dist/server/schemas/SkipValid.schema.js.map +1 -0
  194. package/dist/server/schemas/SnapshotDiff.schema.js +44 -0
  195. package/dist/server/schemas/SnapshotDiff.schema.js.map +1 -0
  196. package/dist/server/schemas/Snapshots.schema.js +115 -0
  197. package/dist/server/schemas/Snapshots.schema.js.map +1 -0
  198. package/dist/server/schemas/Suite.schema.js +114 -0
  199. package/dist/server/schemas/Suite.schema.js.map +1 -0
  200. package/dist/server/schemas/Test.schema.js +204 -0
  201. package/dist/server/schemas/Test.schema.js.map +1 -0
  202. package/dist/server/schemas/TestDistinct.schema.js +63 -0
  203. package/dist/server/schemas/TestDistinct.schema.js.map +1 -0
  204. package/dist/server/schemas/User.schema.js +139 -0
  205. package/dist/server/schemas/User.schema.js.map +1 -0
  206. package/dist/server/schemas/common/ApiError.schema.js +51 -0
  207. package/dist/server/schemas/common/ApiError.schema.js.map +1 -0
  208. package/dist/server/schemas/common/Error.schema.js +47 -0
  209. package/dist/server/schemas/common/Error.schema.js.map +1 -0
  210. package/dist/server/schemas/common/RequestPagination.schema.js +121 -0
  211. package/dist/server/schemas/common/RequestPagination.schema.js.map +1 -0
  212. package/dist/server/schemas/common/Version.schema.js +36 -0
  213. package/dist/server/schemas/common/Version.schema.js.map +1 -0
  214. package/dist/server/schemas/common/requestQueryFilterSchema.schema.js +53 -0
  215. package/dist/server/schemas/common/requestQueryFilterSchema.schema.js.map +1 -0
  216. package/dist/server/schemas/index.js +155 -0
  217. package/dist/server/schemas/index.js.map +1 -0
  218. package/dist/server/schemas/utils/commonValidations.js +82 -0
  219. package/dist/server/schemas/utils/commonValidations.js.map +1 -0
  220. package/dist/server/schemas/utils/createRequestBodySchema.js +32 -0
  221. package/dist/server/schemas/utils/createRequestBodySchema.js.map +1 -0
  222. package/dist/server/schemas/utils/createRequestOpenApiBodySchema.js +35 -0
  223. package/dist/server/schemas/utils/createRequestOpenApiBodySchema.js.map +1 -0
  224. package/dist/server/schemas/utils/createRequestParamsSchema.js +93 -0
  225. package/dist/server/schemas/utils/createRequestParamsSchema.js.map +1 -0
  226. package/dist/server/schemas/utils/createRequestQuerySchema.js +32 -0
  227. package/dist/server/schemas/utils/createRequestQuerySchema.js.map +1 -0
  228. package/dist/server/schemas/utils/index.js +84 -0
  229. package/dist/server/schemas/utils/index.js.map +1 -0
  230. package/dist/server/server.js +6921 -0
  231. package/dist/server/server.js.map +1 -0
  232. package/dist/server/server_old.js +7284 -0
  233. package/dist/server/server_old.js.map +1 -0
  234. package/dist/server/services/app.service.js +696 -0
  235. package/dist/server/services/app.service.js.map +1 -0
  236. package/dist/server/services/auth.service.js +2025 -0
  237. package/dist/server/services/auth.service.js.map +1 -0
  238. package/dist/server/services/check.service.js +2149 -0
  239. package/dist/server/services/check.service.js.map +1 -0
  240. package/dist/server/services/client.service.js +2648 -0
  241. package/dist/server/services/client.service.js.map +1 -0
  242. package/dist/server/services/generic.service.js +1888 -0
  243. package/dist/server/services/generic.service.js.map +1 -0
  244. package/dist/server/services/index.js +3548 -0
  245. package/dist/server/services/index.js.map +1 -0
  246. package/dist/server/services/logs.service.js +1875 -0
  247. package/dist/server/services/logs.service.js.map +1 -0
  248. package/dist/server/services/run.service.js +2221 -0
  249. package/dist/server/services/run.service.js.map +1 -0
  250. package/dist/server/services/snapshot.service.js +1921 -0
  251. package/dist/server/services/snapshot.service.js.map +1 -0
  252. package/dist/server/services/suite.service.js +2218 -0
  253. package/dist/server/services/suite.service.js.map +1 -0
  254. package/dist/server/services/tasks.service.js +2288 -0
  255. package/dist/server/services/tasks.service.js.map +1 -0
  256. package/dist/server/services/test.service.js +2230 -0
  257. package/dist/server/services/test.service.js.map +1 -0
  258. package/dist/server/services/user.service.js +1925 -0
  259. package/dist/server/services/user.service.js.map +1 -0
  260. package/dist/server/utils/ApiError.js +39 -0
  261. package/dist/server/utils/ApiError.js.map +1 -0
  262. package/dist/server/utils/ProgressBar.js +54 -0
  263. package/dist/server/utils/ProgressBar.js.map +1 -0
  264. package/dist/server/utils/ServiceResponse.js +45 -0
  265. package/dist/server/utils/ServiceResponse.js.map +1 -0
  266. package/dist/server/utils/buildIdentObject.js +52 -0
  267. package/dist/server/utils/buildIdentObject.js.map +1 -0
  268. package/dist/server/utils/calculateAcceptedStatus.js +710 -0
  269. package/dist/server/utils/calculateAcceptedStatus.js.map +1 -0
  270. package/dist/server/utils/catchAsync.js +32 -0
  271. package/dist/server/utils/catchAsync.js.map +1 -0
  272. package/dist/server/utils/checkIdent.js +36 -0
  273. package/dist/server/utils/checkIdent.js.map +1 -0
  274. package/dist/server/utils/dateToISO8601.js +30 -0
  275. package/dist/server/utils/dateToISO8601.js.map +1 -0
  276. package/dist/server/utils/deserializeIfJSON.js +706 -0
  277. package/dist/server/utils/deserializeIfJSON.js.map +1 -0
  278. package/dist/server/utils/errMsg.js +33 -0
  279. package/dist/server/utils/errMsg.js.map +1 -0
  280. package/dist/server/utils/formatISOToDateTime.js +31 -0
  281. package/dist/server/utils/formatISOToDateTime.js.map +1 -0
  282. package/dist/server/utils/ident.js +31 -0
  283. package/dist/server/utils/ident.js.map +1 -0
  284. package/dist/server/utils/index.js +910 -0
  285. package/dist/server/utils/index.js.map +1 -0
  286. package/dist/server/utils/isJSON.js +34 -0
  287. package/dist/server/utils/isJSON.js.map +1 -0
  288. package/dist/server/utils/paramsGuard.js +45 -0
  289. package/dist/server/utils/paramsGuard.js.map +1 -0
  290. package/dist/server/utils/pick.js +35 -0
  291. package/dist/server/utils/pick.js.map +1 -0
  292. package/dist/server/utils/prettyCheckParams.js +37 -0
  293. package/dist/server/utils/prettyCheckParams.js.map +1 -0
  294. package/dist/server/utils/removeEmptyProperties.js +34 -0
  295. package/dist/server/utils/removeEmptyProperties.js.map +1 -0
  296. package/dist/server/utils/subDays.js +32 -0
  297. package/dist/server/utils/subDays.js.map +1 -0
  298. package/dist/server/utils/validateRequest.js +1922 -0
  299. package/dist/server/utils/validateRequest.js.map +1 -0
  300. package/dist/server/utils/waitUntil.js +43 -0
  301. package/dist/server/utils/waitUntil.js.map +1 -0
  302. package/dist/tasks/backup.js +1085 -0
  303. package/dist/tasks/backup.js.map +1 -0
  304. package/dist/tasks/lib/index.js +717 -0
  305. package/dist/tasks/lib/index.js.map +1 -0
  306. package/dist/tasks/lib/utils.js +1070 -0
  307. package/dist/tasks/lib/utils.js.map +1 -0
  308. package/dist/tasks/migrations/2.0.migration.js +908 -0
  309. package/dist/tasks/migrations/2.0.migration.js.map +1 -0
  310. package/dist/tasks/reindex.js +1742 -0
  311. package/dist/tasks/reindex.js.map +1 -0
  312. package/dist/tasks/restore.js +1097 -0
  313. package/dist/tasks/restore.js.map +1 -0
  314. package/docker-compose.yml +3 -3
  315. package/mvc/views/react/admin/index.html +4 -4
  316. package/mvc/views/react/assets/{LogicalGroup.6c0a9f4a.js → LogicalGroup.80e37bbf.js} +1 -22
  317. package/mvc/views/react/assets/{PasswordInput.b97a4ef7.js → PasswordInput.eb05d2ed.js} +1 -1
  318. package/mvc/views/react/assets/{admin.6d843d1b.js → admin.d6aa02f7.js} +3 -3
  319. package/mvc/views/react/assets/{auth.ecf25364.js → auth.e49d0968.js} +3 -2
  320. package/mvc/views/react/assets/{root.25abcc85.js → root.b071750f.js} +7 -9
  321. package/mvc/views/react/assets/{use-form.10003abf.js → use-form.c4a2cf47.js} +203 -151
  322. package/mvc/views/react/auth/index.html +3 -3
  323. package/mvc/views/react/index2/index.html +3 -3
  324. package/package.json +45 -14
  325. package/src/seeds/testAdmin.json +10 -0
  326. package/src/server/api-docs/openAPIDocumentGenerator.ts +48 -0
  327. package/src/server/api-docs/openAPIResponseBuilders.ts +38 -0
  328. package/src/server/api-docs/openAPIRouter.ts +18 -0
  329. package/src/server/api-docs/serviceResponse.ts +11 -0
  330. package/src/server/app.ts +77 -0
  331. package/src/server/config.ts +57 -0
  332. package/src/server/controllers/app.controller.ts +23 -0
  333. package/src/server/controllers/auth.controller.ts +149 -0
  334. package/src/server/controllers/baseline.controller.ts +32 -0
  335. package/src/server/controllers/{check.controller.js → check.controller.ts} +17 -14
  336. package/src/server/controllers/client.controller.ts +134 -0
  337. package/src/server/controllers/index.ts +27 -0
  338. package/src/server/controllers/logs.controller.ts +36 -0
  339. package/src/server/controllers/runs.controller.ts +32 -0
  340. package/src/server/controllers/settings.controller.ts +28 -0
  341. package/src/server/controllers/snapshots.controller.ts +24 -0
  342. package/src/server/controllers/suite.controller.ts +30 -0
  343. package/src/server/controllers/tasks.controller.ts +47 -0
  344. package/src/server/controllers/test.controller.ts +62 -0
  345. package/src/server/controllers/users.controller.ts +89 -0
  346. package/src/server/envConfig.ts +36 -0
  347. package/src/server/lib/AppSettings/AppSettings.ts +88 -0
  348. package/src/server/lib/AppSettings/index.ts +1 -0
  349. package/src/server/lib/connectDb.ts +18 -0
  350. package/src/server/lib/dbItems/createAppIfNotExist.ts +26 -0
  351. package/src/server/lib/dbItems/createItemIfNotExist.ts +29 -0
  352. package/src/server/lib/dbItems/createItemProm.ts +22 -0
  353. package/src/server/lib/dbItems/createRunIfNotExist.ts +44 -0
  354. package/src/server/lib/dbItems/createSuiteIfNotExist.ts +26 -0
  355. package/src/server/lib/dbItems/createTest.ts +7 -0
  356. package/src/server/lib/dbItems/createUser.ts +7 -0
  357. package/src/server/lib/dbItems/index.ts +12 -0
  358. package/src/server/lib/dbItems/updateItem.ts +17 -0
  359. package/src/server/lib/dbItems/updateItemDate.ts +18 -0
  360. package/src/server/lib/httpLogger.ts +14 -0
  361. package/src/server/lib/logger.ts +147 -0
  362. package/src/server/lib/startup/createBasicUsers.ts +25 -0
  363. package/src/server/lib/startup/createInitialSettings.ts +8 -0
  364. package/src/server/lib/startup/createTempDir.ts +9 -0
  365. package/src/server/lib/startup/createTestsUsers.ts +17 -0
  366. package/src/server/lib/startup/index.ts +4 -0
  367. package/src/server/lib//321/201omparison/comparator.ts +49 -0
  368. package/src/server/lib//321/201omparison/compareImagesNode.ts +61 -0
  369. package/src/server/lib//321/201omparison/index.ts +1 -0
  370. package/src/server/middlewares/{authorization.js → authorization.ts} +23 -14
  371. package/src/server/middlewares/compressionFilter.ts +9 -0
  372. package/src/server/middlewares/disableCors.ts +32 -0
  373. package/src/server/{lib/ensureLogin/ensureLoggedIn.js → middlewares/ensureLogin/ensureLoggedIn.ts} +60 -63
  374. package/src/server/middlewares/ensureLogin/index.ts +2 -0
  375. package/src/server/middlewares/errorHandler.ts +42 -0
  376. package/src/server/middlewares/index.ts +4 -0
  377. package/src/server/models/App.model.ts +42 -0
  378. package/src/server/models/AppSettings.model.ts +48 -0
  379. package/src/server/models/Baseline.model.ts +98 -0
  380. package/src/server/models/Check.model.ts +166 -0
  381. package/src/server/models/Log.model.ts +36 -0
  382. package/src/server/models/Run.model.ts +55 -0
  383. package/src/server/models/Snapshot.model.ts +47 -0
  384. package/src/server/models/Suite.model.ts +50 -0
  385. package/src/server/models/Test.model.ts +117 -0
  386. package/src/server/models/User.model.ts +77 -0
  387. package/src/server/models/index.ts +11 -0
  388. package/src/server/models/plugins/index.ts +3 -0
  389. package/src/server/models/plugins/paginate.plugin.ts +74 -0
  390. package/src/server/models/plugins/paginateDistinct.plugin.ts +90 -0
  391. package/src/server/models/plugins/toJSON.plugin.ts +41 -0
  392. package/src/server/models/plugins/utils.ts +34 -0
  393. package/src/server/routes/ui/admin.ts +29 -0
  394. package/src/server/routes/ui/auth.ts +22 -0
  395. package/src/server/routes/ui/index.ts +25 -0
  396. package/src/server/routes/v1/app.route.ts +48 -0
  397. package/src/server/routes/v1/auth.route.ts +88 -0
  398. package/src/server/routes/v1/baselines.route.ts +52 -0
  399. package/src/server/routes/v1/checks.route.ts +85 -0
  400. package/src/server/routes/v1/client.route.ts +123 -0
  401. package/src/server/routes/v1/{index.js → index.route.ts} +16 -16
  402. package/src/server/routes/v1/logs.route.ts +65 -0
  403. package/src/server/routes/v1/runs.route.ts +55 -0
  404. package/src/server/routes/v1/settings.route.ts +54 -0
  405. package/src/server/routes/v1/snapshots.route.ts +32 -0
  406. package/src/server/routes/v1/suites.route.ts +52 -0
  407. package/src/server/routes/v1/tasks.route.ts +121 -0
  408. package/src/server/routes/v1/test_distinct.route.ts +32 -0
  409. package/src/server/routes/v1/tests.route.ts +90 -0
  410. package/src/server/routes/v1/users.route.ts +115 -0
  411. package/src/server/schemas/App.schema.ts +19 -0
  412. package/src/server/schemas/Auth.schema.ts +27 -0
  413. package/src/server/schemas/Baseline.schema.ts +106 -0
  414. package/src/server/schemas/Check.schema.ts +117 -0
  415. package/src/server/schemas/Client.schema.ts +380 -0
  416. package/src/server/schemas/GetBaseline.shema.ts +34 -0
  417. package/src/server/schemas/Logs.schema.ts +61 -0
  418. package/src/server/schemas/Runs.schema.ts +45 -0
  419. package/src/server/schemas/Settings.schema.ts +71 -0
  420. package/src/server/schemas/SkipValid.schema.ts +2 -0
  421. package/src/server/schemas/SnapshotDiff.schema.ts +18 -0
  422. package/src/server/schemas/Snapshots.schema.ts +42 -0
  423. package/src/server/schemas/Suite.schema.ts +34 -0
  424. package/src/server/schemas/Test.schema.ts +126 -0
  425. package/src/server/schemas/TestDistinct.schema.ts +36 -0
  426. package/src/server/schemas/User.schema.ts +59 -0
  427. package/src/server/schemas/common/ApiError.schema.ts +23 -0
  428. package/src/server/schemas/common/Error.schema.ts +19 -0
  429. package/src/server/schemas/common/RequestPagination.schema.ts +16 -0
  430. package/src/server/schemas/common/Version.schema.ts +14 -0
  431. package/src/server/schemas/common/requestQueryFilterSchema.schema.ts +32 -0
  432. package/src/server/schemas/index.ts +4 -0
  433. package/src/server/schemas/utils/commonValidations.ts +51 -0
  434. package/src/server/schemas/utils/createRequestBodySchema.ts +2 -0
  435. package/src/server/schemas/utils/createRequestOpenApiBodySchema.ts +6 -0
  436. package/src/server/schemas/utils/createRequestParamsSchema.ts +7 -0
  437. package/src/server/schemas/utils/createRequestQuerySchema.ts +2 -0
  438. package/src/server/schemas/utils/index.ts +3 -0
  439. package/src/server/server.ts +54 -0
  440. package/src/server/server_old.ts +185 -0
  441. package/src/server/services/app.service.ts +9 -0
  442. package/src/server/services/auth.service.ts +94 -0
  443. package/src/server/services/check.service.ts +241 -0
  444. package/src/server/services/client.service.ts +691 -0
  445. package/src/server/services/generic.service.ts +37 -0
  446. package/src/server/services/index.ts +24 -0
  447. package/src/server/services/logs.service.ts +27 -0
  448. package/src/server/services/run.service.ts +32 -0
  449. package/src/server/services/snapshot.service.ts +78 -0
  450. package/src/server/services/suite.service.ts +30 -0
  451. package/src/server/services/{tasks.service.js → tasks.service.ts} +157 -228
  452. package/src/server/services/test.service.ts +65 -0
  453. package/src/server/services/user.service.ts +90 -0
  454. package/src/server/utils/{ApiError.js → ApiError.ts} +5 -2
  455. package/src/server/utils/ProgressBar.ts +35 -0
  456. package/src/server/utils/ServiceResponse.ts +18 -0
  457. package/src/server/utils/buildIdentObject.ts +34 -0
  458. package/src/server/utils/calculateAcceptedStatus.ts +22 -0
  459. package/src/server/utils/catchAsync.ts +11 -0
  460. package/src/server/utils/checkIdent.ts +4 -0
  461. package/src/server/utils/dateToISO8601.ts +5 -0
  462. package/src/server/utils/deserializeIfJSON.ts +9 -0
  463. package/src/server/utils/errMsg.ts +3 -0
  464. package/src/server/utils/{formatISOToDateTime.js → formatISOToDateTime.ts} +2 -2
  465. package/src/server/utils/ident.ts +1 -0
  466. package/src/server/utils/index.ts +24 -0
  467. package/src/server/utils/isJSON.ts +14 -0
  468. package/src/server/utils/paramsGuard.ts +7 -6
  469. package/src/server/utils/pick.ts +17 -0
  470. package/src/server/utils/prettyCheckParams.ts +18 -0
  471. package/src/server/utils/removeEmptyProperties.ts +5 -0
  472. package/src/server/utils/{subDays.js → subDays.ts} +2 -2
  473. package/src/server/utils/validateRequest.ts +56 -0
  474. package/src/server/utils/waitUntil.ts +14 -0
  475. package/src/tasks/backup.ts +1 -1
  476. package/src/tasks/lib/index.ts +13 -0
  477. package/src/tasks/lib/utils.ts +14 -0
  478. package/src/tasks/migrations/2.0.migration.ts +2 -2
  479. package/src/tasks/reindex.ts +34 -0
  480. package/src/tasks/restore.ts +1 -1
  481. package/src/types/ExtRequest.ts +10 -0
  482. package/src/types/LogOpts.ts +20 -0
  483. package/src/types/Midleware.ts +3 -0
  484. package/src/types/RequestUser.ts +14 -0
  485. package/src/types/index.ts +4 -0
  486. package/src/ui-app/README.md +2 -2
  487. package/src/ui-app/auth/components/ChangePasswordForm.tsx +1 -1
  488. package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Canvas/mainView.ts +3 -3
  489. package/src/ui-app/index2/components/Tests/Table/Checks/Checks.tsx +30 -2
  490. package/src/ui-app/package-lock.json +10 -16
  491. package/src/ui-app/package.json +2 -2
  492. package/src/ui-app/shared/services/checks.service.ts +1 -1
  493. package/src/ui-app/shared/services/generic.service.ts +0 -28
  494. package/src/ui-app/tsconfig.json +3 -2
  495. package/config.js +0 -17
  496. package/dist/config.js +0 -16
  497. package/dist/src/server/models/index.js +0 -508
  498. package/dist/src/server/models/plugins/index.js +0 -4
  499. package/dist/src/server/models/plugins/paginate.plugin.js +0 -76
  500. package/dist/src/server/models/plugins/paginateDistinct.plugin.js +0 -76
  501. package/dist/src/server/models/plugins/toJSON.plugin.js +0 -39
  502. package/dist/src/server/schemas/createCheck.shema.js +0 -17
  503. package/dist/src/server/schemas/getBaseline.shema.js +0 -12
  504. package/dist/src/server/utils/paramsGuard.js +0 -18
  505. package/dist/src/tasks/backup.js +0 -68
  506. package/dist/src/tasks/lib/common.js +0 -14
  507. package/dist/src/tasks/lib/utils.js +0 -14
  508. package/dist/src/tasks/migrations/2.0.migration.js +0 -86
  509. package/dist/src/tasks/migrations/2.0.migration_mql.js +0 -57
  510. package/dist/src/tasks/reindex.js +0 -28
  511. package/dist/src/tasks/restore.js +0 -86
  512. package/dist/tsconfig.tsbuildinfo +0 -1
  513. package/mvc/views/react/index.html +0 -19
  514. package/server.js +0 -166
  515. package/src/server/controllers/app.controller.js +0 -21
  516. package/src/server/controllers/auth.controller.js +0 -156
  517. package/src/server/controllers/baseline.controller.js +0 -24
  518. package/src/server/controllers/client.controller.js +0 -173
  519. package/src/server/controllers/index.js +0 -12
  520. package/src/server/controllers/logs.controller.js +0 -30
  521. package/src/server/controllers/runs.controller.js +0 -25
  522. package/src/server/controllers/settings.controller.js +0 -23
  523. package/src/server/controllers/snapshots.controller.js +0 -17
  524. package/src/server/controllers/suite.controller.js +0 -24
  525. package/src/server/controllers/tasks.controller.js +0 -47
  526. package/src/server/controllers/test.controller.js +0 -70
  527. package/src/server/controllers/users.controller.js +0 -79
  528. package/src/server/data/custom_devices.json +0 -8
  529. package/src/server/lib/AppSettings.js +0 -56
  530. package/src/server/lib/comparator.js +0 -147
  531. package/src/server/lib/compareImagesNode.js +0 -60
  532. package/src/server/lib/dbItems.js +0 -215
  533. package/src/server/lib/ensureLogin/ensureLoggedOut.js +0 -44
  534. package/src/server/lib/getElementsByPixPositionsFromDump.js +0 -72
  535. package/src/server/lib/logger.js +0 -95
  536. package/src/server/lib/onStart.js +0 -53
  537. package/src/server/lib/parseDiff.js.bak +0 -72
  538. package/src/server/middlewares/disableCors.js +0 -19
  539. package/src/server/models/index.js +0 -534
  540. package/src/server/models/plugins/index.js +0 -3
  541. package/src/server/models/plugins/paginate.plugin.js +0 -83
  542. package/src/server/models/plugins/paginateDistinct.plugin.js +0 -80
  543. package/src/server/models/plugins/toJSON.plugin.js +0 -44
  544. package/src/server/routes/ui/admin.js +0 -20
  545. package/src/server/routes/ui/auth.js +0 -15
  546. package/src/server/routes/ui/index.js +0 -19
  547. package/src/server/routes/v1/app.route.js +0 -9
  548. package/src/server/routes/v1/auth.route.js +0 -12
  549. package/src/server/routes/v1/baselines.route.js +0 -14
  550. package/src/server/routes/v1/checks.route.js +0 -25
  551. package/src/server/routes/v1/client.route.js +0 -39
  552. package/src/server/routes/v1/logs.route.js +0 -16
  553. package/src/server/routes/v1/runs.route.js +0 -15
  554. package/src/server/routes/v1/settings.route.js +0 -23
  555. package/src/server/routes/v1/snapshots.route.js +0 -11
  556. package/src/server/routes/v1/suites.route.js +0 -15
  557. package/src/server/routes/v1/tasks.route.js +0 -59
  558. package/src/server/routes/v1/test.route.js +0 -20
  559. package/src/server/routes/v1/test_distinct.route.js +0 -14
  560. package/src/server/routes/v1/users.route.js +0 -36
  561. package/src/server/schemas/getBaseline.shema.ts +0 -12
  562. package/src/server/services/app.service.js +0 -23
  563. package/src/server/services/check.service.js +0 -178
  564. package/src/server/services/client.service.js +0 -648
  565. package/src/server/services/generic.service.js +0 -51
  566. package/src/server/services/index.js +0 -12
  567. package/src/server/services/logs.service.js +0 -38
  568. package/src/server/services/run.service.js +0 -40
  569. package/src/server/services/suite.service.js +0 -39
  570. package/src/server/services/test.service.js +0 -72
  571. package/src/server/services/user.service.js +0 -128
  572. package/src/server/utils/catchAsync.js +0 -8
  573. package/src/server/utils/check.js +0 -58
  574. package/src/server/utils/dateToISO8601.js +0 -2
  575. package/src/server/utils/deserializeIfJSON.js +0 -9
  576. package/src/server/utils/index.js +0 -10
  577. package/src/server/utils/isJSON.js +0 -6
  578. package/src/server/utils/pick.js +0 -15
  579. package/src/server/utils/prettyCheckParams.js +0 -13
  580. package/src/server/utils/snapshots.js +0 -73
  581. package/src/server/utils/tests.js +0 -36
  582. package/src/server/utils/utils.js +0 -146
  583. package/src/tasks/backup.js.bak +0 -84
  584. package/src/tasks/lib/common.js +0 -24
  585. package/src/tasks/lib/utils.js +0 -15
  586. package/src/tasks/reindex.js +0 -36
  587. package/src/tasks/restore.js.bak +0 -100
  588. package/src/ui-app/tsconfig.node.json +0 -12
  589. package/static/js/canvasjs.min.js.bak +0 -957
  590. package/static/js/chart.js.bak +0 -92
  591. package/static/js/jquery-3.3.1.slim.js.bak +0 -8269
  592. package/static/js/jquery-3.3.1.slim.min.js.bak +0 -2
  593. package/static/js/moment.min.js.bak +0 -2
  594. /package/src/{server/lib → seeds}/admin.json +0 -0
  595. /package/src/{server/lib → seeds}/guest.json +0 -0
  596. /package/src/{server/lib → seeds}/initialAppSettings.json +0 -0
  597. /package/src/{server/lib/testAdmin.json → seeds/testAdmin copy.json} +0 -0
  598. /package/src/{server/lib → seeds}/testUsers.json +0 -0
  599. /package/src/server/schemas/{createCheck.shema.ts → CreateCheck.shema.ts} +0 -0
  600. /package/{static → src/server/static/static}/A.png +0 -0
  601. /package/{static → src/server/static/static}/B.png +0 -0
  602. /package/{static → src/server/static/static}/affected.html +0 -0
  603. /package/{static → src/server/static/static}/affected_2.html +0 -0
  604. /package/{static → src/server/static/static}/data/custom_devices.json +0 -0
  605. /package/{static → src/server/static/static}/grids/desktop-higher.html +0 -0
  606. /package/{static → src/server/static/static}/grids/desktop-wider.html +0 -0
  607. /package/{static → src/server/static/static}/grids/desktop.html +0 -0
  608. /package/{static → src/server/static/static}/grids/fit-in-view.html +0 -0
  609. /package/{static → src/server/static/static}/low_diff_0.png +0 -0
  610. /package/{static → src/server/static/static}/low_diff_1.png +0 -0
  611. /package/{static → src/server/static/static}/vShift.png +0 -0
  612. /package/{static → src/server/static/static}/vShift_bottom.png +0 -0
  613. /package/{static → src/server/static/static}/vShift_top.png +0 -0
@@ -1,12 +0,0 @@
1
- module.exports = {
2
- checkService: require('./check.service'),
3
- runService: require('./run.service'),
4
- suiteService: require('./suite.service'),
5
- testService: require('./test.service'),
6
- usersService: require('./user.service'),
7
- logsService: require('./logs.service'),
8
- genericService: require('./generic.service'),
9
- appService: require('./app.service'),
10
- tasksService: require('./tasks.service'),
11
- clientService: require('./client.service'),
12
- };
@@ -1,38 +0,0 @@
1
- /* eslint-disable valid-jsdoc */
2
- const { Log } = require('../models');
3
- // const ApiError = require('../utils/ApiError');
4
-
5
- const $this = this;
6
- $this.logMeta = {
7
- scope: 'logs_service',
8
- msgType: 'LOG',
9
- };
10
-
11
- /**
12
- * Query for users
13
- * @param {Object} filter - Mongo filter
14
- * @param {Object} options - Query options
15
- * @param {string} [options.sortBy] - Sort option in the format: sortField:(desc|asc)
16
- * @param {number} [options.limit] - Maximum number of results per page (default = 10)
17
- * @param {number} [options.page] - Current page (default = 1)
18
- * @returns {Promise<QueryResult>}
19
- */
20
- const queryLogs = async (filter, options) => Log.paginate(filter, options);
21
-
22
- const distinct = async (field) => Log.distinct(field);
23
-
24
- const createLogs = async (body) => {
25
- log[body.level || 'debug'](body.message,
26
- {
27
- user: body.user,
28
- scope: body.scope || 'test_scope',
29
- msgType: body.msgType || 'TEST_MSG_TYPE',
30
- });
31
- return { message: 'success' };
32
- };
33
-
34
- module.exports = {
35
- queryLogs,
36
- distinct,
37
- createLogs,
38
- };
@@ -1,40 +0,0 @@
1
- /* eslint-disable valid-jsdoc,no-restricted-syntax,no-await-in-loop */
2
- const { Test, Run } = require('../models');
3
-
4
- const testService = require('./test.service');
5
-
6
- const $this = this;
7
- $this.logMeta = {
8
- scope: 'run_service',
9
- msgType: 'RUN',
10
- };
11
-
12
- /**
13
- * Remove a run
14
- * @param {String} id - run id
15
- * @param {Object} user - current user
16
- * @returns {Promise<Run>}
17
- */
18
- const remove = async (id, user) => {
19
- const logOpts = {
20
- scope: 'removeRun',
21
- itemType: 'run',
22
- ref: id,
23
- user: user?.username,
24
- msgType: 'REMOVE',
25
- };
26
- log.info(`remove run with, id: '${id}', user: '${user.username}'`, $this, logOpts);
27
- const tests = await Test.find({ run: id })
28
- .exec();
29
-
30
- for (const test of tests) {
31
- await testService.remove(test._id, user);
32
- }
33
- const run = await Run.findByIdAndRemove(id)
34
- .exec();
35
- return run;
36
- };
37
-
38
- module.exports = {
39
- remove,
40
- };
@@ -1,39 +0,0 @@
1
- /* eslint-disable valid-jsdoc,no-restricted-syntax,no-await-in-loop */
2
- const { Test, Suite } = require('../models');
3
- const testService = require('./test.service');
4
-
5
- const $this = this;
6
- $this.logMeta = {
7
- scope: 'suite_service',
8
- msgType: 'SUITE',
9
- };
10
-
11
- /**
12
- * Remove a suite
13
- * @param {String} id - suite id
14
- * @param {Object} user - current user
15
- * @returns {Promise<Run>}
16
- */
17
- const remove = async (id, user) => {
18
- const logOpts = {
19
- scope: 'removeSuite',
20
- itemType: 'suite',
21
- ref: id,
22
- user: user?.username,
23
- msgType: 'REMOVE',
24
- };
25
- log.info(`remove suite with, id: '${id}', user: '${user.username}'`, $this, logOpts);
26
- const tests = await Test.find({ suite: id })
27
- .exec();
28
-
29
- for (const test of tests) {
30
- await testService.remove(test._id, user);
31
- }
32
- const suite = await Suite.findByIdAndRemove(id)
33
- .exec();
34
- return suite;
35
- };
36
-
37
- module.exports = {
38
- remove,
39
- };
@@ -1,72 +0,0 @@
1
- /* eslint-disable no-restricted-syntax,no-await-in-loop */
2
- const testUtil = require('../utils/tests');
3
- const checkService = require('./check.service');
4
- const { Test, Check } = require('../models');
5
-
6
- const $this = this;
7
- $this.logMeta = {
8
- scope: 'test_service',
9
- msgType: 'TEST',
10
- };
11
-
12
- /**
13
- * Query for test
14
- * @param {Object} filter - Mongo filter
15
- * @param {Object} options - Query options
16
- * @param {string} [options.sortBy] - Sort option in the format: sortField:(desc|asc)
17
- * @param {number} [options.limit] - Maximum number of results per page (default = 10)
18
- * @param {number} [options.page] - Current page (default = 1)
19
- * @returns {Promise<QueryResult>} - result
20
- */
21
- const queryTests = async (filter, options) => {
22
- const tests = await Test.paginate(filter, options);
23
- return tests;
24
- };
25
- const queryTestsDistinct = async (filter, options) => {
26
- const tests = await Test.paginateDistinct(filter, options);
27
- return tests;
28
- };
29
-
30
- /**
31
- * Remove a test
32
- * @param {String} id - test id
33
- * @param {Object} user - current user
34
- * @returns {Promise<Check>} - removed test
35
- */
36
- const remove = async (id, user) => {
37
- const logOpts = {
38
- scope: 'removeTest',
39
- itemType: 'test',
40
- ref: id,
41
- user: user?.username,
42
- msgType: 'REMOVE',
43
- };
44
- log.info(`remove test with, id: '${id}', user: '${user.username}'`, $this, logOpts);
45
- return testUtil.removeTest(id);
46
- };
47
-
48
- const accept = async (id, user) => {
49
- const logOpts = {
50
- scope: 'acceptTest',
51
- itemType: 'test',
52
- ref: id,
53
- user: user?.username,
54
- msgType: 'ACCEPT',
55
- };
56
- log.info(`accept test with, id: '${id}', user: '${user.username}'`, $this, logOpts);
57
-
58
- const checks = await Check.find({ test: id })
59
- .exec();
60
-
61
- for (const check of checks) {
62
- await checkService.accept(check._id, check.actualSnapshotId, user);
63
- }
64
- return { message: 'success' };
65
- };
66
-
67
- module.exports = {
68
- queryTests,
69
- queryTestsDistinct,
70
- remove,
71
- accept,
72
- };
@@ -1,128 +0,0 @@
1
- /* eslint-disable valid-jsdoc */
2
- const httpStatus = require('http-status');
3
- const { User } = require('../models');
4
- const ApiError = require('../utils/ApiError');
5
-
6
- const $this = this;
7
- $this.logMeta = {
8
- scope: 'user_service',
9
- msgType: 'USER',
10
- };
11
-
12
- /**
13
- * Create a user
14
- * @param {Object} userBody
15
- * @returns {Promise<User>}
16
- */
17
- const createUser = async (userBody) => {
18
- if (await User.isEmailTaken(userBody.username)) {
19
- throw new ApiError(httpStatus.BAD_REQUEST, 'Email already taken');
20
- }
21
- const logOpts = {
22
- msgType: 'CREATE',
23
- itemType: 'user',
24
- ref: userBody.username,
25
- scope: 'createUser',
26
- };
27
- log.debug(`create the user with name '${userBody.username}', params: '${JSON.stringify(userBody)}'`, $this, logOpts);
28
-
29
- const user = await User.create({ ...userBody, createdDate: Date.now() });
30
-
31
- const updatedUser = await user.setPassword(userBody.password);
32
- await updatedUser.save();
33
-
34
- log.debug(`password for user: '${userBody.username}' set successfully`, $this, logOpts);
35
- return updatedUser;
36
- };
37
-
38
- /**
39
- * Query for users
40
- * @param {Object} filter - Mongo filter
41
- * @param {Object} options - Query options
42
- * @param {string} [options.sortBy] - Sort option in the format: sortField:(desc|asc)
43
- * @param {number} [options.limit] - Maximum number of results per page (default = 10)
44
- * @param {number} [options.page] - Current page (default = 1)
45
- * @returns {Promise<QueryResult>}
46
- */
47
- const queryUsers = async (filter, options) => {
48
- const users = await User.paginate(filter, options);
49
- return users;
50
- };
51
-
52
- /**
53
- * Get user by id
54
- * @param {ObjectId} id
55
- * @returns {Promise<User>}
56
- */
57
- const getUserById = async (id) => User.findById(id);
58
-
59
- /**
60
- * Get user by email
61
- * @param {string} email
62
- * @returns {Promise<User>}
63
- */
64
- const getUserByEmail = async (email) => User.findOne({ email });
65
-
66
- /**
67
- * Update user by id
68
- * @param {ObjectId} userId
69
- * @param {Object} updateBody
70
- * @returns {Promise<User>}
71
- */
72
- const updateUserById = async (userId, updateBody) => {
73
- const logOpts = {
74
- msgType: 'UPDATE',
75
- itemType: 'user',
76
- scope: 'updateUserById',
77
- };
78
-
79
- log.info(
80
- `update user with id: '${userId}' name '${updateBody.username}', params: '${JSON.stringify(updateBody)}'`,
81
- $this,
82
- logOpts
83
- );
84
- const user = await getUserById(userId);
85
- if (!user) {
86
- throw new ApiError(httpStatus.NOT_FOUND, 'User not found');
87
- }
88
- if (updateBody.email && (await User.isEmailTaken(updateBody.email, userId))) {
89
- throw new ApiError(httpStatus.BAD_REQUEST, 'Email already taken');
90
- }
91
- if (updateBody.password) {
92
- log.debug(`update password for '${updateBody.username}'`, $this, logOpts);
93
- await user.setPassword(updateBody.password);
94
- await user.save();
95
- log.debug(`password for '${updateBody.username}' was updated`, $this, logOpts);
96
- }
97
- log.debug(`user '${updateBody.username}' was updated successfully`, $this, logOpts);
98
-
99
- // remove password
100
- const { password, ...newupdateBody } = updateBody;
101
- Object.assign(user, {
102
- ...newupdateBody, updatedDate: Date.now(),
103
- });
104
- await user.save();
105
- return user;
106
- };
107
-
108
- /**
109
- * Delete user by id
110
- * @param {ObjectId} userId
111
- * @returns {Promise<User>}
112
- */
113
- const deleteUserById = async (userId) => User.findByIdAndDelete(userId).exec();
114
- // const user = await getUserById(userId);
115
- // if (!user) {
116
- // throw new ApiError(httpStatus.NOT_FOUND, 'User not found');
117
- // }
118
- // await user.remove();
119
- // return user;
120
-
121
- module.exports = {
122
- createUser,
123
- queryUsers,
124
- getUserById,
125
- getUserByEmail,
126
- updateUserById,
127
- deleteUserById,
128
- };
@@ -1,8 +0,0 @@
1
- const catchAsync = (fn) => (req, res, next) => {
2
- Promise.resolve(fn(req, res, next)).catch((err) => {
3
- log.error(err.stack || err.toString());
4
- return next(err);
5
- });
6
- };
7
-
8
- module.exports = catchAsync;
@@ -1,58 +0,0 @@
1
- const snapshotUtil = require('./snapshots');
2
- const { calculateAcceptedStatus } = require('./utils');
3
- const testUtil = require('./tests');
4
- const orm = require('../lib/dbItems');
5
- const { Check, Test } = require('../models');
6
-
7
- const $this = this;
8
-
9
- $this.logMeta = {
10
- scope: 'check_helper',
11
- msgType: 'API',
12
- };
13
-
14
- module.exports.removeCheck = async function removeCheck(id) {
15
- const logOpts = {
16
- scope: 'removeCheck',
17
- itemType: 'check',
18
- ref: id,
19
- msgType: 'REMOVE',
20
- };
21
-
22
- try {
23
- const check = await Check.findByIdAndDelete(id)
24
- .exec();
25
-
26
- log.debug(`check with id: '${id}' was removed, update test: ${check.test}`, $this, logOpts);
27
-
28
- const test = await Test.findById(check.test)
29
- .exec();
30
- const testCalculatedStatus = await testUtil.calculateTestStatus(check.test);
31
- const testCalculatedAcceptedStatus = await calculateAcceptedStatus(check.test);
32
- test.status = testCalculatedStatus;
33
- test.markedAs = testCalculatedAcceptedStatus;
34
- test.updatedDate = new Date();
35
- await orm.updateItemDate('VRSSuite', check.suite);
36
- await test.save();
37
-
38
- if ((check.baselineId) && (check.baselineId !== 'undefined')) {
39
- log.debug(`try to remove the snapshot, baseline: ${check.baselineId}`, $this, logOpts);
40
- await snapshotUtil.removeSnapshot(check.baselineId?.toString());
41
- }
42
-
43
- if ((check.actualSnapshotId) && (check.baselineId !== 'undefined')) {
44
- log.debug(`try to remove the snapshot, actual: ${check.actualSnapshotId}`, $this, logOpts);
45
- await snapshotUtil.removeSnapshot(check.actualSnapshotId?.toString());
46
- }
47
-
48
- if ((check.diffId) && (check.baselineId !== 'undefined')) {
49
- log.debug(`try to remove snapshot, diff: ${check.diffId}`, $this, logOpts);
50
- await snapshotUtil.removeSnapshot(check.diffId?.toString());
51
- }
52
- return check;
53
- } catch (e) {
54
- const errMsg = `cannot remove a check with id: '${id}', error: '${e.stack || e.toString()}'`;
55
- log.error(errMsg, $this, logOpts);
56
- throw new Error(errMsg);
57
- }
58
- };
@@ -1,2 +0,0 @@
1
- const dateToISO8601 = (date) => new Date(new Date(date)).toISOString().split('T')[0];
2
- module.exports = dateToISO8601;
@@ -1,9 +0,0 @@
1
- const { EJSON } = require('bson');
2
- const isJSON = require('./isJSON');
3
-
4
- const deserializeIfJSON = (text) => {
5
- if (isJSON(text)) return EJSON.parse(text || null) || undefined;
6
- return text;
7
- };
8
-
9
- module.exports = deserializeIfJSON;
@@ -1,10 +0,0 @@
1
- module.exports = {
2
- pick: require('./pick'),
3
- catchAsync: require('./catchAsync'),
4
- ApiError: require('./ApiError'),
5
- isJSON: require('./isJSON'),
6
- deserializeIfJSON: require('./deserializeIfJSON'),
7
- subDays: require('./subDays'),
8
- dateToISO8601: require('./dateToISO8601'),
9
- formatISOToDateTime: require('./formatISOToDateTime'),
10
- };
@@ -1,6 +0,0 @@
1
- /* eslint-disable */
2
- const isJSON = (text) => (!text ? '' : (/^[\],:{}\s]*$/.test(text.replace(/\\["\\\/bfnrtu]/g, '@')
3
- .replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']')
4
- .replace(/(?:^|:|,)(?:\s*\[)+/g, ''))));
5
-
6
- module.exports = isJSON;
@@ -1,15 +0,0 @@
1
- /**
2
- * Create an object composed of the picked object properties
3
- * @param {Object} object input object
4
- * @param {string[]} keys fields to pick
5
- * @returns {Object} new object
6
- */
7
- const pick = (object, keys) => keys.reduce((obj, key) => {
8
- if (object && Object.prototype.hasOwnProperty.call(object, key)) {
9
- // eslint-disable-next-line no-param-reassign
10
- if (object[key] !== undefined) obj[key] = object[key];
11
- }
12
- return obj;
13
- }, {});
14
-
15
- module.exports = pick;
@@ -1,13 +0,0 @@
1
- const prettyCheckParams = (result) => {
2
- if (!result.domDump) {
3
- return JSON.stringify(result);
4
- }
5
- const dump = JSON.parse(result.domDump);
6
- const resObs = { ...result };
7
- delete resObs.domDump;
8
- resObs.domDump = `${JSON.stringify(dump)
9
- .substr(0, 20)}... and about ${dump.length} items]`;
10
- return JSON.stringify(resObs);
11
- };
12
-
13
- module.exports = prettyCheckParams;
@@ -1,73 +0,0 @@
1
- const fss = require('fs');
2
- const { config } = require('../../../config');
3
-
4
- const { Baseline, Snapshot } = require('../models');
5
-
6
- const $this = this;
7
-
8
- $this.logMeta = {
9
- scope: 'snapshot_helper',
10
- msgType: 'API',
11
- };
12
-
13
- const removeSnapshotFile = async (snapshot) => {
14
- let relatedSnapshots;
15
- if (snapshot.filename) {
16
- relatedSnapshots = await Snapshot.find({ filename: snapshot.filename });
17
- log.debug(`there is '${relatedSnapshots.length}' snapshots with such filename: '${snapshot.filename}'`, $this);
18
- }
19
-
20
- // eslint-disable-next-line arrow-body-style
21
- const isLastSnapshotFile = () => {
22
- if (snapshot.filename === undefined) {
23
- return true;
24
- }
25
- return (relatedSnapshots.length === 0);
26
- };
27
- log.debug({ isLastSnapshotFile: isLastSnapshotFile() });
28
- if (isLastSnapshotFile()) {
29
- const path = `${config.defaultImagesPath}${snapshot.filename}`;
30
- log.silly(`path: ${path}`, $this);
31
- if (fss.existsSync(path)) {
32
- log.debug(`remove file: '${path}'`, $this, {
33
- msgType: 'REMOVE',
34
- itemType: 'file',
35
- });
36
- fss.unlinkSync(path);
37
- }
38
- }
39
- };
40
-
41
- module.exports.removeSnapshot = async (id) => {
42
- const logOpts = {
43
- scope: 'removeSnapshot',
44
- msgType: 'REMOVE',
45
- itemType: 'snapshot',
46
- ref: id,
47
- };
48
- log.silly(`delete snapshot with id: '${id}'`, logOpts);
49
- if (!id) {
50
- log.warn('id is empty');
51
- return;
52
- }
53
- const snapshot = await Snapshot.findById(id);
54
-
55
- if (snapshot === null) {
56
- log.warn(`cannot find the snapshot with id: '${id}'`);
57
- return;
58
- }
59
- const baseline = await Baseline.findOne({ snapshootId: id });
60
-
61
- if (baseline) {
62
- log.debug(`snapshot: '${id}' related to baseline baseline, skip`, logOpts);
63
- return;
64
- }
65
-
66
- log.debug(`snapshot: '${id}' is not related to baseline, try to remove it`, logOpts);
67
- await Snapshot.findByIdAndDelete(id);
68
- log.debug(`snapshot: '${id}' was removed`, logOpts);
69
- const path = `${config.defaultImagesPath}${snapshot.filename}`;
70
-
71
- log.debug(`try to remove snapshot file, id: '${snapshot._id}', filename: '${path}'`, logOpts);
72
- await removeSnapshotFile(snapshot);
73
- };
@@ -1,36 +0,0 @@
1
- const checkUtil = require('./check');
2
- const { Check, Test } = require('../models');
3
-
4
- module.exports.calculateTestStatus = async function calculateTestStatus(testId) {
5
- const checksInTest = await Check.find({ test: testId });
6
- const statuses = checksInTest.map((x) => x.status[0]);
7
- let testCalculatedStatus = 'Failed';
8
- if (statuses.every((x) => (x === 'new') || (x === 'passed'))) {
9
- testCalculatedStatus = 'Passed';
10
- }
11
- if (statuses.every((x) => (x === 'new'))) {
12
- testCalculatedStatus = 'New';
13
- }
14
- return testCalculatedStatus;
15
- };
16
-
17
- module.exports.removeTest = async function removeTest(id) {
18
- const logOpts = {
19
- itemType: 'test',
20
- msgType: 'REMOVE',
21
- ref: id,
22
- };
23
- try {
24
- log.debug(`try to delete all checks associated to test with ID: '${id}'`, logOpts);
25
- const checks = await Check.find({ test: id });
26
- // eslint-disable-next-line no-restricted-syntax
27
- for (const check of checks) {
28
- // eslint-disable-next-line no-await-in-loop
29
- await checkUtil.removeCheck(check._id);
30
- }
31
- return Test.findByIdAndDelete(id);
32
- } catch (e) {
33
- log.error(`cannot remove test with id: ${id} error: ${e.stack || e.toString()}`, logOpts);
34
- throw new Error();
35
- }
36
- };