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.
Files changed (586) hide show
  1. package/README.md +5 -3
  2. package/dist/lib/addons/addon-schema.js +2 -1
  3. package/dist/lib/addons/addon-schema.js.map +1 -1
  4. package/dist/lib/addons/datadog-definition.js +22 -7
  5. package/dist/lib/addons/datadog-definition.js.map +1 -1
  6. package/dist/lib/addons/datadog.d.ts +7 -1
  7. package/dist/lib/addons/datadog.js +16 -3
  8. package/dist/lib/addons/datadog.js.map +1 -1
  9. package/dist/lib/addons/datadog.test.js +62 -0
  10. package/dist/lib/addons/datadog.test.js.map +1 -1
  11. package/dist/lib/addons/index.js +3 -11
  12. package/dist/lib/addons/index.js.map +1 -1
  13. package/dist/lib/addons/slack-app-definition.js +5 -24
  14. package/dist/lib/addons/slack-app-definition.js.map +1 -1
  15. package/dist/lib/addons/slack-app.d.ts +0 -1
  16. package/dist/lib/addons/slack-app.js +5 -17
  17. package/dist/lib/addons/slack-app.js.map +1 -1
  18. package/dist/lib/addons/slack-app.test.js +39 -25
  19. package/dist/lib/addons/slack-app.test.js.map +1 -1
  20. package/dist/lib/addons/slack-definition.js +11 -4
  21. package/dist/lib/addons/slack-definition.js.map +1 -1
  22. package/dist/lib/addons/teams-definition.js +5 -4
  23. package/dist/lib/addons/teams-definition.js.map +1 -1
  24. package/dist/lib/addons/webhook-definition.js +10 -12
  25. package/dist/lib/addons/webhook-definition.js.map +1 -1
  26. package/dist/lib/create-config.js +13 -1
  27. package/dist/lib/create-config.js.map +1 -1
  28. package/dist/lib/create-config.test.js +14 -0
  29. package/dist/lib/create-config.test.js.map +1 -1
  30. package/dist/lib/db/access-store.d.ts +23 -5
  31. package/dist/lib/db/access-store.js +263 -17
  32. package/dist/lib/db/access-store.js.map +1 -1
  33. package/dist/lib/db/access-store.test.js +83 -0
  34. package/dist/lib/db/access-store.test.js.map +1 -0
  35. package/dist/lib/db/client-applications-store.d.ts +1 -3
  36. package/dist/lib/db/client-applications-store.js +13 -24
  37. package/dist/lib/db/client-applications-store.js.map +1 -1
  38. package/dist/lib/db/event-store.js +1 -0
  39. package/dist/lib/db/event-store.js.map +1 -1
  40. package/dist/lib/db/feature-toggle-client-store.js +17 -4
  41. package/dist/lib/db/feature-toggle-client-store.js.map +1 -1
  42. package/dist/lib/db/feature-toggle-store.js +1 -1
  43. package/dist/lib/db/feature-toggle-store.js.map +1 -1
  44. package/dist/lib/db/group-store.d.ts +4 -2
  45. package/dist/lib/db/group-store.js +24 -0
  46. package/dist/lib/db/group-store.js.map +1 -1
  47. package/dist/lib/db/index.d.ts +1 -2
  48. package/dist/lib/db/index.js +5 -1
  49. package/dist/lib/db/index.js.map +1 -1
  50. package/dist/lib/db/project-stats-store.d.ts +2 -0
  51. package/dist/lib/db/project-stats-store.js +27 -0
  52. package/dist/lib/db/project-stats-store.js.map +1 -1
  53. package/dist/lib/db/project-store.d.ts +7 -1
  54. package/dist/lib/db/project-store.js +34 -1
  55. package/dist/lib/db/project-store.js.map +1 -1
  56. package/dist/lib/error/bad-data-error.d.ts +1 -1
  57. package/dist/lib/error/index.d.ts +2 -1
  58. package/dist/lib/error/index.js +3 -1
  59. package/dist/lib/error/index.js.map +1 -1
  60. package/dist/lib/error/pattern-error.d.ts +10 -0
  61. package/dist/lib/error/pattern-error.js +20 -0
  62. package/dist/lib/error/pattern-error.js.map +1 -0
  63. package/dist/lib/features/dependent-features/createDependentFeaturesService.d.ts +3 -0
  64. package/dist/lib/features/dependent-features/createDependentFeaturesService.js +11 -0
  65. package/dist/lib/features/dependent-features/createDependentFeaturesService.js.map +1 -0
  66. package/dist/lib/features/dependent-features/dependent-features-controller.d.ts +28 -0
  67. package/dist/lib/features/dependent-features/dependent-features-controller.js +151 -0
  68. package/dist/lib/features/dependent-features/dependent-features-controller.js.map +1 -0
  69. package/dist/lib/features/dependent-features/dependent-features-service.d.ts +11 -0
  70. package/dist/lib/features/dependent-features/dependent-features-service.js +40 -0
  71. package/dist/lib/features/dependent-features/dependent-features-service.js.map +1 -0
  72. package/dist/lib/features/dependent-features/dependent-features-store-type.d.ts +8 -0
  73. package/dist/lib/features/dependent-features/dependent-features-store-type.js +3 -0
  74. package/dist/lib/features/dependent-features/dependent-features-store-type.js.map +1 -0
  75. package/dist/lib/features/dependent-features/dependent-features-store.d.ts +12 -0
  76. package/dist/lib/features/dependent-features/dependent-features-store.js +56 -0
  77. package/dist/lib/features/dependent-features/dependent-features-store.js.map +1 -0
  78. package/dist/lib/features/dependent-features/dependent-features.d.ts +14 -0
  79. package/dist/lib/features/dependent-features/dependent-features.js +3 -0
  80. package/dist/lib/features/dependent-features/dependent-features.js.map +1 -0
  81. package/dist/lib/features/dependent-features/dependent.features.e2e.test.d.ts +1 -0
  82. package/dist/lib/features/dependent-features/dependent.features.e2e.test.js +82 -0
  83. package/dist/lib/features/dependent-features/dependent.features.e2e.test.js.map +1 -0
  84. package/dist/lib/features/dependent-features/fake-dependent-features-store.d.ts +8 -0
  85. package/dist/lib/features/dependent-features/fake-dependent-features-store.js +22 -0
  86. package/dist/lib/features/dependent-features/fake-dependent-features-store.js.map +1 -0
  87. package/dist/lib/features/export-import-toggles/createExportImportService.js +6 -3
  88. package/dist/lib/features/export-import-toggles/createExportImportService.js.map +1 -1
  89. package/dist/lib/features/export-import-toggles/export-import-service.d.ts +9 -3
  90. package/dist/lib/features/export-import-toggles/export-import-service.js +51 -21
  91. package/dist/lib/features/export-import-toggles/export-import-service.js.map +1 -1
  92. package/dist/lib/features/export-import-toggles/export-import.e2e.test.js +120 -50
  93. package/dist/lib/features/export-import-toggles/export-import.e2e.test.js.map +1 -1
  94. package/dist/lib/features/export-import-toggles/import-permissions-service.d.ts +1 -2
  95. package/dist/lib/features/export-import-toggles/import-toggles-store-type.d.ts +6 -0
  96. package/dist/lib/features/export-import-toggles/import-toggles-store.d.ts +2 -1
  97. package/dist/lib/features/export-import-toggles/import-toggles-store.js +25 -0
  98. package/dist/lib/features/export-import-toggles/import-toggles-store.js.map +1 -1
  99. package/dist/lib/features/export-import-toggles/import-validation-messages.d.ts +18 -2
  100. package/dist/lib/features/export-import-toggles/import-validation-messages.js +27 -11
  101. package/dist/lib/features/export-import-toggles/import-validation-messages.js.map +1 -1
  102. package/dist/lib/features/feature-naming-pattern/feature-naming-validation.d.ts +14 -0
  103. package/dist/lib/features/feature-naming-pattern/feature-naming-validation.js +46 -0
  104. package/dist/lib/features/feature-naming-pattern/feature-naming-validation.js.map +1 -0
  105. package/dist/lib/features/feature-naming-pattern/feature-naming-validation.test.d.ts +1 -0
  106. package/dist/lib/features/feature-naming-pattern/feature-naming-validation.test.js +116 -0
  107. package/dist/lib/features/feature-naming-pattern/feature-naming-validation.test.js.map +1 -0
  108. package/dist/lib/features/feature-toggle/createFeatureToggleService.js +11 -2
  109. package/dist/lib/features/feature-toggle/createFeatureToggleService.js.map +1 -1
  110. package/dist/lib/features/instance-stats/getActiveUsers.d.ts +9 -0
  111. package/dist/lib/features/instance-stats/getActiveUsers.e2e.test.d.ts +1 -0
  112. package/dist/lib/features/instance-stats/getActiveUsers.e2e.test.js +141 -0
  113. package/dist/lib/features/instance-stats/getActiveUsers.e2e.test.js.map +1 -0
  114. package/dist/lib/features/instance-stats/getActiveUsers.js +33 -0
  115. package/dist/lib/features/instance-stats/getActiveUsers.js.map +1 -0
  116. package/dist/lib/{services → features/instance-stats}/instance-stats-service.d.ts +13 -7
  117. package/dist/lib/{services → features/instance-stats}/instance-stats-service.js +16 -7
  118. package/dist/lib/features/instance-stats/instance-stats-service.js.map +1 -0
  119. package/dist/lib/features/instance-stats/instance-stats-service.test.d.ts +1 -0
  120. package/dist/lib/{services → features/instance-stats}/instance-stats-service.test.js +6 -5
  121. package/dist/lib/features/instance-stats/instance-stats-service.test.js.map +1 -0
  122. package/dist/lib/features/playground/advanced-playground.test.js +2 -3
  123. package/dist/lib/features/playground/advanced-playground.test.js.map +1 -1
  124. package/dist/lib/features/playground/feature-evaluator/variant.d.ts +1 -1
  125. package/dist/lib/features/playground/generateObjectCombinations.d.ts +1 -1
  126. package/dist/lib/features/playground/generateObjectCombinations.js +14 -4
  127. package/dist/lib/features/playground/generateObjectCombinations.js.map +1 -1
  128. package/dist/lib/features/playground/generateObjectCombinations.test.js +21 -0
  129. package/dist/lib/features/playground/generateObjectCombinations.test.js.map +1 -1
  130. package/dist/lib/features/playground/playground-service.d.ts +5 -3
  131. package/dist/lib/features/playground/playground-service.js +18 -3
  132. package/dist/lib/features/playground/playground-service.js.map +1 -1
  133. package/dist/lib/features/playground/playground.d.ts +2 -1
  134. package/dist/lib/features/playground/playground.js +2 -1
  135. package/dist/lib/features/playground/playground.js.map +1 -1
  136. package/dist/lib/features/private-project/createPrivateProjectChecker.d.ts +5 -0
  137. package/dist/lib/features/private-project/createPrivateProjectChecker.js +22 -0
  138. package/dist/lib/features/private-project/createPrivateProjectChecker.js.map +1 -0
  139. package/dist/lib/features/private-project/fakePrivateProjectChecker.d.ts +7 -0
  140. package/dist/lib/features/private-project/fakePrivateProjectChecker.js +15 -0
  141. package/dist/lib/features/private-project/fakePrivateProjectChecker.js.map +1 -0
  142. package/dist/lib/features/private-project/privateProjectChecker.d.ts +10 -0
  143. package/dist/lib/features/private-project/privateProjectChecker.js +22 -0
  144. package/dist/lib/features/private-project/privateProjectChecker.js.map +1 -0
  145. package/dist/lib/features/private-project/privateProjectCheckerType.d.ts +5 -0
  146. package/dist/lib/features/private-project/privateProjectCheckerType.js +3 -0
  147. package/dist/lib/features/private-project/privateProjectCheckerType.js.map +1 -0
  148. package/dist/lib/features/private-project/privateProjectStore.d.ts +18 -0
  149. package/dist/lib/features/private-project/privateProjectStore.js +70 -0
  150. package/dist/lib/features/private-project/privateProjectStore.js.map +1 -0
  151. package/dist/lib/features/private-project/privateProjectStoreType.d.ts +4 -0
  152. package/dist/lib/features/private-project/privateProjectStoreType.js +3 -0
  153. package/dist/lib/features/private-project/privateProjectStoreType.js.map +1 -0
  154. package/dist/lib/features/project/createProjectService.js +5 -8
  155. package/dist/lib/features/project/createProjectService.js.map +1 -1
  156. package/dist/lib/features/segment/createSegmentService.js +5 -2
  157. package/dist/lib/features/segment/createSegmentService.js.map +1 -1
  158. package/dist/lib/features/segment/segment-controller.d.ts +39 -0
  159. package/dist/lib/features/segment/segment-controller.js +291 -0
  160. package/dist/lib/features/segment/segment-controller.js.map +1 -0
  161. package/dist/lib/metrics.d.ts +1 -1
  162. package/dist/lib/metrics.js +30 -1
  163. package/dist/lib/metrics.js.map +1 -1
  164. package/dist/lib/metrics.test.js +3 -2
  165. package/dist/lib/metrics.test.js.map +1 -1
  166. package/dist/lib/middleware/rbac-middleware.d.ts +2 -0
  167. package/dist/lib/middleware/rbac-middleware.js +2 -0
  168. package/dist/lib/middleware/rbac-middleware.js.map +1 -1
  169. package/dist/lib/middleware/secure-headers.js +18 -0
  170. package/dist/lib/middleware/secure-headers.js.map +1 -1
  171. package/dist/lib/openapi/index.js +13 -0
  172. package/dist/lib/openapi/index.js.map +1 -1
  173. package/dist/lib/openapi/meta-schema-rules.test.js +14 -4
  174. package/dist/lib/openapi/meta-schema-rules.test.js.map +1 -1
  175. package/dist/lib/openapi/spec/addon-type-schema.d.ts +6 -1
  176. package/dist/lib/openapi/spec/addon-type-schema.js +6 -1
  177. package/dist/lib/openapi/spec/addon-type-schema.js.map +1 -1
  178. package/dist/lib/openapi/spec/addons-schema.d.ts +8 -3
  179. package/dist/lib/openapi/spec/addons-schema.js +8 -3
  180. package/dist/lib/openapi/spec/addons-schema.js.map +1 -1
  181. package/dist/lib/openapi/spec/admin-segment-schema.d.ts +115 -0
  182. package/dist/lib/openapi/spec/admin-segment-schema.js +75 -0
  183. package/dist/lib/openapi/spec/admin-segment-schema.js.map +1 -0
  184. package/dist/lib/openapi/spec/admin-segment-schema.test.d.ts +1 -0
  185. package/dist/lib/openapi/spec/admin-segment-schema.test.js +39 -0
  186. package/dist/lib/openapi/spec/admin-segment-schema.test.js.map +1 -0
  187. package/dist/lib/openapi/spec/admin-strategies-schema.d.ts +46 -0
  188. package/dist/lib/openapi/spec/admin-strategies-schema.js +54 -0
  189. package/dist/lib/openapi/spec/admin-strategies-schema.js.map +1 -0
  190. package/dist/lib/openapi/spec/admin-strategies-schema.test.d.ts +1 -0
  191. package/dist/lib/openapi/spec/admin-strategies-schema.test.js +40 -0
  192. package/dist/lib/openapi/spec/admin-strategies-schema.test.js.map +1 -0
  193. package/dist/lib/openapi/spec/advanced-playground-environment-feature-schema.d.ts +51 -6
  194. package/dist/lib/openapi/spec/advanced-playground-environment-feature-schema.js +3 -1
  195. package/dist/lib/openapi/spec/advanced-playground-environment-feature-schema.js.map +1 -1
  196. package/dist/lib/openapi/spec/advanced-playground-feature-schema.d.ts +101 -11
  197. package/dist/lib/openapi/spec/advanced-playground-feature-schema.js +2 -0
  198. package/dist/lib/openapi/spec/advanced-playground-feature-schema.js.map +1 -1
  199. package/dist/lib/openapi/spec/advanced-playground-request-schema.d.ts +1 -0
  200. package/dist/lib/openapi/spec/advanced-playground-response-schema.d.ts +203 -22
  201. package/dist/lib/openapi/spec/advanced-playground-response-schema.js +2 -0
  202. package/dist/lib/openapi/spec/advanced-playground-response-schema.js.map +1 -1
  203. package/dist/lib/openapi/spec/client-feature-schema.d.ts +41 -6
  204. package/dist/lib/openapi/spec/client-feature-schema.js +9 -0
  205. package/dist/lib/openapi/spec/client-feature-schema.js.map +1 -1
  206. package/dist/lib/openapi/spec/client-features-schema.d.ts +75 -12
  207. package/dist/lib/openapi/spec/client-features-schema.js +2 -0
  208. package/dist/lib/openapi/spec/client-features-schema.js.map +1 -1
  209. package/dist/lib/openapi/spec/context-field-strategies-schema.d.ts +1 -1
  210. package/dist/lib/openapi/spec/context-field-strategies-schema.js +1 -1
  211. package/dist/lib/openapi/spec/context-field-strategies-schema.js.map +1 -1
  212. package/dist/lib/openapi/spec/create-api-token-schema.d.ts +1 -139
  213. package/dist/lib/openapi/spec/create-api-token-schema.js +16 -20
  214. package/dist/lib/openapi/spec/create-api-token-schema.js.map +1 -1
  215. package/dist/lib/openapi/spec/create-dependent-feature-schema.d.ts +29 -0
  216. package/dist/lib/openapi/spec/create-dependent-feature-schema.js +31 -0
  217. package/dist/lib/openapi/spec/create-dependent-feature-schema.js.map +1 -0
  218. package/dist/lib/openapi/spec/create-feature-naming-pattern-schema.d.ts +29 -0
  219. package/dist/lib/openapi/spec/create-feature-naming-pattern-schema.js +33 -0
  220. package/dist/lib/openapi/spec/create-feature-naming-pattern-schema.js.map +1 -0
  221. package/dist/lib/openapi/spec/create-feature-strategy-schema.d.ts +2 -2
  222. package/dist/lib/openapi/spec/create-strategy-schema.d.ts +15 -0
  223. package/dist/lib/openapi/spec/create-strategy-schema.js +15 -0
  224. package/dist/lib/openapi/spec/create-strategy-schema.js.map +1 -1
  225. package/dist/lib/openapi/spec/create-strategy-variant-schema.d.ts +2 -2
  226. package/dist/lib/openapi/spec/create-strategy-variant-schema.js +2 -2
  227. package/dist/lib/openapi/spec/create-strategy-variant-schema.js.map +1 -1
  228. package/dist/lib/openapi/spec/dependent-feature-schema.d.ts +30 -0
  229. package/dist/lib/openapi/spec/dependent-feature-schema.js +14 -0
  230. package/dist/lib/openapi/spec/dependent-feature-schema.js.map +1 -0
  231. package/dist/lib/openapi/spec/dora-features-schema.d.ts +20 -0
  232. package/dist/lib/openapi/spec/dora-features-schema.js +22 -0
  233. package/dist/lib/openapi/spec/dora-features-schema.js.map +1 -0
  234. package/dist/lib/openapi/spec/environment-project-schema.d.ts +4 -4
  235. package/dist/lib/openapi/spec/environments-project-schema.d.ts +4 -4
  236. package/dist/lib/openapi/spec/event-schema.d.ts +3 -3
  237. package/dist/lib/openapi/spec/events-schema.d.ts +3 -3
  238. package/dist/lib/openapi/spec/export-query-schema.d.ts +22 -15
  239. package/dist/lib/openapi/spec/export-query-schema.js +16 -15
  240. package/dist/lib/openapi/spec/export-query-schema.js.map +1 -1
  241. package/dist/lib/openapi/spec/export-result-schema.d.ts +26 -26
  242. package/dist/lib/openapi/spec/feature-environment-schema.d.ts +6 -6
  243. package/dist/lib/openapi/spec/feature-events-schema.d.ts +3 -3
  244. package/dist/lib/openapi/spec/feature-schema.d.ts +12 -12
  245. package/dist/lib/openapi/spec/feature-strategy-schema.d.ts +2 -2
  246. package/dist/lib/openapi/spec/feature-variants-schema.d.ts +2 -2
  247. package/dist/lib/openapi/spec/features-schema.d.ts +24 -24
  248. package/dist/lib/openapi/spec/health-overview-schema.d.ts +63 -33
  249. package/dist/lib/openapi/spec/health-overview-schema.js +6 -1
  250. package/dist/lib/openapi/spec/health-overview-schema.js.map +1 -1
  251. package/dist/lib/openapi/spec/health-report-schema.d.ts +63 -33
  252. package/dist/lib/openapi/spec/import-toggles-schema.d.ts +52 -52
  253. package/dist/lib/openapi/spec/index.d.ts +9 -0
  254. package/dist/lib/openapi/spec/index.js +9 -0
  255. package/dist/lib/openapi/spec/index.js.map +1 -1
  256. package/dist/lib/openapi/spec/instance-admin-stats-schema.d.ts +42 -0
  257. package/dist/lib/openapi/spec/instance-admin-stats-schema.js +42 -0
  258. package/dist/lib/openapi/spec/instance-admin-stats-schema.js.map +1 -1
  259. package/dist/lib/openapi/spec/parent-feature-options-schema.d.ts +11 -0
  260. package/dist/lib/openapi/spec/parent-feature-options-schema.js +13 -0
  261. package/dist/lib/openapi/spec/parent-feature-options-schema.js.map +1 -0
  262. package/dist/lib/openapi/spec/playground-feature-schema.d.ts +5 -5
  263. package/dist/lib/openapi/spec/playground-request-schema.d.ts +1 -0
  264. package/dist/lib/openapi/spec/playground-response-schema.d.ts +12 -10
  265. package/dist/lib/openapi/spec/playground-strategy-schema.d.ts +4 -4
  266. package/dist/lib/openapi/spec/playground-strategy-schema.js +1 -1
  267. package/dist/lib/openapi/spec/playground-strategy-schema.js.map +1 -1
  268. package/dist/lib/openapi/spec/profile-schema.d.ts +12 -12
  269. package/dist/lib/openapi/spec/project-dora-metrics-schema.d.ts +44 -0
  270. package/dist/lib/openapi/spec/project-dora-metrics-schema.js +28 -0
  271. package/dist/lib/openapi/spec/project-dora-metrics-schema.js.map +1 -0
  272. package/dist/lib/openapi/spec/project-environment-schema.d.ts +4 -4
  273. package/dist/lib/openapi/spec/project-overview-schema.d.ts +63 -33
  274. package/dist/lib/openapi/spec/project-overview-schema.js +6 -1
  275. package/dist/lib/openapi/spec/project-overview-schema.js.map +1 -1
  276. package/dist/lib/openapi/spec/project-schema.d.ts +1 -1
  277. package/dist/lib/openapi/spec/project-schema.js +1 -1
  278. package/dist/lib/openapi/spec/project-schema.js.map +1 -1
  279. package/dist/lib/openapi/spec/projects-schema.d.ts +1 -1
  280. package/dist/lib/openapi/spec/push-variants-schema.d.ts +2 -2
  281. package/dist/lib/openapi/spec/sdk-context-schema.d.ts +1 -0
  282. package/dist/lib/openapi/spec/sdk-context-schema.js +1 -0
  283. package/dist/lib/openapi/spec/sdk-context-schema.js.map +1 -1
  284. package/dist/lib/openapi/spec/sdk-flat-context-schema.d.ts +46 -0
  285. package/dist/lib/openapi/spec/sdk-flat-context-schema.js +15 -0
  286. package/dist/lib/openapi/spec/sdk-flat-context-schema.js.map +1 -0
  287. package/dist/lib/openapi/spec/search-events-schema.d.ts +1 -1
  288. package/dist/lib/openapi/spec/segments-schema.d.ts +177 -0
  289. package/dist/lib/openapi/spec/segments-schema.js +26 -0
  290. package/dist/lib/openapi/spec/segments-schema.js.map +1 -0
  291. package/dist/lib/openapi/spec/segments-schema.test.d.ts +1 -0
  292. package/dist/lib/openapi/spec/segments-schema.test.js +16 -0
  293. package/dist/lib/openapi/spec/segments-schema.test.js.map +1 -0
  294. package/dist/lib/openapi/spec/state-schema.d.ts +23 -23
  295. package/dist/lib/openapi/spec/strategy-variant-schema.d.ts +2 -2
  296. package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.d.ts +35 -0
  297. package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.js +37 -0
  298. package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.js.map +1 -0
  299. package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.test.d.ts +1 -0
  300. package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.test.js +19 -0
  301. package/dist/lib/openapi/spec/update-feature-strategy-segments-schema.test.js.map +1 -0
  302. package/dist/lib/openapi/spec/upsert-segment-schema.d.ts +8 -15
  303. package/dist/lib/openapi/spec/upsert-segment-schema.js +8 -17
  304. package/dist/lib/openapi/spec/upsert-segment-schema.js.map +1 -1
  305. package/dist/lib/openapi/spec/upsert-segment-schema.test.d.ts +1 -0
  306. package/dist/lib/openapi/spec/upsert-segment-schema.test.js +35 -0
  307. package/dist/lib/openapi/spec/upsert-segment-schema.test.js.map +1 -0
  308. package/dist/lib/openapi/spec/validate-feature-schema.d.ts +6 -0
  309. package/dist/lib/openapi/spec/validate-feature-schema.js +6 -0
  310. package/dist/lib/openapi/spec/validate-feature-schema.js.map +1 -1
  311. package/dist/lib/openapi/spec/variant-schema.d.ts +2 -2
  312. package/dist/lib/openapi/spec/variant-schema.js +2 -2
  313. package/dist/lib/openapi/spec/variant-schema.js.map +1 -1
  314. package/dist/lib/openapi/spec/variants-schema.d.ts +2 -2
  315. package/dist/lib/openapi/util/all-of.d.ts +3 -0
  316. package/dist/lib/openapi/util/all-of.js +34 -0
  317. package/dist/lib/openapi/util/all-of.js.map +1 -0
  318. package/dist/lib/openapi/util/openapi-tags.d.ts +46 -58
  319. package/dist/lib/openapi/util/openapi-tags.js +27 -34
  320. package/dist/lib/openapi/util/openapi-tags.js.map +1 -1
  321. package/dist/lib/openapi/util/openapi-tags.test.d.ts +1 -0
  322. package/dist/lib/openapi/util/openapi-tags.test.js +15 -0
  323. package/dist/lib/openapi/util/openapi-tags.test.js.map +1 -0
  324. package/dist/lib/openapi/validate.js +0 -1
  325. package/dist/lib/openapi/validate.js.map +1 -1
  326. package/dist/lib/routes/admin-api/archive.d.ts +1 -1
  327. package/dist/lib/routes/admin-api/archive.js +3 -2
  328. package/dist/lib/routes/admin-api/archive.js.map +1 -1
  329. package/dist/lib/routes/admin-api/context.js +2 -1
  330. package/dist/lib/routes/admin-api/context.js.map +1 -1
  331. package/dist/lib/routes/admin-api/feature.js +2 -1
  332. package/dist/lib/routes/admin-api/feature.js.map +1 -1
  333. package/dist/lib/routes/admin-api/index.js +2 -0
  334. package/dist/lib/routes/admin-api/index.js.map +1 -1
  335. package/dist/lib/routes/admin-api/instance-admin.d.ts +2 -2
  336. package/dist/lib/routes/admin-api/instance-admin.js +7 -1
  337. package/dist/lib/routes/admin-api/instance-admin.js.map +1 -1
  338. package/dist/lib/routes/admin-api/metrics.d.ts +2 -1
  339. package/dist/lib/routes/admin-api/metrics.js +2 -1
  340. package/dist/lib/routes/admin-api/metrics.js.map +1 -1
  341. package/dist/lib/routes/admin-api/project/api-token.d.ts +2 -1
  342. package/dist/lib/routes/admin-api/project/api-token.js +12 -3
  343. package/dist/lib/routes/admin-api/project/api-token.js.map +1 -1
  344. package/dist/lib/routes/admin-api/project/environments.d.ts +2 -1
  345. package/dist/lib/routes/admin-api/project/environments.js +3 -1
  346. package/dist/lib/routes/admin-api/project/environments.js.map +1 -1
  347. package/dist/lib/routes/admin-api/project/index.d.ts +2 -1
  348. package/dist/lib/routes/admin-api/project/index.js +31 -0
  349. package/dist/lib/routes/admin-api/project/index.js.map +1 -1
  350. package/dist/lib/routes/admin-api/strategy.d.ts +1 -1
  351. package/dist/lib/routes/admin-api/strategy.js.map +1 -1
  352. package/dist/lib/routes/client-api/metrics.js +14 -8
  353. package/dist/lib/routes/client-api/metrics.js.map +1 -1
  354. package/dist/lib/routes/client-api/metrics.test.js +27 -0
  355. package/dist/lib/routes/client-api/metrics.test.js.map +1 -1
  356. package/dist/lib/routes/controller.d.ts +1 -1
  357. package/dist/lib/routes/controller.js +17 -10
  358. package/dist/lib/routes/controller.js.map +1 -1
  359. package/dist/lib/routes/proxy-api/index.js +5 -0
  360. package/dist/lib/routes/proxy-api/index.js.map +1 -1
  361. package/dist/lib/schema/role-schema.js +3 -1
  362. package/dist/lib/schema/role-schema.js.map +1 -1
  363. package/dist/lib/schema/role-schema.test.js +1 -1
  364. package/dist/lib/schema/role-schema.test.js.map +1 -1
  365. package/dist/lib/segments/segment-service-interface.d.ts +1 -1
  366. package/dist/lib/services/access-service.d.ts +29 -11
  367. package/dist/lib/services/access-service.js +53 -10
  368. package/dist/lib/services/access-service.js.map +1 -1
  369. package/dist/lib/services/access-service.test.js +2 -1
  370. package/dist/lib/services/access-service.test.js.map +1 -1
  371. package/dist/lib/services/addon-service.js +4 -2
  372. package/dist/lib/services/addon-service.js.map +1 -1
  373. package/dist/lib/services/addon-service.test.js +65 -0
  374. package/dist/lib/services/addon-service.test.js.map +1 -1
  375. package/dist/lib/services/client-metrics/instance-service.d.ts +5 -2
  376. package/dist/lib/services/client-metrics/instance-service.js +22 -3
  377. package/dist/lib/services/client-metrics/instance-service.js.map +1 -1
  378. package/dist/lib/services/client-metrics/instance-service.test.js +5 -4
  379. package/dist/lib/services/client-metrics/instance-service.test.js.map +1 -1
  380. package/dist/lib/services/context-service.d.ts +6 -2
  381. package/dist/lib/services/context-service.js +16 -2
  382. package/dist/lib/services/context-service.js.map +1 -1
  383. package/dist/lib/services/feature-service-potentially-stale.test.js +1 -1
  384. package/dist/lib/services/feature-service-potentially-stale.test.js.map +1 -1
  385. package/dist/lib/services/feature-toggle-service.d.ts +20 -7
  386. package/dist/lib/services/feature-toggle-service.js +105 -41
  387. package/dist/lib/services/feature-toggle-service.js.map +1 -1
  388. package/dist/lib/services/group-service.d.ts +4 -4
  389. package/dist/lib/services/group-service.js +17 -16
  390. package/dist/lib/services/group-service.js.map +1 -1
  391. package/dist/lib/services/index.d.ts +3 -2
  392. package/dist/lib/services/index.js +31 -17
  393. package/dist/lib/services/index.js.map +1 -1
  394. package/dist/lib/services/project-schema.js +9 -1
  395. package/dist/lib/services/project-schema.js.map +1 -1
  396. package/dist/lib/services/project-service.d.ts +16 -12
  397. package/dist/lib/services/project-service.js +127 -17
  398. package/dist/lib/services/project-service.js.map +1 -1
  399. package/dist/lib/services/scheduler-service.d.ts +1 -1
  400. package/dist/lib/services/scheduler-service.js +3 -3
  401. package/dist/lib/services/scheduler-service.js.map +1 -1
  402. package/dist/lib/services/scheduler-service.test.js +15 -15
  403. package/dist/lib/services/scheduler-service.test.js.map +1 -1
  404. package/dist/lib/services/segment-service.d.ts +4 -2
  405. package/dist/lib/services/segment-service.js +17 -10
  406. package/dist/lib/services/segment-service.js.map +1 -1
  407. package/dist/lib/services/state-service.test.js +13 -3
  408. package/dist/lib/services/state-service.test.js.map +1 -1
  409. package/dist/lib/services/version-service.test.js +3 -0
  410. package/dist/lib/services/version-service.test.js.map +1 -1
  411. package/dist/lib/types/events.d.ts +60 -1
  412. package/dist/lib/types/events.js +65 -3
  413. package/dist/lib/types/events.js.map +1 -1
  414. package/dist/lib/types/experimental.d.ts +1 -1
  415. package/dist/lib/types/experimental.js +9 -5
  416. package/dist/lib/types/experimental.js.map +1 -1
  417. package/dist/lib/types/group.d.ts +2 -2
  418. package/dist/lib/types/model.d.ts +31 -2
  419. package/dist/lib/types/model.js.map +1 -1
  420. package/dist/lib/types/no-auth-user.d.ts +1 -0
  421. package/dist/lib/types/no-auth-user.js +3 -1
  422. package/dist/lib/types/no-auth-user.js.map +1 -1
  423. package/dist/lib/types/option.d.ts +7 -0
  424. package/dist/lib/types/services.d.ts +6 -1
  425. package/dist/lib/types/stores/access-store.d.ts +23 -4
  426. package/dist/lib/types/stores/feature-strategies-store.d.ts +2 -1
  427. package/dist/lib/types/stores/group-store.d.ts +4 -2
  428. package/dist/lib/types/stores/project-stats-store-type.d.ts +2 -0
  429. package/dist/lib/types/stores/project-store.d.ts +7 -14
  430. package/dist/lib/types/stores/strategy-store.d.ts +3 -17
  431. package/dist/lib/types/stores.d.ts +5 -1
  432. package/dist/lib/util/findDuplicates.d.ts +1 -0
  433. package/dist/lib/util/findDuplicates.js +18 -0
  434. package/dist/lib/util/findDuplicates.js.map +1 -0
  435. package/dist/lib/util/findDuplicates.test.d.ts +1 -0
  436. package/dist/lib/util/findDuplicates.test.js +23 -0
  437. package/dist/lib/util/findDuplicates.test.js.map +1 -0
  438. package/dist/migrations/20230830121352-update-client-applications-usage-table.d.ts +2 -0
  439. package/dist/migrations/20230830121352-update-client-applications-usage-table.js +16 -0
  440. package/dist/migrations/20230830121352-update-client-applications-usage-table.js.map +1 -0
  441. package/dist/migrations/20230905122605-add-feature-naming-description.d.ts +2 -0
  442. package/dist/migrations/20230905122605-add-feature-naming-description.js +13 -0
  443. package/dist/migrations/20230905122605-add-feature-naming-description.js.map +1 -0
  444. package/dist/migrations/20230919104006-dependent-features.d.ts +2 -0
  445. package/dist/migrations/20230919104006-dependent-features.js +21 -0
  446. package/dist/migrations/20230919104006-dependent-features.js.map +1 -0
  447. package/dist/migrations/20230927071830-reset-pnps-feedback.d.ts +2 -0
  448. package/dist/migrations/20230927071830-reset-pnps-feedback.js +10 -0
  449. package/dist/migrations/20230927071830-reset-pnps-feedback.js.map +1 -0
  450. package/dist/server-dev.js +7 -4
  451. package/dist/server-dev.js.map +1 -1
  452. package/dist/test/e2e/api/admin/addon.e2e.test.js +0 -1
  453. package/dist/test/e2e/api/admin/addon.e2e.test.js.map +1 -1
  454. package/dist/test/e2e/api/admin/api-token.auth.e2e.test.js +8 -12
  455. package/dist/test/e2e/api/admin/api-token.auth.e2e.test.js.map +1 -1
  456. package/dist/test/e2e/api/admin/event.e2e.test.js +9 -2
  457. package/dist/test/e2e/api/admin/event.e2e.test.js.map +1 -1
  458. package/dist/test/e2e/api/admin/metrics.e2e.test.js +2 -10
  459. package/dist/test/e2e/api/admin/metrics.e2e.test.js.map +1 -1
  460. package/dist/test/e2e/api/admin/project/environments.e2e.test.js +8 -0
  461. package/dist/test/e2e/api/admin/project/environments.e2e.test.js.map +1 -1
  462. package/dist/test/e2e/api/admin/project/features.e2e.test.js +41 -15
  463. package/dist/test/e2e/api/admin/project/features.e2e.test.js.map +1 -1
  464. package/dist/test/e2e/api/admin/project/project.api.tokens.e2e.test.js +30 -3
  465. package/dist/test/e2e/api/admin/project/project.api.tokens.e2e.test.js.map +1 -1
  466. package/dist/test/e2e/api/admin/segment.e2e.test.d.ts +1 -0
  467. package/dist/test/e2e/api/admin/segment.e2e.test.js +272 -0
  468. package/dist/test/e2e/api/admin/segment.e2e.test.js.map +1 -0
  469. package/dist/test/e2e/api/admin/state.e2e.test.js +0 -11
  470. package/dist/test/e2e/api/admin/state.e2e.test.js.map +1 -1
  471. package/dist/test/e2e/api/admin/strategy.e2e.test.js +1 -1
  472. package/dist/test/e2e/api/client/feature.e2e.test.js +27 -3
  473. package/dist/test/e2e/api/client/feature.e2e.test.js.map +1 -1
  474. package/dist/test/e2e/api/client/feature.token.access.e2e.test.js +2 -2
  475. package/dist/test/e2e/api/client/feature.token.access.e2e.test.js.map +1 -1
  476. package/dist/test/e2e/api/client/segment.e2e.test.js +1 -1
  477. package/dist/test/e2e/api/client/segment.e2e.test.js.map +1 -1
  478. package/dist/test/e2e/api/proxy/proxy.e2e.test.js +34 -9
  479. package/dist/test/e2e/api/proxy/proxy.e2e.test.js.map +1 -1
  480. package/dist/test/e2e/helpers/app.utils.d.ts +6 -0
  481. package/dist/test/e2e/helpers/app.utils.js +16 -0
  482. package/dist/test/e2e/helpers/app.utils.js.map +1 -0
  483. package/dist/test/e2e/helpers/database.json +24 -0
  484. package/dist/test/e2e/services/access-service.e2e.test.js +549 -135
  485. package/dist/test/e2e/services/access-service.e2e.test.js.map +1 -1
  486. package/dist/test/e2e/services/api-token-service.e2e.test.js +4 -2
  487. package/dist/test/e2e/services/api-token-service.e2e.test.js.map +1 -1
  488. package/dist/test/e2e/services/client-metrics-service.e2e.test.js +2 -1
  489. package/dist/test/e2e/services/client-metrics-service.e2e.test.js.map +1 -1
  490. package/dist/test/e2e/services/feature-toggle-service-v2.e2e.test.js +38 -5
  491. package/dist/test/e2e/services/feature-toggle-service-v2.e2e.test.js.map +1 -1
  492. package/dist/test/e2e/services/group-service.e2e.test.js +16 -11
  493. package/dist/test/e2e/services/group-service.e2e.test.js.map +1 -1
  494. package/dist/test/e2e/services/playground-service.test.js +5 -2
  495. package/dist/test/e2e/services/playground-service.test.js.map +1 -1
  496. package/dist/test/e2e/services/project-health-service.e2e.test.js +4 -2
  497. package/dist/test/e2e/services/project-health-service.e2e.test.js.map +1 -1
  498. package/dist/test/e2e/services/project-service.e2e.test.js +242 -60
  499. package/dist/test/e2e/services/project-service.e2e.test.js.map +1 -1
  500. package/dist/test/fixtures/access-service-mock.d.ts +3 -4
  501. package/dist/test/fixtures/access-service-mock.js.map +1 -1
  502. package/dist/test/fixtures/fake-access-store.d.ts +15 -5
  503. package/dist/test/fixtures/fake-access-store.js +30 -3
  504. package/dist/test/fixtures/fake-access-store.js.map +1 -1
  505. package/dist/test/fixtures/fake-group-store.d.ts +4 -2
  506. package/dist/test/fixtures/fake-group-store.js +3 -0
  507. package/dist/test/fixtures/fake-group-store.js.map +1 -1
  508. package/dist/test/fixtures/fake-project-stats-store.d.ts +1 -0
  509. package/dist/test/fixtures/fake-project-stats-store.js +3 -0
  510. package/dist/test/fixtures/fake-project-stats-store.js.map +1 -1
  511. package/dist/test/fixtures/fake-project-store.d.ts +2 -1
  512. package/dist/test/fixtures/fake-project-store.js +3 -0
  513. package/dist/test/fixtures/fake-project-store.js.map +1 -1
  514. package/dist/test/fixtures/no-logger.d.ts +2 -1
  515. package/dist/test/fixtures/no-logger.js +8 -4
  516. package/dist/test/fixtures/no-logger.js.map +1 -1
  517. package/dist/test/fixtures/store.js +3 -0
  518. package/dist/test/fixtures/store.js.map +1 -1
  519. package/frontend/README.md +7 -1
  520. package/frontend/build/index.html +2 -2
  521. package/frontend/build/static/{AdvancedPlayground-1748fcdd.js → AdvancedPlayground-20059178.js} +11 -11
  522. package/frontend/build/static/CreateProject-6955728f.js +4 -0
  523. package/frontend/build/static/{Error-cbce6b64.js → Error-f56339ab.js} +1 -1
  524. package/frontend/build/static/FeatureArchiveDialog-33dc3a5b.js +10 -0
  525. package/frontend/build/static/{FeatureMetricsChart-8fd8a304.js → FeatureMetricsChart-5ad514bc.js} +2 -2
  526. package/frontend/build/static/FeatureViewLazyExport-85a68ed0.js +7 -0
  527. package/frontend/build/static/LazyAdminExport-e2677758.js +35 -0
  528. package/frontend/build/static/LazyProjectExport-969bb54e.js +24 -0
  529. package/frontend/build/static/Logo-android-218bddbb.svg +1 -0
  530. package/frontend/build/static/Logo-flutter-cc3c706f.svg +1 -0
  531. package/frontend/build/static/Logo-go-02475b3d.svg +1 -0
  532. package/frontend/build/static/Logo-java-6e556b26.svg +1 -0
  533. package/frontend/build/static/Logo-javascript-caebc06e.svg +1 -0
  534. package/frontend/build/static/Logo-net-0a33abee.svg +1 -0
  535. package/frontend/build/static/Logo-node-318ed025.svg +1 -0
  536. package/frontend/build/static/Logo-php-201f18c3.svg +1 -0
  537. package/frontend/build/static/Logo-python-4305760e.svg +1 -0
  538. package/frontend/build/static/Logo-react-18e98687.svg +1 -0
  539. package/frontend/build/static/Logo-ruby-58f46832.svg +1 -0
  540. package/frontend/build/static/Logo-rust-c83a80f9.svg +1 -0
  541. package/frontend/build/static/Logo-svelte-97dcb624.svg +1 -0
  542. package/frontend/build/static/Logo-swift-315f842b.svg +5 -0
  543. package/frontend/build/static/Logo-vue-0de73099.svg +1 -0
  544. package/frontend/build/static/{NetworkOverview-349a7bdd.js → NetworkOverview-894877e6.js} +2 -2
  545. package/frontend/build/static/{NetworkTraffic-60478e50.js → NetworkTraffic-81eff1ae.js} +1 -1
  546. package/frontend/build/static/ReactJSONEditor-59c8a094.js +129 -0
  547. package/frontend/build/static/RoleCell-35857d41.js +1 -0
  548. package/frontend/build/static/{StrategyItemContainer-a4caeace.js → StrategyItemContainer-b250f2d4.js} +1 -1
  549. package/frontend/build/static/{chartjs-adapter-date-fns.esm-03d2fbea.js → chartjs-adapter-date-fns.esm-c51fe022.js} +1 -1
  550. package/frontend/build/static/cr-db7653ac.png +0 -0
  551. package/frontend/build/static/datadog-543762b6.svg +5 -0
  552. package/frontend/build/static/edge-daisy-chaining-012bfdef.svg +48 -0
  553. package/frontend/build/static/edge-mode-5d25949b.svg +22 -0
  554. package/frontend/build/static/edge-offline-f6a0f761.svg +19 -0
  555. package/frontend/build/static/{flowchart-elk-definition-170a3958-fc100c77.js → flowchart-elk-definition-170a3958-a8c4a86a.js} +1 -1
  556. package/frontend/build/static/{index-866f9bf9.js → index-0515f416.js} +1 -1
  557. package/frontend/build/static/index-942e9eeb.js +463 -0
  558. package/frontend/build/static/{index-3c63138f.js → index-a59b2d65.js} +1 -1
  559. package/frontend/build/static/{is_dark-31c253e9.js → is_dark-464961a8.js} +1 -1
  560. package/frontend/build/static/jira-1abe7cbf.svg +17 -0
  561. package/frontend/build/static/{mindmap-definition-44684416-398682f9.js → mindmap-definition-44684416-3a71a9a5.js} +1 -1
  562. package/frontend/build/static/slack-36ce798a.svg +18 -0
  563. package/frontend/build/static/style-97d3ef98.css +1 -0
  564. package/frontend/build/static/teams-4e30b51f.svg +45 -0
  565. package/frontend/build/static/{timeline-definition-8e5a9bc6-04a0ae08.js → timeline-definition-8e5a9bc6-da4ebc88.js} +1 -1
  566. package/frontend/build/static/{unknownify-b8618d88.js → unknownify-3563456b.js} +1 -1
  567. package/frontend/build/static/unleash-integration-949d8966.svg +1 -0
  568. package/frontend/build/static/webhooks-b1b44207.svg +16 -0
  569. package/frontend/package.json +20 -18
  570. package/package.json +23 -23
  571. package/dist/lib/services/instance-stats-service.js.map +0 -1
  572. package/dist/lib/services/instance-stats-service.test.js.map +0 -1
  573. package/frontend/build/static/CreateProject-972fa820.js +0 -4
  574. package/frontend/build/static/FeatureArchiveDialog-8a281845.js +0 -10
  575. package/frontend/build/static/FeatureViewLazyExport-a215d53b.js +0 -7
  576. package/frontend/build/static/LazyAdminExport-ba7d55ca.js +0 -35
  577. package/frontend/build/static/LazyProjectExport-12bccd40.js +0 -17
  578. package/frontend/build/static/RoleCell-144e7eca.js +0 -1
  579. package/frontend/build/static/datadog-591b6a73.svg +0 -1
  580. package/frontend/build/static/index-17d74ac9.js +0 -454
  581. package/frontend/build/static/slack-c0af31c6.svg +0 -1
  582. package/frontend/build/static/style-770afaee.css +0 -1
  583. package/frontend/build/static/teams-62e72076.svg +0 -26
  584. package/frontend/build/static/webhooks-ffa904ac.svg +0 -1
  585. /package/dist/lib/{services/instance-stats-service.test.d.ts → db/access-store.test.d.ts} +0 -0
  586. /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,4 @@
1
+ import { ProjectAccess } from './privateProjectStore';
2
+ export interface IPrivateProjectStore {
3
+ getUserAccessibleProjects(userId: number): Promise<ProjectAccess>;
4
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=privateProjectStoreType.js.map
@@ -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":"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"}
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,uFAA6D;AAC7D,uEAGuC;AACvC,6FAGsD;AACtD,8EAAyE;AACzE,8EAAyE;AACzE,mGAAyE;AACzE,iHAAsF;AACtF,6GAAkF;AAClF,2GAAiF;AACjF,2HAAgG;AAChG,+GAAoF;AACpF,uHAA4F;AAC5F,uHAA4F;AAC5F,kFAA6E;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,UAAU,GAAG,IAAI,qBAAU,CAAC,EAAE,CAAC,CAAC;IACtC,MAAM,kBAAkB,GAAG,IAAI,8BAAkB,CAAC,EAAE,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;IAC3E,MAAM,gBAAgB,GAAG,IAAI,4BAAgB,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,IAAI,4BAAY,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;IACrD,MAAM,gBAAgB,GAAG,IAAI,2BAAgB,CAAC,EAAE,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;IACvE,MAAM,uBAAuB,GAAG,IAAI,mDAAuB,CACvD,EAAE,EACF,QAAQ,EACR,SAAS,CACZ,CAAC;IACF,MAAM,iBAAiB,GAAG,IAAI,6BAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;IACzE,MAAM,aAAa,GAAkB,IAAA,yCAAmB,EAAC,EAAE,EAAE,MAAM,CAAC,CAAC;IACrE,MAAM,oBAAoB,GAAG,IAAA,uDAA0B,EAAC,EAAE,EAAE,MAAM,CAAC,CAAC;IACpE,MAAM,qBAAqB,GAAG,IAAI,+CAAqB,CACnD,EAAE,EACF,QAAQ,EACR,SAAS,CACZ,CAAC;IACF,MAAM,qBAAqB,GAAG,IAAI,+CAAqB,CACnD,EAAE,EACF,QAAQ,EACR,SAAS,CACZ,CAAC;IACF,MAAM,eAAe,GAAG,IAAI,2BAAgB,CACxC;QACI,qBAAqB;QACrB,qBAAqB;QACrB,UAAU;KACb,EACD,MAAM,CACT,CAAC;IACF,MAAM,YAAY,GAAG,IAAI,uBAAY,CACjC,EAAE,UAAU,EAAE,UAAU,EAAE,YAAY,EAAE,EACxC,EAAE,SAAS,EAAE,CAChB,CAAC;IAEF,MAAM,qBAAqB,GAAG,IAAA,yDAA2B,EAAC,EAAE,EAAE,MAAM,CAAC,CAAC;IAEtE,OAAO,IAAI,yBAAc,CACrB;QACI,YAAY;QACZ,UAAU;QACV,kBAAkB;QAClB,gBAAgB;QAChB,gBAAgB;QAChB,uBAAuB;QACvB,YAAY;QACZ,iBAAiB;KACpB,EACD,MAAM,EACN,aAAa,EACb,oBAAoB,EACpB,YAAY,EACZ,eAAe,EACf,qBAAqB,CACxB,CAAC;AACN,CAAC,CAAC;AApEW,QAAA,oBAAoB,wBAoE/B;AAEK,MAAM,wBAAwB,GAAG,CACpC,MAAsB,EACR,EAAE;IAChB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;IAC7B,MAAM,UAAU,GAAG,IAAI,0BAAc,EAAE,CAAC;IACxC,MAAM,YAAY,GAAG,IAAI,4BAAgB,EAAE,CAAC;IAC5C,MAAM,UAAU,GAAG,IAAI,0BAAc,EAAE,CAAC;IACxC,MAAM,kBAAkB,GAAG,IAAI,mCAAsB,EAAE,CAAC;IACxD,MAAM,gBAAgB,GAAG,IAAI,iCAAoB,EAAE,CAAC;IACpD,MAAM,YAAY,GAAG,IAAI,qCAAgB,EAAE,CAAC;IAC5C,MAAM,gBAAgB,GAAG,IAAI,gCAAoB,EAAE,CAAC;IACpD,MAAM,uBAAuB,GAAG,IAAI,wCAA2B,EAAE,CAAC;IAClE,MAAM,iBAAiB,GAAG,IAAI,kCAAqB,EAAE,CAAC;IACtD,MAAM,aAAa,GAAG,IAAA,6CAAuB,EAAC,MAAM,CAAC,CAAC;IACtD,MAAM,oBAAoB,GAAG,IAAA,2DAA8B,EAAC,MAAM,CAAC,CAAC;IACpE,MAAM,qBAAqB,GAAG,IAAI,sCAAyB,EAAE,CAAC;IAC9D,MAAM,qBAAqB,GAAG,IAAI,sCAAyB,EAAE,CAAC;IAC9D,MAAM,eAAe,GAAG,IAAI,2BAAgB,CACxC;QACI,qBAAqB;QACrB,qBAAqB;QACrB,UAAU;KACb,EACD,MAAM,CACT,CAAC;IACF,MAAM,YAAY,GAAG,IAAI,uBAAY,CACjC,EAAE,UAAU,EAAE,UAAU,EAAE,YAAY,EAAE,EACxC,EAAE,SAAS,EAAE,CAChB,CAAC;IAEF,MAAM,qBAAqB,GAAG,IAAA,6DAA+B,GAAE,CAAC;IAEhE,OAAO,IAAI,yBAAc,CACrB;QACI,YAAY;QACZ,UAAU;QACV,kBAAkB;QAClB,gBAAgB;QAChB,gBAAgB;QAChB,uBAAuB;QACvB,YAAY;QACZ,iBAAiB;KACpB,EACD,MAAM,EACN,aAAa,EACb,oBAAoB,EACpB,YAAY,EACZ,eAAe,EACf,qBAAqB,CACxB,CAAC;AACN,CAAC,CAAC;AAlDW,QAAA,wBAAwB,4BAkDnC"}
@@ -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
- return new services_1.SegmentService({ segmentStore, featureStrategiesStore, eventStore }, changeRequestAccessReadModel, config);
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
- return new services_1.SegmentService({ segmentStore, featureStrategiesStore, eventStore }, changeRequestAccessReadModel, config);
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;AAEtE,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;IAEF,OAAO,IAAI,yBAAc,CACrB,EAAE,YAAY,EAAE,sBAAsB,EAAE,UAAU,EAAE,EACpD,4BAA4B,EAC5B,MAAM,CACT,CAAC;AACN,CAAC,CAAC;AA5BW,QAAA,oBAAoB,wBA4B/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,OAAO,IAAI,yBAAc,CACrB,EAAE,YAAY,EAAE,sBAAsB,EAAE,UAAU,EAAE,EACpD,4BAA4B,EAC5B,MAAM,CACT,CAAC;AACN,CAAC,CAAC;AAbW,QAAA,wBAAwB,4BAanC"}
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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"}
@@ -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 './services/instance-stats-service';
8
+ import { InstanceStatsService } from './features/instance-stats/instance-stats-service';
9
9
  export default class MetricsMonitor {
10
10
  timer?: Timer;
11
11
  poolMetricsTimer?: Timer;
@@ -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
- projectsTotal.set(stats.projects);
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();