@syngrisi/syngrisi 2.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.nvmrc +1 -0
- package/LICENSE.md +9 -0
- package/README.md +139 -0
- package/config.js +17 -0
- package/dist/config.js +16 -0
- package/dist/src/server/models/index.js +508 -0
- package/dist/src/server/models/plugins/index.js +4 -0
- package/dist/src/server/models/plugins/paginate.plugin.js +76 -0
- package/dist/src/server/models/plugins/paginateDistinct.plugin.js +76 -0
- package/dist/src/server/models/plugins/toJSON.plugin.js +39 -0
- package/dist/src/server/schemas/createCheck.shema.js +17 -0
- package/dist/src/server/schemas/getBaseline.shema.js +12 -0
- package/dist/src/server/utils/paramsGuard.js +18 -0
- package/dist/src/tasks/backup.js +68 -0
- package/dist/src/tasks/lib/common.js +14 -0
- package/dist/src/tasks/lib/utils.js +14 -0
- package/dist/src/tasks/migrations/2.0.migration.js +86 -0
- package/dist/src/tasks/migrations/2.0.migration_mql.js +57 -0
- package/dist/src/tasks/reindex.js +28 -0
- package/dist/src/tasks/restore.js +86 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/docker-compose.yml +70 -0
- package/mvc/views/react/admin/index.html +22 -0
- package/mvc/views/react/assets/LogicalGroup.95929360.js +15993 -0
- package/mvc/views/react/assets/PasswordInput.8a73fdd2.js +299 -0
- package/mvc/views/react/assets/admin.94703bdc.js +14448 -0
- package/mvc/views/react/assets/auth.748478ef.js +673 -0
- package/mvc/views/react/assets/bg_2_0_dark_L2.3a31edc0.png +0 -0
- package/mvc/views/react/assets/favicon.bf5828d5.svg +7 -0
- package/mvc/views/react/assets/index.a5606313.css +23 -0
- package/mvc/views/react/assets/roboto-v30-latin-100.0f303f31.woff2 +0 -0
- package/mvc/views/react/assets/roboto-v30-latin-100.34e9582c.woff +0 -0
- package/mvc/views/react/assets/roboto-v30-latin-500.9ce7f3ac.woff +0 -0
- package/mvc/views/react/assets/roboto-v30-latin-500.b0195382.woff2 +0 -0
- package/mvc/views/react/assets/roboto-v30-latin-700.e0fd57c0.woff +0 -0
- package/mvc/views/react/assets/roboto-v30-latin-700.f5aebdfe.woff2 +0 -0
- package/mvc/views/react/assets/roboto-v30-latin-regular.f2abf7fb.woff +0 -0
- package/mvc/views/react/assets/roboto-v30-latin-regular.f6734f81.woff2 +0 -0
- package/mvc/views/react/assets/root.136e0ea3.js +25451 -0
- package/mvc/views/react/assets/use-form.57ebe175.js +24472 -0
- package/mvc/views/react/assets/use-form.ecb4391b.css +36 -0
- package/mvc/views/react/auth/index.html +22 -0
- package/mvc/views/react/index.html +19 -0
- package/mvc/views/react/index2/index.html +21 -0
- package/package.json +144 -0
- package/server.js +166 -0
- package/src/server/controllers/app.controller.js +21 -0
- package/src/server/controllers/auth.controller.js +156 -0
- package/src/server/controllers/baseline.controller.js +24 -0
- package/src/server/controllers/check.controller.js +56 -0
- package/src/server/controllers/client.controller.js +173 -0
- package/src/server/controllers/index.js +12 -0
- package/src/server/controllers/logs.controller.js +30 -0
- package/src/server/controllers/runs.controller.js +25 -0
- package/src/server/controllers/settings.controller.js +23 -0
- package/src/server/controllers/snapshots.controller.js +17 -0
- package/src/server/controllers/suite.controller.js +24 -0
- package/src/server/controllers/tasks.controller.js +47 -0
- package/src/server/controllers/test.controller.js +70 -0
- package/src/server/controllers/users.controller.js +79 -0
- package/src/server/data/custom_devices.json +8 -0
- package/src/server/data/devices.json +773 -0
- package/src/server/data/get_devices.sh +2 -0
- package/src/server/lib/AppSettings.js +56 -0
- package/src/server/lib/admin.json +9 -0
- package/src/server/lib/comparator.js +147 -0
- package/src/server/lib/compareImagesNode.js +60 -0
- package/src/server/lib/dbItems.js +215 -0
- package/src/server/lib/ensureLogin/ensureLoggedIn.js +223 -0
- package/src/server/lib/ensureLogin/ensureLoggedOut.js +44 -0
- package/src/server/lib/getElementsByPixPositionsFromDump.js +72 -0
- package/src/server/lib/guest.json +9 -0
- package/src/server/lib/initialAppSettings.json +18 -0
- package/src/server/lib/logger.js +95 -0
- package/src/server/lib/onStart.js +53 -0
- package/src/server/lib/parseDiff.js.bak +72 -0
- package/src/server/lib/testAdmin.json +9 -0
- package/src/server/lib/testUsers.json +41 -0
- package/src/server/middlewares/authorization.js +50 -0
- package/src/server/middlewares/disableCors.js +19 -0
- package/src/server/models/index.js +534 -0
- package/src/server/models/plugins/index.js +3 -0
- package/src/server/models/plugins/paginate.plugin.js +83 -0
- package/src/server/models/plugins/paginateDistinct.plugin.js +80 -0
- package/src/server/models/plugins/toJSON.plugin.js +44 -0
- package/src/server/routes/ui/admin.js +20 -0
- package/src/server/routes/ui/auth.js +15 -0
- package/src/server/routes/ui/index.js +19 -0
- package/src/server/routes/v1/app.route.js +9 -0
- package/src/server/routes/v1/auth.route.js +12 -0
- package/src/server/routes/v1/baselines.route.js +14 -0
- package/src/server/routes/v1/checks.route.js +25 -0
- package/src/server/routes/v1/client.route.js +39 -0
- package/src/server/routes/v1/index.js +82 -0
- package/src/server/routes/v1/logs.route.js +16 -0
- package/src/server/routes/v1/runs.route.js +15 -0
- package/src/server/routes/v1/settings.route.js +23 -0
- package/src/server/routes/v1/snapshots.route.js +11 -0
- package/src/server/routes/v1/suites.route.js +15 -0
- package/src/server/routes/v1/tasks.route.js +59 -0
- package/src/server/routes/v1/test.route.js +20 -0
- package/src/server/routes/v1/test_distinct.route.js +14 -0
- package/src/server/routes/v1/users.route.js +36 -0
- package/src/server/schemas/createCheck.shema.ts +17 -0
- package/src/server/schemas/getBaseline.shema.ts +12 -0
- package/src/server/services/app.service.js +23 -0
- package/src/server/services/check.service.js +178 -0
- package/src/server/services/client.service.js +648 -0
- package/src/server/services/generic.service.js +51 -0
- package/src/server/services/index.js +12 -0
- package/src/server/services/logs.service.js +38 -0
- package/src/server/services/run.service.js +40 -0
- package/src/server/services/suite.service.js +39 -0
- package/src/server/services/tasks.service.js +536 -0
- package/src/server/services/test.service.js +72 -0
- package/src/server/services/user.service.js +128 -0
- package/src/server/utils/ApiError.js +14 -0
- package/src/server/utils/catchAsync.js +8 -0
- package/src/server/utils/check.js +58 -0
- package/src/server/utils/dateToISO8601.js +2 -0
- package/src/server/utils/deserializeIfJSON.js +9 -0
- package/src/server/utils/formatISOToDateTime.js +6 -0
- package/src/server/utils/index.js +10 -0
- package/src/server/utils/isJSON.js +6 -0
- package/src/server/utils/paramsGuard.ts +15 -0
- package/src/server/utils/pick.js +15 -0
- package/src/server/utils/prettyCheckParams.js +13 -0
- package/src/server/utils/snapshots.js +73 -0
- package/src/server/utils/subDays.js +7 -0
- package/src/server/utils/tests.js +36 -0
- package/src/server/utils/utils.js +146 -0
- package/src/tasks/backup.js.bak +84 -0
- package/src/tasks/backup.ts +53 -0
- package/src/tasks/lib/common.js +24 -0
- package/src/tasks/lib/utils.js +15 -0
- package/src/tasks/migrations/2.0.migration.js +86 -0
- package/src/tasks/migrations/2.0.migration.ts +95 -0
- package/src/tasks/migrations/2.0.migration_mql.js +63 -0
- package/src/tasks/reindex.js +36 -0
- package/src/tasks/restore.js.bak +100 -0
- package/src/tasks/restore.ts +75 -0
- package/src/ui-app/.eslintrc.json +119 -0
- package/src/ui-app/README.md +15 -0
- package/src/ui-app/admin/AdminLayout.tsx +38 -0
- package/src/ui-app/admin/App.tsx +108 -0
- package/src/ui-app/admin/AppContext.ts +3 -0
- package/src/ui-app/admin/components/Header/AdminHeader.tsx +148 -0
- package/src/ui-app/admin/components/Logs/AdminLogs.tsx +142 -0
- package/src/ui-app/admin/components/Logs/RefreshActionIcon.tsx +60 -0
- package/src/ui-app/admin/components/Logs/Table/AdminLogsTable.tsx +81 -0
- package/src/ui-app/admin/components/Logs/Table/AdminLogsTableFilter.tsx +170 -0
- package/src/ui-app/admin/components/Logs/Table/AdminLogsTableHeads.tsx +50 -0
- package/src/ui-app/admin/components/Logs/Table/AdminLogsTableRows.tsx +207 -0
- package/src/ui-app/admin/components/Logs/Table/AdminLogsTableSettings.tsx +95 -0
- package/src/ui-app/admin/components/Logs/Table/InfinityScrollSkeleton.tsx +77 -0
- package/src/ui-app/admin/components/Logs/Table/InfinityScrollSkeletonFIller.tsx +57 -0
- package/src/ui-app/admin/components/Logs/Table/PagesCountAffix.tsx +61 -0
- package/src/ui-app/admin/components/Logs/Table/adminLogsCreateStyle.tsx +36 -0
- package/src/ui-app/admin/components/Logs/Table/adminLogsTableColumns.ts +52 -0
- package/src/ui-app/admin/components/Logs/UnfoldActionIcon.tsx +39 -0
- package/src/ui-app/admin/components/Navbar/AdminNavbar.tsx +50 -0
- package/src/ui-app/admin/components/Navbar/NavbarLinksGroup.tsx +104 -0
- package/src/ui-app/admin/components/Settings/AdminSettings.tsx +51 -0
- package/src/ui-app/admin/components/Settings/Forms/Boolean.tsx +59 -0
- package/src/ui-app/admin/components/Settings/Forms/FormWrapper.tsx +45 -0
- package/src/ui-app/admin/components/Settings/Forms/index.tsx +5 -0
- package/src/ui-app/admin/components/Settings/Forms/interfaces.tsx +17 -0
- package/src/ui-app/admin/components/Tasks/Task.tsx +138 -0
- package/src/ui-app/admin/components/Tasks/TaskWrapper.tsx +11 -0
- package/src/ui-app/admin/components/Tasks/tasksList.ts +59 -0
- package/src/ui-app/admin/components/Users/AdminUsers.tsx +182 -0
- package/src/ui-app/admin/components/Users/UserAddForm.tsx +137 -0
- package/src/ui-app/admin/components/Users/UserForm.tsx +196 -0
- package/src/ui-app/admin/hooks/useParams.tsx +18 -0
- package/src/ui-app/admin/index.html +17 -0
- package/src/ui-app/admin/main.tsx +24 -0
- package/src/ui-app/asserts/css/auth/index.css +23 -0
- package/src/ui-app/asserts/css/styles.css +36 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-100.eot +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-100.svg +313 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-100.ttf +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-100.woff +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-100.woff2 +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-500.eot +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-500.svg +305 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-500.ttf +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-500.woff +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-500.woff2 +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-700.eot +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-700.svg +309 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-700.ttf +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-700.woff +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-700.woff2 +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-regular.eot +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-regular.svg +308 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-regular.ttf +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-regular.woff +0 -0
- package/src/ui-app/asserts/fonts/roboto/roboto-v30-latin-regular.woff2 +0 -0
- package/src/ui-app/asserts/images/background.jpg +0 -0
- package/src/ui-app/asserts/images/bg_2_0_dark_L2.png +0 -0
- package/src/ui-app/asserts/images/favicon.svg +7 -0
- package/src/ui-app/auth/App.tsx +82 -0
- package/src/ui-app/auth/commonStyles.tsx +26 -0
- package/src/ui-app/auth/components/AuthFooter.tsx +51 -0
- package/src/ui-app/auth/components/AuthLogo.tsx +58 -0
- package/src/ui-app/auth/components/ChangePasswordForm.tsx +216 -0
- package/src/ui-app/auth/components/ChangePasswordSuccessForm.tsx +38 -0
- package/src/ui-app/auth/components/LoginForm.tsx +148 -0
- package/src/ui-app/auth/components/LogoutForm.tsx +89 -0
- package/src/ui-app/auth/components/ToggleThemeButton.tsx +41 -0
- package/src/ui-app/auth/components/change-password/Bars.tsx +45 -0
- package/src/ui-app/auth/components/change-password/PasswordRequirement.tsx +14 -0
- package/src/ui-app/auth/components/change-password/requirements.tsx +6 -0
- package/src/ui-app/auth/index.html +17 -0
- package/src/ui-app/auth/main.tsx +12 -0
- package/src/ui-app/auth/routes.tsx +26 -0
- package/src/ui-app/config.ts +15 -0
- package/src/ui-app/index.html +12 -0
- package/src/ui-app/index2/App.tsx +162 -0
- package/src/ui-app/index2/AppContext.ts +3 -0
- package/src/ui-app/index2/IndexLayout.tsx +34 -0
- package/src/ui-app/index2/components/Header/HeaderIndex.tsx +248 -0
- package/src/ui-app/index2/components/Header/QuickFilter.tsx +312 -0
- package/src/ui-app/index2/components/Navbar/Items/AcceptStatusItem.tsx +42 -0
- package/src/ui-app/index2/components/Navbar/Items/BaseItemWrapper.tsx +94 -0
- package/src/ui-app/index2/components/Navbar/Items/BrowserItem.tsx +42 -0
- package/src/ui-app/index2/components/Navbar/Items/PlatformItem.tsx +42 -0
- package/src/ui-app/index2/components/Navbar/Items/RemoveItemModalAsk.tsx +71 -0
- package/src/ui-app/index2/components/Navbar/Items/RemoveItemPopover.tsx +58 -0
- package/src/ui-app/index2/components/Navbar/Items/RemoveSuiteModalAsk.tsx +61 -0
- package/src/ui-app/index2/components/Navbar/Items/RunItem.tsx +149 -0
- package/src/ui-app/index2/components/Navbar/Items/StatusItem.tsx +42 -0
- package/src/ui-app/index2/components/Navbar/Items/SuiteItem.tsx +109 -0
- package/src/ui-app/index2/components/Navbar/Items/index.tsx +6 -0
- package/src/ui-app/index2/components/Navbar/NavbarFilter.tsx +93 -0
- package/src/ui-app/index2/components/Navbar/NavbarGroupBySelect.tsx +83 -0
- package/src/ui-app/index2/components/Navbar/NavbarIndex.tsx +247 -0
- package/src/ui-app/index2/components/Navbar/NavbarItems.tsx +38 -0
- package/src/ui-app/index2/components/Navbar/NavbarSort.tsx +105 -0
- package/src/ui-app/index2/components/Navbar/Skeletons/RunsDummySkeleton.tsx +27 -0
- package/src/ui-app/index2/components/Navbar/Skeletons/SimpleDummySkeleton.tsx +23 -0
- package/src/ui-app/index2/components/Navbar/Skeletons/SkeletonWrapper.tsx +45 -0
- package/src/ui-app/index2/components/Navbar/Skeletons/SuitesDummySkeleton.tsx +27 -0
- package/src/ui-app/index2/components/Tests/Table/AcceptTestModalAsk.tsx +68 -0
- package/src/ui-app/index2/components/Tests/Table/AcceptTestsButton.tsx +44 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/Branch.tsx +35 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/BrowserName.tsx +33 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/BrowserVersion.tsx +31 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/CellWrapper.tsx +49 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/Os.tsx +32 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/StartDate.tsx +34 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/Status.tsx +50 -0
- package/src/ui-app/index2/components/Tests/Table/Cells/ViewPort.tsx +46 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/AcceptButton.tsx +142 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/Check.tsx +281 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Canvas/Canvas.tsx +36 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Canvas/helpers.ts +72 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Canvas/mainView.ts +495 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Canvas/sideToSideView.ts +398 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Canvas/simpleView.ts +21 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/CheckDetails.tsx +237 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Header.tsx +221 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/RelatedChecks/RelatedCheckItem.tsx +167 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/RelatedChecks/RelatedCheckSort.tsx +81 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/RelatedChecks/RelatedChecks.tsx +197 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/RelatedChecks/RelatedChecksItems.tsx +31 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/RelatedChecks/RelatedChecksSkeleton.tsx +37 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Toolbar/HighlightButton.tsx +56 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Toolbar/RegionsToolbar.tsx +150 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Toolbar/ScreenshotDetails.tsx +137 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Toolbar/Toolbar.tsx +101 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Toolbar/ViewSegmentedControl.tsx +159 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Toolbar/ZoomToolbar.tsx +326 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/Toolbar/highlightDiff.ts +167 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckDetails/hooks/useRelatedChecks.tsx +43 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/CheckModal.tsx +119 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/Checks.tsx +91 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/ChecksSkeleton.tsx +21 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/PreviewCheckTooltipLabel.tsx +121 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/RemoveButton.tsx +63 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/ViewPortLabel.tsx +94 -0
- package/src/ui-app/index2/components/Tests/Table/Checks/checkSizes.ts +27 -0
- package/src/ui-app/index2/components/Tests/Table/Filter.tsx +179 -0
- package/src/ui-app/index2/components/Tests/Table/Heads.tsx +54 -0
- package/src/ui-app/index2/components/Tests/Table/InfinityScrollSkeleton.tsx +71 -0
- package/src/ui-app/index2/components/Tests/Table/PagesCountAffix.tsx +61 -0
- package/src/ui-app/index2/components/Tests/Table/RefreshActionIcon.tsx +65 -0
- package/src/ui-app/index2/components/Tests/Table/RemoveTestModalAsk.tsx +66 -0
- package/src/ui-app/index2/components/Tests/Table/RemoveTestsButton.tsx +43 -0
- package/src/ui-app/index2/components/Tests/Table/Row.tsx +128 -0
- package/src/ui-app/index2/components/Tests/Table/Rows.tsx +87 -0
- package/src/ui-app/index2/components/Tests/Table/Settings.tsx +121 -0
- package/src/ui-app/index2/components/Tests/Table/TestsTable.tsx +140 -0
- package/src/ui-app/index2/components/Tests/Table/UnfoldActionIcon.tsx +39 -0
- package/src/ui-app/index2/components/Tests/Table/tableColumns.ts +80 -0
- package/src/ui-app/index2/components/Tests/Table/testsCreateStyle.tsx +35 -0
- package/src/ui-app/index2/components/Tests/Tests.tsx +157 -0
- package/src/ui-app/index2/hooks/useIndexSubpageEffect.tsx +14 -0
- package/src/ui-app/index2/hooks/useNavbarActiveItems.tsx +66 -0
- package/src/ui-app/index2/hooks/useParams.tsx +25 -0
- package/src/ui-app/index2/index.html +17 -0
- package/src/ui-app/index2/main.tsx +33 -0
- package/src/ui-app/package-lock.json +6150 -0
- package/src/ui-app/package.json +58 -0
- package/src/ui-app/shared/components/ActionPopoverIcon.tsx +116 -0
- package/src/ui-app/shared/components/Check/AcceptedStatusIcon.tsx +51 -0
- package/src/ui-app/shared/components/Check/BrowserIcon.tsx +50 -0
- package/src/ui-app/shared/components/Check/OsIcon.tsx +73 -0
- package/src/ui-app/shared/components/Check/Status.tsx +37 -0
- package/src/ui-app/shared/components/Check/StatusIcon.tsx +66 -0
- package/src/ui-app/shared/components/Email.tsx +83 -0
- package/src/ui-app/shared/components/Header/ApiKeyModalAsk.tsx +31 -0
- package/src/ui-app/shared/components/Header/ApiKeyModalResult.tsx +89 -0
- package/src/ui-app/shared/components/Header/HeaderLogo.tsx +82 -0
- package/src/ui-app/shared/components/Header/UserInfoModal.tsx +92 -0
- package/src/ui-app/shared/components/Header/UserMenu.tsx +151 -0
- package/src/ui-app/shared/components/Password.tsx +95 -0
- package/src/ui-app/shared/components/RelativeDrawer.tsx +43 -0
- package/src/ui-app/shared/components/SafeSelect.tsx +95 -0
- package/src/ui-app/shared/components/Tests/StatusesRing.tsx +66 -0
- package/src/ui-app/shared/components/ToggleThemeButton.tsx +33 -0
- package/src/ui-app/shared/components/Users/LabelUser.tsx +60 -0
- package/src/ui-app/shared/components/errors/ErrorFallback.tsx +66 -0
- package/src/ui-app/shared/components/filter/AcceptedFilter.tsx +20 -0
- package/src/ui-app/shared/components/filter/BrowserNameFilter.tsx +20 -0
- package/src/ui-app/shared/components/filter/CommonDistinctFilter.tsx +104 -0
- package/src/ui-app/shared/components/filter/DateFilter.tsx +54 -0
- package/src/ui-app/shared/components/filter/FilterWrapper.tsx +80 -0
- package/src/ui-app/shared/components/filter/IdFilter.tsx +60 -0
- package/src/ui-app/shared/components/filter/LogLevelFilter.tsx +77 -0
- package/src/ui-app/shared/components/filter/LogicalGroup.tsx +179 -0
- package/src/ui-app/shared/components/filter/OsFilter.tsx +20 -0
- package/src/ui-app/shared/components/filter/StatusFilter.tsx +20 -0
- package/src/ui-app/shared/components/filter/StringFilter.tsx +55 -0
- package/src/ui-app/shared/components/filter/index.ts +19 -0
- package/src/ui-app/shared/components/heaserLinks.tsx +4 -0
- package/src/ui-app/shared/hooks/index.ts +3 -0
- package/src/ui-app/shared/hooks/useColorSheme.ts +22 -0
- package/src/ui-app/shared/hooks/useDistinctLogQuery.tsx +33 -0
- package/src/ui-app/shared/hooks/useDistinctQuery.tsx +37 -0
- package/src/ui-app/shared/hooks/useInfinityScroll.tsx +163 -0
- package/src/ui-app/shared/hooks/useInfinityScrollRelatedChecks.tsx +60 -0
- package/src/ui-app/shared/hooks/useNavProgressFetchEffect.tsx +17 -0
- package/src/ui-app/shared/hooks/useSubpageEffect.tsx +28 -0
- package/src/ui-app/shared/hooks/user.hooks.ts +49 -0
- package/src/ui-app/shared/interfaces/ILog.tsx +13 -0
- package/src/ui-app/shared/interfaces/IUser.tsx +13 -0
- package/src/ui-app/shared/interfaces/logQueries.tsx +31 -0
- package/src/ui-app/shared/navigation/interfaces.tsx +7 -0
- package/src/ui-app/shared/navigation/navigationData.tsx +191 -0
- package/src/ui-app/shared/services/checks.service.ts +39 -0
- package/src/ui-app/shared/services/generic.service.ts +115 -0
- package/src/ui-app/shared/services/index.ts +6 -0
- package/src/ui-app/shared/services/runs.service.ts +20 -0
- package/src/ui-app/shared/services/suites.service.ts +20 -0
- package/src/ui-app/shared/services/tests.service.ts +39 -0
- package/src/ui-app/shared/services/users.service.ts +29 -0
- package/src/ui-app/shared/utils/Logger.ts +12 -0
- package/src/ui-app/shared/utils/SearchParams.ts +17 -0
- package/src/ui-app/shared/utils/filters.tsx +14 -0
- package/src/ui-app/shared/utils/index.ts +5 -0
- package/src/ui-app/shared/utils/utils.tsx +70 -0
- package/src/ui-app/stub.html +12 -0
- package/src/ui-app/stub.tsx +58 -0
- package/src/ui-app/stubDemoColors.tsx +47 -0
- package/src/ui-app/stubDemoNav.tsx +41 -0
- package/src/ui-app/tsconfig.json +21 -0
- package/src/ui-app/tsconfig.node.json +12 -0
- package/static/A.png +0 -0
- package/static/B.png +0 -0
- package/static/affected.html +39 -0
- package/static/affected_2.html +40 -0
- package/static/data/custom_devices.json +14 -0
- package/static/grids/desktop-higher.html +72 -0
- package/static/grids/desktop-wider.html +72 -0
- package/static/grids/desktop.html +61 -0
- package/static/grids/fit-in-view.html +62 -0
- package/static/js/canvasjs.min.js.bak +957 -0
- package/static/js/chart.js.bak +92 -0
- package/static/js/jquery-3.3.1.slim.js.bak +8269 -0
- package/static/js/jquery-3.3.1.slim.min.js.bak +2 -0
- package/static/js/moment.min.js.bak +2 -0
- package/static/low_diff_0.png +0 -0
- package/static/low_diff_1.png +0 -0
- package/static/vShift.png +0 -0
- package/static/vShift_bottom.png +0 -0
- package/static/vShift_top.png +0 -0
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/* eslint-disable no-param-reassign, valid-jsdoc */
|
|
2
|
+
const { EJSON } = require('bson');
|
|
3
|
+
|
|
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
|
+
} else {
|
|
35
|
+
sort = { _id: -1 };
|
|
36
|
+
}
|
|
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
|
+
|
|
43
|
+
const groupAggregateObj = { $group: { _id: `$${options.field}` } };
|
|
44
|
+
|
|
45
|
+
const documentsCount = (await this.aggregate([groupAggregateObj])
|
|
46
|
+
.exec()).length;
|
|
47
|
+
const aggregateArr = [
|
|
48
|
+
{ $match: EJSON.parse(filter.filter || '{}') },
|
|
49
|
+
groupAggregateObj,
|
|
50
|
+
{ $sort: sort },
|
|
51
|
+
{ $skip: skip },
|
|
52
|
+
{ $limit: limit },
|
|
53
|
+
];
|
|
54
|
+
const aggregatedDocs = (await this.aggregate(aggregateArr))
|
|
55
|
+
.filter((x) => x._id)
|
|
56
|
+
.map((x) => {
|
|
57
|
+
if (x[options.field]) {
|
|
58
|
+
return x[options.field][0];
|
|
59
|
+
}
|
|
60
|
+
return { name: x._id };
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
return Promise.all([documentsCount, aggregatedDocs])
|
|
64
|
+
.then((values) => {
|
|
65
|
+
const [totalResults, results] = values;
|
|
66
|
+
const totalPages = Math.ceil(totalResults / limit);
|
|
67
|
+
const result = {
|
|
68
|
+
results,
|
|
69
|
+
page,
|
|
70
|
+
limit,
|
|
71
|
+
totalPages,
|
|
72
|
+
totalResults,
|
|
73
|
+
timestamp: new Date() / 1,
|
|
74
|
+
};
|
|
75
|
+
return Promise.resolve(result);
|
|
76
|
+
});
|
|
77
|
+
};
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
module.exports = paginateDistinct;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/* eslint-disable no-param-reassign */
|
|
2
|
+
|
|
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
|
+
|
|
9
|
+
const deleteAtPath = (obj, path, index) => {
|
|
10
|
+
if (index === path.length - 1) {
|
|
11
|
+
delete obj[path[index]];
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
deleteAtPath(obj[path[index]], path, index + 1);
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
const toJSON = (schema) => {
|
|
18
|
+
let transform;
|
|
19
|
+
if (schema.options.toJSON && schema.options.toJSON.transform) {
|
|
20
|
+
transform = schema.options.toJSON.transform;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
schema.options.toJSON = Object.assign(schema.options.toJSON || {}, {
|
|
24
|
+
transform(doc, ret, options) {
|
|
25
|
+
Object.keys(schema.paths).forEach((path) => {
|
|
26
|
+
if (schema.paths[path].options && schema.paths[path].options.private) {
|
|
27
|
+
deleteAtPath(ret, path.split('.'), 0);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
ret.id = ret._id.toString();
|
|
32
|
+
// delete ret._id;
|
|
33
|
+
// eslint-disable-next-line no-underscore-dangle
|
|
34
|
+
delete ret.__v;
|
|
35
|
+
delete ret.createdAt;
|
|
36
|
+
delete ret.updatedAt;
|
|
37
|
+
if (transform) {
|
|
38
|
+
return transform(doc, ret, options);
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
module.exports = toJSON;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const httpStatus = require('http-status');
|
|
4
|
+
|
|
5
|
+
const catchAsync = require('../../utils/catchAsync');
|
|
6
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
7
|
+
const { authorization } = require('../../middlewares/authorization');
|
|
8
|
+
|
|
9
|
+
const router = express.Router();
|
|
10
|
+
|
|
11
|
+
const adminController = catchAsync(async (req, res) => {
|
|
12
|
+
res.status(httpStatus.OK)
|
|
13
|
+
.sendFile(path.normalize(path.join(`${__dirname}./../../../../mvc/views/react/admin/index.html`)));
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
router.get('*', ensureLoggedIn(),
|
|
17
|
+
authorization('admin'),
|
|
18
|
+
adminController);
|
|
19
|
+
|
|
20
|
+
module.exports = router;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const httpStatus = require('http-status');
|
|
4
|
+
|
|
5
|
+
const catchAsync = require('../../utils/catchAsync');
|
|
6
|
+
|
|
7
|
+
const router = express.Router();
|
|
8
|
+
|
|
9
|
+
const authController = catchAsync(async (req, res) => {
|
|
10
|
+
res.status(httpStatus.OK).sendFile(path.normalize(path.join(`${__dirname}./../../../../mvc/views/react/auth/index.html`)));
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
router.get('*', authController);
|
|
14
|
+
|
|
15
|
+
module.exports = router;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const httpStatus = require('http-status');
|
|
4
|
+
|
|
5
|
+
const catchAsync = require('../../utils/catchAsync');
|
|
6
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
7
|
+
|
|
8
|
+
const router = express.Router();
|
|
9
|
+
|
|
10
|
+
router.get(
|
|
11
|
+
'',
|
|
12
|
+
ensureLoggedIn(),
|
|
13
|
+
catchAsync(async (req, res) => {
|
|
14
|
+
res.status(httpStatus.OK)
|
|
15
|
+
.sendFile(path.normalize(path.join(`${__dirname}./../../../../mvc/views/react/index2/index.html`)));
|
|
16
|
+
})
|
|
17
|
+
);
|
|
18
|
+
|
|
19
|
+
module.exports = router;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const authController = require('../../controllers/auth.controller');
|
|
3
|
+
|
|
4
|
+
const router = express.Router();
|
|
5
|
+
|
|
6
|
+
router.get('/logout', authController.logout);
|
|
7
|
+
router.get('/apikey', authController.apikey);
|
|
8
|
+
router.post('/login', authController.login);
|
|
9
|
+
router.post('/change', authController.changePassword);
|
|
10
|
+
router.post('/change_first_run', authController.changePasswordFirstRun);
|
|
11
|
+
|
|
12
|
+
module.exports = router;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { baselinesController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router
|
|
8
|
+
.route('/')
|
|
9
|
+
.get(ensureLoggedIn(), baselinesController.get);
|
|
10
|
+
|
|
11
|
+
router.route('/:id')
|
|
12
|
+
.put(ensureLoggedIn(), baselinesController.put);
|
|
13
|
+
|
|
14
|
+
module.exports = router;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { checksController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router
|
|
8
|
+
.route('/')
|
|
9
|
+
.get(ensureLoggedIn(), checksController.get);
|
|
10
|
+
|
|
11
|
+
router
|
|
12
|
+
.route('/:id')
|
|
13
|
+
.delete(ensureLoggedIn(), checksController.remove);
|
|
14
|
+
|
|
15
|
+
// update
|
|
16
|
+
router.route('/:id')
|
|
17
|
+
.put(ensureLoggedIn(), checksController.update);
|
|
18
|
+
|
|
19
|
+
router.route('/accept/:id')
|
|
20
|
+
.put(ensureLoggedIn(), checksController.accept);
|
|
21
|
+
|
|
22
|
+
router.route('/get_via_post')
|
|
23
|
+
.post(ensureLoggedIn(), checksController.getViaPost);
|
|
24
|
+
|
|
25
|
+
module.exports = router;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const Bottleneck = require('bottleneck/es5');
|
|
3
|
+
const { clientController } = require('../../controllers');
|
|
4
|
+
const { ensureApiKey } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
5
|
+
|
|
6
|
+
const router = express.Router();
|
|
7
|
+
|
|
8
|
+
global.limiter.startSession = new Bottleneck({
|
|
9
|
+
maxConcurrent: 1,
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
router
|
|
13
|
+
.route('/startSession')
|
|
14
|
+
.post(ensureApiKey(),
|
|
15
|
+
async (req, res, next) => global.limiter.startSession.schedule(
|
|
16
|
+
() => clientController.startSession(req, res, next)
|
|
17
|
+
));
|
|
18
|
+
|
|
19
|
+
router
|
|
20
|
+
.route('/stopSession/:testid')
|
|
21
|
+
.post(ensureApiKey(), clientController.endSession);
|
|
22
|
+
|
|
23
|
+
router
|
|
24
|
+
.route('/createCheck')
|
|
25
|
+
.post(ensureApiKey(), clientController.createCheck);
|
|
26
|
+
|
|
27
|
+
router
|
|
28
|
+
.route('/getIdent')
|
|
29
|
+
.get(ensureApiKey(), clientController.getIdent);
|
|
30
|
+
|
|
31
|
+
router
|
|
32
|
+
.route('/baselines')
|
|
33
|
+
.get(ensureApiKey(), clientController.getBaselines);
|
|
34
|
+
|
|
35
|
+
router
|
|
36
|
+
.route('/snapshots')
|
|
37
|
+
.get(ensureApiKey(), clientController.getSnapshots);
|
|
38
|
+
|
|
39
|
+
module.exports = router;
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const authRoute = require('./auth.route');
|
|
3
|
+
const appRoute = require('./app.route');
|
|
4
|
+
const testsRoute = require('./test.route');
|
|
5
|
+
const usersRoute = require('./users.route');
|
|
6
|
+
const logsRoute = require('./logs.route');
|
|
7
|
+
const runsRoute = require('./runs.route');
|
|
8
|
+
const snapshotRoute = require('./snapshots.route');
|
|
9
|
+
const checkRoute = require('./checks.route');
|
|
10
|
+
const baselinesRoute = require('./baselines.route');
|
|
11
|
+
const suitesRoute = require('./suites.route');
|
|
12
|
+
const settingsRoute = require('./settings.route');
|
|
13
|
+
const testDistinctRoute = require('./test_distinct.route');
|
|
14
|
+
const tasksRoute = require('./tasks.route');
|
|
15
|
+
const clientRoute = require('./client.route');
|
|
16
|
+
|
|
17
|
+
const router = express.Router();
|
|
18
|
+
|
|
19
|
+
const defaultRoutes = [
|
|
20
|
+
{
|
|
21
|
+
path: '/auth',
|
|
22
|
+
route: authRoute,
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
path: '/client',
|
|
26
|
+
route: clientRoute,
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
path: '/tasks',
|
|
30
|
+
route: tasksRoute,
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
path: '/users',
|
|
34
|
+
route: usersRoute,
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
path: '/app',
|
|
38
|
+
route: appRoute,
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
path: '/tests',
|
|
42
|
+
route: testsRoute,
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
path: '/logs',
|
|
46
|
+
route: logsRoute,
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
path: '/runs',
|
|
50
|
+
route: runsRoute,
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
path: '/snapshots',
|
|
54
|
+
route: snapshotRoute,
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
path: '/checks',
|
|
58
|
+
route: checkRoute,
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
path: '/baselines',
|
|
62
|
+
route: baselinesRoute,
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
path: '/suites',
|
|
66
|
+
route: suitesRoute,
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
path: '/settings',
|
|
70
|
+
route: settingsRoute,
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
path: '/test-distinct',
|
|
74
|
+
route: testDistinctRoute,
|
|
75
|
+
},
|
|
76
|
+
];
|
|
77
|
+
|
|
78
|
+
defaultRoutes.forEach((route) => {
|
|
79
|
+
router.use(route.path, route.route);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
module.exports = router;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { logsController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router
|
|
8
|
+
.route('/')
|
|
9
|
+
.get(ensureLoggedIn(), logsController.getLogs)
|
|
10
|
+
.post(ensureLoggedIn(), logsController.createLog);
|
|
11
|
+
|
|
12
|
+
router
|
|
13
|
+
.route('/distinct')
|
|
14
|
+
.get(ensureLoggedIn(), logsController.distinct);
|
|
15
|
+
|
|
16
|
+
module.exports = router;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { runsController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router
|
|
8
|
+
.route('/')
|
|
9
|
+
.get(ensureLoggedIn(), runsController.get);
|
|
10
|
+
|
|
11
|
+
router
|
|
12
|
+
.route('/:id')
|
|
13
|
+
.delete(ensureLoggedIn(), runsController.remove);
|
|
14
|
+
|
|
15
|
+
module.exports = router;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { settingsController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
const { authorization } = require('../../middlewares/authorization');
|
|
5
|
+
|
|
6
|
+
const router = express.Router();
|
|
7
|
+
|
|
8
|
+
router
|
|
9
|
+
.route('/')
|
|
10
|
+
.get(
|
|
11
|
+
ensureLoggedIn(),
|
|
12
|
+
authorization('admin'),
|
|
13
|
+
settingsController.getSettings
|
|
14
|
+
);
|
|
15
|
+
router
|
|
16
|
+
.route('/:name')
|
|
17
|
+
.patch(
|
|
18
|
+
ensureLoggedIn(),
|
|
19
|
+
authorization('admin'),
|
|
20
|
+
settingsController.updateSetting
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
module.exports = router;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { snapshotController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router
|
|
8
|
+
.route('/')
|
|
9
|
+
.get(ensureLoggedIn(), snapshotController.get);
|
|
10
|
+
|
|
11
|
+
module.exports = router;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { suiteController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router
|
|
8
|
+
.route('/')
|
|
9
|
+
.get(ensureLoggedIn(), suiteController.get);
|
|
10
|
+
|
|
11
|
+
router
|
|
12
|
+
.route('/:id')
|
|
13
|
+
.delete(ensureLoggedIn(), suiteController.remove);
|
|
14
|
+
|
|
15
|
+
module.exports = router;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
3
|
+
const { authorization } = require('../../middlewares/authorization');
|
|
4
|
+
const { tasksController } = require('../../controllers');
|
|
5
|
+
|
|
6
|
+
const router = express.Router();
|
|
7
|
+
|
|
8
|
+
router
|
|
9
|
+
.route('/task_test')
|
|
10
|
+
.get(
|
|
11
|
+
ensureLoggedIn(),
|
|
12
|
+
authorization('admin'),
|
|
13
|
+
tasksController.task_test
|
|
14
|
+
);
|
|
15
|
+
|
|
16
|
+
router
|
|
17
|
+
.route('/task_handle_old_checks')
|
|
18
|
+
.get(
|
|
19
|
+
ensureLoggedIn(),
|
|
20
|
+
authorization('admin'),
|
|
21
|
+
tasksController.task_handle_old_checks
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
router
|
|
25
|
+
.route('/task_handle_database_consistency')
|
|
26
|
+
.get(
|
|
27
|
+
ensureLoggedIn(),
|
|
28
|
+
authorization('admin'),
|
|
29
|
+
tasksController.task_handle_database_consistency
|
|
30
|
+
);
|
|
31
|
+
|
|
32
|
+
router
|
|
33
|
+
.route('/task_remove_old_logs')
|
|
34
|
+
.get(
|
|
35
|
+
ensureLoggedIn(),
|
|
36
|
+
authorization('admin'),
|
|
37
|
+
tasksController.task_remove_old_logs
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
router
|
|
41
|
+
.route('/loadTestUser')
|
|
42
|
+
.get(
|
|
43
|
+
ensureLoggedIn(),
|
|
44
|
+
tasksController.loadTestUser
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
router
|
|
48
|
+
.route('/status')
|
|
49
|
+
.get(
|
|
50
|
+
tasksController.status
|
|
51
|
+
);
|
|
52
|
+
|
|
53
|
+
router
|
|
54
|
+
.route('/screenshots')
|
|
55
|
+
.get(
|
|
56
|
+
tasksController.screenshots
|
|
57
|
+
);
|
|
58
|
+
|
|
59
|
+
module.exports = router;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const testController = require('../../controllers/test.controller');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router.route('/')
|
|
8
|
+
.get(ensureLoggedIn(), testController.getTest);
|
|
9
|
+
|
|
10
|
+
router.route('/distinct')
|
|
11
|
+
.get(ensureLoggedIn(), testController.distinct);
|
|
12
|
+
router
|
|
13
|
+
.route('/:id')
|
|
14
|
+
.delete(ensureLoggedIn(), testController.remove);
|
|
15
|
+
|
|
16
|
+
router
|
|
17
|
+
.route('/accept/:id')
|
|
18
|
+
.put(ensureLoggedIn(), testController.accept);
|
|
19
|
+
|
|
20
|
+
module.exports = router;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { testsController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
|
|
5
|
+
const router = express.Router();
|
|
6
|
+
|
|
7
|
+
router
|
|
8
|
+
.route('/:id')
|
|
9
|
+
.get(
|
|
10
|
+
ensureLoggedIn(),
|
|
11
|
+
testsController.distinct
|
|
12
|
+
);
|
|
13
|
+
|
|
14
|
+
module.exports = router;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
const express = require('express');
|
|
2
|
+
const { userController } = require('../../controllers');
|
|
3
|
+
const { ensureLoggedIn } = require('../../lib/ensureLogin/ensureLoggedIn');
|
|
4
|
+
const { authorization } = require('../../middlewares/authorization');
|
|
5
|
+
|
|
6
|
+
const router = express.Router();
|
|
7
|
+
|
|
8
|
+
router.get('/current', userController.current);
|
|
9
|
+
|
|
10
|
+
router
|
|
11
|
+
.route('/')
|
|
12
|
+
.post(
|
|
13
|
+
ensureLoggedIn(),
|
|
14
|
+
authorization('admin'),
|
|
15
|
+
userController.createUser
|
|
16
|
+
)
|
|
17
|
+
.get(
|
|
18
|
+
ensureLoggedIn(),
|
|
19
|
+
authorization('user'),
|
|
20
|
+
userController.getUsers
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
router
|
|
24
|
+
.route('/:userId')
|
|
25
|
+
.patch(
|
|
26
|
+
ensureLoggedIn(),
|
|
27
|
+
authorization('admin'),
|
|
28
|
+
userController.updateUser
|
|
29
|
+
)
|
|
30
|
+
.delete(
|
|
31
|
+
ensureLoggedIn(),
|
|
32
|
+
authorization('admin'),
|
|
33
|
+
userController.deleteUser
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
module.exports = router;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
|
|
3
|
+
export const createCheckParamsSchema = z.object({
|
|
4
|
+
branch: z.string().min(1),
|
|
5
|
+
appName: z.string().min(1),
|
|
6
|
+
suitename: z.string().min(1),
|
|
7
|
+
testid: z.string().regex(/^[a-f0-9]{24}$/), // Regex for 24 hex characters
|
|
8
|
+
name: z.string().min(1),
|
|
9
|
+
viewport: z.string().regex(/^\d+x\d+$/), // "WidthxHeight" format
|
|
10
|
+
browserName: z.string().min(1),
|
|
11
|
+
browserVersion: z.string().min(1),
|
|
12
|
+
browserFullVersion: z.string(),
|
|
13
|
+
os: z.string().min(1),
|
|
14
|
+
hashcode: z.string().length(128) // Assuming hashcode is always 128 chars length
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
export type createCheckParam = z.infer<typeof createCheckParamsSchema>;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
|
|
3
|
+
export const RequiredIdentOptionsSchema = z.object({
|
|
4
|
+
name: z.string().min(1),
|
|
5
|
+
viewport: z.string().min(3),
|
|
6
|
+
browserName: z.string().min(1),
|
|
7
|
+
os: z.string().min(1),
|
|
8
|
+
app: z.string().min(1),
|
|
9
|
+
branch: z.string().min(1),
|
|
10
|
+
})
|
|
11
|
+
|
|
12
|
+
export type RequiredIdentOptions = z.infer<typeof RequiredIdentOptionsSchema>;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/* eslint-disable valid-jsdoc */
|
|
2
|
+
const { App } = require('../models');
|
|
3
|
+
|
|
4
|
+
const $this = this;
|
|
5
|
+
$this.logMeta = {
|
|
6
|
+
scope: 'logs_service',
|
|
7
|
+
msgType: 'LOG',
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Query for users
|
|
12
|
+
* @param {Object} filter - Mongo filter
|
|
13
|
+
* @param {Object} options - Query options
|
|
14
|
+
* @param {string} [options.sortBy] - Sort option in the format: sortField:(desc|asc)
|
|
15
|
+
* @param {number} [options.limit] - Maximum number of results per page (default = 10)
|
|
16
|
+
* @param {number} [options.page] - Current page (default = 1)
|
|
17
|
+
* @returns {Promise<QueryResult>}
|
|
18
|
+
*/
|
|
19
|
+
const get = async (filter, options) => App.paginate(filter, options);
|
|
20
|
+
|
|
21
|
+
module.exports = {
|
|
22
|
+
get,
|
|
23
|
+
};
|