@urateam/core 0.1.4 → 0.1.8

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 (478) hide show
  1. package/dist/__tests__/audit/audit-e2e.test.d.ts +2 -0
  2. package/dist/__tests__/audit/audit-e2e.test.d.ts.map +1 -0
  3. package/dist/__tests__/audit/audit-e2e.test.js +56 -0
  4. package/dist/__tests__/audit/audit-e2e.test.js.map +1 -0
  5. package/dist/__tests__/audit/csv.test.d.ts +2 -0
  6. package/dist/__tests__/audit/csv.test.d.ts.map +1 -0
  7. package/dist/__tests__/audit/csv.test.js +134 -0
  8. package/dist/__tests__/audit/csv.test.js.map +1 -0
  9. package/dist/__tests__/audit/events.test.d.ts +2 -0
  10. package/dist/__tests__/audit/events.test.d.ts.map +1 -0
  11. package/dist/__tests__/audit/events.test.js +45 -0
  12. package/dist/__tests__/audit/events.test.js.map +1 -0
  13. package/dist/__tests__/audit/policy-events.test.d.ts +2 -0
  14. package/dist/__tests__/audit/policy-events.test.d.ts.map +1 -0
  15. package/dist/__tests__/audit/policy-events.test.js +49 -0
  16. package/dist/__tests__/audit/policy-events.test.js.map +1 -0
  17. package/dist/__tests__/audit/projection.test.d.ts +2 -0
  18. package/dist/__tests__/audit/projection.test.d.ts.map +1 -0
  19. package/dist/__tests__/audit/projection.test.js +76 -0
  20. package/dist/__tests__/audit/projection.test.js.map +1 -0
  21. package/dist/__tests__/audit/rbac-events.test.d.ts +2 -0
  22. package/dist/__tests__/audit/rbac-events.test.d.ts.map +1 -0
  23. package/dist/__tests__/audit/rbac-events.test.js +56 -0
  24. package/dist/__tests__/audit/rbac-events.test.js.map +1 -0
  25. package/dist/__tests__/audit/reader.test.d.ts +2 -0
  26. package/dist/__tests__/audit/reader.test.d.ts.map +1 -0
  27. package/dist/__tests__/audit/reader.test.js +133 -0
  28. package/dist/__tests__/audit/reader.test.js.map +1 -0
  29. package/dist/__tests__/audit/retention.test.d.ts +2 -0
  30. package/dist/__tests__/audit/retention.test.d.ts.map +1 -0
  31. package/dist/__tests__/audit/retention.test.js +48 -0
  32. package/dist/__tests__/audit/retention.test.js.map +1 -0
  33. package/dist/__tests__/audit/sso-events.test.d.ts +2 -0
  34. package/dist/__tests__/audit/sso-events.test.d.ts.map +1 -0
  35. package/dist/__tests__/audit/sso-events.test.js +49 -0
  36. package/dist/__tests__/audit/sso-events.test.js.map +1 -0
  37. package/dist/__tests__/audit/writer.test.d.ts +2 -0
  38. package/dist/__tests__/audit/writer.test.d.ts.map +1 -0
  39. package/dist/__tests__/audit/writer.test.js +67 -0
  40. package/dist/__tests__/audit/writer.test.js.map +1 -0
  41. package/dist/__tests__/audit-immutability.test.d.ts +2 -0
  42. package/dist/__tests__/audit-immutability.test.d.ts.map +1 -0
  43. package/dist/__tests__/audit-immutability.test.js +61 -0
  44. package/dist/__tests__/audit-immutability.test.js.map +1 -0
  45. package/dist/__tests__/audit-types.test.d.ts +2 -0
  46. package/dist/__tests__/audit-types.test.d.ts.map +1 -0
  47. package/dist/__tests__/audit-types.test.js +35 -0
  48. package/dist/__tests__/audit-types.test.js.map +1 -0
  49. package/dist/__tests__/auth/session-store.test.d.ts +2 -0
  50. package/dist/__tests__/auth/session-store.test.d.ts.map +1 -0
  51. package/dist/__tests__/auth/session-store.test.js +65 -0
  52. package/dist/__tests__/auth/session-store.test.js.map +1 -0
  53. package/dist/__tests__/auth/sso-config.test.d.ts +2 -0
  54. package/dist/__tests__/auth/sso-config.test.d.ts.map +1 -0
  55. package/dist/__tests__/auth/sso-config.test.js +75 -0
  56. package/dist/__tests__/auth/sso-config.test.js.map +1 -0
  57. package/dist/__tests__/auth/sso-feature-flag.test.d.ts +2 -0
  58. package/dist/__tests__/auth/sso-feature-flag.test.d.ts.map +1 -0
  59. package/dist/__tests__/auth/sso-feature-flag.test.js +33 -0
  60. package/dist/__tests__/auth/sso-feature-flag.test.js.map +1 -0
  61. package/dist/__tests__/auth/user-role-round-trip.test.d.ts +2 -0
  62. package/dist/__tests__/auth/user-role-round-trip.test.d.ts.map +1 -0
  63. package/dist/__tests__/auth/user-role-round-trip.test.js +30 -0
  64. package/dist/__tests__/auth/user-role-round-trip.test.js.map +1 -0
  65. package/dist/__tests__/auth/user-store.test.d.ts +2 -0
  66. package/dist/__tests__/auth/user-store.test.d.ts.map +1 -0
  67. package/dist/__tests__/auth/user-store.test.js +119 -0
  68. package/dist/__tests__/auth/user-store.test.js.map +1 -0
  69. package/dist/__tests__/auth/workos-client.test.d.ts +2 -0
  70. package/dist/__tests__/auth/workos-client.test.d.ts.map +1 -0
  71. package/dist/__tests__/auth/workos-client.test.js +17 -0
  72. package/dist/__tests__/auth/workos-client.test.js.map +1 -0
  73. package/dist/__tests__/auto-merge.test.js +2 -1
  74. package/dist/__tests__/auto-merge.test.js.map +1 -1
  75. package/dist/__tests__/cost/aggregate.test.d.ts +2 -0
  76. package/dist/__tests__/cost/aggregate.test.d.ts.map +1 -0
  77. package/dist/__tests__/cost/aggregate.test.js +358 -0
  78. package/dist/__tests__/cost/aggregate.test.js.map +1 -0
  79. package/dist/__tests__/cost/csv.test.d.ts +2 -0
  80. package/dist/__tests__/cost/csv.test.d.ts.map +1 -0
  81. package/dist/__tests__/cost/csv.test.js +109 -0
  82. package/dist/__tests__/cost/csv.test.js.map +1 -0
  83. package/dist/__tests__/cost/per-run.test.d.ts +2 -0
  84. package/dist/__tests__/cost/per-run.test.d.ts.map +1 -0
  85. package/dist/__tests__/cost/per-run.test.js +64 -0
  86. package/dist/__tests__/cost/per-run.test.js.map +1 -0
  87. package/dist/__tests__/cost/rates.test.d.ts +2 -0
  88. package/dist/__tests__/cost/rates.test.d.ts.map +1 -0
  89. package/dist/__tests__/cost/rates.test.js +47 -0
  90. package/dist/__tests__/cost/rates.test.js.map +1 -0
  91. package/dist/__tests__/cost/rollup.test.d.ts +2 -0
  92. package/dist/__tests__/cost/rollup.test.d.ts.map +1 -0
  93. package/dist/__tests__/cost/rollup.test.js +187 -0
  94. package/dist/__tests__/cost/rollup.test.js.map +1 -0
  95. package/dist/__tests__/cost-defensive.test.d.ts +2 -0
  96. package/dist/__tests__/cost-defensive.test.d.ts.map +1 -0
  97. package/dist/__tests__/cost-defensive.test.js +123 -0
  98. package/dist/__tests__/cost-defensive.test.js.map +1 -0
  99. package/dist/__tests__/cost-integration.test.d.ts +2 -0
  100. package/dist/__tests__/cost-integration.test.d.ts.map +1 -0
  101. package/dist/__tests__/cost-integration.test.js +80 -0
  102. package/dist/__tests__/cost-integration.test.js.map +1 -0
  103. package/dist/__tests__/cost-license.test.d.ts +2 -0
  104. package/dist/__tests__/cost-license.test.d.ts.map +1 -0
  105. package/dist/__tests__/cost-license.test.js +23 -0
  106. package/dist/__tests__/cost-license.test.js.map +1 -0
  107. package/dist/__tests__/cost-types.test.d.ts +2 -0
  108. package/dist/__tests__/cost-types.test.d.ts.map +1 -0
  109. package/dist/__tests__/cost-types.test.js +65 -0
  110. package/dist/__tests__/cost-types.test.js.map +1 -0
  111. package/dist/__tests__/db-audit-schema.test.d.ts +2 -0
  112. package/dist/__tests__/db-audit-schema.test.d.ts.map +1 -0
  113. package/dist/__tests__/db-audit-schema.test.js +35 -0
  114. package/dist/__tests__/db-audit-schema.test.js.map +1 -0
  115. package/dist/__tests__/db-cost-rollups-schema.test.d.ts +2 -0
  116. package/dist/__tests__/db-cost-rollups-schema.test.d.ts.map +1 -0
  117. package/dist/__tests__/db-cost-rollups-schema.test.js +28 -0
  118. package/dist/__tests__/db-cost-rollups-schema.test.js.map +1 -0
  119. package/dist/__tests__/db-rbac-schema.test.d.ts +2 -0
  120. package/dist/__tests__/db-rbac-schema.test.d.ts.map +1 -0
  121. package/dist/__tests__/db-rbac-schema.test.js +32 -0
  122. package/dist/__tests__/db-rbac-schema.test.js.map +1 -0
  123. package/dist/__tests__/db-sso-schema.test.d.ts +2 -0
  124. package/dist/__tests__/db-sso-schema.test.d.ts.map +1 -0
  125. package/dist/__tests__/db-sso-schema.test.js +48 -0
  126. package/dist/__tests__/db-sso-schema.test.js.map +1 -0
  127. package/dist/__tests__/helpers/license.d.ts +3 -0
  128. package/dist/__tests__/helpers/license.d.ts.map +1 -0
  129. package/dist/__tests__/helpers/license.js +74 -0
  130. package/dist/__tests__/helpers/license.js.map +1 -0
  131. package/dist/__tests__/license-audit-event.test.d.ts +2 -0
  132. package/dist/__tests__/license-audit-event.test.d.ts.map +1 -0
  133. package/dist/__tests__/license-audit-event.test.js +60 -0
  134. package/dist/__tests__/license-audit-event.test.js.map +1 -0
  135. package/dist/__tests__/license-end-to-end.test.d.ts +2 -0
  136. package/dist/__tests__/license-end-to-end.test.d.ts.map +1 -0
  137. package/dist/__tests__/license-end-to-end.test.js +75 -0
  138. package/dist/__tests__/license-end-to-end.test.js.map +1 -0
  139. package/dist/__tests__/license-public-key.test.d.ts +2 -0
  140. package/dist/__tests__/license-public-key.test.d.ts.map +1 -0
  141. package/dist/__tests__/license-public-key.test.js +18 -0
  142. package/dist/__tests__/license-public-key.test.js.map +1 -0
  143. package/dist/__tests__/license.test.js +195 -32
  144. package/dist/__tests__/license.test.js.map +1 -1
  145. package/dist/__tests__/pm-action-audit-events.test.d.ts +2 -0
  146. package/dist/__tests__/pm-action-audit-events.test.d.ts.map +1 -0
  147. package/dist/__tests__/pm-action-audit-events.test.js +185 -0
  148. package/dist/__tests__/pm-action-audit-events.test.js.map +1 -0
  149. package/dist/__tests__/pm-approvals.test.js +1 -1
  150. package/dist/__tests__/pm-approvals.test.js.map +1 -1
  151. package/dist/__tests__/pm-audit-retention-step.test.d.ts +2 -0
  152. package/dist/__tests__/pm-audit-retention-step.test.d.ts.map +1 -0
  153. package/dist/__tests__/pm-audit-retention-step.test.js +126 -0
  154. package/dist/__tests__/pm-audit-retention-step.test.js.map +1 -0
  155. package/dist/__tests__/pm-budget-alerts.test.d.ts +2 -0
  156. package/dist/__tests__/pm-budget-alerts.test.d.ts.map +1 -0
  157. package/dist/__tests__/pm-budget-alerts.test.js +128 -0
  158. package/dist/__tests__/pm-budget-alerts.test.js.map +1 -0
  159. package/dist/__tests__/pm-budget-refused-event.test.d.ts +2 -0
  160. package/dist/__tests__/pm-budget-refused-event.test.d.ts.map +1 -0
  161. package/dist/__tests__/pm-budget-refused-event.test.js +141 -0
  162. package/dist/__tests__/pm-budget-refused-event.test.js.map +1 -0
  163. package/dist/__tests__/pm-budget.test.js +138 -42
  164. package/dist/__tests__/pm-budget.test.js.map +1 -1
  165. package/dist/__tests__/pm-cost-rollup-step.test.d.ts +2 -0
  166. package/dist/__tests__/pm-cost-rollup-step.test.d.ts.map +1 -0
  167. package/dist/__tests__/pm-cost-rollup-step.test.js +113 -0
  168. package/dist/__tests__/pm-cost-rollup-step.test.js.map +1 -0
  169. package/dist/__tests__/pm-scheduler.test.js +48 -21
  170. package/dist/__tests__/pm-scheduler.test.js.map +1 -1
  171. package/dist/__tests__/pm-slack.test.js +37 -0
  172. package/dist/__tests__/pm-slack.test.js.map +1 -1
  173. package/dist/__tests__/pm-sso-prune-step.test.d.ts +2 -0
  174. package/dist/__tests__/pm-sso-prune-step.test.d.ts.map +1 -0
  175. package/dist/__tests__/pm-sso-prune-step.test.js +103 -0
  176. package/dist/__tests__/pm-sso-prune-step.test.js.map +1 -0
  177. package/dist/__tests__/pm-types.test.js +130 -1
  178. package/dist/__tests__/pm-types.test.js.map +1 -1
  179. package/dist/__tests__/policy/auto-merge-reviewer-gate.test.d.ts +2 -0
  180. package/dist/__tests__/policy/auto-merge-reviewer-gate.test.d.ts.map +1 -0
  181. package/dist/__tests__/policy/auto-merge-reviewer-gate.test.js +50 -0
  182. package/dist/__tests__/policy/auto-merge-reviewer-gate.test.js.map +1 -0
  183. package/dist/__tests__/policy/cost-gate.test.d.ts +2 -0
  184. package/dist/__tests__/policy/cost-gate.test.d.ts.map +1 -0
  185. package/dist/__tests__/policy/cost-gate.test.js +27 -0
  186. package/dist/__tests__/policy/cost-gate.test.js.map +1 -0
  187. package/dist/__tests__/policy/evaluate.test.d.ts +2 -0
  188. package/dist/__tests__/policy/evaluate.test.d.ts.map +1 -0
  189. package/dist/__tests__/policy/evaluate.test.js +105 -0
  190. package/dist/__tests__/policy/evaluate.test.js.map +1 -0
  191. package/dist/__tests__/policy/override.test.d.ts +2 -0
  192. package/dist/__tests__/policy/override.test.d.ts.map +1 -0
  193. package/dist/__tests__/policy/override.test.js +26 -0
  194. package/dist/__tests__/policy/override.test.js.map +1 -0
  195. package/dist/__tests__/policy/path-gate.test.d.ts +2 -0
  196. package/dist/__tests__/policy/path-gate.test.d.ts.map +1 -0
  197. package/dist/__tests__/policy/path-gate.test.js +31 -0
  198. package/dist/__tests__/policy/path-gate.test.js.map +1 -0
  199. package/dist/__tests__/policy/pr-reviewer-wiring.test.d.ts +2 -0
  200. package/dist/__tests__/policy/pr-reviewer-wiring.test.d.ts.map +1 -0
  201. package/dist/__tests__/policy/pr-reviewer-wiring.test.js +24 -0
  202. package/dist/__tests__/policy/pr-reviewer-wiring.test.js.map +1 -0
  203. package/dist/__tests__/policy/reviewer-gate.test.d.ts +2 -0
  204. package/dist/__tests__/policy/reviewer-gate.test.d.ts.map +1 -0
  205. package/dist/__tests__/policy/reviewer-gate.test.js +125 -0
  206. package/dist/__tests__/policy/reviewer-gate.test.js.map +1 -0
  207. package/dist/__tests__/policy-license.test.d.ts +2 -0
  208. package/dist/__tests__/policy-license.test.d.ts.map +1 -0
  209. package/dist/__tests__/policy-license.test.js +31 -0
  210. package/dist/__tests__/policy-license.test.js.map +1 -0
  211. package/dist/__tests__/policy-types.test.d.ts +2 -0
  212. package/dist/__tests__/policy-types.test.d.ts.map +1 -0
  213. package/dist/__tests__/policy-types.test.js +49 -0
  214. package/dist/__tests__/policy-types.test.js.map +1 -0
  215. package/dist/__tests__/ralph-gate.test.js +6 -4
  216. package/dist/__tests__/ralph-gate.test.js.map +1 -1
  217. package/dist/__tests__/rbac/bootstrap.test.d.ts +2 -0
  218. package/dist/__tests__/rbac/bootstrap.test.d.ts.map +1 -0
  219. package/dist/__tests__/rbac/bootstrap.test.js +62 -0
  220. package/dist/__tests__/rbac/bootstrap.test.js.map +1 -0
  221. package/dist/__tests__/rbac/matrix.test.d.ts +2 -0
  222. package/dist/__tests__/rbac/matrix.test.d.ts.map +1 -0
  223. package/dist/__tests__/rbac/matrix.test.js +62 -0
  224. package/dist/__tests__/rbac/matrix.test.js.map +1 -0
  225. package/dist/__tests__/rbac/user-role-store.test.d.ts +2 -0
  226. package/dist/__tests__/rbac/user-role-store.test.d.ts.map +1 -0
  227. package/dist/__tests__/rbac/user-role-store.test.js +78 -0
  228. package/dist/__tests__/rbac/user-role-store.test.js.map +1 -0
  229. package/dist/__tests__/rbac-defensive.test.d.ts +2 -0
  230. package/dist/__tests__/rbac-defensive.test.d.ts.map +1 -0
  231. package/dist/__tests__/rbac-defensive.test.js +29 -0
  232. package/dist/__tests__/rbac-defensive.test.js.map +1 -0
  233. package/dist/__tests__/rbac-integration.test.d.ts +2 -0
  234. package/dist/__tests__/rbac-integration.test.d.ts.map +1 -0
  235. package/dist/__tests__/rbac-integration.test.js +58 -0
  236. package/dist/__tests__/rbac-integration.test.js.map +1 -0
  237. package/dist/__tests__/rbac-license.test.d.ts +2 -0
  238. package/dist/__tests__/rbac-license.test.d.ts.map +1 -0
  239. package/dist/__tests__/rbac-license.test.js +27 -0
  240. package/dist/__tests__/rbac-license.test.js.map +1 -0
  241. package/dist/__tests__/reproduce-bec113-pagination-warning.test.js +14 -2
  242. package/dist/__tests__/reproduce-bec113-pagination-warning.test.js.map +1 -1
  243. package/dist/__tests__/reproduce-bec62.test.js +10 -3
  244. package/dist/__tests__/reproduce-bec62.test.js.map +1 -1
  245. package/dist/__tests__/reproduce-bec91-stuck-in-progress.test.js +24 -4
  246. package/dist/__tests__/reproduce-bec91-stuck-in-progress.test.js.map +1 -1
  247. package/dist/__tests__/server.test.js +46 -2
  248. package/dist/__tests__/server.test.js.map +1 -1
  249. package/dist/__tests__/sso-license.test.d.ts +2 -0
  250. package/dist/__tests__/sso-license.test.d.ts.map +1 -0
  251. package/dist/__tests__/sso-license.test.js +49 -0
  252. package/dist/__tests__/sso-license.test.js.map +1 -0
  253. package/dist/__tests__/start-todo.test.js +5 -0
  254. package/dist/__tests__/start-todo.test.js.map +1 -1
  255. package/dist/__tests__/webhook-handler.test.js +138 -0
  256. package/dist/__tests__/webhook-handler.test.js.map +1 -1
  257. package/dist/audit/config-fingerprint.d.ts +10 -0
  258. package/dist/audit/config-fingerprint.d.ts.map +1 -0
  259. package/dist/audit/config-fingerprint.js +20 -0
  260. package/dist/audit/config-fingerprint.js.map +1 -0
  261. package/dist/audit/csv.d.ts +8 -0
  262. package/dist/audit/csv.d.ts.map +1 -0
  263. package/dist/audit/csv.js +56 -0
  264. package/dist/audit/csv.js.map +1 -0
  265. package/dist/audit/events.d.ts +107 -0
  266. package/dist/audit/events.d.ts.map +1 -0
  267. package/dist/audit/events.js +221 -0
  268. package/dist/audit/events.js.map +1 -0
  269. package/dist/audit/index.d.ts +7 -0
  270. package/dist/audit/index.d.ts.map +1 -0
  271. package/dist/audit/index.js +7 -0
  272. package/dist/audit/index.js.map +1 -0
  273. package/dist/audit/projection.d.ts +38 -0
  274. package/dist/audit/projection.d.ts.map +1 -0
  275. package/dist/audit/projection.js +109 -0
  276. package/dist/audit/projection.js.map +1 -0
  277. package/dist/audit/reader.d.ts +42 -0
  278. package/dist/audit/reader.d.ts.map +1 -0
  279. package/dist/audit/reader.js +243 -0
  280. package/dist/audit/reader.js.map +1 -0
  281. package/dist/audit/retention.d.ts +12 -0
  282. package/dist/audit/retention.d.ts.map +1 -0
  283. package/dist/audit/retention.js +23 -0
  284. package/dist/audit/retention.js.map +1 -0
  285. package/dist/audit/writer.d.ts +26 -0
  286. package/dist/audit/writer.d.ts.map +1 -0
  287. package/dist/audit/writer.js +54 -0
  288. package/dist/audit/writer.js.map +1 -0
  289. package/dist/auth/index.d.ts +5 -0
  290. package/dist/auth/index.d.ts.map +1 -0
  291. package/dist/auth/index.js +5 -0
  292. package/dist/auth/index.js.map +1 -0
  293. package/dist/auth/session-store.d.ts +17 -0
  294. package/dist/auth/session-store.d.ts.map +1 -0
  295. package/dist/auth/session-store.js +59 -0
  296. package/dist/auth/session-store.js.map +1 -0
  297. package/dist/auth/sso-config.d.ts +14 -0
  298. package/dist/auth/sso-config.d.ts.map +1 -0
  299. package/dist/auth/sso-config.js +50 -0
  300. package/dist/auth/sso-config.js.map +1 -0
  301. package/dist/auth/user-store.d.ts +33 -0
  302. package/dist/auth/user-store.d.ts.map +1 -0
  303. package/dist/auth/user-store.js +71 -0
  304. package/dist/auth/user-store.js.map +1 -0
  305. package/dist/auth/workos-client.d.ts +46 -0
  306. package/dist/auth/workos-client.d.ts.map +1 -0
  307. package/dist/auth/workos-client.js +66 -0
  308. package/dist/auth/workos-client.js.map +1 -0
  309. package/dist/cost/aggregate.d.ts +49 -0
  310. package/dist/cost/aggregate.d.ts.map +1 -0
  311. package/dist/cost/aggregate.js +364 -0
  312. package/dist/cost/aggregate.js.map +1 -0
  313. package/dist/cost/csv.d.ts +12 -0
  314. package/dist/cost/csv.d.ts.map +1 -0
  315. package/dist/cost/csv.js +79 -0
  316. package/dist/cost/csv.js.map +1 -0
  317. package/dist/cost/index.d.ts +7 -0
  318. package/dist/cost/index.d.ts.map +1 -0
  319. package/dist/cost/index.js +7 -0
  320. package/dist/cost/index.js.map +1 -0
  321. package/dist/cost/per-run.d.ts +31 -0
  322. package/dist/cost/per-run.d.ts.map +1 -0
  323. package/dist/cost/per-run.js +35 -0
  324. package/dist/cost/per-run.js.map +1 -0
  325. package/dist/cost/rates.d.ts +27 -0
  326. package/dist/cost/rates.d.ts.map +1 -0
  327. package/dist/cost/rates.js +26 -0
  328. package/dist/cost/rates.js.map +1 -0
  329. package/dist/cost/rollup.d.ts +17 -0
  330. package/dist/cost/rollup.d.ts.map +1 -0
  331. package/dist/cost/rollup.js +164 -0
  332. package/dist/cost/rollup.js.map +1 -0
  333. package/dist/cost/types.d.ts +54 -0
  334. package/dist/cost/types.d.ts.map +1 -0
  335. package/dist/cost/types.js +2 -0
  336. package/dist/cost/types.js.map +1 -0
  337. package/dist/db/client.d.ts.map +1 -1
  338. package/dist/db/client.js +79 -1
  339. package/dist/db/client.js.map +1 -1
  340. package/dist/db/migrations/postgres/006_spend_caps.sql +14 -0
  341. package/dist/db/migrations/postgres/007_audit_events.sql +19 -0
  342. package/dist/db/migrations/postgres/008_cost_rollups.sql +19 -0
  343. package/dist/db/migrations/postgres/008_sso.sql +20 -0
  344. package/dist/db/migrations/sqlite/005_spend_caps.sql +16 -0
  345. package/dist/db/migrations/sqlite/006_audit_events.sql +19 -0
  346. package/dist/db/migrations/sqlite/007_cost_rollups.sql +19 -0
  347. package/dist/db/migrations/sqlite/007_sso.sql +20 -0
  348. package/dist/db/schema.d.ts +802 -0
  349. package/dist/db/schema.d.ts.map +1 -1
  350. package/dist/db/schema.js +80 -1
  351. package/dist/db/schema.js.map +1 -1
  352. package/dist/index.d.ts +7 -1
  353. package/dist/index.d.ts.map +1 -1
  354. package/dist/index.js +8 -1
  355. package/dist/index.js.map +1 -1
  356. package/dist/license-public-key.d.ts +15 -0
  357. package/dist/license-public-key.d.ts.map +1 -0
  358. package/dist/license-public-key.js +15 -0
  359. package/dist/license-public-key.js.map +1 -0
  360. package/dist/license.d.ts +30 -5
  361. package/dist/license.d.ts.map +1 -1
  362. package/dist/license.js +142 -12
  363. package/dist/license.js.map +1 -1
  364. package/dist/pipeline/runner.d.ts +1 -7
  365. package/dist/pipeline/runner.d.ts.map +1 -1
  366. package/dist/pipeline/runner.js +168 -21
  367. package/dist/pipeline/runner.js.map +1 -1
  368. package/dist/pm/actions/promote.d.ts +3 -0
  369. package/dist/pm/actions/promote.d.ts.map +1 -1
  370. package/dist/pm/actions/promote.js +12 -0
  371. package/dist/pm/actions/promote.js.map +1 -1
  372. package/dist/pm/actions/resolve-approvals.d.ts.map +1 -1
  373. package/dist/pm/actions/resolve-approvals.js +16 -0
  374. package/dist/pm/actions/resolve-approvals.js.map +1 -1
  375. package/dist/pm/actions/start-todo.d.ts +3 -0
  376. package/dist/pm/actions/start-todo.d.ts.map +1 -1
  377. package/dist/pm/actions/start-todo.js +5 -1
  378. package/dist/pm/actions/start-todo.js.map +1 -1
  379. package/dist/pm/actions/triage.d.ts +3 -0
  380. package/dist/pm/actions/triage.d.ts.map +1 -1
  381. package/dist/pm/actions/triage.js +8 -0
  382. package/dist/pm/actions/triage.js.map +1 -1
  383. package/dist/pm/budget-alerts.d.ts +18 -0
  384. package/dist/pm/budget-alerts.d.ts.map +1 -0
  385. package/dist/pm/budget-alerts.js +100 -0
  386. package/dist/pm/budget-alerts.js.map +1 -0
  387. package/dist/pm/budget.d.ts +28 -5
  388. package/dist/pm/budget.d.ts.map +1 -1
  389. package/dist/pm/budget.js +115 -39
  390. package/dist/pm/budget.js.map +1 -1
  391. package/dist/pm/scheduler.d.ts +8 -4
  392. package/dist/pm/scheduler.d.ts.map +1 -1
  393. package/dist/pm/scheduler.js +128 -5
  394. package/dist/pm/scheduler.js.map +1 -1
  395. package/dist/pm/slack.d.ts.map +1 -1
  396. package/dist/pm/slack.js +11 -0
  397. package/dist/pm/slack.js.map +1 -1
  398. package/dist/pm/types.d.ts +36 -0
  399. package/dist/pm/types.d.ts.map +1 -1
  400. package/dist/pm/types.js +12 -0
  401. package/dist/pm/types.js.map +1 -1
  402. package/dist/policy/cost-gate.d.ts +3 -0
  403. package/dist/policy/cost-gate.d.ts.map +1 -0
  404. package/dist/policy/cost-gate.js +11 -0
  405. package/dist/policy/cost-gate.js.map +1 -0
  406. package/dist/policy/evaluate.d.ts +32 -0
  407. package/dist/policy/evaluate.d.ts.map +1 -0
  408. package/dist/policy/evaluate.js +61 -0
  409. package/dist/policy/evaluate.js.map +1 -0
  410. package/dist/policy/index.d.ts +7 -0
  411. package/dist/policy/index.d.ts.map +1 -0
  412. package/dist/policy/index.js +7 -0
  413. package/dist/policy/index.js.map +1 -0
  414. package/dist/policy/override.d.ts +23 -0
  415. package/dist/policy/override.d.ts.map +1 -0
  416. package/dist/policy/override.js +26 -0
  417. package/dist/policy/override.js.map +1 -0
  418. package/dist/policy/path-gate.d.ts +3 -0
  419. package/dist/policy/path-gate.d.ts.map +1 -0
  420. package/dist/policy/path-gate.js +20 -0
  421. package/dist/policy/path-gate.js.map +1 -0
  422. package/dist/policy/reviewer-gate.d.ts +45 -0
  423. package/dist/policy/reviewer-gate.d.ts.map +1 -0
  424. package/dist/policy/reviewer-gate.js +77 -0
  425. package/dist/policy/reviewer-gate.js.map +1 -0
  426. package/dist/policy/types.d.ts +7 -0
  427. package/dist/policy/types.d.ts.map +1 -0
  428. package/dist/policy/types.js +2 -0
  429. package/dist/policy/types.js.map +1 -0
  430. package/dist/rbac/errors.d.ts +7 -0
  431. package/dist/rbac/errors.d.ts.map +1 -0
  432. package/dist/rbac/errors.js +13 -0
  433. package/dist/rbac/errors.js.map +1 -0
  434. package/dist/rbac/index.d.ts +5 -0
  435. package/dist/rbac/index.d.ts.map +1 -0
  436. package/dist/rbac/index.js +5 -0
  437. package/dist/rbac/index.js.map +1 -0
  438. package/dist/rbac/matrix.d.ts +35 -0
  439. package/dist/rbac/matrix.d.ts.map +1 -0
  440. package/dist/rbac/matrix.js +42 -0
  441. package/dist/rbac/matrix.js.map +1 -0
  442. package/dist/rbac/types.d.ts +2 -0
  443. package/dist/rbac/types.d.ts.map +1 -0
  444. package/dist/rbac/types.js +2 -0
  445. package/dist/rbac/types.js.map +1 -0
  446. package/dist/rbac/user-role-store.d.ts +27 -0
  447. package/dist/rbac/user-role-store.d.ts.map +1 -0
  448. package/dist/rbac/user-role-store.js +148 -0
  449. package/dist/rbac/user-role-store.js.map +1 -0
  450. package/dist/repo/git.d.ts +9 -0
  451. package/dist/repo/git.d.ts.map +1 -1
  452. package/dist/repo/git.js +11 -0
  453. package/dist/repo/git.js.map +1 -1
  454. package/dist/repo/github.d.ts +4 -0
  455. package/dist/repo/github.d.ts.map +1 -1
  456. package/dist/repo/github.js +27 -0
  457. package/dist/repo/github.js.map +1 -1
  458. package/dist/repo/gitlab.d.ts +4 -0
  459. package/dist/repo/gitlab.d.ts.map +1 -1
  460. package/dist/repo/gitlab.js +7 -0
  461. package/dist/repo/gitlab.js.map +1 -1
  462. package/dist/server.d.ts +6 -0
  463. package/dist/server.d.ts.map +1 -1
  464. package/dist/server.js +16 -10
  465. package/dist/server.js.map +1 -1
  466. package/dist/types.d.ts +155 -0
  467. package/dist/types.d.ts.map +1 -1
  468. package/dist/types.js +83 -0
  469. package/dist/types.js.map +1 -1
  470. package/dist/util/glob.d.ts +7 -0
  471. package/dist/util/glob.d.ts.map +1 -0
  472. package/dist/util/glob.js +20 -0
  473. package/dist/util/glob.js.map +1 -0
  474. package/dist/webhook/handler.d.ts +3 -0
  475. package/dist/webhook/handler.d.ts.map +1 -1
  476. package/dist/webhook/handler.js +30 -1
  477. package/dist/webhook/handler.js.map +1 -1
  478. package/package.json +2 -1
@@ -0,0 +1,35 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { createDb } from "../db/client.js";
3
+ import { auditEvents } from "../db/schema.js";
4
+ import { sql } from "drizzle-orm";
5
+ describe("audit_events schema", () => {
6
+ it("creates the table with required columns on fresh SQLite db", async () => {
7
+ const db = await createDb({ connectionString: ":memory:" });
8
+ const cols = db.all(sql `PRAGMA table_info(audit_events)`);
9
+ const names = cols.map(c => c.name).sort();
10
+ expect(names).toEqual([
11
+ "actor", "actor_type", "event_type", "id", "input_tokens",
12
+ "issue_id", "output_tokens", "payload", "run_id", "scope", "timestamp",
13
+ ]);
14
+ });
15
+ it("inserts and reads back an audit event", async () => {
16
+ const db = await createDb({ connectionString: ":memory:" });
17
+ await db.insert(auditEvents).values({
18
+ id: "evt_1",
19
+ eventType: "pm.issue_promoted",
20
+ actor: "pm-agent",
21
+ actorType: "pm-agent",
22
+ scope: "team:T1",
23
+ runId: null,
24
+ issueId: "BEC-1",
25
+ inputTokens: 0,
26
+ outputTokens: 0,
27
+ payload: JSON.stringify({ test: true }),
28
+ });
29
+ const rows = await db.select().from(auditEvents);
30
+ expect(rows).toHaveLength(1);
31
+ expect(rows[0].eventType).toBe("pm.issue_promoted");
32
+ expect(rows[0].timestamp).toBeInstanceOf(Date);
33
+ });
34
+ });
35
+ //# sourceMappingURL=db-audit-schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-audit-schema.test.js","sourceRoot":"","sources":["../../src/__tests__/db-audit-schema.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AAElC,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,4DAA4D,EAAE,KAAK,IAAI,EAAE;QAC1E,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAM,IAAI,GAAI,EAAU,CAAC,GAAG,CAAC,GAAG,CAAA,iCAAiC,CAA0B,CAAC;QAC5F,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;QAC3C,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;YACpB,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,IAAI,EAAE,cAAc;YACzD,UAAU,EAAE,eAAe,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW;SACvE,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAO,EAAU,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC;YAC3C,EAAE,EAAE,OAAO;YACX,SAAS,EAAE,mBAAmB;YAC9B,KAAK,EAAE,UAAU;YACjB,SAAS,EAAE,UAAU;YACrB,KAAK,EAAE,SAAS;YAChB,KAAK,EAAE,IAAI;YACX,OAAO,EAAE,OAAO;YAChB,WAAW,EAAE,CAAC;YACd,YAAY,EAAE,CAAC;YACf,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;SACxC,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1D,MAAM,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACpD,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=db-cost-rollups-schema.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-cost-rollups-schema.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/db-cost-rollups-schema.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,28 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { createDb } from "../db/client.js";
3
+ import { costRollupsDaily } from "../db/schema.js";
4
+ import { sql } from "drizzle-orm";
5
+ describe("cost_rollups_daily schema", () => {
6
+ it("creates table with the expected columns", async () => {
7
+ const db = await createDb({ connectionString: ":memory:" });
8
+ const cols = db.all(sql `PRAGMA table_info(cost_rollups_daily)`);
9
+ expect(cols.map(c => c.name).sort()).toEqual([
10
+ "computed_at", "date", "dollars", "id", "input_tokens", "linear_team_id",
11
+ "output_tokens", "pipeline_key", "prs_merged", "repo_url", "runs", "time_saved_hours",
12
+ ]);
13
+ });
14
+ it("inserts and reads back a row", async () => {
15
+ const db = await createDb({ connectionString: ":memory:" });
16
+ await db.insert(costRollupsDaily).values({
17
+ id: "r_1", date: "2026-04-01", pipelineKey: "auto-implement",
18
+ linearTeamId: "T1", repoUrl: "https://github.com/x/y",
19
+ runs: 5, prsMerged: 4, inputTokens: 1000, outputTokens: 500,
20
+ dollars: 12.34, timeSavedHours: 16,
21
+ });
22
+ const rows = await db.select().from(costRollupsDaily);
23
+ expect(rows).toHaveLength(1);
24
+ expect(rows[0].dollars).toBeCloseTo(12.34, 2);
25
+ expect(rows[0].timeSavedHours).toBe(16);
26
+ });
27
+ });
28
+ //# sourceMappingURL=db-cost-rollups-schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-cost-rollups-schema.test.js","sourceRoot":"","sources":["../../src/__tests__/db-cost-rollups-schema.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AAElC,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAM,IAAI,GAAI,EAAU,CAAC,GAAG,CAAC,GAAG,CAAA,uCAAuC,CAA0B,CAAC;QAClG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC;YAC3C,aAAa,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,cAAc,EAAE,gBAAgB;YACxE,eAAe,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,kBAAkB;SACtF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;QAC5C,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAO,EAAU,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC;YAChD,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,WAAW,EAAE,gBAAgB;YAC5D,YAAY,EAAE,IAAI,EAAE,OAAO,EAAE,wBAAwB;YACrD,IAAI,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG;YAC3D,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE;SACnC,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC/D,MAAM,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=db-rbac-schema.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-rbac-schema.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/db-rbac-schema.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,32 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { createDb } from "../db/client.js";
3
+ import { dashboardUsers } from "../db/schema.js";
4
+ import { sql } from "drizzle-orm";
5
+ describe("dashboard_users.role column", () => {
6
+ it("includes role in the table schema with default 'viewer'", async () => {
7
+ const db = await createDb({ connectionString: ":memory:" });
8
+ const cols = db.all(sql `PRAGMA table_info(dashboard_users)`);
9
+ expect(cols.map(c => c.name).sort()).toContain("role");
10
+ });
11
+ it("defaults new rows to 'viewer'", async () => {
12
+ const db = await createDb({ connectionString: ":memory:" });
13
+ await db.insert(dashboardUsers).values({
14
+ id: "u_1", email: "a@b.com", name: "A B", workosUserId: "wu_1",
15
+ });
16
+ const rows = await db.select().from(dashboardUsers);
17
+ expect(rows[0].role).toBe("viewer");
18
+ });
19
+ it("accepts explicit role values", async () => {
20
+ const db = await createDb({ connectionString: ":memory:" });
21
+ await db.insert(dashboardUsers).values({
22
+ id: "u_admin", email: "admin@b.com", name: null, workosUserId: null, role: "admin",
23
+ });
24
+ await db.insert(dashboardUsers).values({
25
+ id: "u_op", email: "op@b.com", name: null, workosUserId: null, role: "operator",
26
+ });
27
+ const rows = await db.select().from(dashboardUsers);
28
+ const roles = rows.map((r) => r.role).sort();
29
+ expect(roles).toEqual(["admin", "operator"]);
30
+ });
31
+ });
32
+ //# sourceMappingURL=db-rbac-schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-rbac-schema.test.js","sourceRoot":"","sources":["../../src/__tests__/db-rbac-schema.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AAElC,QAAQ,CAAC,6BAA6B,EAAE,GAAG,EAAE;IAC3C,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACvE,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAM,IAAI,GAAI,EAAU,CAAC,GAAG,CAAC,GAAG,CAAA,oCAAoC,CAA0B,CAAC;QAC/F,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE,KAAK,IAAI,EAAE;QAC7C,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAO,EAAU,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC;YAC9C,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM;SAC/D,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC7D,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;QAC5C,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAO,EAAU,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC;YAC9C,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO;SACnF,CAAC,CAAC;QACH,MAAO,EAAU,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC;YAC9C,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU;SAChF,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;QAClD,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=db-sso-schema.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-sso-schema.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/db-sso-schema.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,48 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { createDb } from "../db/client.js";
3
+ import { dashboardUsers, dashboardSessions } from "../db/schema.js";
4
+ import { sql } from "drizzle-orm";
5
+ describe("sso schema", () => {
6
+ it("creates dashboard_users and dashboard_sessions tables on fresh SQLite db", async () => {
7
+ const db = await createDb({ connectionString: ":memory:" });
8
+ const userCols = db.all(sql `PRAGMA table_info(dashboard_users)`);
9
+ expect(userCols.map((c) => c.name).sort()).toEqual([
10
+ "created_at",
11
+ "email",
12
+ "id",
13
+ "last_login_at",
14
+ "name",
15
+ "role",
16
+ "workos_user_id",
17
+ ]);
18
+ const sessionCols = db.all(sql `PRAGMA table_info(dashboard_sessions)`);
19
+ expect(sessionCols.map((c) => c.name).sort()).toEqual([
20
+ "created_at",
21
+ "expires_at",
22
+ "id",
23
+ "last_seen_at",
24
+ "user_id",
25
+ ]);
26
+ });
27
+ it("inserts and reads back a user + session", async () => {
28
+ const db = await createDb({ connectionString: ":memory:" });
29
+ await db.insert(dashboardUsers).values({
30
+ id: "u_1",
31
+ email: "a@b.com",
32
+ name: "A B",
33
+ workosUserId: "wu_1",
34
+ });
35
+ await db.insert(dashboardSessions).values({
36
+ id: "s_1",
37
+ userId: "u_1",
38
+ expiresAt: new Date(Date.now() + 3600_000),
39
+ });
40
+ const users = await db.select().from(dashboardUsers);
41
+ expect(users).toHaveLength(1);
42
+ expect(users[0].email).toBe("a@b.com");
43
+ const sessions = await db.select().from(dashboardSessions);
44
+ expect(sessions).toHaveLength(1);
45
+ expect(sessions[0].userId).toBe("u_1");
46
+ });
47
+ });
48
+ //# sourceMappingURL=db-sso-schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-sso-schema.test.js","sourceRoot":"","sources":["../../src/__tests__/db-sso-schema.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpE,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AAElC,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,EAAE,CAAC,0EAA0E,EAAE,KAAK,IAAI,EAAE;QACxF,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAM,QAAQ,GAAI,EAAU,CAAC,GAAG,CAC9B,GAAG,CAAA,oCAAoC,CACb,CAAC;QAC7B,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC;YACjD,YAAY;YACZ,OAAO;YACP,IAAI;YACJ,eAAe;YACf,MAAM;YACN,MAAM;YACN,gBAAgB;SACjB,CAAC,CAAC;QACH,MAAM,WAAW,GAAI,EAAU,CAAC,GAAG,CACjC,GAAG,CAAA,uCAAuC,CAChB,CAAC;QAC7B,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC;YACpD,YAAY;YACZ,YAAY;YACZ,IAAI;YACJ,cAAc;YACd,SAAS;SACV,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAO,EAAU,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC;YAC9C,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,KAAK;YACX,YAAY,EAAE,MAAM;SACrB,CAAC,CAAC;QACH,MAAO,EAAU,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC;YACjD,EAAE,EAAE,KAAK;YACT,MAAM,EAAE,KAAK;YACb,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC;SAC3C,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC9D,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvC,MAAM,QAAQ,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACpE,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare function installTestProLicense(tier?: "pro" | "enterprise"): Promise<void>;
2
+ export declare function restoreLicense(): Promise<void>;
3
+ //# sourceMappingURL=license.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license.d.ts","sourceRoot":"","sources":["../../../src/__tests__/helpers/license.ts"],"names":[],"mappings":"AA8BA,wBAAsB,qBAAqB,CACzC,IAAI,GAAE,KAAK,GAAG,YAAoB,GACjC,OAAO,CAAC,IAAI,CAAC,CAgCf;AAED,wBAAsB,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC,CAiBpD"}
@@ -0,0 +1,74 @@
1
+ /**
2
+ * Test helper: install a valid signed pro-tier license JWT for tests that
3
+ * exercise license-gated features. Generates a fresh ed25519 keypair, patches
4
+ * the embedded public key, and signs a pro-tier JWT into URATEAM_LICENSE_KEY.
5
+ *
6
+ * Use in `beforeEach`:
7
+ *
8
+ * import { installTestProLicense, restoreLicense } from "./helpers/license.js";
9
+ * beforeEach(async () => { await installTestProLicense(); });
10
+ * afterEach(async () => { await restoreLicense(); });
11
+ */
12
+ import { generateKeyPairSync, sign } from "node:crypto";
13
+ import { _resetLicenseCache } from "../../license.js";
14
+ function b64url(buf) {
15
+ return buf.toString("base64").replace(/\+/g, "-").replace(/\//g, "_").replace(/=+$/, "");
16
+ }
17
+ function makeJwt(privateKey, payload) {
18
+ const header = { alg: "EdDSA", typ: "JWT" };
19
+ const headerB64 = b64url(Buffer.from(JSON.stringify(header)));
20
+ const payloadB64 = b64url(Buffer.from(JSON.stringify(payload)));
21
+ const signingInput = `${headerB64}.${payloadB64}`;
22
+ const sig = sign(null, Buffer.from(signingInput), privateKey);
23
+ return `${signingInput}.${b64url(sig)}`;
24
+ }
25
+ let originalPublicKey;
26
+ let originalEnv;
27
+ export async function installTestProLicense(tier = "pro") {
28
+ const { publicKey, privateKey } = generateKeyPairSync("ed25519");
29
+ const publicKeyB64 = Buffer.from(publicKey.export({ format: "der", type: "spki" })).toString("base64");
30
+ const mod = await import("../../license-public-key.js");
31
+ if (originalPublicKey === undefined) {
32
+ originalPublicKey = mod
33
+ .LICENSE_PUBLIC_KEY_DER_B64;
34
+ }
35
+ Object.defineProperty(mod, "LICENSE_PUBLIC_KEY_DER_B64", {
36
+ value: publicKeyB64,
37
+ writable: true,
38
+ configurable: true,
39
+ });
40
+ const now = Math.floor(Date.now() / 1000);
41
+ const jwt = makeJwt(privateKey, {
42
+ iss: "urateams.com",
43
+ sub: "cust_test",
44
+ tier,
45
+ seats: 25,
46
+ iat: now,
47
+ exp: now + 86_400,
48
+ });
49
+ if (originalEnv === undefined) {
50
+ originalEnv = process.env.URATEAM_LICENSE_KEY;
51
+ }
52
+ process.env.URATEAM_LICENSE_KEY = jwt;
53
+ _resetLicenseCache();
54
+ }
55
+ export async function restoreLicense() {
56
+ if (originalPublicKey !== undefined) {
57
+ const mod = await import("../../license-public-key.js");
58
+ Object.defineProperty(mod, "LICENSE_PUBLIC_KEY_DER_B64", {
59
+ value: originalPublicKey,
60
+ writable: true,
61
+ configurable: true,
62
+ });
63
+ originalPublicKey = undefined;
64
+ }
65
+ if (originalEnv === undefined) {
66
+ delete process.env.URATEAM_LICENSE_KEY;
67
+ }
68
+ else {
69
+ process.env.URATEAM_LICENSE_KEY = originalEnv;
70
+ originalEnv = undefined;
71
+ }
72
+ _resetLicenseCache();
73
+ }
74
+ //# sourceMappingURL=license.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license.js","sourceRoot":"","sources":["../../../src/__tests__/helpers/license.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=license-audit-event.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license-audit-event.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/license-audit-event.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,60 @@
1
+ import { describe, it, expect, beforeEach, afterEach } from "vitest";
2
+ import { createDb } from "../db/client.js";
3
+ import { auditEvents } from "../db/schema.js";
4
+ import { checkLicense, _resetLicenseCache } from "../license.js";
5
+ describe("checkLicense — audit event on invalid license", () => {
6
+ beforeEach(() => {
7
+ _resetLicenseCache();
8
+ delete process.env.URATEAM_LICENSE_KEY;
9
+ });
10
+ afterEach(() => {
11
+ _resetLicenseCache();
12
+ delete process.env.URATEAM_LICENSE_KEY;
13
+ });
14
+ it("emits license.validation_failed when license key is bad-signature", async () => {
15
+ const db = await createDb({ connectionString: ":memory:" });
16
+ // A syntactically-valid JWT shape (three parts, EdDSA header) but bogus
17
+ // signature — verifyJwt returns { ok: false, reason: "bad-signature" }.
18
+ const header = Buffer.from(JSON.stringify({ alg: "EdDSA", typ: "JWT" }))
19
+ .toString("base64")
20
+ .replace(/\+/g, "-")
21
+ .replace(/\//g, "_")
22
+ .replace(/=+$/, "");
23
+ const payload = Buffer.from(JSON.stringify({
24
+ iss: "urateams.com",
25
+ sub: "cust",
26
+ tier: "pro",
27
+ iat: 1,
28
+ exp: Math.floor(Date.now() / 1000) + 3600,
29
+ }))
30
+ .toString("base64")
31
+ .replace(/\+/g, "-")
32
+ .replace(/\//g, "_")
33
+ .replace(/=+$/, "");
34
+ const sig = "AAAA";
35
+ process.env.URATEAM_LICENSE_KEY = `${header}.${payload}.${sig}`;
36
+ const status = checkLicense(db);
37
+ expect(status.licensed).toBe(false);
38
+ expect(status.tier).toBe("oss");
39
+ expect(status.invalidReason).toBe("bad-signature");
40
+ // void logAuditEvent — flush microtask
41
+ await new Promise((r) => setImmediate(r));
42
+ const rows = await db.select().from(auditEvents);
43
+ const failures = rows.filter((r) => r.eventType === "license.validation_failed");
44
+ expect(failures).toHaveLength(1);
45
+ expect(failures[0].actor).toBe("system");
46
+ expect(failures[0].actorType).toBe("system");
47
+ const payloadJson = JSON.parse(failures[0].payload);
48
+ expect(payloadJson.invalidReason).toBe("bad-signature");
49
+ });
50
+ it("does not emit an audit event when no license key is set (OSS mode)", async () => {
51
+ const db = await createDb({ connectionString: ":memory:" });
52
+ const status = checkLicense(db);
53
+ expect(status.tier).toBe("oss");
54
+ expect(status.invalidReason).toBeUndefined();
55
+ await new Promise((r) => setImmediate(r));
56
+ const rows = await db.select().from(auditEvents);
57
+ expect(rows).toHaveLength(0);
58
+ });
59
+ });
60
+ //# sourceMappingURL=license-audit-event.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license-audit-event.test.js","sourceRoot":"","sources":["../../src/__tests__/license-audit-event.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACrE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAEjE,QAAQ,CAAC,+CAA+C,EAAE,GAAG,EAAE;IAC7D,UAAU,CAAC,GAAG,EAAE;QACd,kBAAkB,EAAE,CAAC;QACrB,OAAO,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,kBAAkB,EAAE,CAAC;QACrB,OAAO,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mEAAmE,EAAE,KAAK,IAAI,EAAE;QACjF,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAE5D,wEAAwE;QACxE,wEAAwE;QACxE,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;aACrE,QAAQ,CAAC,QAAQ,CAAC;aAClB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;aACnB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;aACnB,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACtB,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CACzB,IAAI,CAAC,SAAS,CAAC;YACb,GAAG,EAAE,cAAc;YACnB,GAAG,EAAE,MAAM;YACX,IAAI,EAAE,KAAK;YACX,GAAG,EAAE,CAAC;YACN,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI;SAC1C,CAAC,CACH;aACE,QAAQ,CAAC,QAAQ,CAAC;aAClB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;aACnB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;aACnB,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACtB,MAAM,GAAG,GAAG,MAAM,CAAC;QACnB,OAAO,CAAC,GAAG,CAAC,mBAAmB,GAAG,GAAG,MAAM,IAAI,OAAO,IAAI,GAAG,EAAE,CAAC;QAEhE,MAAM,MAAM,GAAG,YAAY,CAAC,EAAS,CAAC,CAAC;QACvC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAEnD,uCAAuC;QACvC,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;QAE1C,MAAM,IAAI,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1D,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAC1B,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,2BAA2B,CACxD,CAAC;QACF,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QACpD,MAAM,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,KAAK,IAAI,EAAE;QAClF,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5D,MAAM,MAAM,GAAG,YAAY,CAAC,EAAS,CAAC,CAAC;QACvC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,aAAa,EAAE,CAAC;QAE7C,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,IAAI,GAAG,MAAO,EAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1D,MAAM,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=license-end-to-end.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license-end-to-end.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/license-end-to-end.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,75 @@
1
+ import { describe, it, expect, beforeAll, beforeEach, afterEach } from "vitest";
2
+ import { generateKeyPairSync } from "node:crypto";
3
+ import { existsSync } from "node:fs";
4
+ import { execFileSync } from "node:child_process";
5
+ import { resolve } from "node:path";
6
+ import { checkLicense, _resetLicenseCache } from "../license.js";
7
+ describe("license end-to-end (CLI issue → core validate)", () => {
8
+ let originalSigningKey;
9
+ let originalLicenseKey;
10
+ let originalPublicKey;
11
+ let issueLicense;
12
+ // The CLI package's compiled output must exist before this test can import
13
+ // issueLicense() from it. turbo's task graph does not express this dependency
14
+ // (core:test does not depend on cli:build — see PR #34 cross-task review),
15
+ // so a `pnpm clean && pnpm test` run could otherwise execute this test before
16
+ // cli is built and fail with ERR_MODULE_NOT_FOUND. We make the test
17
+ // self-sufficient by building cli on-demand if its dist/ is missing.
18
+ beforeAll(async () => {
19
+ const cliDist = resolve(__dirname, "..", "..", "..", "cli", "dist", "commands", "license.js");
20
+ if (!existsSync(cliDist)) {
21
+ execFileSync("pnpm", ["--filter", "@urateam/cli", "build"], {
22
+ stdio: "inherit",
23
+ cwd: resolve(__dirname, "..", "..", "..", ".."),
24
+ });
25
+ }
26
+ // @ts-ignore — relative path into a sibling package's dist/
27
+ const mod = await import("../../../cli/dist/commands/license.js");
28
+ issueLicense = mod.issueLicense;
29
+ }, 60_000);
30
+ beforeEach(async () => {
31
+ _resetLicenseCache();
32
+ originalSigningKey = process.env.URATEAM_LICENSE_SIGNING_KEY_DER_B64;
33
+ originalLicenseKey = process.env.URATEAM_LICENSE_KEY;
34
+ const { publicKey, privateKey } = generateKeyPairSync("ed25519");
35
+ process.env.URATEAM_LICENSE_SIGNING_KEY_DER_B64 = Buffer.from(privateKey.export({ format: "der", type: "pkcs8" })).toString("base64");
36
+ const mod = await import("../license-public-key.js");
37
+ originalPublicKey = mod.LICENSE_PUBLIC_KEY_DER_B64;
38
+ Object.defineProperty(mod, "LICENSE_PUBLIC_KEY_DER_B64", {
39
+ value: Buffer.from(publicKey.export({ format: "der", type: "spki" })).toString("base64"),
40
+ writable: true,
41
+ configurable: true,
42
+ });
43
+ });
44
+ afterEach(async () => {
45
+ process.env.URATEAM_LICENSE_SIGNING_KEY_DER_B64 = originalSigningKey;
46
+ if (originalLicenseKey === undefined)
47
+ delete process.env.URATEAM_LICENSE_KEY;
48
+ else
49
+ process.env.URATEAM_LICENSE_KEY = originalLicenseKey;
50
+ if (originalPublicKey !== undefined) {
51
+ const mod = await import("../license-public-key.js");
52
+ Object.defineProperty(mod, "LICENSE_PUBLIC_KEY_DER_B64", {
53
+ value: originalPublicKey,
54
+ writable: true,
55
+ configurable: true,
56
+ });
57
+ }
58
+ });
59
+ it("CLI-issued enterprise JWT validates and unlocks enterprise features", () => {
60
+ const token = issueLicense({
61
+ customerId: "cust_e2e",
62
+ tier: "enterprise",
63
+ seats: null,
64
+ expiresAt: new Date(Date.now() + 30 * 86_400_000),
65
+ });
66
+ process.env.URATEAM_LICENSE_KEY = token;
67
+ const status = checkLicense();
68
+ expect(status.licensed).toBe(true);
69
+ expect(status.tier).toBe("enterprise");
70
+ expect(status.customerId).toBe("cust_e2e");
71
+ expect(status.features.has("sso")).toBe(true);
72
+ expect(status.features.has("audit-log")).toBe(true);
73
+ });
74
+ });
75
+ //# sourceMappingURL=license-end-to-end.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license-end-to-end.test.js","sourceRoot":"","sources":["../../src/__tests__/license-end-to-end.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=license-public-key.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license-public-key.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/license-public-key.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,18 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { createPublicKey } from "node:crypto";
3
+ import { LICENSE_PUBLIC_KEY_DER_B64 } from "../license-public-key.js";
4
+ describe("embedded production public key", () => {
5
+ it("is a structurally valid Ed25519 SPKI-DER base64 string", () => {
6
+ const buf = Buffer.from(LICENSE_PUBLIC_KEY_DER_B64, "base64");
7
+ // Ed25519 SPKI: 12-byte ASN.1 prefix + 32-byte raw public key = 44 bytes.
8
+ // A character transposition or truncation in the constant would typically
9
+ // still be "parseable" as some key; the length + OID check catches
10
+ // specifically-bad tweaks the createPublicKey round-trip alone misses.
11
+ expect(buf.byteLength).toBe(44);
12
+ // OID for Ed25519 is 1.3.101.112, encoded as hex `2b6570` at bytes 6-8.
13
+ expect(buf.subarray(6, 9).toString("hex")).toBe("2b6570");
14
+ const key = createPublicKey({ key: buf, format: "der", type: "spki" });
15
+ expect(key.asymmetricKeyType).toBe("ed25519");
16
+ });
17
+ });
18
+ //# sourceMappingURL=license-public-key.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"license-public-key.test.js","sourceRoot":"","sources":["../../src/__tests__/license-public-key.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAEtE,QAAQ,CAAC,gCAAgC,EAAE,GAAG,EAAE;IAC9C,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;QAChE,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;QAC9D,0EAA0E;QAC1E,0EAA0E;QAC1E,mEAAmE;QACnE,uEAAuE;QACvE,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAChC,wEAAwE;QACxE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1D,MAAM,GAAG,GAAG,eAAe,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACvE,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}