openvsx-webui-test 0.17.2 → 0.18.0-dev.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (403) hide show
  1. package/lib/components/button-with-progress.d.ts +1 -0
  2. package/lib/components/button-with-progress.d.ts.map +1 -1
  3. package/lib/components/button-with-progress.js +1 -1
  4. package/lib/components/button-with-progress.js.map +1 -1
  5. package/lib/components/sanitized-markdown.d.ts.map +1 -1
  6. package/lib/components/sanitized-markdown.js +79 -1
  7. package/lib/components/sanitized-markdown.js.map +1 -1
  8. package/lib/components/scan-admin/common/auto-refresh.d.ts +21 -0
  9. package/lib/components/scan-admin/common/auto-refresh.d.ts.map +1 -0
  10. package/lib/components/scan-admin/common/auto-refresh.js +45 -0
  11. package/lib/components/scan-admin/common/auto-refresh.js.map +1 -0
  12. package/lib/components/scan-admin/common/conditional-tooltip.d.ts +24 -0
  13. package/lib/components/scan-admin/common/conditional-tooltip.d.ts.map +1 -0
  14. package/lib/components/scan-admin/common/conditional-tooltip.js +63 -0
  15. package/lib/components/scan-admin/common/conditional-tooltip.js.map +1 -0
  16. package/lib/components/scan-admin/common/file-table.d.ts +23 -0
  17. package/lib/components/scan-admin/common/file-table.d.ts.map +1 -0
  18. package/lib/components/scan-admin/common/file-table.js +350 -0
  19. package/lib/components/scan-admin/common/file-table.js.map +1 -0
  20. package/lib/components/scan-admin/common/index.d.ts +18 -0
  21. package/lib/components/scan-admin/common/index.d.ts.map +1 -0
  22. package/lib/components/scan-admin/common/index.js +18 -0
  23. package/lib/components/scan-admin/common/index.js.map +1 -0
  24. package/lib/components/scan-admin/common/tab-panel.d.ts +25 -0
  25. package/lib/components/scan-admin/common/tab-panel.d.ts.map +1 -0
  26. package/lib/components/scan-admin/common/tab-panel.js +22 -0
  27. package/lib/components/scan-admin/common/tab-panel.js.map +1 -0
  28. package/lib/components/scan-admin/common/utils.d.ts +15 -0
  29. package/lib/components/scan-admin/common/utils.d.ts.map +1 -0
  30. package/lib/components/scan-admin/common/utils.js +46 -0
  31. package/lib/components/scan-admin/common/utils.js.map +1 -0
  32. package/lib/components/scan-admin/dialogs/file-dialog.d.ts +19 -0
  33. package/lib/components/scan-admin/dialogs/file-dialog.d.ts.map +1 -0
  34. package/lib/components/scan-admin/dialogs/file-dialog.js +85 -0
  35. package/lib/components/scan-admin/dialogs/file-dialog.js.map +1 -0
  36. package/lib/components/scan-admin/dialogs/index.d.ts +15 -0
  37. package/lib/components/scan-admin/dialogs/index.d.ts.map +1 -0
  38. package/lib/components/scan-admin/dialogs/index.js +15 -0
  39. package/lib/components/scan-admin/dialogs/index.js.map +1 -0
  40. package/lib/components/scan-admin/dialogs/quarantine-dialog.d.ts +23 -0
  41. package/lib/components/scan-admin/dialogs/quarantine-dialog.d.ts.map +1 -0
  42. package/lib/components/scan-admin/dialogs/quarantine-dialog.js +192 -0
  43. package/lib/components/scan-admin/dialogs/quarantine-dialog.js.map +1 -0
  44. package/lib/components/scan-admin/index.d.ts +20 -0
  45. package/lib/components/scan-admin/index.d.ts.map +1 -0
  46. package/lib/components/scan-admin/index.js +25 -0
  47. package/lib/components/scan-admin/index.js.map +1 -0
  48. package/lib/components/scan-admin/scan-card/index.d.ts +20 -0
  49. package/lib/components/scan-admin/scan-card/index.d.ts.map +1 -0
  50. package/lib/components/scan-admin/scan-card/index.js +20 -0
  51. package/lib/components/scan-admin/scan-card/index.js.map +1 -0
  52. package/lib/components/scan-admin/scan-card/scan-card-content.d.ts +30 -0
  53. package/lib/components/scan-admin/scan-card/scan-card-content.d.ts.map +1 -0
  54. package/lib/components/scan-admin/scan-card/scan-card-content.js +232 -0
  55. package/lib/components/scan-admin/scan-card/scan-card-content.js.map +1 -0
  56. package/lib/components/scan-admin/scan-card/scan-card-expand-strip-badges.d.ts +26 -0
  57. package/lib/components/scan-admin/scan-card/scan-card-expand-strip-badges.d.ts.map +1 -0
  58. package/lib/components/scan-admin/scan-card/scan-card-expand-strip-badges.js +121 -0
  59. package/lib/components/scan-admin/scan-card/scan-card-expand-strip-badges.js.map +1 -0
  60. package/lib/components/scan-admin/scan-card/scan-card-expand-strip.d.ts +27 -0
  61. package/lib/components/scan-admin/scan-card/scan-card-expand-strip.d.ts.map +1 -0
  62. package/lib/components/scan-admin/scan-card/scan-card-expand-strip.js +66 -0
  63. package/lib/components/scan-admin/scan-card/scan-card-expand-strip.js.map +1 -0
  64. package/lib/components/scan-admin/scan-card/scan-card-expanded-content.d.ts +26 -0
  65. package/lib/components/scan-admin/scan-card/scan-card-expanded-content.d.ts.map +1 -0
  66. package/lib/components/scan-admin/scan-card/scan-card-expanded-content.js +151 -0
  67. package/lib/components/scan-admin/scan-card/scan-card-expanded-content.js.map +1 -0
  68. package/lib/components/scan-admin/scan-card/scan-card-header.d.ts +26 -0
  69. package/lib/components/scan-admin/scan-card/scan-card-header.d.ts.map +1 -0
  70. package/lib/components/scan-admin/scan-card/scan-card-header.js +101 -0
  71. package/lib/components/scan-admin/scan-card/scan-card-header.js.map +1 -0
  72. package/lib/components/scan-admin/scan-card/scan-card.d.ts +34 -0
  73. package/lib/components/scan-admin/scan-card/scan-card.d.ts.map +1 -0
  74. package/lib/components/scan-admin/scan-card/scan-card.js +90 -0
  75. package/lib/components/scan-admin/scan-card/scan-card.js.map +1 -0
  76. package/lib/components/scan-admin/scan-card/scan-detail-card.d.ts +38 -0
  77. package/lib/components/scan-admin/scan-card/scan-detail-card.d.ts.map +1 -0
  78. package/lib/components/scan-admin/scan-card/scan-detail-card.js +72 -0
  79. package/lib/components/scan-admin/scan-card/scan-detail-card.js.map +1 -0
  80. package/lib/components/scan-admin/scan-card/utils.d.ts +48 -0
  81. package/lib/components/scan-admin/scan-card/utils.d.ts.map +1 -0
  82. package/lib/components/scan-admin/scan-card/utils.js +166 -0
  83. package/lib/components/scan-admin/scan-card/utils.js.map +1 -0
  84. package/lib/components/scan-admin/tab-contents/allow-list-tab-content.d.ts +19 -0
  85. package/lib/components/scan-admin/tab-contents/allow-list-tab-content.d.ts.map +1 -0
  86. package/lib/components/scan-admin/tab-contents/allow-list-tab-content.js +55 -0
  87. package/lib/components/scan-admin/tab-contents/allow-list-tab-content.js.map +1 -0
  88. package/lib/components/scan-admin/tab-contents/auto-rejected-tab-content.d.ts +19 -0
  89. package/lib/components/scan-admin/tab-contents/auto-rejected-tab-content.d.ts.map +1 -0
  90. package/lib/components/scan-admin/tab-contents/auto-rejected-tab-content.js +43 -0
  91. package/lib/components/scan-admin/tab-contents/auto-rejected-tab-content.js.map +1 -0
  92. package/lib/components/scan-admin/tab-contents/block-list-tab-content.d.ts +19 -0
  93. package/lib/components/scan-admin/tab-contents/block-list-tab-content.d.ts.map +1 -0
  94. package/lib/components/scan-admin/tab-contents/block-list-tab-content.js +55 -0
  95. package/lib/components/scan-admin/tab-contents/block-list-tab-content.js.map +1 -0
  96. package/lib/components/scan-admin/tab-contents/index.d.ts +18 -0
  97. package/lib/components/scan-admin/tab-contents/index.d.ts.map +1 -0
  98. package/lib/components/scan-admin/tab-contents/index.js +18 -0
  99. package/lib/components/scan-admin/tab-contents/index.js.map +1 -0
  100. package/lib/components/scan-admin/tab-contents/quarantined-tab-content.d.ts +19 -0
  101. package/lib/components/scan-admin/tab-contents/quarantined-tab-content.d.ts.map +1 -0
  102. package/lib/components/scan-admin/tab-contents/quarantined-tab-content.js +78 -0
  103. package/lib/components/scan-admin/tab-contents/quarantined-tab-content.js.map +1 -0
  104. package/lib/components/scan-admin/tab-contents/scans-tab-content.d.ts +19 -0
  105. package/lib/components/scan-admin/tab-contents/scans-tab-content.d.ts.map +1 -0
  106. package/lib/components/scan-admin/tab-contents/scans-tab-content.js +52 -0
  107. package/lib/components/scan-admin/tab-contents/scans-tab-content.js.map +1 -0
  108. package/lib/components/scan-admin/toolbars/counts-toolbar.d.ts +35 -0
  109. package/lib/components/scan-admin/toolbars/counts-toolbar.d.ts.map +1 -0
  110. package/lib/components/scan-admin/toolbars/counts-toolbar.js +132 -0
  111. package/lib/components/scan-admin/toolbars/counts-toolbar.js.map +1 -0
  112. package/lib/components/scan-admin/toolbars/index.d.ts +16 -0
  113. package/lib/components/scan-admin/toolbars/index.d.ts.map +1 -0
  114. package/lib/components/scan-admin/toolbars/index.js +16 -0
  115. package/lib/components/scan-admin/toolbars/index.js.map +1 -0
  116. package/lib/components/scan-admin/toolbars/search-toolbar.d.ts +43 -0
  117. package/lib/components/scan-admin/toolbars/search-toolbar.d.ts.map +1 -0
  118. package/lib/components/scan-admin/toolbars/search-toolbar.js +106 -0
  119. package/lib/components/scan-admin/toolbars/search-toolbar.js.map +1 -0
  120. package/lib/components/scan-admin/toolbars/tab-toolbar.d.ts +25 -0
  121. package/lib/components/scan-admin/toolbars/tab-toolbar.d.ts.map +1 -0
  122. package/lib/components/scan-admin/toolbars/tab-toolbar.js +33 -0
  123. package/lib/components/scan-admin/toolbars/tab-toolbar.js.map +1 -0
  124. package/lib/context/scan-admin/index.d.ts +21 -0
  125. package/lib/context/scan-admin/index.d.ts.map +1 -0
  126. package/lib/context/scan-admin/index.js +27 -0
  127. package/lib/context/scan-admin/index.js.map +1 -0
  128. package/lib/context/scan-admin/scan-actions.d.ts +19 -0
  129. package/lib/context/scan-admin/scan-actions.d.ts.map +1 -0
  130. package/lib/context/scan-admin/scan-actions.js +64 -0
  131. package/lib/context/scan-admin/scan-actions.js.map +1 -0
  132. package/lib/context/scan-admin/scan-api-actions.d.ts +26 -0
  133. package/lib/context/scan-admin/scan-api-actions.d.ts.map +1 -0
  134. package/lib/context/scan-admin/scan-api-actions.js +118 -0
  135. package/lib/context/scan-admin/scan-api-actions.js.map +1 -0
  136. package/lib/context/scan-admin/scan-api-effects.d.ts +40 -0
  137. package/lib/context/scan-admin/scan-api-effects.d.ts.map +1 -0
  138. package/lib/context/scan-admin/scan-api-effects.js +446 -0
  139. package/lib/context/scan-admin/scan-api-effects.js.map +1 -0
  140. package/lib/context/scan-admin/scan-context-types.d.ts +69 -0
  141. package/lib/context/scan-admin/scan-context-types.d.ts.map +1 -0
  142. package/lib/context/scan-admin/scan-context-types.js +14 -0
  143. package/lib/context/scan-admin/scan-context-types.js.map +1 -0
  144. package/lib/context/scan-admin/scan-context.d.ts +17 -0
  145. package/lib/context/scan-admin/scan-context.d.ts.map +1 -0
  146. package/lib/context/scan-admin/scan-context.js +90 -0
  147. package/lib/context/scan-admin/scan-context.js.map +1 -0
  148. package/lib/context/scan-admin/scan-helpers.d.ts +28 -0
  149. package/lib/context/scan-admin/scan-helpers.d.ts.map +1 -0
  150. package/lib/context/scan-admin/scan-helpers.js +56 -0
  151. package/lib/context/scan-admin/scan-helpers.js.map +1 -0
  152. package/lib/context/scan-admin/scan-reducer.d.ts +18 -0
  153. package/lib/context/scan-admin/scan-reducer.d.ts.map +1 -0
  154. package/lib/context/scan-admin/scan-reducer.js +194 -0
  155. package/lib/context/scan-admin/scan-reducer.js.map +1 -0
  156. package/lib/context/scan-admin/scan-types.d.ts +292 -0
  157. package/lib/context/scan-admin/scan-types.d.ts.map +1 -0
  158. package/lib/context/scan-admin/scan-types.js +67 -0
  159. package/lib/context/scan-admin/scan-types.js.map +1 -0
  160. package/lib/default/page-settings.d.ts.map +1 -1
  161. package/lib/default/page-settings.js +3 -0
  162. package/lib/default/page-settings.js.map +1 -1
  163. package/lib/default/theme.d.ts +50 -12
  164. package/lib/default/theme.d.ts.map +1 -1
  165. package/lib/default/theme.js +42 -0
  166. package/lib/default/theme.js.map +1 -1
  167. package/lib/extension-registry-service.d.ts +106 -1
  168. package/lib/extension-registry-service.d.ts.map +1 -1
  169. package/lib/extension-registry-service.js +348 -1
  170. package/lib/extension-registry-service.js.map +1 -1
  171. package/lib/extension-registry-types.d.ts +181 -0
  172. package/lib/extension-registry-types.d.ts.map +1 -1
  173. package/lib/extension-registry-types.js +16 -0
  174. package/lib/extension-registry-types.js.map +1 -1
  175. package/lib/hooks/scan-admin/index.d.ts +34 -0
  176. package/lib/hooks/scan-admin/index.d.ts.map +1 -0
  177. package/lib/hooks/scan-admin/index.js +28 -0
  178. package/lib/hooks/scan-admin/index.js.map +1 -0
  179. package/lib/hooks/scan-admin/use-auto-rejected-tab.d.ts +76 -0
  180. package/lib/hooks/scan-admin/use-auto-rejected-tab.d.ts.map +1 -0
  181. package/lib/hooks/scan-admin/use-auto-rejected-tab.js +79 -0
  182. package/lib/hooks/scan-admin/use-auto-rejected-tab.js.map +1 -0
  183. package/lib/hooks/scan-admin/use-dialogs.d.ts +43 -0
  184. package/lib/hooks/scan-admin/use-dialogs.d.ts.map +1 -0
  185. package/lib/hooks/scan-admin/use-dialogs.js +55 -0
  186. package/lib/hooks/scan-admin/use-dialogs.js.map +1 -0
  187. package/lib/hooks/scan-admin/use-file-list-tab.d.ts +208 -0
  188. package/lib/hooks/scan-admin/use-file-list-tab.d.ts.map +1 -0
  189. package/lib/hooks/scan-admin/use-file-list-tab.js +125 -0
  190. package/lib/hooks/scan-admin/use-file-list-tab.js.map +1 -0
  191. package/lib/hooks/scan-admin/use-pagination.d.ts +36 -0
  192. package/lib/hooks/scan-admin/use-pagination.d.ts.map +1 -0
  193. package/lib/hooks/scan-admin/use-pagination.js +79 -0
  194. package/lib/hooks/scan-admin/use-pagination.js.map +1 -0
  195. package/lib/hooks/scan-admin/use-quarantined-tab.d.ts +92 -0
  196. package/lib/hooks/scan-admin/use-quarantined-tab.d.ts.map +1 -0
  197. package/lib/hooks/scan-admin/use-quarantined-tab.js +125 -0
  198. package/lib/hooks/scan-admin/use-quarantined-tab.js.map +1 -0
  199. package/lib/hooks/scan-admin/use-scan-card-state.d.ts +29 -0
  200. package/lib/hooks/scan-admin/use-scan-card-state.d.ts.map +1 -0
  201. package/lib/hooks/scan-admin/use-scan-card-state.js +50 -0
  202. package/lib/hooks/scan-admin/use-scan-card-state.js.map +1 -0
  203. package/lib/hooks/scan-admin/use-scan-filters.d.ts +53 -0
  204. package/lib/hooks/scan-admin/use-scan-filters.d.ts.map +1 -0
  205. package/lib/hooks/scan-admin/use-scan-filters.js +75 -0
  206. package/lib/hooks/scan-admin/use-scan-filters.js.map +1 -0
  207. package/lib/hooks/scan-admin/use-scans-tab.d.ts +85 -0
  208. package/lib/hooks/scan-admin/use-scans-tab.d.ts.map +1 -0
  209. package/lib/hooks/scan-admin/use-scans-tab.js +87 -0
  210. package/lib/hooks/scan-admin/use-scans-tab.js.map +1 -0
  211. package/lib/hooks/scan-admin/use-search.d.ts +32 -0
  212. package/lib/hooks/scan-admin/use-search.d.ts.map +1 -0
  213. package/lib/hooks/scan-admin/use-search.js +48 -0
  214. package/lib/hooks/scan-admin/use-search.js.map +1 -0
  215. package/lib/hooks/scan-admin/use-tab-navigation.d.ts +96 -0
  216. package/lib/hooks/scan-admin/use-tab-navigation.d.ts.map +1 -0
  217. package/lib/hooks/scan-admin/use-tab-navigation.js +70 -0
  218. package/lib/hooks/scan-admin/use-tab-navigation.js.map +1 -0
  219. package/lib/hooks/scan-admin/use-url-sync.d.ts +22 -0
  220. package/lib/hooks/scan-admin/use-url-sync.d.ts.map +1 -0
  221. package/lib/hooks/scan-admin/use-url-sync.js +252 -0
  222. package/lib/hooks/scan-admin/use-url-sync.js.map +1 -0
  223. package/lib/page-settings.d.ts +4 -0
  224. package/lib/page-settings.d.ts.map +1 -1
  225. package/lib/pages/admin-dashboard/admin-dashboard.d.ts +4 -0
  226. package/lib/pages/admin-dashboard/admin-dashboard.d.ts.map +1 -1
  227. package/lib/pages/admin-dashboard/admin-dashboard.js +55 -5
  228. package/lib/pages/admin-dashboard/admin-dashboard.js.map +1 -1
  229. package/lib/pages/admin-dashboard/components/data-grid-filter-operators.d.ts +28 -0
  230. package/lib/pages/admin-dashboard/components/data-grid-filter-operators.d.ts.map +1 -0
  231. package/lib/pages/admin-dashboard/components/data-grid-filter-operators.js +93 -0
  232. package/lib/pages/admin-dashboard/components/data-grid-filter-operators.js.map +1 -0
  233. package/lib/pages/admin-dashboard/components/index.d.ts +2 -0
  234. package/lib/pages/admin-dashboard/components/index.d.ts.map +1 -0
  235. package/lib/pages/admin-dashboard/components/index.js +14 -0
  236. package/lib/pages/admin-dashboard/components/index.js.map +1 -0
  237. package/lib/pages/admin-dashboard/customers/customer-form-dialog.d.ts +23 -0
  238. package/lib/pages/admin-dashboard/customers/customer-form-dialog.d.ts.map +1 -0
  239. package/lib/pages/admin-dashboard/customers/customer-form-dialog.js +225 -0
  240. package/lib/pages/admin-dashboard/customers/customer-form-dialog.js.map +1 -0
  241. package/lib/pages/admin-dashboard/customers/customers.d.ts +15 -0
  242. package/lib/pages/admin-dashboard/customers/customers.d.ts.map +1 -0
  243. package/lib/pages/admin-dashboard/customers/customers.js +175 -0
  244. package/lib/pages/admin-dashboard/customers/customers.js.map +1 -0
  245. package/lib/pages/admin-dashboard/customers/delete-customer-dialog.d.ts +23 -0
  246. package/lib/pages/admin-dashboard/customers/delete-customer-dialog.d.ts.map +1 -0
  247. package/lib/pages/admin-dashboard/customers/delete-customer-dialog.js +64 -0
  248. package/lib/pages/admin-dashboard/customers/delete-customer-dialog.js.map +1 -0
  249. package/lib/pages/admin-dashboard/publisher-admin.js +5 -5
  250. package/lib/pages/admin-dashboard/publisher-admin.js.map +1 -1
  251. package/lib/pages/admin-dashboard/publisher-revoke-dialog.d.ts.map +1 -1
  252. package/lib/pages/admin-dashboard/publisher-revoke-dialog.js +1 -1
  253. package/lib/pages/admin-dashboard/publisher-revoke-dialog.js.map +1 -1
  254. package/lib/pages/admin-dashboard/scan-admin.d.ts +20 -0
  255. package/lib/pages/admin-dashboard/scan-admin.d.ts.map +1 -0
  256. package/lib/pages/admin-dashboard/scan-admin.js +66 -0
  257. package/lib/pages/admin-dashboard/scan-admin.js.map +1 -0
  258. package/lib/pages/admin-dashboard/tiers/delete-tier-dialog.d.ts +23 -0
  259. package/lib/pages/admin-dashboard/tiers/delete-tier-dialog.d.ts.map +1 -0
  260. package/lib/pages/admin-dashboard/tiers/delete-tier-dialog.js +55 -0
  261. package/lib/pages/admin-dashboard/tiers/delete-tier-dialog.js.map +1 -0
  262. package/lib/pages/admin-dashboard/tiers/tier-form-dialog.d.ts +23 -0
  263. package/lib/pages/admin-dashboard/tiers/tier-form-dialog.d.ts.map +1 -0
  264. package/lib/pages/admin-dashboard/tiers/tier-form-dialog.js +215 -0
  265. package/lib/pages/admin-dashboard/tiers/tier-form-dialog.js.map +1 -0
  266. package/lib/pages/admin-dashboard/tiers/tiers.d.ts +15 -0
  267. package/lib/pages/admin-dashboard/tiers/tiers.d.ts.map +1 -0
  268. package/lib/pages/admin-dashboard/tiers/tiers.js +174 -0
  269. package/lib/pages/admin-dashboard/tiers/tiers.js.map +1 -0
  270. package/lib/pages/admin-dashboard/usage-stats/usage-stats-chart.d.ts +23 -0
  271. package/lib/pages/admin-dashboard/usage-stats/usage-stats-chart.d.ts.map +1 -0
  272. package/lib/pages/admin-dashboard/usage-stats/usage-stats-chart.js +106 -0
  273. package/lib/pages/admin-dashboard/usage-stats/usage-stats-chart.js.map +1 -0
  274. package/lib/pages/admin-dashboard/usage-stats/usage-stats-search.d.ts +26 -0
  275. package/lib/pages/admin-dashboard/usage-stats/usage-stats-search.d.ts.map +1 -0
  276. package/lib/pages/admin-dashboard/usage-stats/usage-stats-search.js +50 -0
  277. package/lib/pages/admin-dashboard/usage-stats/usage-stats-search.js.map +1 -0
  278. package/lib/pages/admin-dashboard/usage-stats/usage-stats-utils.d.ts +14 -0
  279. package/lib/pages/admin-dashboard/usage-stats/usage-stats-utils.d.ts.map +1 -0
  280. package/lib/pages/admin-dashboard/usage-stats/usage-stats-utils.js +16 -0
  281. package/lib/pages/admin-dashboard/usage-stats/usage-stats-utils.js.map +1 -0
  282. package/lib/pages/admin-dashboard/usage-stats/usage-stats.d.ts +15 -0
  283. package/lib/pages/admin-dashboard/usage-stats/usage-stats.d.ts.map +1 -0
  284. package/lib/pages/admin-dashboard/usage-stats/usage-stats.js +103 -0
  285. package/lib/pages/admin-dashboard/usage-stats/usage-stats.js.map +1 -0
  286. package/lib/pages/admin-dashboard/welcome.d.ts.map +1 -1
  287. package/lib/pages/admin-dashboard/welcome.js +5 -1
  288. package/lib/pages/admin-dashboard/welcome.js.map +1 -1
  289. package/lib/pages/extension-detail/extension-detail-overview.d.ts.map +1 -1
  290. package/lib/pages/extension-detail/extension-detail-overview.js +9 -1
  291. package/lib/pages/extension-detail/extension-detail-overview.js.map +1 -1
  292. package/lib/pages/extension-detail/extension-detail-reviews.d.ts.map +1 -1
  293. package/lib/pages/extension-detail/extension-detail-reviews.js +67 -18
  294. package/lib/pages/extension-detail/extension-detail-reviews.js.map +1 -1
  295. package/lib/pages/extension-detail/extension-detail.js +2 -2
  296. package/lib/pages/extension-detail/extension-detail.js.map +1 -1
  297. package/lib/pages/extension-detail/extension-rating-stars.d.ts +2 -2
  298. package/lib/pages/extension-detail/extension-rating-stars.d.ts.map +1 -1
  299. package/lib/pages/extension-detail/extension-rating-stars.js +1 -1
  300. package/lib/pages/extension-detail/extension-rating-stars.js.map +1 -1
  301. package/lib/pages/extension-list/extension-list-item.js +2 -2
  302. package/lib/pages/extension-list/extension-list-item.js.map +1 -1
  303. package/lib/pages/user/user-namespace-extension-list-item.d.ts.map +1 -1
  304. package/lib/pages/user/user-namespace-extension-list-item.js +23 -9
  305. package/lib/pages/user/user-namespace-extension-list-item.js.map +1 -1
  306. package/lib/pages/user/user-publisher-agreement.d.ts.map +1 -1
  307. package/lib/pages/user/user-publisher-agreement.js +34 -13
  308. package/lib/pages/user/user-publisher-agreement.js.map +1 -1
  309. package/lib/pages/user/user-settings-profile.d.ts.map +1 -1
  310. package/lib/pages/user/user-settings-profile.js +10 -5
  311. package/lib/pages/user/user-settings-profile.js.map +1 -1
  312. package/lib/pages/user/user-settings-tokens.d.ts.map +1 -1
  313. package/lib/pages/user/user-settings-tokens.js +13 -5
  314. package/lib/pages/user/user-settings-tokens.js.map +1 -1
  315. package/lib/server-request.d.ts +1 -1
  316. package/lib/server-request.d.ts.map +1 -1
  317. package/lib/server-request.js +3 -3
  318. package/lib/server-request.js.map +1 -1
  319. package/package.json +17 -9
  320. package/src/components/button-with-progress.tsx +2 -1
  321. package/src/components/sanitized-markdown.tsx +81 -1
  322. package/src/components/scan-admin/common/auto-refresh.tsx +79 -0
  323. package/src/components/scan-admin/common/conditional-tooltip.tsx +74 -0
  324. package/src/components/scan-admin/common/file-table.tsx +508 -0
  325. package/src/components/scan-admin/common/index.ts +18 -0
  326. package/src/components/scan-admin/common/tab-panel.tsx +42 -0
  327. package/src/components/scan-admin/common/utils.ts +48 -0
  328. package/src/components/scan-admin/dialogs/file-dialog.tsx +137 -0
  329. package/src/components/scan-admin/dialogs/index.ts +15 -0
  330. package/src/components/scan-admin/dialogs/quarantine-dialog.tsx +270 -0
  331. package/src/components/scan-admin/index.ts +52 -0
  332. package/src/components/scan-admin/scan-card/index.ts +20 -0
  333. package/src/components/scan-admin/scan-card/scan-card-content.tsx +457 -0
  334. package/src/components/scan-admin/scan-card/scan-card-expand-strip-badges.tsx +186 -0
  335. package/src/components/scan-admin/scan-card/scan-card-expand-strip.tsx +104 -0
  336. package/src/components/scan-admin/scan-card/scan-card-expanded-content.tsx +262 -0
  337. package/src/components/scan-admin/scan-card/scan-card-header.tsx +176 -0
  338. package/src/components/scan-admin/scan-card/scan-card.tsx +152 -0
  339. package/src/components/scan-admin/scan-card/scan-detail-card.tsx +144 -0
  340. package/src/components/scan-admin/scan-card/utils.ts +199 -0
  341. package/src/components/scan-admin/tab-contents/allow-list-tab-content.tsx +119 -0
  342. package/src/components/scan-admin/tab-contents/auto-rejected-tab-content.tsx +106 -0
  343. package/src/components/scan-admin/tab-contents/block-list-tab-content.tsx +119 -0
  344. package/src/components/scan-admin/tab-contents/index.ts +18 -0
  345. package/src/components/scan-admin/tab-contents/quarantined-tab-content.tsx +158 -0
  346. package/src/components/scan-admin/tab-contents/scans-tab-content.tsx +113 -0
  347. package/src/components/scan-admin/toolbars/counts-toolbar.tsx +262 -0
  348. package/src/components/scan-admin/toolbars/index.ts +16 -0
  349. package/src/components/scan-admin/toolbars/search-toolbar.tsx +255 -0
  350. package/src/components/scan-admin/toolbars/tab-toolbar.tsx +56 -0
  351. package/src/context/scan-admin/index.ts +43 -0
  352. package/src/context/scan-admin/scan-actions.ts +87 -0
  353. package/src/context/scan-admin/scan-api-actions.ts +137 -0
  354. package/src/context/scan-admin/scan-api-effects.ts +491 -0
  355. package/src/context/scan-admin/scan-context-types.ts +102 -0
  356. package/src/context/scan-admin/scan-context.tsx +123 -0
  357. package/src/context/scan-admin/scan-helpers.ts +63 -0
  358. package/src/context/scan-admin/scan-reducer.ts +321 -0
  359. package/src/context/scan-admin/scan-types.ts +337 -0
  360. package/src/default/page-settings.tsx +3 -0
  361. package/src/default/theme.tsx +102 -13
  362. package/src/extension-registry-service.ts +372 -1
  363. package/src/extension-registry-types.ts +207 -0
  364. package/src/hooks/scan-admin/index.ts +48 -0
  365. package/src/hooks/scan-admin/use-auto-rejected-tab.ts +85 -0
  366. package/src/hooks/scan-admin/use-dialogs.ts +83 -0
  367. package/src/hooks/scan-admin/use-file-list-tab.ts +149 -0
  368. package/src/hooks/scan-admin/use-pagination.ts +90 -0
  369. package/src/hooks/scan-admin/use-quarantined-tab.ts +138 -0
  370. package/src/hooks/scan-admin/use-scan-card-state.ts +73 -0
  371. package/src/hooks/scan-admin/use-scan-filters.ts +83 -0
  372. package/src/hooks/scan-admin/use-scans-tab.ts +92 -0
  373. package/src/hooks/scan-admin/use-search.ts +54 -0
  374. package/src/hooks/scan-admin/use-tab-navigation.ts +82 -0
  375. package/src/hooks/scan-admin/use-url-sync.ts +293 -0
  376. package/src/page-settings.ts +4 -0
  377. package/src/pages/admin-dashboard/admin-dashboard.tsx +71 -4
  378. package/src/pages/admin-dashboard/components/data-grid-filter-operators.tsx +126 -0
  379. package/src/pages/admin-dashboard/components/index.ts +18 -0
  380. package/src/pages/admin-dashboard/customers/customer-form-dialog.tsx +348 -0
  381. package/src/pages/admin-dashboard/customers/customers.tsx +279 -0
  382. package/src/pages/admin-dashboard/customers/delete-customer-dialog.tsx +94 -0
  383. package/src/pages/admin-dashboard/publisher-admin.tsx +5 -5
  384. package/src/pages/admin-dashboard/publisher-revoke-dialog.tsx +2 -1
  385. package/src/pages/admin-dashboard/scan-admin.tsx +109 -0
  386. package/src/pages/admin-dashboard/tiers/delete-tier-dialog.tsx +83 -0
  387. package/src/pages/admin-dashboard/tiers/tier-form-dialog.tsx +372 -0
  388. package/src/pages/admin-dashboard/tiers/tiers.tsx +254 -0
  389. package/src/pages/admin-dashboard/usage-stats/usage-stats-chart.tsx +189 -0
  390. package/src/pages/admin-dashboard/usage-stats/usage-stats-search.tsx +83 -0
  391. package/src/pages/admin-dashboard/usage-stats/usage-stats-utils.ts +16 -0
  392. package/src/pages/admin-dashboard/usage-stats/usage-stats.tsx +127 -0
  393. package/src/pages/admin-dashboard/welcome.tsx +4 -0
  394. package/src/pages/extension-detail/extension-detail-overview.tsx +16 -2
  395. package/src/pages/extension-detail/extension-detail-reviews.tsx +116 -30
  396. package/src/pages/extension-detail/extension-detail.tsx +2 -2
  397. package/src/pages/extension-detail/extension-rating-stars.tsx +2 -2
  398. package/src/pages/extension-list/extension-list-item.tsx +2 -2
  399. package/src/pages/user/user-namespace-extension-list-item.tsx +38 -13
  400. package/src/pages/user/user-publisher-agreement.tsx +30 -11
  401. package/src/pages/user/user-settings-profile.tsx +10 -6
  402. package/src/pages/user/user-settings-tokens.tsx +15 -6
  403. package/src/server-request.ts +3 -3
@@ -12,7 +12,10 @@ import {
12
12
  Extension, UserData, ExtensionCategory, ExtensionReviewList, PersonalAccessToken, SearchResult, NewReview,
13
13
  SuccessResult, ErrorResult, CsrfTokenJson, isError, Namespace, NamespaceDetails, MembershipRole, SortBy,
14
14
  SortOrder, UrlString, NamespaceMembershipList, PublisherInfo, SearchEntry, RegistryVersion,
15
- LoginProviders
15
+ LoginProviders, ScanResultJson, ScanCounts, ScanResultsResponse, ScanFilterOptions,
16
+ FilesResponse, FileDecisionCountsJson, ScanDecisionRequest, ScanDecisionResponse,
17
+ FileDecisionRequest, FileDecisionResponse, FileDecisionDeleteRequest, FileDecisionDeleteResponse,
18
+ Tier, TierList, Customer, CustomerList, UsageStatsList,
16
19
  } from './extension-registry-types';
17
20
  import { createAbsoluteURL, addQuery } from './utils';
18
21
  import { sendRequest, ErrorResponse } from './server-request';
@@ -209,6 +212,22 @@ export class ExtensionRegistryService {
209
212
  });
210
213
  }
211
214
 
215
+ async deleteUserReview(abortController: AbortController, extension: Extension, user: UserData): Promise<Readonly<SuccessResult | ErrorResult>> {
216
+ const csrfResponse = await this.getCsrfToken(abortController);
217
+ const headers: Record<string, string> = {};
218
+ if (!isError(csrfResponse)) {
219
+ const csrfToken = csrfResponse as CsrfTokenJson;
220
+ headers[csrfToken.header] = csrfToken.value;
221
+ }
222
+ return sendRequest({
223
+ abortController,
224
+ method: 'POST',
225
+ credentials: true,
226
+ endpoint: createAbsoluteURL([this.serverUrl, 'admin', 'extension', extension.namespace, extension.name, 'review', user.provider || 'github', user.loginName, 'delete']),
227
+ headers
228
+ });
229
+ }
230
+
212
231
  getUser(abortController: AbortController): Promise<Readonly<UserData | ErrorResult>> {
213
232
  return sendRequest({
214
233
  abortController,
@@ -470,6 +489,26 @@ export interface AdminService {
470
489
  getPublisherInfo(abortController: AbortController, provider: string, login: string): Promise<Readonly<PublisherInfo>>
471
490
  revokePublisherContributions(abortController: AbortController, provider: string, login: string): Promise<Readonly<SuccessResult | ErrorResult>>
472
491
  revokeAccessTokens(abortController: AbortController, provider: string, login: string): Promise<Readonly<SuccessResult | ErrorResult>>
492
+ getAllScans(abortController: AbortController, params?: { size?: number; offset?: number; status?: string | string[]; publisher?: string; namespace?: string; name?: string; validationType?: string[]; threatScannerName?: string[]; dateStartedFrom?: string; dateStartedTo?: string; enforcement?: 'enforced' | 'notEnforced' | 'all' }): Promise<Readonly<ScanResultsResponse>>
493
+ getScan(abortController: AbortController, scanId: string): Promise<Readonly<ScanResultJson>>
494
+ getScanCounts(abortController: AbortController, params?: { dateStartedFrom?: string; dateStartedTo?: string; enforcement?: 'enforced' | 'notEnforced' | 'all'; threatScannerName?: string[]; validationType?: string[] }): Promise<Readonly<ScanCounts>>
495
+ getScanFilterOptions(abortController: AbortController): Promise<Readonly<ScanFilterOptions>>
496
+ // Files API
497
+ getFiles(abortController: AbortController, params?: { size?: number; offset?: number; decision?: string; publisher?: string; namespace?: string; name?: string; dateDecidedFrom?: string; dateDecidedTo?: string; sortBy?: string; sortOrder?: 'asc' | 'desc' }): Promise<Readonly<FilesResponse>>;
498
+ getFileCounts(abortController: AbortController, params?: { dateDecidedFrom?: string; dateDecidedTo?: string }): Promise<Readonly<FileDecisionCountsJson>>
499
+ // Decision APIs
500
+ makeScanDecision(abortController: AbortController, request: ScanDecisionRequest): Promise<Readonly<ScanDecisionResponse>>
501
+ makeFileDecision(abortController: AbortController, request: FileDecisionRequest): Promise<Readonly<FileDecisionResponse>>
502
+ deleteFileDecisions(abortController: AbortController, request: FileDecisionDeleteRequest): Promise<Readonly<FileDecisionDeleteResponse>>
503
+ getTiers(abortController: AbortController): Promise<Readonly<TierList>>;
504
+ createTier(abortController: AbortController, tier: Tier): Promise<Readonly<Tier>>;
505
+ updateTier(abortController: AbortController, name: string, tier: Tier): Promise<Readonly<Tier>>;
506
+ deleteTier(abortController: AbortController, name: string): Promise<Readonly<SuccessResult | ErrorResult>>;
507
+ getCustomers(abortController: AbortController): Promise<Readonly<CustomerList>>;
508
+ createCustomer(abortController: AbortController, customer: Customer): Promise<Readonly<Customer>>;
509
+ updateCustomer(abortController: AbortController, name: string, customer: Customer): Promise<Readonly<Customer>>;
510
+ deleteCustomer(abortController: AbortController, name: string): Promise<Readonly<SuccessResult | ErrorResult>>;
511
+ getUsageStats(abortController: AbortController, customerName: string, date: Date): Promise<Readonly<UsageStatsList>>;
473
512
  }
474
513
 
475
514
  export interface AdminServiceConstructor {
@@ -593,6 +632,338 @@ export class AdminServiceImpl implements AdminService {
593
632
  headers
594
633
  });
595
634
  }
635
+
636
+ getAllScans(abortController: AbortController, params?: { size?: number; offset?: number; status?: string | string[]; publisher?: string; namespace?: string; name?: string; validationType?: string[]; threatScannerName?: string[]; dateStartedFrom?: string; dateStartedTo?: string; enforcement?: 'enforced' | 'notEnforced' | 'all'; adminDecision?: string[] }): Promise<Readonly<ScanResultsResponse>> {
637
+ const query: { key: string, value: string | number }[] = [];
638
+ if (params) {
639
+ if (params.size !== undefined)
640
+ query.push({ key: 'size', value: params.size });
641
+ if (params.offset !== undefined)
642
+ query.push({ key: 'offset', value: params.offset });
643
+ if (params.status) {
644
+ const statusValue = Array.isArray(params.status) ? params.status.join(',') : params.status;
645
+ query.push({ key: 'status', value: statusValue });
646
+ }
647
+ if (params.publisher)
648
+ query.push({ key: 'publisher', value: params.publisher });
649
+ if (params.namespace)
650
+ query.push({ key: 'namespace', value: params.namespace });
651
+ if (params.name)
652
+ query.push({ key: 'name', value: params.name });
653
+ if (params.validationType && params.validationType.length > 0)
654
+ query.push({ key: 'validationType', value: params.validationType.join(',') });
655
+ if (params.threatScannerName && params.threatScannerName.length > 0)
656
+ query.push({ key: 'threatScannerName', value: params.threatScannerName.join(',') });
657
+ if (params.dateStartedFrom)
658
+ query.push({ key: 'dateStartedFrom', value: params.dateStartedFrom });
659
+ if (params.dateStartedTo)
660
+ query.push({ key: 'dateStartedTo', value: params.dateStartedTo });
661
+ if (params.enforcement)
662
+ query.push({ key: 'enforcement', value: params.enforcement });
663
+ if (params.adminDecision && params.adminDecision.length > 0)
664
+ query.push({ key: 'adminDecision', value: params.adminDecision.join(',') });
665
+ }
666
+ const endpoint = createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans'], query);
667
+ return sendRequest({
668
+ abortController,
669
+ credentials: true,
670
+ endpoint
671
+ });
672
+ }
673
+
674
+ getScan(abortController: AbortController, scanId: string): Promise<Readonly<ScanResultJson>> {
675
+ return sendRequest({
676
+ abortController,
677
+ credentials: true,
678
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', scanId])
679
+ });
680
+ }
681
+
682
+ getScanCounts(abortController: AbortController, params?: { dateStartedFrom?: string; dateStartedTo?: string; enforcement?: 'enforced' | 'notEnforced' | 'all'; threatScannerName?: string[]; validationType?: string[] }): Promise<Readonly<ScanCounts>> {
683
+ const query: { key: string, value: string | number }[] = [];
684
+ if (params) {
685
+ if (params.dateStartedFrom)
686
+ query.push({ key: 'dateStartedFrom', value: params.dateStartedFrom });
687
+ if (params.dateStartedTo)
688
+ query.push({ key: 'dateStartedTo', value: params.dateStartedTo });
689
+ if (params.enforcement)
690
+ query.push({ key: 'enforcement', value: params.enforcement });
691
+ if (params.threatScannerName && params.threatScannerName.length > 0) {
692
+ query.push({ key: 'threatScannerName', value: params.threatScannerName.join(',') });
693
+ }
694
+ if (params.validationType && params.validationType.length > 0) {
695
+ query.push({ key: 'validationType', value: params.validationType.join(',') });
696
+ }
697
+ }
698
+ const endpoint = createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', 'counts'], query);
699
+ return sendRequest({
700
+ abortController,
701
+ credentials: true,
702
+ endpoint
703
+ });
704
+ }
705
+
706
+ getScanFilterOptions(abortController: AbortController): Promise<Readonly<ScanFilterOptions>> {
707
+ return sendRequest({
708
+ abortController,
709
+ credentials: true,
710
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', 'filterOptions'])
711
+ });
712
+ }
713
+
714
+ getFiles(abortController: AbortController, params?: { size?: number; offset?: number; decision?: string; publisher?: string; namespace?: string; name?: string; dateDecidedFrom?: string; dateDecidedTo?: string; sortBy?: string; sortOrder?: 'asc' | 'desc' }): Promise<Readonly<FilesResponse>> {
715
+ const query: { key: string, value: string | number }[] = [];
716
+ if (params) {
717
+ if (params.size !== undefined)
718
+ query.push({ key: 'size', value: params.size });
719
+ if (params.offset !== undefined)
720
+ query.push({ key: 'offset', value: params.offset });
721
+ if (params.decision)
722
+ query.push({ key: 'decision', value: params.decision });
723
+ if (params.publisher)
724
+ query.push({ key: 'publisher', value: params.publisher });
725
+ if (params.namespace)
726
+ query.push({ key: 'namespace', value: params.namespace });
727
+ if (params.name)
728
+ query.push({ key: 'name', value: params.name });
729
+ if (params.dateDecidedFrom)
730
+ query.push({ key: 'dateDecidedFrom', value: params.dateDecidedFrom });
731
+ if (params.dateDecidedTo)
732
+ query.push({ key: 'dateDecidedTo', value: params.dateDecidedTo });
733
+ if (params.sortBy)
734
+ query.push({ key: 'sortBy', value: params.sortBy });
735
+ if (params.sortOrder)
736
+ query.push({ key: 'sortOrder', value: params.sortOrder });
737
+ }
738
+ const endpoint = createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', 'files'], query);
739
+ return sendRequest({
740
+ abortController,
741
+ credentials: true,
742
+ endpoint
743
+ });
744
+ }
745
+
746
+ getFileCounts(abortController: AbortController, params?: { dateDecidedFrom?: string; dateDecidedTo?: string }): Promise<Readonly<FileDecisionCountsJson>> {
747
+ const query: { key: string, value: string | number }[] = [];
748
+ if (params) {
749
+ if (params.dateDecidedFrom)
750
+ query.push({ key: 'dateDecidedFrom', value: params.dateDecidedFrom });
751
+ if (params.dateDecidedTo)
752
+ query.push({ key: 'dateDecidedTo', value: params.dateDecidedTo });
753
+ }
754
+ const endpoint = createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', 'files', 'counts'], query);
755
+ return sendRequest({
756
+ abortController,
757
+ credentials: true,
758
+ endpoint
759
+ });
760
+ }
761
+
762
+ async makeScanDecision(abortController: AbortController, request: ScanDecisionRequest): Promise<Readonly<ScanDecisionResponse>> {
763
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
764
+ const headers: Record<string, string> = {
765
+ 'Content-Type': 'application/json;charset=UTF-8'
766
+ };
767
+ if (!isError(csrfResponse)) {
768
+ const csrfToken = csrfResponse as CsrfTokenJson;
769
+ headers[csrfToken.header] = csrfToken.value;
770
+ }
771
+
772
+ return sendRequest({
773
+ abortController,
774
+ method: 'POST',
775
+ credentials: true,
776
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', 'decisions']),
777
+ headers,
778
+ payload: request
779
+ });
780
+ }
781
+
782
+ async makeFileDecision(abortController: AbortController, request: FileDecisionRequest): Promise<Readonly<FileDecisionResponse>> {
783
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
784
+ const headers: Record<string, string> = {
785
+ 'Content-Type': 'application/json;charset=UTF-8'
786
+ };
787
+ if (!isError(csrfResponse)) {
788
+ const csrfToken = csrfResponse as CsrfTokenJson;
789
+ headers[csrfToken.header] = csrfToken.value;
790
+ }
791
+
792
+ return sendRequest({
793
+ abortController,
794
+ method: 'POST',
795
+ credentials: true,
796
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', 'files', 'decisions']),
797
+ headers,
798
+ payload: request
799
+ });
800
+ }
801
+
802
+ async deleteFileDecisions(abortController: AbortController, request: FileDecisionDeleteRequest): Promise<Readonly<FileDecisionDeleteResponse>> {
803
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
804
+ const headers: Record<string, string> = {
805
+ 'Content-Type': 'application/json;charset=UTF-8'
806
+ };
807
+ if (!isError(csrfResponse)) {
808
+ const csrfToken = csrfResponse as CsrfTokenJson;
809
+ headers[csrfToken.header] = csrfToken.value;
810
+ }
811
+
812
+ return sendRequest({
813
+ abortController,
814
+ method: 'DELETE',
815
+ credentials: true,
816
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'scans', 'files', 'decisions']),
817
+ headers,
818
+ payload: request
819
+ });
820
+ }
821
+
822
+ async getTiers(abortController: AbortController): Promise<Readonly<TierList>> {
823
+ return sendRequest({
824
+ abortController,
825
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'tiers']),
826
+ credentials: true
827
+ }, false);
828
+ }
829
+
830
+ async createTier(abortController: AbortController, tier: Tier): Promise<Readonly<Tier>> {
831
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
832
+ const headers: Record<string, string> = {
833
+ 'Content-Type': 'application/json;charset=UTF-8'
834
+ };
835
+ if (!isError(csrfResponse)) {
836
+ const csrfToken = csrfResponse as CsrfTokenJson;
837
+ headers[csrfToken.header] = csrfToken.value;
838
+ }
839
+ return sendRequest({
840
+ abortController,
841
+ method: 'POST',
842
+ payload: tier,
843
+ credentials: true,
844
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'tiers', 'create']),
845
+ headers
846
+ }, false);
847
+ }
848
+
849
+ async updateTier(abortController: AbortController, name: string, tier: Tier): Promise<Readonly<Tier>> {
850
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
851
+ const headers: Record<string, string> = {
852
+ 'Content-Type': 'application/json;charset=UTF-8'
853
+ };
854
+ if (!isError(csrfResponse)) {
855
+ const csrfToken = csrfResponse as CsrfTokenJson;
856
+ headers[csrfToken.header] = csrfToken.value;
857
+ }
858
+ return sendRequest({
859
+ abortController,
860
+ method: 'PUT',
861
+ payload: tier,
862
+ credentials: true,
863
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'tiers', name]),
864
+ headers
865
+ }, false);
866
+ }
867
+
868
+ async deleteTier(abortController: AbortController, name: string): Promise<SuccessResult | ErrorResult> {
869
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
870
+ const headers: Record<string, string> = {
871
+ 'Content-Type': 'application/json;charset=UTF-8'
872
+ };
873
+ if (!isError(csrfResponse)) {
874
+ const csrfToken = csrfResponse as CsrfTokenJson;
875
+ headers[csrfToken.header] = csrfToken.value;
876
+ }
877
+ return sendRequest({
878
+ abortController,
879
+ method: 'DELETE',
880
+ credentials: true,
881
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'tiers', name]),
882
+ headers
883
+ }, false);
884
+ }
885
+
886
+ async getCustomers(abortController: AbortController): Promise<Readonly<CustomerList>> {
887
+ return sendRequest({
888
+ abortController,
889
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'customers']),
890
+ credentials: true
891
+ }, false);
892
+ }
893
+
894
+ async createCustomer(abortController: AbortController, customer: Customer): Promise<Readonly<Customer>> {
895
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
896
+ const headers: Record<string, string> = {
897
+ 'Content-Type': 'application/json;charset=UTF-8'
898
+ };
899
+ if (!isError(csrfResponse)) {
900
+ const csrfToken = csrfResponse as CsrfTokenJson;
901
+ headers[csrfToken.header] = csrfToken.value;
902
+ }
903
+ return sendRequest({
904
+ abortController,
905
+ method: 'POST',
906
+ payload: customer,
907
+ credentials: true,
908
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'customers', 'create']),
909
+ headers
910
+ }, false);
911
+ }
912
+
913
+ async updateCustomer(abortController: AbortController, name: string, customer: Customer): Promise<Readonly<Customer>> {
914
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
915
+ const headers: Record<string, string> = {
916
+ 'Content-Type': 'application/json;charset=UTF-8'
917
+ };
918
+ if (!isError(csrfResponse)) {
919
+ const csrfToken = csrfResponse as CsrfTokenJson;
920
+ headers[csrfToken.header] = csrfToken.value;
921
+ }
922
+ return sendRequest({
923
+ abortController,
924
+ method: 'PUT',
925
+ payload: customer,
926
+ credentials: true,
927
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'customers', name]),
928
+ headers
929
+ }, false);
930
+ }
931
+
932
+ async deleteCustomer(abortController: AbortController, name: string): Promise<SuccessResult | ErrorResult> {
933
+ const csrfResponse = await this.registry.getCsrfToken(abortController);
934
+ const headers: Record<string, string> = {
935
+ 'Content-Type': 'application/json;charset=UTF-8'
936
+ };
937
+ if (!isError(csrfResponse)) {
938
+ const csrfToken = csrfResponse as CsrfTokenJson;
939
+ headers[csrfToken.header] = csrfToken.value;
940
+ }
941
+ return sendRequest({
942
+ abortController,
943
+ method: 'DELETE',
944
+ credentials: true,
945
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'customers', name]),
946
+ headers
947
+ }, false);
948
+ }
949
+
950
+ /**
951
+ * Get usage stats for a customer within an optional date range.
952
+ */
953
+ async getUsageStats(
954
+ abortController: AbortController,
955
+ customerName: string,
956
+ date: Date,
957
+ ): Promise<Readonly<UsageStatsList>> {
958
+ const query: { key: string, value: string | number }[] = [];
959
+ query.push({ key: 'date', value: date.toISOString() });
960
+
961
+ return sendRequest({
962
+ abortController,
963
+ endpoint: createAbsoluteURL([this.registry.serverUrl, 'admin', 'ratelimit', 'customers', customerName, 'usage'], query),
964
+ credentials: true
965
+ }, false);
966
+ }
596
967
  }
597
968
 
598
969
  export interface ExtensionFilter {
@@ -78,6 +78,8 @@ export interface Extension {
78
78
  // key: version, value: url
79
79
  allVersions: { [version: string]: UrlString };
80
80
  active?: boolean;
81
+ reviewStatus?: 'published' | 'under_review' | 'rejected';
82
+ reviewMessage?: string;
81
83
 
82
84
  averageRating?: number;
83
85
  downloadCount: number;
@@ -258,3 +260,208 @@ export interface LoginProviders {
258
260
  export type MembershipRole = 'contributor' | 'owner';
259
261
  export type SortBy = 'relevance' | 'timestamp' | 'rating' | 'downloadCount';
260
262
  export type SortOrder = 'asc' | 'desc';
263
+
264
+ // Scan and file decision types (used by admin scan UI)
265
+ export interface ScanResultJson {
266
+ id: string;
267
+ namespace: string;
268
+ extensionName: string;
269
+ version: string;
270
+ displayName: string;
271
+ publisher: string;
272
+ extensionIcon?: string;
273
+ downloadUrl?: string;
274
+ publisherUrl?: string;
275
+ status: string;
276
+ dateScanStarted: string;
277
+ dateScanEnded?: string;
278
+ errorMessage?: string;
279
+ dateQuarantined?: string;
280
+ dateRejected?: string;
281
+ threats?: Array<{
282
+ id: string;
283
+ fileName: string;
284
+ fileHash: string;
285
+ type: string;
286
+ severity?: string;
287
+ reason: string;
288
+ fileExtension: string;
289
+ dateDetected: string;
290
+ ruleName: string;
291
+ enforcedFlag?: boolean;
292
+ }>;
293
+ validationFailures?: Array<{
294
+ id: string;
295
+ type: string;
296
+ ruleName: string;
297
+ reason: string;
298
+ dateDetected: string;
299
+ enforcedFlag: boolean;
300
+ }>;
301
+ adminDecision?: {
302
+ decision: string;
303
+ decidedBy: string;
304
+ dateDecided: string;
305
+ };
306
+ }
307
+
308
+ export interface ScanCounts {
309
+ STARTED: number;
310
+ VALIDATING: number;
311
+ SCANNING: number;
312
+ PASSED: number;
313
+ QUARANTINED: number;
314
+ AUTO_REJECTED: number;
315
+ ERROR: number;
316
+ ALLOWED: number;
317
+ BLOCKED: number;
318
+ NEEDS_REVIEW: number;
319
+ }
320
+
321
+ export interface ScanResultsResponse {
322
+ success?: string;
323
+ warning?: string;
324
+ error?: string;
325
+ offset: number;
326
+ totalSize: number;
327
+ scans: ScanResultJson[];
328
+ }
329
+
330
+ export interface ScanFilterOptions {
331
+ validationTypes: string[];
332
+ threatScannerNames: string[];
333
+ }
334
+
335
+ export interface FileDecisionJson {
336
+ id: string;
337
+ fileName: string;
338
+ fileHash: string;
339
+ fileType: string;
340
+ decision: string;
341
+ decidedBy: string;
342
+ dateDecided: string;
343
+ displayName: string;
344
+ namespace: string;
345
+ extensionName: string;
346
+ publisher: string;
347
+ version: string;
348
+ scanId?: string;
349
+ }
350
+
351
+ export interface FilesResponse {
352
+ success?: string;
353
+ warning?: string;
354
+ error?: string;
355
+ offset: number;
356
+ totalSize: number;
357
+ files: FileDecisionJson[];
358
+ }
359
+
360
+ export interface FileDecisionCountsJson {
361
+ allowed: number;
362
+ blocked: number;
363
+ total: number;
364
+ }
365
+
366
+ export interface ScanDecisionRequest {
367
+ scanIds: string[];
368
+ decision: string;
369
+ }
370
+
371
+ export interface ScanDecisionResult {
372
+ scanId: string;
373
+ success: boolean;
374
+ error?: string;
375
+ }
376
+
377
+ export interface ScanDecisionResponse {
378
+ processed: number;
379
+ successful: number;
380
+ failed: number;
381
+ results: ScanDecisionResult[];
382
+ }
383
+
384
+ export interface FileDecisionRequest {
385
+ fileHashes: string[];
386
+ decision: string;
387
+ }
388
+
389
+ export interface FileDecisionResult {
390
+ fileHash: string;
391
+ success: boolean;
392
+ error?: string;
393
+ }
394
+
395
+ export interface FileDecisionResponse {
396
+ processed: number;
397
+ successful: number;
398
+ failed: number;
399
+ results: FileDecisionResult[];
400
+ }
401
+
402
+ export interface FileDecisionDeleteRequest {
403
+ fileIds: string[];
404
+ }
405
+
406
+ export interface FileDecisionDeleteResult {
407
+ fileId: string;
408
+ success: boolean;
409
+ error?: string;
410
+ }
411
+
412
+ export interface FileDecisionDeleteResponse {
413
+ processed: number;
414
+ successful: number;
415
+ failed: number;
416
+ results: FileDecisionDeleteResult[];
417
+ }
418
+
419
+ export enum TierType {
420
+ FREE = 'FREE',
421
+ SAFETY = 'SAFETY',
422
+ NON_FREE = 'NON_FREE'
423
+ }
424
+
425
+ export enum RefillStrategy {
426
+ GREEDY = 'GREEDY',
427
+ INTERVAL = 'INTERVAL'
428
+ }
429
+
430
+ export interface Tier {
431
+ name: string;
432
+ description?: string;
433
+ tierType: TierType;
434
+ capacity: number;
435
+ duration: number;
436
+ refillStrategy: RefillStrategy;
437
+ }
438
+
439
+ export interface TierList {
440
+ tiers: Tier[];
441
+ }
442
+
443
+ export enum EnforcementState {
444
+ EVALUATION = 'EVALUATION',
445
+ ENFORCEMENT = 'ENFORCEMENT'
446
+ }
447
+
448
+ export interface Customer {
449
+ name: string;
450
+ tier?: Tier;
451
+ state: EnforcementState;
452
+ cidrBlocks: string[];
453
+ }
454
+
455
+ export interface CustomerList {
456
+ customers: Customer[];
457
+ }
458
+
459
+ export interface UsageStats {
460
+ windowStart: number; // epoch seconds in UTC
461
+ duration: number; // in seconds
462
+ count: number;
463
+ }
464
+
465
+ export interface UsageStatsList {
466
+ stats: UsageStats[];
467
+ }
@@ -0,0 +1,48 @@
1
+ /********************************************************************************
2
+ * Copyright (c) 2026 Contributors to the Eclipse Foundation
3
+ *
4
+ * See the NOTICE file(s) distributed with this work for additional
5
+ * information regarding copyright ownership.
6
+ *
7
+ * This program and the accompanying materials are made available under the
8
+ * terms of the Eclipse Public License 2.0 which is available at
9
+ * https://www.eclipse.org/legal/epl-2.0
10
+ *
11
+ * SPDX-License-Identifier: EPL-2.0
12
+ ********************************************************************************/
13
+
14
+ // Core hooks
15
+ export { useTabNavigation, TAB_DEFINITIONS } from './use-tab-navigation';
16
+ export type { UseTabNavigationReturn, TabIndex, TabName } from './use-tab-navigation';
17
+
18
+ export { useScanFilters } from './use-scan-filters';
19
+ export type { UseScanFiltersReturn } from './use-scan-filters';
20
+
21
+ export { usePagination } from './use-pagination';
22
+ export type { UsePaginationReturn } from './use-pagination';
23
+
24
+ export { useSearch } from './use-search';
25
+ export type { UseSearchReturn } from './use-search';
26
+
27
+ export { useDialogs } from './use-dialogs';
28
+ export type { UseDialogsReturn } from './use-dialogs';
29
+
30
+ // Tab-specific hooks
31
+ export { useScansTab } from './use-scans-tab';
32
+ export type { UseScansTabReturn } from './use-scans-tab';
33
+
34
+ export { useQuarantinedTab } from './use-quarantined-tab';
35
+ export type { UseQuarantinedTabReturn } from './use-quarantined-tab';
36
+
37
+ export { useAutoRejectedTab } from './use-auto-rejected-tab';
38
+ export type { UseAutoRejectedTabReturn } from './use-auto-rejected-tab';
39
+
40
+ export { useFileListTab, useAllowListTab, useBlockListTab } from './use-file-list-tab';
41
+ export type { UseFileListTabReturn, UseAllowListTabReturn, UseBlockListTabReturn } from './use-file-list-tab';
42
+
43
+ // URL sync hook
44
+ export { useUrlSync } from './use-url-sync';
45
+ export type { UseUrlSyncReturn } from './use-url-sync';
46
+
47
+ // Component-specific hooks
48
+ export { useScanCardState } from './use-scan-card-state';