unleash-server 5.4.4 → 5.5.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 +5 -3
- package/dist/lib/addons/addon-schema.js +2 -1
- package/dist/lib/addons/addon-schema.js.map +1 -1
- package/dist/lib/addons/datadog-definition.js +22 -7
- package/dist/lib/addons/datadog-definition.js.map +1 -1
- package/dist/lib/addons/datadog.d.ts +7 -1
- package/dist/lib/addons/datadog.js +16 -3
- package/dist/lib/addons/datadog.js.map +1 -1
- package/dist/lib/addons/datadog.test.js +62 -0
- package/dist/lib/addons/datadog.test.js.map +1 -1
- package/dist/lib/addons/index.js +3 -11
- package/dist/lib/addons/index.js.map +1 -1
- package/dist/lib/addons/slack-app-definition.js +5 -24
- package/dist/lib/addons/slack-app-definition.js.map +1 -1
- package/dist/lib/addons/slack-app.d.ts +0 -1
- package/dist/lib/addons/slack-app.js +5 -17
- package/dist/lib/addons/slack-app.js.map +1 -1
- package/dist/lib/addons/slack-app.test.js +39 -25
- package/dist/lib/addons/slack-app.test.js.map +1 -1
- package/dist/lib/addons/slack-definition.js +11 -4
- package/dist/lib/addons/slack-definition.js.map +1 -1
- package/dist/lib/addons/teams-definition.js +5 -4
- package/dist/lib/addons/teams-definition.js.map +1 -1
- package/dist/lib/addons/webhook-definition.js +10 -12
- package/dist/lib/addons/webhook-definition.js.map +1 -1
- package/dist/lib/create-config.js +13 -1
- package/dist/lib/create-config.js.map +1 -1
- package/dist/lib/create-config.test.js +14 -0
- package/dist/lib/create-config.test.js.map +1 -1
- package/dist/lib/db/access-store.d.ts +23 -5
- package/dist/lib/db/access-store.js +263 -17
- package/dist/lib/db/access-store.js.map +1 -1
- package/dist/lib/db/access-store.test.js +83 -0
- package/dist/lib/db/access-store.test.js.map +1 -0
- package/dist/lib/db/client-applications-store.d.ts +1 -3
- package/dist/lib/db/client-applications-store.js +13 -24
- package/dist/lib/db/client-applications-store.js.map +1 -1
- package/dist/lib/db/event-store.js +1 -0
- package/dist/lib/db/event-store.js.map +1 -1
- package/dist/lib/db/feature-toggle-client-store.js +17 -4
- package/dist/lib/db/feature-toggle-client-store.js.map +1 -1
- package/dist/lib/db/feature-toggle-store.js +1 -1
- package/dist/lib/db/feature-toggle-store.js.map +1 -1
- package/dist/lib/db/group-store.d.ts +4 -2
- package/dist/lib/db/group-store.js +24 -0
- package/dist/lib/db/group-store.js.map +1 -1
- package/dist/lib/db/index.d.ts +1 -2
- package/dist/lib/db/index.js +5 -1
- package/dist/lib/db/index.js.map +1 -1
- package/dist/lib/db/project-stats-store.d.ts +2 -0
- package/dist/lib/db/project-stats-store.js +27 -0
- package/dist/lib/db/project-stats-store.js.map +1 -1
- package/dist/lib/db/project-store.d.ts +7 -1
- package/dist/lib/db/project-store.js +34 -1
- package/dist/lib/db/project-store.js.map +1 -1
- package/dist/lib/error/bad-data-error.d.ts +1 -1
- package/dist/lib/error/index.d.ts +2 -1
- package/dist/lib/error/index.js +3 -1
- package/dist/lib/error/index.js.map +1 -1
- package/dist/lib/error/pattern-error.d.ts +10 -0
- package/dist/lib/error/pattern-error.js +20 -0
- package/dist/lib/error/pattern-error.js.map +1 -0
- package/dist/lib/features/dependent-features/createDependentFeaturesService.d.ts +3 -0
- package/dist/lib/features/dependent-features/createDependentFeaturesService.js +11 -0
- package/dist/lib/features/dependent-features/createDependentFeaturesService.js.map +1 -0
- package/dist/lib/features/dependent-features/dependent-features-controller.d.ts +28 -0
- package/dist/lib/features/dependent-features/dependent-features-controller.js +151 -0
- package/dist/lib/features/dependent-features/dependent-features-controller.js.map +1 -0
- package/dist/lib/features/dependent-features/dependent-features-service.d.ts +11 -0
- package/dist/lib/features/dependent-features/dependent-features-service.js +40 -0
- package/dist/lib/features/dependent-features/dependent-features-service.js.map +1 -0
- package/dist/lib/features/dependent-features/dependent-features-store-type.d.ts +8 -0
- package/dist/lib/features/dependent-features/dependent-features-store-type.js +3 -0
- package/dist/lib/features/dependent-features/dependent-features-store-type.js.map +1 -0
- package/dist/lib/features/dependent-features/dependent-features-store.d.ts +12 -0
- package/dist/lib/features/dependent-features/dependent-features-store.js +56 -0
- package/dist/lib/features/dependent-features/dependent-features-store.js.map +1 -0
- package/dist/lib/features/dependent-features/dependent-features.d.ts +14 -0
- package/dist/lib/features/dependent-features/dependent-features.js +3 -0
- package/dist/lib/features/dependent-features/dependent-features.js.map +1 -0
- package/dist/lib/features/dependent-features/dependent.features.e2e.test.d.ts +1 -0
- package/dist/lib/features/dependent-features/dependent.features.e2e.test.js +82 -0
- package/dist/lib/features/dependent-features/dependent.features.e2e.test.js.map +1 -0
- package/dist/lib/features/dependent-features/fake-dependent-features-store.d.ts +8 -0
- package/dist/lib/features/dependent-features/fake-dependent-features-store.js +22 -0
- package/dist/lib/features/dependent-features/fake-dependent-features-store.js.map +1 -0
- package/dist/lib/features/export-import-toggles/createExportImportService.js +6 -3
- package/dist/lib/features/export-import-toggles/createExportImportService.js.map +1 -1
- package/dist/lib/features/export-import-toggles/export-import-service.d.ts +9 -3
- package/dist/lib/features/export-import-toggles/export-import-service.js +51 -21
- package/dist/lib/features/export-import-toggles/export-import-service.js.map +1 -1
- package/dist/lib/features/export-import-toggles/export-import.e2e.test.js +120 -50
- package/dist/lib/features/export-import-toggles/export-import.e2e.test.js.map +1 -1
- package/dist/lib/features/export-import-toggles/import-permissions-service.d.ts +1 -2
- package/dist/lib/features/export-import-toggles/import-toggles-store-type.d.ts +6 -0
- package/dist/lib/features/export-import-toggles/import-toggles-store.d.ts +2 -1
- package/dist/lib/features/export-import-toggles/import-toggles-store.js +25 -0
- package/dist/lib/features/export-import-toggles/import-toggles-store.js.map +1 -1
- package/dist/lib/features/export-import-toggles/import-validation-messages.d.ts +18 -2
- package/dist/lib/features/export-import-toggles/import-validation-messages.js +27 -11
- package/dist/lib/features/export-import-toggles/import-validation-messages.js.map +1 -1
- package/dist/lib/features/feature-naming-pattern/feature-naming-validation.d.ts +14 -0
- package/dist/lib/features/feature-naming-pattern/feature-naming-validation.js +46 -0
- package/dist/lib/features/feature-naming-pattern/feature-naming-validation.js.map +1 -0
- package/dist/lib/features/feature-naming-pattern/feature-naming-validation.test.d.ts +1 -0
- package/dist/lib/features/feature-naming-pattern/feature-naming-validation.test.js +116 -0
- package/dist/lib/features/feature-naming-pattern/feature-naming-validation.test.js.map +1 -0
- package/dist/lib/features/feature-toggle/createFeatureToggleService.js +11 -2
- package/dist/lib/features/feature-toggle/createFeatureToggleService.js.map +1 -1
- package/dist/lib/features/instance-stats/getActiveUsers.d.ts +9 -0
- package/dist/lib/features/instance-stats/getActiveUsers.e2e.test.d.ts +1 -0
- package/dist/lib/features/instance-stats/getActiveUsers.e2e.test.js +141 -0
- package/dist/lib/features/instance-stats/getActiveUsers.e2e.test.js.map +1 -0
- package/dist/lib/features/instance-stats/getActiveUsers.js +33 -0
- package/dist/lib/features/instance-stats/getActiveUsers.js.map +1 -0
- package/dist/lib/{services → features/instance-stats}/instance-stats-service.d.ts +13 -7
- package/dist/lib/{services → features/instance-stats}/instance-stats-service.js +16 -7
- package/dist/lib/features/instance-stats/instance-stats-service.js.map +1 -0
- package/dist/lib/features/instance-stats/instance-stats-service.test.d.ts +1 -0
- package/dist/lib/{services → features/instance-stats}/instance-stats-service.test.js +6 -5
- package/dist/lib/features/instance-stats/instance-stats-service.test.js.map +1 -0
- package/dist/lib/features/playground/advanced-playground.test.js +2 -3
- package/dist/lib/features/playground/advanced-playground.test.js.map +1 -1
- package/dist/lib/features/playground/feature-evaluator/variant.d.ts +1 -1
- package/dist/lib/features/playground/generateObjectCombinations.d.ts +1 -1
- package/dist/lib/features/playground/generateObjectCombinations.js +14 -4
- package/dist/lib/features/playground/generateObjectCombinations.js.map +1 -1
- package/dist/lib/features/playground/generateObjectCombinations.test.js +21 -0
- package/dist/lib/features/playground/generateObjectCombinations.test.js.map +1 -1
- package/dist/lib/features/playground/playground-service.d.ts +5 -3
- package/dist/lib/features/playground/playground-service.js +18 -3
- package/dist/lib/features/playground/playground-service.js.map +1 -1
- package/dist/lib/features/playground/playground.d.ts +2 -1
- package/dist/lib/features/playground/playground.js +2 -1
- package/dist/lib/features/playground/playground.js.map +1 -1
- package/dist/lib/features/private-project/createPrivateProjectChecker.d.ts +5 -0
- package/dist/lib/features/private-project/createPrivateProjectChecker.js +22 -0
- package/dist/lib/features/private-project/createPrivateProjectChecker.js.map +1 -0
- package/dist/lib/features/private-project/fakePrivateProjectChecker.d.ts +7 -0
- package/dist/lib/features/private-project/fakePrivateProjectChecker.js +15 -0
- package/dist/lib/features/private-project/fakePrivateProjectChecker.js.map +1 -0
- package/dist/lib/features/private-project/privateProjectChecker.d.ts +10 -0
- package/dist/lib/features/private-project/privateProjectChecker.js +22 -0
- package/dist/lib/features/private-project/privateProjectChecker.js.map +1 -0
- package/dist/lib/features/private-project/privateProjectCheckerType.d.ts +5 -0
- package/dist/lib/features/private-project/privateProjectCheckerType.js +3 -0
- package/dist/lib/features/private-project/privateProjectCheckerType.js.map +1 -0
- package/dist/lib/features/private-project/privateProjectStore.d.ts +18 -0
- package/dist/lib/features/private-project/privateProjectStore.js +70 -0
- package/dist/lib/features/private-project/privateProjectStore.js.map +1 -0
- package/dist/lib/features/private-project/privateProjectStoreType.d.ts +4 -0
- package/dist/lib/features/private-project/privateProjectStoreType.js +3 -0
- package/dist/lib/features/private-project/privateProjectStoreType.js.map +1 -0
- package/dist/lib/features/project/createProjectService.js +5 -8
- package/dist/lib/features/project/createProjectService.js.map +1 -1
- package/dist/lib/features/segment/createSegmentService.js +5 -2
- package/dist/lib/features/segment/createSegmentService.js.map +1 -1
- package/dist/lib/features/segment/segment-controller.d.ts +39 -0
- package/dist/lib/features/segment/segment-controller.js +291 -0
- package/dist/lib/features/segment/segment-controller.js.map +1 -0
- package/dist/lib/metrics.d.ts +1 -1
- package/dist/lib/metrics.js +30 -1
- package/dist/lib/metrics.js.map +1 -1
- package/dist/lib/metrics.test.js +3 -2
- package/dist/lib/metrics.test.js.map +1 -1
- package/dist/lib/middleware/rbac-middleware.d.ts +2 -0
- package/dist/lib/middleware/rbac-middleware.js +2 -0
- package/dist/lib/middleware/rbac-middleware.js.map +1 -1
- package/dist/lib/middleware/secure-headers.js +18 -0
- package/dist/lib/middleware/secure-headers.js.map +1 -1
- package/dist/lib/openapi/index.js +13 -0
- package/dist/lib/openapi/index.js.map +1 -1
- package/dist/lib/openapi/meta-schema-rules.test.js +14 -4
- package/dist/lib/openapi/meta-schema-rules.test.js.map +1 -1
- package/dist/lib/openapi/spec/addon-type-schema.d.ts +6 -1
- package/dist/lib/openapi/spec/addon-type-schema.js +6 -1
- package/dist/lib/openapi/spec/addon-type-schema.js.map +1 -1
- package/dist/lib/openapi/spec/addons-schema.d.ts +8 -3
- package/dist/lib/openapi/spec/addons-schema.js +8 -3
- package/dist/lib/openapi/spec/addons-schema.js.map +1 -1
- package/dist/lib/openapi/spec/admin-segment-schema.d.ts +115 -0
- package/dist/lib/openapi/spec/admin-segment-schema.js +75 -0
- package/dist/lib/openapi/spec/admin-segment-schema.js.map +1 -0
- package/dist/lib/openapi/spec/admin-segment-schema.test.d.ts +1 -0
- package/dist/lib/openapi/spec/admin-segment-schema.test.js +39 -0
- package/dist/lib/openapi/spec/admin-segment-schema.test.js.map +1 -0
- package/dist/lib/openapi/spec/admin-strategies-schema.d.ts +46 -0
- package/dist/lib/openapi/spec/admin-strategies-schema.js +54 -0
- package/dist/lib/openapi/spec/admin-strategies-schema.js.map +1 -0
- package/dist/lib/openapi/spec/admin-strategies-schema.test.d.ts +1 -0
- package/dist/lib/openapi/spec/admin-strategies-schema.test.js +40 -0
- package/dist/lib/openapi/spec/admin-strategies-schema.test.js.map +1 -0
- package/dist/lib/openapi/spec/advanced-playground-environment-feature-schema.d.ts +51 -6
- package/dist/lib/openapi/spec/advanced-playground-environment-feature-schema.js +3 -1
- package/dist/lib/openapi/spec/advanced-playground-environment-feature-schema.js.map +1 -1
- package/dist/lib/openapi/spec/advanced-playground-feature-schema.d.ts +101 -11
- package/dist/lib/openapi/spec/advanced-playground-feature-schema.js +2 -0
- package/dist/lib/openapi/spec/advanced-playground-feature-schema.js.map +1 -1
- package/dist/lib/openapi/spec/advanced-playground-request-schema.d.ts +1 -0
- package/dist/lib/openapi/spec/advanced-playground-response-schema.d.ts +203 -22
- package/dist/lib/openapi/spec/advanced-playground-response-schema.js +2 -0
- package/dist/lib/openapi/spec/advanced-playground-response-schema.js.map +1 -1
- package/dist/lib/openapi/spec/client-feature-schema.d.ts +41 -6
- package/dist/lib/openapi/spec/client-feature-schema.js +9 -0
- package/dist/lib/openapi/spec/client-feature-schema.js.map +1 -1
- package/dist/lib/openapi/spec/client-features-schema.d.ts +75 -12
- package/dist/lib/openapi/spec/client-features-schema.js +2 -0
- package/dist/lib/openapi/spec/client-features-schema.js.map +1 -1
- package/dist/lib/openapi/spec/context-field-strategies-schema.d.ts +1 -1
- package/dist/lib/openapi/spec/context-field-strategies-schema.js +1 -1
- package/dist/lib/openapi/spec/context-field-strategies-schema.js.map +1 -1
- package/dist/lib/openapi/spec/create-api-token-schema.d.ts +1 -139
- package/dist/lib/openapi/spec/create-api-token-schema.js +16 -20
- package/dist/lib/openapi/spec/create-api-token-schema.js.map +1 -1
- package/dist/lib/openapi/spec/create-dependent-feature-schema.d.ts +29 -0
- package/dist/lib/openapi/spec/create-dependent-feature-schema.js +31 -0
- package/dist/lib/openapi/spec/create-dependent-feature-schema.js.map +1 -0
- package/dist/lib/openapi/spec/create-feature-naming-pattern-schema.d.ts +29 -0
- package/dist/lib/openapi/spec/create-feature-naming-pattern-schema.js +33 -0
- package/dist/lib/openapi/spec/create-feature-naming-pattern-schema.js.map +1 -0
- package/dist/lib/openapi/spec/create-feature-strategy-schema.d.ts +2 -2
- package/dist/lib/openapi/spec/create-strategy-schema.d.ts +15 -0
- package/dist/lib/openapi/spec/create-strategy-schema.js +15 -0
- package/dist/lib/openapi/spec/create-strategy-schema.js.map +1 -1
- package/dist/lib/openapi/spec/create-strategy-variant-schema.d.ts +2 -2
- package/dist/lib/openapi/spec/create-strategy-variant-schema.js +2 -2
- package/dist/lib/openapi/spec/create-strategy-variant-schema.js.map +1 -1
- package/dist/lib/openapi/spec/dependent-feature-schema.d.ts +30 -0
- package/dist/lib/openapi/spec/dependent-feature-schema.js +14 -0
- package/dist/lib/openapi/spec/dependent-feature-schema.js.map +1 -0
- package/dist/lib/openapi/spec/dora-features-schema.d.ts +20 -0
- package/dist/lib/openapi/spec/dora-features-schema.js +22 -0
- package/dist/lib/openapi/spec/dora-features-schema.js.map +1 -0
- package/dist/lib/openapi/spec/environment-project-schema.d.ts +4 -4
- package/dist/lib/openapi/spec/environments-project-schema.d.ts +4 -4
- package/dist/lib/openapi/spec/event-schema.d.ts +3 -3
- package/dist/lib/openapi/spec/events-schema.d.ts +3 -3
- package/dist/lib/openapi/spec/export-query-schema.d.ts +22 -15
- package/dist/lib/openapi/spec/export-query-schema.js +16 -15
- package/dist/lib/openapi/spec/export-query-schema.js.map +1 -1
- package/dist/lib/openapi/spec/export-result-schema.d.ts +26 -26
- package/dist/lib/openapi/spec/feature-environment-schema.d.ts +6 -6
- package/dist/lib/openapi/spec/feature-events-schema.d.ts +3 -3
- package/dist/lib/openapi/spec/feature-schema.d.ts +12 -12
- package/dist/lib/openapi/spec/feature-strategy-schema.d.ts +2 -2
- package/dist/lib/openapi/spec/feature-variants-schema.d.ts +2 -2
- package/dist/lib/openapi/spec/features-schema.d.ts +24 -24
- package/dist/lib/openapi/spec/health-overview-schema.d.ts +63 -33
- package/dist/lib/openapi/spec/health-overview-schema.js +6 -1
- package/dist/lib/openapi/spec/health-overview-schema.js.map +1 -1
- package/dist/lib/openapi/spec/health-report-schema.d.ts +63 -33
- package/dist/lib/openapi/spec/import-toggles-schema.d.ts +52 -52
- package/dist/lib/openapi/spec/index.d.ts +9 -0
- package/dist/lib/openapi/spec/index.js +9 -0
- package/dist/lib/openapi/spec/index.js.map +1 -1
- package/dist/lib/openapi/spec/instance-admin-stats-schema.d.ts +42 -0
- package/dist/lib/openapi/spec/instance-admin-stats-schema.js +42 -0
- package/dist/lib/openapi/spec/instance-admin-stats-schema.js.map +1 -1
- package/dist/lib/openapi/spec/parent-feature-options-schema.d.ts +11 -0
- package/dist/lib/openapi/spec/parent-feature-options-schema.js +13 -0
- package/dist/lib/openapi/spec/parent-feature-options-schema.js.map +1 -0
- package/dist/lib/openapi/spec/playground-feature-schema.d.ts +5 -5
- package/dist/lib/openapi/spec/playground-request-schema.d.ts +1 -0
- package/dist/lib/openapi/spec/playground-response-schema.d.ts +12 -10
- package/dist/lib/openapi/spec/playground-strategy-schema.d.ts +4 -4
- package/dist/lib/openapi/spec/playground-strategy-schema.js +1 -1
- package/dist/lib/openapi/spec/playground-strategy-schema.js.map +1 -1
- package/dist/lib/openapi/spec/profile-schema.d.ts +12 -12
- package/dist/lib/openapi/spec/project-dora-metrics-schema.d.ts +44 -0
- package/dist/lib/openapi/spec/project-dora-metrics-schema.js +28 -0
- package/dist/lib/openapi/spec/project-dora-metrics-schema.js.map +1 -0
- package/dist/lib/openapi/spec/project-environment-schema.d.ts +4 -4
- package/dist/lib/openapi/spec/project-overview-schema.d.ts +63 -33
- package/dist/lib/openapi/spec/project-overview-schema.js +6 -1
- package/dist/lib/openapi/spec/project-overview-schema.js.map +1 -1
- package/dist/lib/openapi/spec/project-schema.d.ts +1 -1
- package/dist/lib/openapi/spec/project-schema.js +1 -1
- package/dist/lib/openapi/spec/project-schema.js.map +1 -1
- package/dist/lib/openapi/spec/projects-schema.d.ts +1 -1
- package/dist/lib/openapi/spec/push-variants-schema.d.ts +2 -2
- package/dist/lib/openapi/spec/sdk-context-schema.d.ts +1 -0
- package/dist/lib/openapi/spec/sdk-context-schema.js +1 -0
- package/dist/lib/openapi/spec/sdk-context-schema.js.map +1 -1
- package/dist/lib/openapi/spec/sdk-flat-context-schema.d.ts +46 -0
- package/dist/lib/openapi/spec/sdk-flat-context-schema.js +15 -0
- package/dist/lib/openapi/spec/sdk-flat-context-schema.js.map +1 -0
- package/dist/lib/openapi/spec/search-events-schema.d.ts +1 -1
- package/dist/lib/openapi/spec/segments-schema.d.ts +177 -0
- package/dist/lib/openapi/spec/segments-schema.js +26 -0
- package/dist/lib/openapi/spec/segments-schema.js.map +1 -0
- package/dist/lib/openapi/spec/segments-schema.test.d.ts +1 -0
- package/dist/lib/openapi/spec/segments-schema.test.js +16 -0
- package/dist/lib/openapi/spec/segments-schema.test.js.map +1 -0
- package/dist/lib/openapi/spec/state-schema.d.ts +23 -23
- package/dist/lib/openapi/spec/strategy-variant-schema.d.ts +2 -2
- package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.d.ts +35 -0
- package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.js +37 -0
- package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.js.map +1 -0
- package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.test.d.ts +1 -0
- package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.test.js +19 -0
- package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.test.js.map +1 -0
- package/dist/lib/openapi/spec/upsert-segment-schema.d.ts +8 -15
- package/dist/lib/openapi/spec/upsert-segment-schema.js +8 -17
- package/dist/lib/openapi/spec/upsert-segment-schema.js.map +1 -1
- package/dist/lib/openapi/spec/upsert-segment-schema.test.d.ts +1 -0
- package/dist/lib/openapi/spec/upsert-segment-schema.test.js +35 -0
- package/dist/lib/openapi/spec/upsert-segment-schema.test.js.map +1 -0
- package/dist/lib/openapi/spec/validate-feature-schema.d.ts +6 -0
- package/dist/lib/openapi/spec/validate-feature-schema.js +6 -0
- package/dist/lib/openapi/spec/validate-feature-schema.js.map +1 -1
- package/dist/lib/openapi/spec/variant-schema.d.ts +2 -2
- package/dist/lib/openapi/spec/variant-schema.js +2 -2
- package/dist/lib/openapi/spec/variant-schema.js.map +1 -1
- package/dist/lib/openapi/spec/variants-schema.d.ts +2 -2
- package/dist/lib/openapi/util/all-of.d.ts +3 -0
- package/dist/lib/openapi/util/all-of.js +34 -0
- package/dist/lib/openapi/util/all-of.js.map +1 -0
- package/dist/lib/openapi/util/openapi-tags.d.ts +46 -58
- package/dist/lib/openapi/util/openapi-tags.js +27 -34
- package/dist/lib/openapi/util/openapi-tags.js.map +1 -1
- package/dist/lib/openapi/util/openapi-tags.test.d.ts +1 -0
- package/dist/lib/openapi/util/openapi-tags.test.js +15 -0
- package/dist/lib/openapi/util/openapi-tags.test.js.map +1 -0
- package/dist/lib/openapi/validate.js +0 -1
- package/dist/lib/openapi/validate.js.map +1 -1
- package/dist/lib/routes/admin-api/archive.d.ts +1 -1
- package/dist/lib/routes/admin-api/archive.js +3 -2
- package/dist/lib/routes/admin-api/archive.js.map +1 -1
- package/dist/lib/routes/admin-api/context.js +2 -1
- package/dist/lib/routes/admin-api/context.js.map +1 -1
- package/dist/lib/routes/admin-api/feature.js +2 -1
- package/dist/lib/routes/admin-api/feature.js.map +1 -1
- package/dist/lib/routes/admin-api/index.js +2 -0
- package/dist/lib/routes/admin-api/index.js.map +1 -1
- package/dist/lib/routes/admin-api/instance-admin.d.ts +2 -2
- package/dist/lib/routes/admin-api/instance-admin.js +7 -1
- package/dist/lib/routes/admin-api/instance-admin.js.map +1 -1
- package/dist/lib/routes/admin-api/metrics.d.ts +2 -1
- package/dist/lib/routes/admin-api/metrics.js +2 -1
- package/dist/lib/routes/admin-api/metrics.js.map +1 -1
- package/dist/lib/routes/admin-api/project/api-token.d.ts +2 -1
- package/dist/lib/routes/admin-api/project/api-token.js +12 -3
- package/dist/lib/routes/admin-api/project/api-token.js.map +1 -1
- package/dist/lib/routes/admin-api/project/environments.d.ts +2 -1
- package/dist/lib/routes/admin-api/project/environments.js +3 -1
- package/dist/lib/routes/admin-api/project/environments.js.map +1 -1
- package/dist/lib/routes/admin-api/project/index.d.ts +2 -1
- package/dist/lib/routes/admin-api/project/index.js +31 -0
- package/dist/lib/routes/admin-api/project/index.js.map +1 -1
- package/dist/lib/routes/admin-api/strategy.d.ts +1 -1
- package/dist/lib/routes/admin-api/strategy.js.map +1 -1
- package/dist/lib/routes/client-api/metrics.js +14 -8
- package/dist/lib/routes/client-api/metrics.js.map +1 -1
- package/dist/lib/routes/client-api/metrics.test.js +27 -0
- package/dist/lib/routes/client-api/metrics.test.js.map +1 -1
- package/dist/lib/routes/controller.d.ts +1 -1
- package/dist/lib/routes/controller.js +17 -10
- package/dist/lib/routes/controller.js.map +1 -1
- package/dist/lib/routes/proxy-api/index.js +5 -0
- package/dist/lib/routes/proxy-api/index.js.map +1 -1
- package/dist/lib/schema/role-schema.js +3 -1
- package/dist/lib/schema/role-schema.js.map +1 -1
- package/dist/lib/schema/role-schema.test.js +1 -1
- package/dist/lib/schema/role-schema.test.js.map +1 -1
- package/dist/lib/segments/segment-service-interface.d.ts +1 -1
- package/dist/lib/services/access-service.d.ts +29 -11
- package/dist/lib/services/access-service.js +53 -10
- package/dist/lib/services/access-service.js.map +1 -1
- package/dist/lib/services/access-service.test.js +2 -1
- package/dist/lib/services/access-service.test.js.map +1 -1
- package/dist/lib/services/addon-service.js +4 -2
- package/dist/lib/services/addon-service.js.map +1 -1
- package/dist/lib/services/addon-service.test.js +65 -0
- package/dist/lib/services/addon-service.test.js.map +1 -1
- package/dist/lib/services/client-metrics/instance-service.d.ts +5 -2
- package/dist/lib/services/client-metrics/instance-service.js +22 -3
- package/dist/lib/services/client-metrics/instance-service.js.map +1 -1
- package/dist/lib/services/client-metrics/instance-service.test.js +5 -4
- package/dist/lib/services/client-metrics/instance-service.test.js.map +1 -1
- package/dist/lib/services/context-service.d.ts +6 -2
- package/dist/lib/services/context-service.js +16 -2
- package/dist/lib/services/context-service.js.map +1 -1
- package/dist/lib/services/feature-service-potentially-stale.test.js +1 -1
- package/dist/lib/services/feature-service-potentially-stale.test.js.map +1 -1
- package/dist/lib/services/feature-toggle-service.d.ts +20 -7
- package/dist/lib/services/feature-toggle-service.js +105 -41
- package/dist/lib/services/feature-toggle-service.js.map +1 -1
- package/dist/lib/services/group-service.d.ts +4 -4
- package/dist/lib/services/group-service.js +17 -16
- package/dist/lib/services/group-service.js.map +1 -1
- package/dist/lib/services/index.d.ts +3 -2
- package/dist/lib/services/index.js +31 -17
- package/dist/lib/services/index.js.map +1 -1
- package/dist/lib/services/project-schema.js +9 -1
- package/dist/lib/services/project-schema.js.map +1 -1
- package/dist/lib/services/project-service.d.ts +16 -12
- package/dist/lib/services/project-service.js +127 -17
- package/dist/lib/services/project-service.js.map +1 -1
- package/dist/lib/services/scheduler-service.d.ts +1 -1
- package/dist/lib/services/scheduler-service.js +3 -3
- package/dist/lib/services/scheduler-service.js.map +1 -1
- package/dist/lib/services/scheduler-service.test.js +15 -15
- package/dist/lib/services/scheduler-service.test.js.map +1 -1
- package/dist/lib/services/segment-service.d.ts +4 -2
- package/dist/lib/services/segment-service.js +17 -10
- package/dist/lib/services/segment-service.js.map +1 -1
- package/dist/lib/services/state-service.test.js +13 -3
- package/dist/lib/services/state-service.test.js.map +1 -1
- package/dist/lib/services/version-service.test.js +3 -0
- package/dist/lib/services/version-service.test.js.map +1 -1
- package/dist/lib/types/events.d.ts +60 -1
- package/dist/lib/types/events.js +65 -3
- package/dist/lib/types/events.js.map +1 -1
- package/dist/lib/types/experimental.d.ts +1 -1
- package/dist/lib/types/experimental.js +9 -5
- package/dist/lib/types/experimental.js.map +1 -1
- package/dist/lib/types/group.d.ts +2 -2
- package/dist/lib/types/model.d.ts +31 -2
- package/dist/lib/types/model.js.map +1 -1
- package/dist/lib/types/no-auth-user.d.ts +1 -0
- package/dist/lib/types/no-auth-user.js +3 -1
- package/dist/lib/types/no-auth-user.js.map +1 -1
- package/dist/lib/types/option.d.ts +7 -0
- package/dist/lib/types/services.d.ts +6 -1
- package/dist/lib/types/stores/access-store.d.ts +23 -4
- package/dist/lib/types/stores/feature-strategies-store.d.ts +2 -1
- package/dist/lib/types/stores/group-store.d.ts +4 -2
- package/dist/lib/types/stores/project-stats-store-type.d.ts +2 -0
- package/dist/lib/types/stores/project-store.d.ts +7 -14
- package/dist/lib/types/stores/strategy-store.d.ts +3 -17
- package/dist/lib/types/stores.d.ts +5 -1
- package/dist/lib/util/findDuplicates.d.ts +1 -0
- package/dist/lib/util/findDuplicates.js +18 -0
- package/dist/lib/util/findDuplicates.js.map +1 -0
- package/dist/lib/util/findDuplicates.test.d.ts +1 -0
- package/dist/lib/util/findDuplicates.test.js +23 -0
- package/dist/lib/util/findDuplicates.test.js.map +1 -0
- package/dist/migrations/20230830121352-update-client-applications-usage-table.d.ts +2 -0
- package/dist/migrations/20230830121352-update-client-applications-usage-table.js +16 -0
- package/dist/migrations/20230830121352-update-client-applications-usage-table.js.map +1 -0
- package/dist/migrations/20230905122605-add-feature-naming-description.d.ts +2 -0
- package/dist/migrations/20230905122605-add-feature-naming-description.js +13 -0
- package/dist/migrations/20230905122605-add-feature-naming-description.js.map +1 -0
- package/dist/migrations/20230919104006-dependent-features.d.ts +2 -0
- package/dist/migrations/20230919104006-dependent-features.js +21 -0
- package/dist/migrations/20230919104006-dependent-features.js.map +1 -0
- package/dist/migrations/20230927071830-reset-pnps-feedback.d.ts +2 -0
- package/dist/migrations/20230927071830-reset-pnps-feedback.js +10 -0
- package/dist/migrations/20230927071830-reset-pnps-feedback.js.map +1 -0
- package/dist/server-dev.js +7 -4
- package/dist/server-dev.js.map +1 -1
- package/dist/test/e2e/api/admin/addon.e2e.test.js +0 -1
- package/dist/test/e2e/api/admin/addon.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/api-token.auth.e2e.test.js +8 -12
- package/dist/test/e2e/api/admin/api-token.auth.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/event.e2e.test.js +9 -2
- package/dist/test/e2e/api/admin/event.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/metrics.e2e.test.js +2 -10
- package/dist/test/e2e/api/admin/metrics.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/project/environments.e2e.test.js +8 -0
- package/dist/test/e2e/api/admin/project/environments.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/project/features.e2e.test.js +41 -15
- package/dist/test/e2e/api/admin/project/features.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/project/project.api.tokens.e2e.test.js +30 -3
- package/dist/test/e2e/api/admin/project/project.api.tokens.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/segment.e2e.test.d.ts +1 -0
- package/dist/test/e2e/api/admin/segment.e2e.test.js +272 -0
- package/dist/test/e2e/api/admin/segment.e2e.test.js.map +1 -0
- package/dist/test/e2e/api/admin/state.e2e.test.js +0 -11
- package/dist/test/e2e/api/admin/state.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/strategy.e2e.test.js +1 -1
- package/dist/test/e2e/api/client/feature.e2e.test.js +27 -3
- package/dist/test/e2e/api/client/feature.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/client/feature.token.access.e2e.test.js +2 -2
- package/dist/test/e2e/api/client/feature.token.access.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/client/segment.e2e.test.js +1 -1
- package/dist/test/e2e/api/client/segment.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/proxy/proxy.e2e.test.js +34 -9
- package/dist/test/e2e/api/proxy/proxy.e2e.test.js.map +1 -1
- package/dist/test/e2e/helpers/app.utils.d.ts +6 -0
- package/dist/test/e2e/helpers/app.utils.js +16 -0
- package/dist/test/e2e/helpers/app.utils.js.map +1 -0
- package/dist/test/e2e/helpers/database.json +24 -0
- package/dist/test/e2e/services/access-service.e2e.test.js +549 -135
- package/dist/test/e2e/services/access-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/api-token-service.e2e.test.js +4 -2
- package/dist/test/e2e/services/api-token-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/client-metrics-service.e2e.test.js +2 -1
- package/dist/test/e2e/services/client-metrics-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/feature-toggle-service-v2.e2e.test.js +38 -5
- package/dist/test/e2e/services/feature-toggle-service-v2.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/group-service.e2e.test.js +16 -11
- package/dist/test/e2e/services/group-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/playground-service.test.js +5 -2
- package/dist/test/e2e/services/playground-service.test.js.map +1 -1
- package/dist/test/e2e/services/project-health-service.e2e.test.js +4 -2
- package/dist/test/e2e/services/project-health-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/project-service.e2e.test.js +242 -60
- package/dist/test/e2e/services/project-service.e2e.test.js.map +1 -1
- package/dist/test/fixtures/access-service-mock.d.ts +3 -4
- package/dist/test/fixtures/access-service-mock.js.map +1 -1
- package/dist/test/fixtures/fake-access-store.d.ts +15 -5
- package/dist/test/fixtures/fake-access-store.js +30 -3
- package/dist/test/fixtures/fake-access-store.js.map +1 -1
- package/dist/test/fixtures/fake-group-store.d.ts +4 -2
- package/dist/test/fixtures/fake-group-store.js +3 -0
- package/dist/test/fixtures/fake-group-store.js.map +1 -1
- package/dist/test/fixtures/fake-project-stats-store.d.ts +1 -0
- package/dist/test/fixtures/fake-project-stats-store.js +3 -0
- package/dist/test/fixtures/fake-project-stats-store.js.map +1 -1
- package/dist/test/fixtures/fake-project-store.d.ts +2 -1
- package/dist/test/fixtures/fake-project-store.js +3 -0
- package/dist/test/fixtures/fake-project-store.js.map +1 -1
- package/dist/test/fixtures/no-logger.d.ts +2 -1
- package/dist/test/fixtures/no-logger.js +8 -4
- package/dist/test/fixtures/no-logger.js.map +1 -1
- package/dist/test/fixtures/store.js +3 -0
- package/dist/test/fixtures/store.js.map +1 -1
- package/frontend/README.md +7 -1
- package/frontend/build/index.html +2 -2
- package/frontend/build/static/{AdvancedPlayground-1748fcdd.js → AdvancedPlayground-20059178.js} +11 -11
- package/frontend/build/static/CreateProject-6955728f.js +4 -0
- package/frontend/build/static/{Error-cbce6b64.js → Error-f56339ab.js} +1 -1
- package/frontend/build/static/FeatureArchiveDialog-33dc3a5b.js +10 -0
- package/frontend/build/static/{FeatureMetricsChart-8fd8a304.js → FeatureMetricsChart-5ad514bc.js} +2 -2
- package/frontend/build/static/FeatureViewLazyExport-85a68ed0.js +7 -0
- package/frontend/build/static/LazyAdminExport-e2677758.js +35 -0
- package/frontend/build/static/LazyProjectExport-969bb54e.js +24 -0
- package/frontend/build/static/Logo-android-218bddbb.svg +1 -0
- package/frontend/build/static/Logo-flutter-cc3c706f.svg +1 -0
- package/frontend/build/static/Logo-go-02475b3d.svg +1 -0
- package/frontend/build/static/Logo-java-6e556b26.svg +1 -0
- package/frontend/build/static/Logo-javascript-caebc06e.svg +1 -0
- package/frontend/build/static/Logo-net-0a33abee.svg +1 -0
- package/frontend/build/static/Logo-node-318ed025.svg +1 -0
- package/frontend/build/static/Logo-php-201f18c3.svg +1 -0
- package/frontend/build/static/Logo-python-4305760e.svg +1 -0
- package/frontend/build/static/Logo-react-18e98687.svg +1 -0
- package/frontend/build/static/Logo-ruby-58f46832.svg +1 -0
- package/frontend/build/static/Logo-rust-c83a80f9.svg +1 -0
- package/frontend/build/static/Logo-svelte-97dcb624.svg +1 -0
- package/frontend/build/static/Logo-swift-315f842b.svg +5 -0
- package/frontend/build/static/Logo-vue-0de73099.svg +1 -0
- package/frontend/build/static/{NetworkOverview-349a7bdd.js → NetworkOverview-894877e6.js} +2 -2
- package/frontend/build/static/{NetworkTraffic-60478e50.js → NetworkTraffic-81eff1ae.js} +1 -1
- package/frontend/build/static/ReactJSONEditor-59c8a094.js +129 -0
- package/frontend/build/static/RoleCell-35857d41.js +1 -0
- package/frontend/build/static/{StrategyItemContainer-a4caeace.js → StrategyItemContainer-b250f2d4.js} +1 -1
- package/frontend/build/static/{chartjs-adapter-date-fns.esm-03d2fbea.js → chartjs-adapter-date-fns.esm-c51fe022.js} +1 -1
- package/frontend/build/static/cr-db7653ac.png +0 -0
- package/frontend/build/static/datadog-543762b6.svg +5 -0
- package/frontend/build/static/edge-daisy-chaining-012bfdef.svg +48 -0
- package/frontend/build/static/edge-mode-5d25949b.svg +22 -0
- package/frontend/build/static/edge-offline-f6a0f761.svg +19 -0
- package/frontend/build/static/{flowchart-elk-definition-170a3958-fc100c77.js → flowchart-elk-definition-170a3958-a8c4a86a.js} +1 -1
- package/frontend/build/static/{index-866f9bf9.js → index-0515f416.js} +1 -1
- package/frontend/build/static/index-942e9eeb.js +463 -0
- package/frontend/build/static/{index-3c63138f.js → index-a59b2d65.js} +1 -1
- package/frontend/build/static/{is_dark-31c253e9.js → is_dark-464961a8.js} +1 -1
- package/frontend/build/static/jira-1abe7cbf.svg +17 -0
- package/frontend/build/static/{mindmap-definition-44684416-398682f9.js → mindmap-definition-44684416-3a71a9a5.js} +1 -1
- package/frontend/build/static/slack-36ce798a.svg +18 -0
- package/frontend/build/static/style-97d3ef98.css +1 -0
- package/frontend/build/static/teams-4e30b51f.svg +45 -0
- package/frontend/build/static/{timeline-definition-8e5a9bc6-04a0ae08.js → timeline-definition-8e5a9bc6-da4ebc88.js} +1 -1
- package/frontend/build/static/{unknownify-b8618d88.js → unknownify-3563456b.js} +1 -1
- package/frontend/build/static/unleash-integration-949d8966.svg +1 -0
- package/frontend/build/static/webhooks-b1b44207.svg +16 -0
- package/frontend/package.json +20 -18
- package/package.json +23 -23
- package/dist/lib/services/instance-stats-service.js.map +0 -1
- package/dist/lib/services/instance-stats-service.test.js.map +0 -1
- package/frontend/build/static/CreateProject-972fa820.js +0 -4
- package/frontend/build/static/FeatureArchiveDialog-8a281845.js +0 -10
- package/frontend/build/static/FeatureViewLazyExport-a215d53b.js +0 -7
- package/frontend/build/static/LazyAdminExport-ba7d55ca.js +0 -35
- package/frontend/build/static/LazyProjectExport-12bccd40.js +0 -17
- package/frontend/build/static/RoleCell-144e7eca.js +0 -1
- package/frontend/build/static/datadog-591b6a73.svg +0 -1
- package/frontend/build/static/index-17d74ac9.js +0 -454
- package/frontend/build/static/slack-c0af31c6.svg +0 -1
- package/frontend/build/static/style-770afaee.css +0 -1
- package/frontend/build/static/teams-62e72076.svg +0 -26
- package/frontend/build/static/webhooks-ffa904ac.svg +0 -1
- /package/dist/lib/{services/instance-stats-service.test.d.ts → db/access-store.test.d.ts} +0 -0
- /package/frontend/build/static/{jira-d9eb9af9.svg → jira-comment-d9eb9af9.svg} +0 -0
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ALL_PROJECT_ACCESS = void 0;
|
|
4
|
+
const types_1 = require("../../types");
|
|
5
|
+
exports.ALL_PROJECT_ACCESS = {
|
|
6
|
+
mode: 'all',
|
|
7
|
+
};
|
|
8
|
+
class PrivateProjectStore {
|
|
9
|
+
constructor(db, getLogger) {
|
|
10
|
+
this.db = db;
|
|
11
|
+
this.logger = getLogger('project-permission-store.ts');
|
|
12
|
+
}
|
|
13
|
+
destroy() { }
|
|
14
|
+
async getUserAccessibleProjects(userId) {
|
|
15
|
+
if (userId === types_1.ADMIN_TOKEN_ID) {
|
|
16
|
+
return exports.ALL_PROJECT_ACCESS;
|
|
17
|
+
}
|
|
18
|
+
const isViewer = await this.db('role_user')
|
|
19
|
+
.join('roles', 'role_user.role_id', 'roles.id')
|
|
20
|
+
.where('role_user.user_id', userId)
|
|
21
|
+
.andWhere({
|
|
22
|
+
'roles.name': 'Viewer',
|
|
23
|
+
'roles.type': 'root',
|
|
24
|
+
})
|
|
25
|
+
.count('*')
|
|
26
|
+
.first();
|
|
27
|
+
if (!isViewer || isViewer.count == 0) {
|
|
28
|
+
return exports.ALL_PROJECT_ACCESS;
|
|
29
|
+
}
|
|
30
|
+
const accessibleProjects = await this.db
|
|
31
|
+
.from((db) => {
|
|
32
|
+
db.distinct()
|
|
33
|
+
.select('projects.id as project_id')
|
|
34
|
+
.from('projects')
|
|
35
|
+
.leftJoin('project_settings', 'projects.id', 'project_settings.project')
|
|
36
|
+
.where((builder) => {
|
|
37
|
+
builder
|
|
38
|
+
.whereNull('project_settings.project')
|
|
39
|
+
.orWhere('project_settings.project_mode', '!=', 'private');
|
|
40
|
+
})
|
|
41
|
+
.unionAll((queryBuilder) => {
|
|
42
|
+
queryBuilder
|
|
43
|
+
.select('projects.id as project_id')
|
|
44
|
+
.from('projects')
|
|
45
|
+
.join('project_settings', 'projects.id', 'project_settings.project')
|
|
46
|
+
.where('project_settings.project_mode', '=', 'private')
|
|
47
|
+
.whereIn('projects.id', (whereBuilder) => {
|
|
48
|
+
whereBuilder
|
|
49
|
+
.select('role_user.project')
|
|
50
|
+
.from('role_user')
|
|
51
|
+
.leftJoin('roles', 'role_user.role_id', 'roles.id')
|
|
52
|
+
.where('role_user.user_id', userId);
|
|
53
|
+
})
|
|
54
|
+
.orWhereIn('projects.id', (whereBuilder) => {
|
|
55
|
+
whereBuilder
|
|
56
|
+
.select('group_role.project')
|
|
57
|
+
.from('group_role')
|
|
58
|
+
.leftJoin('group_user', 'group_user.group_id', 'group_role.group_id')
|
|
59
|
+
.where('group_user.user_id', userId);
|
|
60
|
+
});
|
|
61
|
+
})
|
|
62
|
+
.as('accessible_projects');
|
|
63
|
+
})
|
|
64
|
+
.select('*')
|
|
65
|
+
.pluck('project_id');
|
|
66
|
+
return { mode: 'limited', projects: accessibleProjects };
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
exports.default = PrivateProjectStore;
|
|
70
|
+
//# sourceMappingURL=privateProjectStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"privateProjectStore.js","sourceRoot":"","sources":["../../../../src/lib/features/private-project/privateProjectStore.ts"],"names":[],"mappings":";;;AAGA,uCAA6C;AAWhC,QAAA,kBAAkB,GAAkB;IAC7C,IAAI,EAAE,KAAK;CACd,CAAC;AAEF,MAAM,mBAAmB;IAKrB,YAAY,EAAM,EAAE,SAAsB;QACtC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,6BAA6B,CAAC,CAAC;IAC3D,CAAC;IAED,OAAO,KAAU,CAAC;IAElB,KAAK,CAAC,yBAAyB,CAAC,MAAc;QAC1C,IAAI,MAAM,KAAK,sBAAc,EAAE;YAC3B,OAAO,0BAAkB,CAAC;SAC7B;QACD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC;aACtC,IAAI,CAAC,OAAO,EAAE,mBAAmB,EAAE,UAAU,CAAC;aAC9C,KAAK,CAAC,mBAAmB,EAAE,MAAM,CAAC;aAClC,QAAQ,CAAC;YACN,YAAY,EAAE,QAAQ;YACtB,YAAY,EAAE,MAAM;SACvB,CAAC;aACD,KAAK,CAAC,GAAG,CAAC;aACV,KAAK,EAAE,CAAC;QAEb,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,KAAK,IAAI,CAAC,EAAE;YAClC,OAAO,0BAAkB,CAAC;SAC7B;QAED,MAAM,kBAAkB,GAAa,MAAM,IAAI,CAAC,EAAE;aAC7C,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE;YACT,EAAE,CAAC,QAAQ,EAAE;iBACR,MAAM,CAAC,2BAA2B,CAAC;iBACnC,IAAI,CAAC,UAAU,CAAC;iBAChB,QAAQ,CACL,kBAAkB,EAClB,aAAa,EACb,0BAA0B,CAC7B;iBACA,KAAK,CAAC,CAAC,OAAO,EAAE,EAAE;gBACf,OAAO;qBACF,SAAS,CAAC,0BAA0B,CAAC;qBACrC,OAAO,CACJ,+BAA+B,EAC/B,IAAI,EACJ,SAAS,CACZ,CAAC;YACV,CAAC,CAAC;iBACD,QAAQ,CAAC,CAAC,YAAY,EAAE,EAAE;gBACvB,YAAY;qBACP,MAAM,CAAC,2BAA2B,CAAC;qBACnC,IAAI,CAAC,UAAU,CAAC;qBAChB,IAAI,CACD,kBAAkB,EAClB,aAAa,EACb,0BAA0B,CAC7B;qBACA,KAAK,CACF,+BAA+B,EAC/B,GAAG,EACH,SAAS,CACZ;qBACA,OAAO,CAAC,aAAa,EAAE,CAAC,YAAY,EAAE,EAAE;oBACrC,YAAY;yBACP,MAAM,CAAC,mBAAmB,CAAC;yBAC3B,IAAI,CAAC,WAAW,CAAC;yBACjB,QAAQ,CACL,OAAO,EACP,mBAAmB,EACnB,UAAU,CACb;yBACA,KAAK,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAC;gBAC5C,CAAC,CAAC;qBACD,SAAS,CAAC,aAAa,EAAE,CAAC,YAAY,EAAE,EAAE;oBACvC,YAAY;yBACP,MAAM,CAAC,oBAAoB,CAAC;yBAC5B,IAAI,CAAC,YAAY,CAAC;yBAClB,QAAQ,CACL,YAAY,EACZ,qBAAqB,EACrB,qBAAqB,CACxB;yBACA,KAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,CAAC;gBAC7C,CAAC,CAAC,CAAC;YACX,CAAC,CAAC;iBACD,EAAE,CAAC,qBAAqB,CAAC,CAAC;QACnC,CAAC,CAAC;aACD,MAAM,CAAC,GAAG,CAAC;aACX,KAAK,CAAC,YAAY,CAAC,CAAC;QAEzB,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,kBAAkB,EAAE,CAAC;IAC7D,CAAC;CACJ;AAED,kBAAe,mBAAmB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"privateProjectStoreType.js","sourceRoot":"","sources":["../../../../src/lib/features/private-project/privateProjectStoreType.ts"],"names":[],"mappings":""}
|
|
@@ -15,7 +15,6 @@ const project_store_1 = __importDefault(require("../../db/project-store"));
|
|
|
15
15
|
const feature_toggle_store_1 = __importDefault(require("../../db/feature-toggle-store"));
|
|
16
16
|
const feature_type_store_1 = __importDefault(require("../../db/feature-type-store"));
|
|
17
17
|
const feature_environment_store_1 = require("../../db/feature-environment-store");
|
|
18
|
-
const feature_tag_store_1 = __importDefault(require("../../db/feature-tag-store"));
|
|
19
18
|
const project_stats_store_1 = __importDefault(require("../../db/project-stats-store"));
|
|
20
19
|
const createAccessService_1 = require("../access/createAccessService");
|
|
21
20
|
const createFeatureToggleService_1 = require("../feature-toggle/createFeatureToggleService");
|
|
@@ -26,11 +25,11 @@ const fake_feature_toggle_store_1 = __importDefault(require("../../../test/fixtu
|
|
|
26
25
|
const fake_feature_type_store_1 = __importDefault(require("../../../test/fixtures/fake-feature-type-store"));
|
|
27
26
|
const fake_environment_store_1 = __importDefault(require("../../../test/fixtures/fake-environment-store"));
|
|
28
27
|
const fake_feature_environment_store_1 = __importDefault(require("../../../test/fixtures/fake-feature-environment-store"));
|
|
29
|
-
const fake_feature_tag_store_1 = __importDefault(require("../../../test/fixtures/fake-feature-tag-store"));
|
|
30
28
|
const fake_project_stats_store_1 = __importDefault(require("../../../test/fixtures/fake-project-stats-store"));
|
|
31
29
|
const fake_favorite_features_store_1 = __importDefault(require("../../../test/fixtures/fake-favorite-features-store"));
|
|
32
30
|
const fake_favorite_projects_store_1 = __importDefault(require("../../../test/fixtures/fake-favorite-projects-store"));
|
|
33
31
|
const fake_account_store_1 = require("../../../test/fixtures/fake-account-store");
|
|
32
|
+
const createPrivateProjectChecker_1 = require("../private-project/createPrivateProjectChecker");
|
|
34
33
|
const createProjectService = (db, config) => {
|
|
35
34
|
const { eventBus, getLogger, flagResolver } = config;
|
|
36
35
|
const eventStore = new event_store_1.default(db, getLogger);
|
|
@@ -41,7 +40,6 @@ const createProjectService = (db, config) => {
|
|
|
41
40
|
const accountStore = new account_store_1.AccountStore(db, getLogger);
|
|
42
41
|
const environmentStore = new environment_store_1.default(db, eventBus, getLogger);
|
|
43
42
|
const featureEnvironmentStore = new feature_environment_store_1.FeatureEnvironmentStore(db, eventBus, getLogger);
|
|
44
|
-
const featureTagStore = new feature_tag_store_1.default(db, eventBus, getLogger);
|
|
45
43
|
const projectStatsStore = new project_stats_store_1.default(db, eventBus, getLogger);
|
|
46
44
|
const accessService = (0, createAccessService_1.createAccessService)(db, config);
|
|
47
45
|
const featureToggleService = (0, createFeatureToggleService_1.createFeatureToggleService)(db, config);
|
|
@@ -53,6 +51,7 @@ const createProjectService = (db, config) => {
|
|
|
53
51
|
eventStore,
|
|
54
52
|
}, config);
|
|
55
53
|
const groupService = new services_1.GroupService({ groupStore, eventStore, accountStore }, { getLogger });
|
|
54
|
+
const privateProjectChecker = (0, createPrivateProjectChecker_1.createPrivateProjectChecker)(db, config);
|
|
56
55
|
return new services_1.ProjectService({
|
|
57
56
|
projectStore,
|
|
58
57
|
eventStore,
|
|
@@ -60,10 +59,9 @@ const createProjectService = (db, config) => {
|
|
|
60
59
|
featureTypeStore,
|
|
61
60
|
environmentStore,
|
|
62
61
|
featureEnvironmentStore,
|
|
63
|
-
featureTagStore,
|
|
64
62
|
accountStore,
|
|
65
63
|
projectStatsStore,
|
|
66
|
-
}, config, accessService, featureToggleService, groupService, favoriteService);
|
|
64
|
+
}, config, accessService, featureToggleService, groupService, favoriteService, privateProjectChecker);
|
|
67
65
|
};
|
|
68
66
|
exports.createProjectService = createProjectService;
|
|
69
67
|
const createFakeProjectService = (config) => {
|
|
@@ -76,7 +74,6 @@ const createFakeProjectService = (config) => {
|
|
|
76
74
|
const accountStore = new fake_account_store_1.FakeAccountStore();
|
|
77
75
|
const environmentStore = new fake_environment_store_1.default();
|
|
78
76
|
const featureEnvironmentStore = new fake_feature_environment_store_1.default();
|
|
79
|
-
const featureTagStore = new fake_feature_tag_store_1.default();
|
|
80
77
|
const projectStatsStore = new fake_project_stats_store_1.default();
|
|
81
78
|
const accessService = (0, createAccessService_1.createFakeAccessService)(config);
|
|
82
79
|
const featureToggleService = (0, createFeatureToggleService_1.createFakeFeatureToggleService)(config);
|
|
@@ -88,6 +85,7 @@ const createFakeProjectService = (config) => {
|
|
|
88
85
|
eventStore,
|
|
89
86
|
}, config);
|
|
90
87
|
const groupService = new services_1.GroupService({ groupStore, eventStore, accountStore }, { getLogger });
|
|
88
|
+
const privateProjectChecker = (0, createPrivateProjectChecker_1.createFakePrivateProjectChecker)();
|
|
91
89
|
return new services_1.ProjectService({
|
|
92
90
|
projectStore,
|
|
93
91
|
eventStore,
|
|
@@ -95,10 +93,9 @@ const createFakeProjectService = (config) => {
|
|
|
95
93
|
featureTypeStore,
|
|
96
94
|
environmentStore,
|
|
97
95
|
featureEnvironmentStore,
|
|
98
|
-
featureTagStore,
|
|
99
96
|
accountStore,
|
|
100
97
|
projectStatsStore,
|
|
101
|
-
}, config, accessService, featureToggleService, groupService, favoriteService);
|
|
98
|
+
}, config, accessService, featureToggleService, groupService, favoriteService, privateProjectChecker);
|
|
102
99
|
};
|
|
103
100
|
exports.createFakeProjectService = createFakeProjectService;
|
|
104
101
|
//# sourceMappingURL=createProjectService.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createProjectService.js","sourceRoot":"","sources":["../../../../src/lib/features/project/createProjectService.ts"],"names":[],"mappings":";;;;;;AACA,uEAA8C;AAC9C,uEAA8C;AAC9C,0DAAsD;AACtD,mFAA0D;AAC1D,6CAKwB;AACxB,+FAAqE;AACrE,+FAAqE;AACrE,2EAAkD;AAClD,yFAA+D;AAC/D,qFAA2D;AAC3D,kFAA6E;AAC7E,
|
|
1
|
+
{"version":3,"file":"createProjectService.js","sourceRoot":"","sources":["../../../../src/lib/features/project/createProjectService.ts"],"names":[],"mappings":"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"}
|
|
@@ -12,13 +12,15 @@ const segment_store_1 = __importDefault(require("../../db/segment-store"));
|
|
|
12
12
|
const fake_segment_store_1 = __importDefault(require("../../../test/fixtures/fake-segment-store"));
|
|
13
13
|
const fake_feature_strategies_store_1 = __importDefault(require("../../../test/fixtures/fake-feature-strategies-store"));
|
|
14
14
|
const createChangeRequestAccessReadModel_1 = require("../change-request-access-service/createChangeRequestAccessReadModel");
|
|
15
|
+
const createPrivateProjectChecker_1 = require("../private-project/createPrivateProjectChecker");
|
|
15
16
|
const createSegmentService = (db, config) => {
|
|
16
17
|
const { eventBus, getLogger, flagResolver } = config;
|
|
17
18
|
const eventStore = new event_store_1.default(db, getLogger);
|
|
18
19
|
const segmentStore = new segment_store_1.default(db, eventBus, getLogger, flagResolver);
|
|
19
20
|
const featureStrategiesStore = new feature_strategy_store_1.default(db, eventBus, getLogger, flagResolver);
|
|
20
21
|
const changeRequestAccessReadModel = (0, createChangeRequestAccessReadModel_1.createChangeRequestAccessReadModel)(db, config);
|
|
21
|
-
|
|
22
|
+
const privateProjectChecker = (0, createPrivateProjectChecker_1.createPrivateProjectChecker)(db, config);
|
|
23
|
+
return new services_1.SegmentService({ segmentStore, featureStrategiesStore, eventStore }, changeRequestAccessReadModel, config, privateProjectChecker);
|
|
22
24
|
};
|
|
23
25
|
exports.createSegmentService = createSegmentService;
|
|
24
26
|
const createFakeSegmentService = (config) => {
|
|
@@ -26,7 +28,8 @@ const createFakeSegmentService = (config) => {
|
|
|
26
28
|
const segmentStore = new fake_segment_store_1.default();
|
|
27
29
|
const featureStrategiesStore = new fake_feature_strategies_store_1.default();
|
|
28
30
|
const changeRequestAccessReadModel = (0, createChangeRequestAccessReadModel_1.createFakeChangeRequestAccessService)();
|
|
29
|
-
|
|
31
|
+
const privateProjectChecker = (0, createPrivateProjectChecker_1.createFakePrivateProjectChecker)();
|
|
32
|
+
return new services_1.SegmentService({ segmentStore, featureStrategiesStore, eventStore }, changeRequestAccessReadModel, config, privateProjectChecker);
|
|
30
33
|
};
|
|
31
34
|
exports.createFakeSegmentService = createFakeSegmentService;
|
|
32
35
|
//# sourceMappingURL=createSegmentService.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createSegmentService.js","sourceRoot":"","sources":["../../../../src/lib/features/segment/createSegmentService.ts"],"names":[],"mappings":";;;;;;AACA,uEAA8C;AAC9C,6CAAgD;AAChD,+FAAqE;AAErE,6FAAqE;AACrE,2EAAkD;AAClD,mGAAyE;AACzE,yHAA8F;AAC9F,4HAG6E;
|
|
1
|
+
{"version":3,"file":"createSegmentService.js","sourceRoot":"","sources":["../../../../src/lib/features/segment/createSegmentService.ts"],"names":[],"mappings":";;;;;;AACA,uEAA8C;AAC9C,6CAAgD;AAChD,+FAAqE;AAErE,6FAAqE;AACrE,2EAAkD;AAClD,mGAAyE;AACzE,yHAA8F;AAC9F,4HAG6E;AAC7E,gGAGwD;AAEjD,MAAM,oBAAoB,GAAG,CAChC,EAAM,EACN,MAAsB,EACR,EAAE;IAChB,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC;IACrD,MAAM,UAAU,GAAG,IAAI,qBAAU,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;IACjD,MAAM,YAAY,GAAG,IAAI,uBAAY,CACjC,EAAE,EACF,QAAQ,EACR,SAAS,EACT,YAAY,CACf,CAAC;IACF,MAAM,sBAAsB,GAAG,IAAI,gCAAsB,CACrD,EAAE,EACF,QAAQ,EACR,SAAS,EACT,YAAY,CACf,CAAC;IACF,MAAM,4BAA4B,GAAG,IAAA,uEAAkC,EACnE,EAAE,EACF,MAAM,CACT,CAAC;IACF,MAAM,qBAAqB,GAAG,IAAA,yDAA2B,EAAC,EAAE,EAAE,MAAM,CAAC,CAAC;IAEtE,OAAO,IAAI,yBAAc,CACrB,EAAE,YAAY,EAAE,sBAAsB,EAAE,UAAU,EAAE,EACpD,4BAA4B,EAC5B,MAAM,EACN,qBAAqB,CACxB,CAAC;AACN,CAAC,CAAC;AA9BW,QAAA,oBAAoB,wBA8B/B;AAEK,MAAM,wBAAwB,GAAG,CACpC,MAAsB,EACP,EAAE;IACjB,MAAM,UAAU,GAAG,IAAI,0BAAc,EAAE,CAAC;IACxC,MAAM,YAAY,GAAG,IAAI,4BAAgB,EAAE,CAAC;IAC5C,MAAM,sBAAsB,GAAG,IAAI,uCAA0B,EAAE,CAAC;IAChE,MAAM,4BAA4B,GAAG,IAAA,yEAAoC,GAAE,CAAC;IAE5E,MAAM,qBAAqB,GAAG,IAAA,6DAA+B,GAAE,CAAC;IAEhE,OAAO,IAAI,yBAAc,CACrB,EAAE,YAAY,EAAE,sBAAsB,EAAE,UAAU,EAAE,EACpD,4BAA4B,EAC5B,MAAM,EACN,qBAAqB,CACxB,CAAC;AACN,CAAC,CAAC;AAhBW,QAAA,wBAAwB,4BAgBnC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Request, Response } from 'express';
|
|
2
|
+
import Controller from '../../routes/controller';
|
|
3
|
+
import { IAuthRequest, IUnleashConfig, IUnleashServices } from '../../server-impl';
|
|
4
|
+
import { AdminSegmentSchema, UpdateFeatureStrategySegmentsSchema, UpsertSegmentSchema } from '../../openapi';
|
|
5
|
+
import { SegmentStrategiesSchema } from '../../openapi/spec/admin-strategies-schema';
|
|
6
|
+
import { SegmentsSchema } from '../../openapi/spec/segments-schema';
|
|
7
|
+
declare type IUpdateFeatureStrategySegmentsRequest = IAuthRequest<{}, undefined, UpdateFeatureStrategySegmentsSchema>;
|
|
8
|
+
export declare class SegmentsController extends Controller {
|
|
9
|
+
private logger;
|
|
10
|
+
private segmentService;
|
|
11
|
+
private accessService;
|
|
12
|
+
private flagResolver;
|
|
13
|
+
private openApiService;
|
|
14
|
+
constructor(config: IUnleashConfig, { segmentService, accessService, openApiService, }: Pick<IUnleashServices, 'segmentService' | 'accessService' | 'openApiService'>);
|
|
15
|
+
validate(req: Request<unknown, unknown, {
|
|
16
|
+
name: string;
|
|
17
|
+
}>, res: Response): Promise<void>;
|
|
18
|
+
getSegmentsByStrategy(req: Request<{
|
|
19
|
+
strategyId: string;
|
|
20
|
+
}>, res: Response<SegmentsSchema>): Promise<void>;
|
|
21
|
+
updateFeatureStrategySegments(req: IUpdateFeatureStrategySegmentsRequest, res: Response<UpdateFeatureStrategySegmentsSchema>): Promise<void>;
|
|
22
|
+
getStrategiesBySegment(req: IAuthRequest<{
|
|
23
|
+
id: number;
|
|
24
|
+
}>, res: Response<SegmentStrategiesSchema>): Promise<void>;
|
|
25
|
+
removeSegment(req: IAuthRequest<{
|
|
26
|
+
id: string;
|
|
27
|
+
}>, res: Response): Promise<void>;
|
|
28
|
+
updateSegment(req: IAuthRequest<{
|
|
29
|
+
id: string;
|
|
30
|
+
}>, res: Response): Promise<void>;
|
|
31
|
+
getSegment(req: Request<{
|
|
32
|
+
id: string;
|
|
33
|
+
}>, res: Response): Promise<void>;
|
|
34
|
+
createSegment(req: IAuthRequest<any, any, UpsertSegmentSchema>, res: Response<AdminSegmentSchema>): Promise<void>;
|
|
35
|
+
getSegments(req: IAuthRequest, res: Response<SegmentsSchema>): Promise<void>;
|
|
36
|
+
private removeFromStrategy;
|
|
37
|
+
private addToStrategy;
|
|
38
|
+
}
|
|
39
|
+
export {};
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SegmentsController = void 0;
|
|
7
|
+
const controller_1 = __importDefault(require("../../routes/controller"));
|
|
8
|
+
const openapi_1 = require("../../openapi");
|
|
9
|
+
const standard_responses_1 = require("../../openapi/util/standard-responses");
|
|
10
|
+
const types_1 = require("../../types");
|
|
11
|
+
const segments_schema_1 = require("../../openapi/spec/segments-schema");
|
|
12
|
+
const util_1 = require("../../util");
|
|
13
|
+
const error_1 = require("../../error");
|
|
14
|
+
class SegmentsController extends controller_1.default {
|
|
15
|
+
constructor(config, { segmentService, accessService, openApiService, }) {
|
|
16
|
+
super(config);
|
|
17
|
+
this.flagResolver = config.flagResolver;
|
|
18
|
+
this.config = config;
|
|
19
|
+
this.logger = config.getLogger('/admin-api/segments.ts');
|
|
20
|
+
this.segmentService = segmentService;
|
|
21
|
+
this.accessService = accessService;
|
|
22
|
+
this.openApiService = openApiService;
|
|
23
|
+
this.route({
|
|
24
|
+
method: 'post',
|
|
25
|
+
path: '/validate',
|
|
26
|
+
handler: this.validate,
|
|
27
|
+
permission: types_1.NONE,
|
|
28
|
+
middleware: [
|
|
29
|
+
openApiService.validPath({
|
|
30
|
+
summary: 'Validates if a segment name exists',
|
|
31
|
+
description: 'Uses the name provided in the body of the request to validate if the given name exists or not',
|
|
32
|
+
tags: ['Segments'],
|
|
33
|
+
operationId: 'validateSegment',
|
|
34
|
+
requestBody: (0, openapi_1.createRequestSchema)('nameSchema'),
|
|
35
|
+
responses: {
|
|
36
|
+
204: standard_responses_1.emptyResponse,
|
|
37
|
+
...(0, standard_responses_1.getStandardResponses)(400, 401, 409, 415),
|
|
38
|
+
},
|
|
39
|
+
}),
|
|
40
|
+
],
|
|
41
|
+
});
|
|
42
|
+
this.route({
|
|
43
|
+
method: 'get',
|
|
44
|
+
path: '/strategies/:strategyId',
|
|
45
|
+
handler: this.getSegmentsByStrategy,
|
|
46
|
+
permission: types_1.NONE,
|
|
47
|
+
middleware: [
|
|
48
|
+
openApiService.validPath({
|
|
49
|
+
tags: ['Segments'],
|
|
50
|
+
operationId: 'getSegmentsByStrategyId',
|
|
51
|
+
summary: 'Get strategy segments',
|
|
52
|
+
description: "Retrieve all segments that are referenced by the specified strategy. Returns an empty list of segments if the strategy ID doesn't exist.",
|
|
53
|
+
responses: {
|
|
54
|
+
200: (0, openapi_1.createResponseSchema)('segmentsSchema'),
|
|
55
|
+
},
|
|
56
|
+
}),
|
|
57
|
+
],
|
|
58
|
+
});
|
|
59
|
+
this.route({
|
|
60
|
+
method: 'post',
|
|
61
|
+
path: '/strategies',
|
|
62
|
+
handler: this.updateFeatureStrategySegments,
|
|
63
|
+
permission: types_1.NONE,
|
|
64
|
+
middleware: [
|
|
65
|
+
openApiService.validPath({
|
|
66
|
+
summary: 'Update strategy segments',
|
|
67
|
+
description: 'Sets the segments of the strategy specified to be exactly the ones passed in the payload. Any segments that were used by the strategy before will be removed if they are not in the provided list of segments.',
|
|
68
|
+
tags: ['Strategies'],
|
|
69
|
+
operationId: 'updateFeatureStrategySegments',
|
|
70
|
+
requestBody: (0, openapi_1.createRequestSchema)('updateFeatureStrategySegmentsSchema'),
|
|
71
|
+
responses: {
|
|
72
|
+
201: (0, openapi_1.resourceCreatedResponseSchema)('updateFeatureStrategySegmentsSchema'),
|
|
73
|
+
...(0, standard_responses_1.getStandardResponses)(400, 401, 403, 415),
|
|
74
|
+
},
|
|
75
|
+
}),
|
|
76
|
+
],
|
|
77
|
+
});
|
|
78
|
+
this.route({
|
|
79
|
+
method: 'get',
|
|
80
|
+
path: '/:id/strategies',
|
|
81
|
+
handler: this.getStrategiesBySegment,
|
|
82
|
+
permission: types_1.NONE,
|
|
83
|
+
middleware: [
|
|
84
|
+
openApiService.validPath({
|
|
85
|
+
tags: ['Segments'],
|
|
86
|
+
operationId: 'getStrategiesBySegmentId',
|
|
87
|
+
summary: 'Get strategies that reference segment',
|
|
88
|
+
description: 'Retrieve all strategies that reference the specified segment.',
|
|
89
|
+
responses: {
|
|
90
|
+
200: (0, openapi_1.createResponseSchema)('adminStrategiesSchema'),
|
|
91
|
+
},
|
|
92
|
+
}),
|
|
93
|
+
],
|
|
94
|
+
});
|
|
95
|
+
this.route({
|
|
96
|
+
method: 'delete',
|
|
97
|
+
path: '/:id',
|
|
98
|
+
handler: this.removeSegment,
|
|
99
|
+
permission: types_1.DELETE_SEGMENT,
|
|
100
|
+
acceptAnyContentType: true,
|
|
101
|
+
middleware: [
|
|
102
|
+
openApiService.validPath({
|
|
103
|
+
summary: 'Deletes a segment by id',
|
|
104
|
+
description: 'Deletes a segment by its id, if not found returns a 409 error',
|
|
105
|
+
tags: ['Segments'],
|
|
106
|
+
operationId: 'removeSegment',
|
|
107
|
+
responses: {
|
|
108
|
+
204: standard_responses_1.emptyResponse,
|
|
109
|
+
...(0, standard_responses_1.getStandardResponses)(401, 403, 409),
|
|
110
|
+
},
|
|
111
|
+
}),
|
|
112
|
+
],
|
|
113
|
+
});
|
|
114
|
+
this.route({
|
|
115
|
+
method: 'put',
|
|
116
|
+
path: '/:id',
|
|
117
|
+
handler: this.updateSegment,
|
|
118
|
+
permission: types_1.UPDATE_SEGMENT,
|
|
119
|
+
middleware: [
|
|
120
|
+
openApiService.validPath({
|
|
121
|
+
summary: 'Update segment by id',
|
|
122
|
+
description: 'Updates the content of the segment with the provided payload. Any fields not specified will be left untouched.',
|
|
123
|
+
tags: ['Segments'],
|
|
124
|
+
operationId: 'updateSegment',
|
|
125
|
+
responses: {
|
|
126
|
+
204: standard_responses_1.emptyResponse,
|
|
127
|
+
...(0, standard_responses_1.getStandardResponses)(400, 401, 403, 409, 415),
|
|
128
|
+
},
|
|
129
|
+
}),
|
|
130
|
+
],
|
|
131
|
+
});
|
|
132
|
+
this.route({
|
|
133
|
+
method: 'get',
|
|
134
|
+
path: '/:id',
|
|
135
|
+
handler: this.getSegment,
|
|
136
|
+
permission: types_1.NONE,
|
|
137
|
+
middleware: [
|
|
138
|
+
openApiService.validPath({
|
|
139
|
+
summary: 'Get a segment',
|
|
140
|
+
description: 'Retrieves a segment based on its ID.',
|
|
141
|
+
tags: ['Segments'],
|
|
142
|
+
operationId: 'getSegment',
|
|
143
|
+
responses: {
|
|
144
|
+
200: (0, openapi_1.createResponseSchema)('adminSegmentSchema'),
|
|
145
|
+
...(0, standard_responses_1.getStandardResponses)(404),
|
|
146
|
+
},
|
|
147
|
+
}),
|
|
148
|
+
],
|
|
149
|
+
});
|
|
150
|
+
this.route({
|
|
151
|
+
method: 'post',
|
|
152
|
+
path: '',
|
|
153
|
+
handler: this.createSegment,
|
|
154
|
+
permission: types_1.CREATE_SEGMENT,
|
|
155
|
+
middleware: [
|
|
156
|
+
openApiService.validPath({
|
|
157
|
+
summary: 'Create a new segment',
|
|
158
|
+
description: 'Creates a new segment using the payload provided',
|
|
159
|
+
tags: ['Segments'],
|
|
160
|
+
operationId: 'createSegment',
|
|
161
|
+
requestBody: (0, openapi_1.createRequestSchema)('upsertSegmentSchema'),
|
|
162
|
+
responses: {
|
|
163
|
+
201: (0, openapi_1.resourceCreatedResponseSchema)('adminSegmentSchema'),
|
|
164
|
+
...(0, standard_responses_1.getStandardResponses)(400, 401, 403, 409, 415),
|
|
165
|
+
},
|
|
166
|
+
}),
|
|
167
|
+
],
|
|
168
|
+
});
|
|
169
|
+
this.route({
|
|
170
|
+
method: 'get',
|
|
171
|
+
path: '',
|
|
172
|
+
handler: this.getSegments,
|
|
173
|
+
permission: types_1.NONE,
|
|
174
|
+
middleware: [
|
|
175
|
+
openApiService.validPath({
|
|
176
|
+
summary: 'Get all segments',
|
|
177
|
+
description: 'Retrieves all segments that exist in this Unleash instance.',
|
|
178
|
+
tags: ['Segments'],
|
|
179
|
+
operationId: 'getSegments',
|
|
180
|
+
responses: {
|
|
181
|
+
200: (0, openapi_1.createResponseSchema)('segmentsSchema'),
|
|
182
|
+
},
|
|
183
|
+
}),
|
|
184
|
+
],
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
async validate(req, res) {
|
|
188
|
+
const { name } = req.body;
|
|
189
|
+
await this.segmentService.validateName(name);
|
|
190
|
+
res.status(204).send();
|
|
191
|
+
}
|
|
192
|
+
async getSegmentsByStrategy(req, res) {
|
|
193
|
+
const { strategyId } = req.params;
|
|
194
|
+
const segments = await this.segmentService.getByStrategy(strategyId);
|
|
195
|
+
const responseBody = this.flagResolver.isEnabled('anonymiseEventLog')
|
|
196
|
+
? {
|
|
197
|
+
segments: (0, util_1.anonymiseKeys)(segments, ['createdBy']),
|
|
198
|
+
}
|
|
199
|
+
: { segments };
|
|
200
|
+
this.openApiService.respondWithValidation(200, res, segments_schema_1.segmentsSchema.$id, (0, types_1.serializeDates)(responseBody));
|
|
201
|
+
}
|
|
202
|
+
async updateFeatureStrategySegments(req, res) {
|
|
203
|
+
const { projectId, environmentId, strategyId, segmentIds } = req.body;
|
|
204
|
+
const hasFeatureStrategyPermission = this.accessService.hasPermission(req.user, types_1.UPDATE_FEATURE_STRATEGY, projectId, environmentId);
|
|
205
|
+
if (!hasFeatureStrategyPermission) {
|
|
206
|
+
res.status(403).send();
|
|
207
|
+
return;
|
|
208
|
+
}
|
|
209
|
+
if (segmentIds.length > this.config.strategySegmentsLimit) {
|
|
210
|
+
throw new error_1.BadDataError(`Strategies may not have more than ${this.config.strategySegmentsLimit} segments`);
|
|
211
|
+
}
|
|
212
|
+
const segments = await this.segmentService.getByStrategy(strategyId);
|
|
213
|
+
const currentSegmentIds = segments.map((segment) => segment.id);
|
|
214
|
+
await this.removeFromStrategy(strategyId, currentSegmentIds.filter((id) => !segmentIds.includes(id)));
|
|
215
|
+
await this.addToStrategy(strategyId, segmentIds.filter((id) => !currentSegmentIds.includes(id)));
|
|
216
|
+
this.openApiService.respondWithValidation(201, res, openapi_1.updateFeatureStrategySchema.$id, req.body, {
|
|
217
|
+
location: `strategies/${strategyId}`,
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
async getStrategiesBySegment(req, res) {
|
|
221
|
+
const { id } = req.params;
|
|
222
|
+
const { user } = req;
|
|
223
|
+
const strategies = await this.segmentService.getStrategies(id, user.id);
|
|
224
|
+
// Remove unnecessary IFeatureStrategy fields from the response.
|
|
225
|
+
const segmentStrategies = strategies.map((strategy) => ({
|
|
226
|
+
id: strategy.id,
|
|
227
|
+
projectId: strategy.projectId,
|
|
228
|
+
featureName: strategy.featureName,
|
|
229
|
+
strategyName: strategy.strategyName,
|
|
230
|
+
environment: strategy.environment,
|
|
231
|
+
}));
|
|
232
|
+
res.json({
|
|
233
|
+
strategies: segmentStrategies,
|
|
234
|
+
});
|
|
235
|
+
}
|
|
236
|
+
async removeSegment(req, res) {
|
|
237
|
+
const id = Number(req.params.id);
|
|
238
|
+
const { user } = req;
|
|
239
|
+
const strategies = await this.segmentService.getStrategies(id, user.id);
|
|
240
|
+
if (strategies.length > 0) {
|
|
241
|
+
res.status(409).send();
|
|
242
|
+
}
|
|
243
|
+
else {
|
|
244
|
+
await this.segmentService.delete(id, req.user);
|
|
245
|
+
res.status(204).send();
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
async updateSegment(req, res) {
|
|
249
|
+
const id = Number(req.params.id);
|
|
250
|
+
const updateRequest = {
|
|
251
|
+
name: req.body.name,
|
|
252
|
+
description: req.body.description,
|
|
253
|
+
project: req.body.project,
|
|
254
|
+
constraints: req.body.constraints,
|
|
255
|
+
};
|
|
256
|
+
await this.segmentService.update(id, updateRequest, req.user);
|
|
257
|
+
res.status(204).send();
|
|
258
|
+
}
|
|
259
|
+
async getSegment(req, res) {
|
|
260
|
+
const id = Number(req.params.id);
|
|
261
|
+
const segment = await this.segmentService.get(id);
|
|
262
|
+
if (this.flagResolver.isEnabled('anonymiseEventLog')) {
|
|
263
|
+
res.json((0, util_1.anonymiseKeys)(segment, ['createdBy']));
|
|
264
|
+
}
|
|
265
|
+
else {
|
|
266
|
+
res.json(segment);
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
async createSegment(req, res) {
|
|
270
|
+
const createRequest = req.body;
|
|
271
|
+
const segment = await this.segmentService.create(createRequest, req.user);
|
|
272
|
+
this.openApiService.respondWithValidation(201, res, openapi_1.adminSegmentSchema.$id, (0, types_1.serializeDates)(segment), { location: `segments/${segment.id}` });
|
|
273
|
+
}
|
|
274
|
+
async getSegments(req, res) {
|
|
275
|
+
const segments = await this.segmentService.getAll();
|
|
276
|
+
const response = {
|
|
277
|
+
segments: this.flagResolver.isEnabled('anonymiseEventLog')
|
|
278
|
+
? (0, util_1.anonymiseKeys)(segments, ['createdBy'])
|
|
279
|
+
: segments,
|
|
280
|
+
};
|
|
281
|
+
this.openApiService.respondWithValidation(200, res, segments_schema_1.segmentsSchema.$id, (0, types_1.serializeDates)(response));
|
|
282
|
+
}
|
|
283
|
+
async removeFromStrategy(strategyId, segmentIds) {
|
|
284
|
+
await Promise.all(segmentIds.map((id) => this.segmentService.removeFromStrategy(id, strategyId)));
|
|
285
|
+
}
|
|
286
|
+
async addToStrategy(strategyId, segmentIds) {
|
|
287
|
+
await Promise.all(segmentIds.map((id) => this.segmentService.addToStrategy(id, strategyId)));
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
exports.SegmentsController = SegmentsController;
|
|
291
|
+
//# sourceMappingURL=segment-controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"segment-controller.js","sourceRoot":"","sources":["../../../../src/lib/features/segment/segment-controller.ts"],"names":[],"mappings":"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"}
|
package/dist/lib/metrics.d.ts
CHANGED
|
@@ -5,7 +5,7 @@ import { Knex } from 'knex';
|
|
|
5
5
|
import { IUnleashConfig } from './types/option';
|
|
6
6
|
import { IUnleashStores } from './types/stores';
|
|
7
7
|
import Timer = NodeJS.Timer;
|
|
8
|
-
import { InstanceStatsService } from './
|
|
8
|
+
import { InstanceStatsService } from './features/instance-stats/instance-stats-service';
|
|
9
9
|
export default class MetricsMonitor {
|
|
10
10
|
timer?: Timer;
|
|
11
11
|
poolMetricsTimer?: Timer;
|
package/dist/lib/metrics.js
CHANGED
|
@@ -77,9 +77,26 @@ class MetricsMonitor {
|
|
|
77
77
|
name: 'users_total',
|
|
78
78
|
help: 'Number of users',
|
|
79
79
|
});
|
|
80
|
+
const usersActive7days = new prom_client_1.default.Gauge({
|
|
81
|
+
name: 'users_active_7',
|
|
82
|
+
help: 'Number of users active in the last 7 days',
|
|
83
|
+
});
|
|
84
|
+
const usersActive30days = new prom_client_1.default.Gauge({
|
|
85
|
+
name: 'users_active_30',
|
|
86
|
+
help: 'Number of users active in the last 30 days',
|
|
87
|
+
});
|
|
88
|
+
const usersActive60days = new prom_client_1.default.Gauge({
|
|
89
|
+
name: 'users_active_60',
|
|
90
|
+
help: 'Number of users active in the last 60 days',
|
|
91
|
+
});
|
|
92
|
+
const usersActive90days = new prom_client_1.default.Gauge({
|
|
93
|
+
name: 'users_active_90',
|
|
94
|
+
help: 'Number of users active in the last 90 days',
|
|
95
|
+
});
|
|
80
96
|
const projectsTotal = new prom_client_1.default.Gauge({
|
|
81
97
|
name: 'projects_total',
|
|
82
98
|
help: 'Number of projects',
|
|
99
|
+
labelNames: ['mode'],
|
|
83
100
|
});
|
|
84
101
|
const environmentsTotal = new prom_client_1.default.Gauge({
|
|
85
102
|
name: 'environments_total',
|
|
@@ -143,8 +160,20 @@ class MetricsMonitor {
|
|
|
143
160
|
featureTogglesTotal.labels(version).set(stats.featureToggles);
|
|
144
161
|
usersTotal.reset();
|
|
145
162
|
usersTotal.set(stats.users);
|
|
163
|
+
usersActive7days.reset();
|
|
164
|
+
usersActive7days.set(stats.activeUsers.last7);
|
|
165
|
+
usersActive30days.reset();
|
|
166
|
+
usersActive30days.set(stats.activeUsers.last30);
|
|
167
|
+
usersActive60days.reset();
|
|
168
|
+
usersActive60days.set(stats.activeUsers.last60);
|
|
169
|
+
usersActive90days.reset();
|
|
170
|
+
usersActive90days.set(stats.activeUsers.last90);
|
|
146
171
|
projectsTotal.reset();
|
|
147
|
-
|
|
172
|
+
stats.projects.forEach((projectStat) => {
|
|
173
|
+
projectsTotal
|
|
174
|
+
.labels({ mode: projectStat.mode })
|
|
175
|
+
.set(projectStat.count);
|
|
176
|
+
});
|
|
148
177
|
environmentsTotal.reset();
|
|
149
178
|
environmentsTotal.set(stats.environments);
|
|
150
179
|
groupsTotal.reset();
|