@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.
- package/README.md +49 -27
- package/dist/server/api-docs/openAPIDocumentGenerator.js +6489 -0
- package/dist/server/api-docs/openAPIDocumentGenerator.js.map +1 -0
- package/dist/server/api-docs/openAPIResponseBuilders.js +89 -0
- package/dist/server/api-docs/openAPIResponseBuilders.js.map +1 -0
- package/dist/server/api-docs/openAPIRouter.js +6505 -0
- package/dist/server/api-docs/openAPIRouter.js.map +1 -0
- package/dist/server/api-docs/serviceResponse.js +39 -0
- package/dist/server/api-docs/serviceResponse.js.map +1 -0
- package/dist/server/app.js +6751 -0
- package/dist/server/app.js.map +1 -0
- package/dist/server/config.js +1055 -0
- package/dist/server/config.js.map +1 -0
- package/dist/server/controllers/app.controller.js +1949 -0
- package/dist/server/controllers/app.controller.js.map +1 -0
- package/dist/server/controllers/auth.controller.js +2079 -0
- package/dist/server/controllers/auth.controller.js.map +1 -0
- package/dist/server/controllers/baseline.controller.js +1976 -0
- package/dist/server/controllers/baseline.controller.js.map +1 -0
- package/dist/server/controllers/check.controller.js +2289 -0
- package/dist/server/controllers/check.controller.js.map +1 -0
- package/dist/server/controllers/client.controller.js +2994 -0
- package/dist/server/controllers/client.controller.js.map +1 -0
- package/dist/server/controllers/index.js +4289 -0
- package/dist/server/controllers/index.js.map +1 -0
- package/dist/server/controllers/logs.controller.js +1954 -0
- package/dist/server/controllers/logs.controller.js.map +1 -0
- package/dist/server/controllers/runs.controller.js +2293 -0
- package/dist/server/controllers/runs.controller.js.map +1 -0
- package/dist/server/controllers/settings.controller.js +843 -0
- package/dist/server/controllers/settings.controller.js.map +1 -0
- package/dist/server/controllers/snapshots.controller.js +1953 -0
- package/dist/server/controllers/snapshots.controller.js.map +1 -0
- package/dist/server/controllers/suite.controller.js +2288 -0
- package/dist/server/controllers/suite.controller.js.map +1 -0
- package/dist/server/controllers/tasks.controller.js +2378 -0
- package/dist/server/controllers/tasks.controller.js.map +1 -0
- package/dist/server/controllers/test.controller.js +2312 -0
- package/dist/server/controllers/test.controller.js.map +1 -0
- package/dist/server/controllers/users.controller.js +2056 -0
- package/dist/server/controllers/users.controller.js.map +1 -0
- package/dist/server/envConfig.js +70 -0
- package/dist/server/envConfig.js.map +1 -0
- package/dist/server/lib/AppSettings/AppSettings.js +814 -0
- package/dist/server/lib/AppSettings/AppSettings.js.map +1 -0
- package/dist/server/lib/AppSettings/index.js +814 -0
- package/dist/server/lib/AppSettings/index.js.map +1 -0
- package/dist/server/lib/connectDb.js +1873 -0
- package/dist/server/lib/connectDb.js.map +1 -0
- package/dist/server/lib/dbItems/createAppIfNotExist.js +1878 -0
- package/dist/server/lib/dbItems/createAppIfNotExist.js.map +1 -0
- package/dist/server/lib/dbItems/createItemIfNotExist.js +1883 -0
- package/dist/server/lib/dbItems/createItemIfNotExist.js.map +1 -0
- package/dist/server/lib/dbItems/createItemProm.js +1877 -0
- package/dist/server/lib/dbItems/createItemProm.js.map +1 -0
- package/dist/server/lib/dbItems/createRunIfNotExist.js +1898 -0
- package/dist/server/lib/dbItems/createRunIfNotExist.js.map +1 -0
- package/dist/server/lib/dbItems/createSuiteIfNotExist.js +1878 -0
- package/dist/server/lib/dbItems/createSuiteIfNotExist.js.map +1 -0
- package/dist/server/lib/dbItems/createTest.js +1884 -0
- package/dist/server/lib/dbItems/createTest.js.map +1 -0
- package/dist/server/lib/dbItems/createUser.js +1884 -0
- package/dist/server/lib/dbItems/createUser.js.map +1 -0
- package/dist/server/lib/dbItems/index.js +2043 -0
- package/dist/server/lib/dbItems/index.js.map +1 -0
- package/dist/server/lib/dbItems/updateItem.js +1873 -0
- package/dist/server/lib/dbItems/updateItem.js.map +1 -0
- package/dist/server/lib/dbItems/updateItemDate.js +1872 -0
- package/dist/server/lib/dbItems/updateItemDate.js.map +1 -0
- package/dist/server/lib/httpLogger.js +1066 -0
- package/dist/server/lib/httpLogger.js.map +1 -0
- package/dist/server/lib/logger.js +1852 -0
- package/dist/server/lib/logger.js.map +1 -0
- package/dist/server/lib/startup/createBasicUsers.js +1901 -0
- package/dist/server/lib/startup/createBasicUsers.js.map +1 -0
- package/dist/server/lib/startup/createInitialSettings.js +820 -0
- package/dist/server/lib/startup/createInitialSettings.js.map +1 -0
- package/dist/server/lib/startup/createTempDir.js +1066 -0
- package/dist/server/lib/startup/createTempDir.js.map +1 -0
- package/dist/server/lib/startup/createTestsUsers.js +1916 -0
- package/dist/server/lib/startup/createTestsUsers.js.map +1 -0
- package/dist/server/lib/startup/index.js +2071 -0
- package/dist/server/lib/startup/index.js.map +1 -0
- package/dist/server/lib//321/201omparison/comparator.js +1955 -0
- package/dist/server/lib//321/201omparison/comparator.js.map +1 -0
- package/dist/server/lib//321/201omparison/compareImagesNode.js +91 -0
- package/dist/server/lib//321/201omparison/compareImagesNode.js.map +1 -0
- package/dist/server/lib//321/201omparison/index.js +1955 -0
- package/dist/server/lib//321/201omparison/index.js.map +1 -0
- package/dist/server/middlewares/authorization.js +1994 -0
- package/dist/server/middlewares/authorization.js.map +1 -0
- package/dist/server/middlewares/compressionFilter.js +47 -0
- package/dist/server/middlewares/compressionFilter.js.map +1 -0
- package/dist/server/middlewares/disableCors.js +1073 -0
- package/dist/server/middlewares/disableCors.js.map +1 -0
- package/dist/server/middlewares/ensureLogin/ensureLoggedIn.js +2103 -0
- package/dist/server/middlewares/ensureLogin/ensureLoggedIn.js.map +1 -0
- package/dist/server/middlewares/ensureLogin/index.js +2087 -0
- package/dist/server/middlewares/ensureLogin/index.js.map +1 -0
- package/dist/server/middlewares/errorHandler.js +1886 -0
- package/dist/server/middlewares/errorHandler.js.map +1 -0
- package/dist/server/middlewares/index.js +2025 -0
- package/dist/server/middlewares/index.js.map +1 -0
- package/dist/server/models/App.model.js +145 -0
- package/dist/server/models/App.model.js.map +1 -0
- package/dist/server/models/AppSettings.model.js +105 -0
- package/dist/server/models/AppSettings.model.js.map +1 -0
- package/dist/server/models/Baseline.model.js +187 -0
- package/dist/server/models/Baseline.model.js.map +1 -0
- package/dist/server/models/Check.model.js +241 -0
- package/dist/server/models/Check.model.js.map +1 -0
- package/dist/server/models/Log.model.js +139 -0
- package/dist/server/models/Log.model.js.map +1 -0
- package/dist/server/models/Run.model.js +154 -0
- package/dist/server/models/Run.model.js.map +1 -0
- package/dist/server/models/Snapshot.model.js +148 -0
- package/dist/server/models/Snapshot.model.js.map +1 -0
- package/dist/server/models/Suite.model.js +151 -0
- package/dist/server/models/Suite.model.js.map +1 -0
- package/dist/server/models/Test.model.js +248 -0
- package/dist/server/models/Test.model.js.map +1 -0
- package/dist/server/models/User.model.js +169 -0
- package/dist/server/models/User.model.js.map +1 -0
- package/dist/server/models/index.js +720 -0
- package/dist/server/models/index.js.map +1 -0
- package/dist/server/models/plugins/index.js +159 -0
- package/dist/server/models/plugins/index.js.map +1 -0
- package/dist/server/models/plugins/paginate.plugin.js +68 -0
- package/dist/server/models/plugins/paginate.plugin.js.map +1 -0
- package/dist/server/models/plugins/paginateDistinct.plugin.js +73 -0
- package/dist/server/models/plugins/paginateDistinct.plugin.js.map +1 -0
- package/dist/server/models/plugins/toJSON.plugin.js +56 -0
- package/dist/server/models/plugins/toJSON.plugin.js.map +1 -0
- package/dist/server/models/plugins/utils.js +19 -0
- package/dist/server/models/plugins/utils.js.map +1 -0
- package/dist/server/routes/ui/admin.js +2082 -0
- package/dist/server/routes/ui/admin.js.map +1 -0
- package/dist/server/routes/ui/auth.js +711 -0
- package/dist/server/routes/ui/auth.js.map +1 -0
- package/dist/server/routes/ui/index.js +2036 -0
- package/dist/server/routes/ui/index.js.map +1 -0
- package/dist/server/routes/v1/app.route.js +4372 -0
- package/dist/server/routes/v1/app.route.js.map +1 -0
- package/dist/server/routes/v1/auth.route.js +2325 -0
- package/dist/server/routes/v1/auth.route.js.map +1 -0
- package/dist/server/routes/v1/baselines.route.js +2487 -0
- package/dist/server/routes/v1/baselines.route.js.map +1 -0
- package/dist/server/routes/v1/checks.route.js +2840 -0
- package/dist/server/routes/v1/checks.route.js.map +1 -0
- package/dist/server/routes/v1/client.route.js +3764 -0
- package/dist/server/routes/v1/client.route.js.map +1 -0
- package/dist/server/routes/v1/index.route.js +6536 -0
- package/dist/server/routes/v1/index.route.js.map +1 -0
- package/dist/server/routes/v1/logs.route.js +2426 -0
- package/dist/server/routes/v1/logs.route.js.map +1 -0
- package/dist/server/routes/v1/runs.route.js +2771 -0
- package/dist/server/routes/v1/runs.route.js.map +1 -0
- package/dist/server/routes/v1/settings.route.js +2349 -0
- package/dist/server/routes/v1/settings.route.js.map +1 -0
- package/dist/server/routes/v1/snapshots.route.js +2361 -0
- package/dist/server/routes/v1/snapshots.route.js.map +1 -0
- package/dist/server/routes/v1/suites.route.js +2713 -0
- package/dist/server/routes/v1/suites.route.js.map +1 -0
- package/dist/server/routes/v1/tasks.route.js +2761 -0
- package/dist/server/routes/v1/tasks.route.js.map +1 -0
- package/dist/server/routes/v1/test_distinct.route.js +2714 -0
- package/dist/server/routes/v1/test_distinct.route.js.map +1 -0
- package/dist/server/routes/v1/tests.route.js +2895 -0
- package/dist/server/routes/v1/tests.route.js.map +1 -0
- package/dist/server/routes/v1/users.route.js +4619 -0
- package/dist/server/routes/v1/users.route.js.map +1 -0
- package/dist/server/schemas/App.schema.js +102 -0
- package/dist/server/schemas/App.schema.js.map +1 -0
- package/dist/server/schemas/Auth.schema.js +116 -0
- package/dist/server/schemas/Auth.schema.js.map +1 -0
- package/dist/server/schemas/Baseline.schema.js +183 -0
- package/dist/server/schemas/Baseline.schema.js.map +1 -0
- package/dist/server/schemas/Check.schema.js +198 -0
- package/dist/server/schemas/Check.schema.js.map +1 -0
- package/dist/server/schemas/Client.schema.js +455 -0
- package/dist/server/schemas/Client.schema.js.map +1 -0
- package/dist/server/schemas/CreateCheck.shema.js +47 -0
- package/dist/server/schemas/CreateCheck.shema.js.map +1 -0
- package/dist/server/schemas/GetBaseline.shema.js +56 -0
- package/dist/server/schemas/GetBaseline.shema.js.map +1 -0
- package/dist/server/schemas/Logs.schema.js +140 -0
- package/dist/server/schemas/Logs.schema.js.map +1 -0
- package/dist/server/schemas/Runs.schema.js +128 -0
- package/dist/server/schemas/Runs.schema.js.map +1 -0
- package/dist/server/schemas/Settings.schema.js +156 -0
- package/dist/server/schemas/Settings.schema.js.map +1 -0
- package/dist/server/schemas/SkipValid.schema.js +32 -0
- package/dist/server/schemas/SkipValid.schema.js.map +1 -0
- package/dist/server/schemas/SnapshotDiff.schema.js +44 -0
- package/dist/server/schemas/SnapshotDiff.schema.js.map +1 -0
- package/dist/server/schemas/Snapshots.schema.js +115 -0
- package/dist/server/schemas/Snapshots.schema.js.map +1 -0
- package/dist/server/schemas/Suite.schema.js +114 -0
- package/dist/server/schemas/Suite.schema.js.map +1 -0
- package/dist/server/schemas/Test.schema.js +204 -0
- package/dist/server/schemas/Test.schema.js.map +1 -0
- package/dist/server/schemas/TestDistinct.schema.js +63 -0
- package/dist/server/schemas/TestDistinct.schema.js.map +1 -0
- package/dist/server/schemas/User.schema.js +139 -0
- package/dist/server/schemas/User.schema.js.map +1 -0
- package/dist/server/schemas/common/ApiError.schema.js +51 -0
- package/dist/server/schemas/common/ApiError.schema.js.map +1 -0
- package/dist/server/schemas/common/Error.schema.js +47 -0
- package/dist/server/schemas/common/Error.schema.js.map +1 -0
- package/dist/server/schemas/common/RequestPagination.schema.js +121 -0
- package/dist/server/schemas/common/RequestPagination.schema.js.map +1 -0
- package/dist/server/schemas/common/Version.schema.js +36 -0
- package/dist/server/schemas/common/Version.schema.js.map +1 -0
- package/dist/server/schemas/common/requestQueryFilterSchema.schema.js +53 -0
- package/dist/server/schemas/common/requestQueryFilterSchema.schema.js.map +1 -0
- package/dist/server/schemas/index.js +155 -0
- package/dist/server/schemas/index.js.map +1 -0
- package/dist/server/schemas/utils/commonValidations.js +82 -0
- package/dist/server/schemas/utils/commonValidations.js.map +1 -0
- package/dist/server/schemas/utils/createRequestBodySchema.js +32 -0
- package/dist/server/schemas/utils/createRequestBodySchema.js.map +1 -0
- package/dist/server/schemas/utils/createRequestOpenApiBodySchema.js +35 -0
- package/dist/server/schemas/utils/createRequestOpenApiBodySchema.js.map +1 -0
- package/dist/server/schemas/utils/createRequestParamsSchema.js +93 -0
- package/dist/server/schemas/utils/createRequestParamsSchema.js.map +1 -0
- package/dist/server/schemas/utils/createRequestQuerySchema.js +32 -0
- package/dist/server/schemas/utils/createRequestQuerySchema.js.map +1 -0
- package/dist/server/schemas/utils/index.js +84 -0
- package/dist/server/schemas/utils/index.js.map +1 -0
- package/dist/server/server.js +6921 -0
- package/dist/server/server.js.map +1 -0
- package/dist/server/server_old.js +7284 -0
- package/dist/server/server_old.js.map +1 -0
- package/dist/server/services/app.service.js +696 -0
- package/dist/server/services/app.service.js.map +1 -0
- package/dist/server/services/auth.service.js +2025 -0
- package/dist/server/services/auth.service.js.map +1 -0
- package/dist/server/services/check.service.js +2149 -0
- package/dist/server/services/check.service.js.map +1 -0
- package/dist/server/services/client.service.js +2648 -0
- package/dist/server/services/client.service.js.map +1 -0
- package/dist/server/services/generic.service.js +1888 -0
- package/dist/server/services/generic.service.js.map +1 -0
- package/dist/server/services/index.js +3548 -0
- package/dist/server/services/index.js.map +1 -0
- package/dist/server/services/logs.service.js +1875 -0
- package/dist/server/services/logs.service.js.map +1 -0
- package/dist/server/services/run.service.js +2221 -0
- package/dist/server/services/run.service.js.map +1 -0
- package/dist/server/services/snapshot.service.js +1921 -0
- package/dist/server/services/snapshot.service.js.map +1 -0
- package/dist/server/services/suite.service.js +2218 -0
- package/dist/server/services/suite.service.js.map +1 -0
- package/dist/server/services/tasks.service.js +2288 -0
- package/dist/server/services/tasks.service.js.map +1 -0
- package/dist/server/services/test.service.js +2230 -0
- package/dist/server/services/test.service.js.map +1 -0
- package/dist/server/services/user.service.js +1925 -0
- package/dist/server/services/user.service.js.map +1 -0
- package/dist/server/utils/ApiError.js +39 -0
- package/dist/server/utils/ApiError.js.map +1 -0
- package/dist/server/utils/ProgressBar.js +54 -0
- package/dist/server/utils/ProgressBar.js.map +1 -0
- package/dist/server/utils/ServiceResponse.js +45 -0
- package/dist/server/utils/ServiceResponse.js.map +1 -0
- package/dist/server/utils/buildIdentObject.js +52 -0
- package/dist/server/utils/buildIdentObject.js.map +1 -0
- package/dist/server/utils/calculateAcceptedStatus.js +710 -0
- package/dist/server/utils/calculateAcceptedStatus.js.map +1 -0
- package/dist/server/utils/catchAsync.js +32 -0
- package/dist/server/utils/catchAsync.js.map +1 -0
- package/dist/server/utils/checkIdent.js +36 -0
- package/dist/server/utils/checkIdent.js.map +1 -0
- package/dist/server/utils/dateToISO8601.js +30 -0
- package/dist/server/utils/dateToISO8601.js.map +1 -0
- package/dist/server/utils/deserializeIfJSON.js +706 -0
- package/dist/server/utils/deserializeIfJSON.js.map +1 -0
- package/dist/server/utils/errMsg.js +33 -0
- package/dist/server/utils/errMsg.js.map +1 -0
- package/dist/server/utils/formatISOToDateTime.js +31 -0
- package/dist/server/utils/formatISOToDateTime.js.map +1 -0
- package/dist/server/utils/ident.js +31 -0
- package/dist/server/utils/ident.js.map +1 -0
- package/dist/server/utils/index.js +910 -0
- package/dist/server/utils/index.js.map +1 -0
- package/dist/server/utils/isJSON.js +34 -0
- package/dist/server/utils/isJSON.js.map +1 -0
- package/dist/server/utils/paramsGuard.js +45 -0
- package/dist/server/utils/paramsGuard.js.map +1 -0
- package/dist/server/utils/pick.js +35 -0
- package/dist/server/utils/pick.js.map +1 -0
- package/dist/server/utils/prettyCheckParams.js +37 -0
- package/dist/server/utils/prettyCheckParams.js.map +1 -0
- package/dist/server/utils/removeEmptyProperties.js +34 -0
- package/dist/server/utils/removeEmptyProperties.js.map +1 -0
- package/dist/server/utils/subDays.js +32 -0
- package/dist/server/utils/subDays.js.map +1 -0
- package/dist/server/utils/validateRequest.js +1922 -0
- package/dist/server/utils/validateRequest.js.map +1 -0
- package/dist/server/utils/waitUntil.js +43 -0
- package/dist/server/utils/waitUntil.js.map +1 -0
- package/dist/tasks/backup.js +1085 -0
- package/dist/tasks/backup.js.map +1 -0
- package/dist/tasks/lib/index.js +717 -0
- package/dist/tasks/lib/index.js.map +1 -0
- package/dist/tasks/lib/utils.js +1070 -0
- package/dist/tasks/lib/utils.js.map +1 -0
- package/dist/tasks/migrations/2.0.migration.js +908 -0
- package/dist/tasks/migrations/2.0.migration.js.map +1 -0
- package/dist/tasks/reindex.js +1742 -0
- package/dist/tasks/reindex.js.map +1 -0
- package/dist/tasks/restore.js +1097 -0
- package/dist/tasks/restore.js.map +1 -0
- package/docker-compose.yml +3 -3
- package/mvc/views/react/admin/index.html +4 -4
- package/mvc/views/react/assets/{LogicalGroup.6c0a9f4a.js → LogicalGroup.80e37bbf.js} +1 -22
- package/mvc/views/react/assets/{PasswordInput.b97a4ef7.js → PasswordInput.eb05d2ed.js} +1 -1
- package/mvc/views/react/assets/{admin.6d843d1b.js → admin.d6aa02f7.js} +3 -3
- package/mvc/views/react/assets/{auth.ecf25364.js → auth.e49d0968.js} +3 -2
- package/mvc/views/react/assets/{root.25abcc85.js → root.b071750f.js} +7 -9
- package/mvc/views/react/assets/{use-form.10003abf.js → use-form.c4a2cf47.js} +203 -151
- package/mvc/views/react/auth/index.html +3 -3
- package/mvc/views/react/index2/index.html +3 -3
- package/package.json +45 -14
- package/src/seeds/testAdmin.json +10 -0
- package/src/server/api-docs/openAPIDocumentGenerator.ts +48 -0
- package/src/server/api-docs/openAPIResponseBuilders.ts +38 -0
- package/src/server/api-docs/openAPIRouter.ts +18 -0
- package/src/server/api-docs/serviceResponse.ts +11 -0
- package/src/server/app.ts +77 -0
- package/src/server/config.ts +57 -0
- package/src/server/controllers/app.controller.ts +23 -0
- package/src/server/controllers/auth.controller.ts +149 -0
- package/src/server/controllers/baseline.controller.ts +32 -0
- package/src/server/controllers/{check.controller.js → check.controller.ts} +17 -14
- package/src/server/controllers/client.controller.ts +134 -0
- package/src/server/controllers/index.ts +27 -0
- package/src/server/controllers/logs.controller.ts +36 -0
- package/src/server/controllers/runs.controller.ts +32 -0
- package/src/server/controllers/settings.controller.ts +28 -0
- package/src/server/controllers/snapshots.controller.ts +24 -0
- package/src/server/controllers/suite.controller.ts +30 -0
- package/src/server/controllers/tasks.controller.ts +47 -0
- package/src/server/controllers/test.controller.ts +62 -0
- package/src/server/controllers/users.controller.ts +89 -0
- package/src/server/envConfig.ts +36 -0
- package/src/server/lib/AppSettings/AppSettings.ts +88 -0
- package/src/server/lib/AppSettings/index.ts +1 -0
- package/src/server/lib/connectDb.ts +18 -0
- package/src/server/lib/dbItems/createAppIfNotExist.ts +26 -0
- package/src/server/lib/dbItems/createItemIfNotExist.ts +29 -0
- package/src/server/lib/dbItems/createItemProm.ts +22 -0
- package/src/server/lib/dbItems/createRunIfNotExist.ts +44 -0
- package/src/server/lib/dbItems/createSuiteIfNotExist.ts +26 -0
- package/src/server/lib/dbItems/createTest.ts +7 -0
- package/src/server/lib/dbItems/createUser.ts +7 -0
- package/src/server/lib/dbItems/index.ts +12 -0
- package/src/server/lib/dbItems/updateItem.ts +17 -0
- package/src/server/lib/dbItems/updateItemDate.ts +18 -0
- package/src/server/lib/httpLogger.ts +14 -0
- package/src/server/lib/logger.ts +147 -0
- package/src/server/lib/startup/createBasicUsers.ts +25 -0
- package/src/server/lib/startup/createInitialSettings.ts +8 -0
- package/src/server/lib/startup/createTempDir.ts +9 -0
- package/src/server/lib/startup/createTestsUsers.ts +17 -0
- package/src/server/lib/startup/index.ts +4 -0
- package/src/server/lib//321/201omparison/comparator.ts +49 -0
- package/src/server/lib//321/201omparison/compareImagesNode.ts +61 -0
- package/src/server/lib//321/201omparison/index.ts +1 -0
- package/src/server/middlewares/{authorization.js → authorization.ts} +23 -14
- package/src/server/middlewares/compressionFilter.ts +9 -0
- package/src/server/middlewares/disableCors.ts +32 -0
- package/src/server/{lib/ensureLogin/ensureLoggedIn.js → middlewares/ensureLogin/ensureLoggedIn.ts} +60 -63
- package/src/server/middlewares/ensureLogin/index.ts +2 -0
- package/src/server/middlewares/errorHandler.ts +42 -0
- package/src/server/middlewares/index.ts +4 -0
- package/src/server/models/App.model.ts +42 -0
- package/src/server/models/AppSettings.model.ts +48 -0
- package/src/server/models/Baseline.model.ts +98 -0
- package/src/server/models/Check.model.ts +166 -0
- package/src/server/models/Log.model.ts +36 -0
- package/src/server/models/Run.model.ts +55 -0
- package/src/server/models/Snapshot.model.ts +47 -0
- package/src/server/models/Suite.model.ts +50 -0
- package/src/server/models/Test.model.ts +117 -0
- package/src/server/models/User.model.ts +77 -0
- package/src/server/models/index.ts +11 -0
- package/src/server/models/plugins/index.ts +3 -0
- package/src/server/models/plugins/paginate.plugin.ts +74 -0
- package/src/server/models/plugins/paginateDistinct.plugin.ts +90 -0
- package/src/server/models/plugins/toJSON.plugin.ts +41 -0
- package/src/server/models/plugins/utils.ts +34 -0
- package/src/server/routes/ui/admin.ts +29 -0
- package/src/server/routes/ui/auth.ts +22 -0
- package/src/server/routes/ui/index.ts +25 -0
- package/src/server/routes/v1/app.route.ts +48 -0
- package/src/server/routes/v1/auth.route.ts +88 -0
- package/src/server/routes/v1/baselines.route.ts +52 -0
- package/src/server/routes/v1/checks.route.ts +85 -0
- package/src/server/routes/v1/client.route.ts +123 -0
- package/src/server/routes/v1/{index.js → index.route.ts} +16 -16
- package/src/server/routes/v1/logs.route.ts +65 -0
- package/src/server/routes/v1/runs.route.ts +55 -0
- package/src/server/routes/v1/settings.route.ts +54 -0
- package/src/server/routes/v1/snapshots.route.ts +32 -0
- package/src/server/routes/v1/suites.route.ts +52 -0
- package/src/server/routes/v1/tasks.route.ts +121 -0
- package/src/server/routes/v1/test_distinct.route.ts +32 -0
- package/src/server/routes/v1/tests.route.ts +90 -0
- package/src/server/routes/v1/users.route.ts +115 -0
- package/src/server/schemas/App.schema.ts +19 -0
- package/src/server/schemas/Auth.schema.ts +27 -0
- package/src/server/schemas/Baseline.schema.ts +106 -0
- package/src/server/schemas/Check.schema.ts +117 -0
- package/src/server/schemas/Client.schema.ts +380 -0
- package/src/server/schemas/GetBaseline.shema.ts +34 -0
- package/src/server/schemas/Logs.schema.ts +61 -0
- package/src/server/schemas/Runs.schema.ts +45 -0
- package/src/server/schemas/Settings.schema.ts +71 -0
- package/src/server/schemas/SkipValid.schema.ts +2 -0
- package/src/server/schemas/SnapshotDiff.schema.ts +18 -0
- package/src/server/schemas/Snapshots.schema.ts +42 -0
- package/src/server/schemas/Suite.schema.ts +34 -0
- package/src/server/schemas/Test.schema.ts +126 -0
- package/src/server/schemas/TestDistinct.schema.ts +36 -0
- package/src/server/schemas/User.schema.ts +59 -0
- package/src/server/schemas/common/ApiError.schema.ts +23 -0
- package/src/server/schemas/common/Error.schema.ts +19 -0
- package/src/server/schemas/common/RequestPagination.schema.ts +16 -0
- package/src/server/schemas/common/Version.schema.ts +14 -0
- package/src/server/schemas/common/requestQueryFilterSchema.schema.ts +32 -0
- package/src/server/schemas/index.ts +4 -0
- package/src/server/schemas/utils/commonValidations.ts +51 -0
- package/src/server/schemas/utils/createRequestBodySchema.ts +2 -0
- package/src/server/schemas/utils/createRequestOpenApiBodySchema.ts +6 -0
- package/src/server/schemas/utils/createRequestParamsSchema.ts +7 -0
- package/src/server/schemas/utils/createRequestQuerySchema.ts +2 -0
- package/src/server/schemas/utils/index.ts +3 -0
- package/src/server/server.ts +54 -0
- package/src/server/server_old.ts +185 -0
- package/src/server/services/app.service.ts +9 -0
- package/src/server/services/auth.service.ts +94 -0
- package/src/server/services/check.service.ts +241 -0
- package/src/server/services/client.service.ts +691 -0
- package/src/server/services/generic.service.ts +37 -0
- package/src/server/services/index.ts +24 -0
- package/src/server/services/logs.service.ts +27 -0
- package/src/server/services/run.service.ts +32 -0
- package/src/server/services/snapshot.service.ts +78 -0
- package/src/server/services/suite.service.ts +30 -0
- package/src/server/services/{tasks.service.js → tasks.service.ts} +157 -228
- package/src/server/services/test.service.ts +65 -0
- package/src/server/services/user.service.ts +90 -0
- package/src/server/utils/{ApiError.js → ApiError.ts} +5 -2
- package/src/server/utils/ProgressBar.ts +35 -0
- package/src/server/utils/ServiceResponse.ts +18 -0
- package/src/server/utils/buildIdentObject.ts +34 -0
- package/src/server/utils/calculateAcceptedStatus.ts +22 -0
- package/src/server/utils/catchAsync.ts +11 -0
- package/src/server/utils/checkIdent.ts +4 -0
- package/src/server/utils/dateToISO8601.ts +5 -0
- package/src/server/utils/deserializeIfJSON.ts +9 -0
- package/src/server/utils/errMsg.ts +3 -0
- package/src/server/utils/{formatISOToDateTime.js → formatISOToDateTime.ts} +2 -2
- package/src/server/utils/ident.ts +1 -0
- package/src/server/utils/index.ts +24 -0
- package/src/server/utils/isJSON.ts +14 -0
- package/src/server/utils/paramsGuard.ts +7 -6
- package/src/server/utils/pick.ts +17 -0
- package/src/server/utils/prettyCheckParams.ts +18 -0
- package/src/server/utils/removeEmptyProperties.ts +5 -0
- package/src/server/utils/{subDays.js → subDays.ts} +2 -2
- package/src/server/utils/validateRequest.ts +56 -0
- package/src/server/utils/waitUntil.ts +14 -0
- package/src/tasks/backup.ts +1 -1
- package/src/tasks/lib/index.ts +13 -0
- package/src/tasks/lib/utils.ts +14 -0
- package/src/tasks/migrations/2.0.migration.ts +2 -2
- package/src/tasks/reindex.ts +34 -0
- package/src/tasks/restore.ts +1 -1
- package/src/types/ExtRequest.ts +10 -0
- package/src/types/LogOpts.ts +20 -0
- package/src/types/Midleware.ts +3 -0
- package/src/types/RequestUser.ts +14 -0
- package/src/types/index.ts +4 -0
- package/src/ui-app/README.md +2 -2
- package/src/ui-app/auth/components/ChangePasswordForm.tsx +1 -1
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Canvas/mainView.ts +3 -3
- package/src/ui-app/index2/components/Tests/Table/Checks/Checks.tsx +30 -2
- package/src/ui-app/package-lock.json +10 -16
- package/src/ui-app/package.json +2 -2
- package/src/ui-app/shared/services/checks.service.ts +1 -1
- package/src/ui-app/shared/services/generic.service.ts +0 -28
- package/src/ui-app/tsconfig.json +3 -2
- package/config.js +0 -17
- package/dist/config.js +0 -16
- package/dist/src/server/models/index.js +0 -508
- package/dist/src/server/models/plugins/index.js +0 -4
- package/dist/src/server/models/plugins/paginate.plugin.js +0 -76
- package/dist/src/server/models/plugins/paginateDistinct.plugin.js +0 -76
- package/dist/src/server/models/plugins/toJSON.plugin.js +0 -39
- package/dist/src/server/schemas/createCheck.shema.js +0 -17
- package/dist/src/server/schemas/getBaseline.shema.js +0 -12
- package/dist/src/server/utils/paramsGuard.js +0 -18
- package/dist/src/tasks/backup.js +0 -68
- package/dist/src/tasks/lib/common.js +0 -14
- package/dist/src/tasks/lib/utils.js +0 -14
- package/dist/src/tasks/migrations/2.0.migration.js +0 -86
- package/dist/src/tasks/migrations/2.0.migration_mql.js +0 -57
- package/dist/src/tasks/reindex.js +0 -28
- package/dist/src/tasks/restore.js +0 -86
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/mvc/views/react/index.html +0 -19
- package/server.js +0 -166
- package/src/server/controllers/app.controller.js +0 -21
- package/src/server/controllers/auth.controller.js +0 -156
- package/src/server/controllers/baseline.controller.js +0 -24
- package/src/server/controllers/client.controller.js +0 -173
- package/src/server/controllers/index.js +0 -12
- package/src/server/controllers/logs.controller.js +0 -30
- package/src/server/controllers/runs.controller.js +0 -25
- package/src/server/controllers/settings.controller.js +0 -23
- package/src/server/controllers/snapshots.controller.js +0 -17
- package/src/server/controllers/suite.controller.js +0 -24
- package/src/server/controllers/tasks.controller.js +0 -47
- package/src/server/controllers/test.controller.js +0 -70
- package/src/server/controllers/users.controller.js +0 -79
- package/src/server/data/custom_devices.json +0 -8
- package/src/server/lib/AppSettings.js +0 -56
- package/src/server/lib/comparator.js +0 -147
- package/src/server/lib/compareImagesNode.js +0 -60
- package/src/server/lib/dbItems.js +0 -215
- package/src/server/lib/ensureLogin/ensureLoggedOut.js +0 -44
- package/src/server/lib/getElementsByPixPositionsFromDump.js +0 -72
- package/src/server/lib/logger.js +0 -95
- package/src/server/lib/onStart.js +0 -53
- package/src/server/lib/parseDiff.js.bak +0 -72
- package/src/server/middlewares/disableCors.js +0 -19
- package/src/server/models/index.js +0 -534
- package/src/server/models/plugins/index.js +0 -3
- package/src/server/models/plugins/paginate.plugin.js +0 -83
- package/src/server/models/plugins/paginateDistinct.plugin.js +0 -80
- package/src/server/models/plugins/toJSON.plugin.js +0 -44
- package/src/server/routes/ui/admin.js +0 -20
- package/src/server/routes/ui/auth.js +0 -15
- package/src/server/routes/ui/index.js +0 -19
- package/src/server/routes/v1/app.route.js +0 -9
- package/src/server/routes/v1/auth.route.js +0 -12
- package/src/server/routes/v1/baselines.route.js +0 -14
- package/src/server/routes/v1/checks.route.js +0 -25
- package/src/server/routes/v1/client.route.js +0 -39
- package/src/server/routes/v1/logs.route.js +0 -16
- package/src/server/routes/v1/runs.route.js +0 -15
- package/src/server/routes/v1/settings.route.js +0 -23
- package/src/server/routes/v1/snapshots.route.js +0 -11
- package/src/server/routes/v1/suites.route.js +0 -15
- package/src/server/routes/v1/tasks.route.js +0 -59
- package/src/server/routes/v1/test.route.js +0 -20
- package/src/server/routes/v1/test_distinct.route.js +0 -14
- package/src/server/routes/v1/users.route.js +0 -36
- package/src/server/schemas/getBaseline.shema.ts +0 -12
- package/src/server/services/app.service.js +0 -23
- package/src/server/services/check.service.js +0 -178
- package/src/server/services/client.service.js +0 -648
- package/src/server/services/generic.service.js +0 -51
- package/src/server/services/index.js +0 -12
- package/src/server/services/logs.service.js +0 -38
- package/src/server/services/run.service.js +0 -40
- package/src/server/services/suite.service.js +0 -39
- package/src/server/services/test.service.js +0 -72
- package/src/server/services/user.service.js +0 -128
- package/src/server/utils/catchAsync.js +0 -8
- package/src/server/utils/check.js +0 -58
- package/src/server/utils/dateToISO8601.js +0 -2
- package/src/server/utils/deserializeIfJSON.js +0 -9
- package/src/server/utils/index.js +0 -10
- package/src/server/utils/isJSON.js +0 -6
- package/src/server/utils/pick.js +0 -15
- package/src/server/utils/prettyCheckParams.js +0 -13
- package/src/server/utils/snapshots.js +0 -73
- package/src/server/utils/tests.js +0 -36
- package/src/server/utils/utils.js +0 -146
- package/src/tasks/backup.js.bak +0 -84
- package/src/tasks/lib/common.js +0 -24
- package/src/tasks/lib/utils.js +0 -15
- package/src/tasks/reindex.js +0 -36
- package/src/tasks/restore.js.bak +0 -100
- package/src/ui-app/tsconfig.node.json +0 -12
- package/static/js/canvasjs.min.js.bak +0 -957
- package/static/js/chart.js.bak +0 -92
- package/static/js/jquery-3.3.1.slim.js.bak +0 -8269
- package/static/js/jquery-3.3.1.slim.min.js.bak +0 -2
- package/static/js/moment.min.js.bak +0 -2
- /package/src/{server/lib → seeds}/admin.json +0 -0
- /package/src/{server/lib → seeds}/guest.json +0 -0
- /package/src/{server/lib → seeds}/initialAppSettings.json +0 -0
- /package/src/{server/lib/testAdmin.json → seeds/testAdmin copy.json} +0 -0
- /package/src/{server/lib → seeds}/testUsers.json +0 -0
- /package/src/server/schemas/{createCheck.shema.ts → CreateCheck.shema.ts} +0 -0
- /package/{static → src/server/static/static}/A.png +0 -0
- /package/{static → src/server/static/static}/B.png +0 -0
- /package/{static → src/server/static/static}/affected.html +0 -0
- /package/{static → src/server/static/static}/affected_2.html +0 -0
- /package/{static → src/server/static/static}/data/custom_devices.json +0 -0
- /package/{static → src/server/static/static}/grids/desktop-higher.html +0 -0
- /package/{static → src/server/static/static}/grids/desktop-wider.html +0 -0
- /package/{static → src/server/static/static}/grids/desktop.html +0 -0
- /package/{static → src/server/static/static}/grids/fit-in-view.html +0 -0
- /package/{static → src/server/static/static}/low_diff_0.png +0 -0
- /package/{static → src/server/static/static}/low_diff_1.png +0 -0
- /package/{static → src/server/static/static}/vShift.png +0 -0
- /package/{static → src/server/static/static}/vShift_bottom.png +0 -0
- /package/{static → src/server/static/static}/vShift_top.png +0 -0
|
@@ -1,508 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/* eslint-disable valid-jsdoc,func-names */
|
|
3
|
-
const passportLocalMongoose = require('passport-local-mongoose');
|
|
4
|
-
const mongoose = require('mongoose');
|
|
5
|
-
const { toJSON, paginate, paginateDistinct } = require('./plugins');
|
|
6
|
-
const { Schema } = mongoose;
|
|
7
|
-
const SnapshotSchema = new Schema({
|
|
8
|
-
name: {
|
|
9
|
-
type: String,
|
|
10
|
-
required: 'SnapshotSchema: the name of the snapshot entity is empty',
|
|
11
|
-
},
|
|
12
|
-
path: {
|
|
13
|
-
type: String,
|
|
14
|
-
},
|
|
15
|
-
filename: {
|
|
16
|
-
type: String,
|
|
17
|
-
},
|
|
18
|
-
imghash: {
|
|
19
|
-
type: String,
|
|
20
|
-
required: 'SnapshotSchema: the image hash of the snapshot entity is empty',
|
|
21
|
-
},
|
|
22
|
-
createdDate: {
|
|
23
|
-
type: Date,
|
|
24
|
-
default: Date.now,
|
|
25
|
-
},
|
|
26
|
-
vOffset: {
|
|
27
|
-
type: Number,
|
|
28
|
-
},
|
|
29
|
-
hOffset: {
|
|
30
|
-
type: Number,
|
|
31
|
-
},
|
|
32
|
-
});
|
|
33
|
-
const CheckSchema = new Schema({
|
|
34
|
-
name: {
|
|
35
|
-
type: String,
|
|
36
|
-
required: 'CheckSchema: the name of the check entity is empty',
|
|
37
|
-
},
|
|
38
|
-
test: {
|
|
39
|
-
type: Schema.Types.ObjectId,
|
|
40
|
-
ref: 'VRSTest',
|
|
41
|
-
required: 'CheckSchema: the test name of the check entity is empty',
|
|
42
|
-
},
|
|
43
|
-
suite: {
|
|
44
|
-
type: Schema.Types.ObjectId,
|
|
45
|
-
ref: 'VRSSuite',
|
|
46
|
-
required: 'CheckSchema: the app field is empty',
|
|
47
|
-
},
|
|
48
|
-
app: {
|
|
49
|
-
type: Schema.Types.ObjectId,
|
|
50
|
-
ref: 'VRSApp',
|
|
51
|
-
required: 'CheckSchema: the app field is empty',
|
|
52
|
-
},
|
|
53
|
-
branch: {
|
|
54
|
-
type: String,
|
|
55
|
-
},
|
|
56
|
-
realBaselineId: {
|
|
57
|
-
type: Schema.Types.ObjectId,
|
|
58
|
-
ref: 'VRSBaseline',
|
|
59
|
-
},
|
|
60
|
-
baselineId: {
|
|
61
|
-
type: Schema.Types.ObjectId,
|
|
62
|
-
ref: 'VRSSnapshot',
|
|
63
|
-
},
|
|
64
|
-
actualSnapshotId: {
|
|
65
|
-
type: Schema.Types.ObjectId,
|
|
66
|
-
ref: 'VRSSnapshot',
|
|
67
|
-
},
|
|
68
|
-
diffId: {
|
|
69
|
-
type: Schema.Types.ObjectId,
|
|
70
|
-
ref: 'VRSSnapshot',
|
|
71
|
-
},
|
|
72
|
-
createdDate: {
|
|
73
|
-
type: Date,
|
|
74
|
-
required: true,
|
|
75
|
-
default: Date.now,
|
|
76
|
-
},
|
|
77
|
-
updatedDate: {
|
|
78
|
-
type: Date,
|
|
79
|
-
},
|
|
80
|
-
status: {
|
|
81
|
-
type: [{
|
|
82
|
-
type: String,
|
|
83
|
-
enum: {
|
|
84
|
-
values: ['new', 'pending', 'approved', 'running', 'passed', 'failed', 'aborted'],
|
|
85
|
-
message: 'status is required',
|
|
86
|
-
},
|
|
87
|
-
}],
|
|
88
|
-
default: 'new',
|
|
89
|
-
},
|
|
90
|
-
browserName: {
|
|
91
|
-
type: String,
|
|
92
|
-
},
|
|
93
|
-
browserVersion: {
|
|
94
|
-
type: String,
|
|
95
|
-
},
|
|
96
|
-
browserFullVersion: {
|
|
97
|
-
type: String,
|
|
98
|
-
},
|
|
99
|
-
viewport: {
|
|
100
|
-
type: String,
|
|
101
|
-
},
|
|
102
|
-
os: {
|
|
103
|
-
type: String,
|
|
104
|
-
},
|
|
105
|
-
domDump: {
|
|
106
|
-
type: String,
|
|
107
|
-
},
|
|
108
|
-
result: {
|
|
109
|
-
type: String,
|
|
110
|
-
default: '{}',
|
|
111
|
-
},
|
|
112
|
-
run: {
|
|
113
|
-
type: Schema.Types.ObjectId,
|
|
114
|
-
},
|
|
115
|
-
markedAs: {
|
|
116
|
-
type: String,
|
|
117
|
-
enum: ['bug', 'accepted'],
|
|
118
|
-
},
|
|
119
|
-
markedDate: {
|
|
120
|
-
type: Date,
|
|
121
|
-
},
|
|
122
|
-
markedById: {
|
|
123
|
-
type: Schema.Types.ObjectId,
|
|
124
|
-
ref: 'VRSUser',
|
|
125
|
-
},
|
|
126
|
-
markedByUsername: {
|
|
127
|
-
type: String,
|
|
128
|
-
},
|
|
129
|
-
markedBugComment: {
|
|
130
|
-
type: String,
|
|
131
|
-
},
|
|
132
|
-
creatorId: {
|
|
133
|
-
type: Schema.Types.ObjectId,
|
|
134
|
-
ref: 'VRSUser',
|
|
135
|
-
},
|
|
136
|
-
creatorUsername: {
|
|
137
|
-
type: String,
|
|
138
|
-
},
|
|
139
|
-
failReasons: {
|
|
140
|
-
type: [String],
|
|
141
|
-
},
|
|
142
|
-
vOffset: {
|
|
143
|
-
type: String,
|
|
144
|
-
},
|
|
145
|
-
topStablePixels: {
|
|
146
|
-
type: String,
|
|
147
|
-
},
|
|
148
|
-
meta: {
|
|
149
|
-
type: Object,
|
|
150
|
-
},
|
|
151
|
-
});
|
|
152
|
-
const BaselineSchema = new Schema({
|
|
153
|
-
snapshootId: Schema.Types.ObjectId,
|
|
154
|
-
name: {
|
|
155
|
-
type: String,
|
|
156
|
-
required: 'VRSBaselineSchema: the name of the snapshoot entity is empty',
|
|
157
|
-
},
|
|
158
|
-
app: {
|
|
159
|
-
type: Schema.Types.ObjectId,
|
|
160
|
-
ref: 'VRSApp',
|
|
161
|
-
required: 'VRSBaselineSchema: the app field is empty',
|
|
162
|
-
},
|
|
163
|
-
branch: {
|
|
164
|
-
type: String,
|
|
165
|
-
},
|
|
166
|
-
browserName: {
|
|
167
|
-
type: String,
|
|
168
|
-
},
|
|
169
|
-
browserVersion: {
|
|
170
|
-
type: String,
|
|
171
|
-
},
|
|
172
|
-
browserFullVersion: {
|
|
173
|
-
type: String,
|
|
174
|
-
},
|
|
175
|
-
viewport: {
|
|
176
|
-
type: String,
|
|
177
|
-
},
|
|
178
|
-
os: {
|
|
179
|
-
type: String,
|
|
180
|
-
},
|
|
181
|
-
markedAs: {
|
|
182
|
-
type: String,
|
|
183
|
-
enum: ['bug', 'accepted'],
|
|
184
|
-
},
|
|
185
|
-
lastMarkedDate: {
|
|
186
|
-
type: Date,
|
|
187
|
-
},
|
|
188
|
-
createdDate: {
|
|
189
|
-
type: Date,
|
|
190
|
-
},
|
|
191
|
-
updatedDate: {
|
|
192
|
-
type: Date,
|
|
193
|
-
},
|
|
194
|
-
markedById: {
|
|
195
|
-
type: Schema.Types.ObjectId,
|
|
196
|
-
ref: 'VRSUser',
|
|
197
|
-
},
|
|
198
|
-
markedByUsername: {
|
|
199
|
-
type: String,
|
|
200
|
-
},
|
|
201
|
-
ignoreRegions: {
|
|
202
|
-
type: String,
|
|
203
|
-
},
|
|
204
|
-
boundRegions: {
|
|
205
|
-
type: String,
|
|
206
|
-
},
|
|
207
|
-
matchType: {
|
|
208
|
-
type: String,
|
|
209
|
-
// enum: ['antialiasing', 'nothing', 'less', 'colors', 'alpha'],
|
|
210
|
-
enum: ['antialiasing', 'nothing', 'colors'],
|
|
211
|
-
},
|
|
212
|
-
meta: {
|
|
213
|
-
type: Object,
|
|
214
|
-
},
|
|
215
|
-
});
|
|
216
|
-
const TestSchema = new Schema({
|
|
217
|
-
name: {
|
|
218
|
-
type: String,
|
|
219
|
-
required: 'TestSchema: the test name is empty',
|
|
220
|
-
},
|
|
221
|
-
description: {
|
|
222
|
-
type: String,
|
|
223
|
-
},
|
|
224
|
-
status: {
|
|
225
|
-
type: String,
|
|
226
|
-
},
|
|
227
|
-
browserName: {
|
|
228
|
-
type: String,
|
|
229
|
-
},
|
|
230
|
-
browserVersion: {
|
|
231
|
-
type: String,
|
|
232
|
-
},
|
|
233
|
-
branch: {
|
|
234
|
-
type: String,
|
|
235
|
-
},
|
|
236
|
-
tags: {
|
|
237
|
-
type: [String],
|
|
238
|
-
},
|
|
239
|
-
viewport: {
|
|
240
|
-
type: String,
|
|
241
|
-
},
|
|
242
|
-
// after handle all checks inside the test
|
|
243
|
-
calculatedViewport: {
|
|
244
|
-
type: String,
|
|
245
|
-
},
|
|
246
|
-
os: {
|
|
247
|
-
type: String,
|
|
248
|
-
},
|
|
249
|
-
app: {
|
|
250
|
-
type: Schema.Types.ObjectId,
|
|
251
|
-
ref: 'VRSApp',
|
|
252
|
-
required: 'TestSchema: the app field is empty',
|
|
253
|
-
},
|
|
254
|
-
blinking: {
|
|
255
|
-
type: Number,
|
|
256
|
-
default: 0,
|
|
257
|
-
},
|
|
258
|
-
updatedDate: {
|
|
259
|
-
type: Date,
|
|
260
|
-
},
|
|
261
|
-
startDate: {
|
|
262
|
-
type: Date,
|
|
263
|
-
},
|
|
264
|
-
checks: [
|
|
265
|
-
{
|
|
266
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
267
|
-
ref: 'VRSCheck',
|
|
268
|
-
},
|
|
269
|
-
],
|
|
270
|
-
suite: {
|
|
271
|
-
type: Schema.Types.ObjectId,
|
|
272
|
-
ref: 'VRSSuite',
|
|
273
|
-
},
|
|
274
|
-
run: {
|
|
275
|
-
type: Schema.Types.ObjectId,
|
|
276
|
-
ref: 'VRSRun',
|
|
277
|
-
},
|
|
278
|
-
markedAs: {
|
|
279
|
-
type: String,
|
|
280
|
-
enum: ['Bug', 'Accepted', 'Unaccepted', 'Partially'],
|
|
281
|
-
},
|
|
282
|
-
creatorId: {
|
|
283
|
-
type: Schema.Types.ObjectId,
|
|
284
|
-
ref: 'VRSUser',
|
|
285
|
-
},
|
|
286
|
-
creatorUsername: {
|
|
287
|
-
type: String,
|
|
288
|
-
},
|
|
289
|
-
meta: {
|
|
290
|
-
type: Object,
|
|
291
|
-
},
|
|
292
|
-
}, { strictQuery: true }); // remove filters that not exist in schema
|
|
293
|
-
const SuiteSchema = new Schema({
|
|
294
|
-
name: {
|
|
295
|
-
type: String,
|
|
296
|
-
default: 'Others',
|
|
297
|
-
unique: true,
|
|
298
|
-
required: 'SuiteSchema: the suite name is empty',
|
|
299
|
-
},
|
|
300
|
-
tags: {
|
|
301
|
-
type: [String],
|
|
302
|
-
},
|
|
303
|
-
app: {
|
|
304
|
-
type: Schema.Types.ObjectId,
|
|
305
|
-
ref: 'VRSApp',
|
|
306
|
-
required: 'SuiteSchema: the app field is empty',
|
|
307
|
-
},
|
|
308
|
-
description: {
|
|
309
|
-
type: String,
|
|
310
|
-
},
|
|
311
|
-
updatedDate: {
|
|
312
|
-
type: Date,
|
|
313
|
-
default: Date.now,
|
|
314
|
-
},
|
|
315
|
-
createdDate: {
|
|
316
|
-
type: Date,
|
|
317
|
-
},
|
|
318
|
-
meta: {
|
|
319
|
-
type: Object,
|
|
320
|
-
},
|
|
321
|
-
});
|
|
322
|
-
const RunSchema = new Schema({
|
|
323
|
-
name: {
|
|
324
|
-
type: String,
|
|
325
|
-
required: 'RunSchema: the run name cannot be empty',
|
|
326
|
-
},
|
|
327
|
-
app: {
|
|
328
|
-
type: Schema.Types.ObjectId,
|
|
329
|
-
ref: 'VRSApp',
|
|
330
|
-
required: 'RunSchema: the app field is empty',
|
|
331
|
-
},
|
|
332
|
-
ident: {
|
|
333
|
-
type: String,
|
|
334
|
-
unique: true,
|
|
335
|
-
required: 'RunSchema: the run ident run cannot be empty',
|
|
336
|
-
},
|
|
337
|
-
description: {
|
|
338
|
-
type: String,
|
|
339
|
-
},
|
|
340
|
-
updatedDate: {
|
|
341
|
-
type: Date,
|
|
342
|
-
default: Date.now,
|
|
343
|
-
},
|
|
344
|
-
createdDate: {
|
|
345
|
-
type: Date,
|
|
346
|
-
},
|
|
347
|
-
parameters: {
|
|
348
|
-
type: [String],
|
|
349
|
-
},
|
|
350
|
-
meta: {
|
|
351
|
-
type: Object,
|
|
352
|
-
},
|
|
353
|
-
});
|
|
354
|
-
const LogSchema = new Schema({
|
|
355
|
-
timestamp: {
|
|
356
|
-
type: Date,
|
|
357
|
-
},
|
|
358
|
-
level: {
|
|
359
|
-
type: String,
|
|
360
|
-
},
|
|
361
|
-
message: {
|
|
362
|
-
type: String,
|
|
363
|
-
},
|
|
364
|
-
meta: {
|
|
365
|
-
type: Object,
|
|
366
|
-
},
|
|
367
|
-
hostname: {
|
|
368
|
-
type: Object,
|
|
369
|
-
},
|
|
370
|
-
});
|
|
371
|
-
// this is the Projects Schema `VRSAppSchema` name is for historical reason
|
|
372
|
-
const AppSchema = new Schema({
|
|
373
|
-
name: {
|
|
374
|
-
type: String,
|
|
375
|
-
default: 'Others',
|
|
376
|
-
unique: true,
|
|
377
|
-
required: 'AppSchema: the Application name is empty',
|
|
378
|
-
},
|
|
379
|
-
description: {
|
|
380
|
-
type: String,
|
|
381
|
-
},
|
|
382
|
-
version: {
|
|
383
|
-
type: String,
|
|
384
|
-
},
|
|
385
|
-
updatedDate: {
|
|
386
|
-
type: Date,
|
|
387
|
-
},
|
|
388
|
-
createdDate: {
|
|
389
|
-
type: Date,
|
|
390
|
-
},
|
|
391
|
-
meta: {
|
|
392
|
-
type: Object,
|
|
393
|
-
},
|
|
394
|
-
});
|
|
395
|
-
const UserSchema = new Schema({
|
|
396
|
-
username: {
|
|
397
|
-
type: String,
|
|
398
|
-
unique: true,
|
|
399
|
-
required: 'UserSchema: the username name is empty',
|
|
400
|
-
},
|
|
401
|
-
firstName: {
|
|
402
|
-
type: String,
|
|
403
|
-
required: 'UserSchema: the firstName name is empty',
|
|
404
|
-
},
|
|
405
|
-
lastName: {
|
|
406
|
-
type: String,
|
|
407
|
-
required: 'UserSchema: the lastName name is empty',
|
|
408
|
-
},
|
|
409
|
-
role: {
|
|
410
|
-
type: String,
|
|
411
|
-
enum: {
|
|
412
|
-
values: ['admin', 'reviewer', 'user'],
|
|
413
|
-
message: 'UserSchema: role is required',
|
|
414
|
-
required: 'UserSchema: role is required',
|
|
415
|
-
},
|
|
416
|
-
},
|
|
417
|
-
password: {
|
|
418
|
-
type: String,
|
|
419
|
-
},
|
|
420
|
-
token: {
|
|
421
|
-
type: String,
|
|
422
|
-
},
|
|
423
|
-
apiKey: {
|
|
424
|
-
type: String,
|
|
425
|
-
},
|
|
426
|
-
createdDate: {
|
|
427
|
-
type: Date,
|
|
428
|
-
},
|
|
429
|
-
updatedDate: {
|
|
430
|
-
type: Date,
|
|
431
|
-
},
|
|
432
|
-
expiration: {
|
|
433
|
-
type: Date,
|
|
434
|
-
},
|
|
435
|
-
meta: {
|
|
436
|
-
type: Object,
|
|
437
|
-
},
|
|
438
|
-
});
|
|
439
|
-
const AppSettingsSchema = new Schema({
|
|
440
|
-
name: {
|
|
441
|
-
type: String,
|
|
442
|
-
unique: true,
|
|
443
|
-
required: 'AppSettingsSchema: the name is empty',
|
|
444
|
-
},
|
|
445
|
-
label: {
|
|
446
|
-
type: String,
|
|
447
|
-
required: 'AppSettingsSchema: the label is empty',
|
|
448
|
-
},
|
|
449
|
-
description: {
|
|
450
|
-
type: String,
|
|
451
|
-
},
|
|
452
|
-
type: {
|
|
453
|
-
type: String,
|
|
454
|
-
required: 'AppSettingsSchema: the type is empty',
|
|
455
|
-
},
|
|
456
|
-
value: {
|
|
457
|
-
type: Schema.Types.Mixed,
|
|
458
|
-
required: 'AppSettingsSchema: the value is empty',
|
|
459
|
-
},
|
|
460
|
-
env_variable: {
|
|
461
|
-
type: String,
|
|
462
|
-
},
|
|
463
|
-
enabled: {
|
|
464
|
-
type: Boolean,
|
|
465
|
-
},
|
|
466
|
-
});
|
|
467
|
-
AppSettingsSchema.plugin(toJSON);
|
|
468
|
-
LogSchema.plugin(toJSON);
|
|
469
|
-
LogSchema.plugin(paginate);
|
|
470
|
-
UserSchema.plugin(toJSON);
|
|
471
|
-
UserSchema.plugin(paginate);
|
|
472
|
-
RunSchema.plugin(paginate);
|
|
473
|
-
RunSchema.plugin(toJSON);
|
|
474
|
-
SuiteSchema.plugin(paginate);
|
|
475
|
-
SuiteSchema.plugin(toJSON);
|
|
476
|
-
AppSchema.plugin(paginate);
|
|
477
|
-
AppSchema.plugin(toJSON);
|
|
478
|
-
BaselineSchema.plugin(toJSON);
|
|
479
|
-
BaselineSchema.plugin(paginate);
|
|
480
|
-
SnapshotSchema.plugin(toJSON);
|
|
481
|
-
SnapshotSchema.plugin(paginate);
|
|
482
|
-
CheckSchema.plugin(toJSON);
|
|
483
|
-
CheckSchema.plugin(paginate);
|
|
484
|
-
TestSchema.plugin(toJSON);
|
|
485
|
-
TestSchema.plugin(paginate);
|
|
486
|
-
TestSchema.plugin(paginateDistinct);
|
|
487
|
-
/**
|
|
488
|
-
* Check if email is taken
|
|
489
|
-
* @param {string} username - The user's email
|
|
490
|
-
* @param {ObjectId} [excludeUserId] - The id of the user to be excluded
|
|
491
|
-
* @returns {Promise<boolean>}
|
|
492
|
-
*/
|
|
493
|
-
UserSchema.statics.isEmailTaken = async function (username, excludeUserId) {
|
|
494
|
-
const user = await this.findOne({ username, _id: { $ne: excludeUserId } });
|
|
495
|
-
return !!user;
|
|
496
|
-
};
|
|
497
|
-
UserSchema.plugin(passportLocalMongoose, { hashField: 'password' });
|
|
498
|
-
const Snapshot = mongoose.model('VRSSnapshot', SnapshotSchema);
|
|
499
|
-
const Check = mongoose.model('VRSCheck', CheckSchema);
|
|
500
|
-
const Test = mongoose.model('VRSTest', TestSchema);
|
|
501
|
-
const Log = mongoose.model('VRSLog', LogSchema);
|
|
502
|
-
const Suite = mongoose.model('VRSSuite', SuiteSchema);
|
|
503
|
-
const App = mongoose.model('VRSApp', AppSchema);
|
|
504
|
-
const Run = mongoose.model('VRSRun', RunSchema);
|
|
505
|
-
const User = mongoose.model('VRSUser', UserSchema);
|
|
506
|
-
const Baseline = mongoose.model('VRSBaseline', BaselineSchema);
|
|
507
|
-
const AppSettings = mongoose.model('VRSAppSettings', AppSettingsSchema);
|
|
508
|
-
module.exports = { Snapshot, Check, Test, Log, Suite, App, Run, User, Baseline, AppSettings };
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/* eslint-disable no-param-reassign, valid-jsdoc */
|
|
3
|
-
const paginate = (schema) => {
|
|
4
|
-
/**
|
|
5
|
-
* @typedef {Object} QueryResult
|
|
6
|
-
* @property {Document[]} results - Results found
|
|
7
|
-
* @property {number} page - Current page
|
|
8
|
-
* @property {number} limit - Maximum number of results per page
|
|
9
|
-
* @property {number} totalPages - Total number of pages
|
|
10
|
-
* @property {number} totalResults - Total number of documents
|
|
11
|
-
*/
|
|
12
|
-
/**
|
|
13
|
-
* Query for documents with pagination
|
|
14
|
-
* @param {Object} [filter] - Mongo filter
|
|
15
|
-
* @param {Object} [options] - Query options
|
|
16
|
-
* @param {string} [options.sortBy] - Sorting criteria using the format: sortField:(desc|asc).
|
|
17
|
-
* Multiple sorting criteria should be separated by commas (,)
|
|
18
|
-
* @param {string} [options.populate] - Populate data fields. Hierarchy of fields should be separated by (.).
|
|
19
|
-
* Multiple populating criteria should be separated by commas (,)
|
|
20
|
-
* @param {number} [options.limit] - Maximum number of results per page (default = 10)
|
|
21
|
-
* @param {number} [options.page] - Current page (default = 1)
|
|
22
|
-
* @returns {Promise<QueryResult>}
|
|
23
|
-
*/
|
|
24
|
-
// eslint-disable-next-line func-names
|
|
25
|
-
schema.statics.paginate = async function (filter, options) {
|
|
26
|
-
let sort = '';
|
|
27
|
-
if (options.sortBy) {
|
|
28
|
-
const sortingCriteria = [];
|
|
29
|
-
options.sortBy.split(',')
|
|
30
|
-
.forEach((sortOption) => {
|
|
31
|
-
const [key, order] = sortOption.split(':');
|
|
32
|
-
sortingCriteria.push((order === 'desc' ? '-' : '') + key);
|
|
33
|
-
});
|
|
34
|
-
sort = sortingCriteria.join(' ');
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
sort = { _id: -1 };
|
|
38
|
-
}
|
|
39
|
-
const limit = options.limit && parseInt(options.limit, 10) >= 0 ? parseInt(options.limit, 10) : 10;
|
|
40
|
-
const page = options.page && parseInt(options.page, 10) > 0 ? parseInt(options.page, 10) : 1;
|
|
41
|
-
const skip = (page - 1) * limit;
|
|
42
|
-
const countPromise = this.countDocuments(filter)
|
|
43
|
-
.exec();
|
|
44
|
-
let docsPromise = this.find(filter)
|
|
45
|
-
.sort(sort)
|
|
46
|
-
.skip(skip)
|
|
47
|
-
.limit(limit);
|
|
48
|
-
if (options.populate) {
|
|
49
|
-
options.populate.split(',')
|
|
50
|
-
.forEach((populateOption) => {
|
|
51
|
-
docsPromise = docsPromise.populate(populateOption
|
|
52
|
-
.split('.')
|
|
53
|
-
.reverse()
|
|
54
|
-
.reduce((a, b) => ({ path: b, populate: a })));
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
docsPromise = docsPromise.exec();
|
|
58
|
-
return Promise.all([countPromise, docsPromise])
|
|
59
|
-
.then((values) => {
|
|
60
|
-
const [totalResults, results] = values;
|
|
61
|
-
const totalPages = Math.ceil(totalResults / limit);
|
|
62
|
-
const result = {
|
|
63
|
-
results,
|
|
64
|
-
page,
|
|
65
|
-
limit,
|
|
66
|
-
totalPages,
|
|
67
|
-
totalResults,
|
|
68
|
-
// microseconds
|
|
69
|
-
timestamp: Number(Date.now() + String(process.hrtime()[1])
|
|
70
|
-
.slice(3, 6)),
|
|
71
|
-
};
|
|
72
|
-
return Promise.resolve(result);
|
|
73
|
-
});
|
|
74
|
-
};
|
|
75
|
-
};
|
|
76
|
-
module.exports = paginate;
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/* eslint-disable no-param-reassign, valid-jsdoc */
|
|
3
|
-
const { EJSON } = require('bson');
|
|
4
|
-
const paginateDistinct = (schema) => {
|
|
5
|
-
/**
|
|
6
|
-
* @typedef {Object} QueryResult
|
|
7
|
-
* @property {Document[]} results - Results found
|
|
8
|
-
* @property {number} page - Current page
|
|
9
|
-
* @property {number} limit - Maximum number of results per page
|
|
10
|
-
* @property {number} totalPages - Total number of pages
|
|
11
|
-
* @property {number} totalResults - Total number of documents
|
|
12
|
-
*/
|
|
13
|
-
/**
|
|
14
|
-
* Query for documents with pagination
|
|
15
|
-
* @param {Object} [filter] - Mongo filter
|
|
16
|
-
* @param {Object} [options] - Query options
|
|
17
|
-
* @param {string} [options.sortBy] - Sorting criteria using the format: sortField:(desc|asc).
|
|
18
|
-
* Multiple sorting criteria should be separated by commas (,)
|
|
19
|
-
* @param {string} [options.populate] - Populate data fields. Hierarchy of fields should be separated by (.).
|
|
20
|
-
* Multiple populating criteria should be separated by commas (,)
|
|
21
|
-
* @param {number} [options.limit] - Maximum number of results per page (default = 10)
|
|
22
|
-
* @param {number} [options.page] - Current page (default = 1)
|
|
23
|
-
* @returns {Promise<QueryResult>}
|
|
24
|
-
*/
|
|
25
|
-
// eslint-disable-next-line func-names
|
|
26
|
-
schema.statics.paginateDistinct = async function (filter, options) {
|
|
27
|
-
let sort = {};
|
|
28
|
-
if (options.sortBy) {
|
|
29
|
-
options.sortBy.split(',')
|
|
30
|
-
.forEach((sortOption) => {
|
|
31
|
-
const [key, order] = sortOption.split(':');
|
|
32
|
-
sort[key] = (order === 'desc') ? -1 : 1;
|
|
33
|
-
});
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
sort = { _id: -1 };
|
|
37
|
-
}
|
|
38
|
-
let limit = options.limit && parseInt(options.limit, 10) >= 0 ? parseInt(options.limit, 10) : 10;
|
|
39
|
-
limit = limit === 0 ? 9007199254740991 : limit;
|
|
40
|
-
const page = options.page && parseInt(options.page, 10) > 0 ? parseInt(options.page, 10) : 1;
|
|
41
|
-
const skip = (page - 1) * limit;
|
|
42
|
-
const groupAggregateObj = { $group: { _id: `$${options.field}` } };
|
|
43
|
-
const documentsCount = (await this.aggregate([groupAggregateObj])
|
|
44
|
-
.exec()).length;
|
|
45
|
-
const aggregateArr = [
|
|
46
|
-
{ $match: EJSON.parse(filter.filter || '{}') },
|
|
47
|
-
groupAggregateObj,
|
|
48
|
-
{ $sort: sort },
|
|
49
|
-
{ $skip: skip },
|
|
50
|
-
{ $limit: limit },
|
|
51
|
-
];
|
|
52
|
-
const aggregatedDocs = (await this.aggregate(aggregateArr))
|
|
53
|
-
.filter((x) => x._id)
|
|
54
|
-
.map((x) => {
|
|
55
|
-
if (x[options.field]) {
|
|
56
|
-
return x[options.field][0];
|
|
57
|
-
}
|
|
58
|
-
return { name: x._id };
|
|
59
|
-
});
|
|
60
|
-
return Promise.all([documentsCount, aggregatedDocs])
|
|
61
|
-
.then((values) => {
|
|
62
|
-
const [totalResults, results] = values;
|
|
63
|
-
const totalPages = Math.ceil(totalResults / limit);
|
|
64
|
-
const result = {
|
|
65
|
-
results,
|
|
66
|
-
page,
|
|
67
|
-
limit,
|
|
68
|
-
totalPages,
|
|
69
|
-
totalResults,
|
|
70
|
-
timestamp: new Date() / 1,
|
|
71
|
-
};
|
|
72
|
-
return Promise.resolve(result);
|
|
73
|
-
});
|
|
74
|
-
};
|
|
75
|
-
};
|
|
76
|
-
module.exports = paginateDistinct;
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/* eslint-disable no-param-reassign */
|
|
3
|
-
/**
|
|
4
|
-
* A mongoose schema plugin which applies the following in the toJSON transform call:
|
|
5
|
-
* - removes __v, createdAt, updatedAt, and any path that has private: true
|
|
6
|
-
* - replaces _id with id
|
|
7
|
-
*/
|
|
8
|
-
const deleteAtPath = (obj, path, index) => {
|
|
9
|
-
if (index === path.length - 1) {
|
|
10
|
-
delete obj[path[index]];
|
|
11
|
-
return;
|
|
12
|
-
}
|
|
13
|
-
deleteAtPath(obj[path[index]], path, index + 1);
|
|
14
|
-
};
|
|
15
|
-
const toJSON = (schema) => {
|
|
16
|
-
let transform;
|
|
17
|
-
if (schema.options.toJSON && schema.options.toJSON.transform) {
|
|
18
|
-
transform = schema.options.toJSON.transform;
|
|
19
|
-
}
|
|
20
|
-
schema.options.toJSON = Object.assign(schema.options.toJSON || {}, {
|
|
21
|
-
transform(doc, ret, options) {
|
|
22
|
-
Object.keys(schema.paths).forEach((path) => {
|
|
23
|
-
if (schema.paths[path].options && schema.paths[path].options.private) {
|
|
24
|
-
deleteAtPath(ret, path.split('.'), 0);
|
|
25
|
-
}
|
|
26
|
-
});
|
|
27
|
-
ret.id = ret._id.toString();
|
|
28
|
-
// delete ret._id;
|
|
29
|
-
// eslint-disable-next-line no-underscore-dangle
|
|
30
|
-
delete ret.__v;
|
|
31
|
-
delete ret.createdAt;
|
|
32
|
-
delete ret.updatedAt;
|
|
33
|
-
if (transform) {
|
|
34
|
-
return transform(doc, ret, options);
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
});
|
|
38
|
-
};
|
|
39
|
-
module.exports = toJSON;
|