@qwickapps/server 1.6.0 → 1.6.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 (703) hide show
  1. package/CHANGELOG.md +64 -0
  2. package/README.md +177 -0
  3. package/dist/core/control-panel.d.ts.map +1 -1
  4. package/dist/core/control-panel.js +111 -254
  5. package/dist/core/control-panel.js.map +1 -1
  6. package/dist/core/plugin-registry.d.ts +20 -0
  7. package/dist/core/plugin-registry.d.ts.map +1 -1
  8. package/dist/core/plugin-registry.js +27 -2
  9. package/dist/core/plugin-registry.js.map +1 -1
  10. package/dist/index.d.ts +2 -2
  11. package/dist/index.d.ts.map +1 -1
  12. package/dist/index.js +4 -2
  13. package/dist/index.js.map +1 -1
  14. package/dist/plugins/api-keys/ApiKeysManagementPage.d.ts +9 -0
  15. package/dist/plugins/api-keys/ApiKeysManagementPage.d.ts.map +1 -0
  16. package/dist/plugins/api-keys/ApiKeysManagementPage.js +66 -0
  17. package/dist/plugins/api-keys/ApiKeysManagementPage.js.map +1 -0
  18. package/dist/plugins/api-keys/ApiKeysStatusWidget.d.ts +9 -0
  19. package/dist/plugins/api-keys/ApiKeysStatusWidget.d.ts.map +1 -0
  20. package/dist/plugins/api-keys/ApiKeysStatusWidget.js +30 -0
  21. package/dist/plugins/api-keys/ApiKeysStatusWidget.js.map +1 -0
  22. package/dist/plugins/api-keys/api-keys-plugin.d.ts.map +1 -1
  23. package/dist/plugins/api-keys/api-keys-plugin.js +126 -3
  24. package/dist/plugins/api-keys/api-keys-plugin.js.map +1 -1
  25. package/dist/plugins/api-keys/index.d.ts +4 -0
  26. package/dist/plugins/api-keys/index.d.ts.map +1 -1
  27. package/dist/plugins/api-keys/index.js +3 -0
  28. package/dist/plugins/api-keys/index.js.map +1 -1
  29. package/dist/plugins/api-keys/middleware/index.d.ts +1 -0
  30. package/dist/plugins/api-keys/middleware/index.d.ts.map +1 -1
  31. package/dist/plugins/api-keys/middleware/index.js +1 -0
  32. package/dist/plugins/api-keys/middleware/index.js.map +1 -1
  33. package/dist/plugins/api-keys/middleware/usage-logging.d.ts +21 -0
  34. package/dist/plugins/api-keys/middleware/usage-logging.d.ts.map +1 -0
  35. package/dist/plugins/api-keys/middleware/usage-logging.js +57 -0
  36. package/dist/plugins/api-keys/middleware/usage-logging.js.map +1 -0
  37. package/dist/plugins/api-keys/stores/index.d.ts +2 -0
  38. package/dist/plugins/api-keys/stores/index.d.ts.map +1 -1
  39. package/dist/plugins/api-keys/stores/index.js +2 -0
  40. package/dist/plugins/api-keys/stores/index.js.map +1 -1
  41. package/dist/plugins/api-keys/stores/plugin-scope-store.d.ts +81 -0
  42. package/dist/plugins/api-keys/stores/plugin-scope-store.d.ts.map +1 -0
  43. package/dist/plugins/api-keys/stores/plugin-scope-store.js +155 -0
  44. package/dist/plugins/api-keys/stores/plugin-scope-store.js.map +1 -0
  45. package/dist/plugins/api-keys/stores/usage-log-store.d.ts +119 -0
  46. package/dist/plugins/api-keys/stores/usage-log-store.d.ts.map +1 -0
  47. package/dist/plugins/api-keys/stores/usage-log-store.js +246 -0
  48. package/dist/plugins/api-keys/stores/usage-log-store.js.map +1 -0
  49. package/dist/plugins/api-keys/types.d.ts +62 -21
  50. package/dist/plugins/api-keys/types.d.ts.map +1 -1
  51. package/dist/plugins/api-keys/types.js +50 -1
  52. package/dist/plugins/api-keys/types.js.map +1 -1
  53. package/dist/plugins/auth/AuthManagementPage.d.ts +9 -0
  54. package/dist/plugins/auth/AuthManagementPage.d.ts.map +1 -0
  55. package/dist/plugins/auth/AuthManagementPage.js +73 -0
  56. package/dist/plugins/auth/AuthManagementPage.js.map +1 -0
  57. package/dist/plugins/auth/AuthStatusWidget.d.ts +9 -0
  58. package/dist/plugins/auth/AuthStatusWidget.d.ts.map +1 -0
  59. package/dist/plugins/auth/AuthStatusWidget.js +30 -0
  60. package/dist/plugins/auth/AuthStatusWidget.js.map +1 -0
  61. package/dist/plugins/auth/adapters/basic-adapter.d.ts +1 -0
  62. package/dist/plugins/auth/adapters/basic-adapter.d.ts.map +1 -1
  63. package/dist/plugins/auth/adapters/basic-adapter.js +54 -0
  64. package/dist/plugins/auth/adapters/basic-adapter.js.map +1 -1
  65. package/dist/plugins/auth/env-config.d.ts +15 -1
  66. package/dist/plugins/auth/env-config.d.ts.map +1 -1
  67. package/dist/plugins/auth/env-config.js +14 -4
  68. package/dist/plugins/auth/env-config.js.map +1 -1
  69. package/dist/plugins/auth/index.d.ts +5 -1
  70. package/dist/plugins/auth/index.d.ts.map +1 -1
  71. package/dist/plugins/auth/index.js +7 -1
  72. package/dist/plugins/auth/index.js.map +1 -1
  73. package/dist/plugins/bans/BansManagementPage.d.ts +9 -0
  74. package/dist/plugins/bans/BansManagementPage.d.ts.map +1 -0
  75. package/dist/plugins/bans/BansManagementPage.js +65 -0
  76. package/dist/plugins/bans/BansManagementPage.js.map +1 -0
  77. package/dist/plugins/bans/BansStatusWidget.d.ts +9 -0
  78. package/dist/plugins/bans/BansStatusWidget.d.ts.map +1 -0
  79. package/dist/plugins/bans/BansStatusWidget.js +30 -0
  80. package/dist/plugins/bans/BansStatusWidget.js.map +1 -0
  81. package/dist/plugins/bans/bans-plugin.js +1 -1
  82. package/dist/plugins/bans/bans-plugin.js.map +1 -1
  83. package/dist/plugins/bans/index.d.ts +4 -0
  84. package/dist/plugins/bans/index.d.ts.map +1 -1
  85. package/dist/plugins/bans/index.js +3 -0
  86. package/dist/plugins/bans/index.js.map +1 -1
  87. package/dist/plugins/cache/CacheManagementPage.d.ts +13 -0
  88. package/dist/plugins/cache/CacheManagementPage.d.ts.map +1 -0
  89. package/dist/plugins/cache/CacheManagementPage.js +175 -0
  90. package/dist/plugins/cache/CacheManagementPage.js.map +1 -0
  91. package/dist/plugins/cache/CacheStatusWidget.d.ts +13 -0
  92. package/dist/plugins/cache/CacheStatusWidget.d.ts.map +1 -0
  93. package/dist/plugins/cache/CacheStatusWidget.js +80 -0
  94. package/dist/plugins/cache/CacheStatusWidget.js.map +1 -0
  95. package/dist/plugins/cache/index.d.ts +10 -0
  96. package/dist/plugins/cache/index.d.ts.map +1 -0
  97. package/dist/plugins/cache/index.js +8 -0
  98. package/dist/plugins/cache/index.js.map +1 -0
  99. package/dist/plugins/cms/cms-plugin.d.ts +24 -0
  100. package/dist/plugins/cms/cms-plugin.d.ts.map +1 -0
  101. package/dist/plugins/cms/cms-plugin.js +220 -0
  102. package/dist/plugins/cms/cms-plugin.js.map +1 -0
  103. package/dist/plugins/cms/index.d.ts +8 -0
  104. package/dist/plugins/cms/index.d.ts.map +1 -0
  105. package/dist/plugins/cms/index.js +7 -0
  106. package/dist/plugins/cms/index.js.map +1 -0
  107. package/dist/plugins/config-plugin.js +4 -4
  108. package/dist/plugins/config-plugin.js.map +1 -1
  109. package/dist/plugins/core/index.d.ts +32 -0
  110. package/dist/plugins/core/index.d.ts.map +1 -0
  111. package/dist/plugins/core/index.js +129 -0
  112. package/dist/plugins/core/index.js.map +1 -0
  113. package/dist/plugins/devices/DevicesManagementPage.d.ts +9 -0
  114. package/dist/plugins/devices/DevicesManagementPage.d.ts.map +1 -0
  115. package/dist/plugins/devices/DevicesManagementPage.js +65 -0
  116. package/dist/plugins/devices/DevicesManagementPage.js.map +1 -0
  117. package/dist/plugins/devices/DevicesStatusWidget.d.ts +9 -0
  118. package/dist/plugins/devices/DevicesStatusWidget.d.ts.map +1 -0
  119. package/dist/plugins/devices/DevicesStatusWidget.js +30 -0
  120. package/dist/plugins/devices/DevicesStatusWidget.js.map +1 -0
  121. package/dist/plugins/devices/devices-plugin.js +1 -1
  122. package/dist/plugins/devices/devices-plugin.js.map +1 -1
  123. package/dist/plugins/devices/index.d.ts +4 -0
  124. package/dist/plugins/devices/index.d.ts.map +1 -1
  125. package/dist/plugins/devices/index.js +3 -0
  126. package/dist/plugins/devices/index.js.map +1 -1
  127. package/dist/plugins/diagnostics/DiagnosticsManagementPage.d.ts +13 -0
  128. package/dist/plugins/diagnostics/DiagnosticsManagementPage.d.ts.map +1 -0
  129. package/dist/plugins/diagnostics/DiagnosticsManagementPage.js +78 -0
  130. package/dist/plugins/diagnostics/DiagnosticsManagementPage.js.map +1 -0
  131. package/dist/plugins/diagnostics/DiagnosticsStatusWidget.d.ts +13 -0
  132. package/dist/plugins/diagnostics/DiagnosticsStatusWidget.d.ts.map +1 -0
  133. package/dist/plugins/diagnostics/DiagnosticsStatusWidget.js +87 -0
  134. package/dist/plugins/diagnostics/DiagnosticsStatusWidget.js.map +1 -0
  135. package/dist/plugins/diagnostics/index.d.ts +10 -0
  136. package/dist/plugins/diagnostics/index.d.ts.map +1 -0
  137. package/dist/plugins/diagnostics/index.js +8 -0
  138. package/dist/plugins/diagnostics/index.js.map +1 -0
  139. package/dist/plugins/diagnostics-plugin.js +4 -3
  140. package/dist/plugins/diagnostics-plugin.js.map +1 -1
  141. package/dist/plugins/entitlements/EntitlementsManagementPage.d.ts +9 -0
  142. package/dist/plugins/entitlements/EntitlementsManagementPage.d.ts.map +1 -0
  143. package/dist/plugins/entitlements/EntitlementsManagementPage.js +59 -0
  144. package/dist/plugins/entitlements/EntitlementsManagementPage.js.map +1 -0
  145. package/dist/plugins/entitlements/EntitlementsStatusWidget.d.ts +9 -0
  146. package/dist/plugins/entitlements/EntitlementsStatusWidget.d.ts.map +1 -0
  147. package/dist/plugins/entitlements/EntitlementsStatusWidget.js +30 -0
  148. package/dist/plugins/entitlements/EntitlementsStatusWidget.js.map +1 -0
  149. package/dist/plugins/entitlements/entitlements-plugin.js +1 -1
  150. package/dist/plugins/entitlements/entitlements-plugin.js.map +1 -1
  151. package/dist/plugins/entitlements/index.d.ts +4 -0
  152. package/dist/plugins/entitlements/index.d.ts.map +1 -1
  153. package/dist/plugins/entitlements/index.js +3 -0
  154. package/dist/plugins/entitlements/index.js.map +1 -1
  155. package/dist/plugins/health/HealthManagementPage.d.ts +13 -0
  156. package/dist/plugins/health/HealthManagementPage.d.ts.map +1 -0
  157. package/dist/plugins/health/HealthManagementPage.js +120 -0
  158. package/dist/plugins/health/HealthManagementPage.js.map +1 -0
  159. package/dist/plugins/health/HealthStatusWidget.d.ts +13 -0
  160. package/dist/plugins/health/HealthStatusWidget.d.ts.map +1 -0
  161. package/dist/plugins/health/HealthStatusWidget.js +80 -0
  162. package/dist/plugins/health/HealthStatusWidget.js.map +1 -0
  163. package/dist/plugins/health/index.d.ts +10 -0
  164. package/dist/plugins/health/index.d.ts.map +1 -0
  165. package/dist/plugins/health/index.js +8 -0
  166. package/dist/plugins/health/index.js.map +1 -0
  167. package/dist/plugins/index.d.ts +9 -1
  168. package/dist/plugins/index.d.ts.map +1 -1
  169. package/dist/plugins/index.js +6 -1
  170. package/dist/plugins/index.js.map +1 -1
  171. package/dist/plugins/logs/LogsManagementPage.d.ts +13 -0
  172. package/dist/plugins/logs/LogsManagementPage.d.ts.map +1 -0
  173. package/dist/plugins/logs/LogsManagementPage.js +151 -0
  174. package/dist/plugins/logs/LogsManagementPage.js.map +1 -0
  175. package/dist/plugins/logs/LogsStatusWidget.d.ts +13 -0
  176. package/dist/plugins/logs/LogsStatusWidget.d.ts.map +1 -0
  177. package/dist/plugins/logs/LogsStatusWidget.js +76 -0
  178. package/dist/plugins/logs/LogsStatusWidget.js.map +1 -0
  179. package/dist/plugins/logs/index.d.ts +10 -0
  180. package/dist/plugins/logs/index.d.ts.map +1 -0
  181. package/dist/plugins/logs/index.js +8 -0
  182. package/dist/plugins/logs/index.js.map +1 -0
  183. package/dist/plugins/logs-plugin.js +6 -6
  184. package/dist/plugins/logs-plugin.js.map +1 -1
  185. package/dist/plugins/maintenance/MaintenanceManagementPage.d.ts +13 -0
  186. package/dist/plugins/maintenance/MaintenanceManagementPage.d.ts.map +1 -0
  187. package/dist/plugins/maintenance/MaintenanceManagementPage.js +40 -0
  188. package/dist/plugins/maintenance/MaintenanceManagementPage.js.map +1 -0
  189. package/dist/plugins/maintenance/MaintenanceStatusWidget.d.ts +13 -0
  190. package/dist/plugins/maintenance/MaintenanceStatusWidget.d.ts.map +1 -0
  191. package/dist/plugins/maintenance/MaintenanceStatusWidget.js +76 -0
  192. package/dist/plugins/maintenance/MaintenanceStatusWidget.js.map +1 -0
  193. package/dist/plugins/maintenance/SeedExecutor.d.ts +17 -0
  194. package/dist/plugins/maintenance/SeedExecutor.d.ts.map +1 -0
  195. package/dist/plugins/maintenance/SeedExecutor.js +154 -0
  196. package/dist/plugins/maintenance/SeedExecutor.js.map +1 -0
  197. package/dist/plugins/maintenance/SeedHistory.d.ts +14 -0
  198. package/dist/plugins/maintenance/SeedHistory.d.ts.map +1 -0
  199. package/dist/plugins/maintenance/SeedHistory.js +183 -0
  200. package/dist/plugins/maintenance/SeedHistory.js.map +1 -0
  201. package/dist/plugins/maintenance/SeedList.d.ts +15 -0
  202. package/dist/plugins/maintenance/SeedList.d.ts.map +1 -0
  203. package/dist/plugins/maintenance/SeedList.js +68 -0
  204. package/dist/plugins/maintenance/SeedList.js.map +1 -0
  205. package/dist/plugins/maintenance/SeedManagementPage.d.ts +14 -0
  206. package/dist/plugins/maintenance/SeedManagementPage.d.ts.map +1 -0
  207. package/dist/plugins/maintenance/SeedManagementPage.js +42 -0
  208. package/dist/plugins/maintenance/SeedManagementPage.js.map +1 -0
  209. package/dist/plugins/maintenance/index.d.ts +20 -0
  210. package/dist/plugins/maintenance/index.d.ts.map +1 -0
  211. package/dist/plugins/maintenance/index.js +15 -0
  212. package/dist/plugins/maintenance/index.js.map +1 -0
  213. package/dist/plugins/maintenance/seed-executor.d.ts +55 -0
  214. package/dist/plugins/maintenance/seed-executor.d.ts.map +1 -0
  215. package/dist/plugins/maintenance/seed-executor.js +178 -0
  216. package/dist/plugins/maintenance/seed-executor.js.map +1 -0
  217. package/dist/plugins/maintenance-plugin.d.ts +35 -0
  218. package/dist/plugins/maintenance-plugin.d.ts.map +1 -0
  219. package/dist/plugins/maintenance-plugin.js +321 -0
  220. package/dist/plugins/maintenance-plugin.js.map +1 -0
  221. package/dist/plugins/notifications/NotificationsManagementPage.d.ts +13 -0
  222. package/dist/plugins/notifications/NotificationsManagementPage.d.ts.map +1 -0
  223. package/dist/plugins/notifications/NotificationsManagementPage.js +59 -0
  224. package/dist/plugins/notifications/NotificationsManagementPage.js.map +1 -0
  225. package/dist/plugins/notifications/NotificationsStatusWidget.d.ts +9 -0
  226. package/dist/plugins/notifications/NotificationsStatusWidget.d.ts.map +1 -0
  227. package/dist/plugins/notifications/NotificationsStatusWidget.js +30 -0
  228. package/dist/plugins/notifications/NotificationsStatusWidget.js.map +1 -0
  229. package/dist/plugins/notifications/index.d.ts +4 -0
  230. package/dist/plugins/notifications/index.d.ts.map +1 -1
  231. package/dist/plugins/notifications/index.js +3 -0
  232. package/dist/plugins/notifications/index.js.map +1 -1
  233. package/dist/plugins/notifications/notifications-plugin.js +1 -1
  234. package/dist/plugins/notifications/notifications-plugin.js.map +1 -1
  235. package/dist/plugins/parental/ParentalManagementPage.d.ts +9 -0
  236. package/dist/plugins/parental/ParentalManagementPage.d.ts.map +1 -0
  237. package/dist/plugins/parental/ParentalManagementPage.js +56 -0
  238. package/dist/plugins/parental/ParentalManagementPage.js.map +1 -0
  239. package/dist/plugins/parental/ParentalStatusWidget.d.ts +9 -0
  240. package/dist/plugins/parental/ParentalStatusWidget.d.ts.map +1 -0
  241. package/dist/plugins/parental/ParentalStatusWidget.js +30 -0
  242. package/dist/plugins/parental/ParentalStatusWidget.js.map +1 -0
  243. package/dist/plugins/parental/index.d.ts +4 -0
  244. package/dist/plugins/parental/index.d.ts.map +1 -1
  245. package/dist/plugins/parental/index.js +3 -0
  246. package/dist/plugins/parental/index.js.map +1 -1
  247. package/dist/plugins/parental/parental-plugin.js +1 -1
  248. package/dist/plugins/parental/parental-plugin.js.map +1 -1
  249. package/dist/plugins/postgres/PostgresManagementPage.d.ts +13 -0
  250. package/dist/plugins/postgres/PostgresManagementPage.d.ts.map +1 -0
  251. package/dist/plugins/postgres/PostgresManagementPage.js +139 -0
  252. package/dist/plugins/postgres/PostgresManagementPage.js.map +1 -0
  253. package/dist/plugins/postgres/PostgresStatusWidget.d.ts +13 -0
  254. package/dist/plugins/postgres/PostgresStatusWidget.d.ts.map +1 -0
  255. package/dist/plugins/postgres/PostgresStatusWidget.js +87 -0
  256. package/dist/plugins/postgres/PostgresStatusWidget.js.map +1 -0
  257. package/dist/plugins/postgres/index.d.ts +10 -0
  258. package/dist/plugins/postgres/index.d.ts.map +1 -0
  259. package/dist/plugins/postgres/index.js +8 -0
  260. package/dist/plugins/postgres/index.js.map +1 -0
  261. package/dist/plugins/preferences/PreferencesManagementPage.d.ts +9 -0
  262. package/dist/plugins/preferences/PreferencesManagementPage.d.ts.map +1 -0
  263. package/dist/plugins/preferences/PreferencesManagementPage.js +67 -0
  264. package/dist/plugins/preferences/PreferencesManagementPage.js.map +1 -0
  265. package/dist/plugins/preferences/PreferencesStatusWidget.d.ts +9 -0
  266. package/dist/plugins/preferences/PreferencesStatusWidget.d.ts.map +1 -0
  267. package/dist/plugins/preferences/PreferencesStatusWidget.js +30 -0
  268. package/dist/plugins/preferences/PreferencesStatusWidget.js.map +1 -0
  269. package/dist/plugins/preferences/index.d.ts +4 -0
  270. package/dist/plugins/preferences/index.d.ts.map +1 -1
  271. package/dist/plugins/preferences/index.js +3 -0
  272. package/dist/plugins/preferences/index.js.map +1 -1
  273. package/dist/plugins/preferences/preferences-plugin.d.ts.map +1 -1
  274. package/dist/plugins/preferences/preferences-plugin.js +9 -4
  275. package/dist/plugins/preferences/preferences-plugin.js.map +1 -1
  276. package/dist/plugins/preferences/types.d.ts +5 -0
  277. package/dist/plugins/preferences/types.d.ts.map +1 -1
  278. package/dist/plugins/preferences/types.js +5 -1
  279. package/dist/plugins/preferences/types.js.map +1 -1
  280. package/dist/plugins/profiles/ProfilesManagementPage.d.ts +9 -0
  281. package/dist/plugins/profiles/ProfilesManagementPage.d.ts.map +1 -0
  282. package/dist/plugins/profiles/ProfilesManagementPage.js +51 -0
  283. package/dist/plugins/profiles/ProfilesManagementPage.js.map +1 -0
  284. package/dist/plugins/profiles/ProfilesStatusWidget.d.ts +9 -0
  285. package/dist/plugins/profiles/ProfilesStatusWidget.d.ts.map +1 -0
  286. package/dist/plugins/profiles/ProfilesStatusWidget.js +30 -0
  287. package/dist/plugins/profiles/ProfilesStatusWidget.js.map +1 -0
  288. package/dist/plugins/profiles/index.d.ts +4 -0
  289. package/dist/plugins/profiles/index.d.ts.map +1 -1
  290. package/dist/plugins/profiles/index.js +3 -0
  291. package/dist/plugins/profiles/index.js.map +1 -1
  292. package/dist/plugins/profiles/profiles-plugin.js +1 -1
  293. package/dist/plugins/profiles/profiles-plugin.js.map +1 -1
  294. package/dist/plugins/qwickbrain/QwickbrainManagementPage.d.ts +13 -0
  295. package/dist/plugins/qwickbrain/QwickbrainManagementPage.d.ts.map +1 -0
  296. package/dist/plugins/qwickbrain/QwickbrainManagementPage.js +59 -0
  297. package/dist/plugins/qwickbrain/QwickbrainManagementPage.js.map +1 -0
  298. package/dist/plugins/qwickbrain/QwickbrainStatusWidget.d.ts +9 -0
  299. package/dist/plugins/qwickbrain/QwickbrainStatusWidget.d.ts.map +1 -0
  300. package/dist/plugins/qwickbrain/QwickbrainStatusWidget.js +30 -0
  301. package/dist/plugins/qwickbrain/QwickbrainStatusWidget.js.map +1 -0
  302. package/dist/plugins/qwickbrain/index.d.ts +4 -0
  303. package/dist/plugins/qwickbrain/index.d.ts.map +1 -1
  304. package/dist/plugins/qwickbrain/index.js +3 -0
  305. package/dist/plugins/qwickbrain/index.js.map +1 -1
  306. package/dist/plugins/qwickbrain/qwickbrain-plugin.d.ts.map +1 -1
  307. package/dist/plugins/qwickbrain/qwickbrain-plugin.js +12 -34
  308. package/dist/plugins/qwickbrain/qwickbrain-plugin.js.map +1 -1
  309. package/dist/plugins/qwickbrain/types.d.ts +0 -1
  310. package/dist/plugins/qwickbrain/types.d.ts.map +1 -1
  311. package/dist/plugins/rate-limit/RateLimitManagementPage.d.ts +13 -0
  312. package/dist/plugins/rate-limit/RateLimitManagementPage.d.ts.map +1 -0
  313. package/dist/plugins/rate-limit/RateLimitManagementPage.js +60 -0
  314. package/dist/plugins/rate-limit/RateLimitManagementPage.js.map +1 -0
  315. package/dist/plugins/rate-limit/RateLimitStatusWidget.d.ts +9 -0
  316. package/dist/plugins/rate-limit/RateLimitStatusWidget.d.ts.map +1 -0
  317. package/dist/plugins/rate-limit/RateLimitStatusWidget.js +30 -0
  318. package/dist/plugins/rate-limit/RateLimitStatusWidget.js.map +1 -0
  319. package/dist/plugins/rate-limit/index.d.ts +4 -0
  320. package/dist/plugins/rate-limit/index.d.ts.map +1 -1
  321. package/dist/plugins/rate-limit/index.js +3 -0
  322. package/dist/plugins/rate-limit/index.js.map +1 -1
  323. package/dist/plugins/rate-limit/rate-limit-plugin.js +5 -5
  324. package/dist/plugins/rate-limit/rate-limit-plugin.js.map +1 -1
  325. package/dist/plugins/subscriptions/SubscriptionsManagementPage.d.ts +9 -0
  326. package/dist/plugins/subscriptions/SubscriptionsManagementPage.d.ts.map +1 -0
  327. package/dist/plugins/subscriptions/SubscriptionsManagementPage.js +66 -0
  328. package/dist/plugins/subscriptions/SubscriptionsManagementPage.js.map +1 -0
  329. package/dist/plugins/subscriptions/SubscriptionsStatusWidget.d.ts +9 -0
  330. package/dist/plugins/subscriptions/SubscriptionsStatusWidget.d.ts.map +1 -0
  331. package/dist/plugins/subscriptions/SubscriptionsStatusWidget.js +30 -0
  332. package/dist/plugins/subscriptions/SubscriptionsStatusWidget.js.map +1 -0
  333. package/dist/plugins/subscriptions/index.d.ts +4 -0
  334. package/dist/plugins/subscriptions/index.d.ts.map +1 -1
  335. package/dist/plugins/subscriptions/index.js +3 -0
  336. package/dist/plugins/subscriptions/index.js.map +1 -1
  337. package/dist/plugins/subscriptions/subscriptions-plugin.js +1 -1
  338. package/dist/plugins/subscriptions/subscriptions-plugin.js.map +1 -1
  339. package/dist/plugins/usage/UsageManagementPage.d.ts +9 -0
  340. package/dist/plugins/usage/UsageManagementPage.d.ts.map +1 -0
  341. package/dist/plugins/usage/UsageManagementPage.js +42 -0
  342. package/dist/plugins/usage/UsageManagementPage.js.map +1 -0
  343. package/dist/plugins/usage/UsageStatusWidget.d.ts +9 -0
  344. package/dist/plugins/usage/UsageStatusWidget.d.ts.map +1 -0
  345. package/dist/plugins/usage/UsageStatusWidget.js +30 -0
  346. package/dist/plugins/usage/UsageStatusWidget.js.map +1 -0
  347. package/dist/plugins/usage/index.d.ts +4 -0
  348. package/dist/plugins/usage/index.d.ts.map +1 -1
  349. package/dist/plugins/usage/index.js +3 -0
  350. package/dist/plugins/usage/index.js.map +1 -1
  351. package/dist/plugins/usage/usage-plugin.js +1 -1
  352. package/dist/plugins/usage/usage-plugin.js.map +1 -1
  353. package/dist/plugins/users/UsersManagementPage.d.ts +13 -0
  354. package/dist/plugins/users/UsersManagementPage.d.ts.map +1 -0
  355. package/dist/plugins/users/UsersManagementPage.js +199 -0
  356. package/dist/plugins/users/UsersManagementPage.js.map +1 -0
  357. package/dist/plugins/users/UsersStatusWidget.d.ts +13 -0
  358. package/dist/plugins/users/UsersStatusWidget.d.ts.map +1 -0
  359. package/dist/plugins/users/UsersStatusWidget.js +79 -0
  360. package/dist/plugins/users/UsersStatusWidget.js.map +1 -0
  361. package/dist/plugins/users/stores/postgres-store.d.ts.map +1 -1
  362. package/dist/plugins/users/stores/postgres-store.js +52 -55
  363. package/dist/plugins/users/stores/postgres-store.js.map +1 -1
  364. package/dist/plugins/users/types.d.ts +8 -1
  365. package/dist/plugins/users/types.d.ts.map +1 -1
  366. package/dist/plugins/users/users-plugin.d.ts.map +1 -1
  367. package/dist/plugins/users/users-plugin.js +118 -3
  368. package/dist/plugins/users/users-plugin.js.map +1 -1
  369. package/dist-ui/assets/index-BiEHWqD3.js +528 -0
  370. package/dist-ui/assets/index-BiEHWqD3.js.map +1 -0
  371. package/dist-ui/index.html +1 -1
  372. package/dist-ui-lib/index.js +3693 -3126
  373. package/dist-ui-lib/index.js.map +1 -1
  374. package/dist-ui-lib/src/api/clientBuilder.d.ts +33 -0
  375. package/dist-ui-lib/{api → src/api}/controlPanelApi.d.ts +65 -3
  376. package/dist-ui-lib/src/api/index.d.ts +11 -0
  377. package/dist-ui-lib/src/api/types.d.ts +313 -0
  378. package/dist-ui-lib/{components → src/components}/ControlPanelApp.d.ts +2 -1
  379. package/dist-ui-lib/src/components/auth/AcceptInvitationPage.d.ts +21 -0
  380. package/dist-ui-lib/src/components/auth/LoginPage.d.ts +27 -0
  381. package/dist-ui-lib/src/components/auth/PasswordResetConfirmPage.d.ts +17 -0
  382. package/dist-ui-lib/src/components/auth/PasswordResetPage.d.ts +12 -0
  383. package/dist-ui-lib/src/components/auth/SignupPage.d.ts +27 -0
  384. package/dist-ui-lib/src/components/auth/VerifyEmailPage.d.ts +12 -0
  385. package/dist-ui-lib/src/components/auth/index.d.ts +19 -0
  386. package/dist-ui-lib/src/components/auth/shared/AuthError.d.ts +9 -0
  387. package/dist-ui-lib/src/components/auth/shared/AuthLayout.d.ts +11 -0
  388. package/dist-ui-lib/src/components/auth/shared/index.d.ts +7 -0
  389. package/dist-ui-lib/{components → src/components}/index.d.ts +3 -1
  390. package/dist-ui-lib/src/components/plugins/PluginConfigPanel.d.ts +65 -0
  391. package/dist-ui-lib/src/components/plugins/PluginManagementPage.d.ts +62 -0
  392. package/dist-ui-lib/src/components/plugins/PluginStatusWidget.d.ts +51 -0
  393. package/dist-ui-lib/src/components/plugins/index.d.ts +13 -0
  394. package/dist-ui-lib/src/config/preferences.d.ts +16 -0
  395. package/dist-ui-lib/src/dashboard/widgets/CMSMaintenanceWidget.d.ts +8 -0
  396. package/dist-ui-lib/src/dashboard/widgets/CMSStatusWidget.d.ts +8 -0
  397. package/dist-ui-lib/{dashboard → src/dashboard}/widgets/index.d.ts +2 -0
  398. package/dist-ui-lib/src/hooks/useJobStream.d.ts +38 -0
  399. package/dist-ui-lib/src/pages/PreferencesPage.d.ts +9 -0
  400. package/package.json +10 -4
  401. package/src/core/control-panel.ts +134 -279
  402. package/src/core/plugin-registry.ts +52 -3
  403. package/src/index.ts +27 -0
  404. package/src/plugins/api-keys/API_ROUTES.md +165 -0
  405. package/src/plugins/api-keys/ApiKeysManagementPage.test.tsx +58 -0
  406. package/src/plugins/api-keys/ApiKeysManagementPage.tsx +131 -0
  407. package/src/plugins/api-keys/ApiKeysStatusWidget.test.tsx +112 -0
  408. package/src/plugins/api-keys/ApiKeysStatusWidget.tsx +53 -0
  409. package/src/plugins/api-keys/api-keys-plugin.ts +139 -3
  410. package/src/plugins/api-keys/index.ts +6 -0
  411. package/src/plugins/api-keys/middleware/index.ts +3 -0
  412. package/src/plugins/api-keys/middleware/usage-logging.ts +78 -0
  413. package/src/plugins/api-keys/stores/index.ts +14 -0
  414. package/src/plugins/api-keys/stores/plugin-scope-store.ts +280 -0
  415. package/src/plugins/api-keys/stores/usage-log-store.ts +423 -0
  416. package/src/plugins/api-keys/types.ts +66 -2
  417. package/src/plugins/auth/API_ROUTES.md +110 -0
  418. package/src/plugins/auth/AuthManagementPage.test.tsx +58 -0
  419. package/src/plugins/auth/AuthManagementPage.tsx +170 -0
  420. package/src/plugins/auth/AuthStatusWidget.test.tsx +112 -0
  421. package/src/plugins/auth/AuthStatusWidget.tsx +53 -0
  422. package/src/plugins/auth/adapters/basic-adapter.ts +62 -0
  423. package/src/plugins/auth/env-config.ts +14 -4
  424. package/src/plugins/auth/index.ts +9 -0
  425. package/src/plugins/bans/API_ROUTES.md +183 -0
  426. package/src/plugins/bans/BansManagementPage.test.tsx +58 -0
  427. package/src/plugins/bans/BansManagementPage.tsx +129 -0
  428. package/src/plugins/bans/BansStatusWidget.test.tsx +112 -0
  429. package/src/plugins/bans/BansStatusWidget.tsx +53 -0
  430. package/src/plugins/bans/bans-plugin.ts +1 -1
  431. package/src/plugins/bans/index.ts +6 -0
  432. package/src/plugins/cache/API_ROUTES.md +312 -0
  433. package/src/plugins/cache/CacheManagementPage.test.tsx +57 -0
  434. package/src/plugins/cache/CacheManagementPage.tsx +360 -0
  435. package/src/plugins/cache/CacheStatusWidget.test.tsx +113 -0
  436. package/src/plugins/cache/CacheStatusWidget.tsx +122 -0
  437. package/src/plugins/cache/index.ts +10 -0
  438. package/src/plugins/cms/cms-plugin.ts +259 -0
  439. package/src/plugins/cms/index.ts +8 -0
  440. package/src/plugins/config-plugin.ts +4 -4
  441. package/src/plugins/core/index.ts +164 -0
  442. package/src/plugins/devices/API_ROUTES.md +27 -0
  443. package/src/plugins/devices/DevicesManagementPage.test.tsx +58 -0
  444. package/src/plugins/devices/DevicesManagementPage.tsx +124 -0
  445. package/src/plugins/devices/DevicesStatusWidget.test.tsx +109 -0
  446. package/src/plugins/devices/DevicesStatusWidget.tsx +52 -0
  447. package/src/plugins/devices/devices-plugin.ts +1 -1
  448. package/src/plugins/devices/index.ts +6 -0
  449. package/src/plugins/diagnostics/API_ROUTES.md +316 -0
  450. package/src/plugins/diagnostics/DiagnosticsManagementPage.test.tsx +58 -0
  451. package/src/plugins/diagnostics/DiagnosticsManagementPage.tsx +306 -0
  452. package/src/plugins/diagnostics/DiagnosticsStatusWidget.test.tsx +112 -0
  453. package/src/plugins/diagnostics/DiagnosticsStatusWidget.tsx +129 -0
  454. package/src/plugins/diagnostics/index.ts +10 -0
  455. package/src/plugins/diagnostics-plugin.ts +3 -3
  456. package/src/plugins/entitlements/API_ROUTES.md +27 -0
  457. package/src/plugins/entitlements/EntitlementsManagementPage.test.tsx +58 -0
  458. package/src/plugins/entitlements/EntitlementsManagementPage.tsx +113 -0
  459. package/src/plugins/entitlements/EntitlementsStatusWidget.test.tsx +109 -0
  460. package/src/plugins/entitlements/EntitlementsStatusWidget.tsx +52 -0
  461. package/src/plugins/entitlements/entitlements-plugin.ts +1 -1
  462. package/src/plugins/entitlements/index.ts +6 -0
  463. package/src/plugins/health/API_ROUTES.md +283 -0
  464. package/src/plugins/health/HealthManagementPage.test.tsx +57 -0
  465. package/src/plugins/health/HealthManagementPage.tsx +320 -0
  466. package/src/plugins/health/HealthStatusWidget.test.tsx +107 -0
  467. package/src/plugins/health/HealthStatusWidget.tsx +134 -0
  468. package/src/plugins/health/index.ts +10 -0
  469. package/src/plugins/index.ts +49 -0
  470. package/src/plugins/logs/API_ROUTES.md +297 -0
  471. package/src/plugins/logs/LogsManagementPage.test.tsx +58 -0
  472. package/src/plugins/logs/LogsManagementPage.tsx +283 -0
  473. package/src/plugins/logs/LogsStatusWidget.test.tsx +119 -0
  474. package/src/plugins/logs/LogsStatusWidget.tsx +123 -0
  475. package/src/plugins/logs/index.ts +10 -0
  476. package/src/plugins/logs-plugin.ts +6 -6
  477. package/src/plugins/maintenance/MaintenanceManagementPage.tsx +193 -0
  478. package/src/plugins/maintenance/MaintenanceStatusWidget.tsx +120 -0
  479. package/src/plugins/maintenance/SeedExecutor.tsx +236 -0
  480. package/src/plugins/maintenance/SeedHistory.tsx +360 -0
  481. package/src/plugins/maintenance/SeedList.tsx +130 -0
  482. package/src/plugins/maintenance/SeedManagementPage.tsx +91 -0
  483. package/src/plugins/maintenance/index.ts +24 -0
  484. package/src/plugins/maintenance/seed-executor.ts +224 -0
  485. package/src/plugins/maintenance-plugin.ts +409 -0
  486. package/src/plugins/notifications/NotificationsManagementPage.test.tsx +58 -0
  487. package/src/plugins/notifications/NotificationsManagementPage.tsx +128 -0
  488. package/src/plugins/notifications/NotificationsStatusWidget.test.tsx +109 -0
  489. package/src/plugins/notifications/NotificationsStatusWidget.tsx +52 -0
  490. package/src/plugins/notifications/index.ts +6 -0
  491. package/src/plugins/notifications/notifications-plugin.ts +1 -1
  492. package/src/plugins/parental/API_ROUTES.md +30 -0
  493. package/src/plugins/parental/ParentalManagementPage.test.tsx +58 -0
  494. package/src/plugins/parental/ParentalManagementPage.tsx +119 -0
  495. package/src/plugins/parental/ParentalStatusWidget.test.tsx +109 -0
  496. package/src/plugins/parental/ParentalStatusWidget.tsx +52 -0
  497. package/src/plugins/parental/index.ts +6 -0
  498. package/src/plugins/parental/parental-plugin.ts +1 -1
  499. package/src/plugins/postgres/API_ROUTES.md +243 -0
  500. package/src/plugins/postgres/PostgresManagementPage.test.tsx +62 -0
  501. package/src/plugins/postgres/PostgresManagementPage.tsx +362 -0
  502. package/src/plugins/postgres/PostgresStatusWidget.test.tsx +117 -0
  503. package/src/plugins/postgres/PostgresStatusWidget.tsx +131 -0
  504. package/src/plugins/postgres/index.ts +10 -0
  505. package/src/plugins/preferences/API_ROUTES.md +162 -0
  506. package/src/plugins/preferences/PreferencesManagementPage.test.tsx +58 -0
  507. package/src/plugins/preferences/PreferencesManagementPage.tsx +139 -0
  508. package/src/plugins/preferences/PreferencesStatusWidget.test.tsx +109 -0
  509. package/src/plugins/preferences/PreferencesStatusWidget.tsx +52 -0
  510. package/src/plugins/preferences/index.ts +6 -0
  511. package/src/plugins/preferences/preferences-plugin.ts +10 -5
  512. package/src/plugins/preferences/types.d.ts +95 -0
  513. package/src/plugins/preferences/types.ts +6 -0
  514. package/src/plugins/profiles/API_ROUTES.md +27 -0
  515. package/src/plugins/profiles/ProfilesManagementPage.test.tsx +58 -0
  516. package/src/plugins/profiles/ProfilesManagementPage.tsx +113 -0
  517. package/src/plugins/profiles/ProfilesStatusWidget.test.tsx +109 -0
  518. package/src/plugins/profiles/ProfilesStatusWidget.tsx +52 -0
  519. package/src/plugins/profiles/index.ts +6 -0
  520. package/src/plugins/profiles/profiles-plugin.ts +1 -1
  521. package/src/plugins/qwickbrain/QwickbrainManagementPage.test.tsx +58 -0
  522. package/src/plugins/qwickbrain/QwickbrainManagementPage.tsx +126 -0
  523. package/src/plugins/qwickbrain/QwickbrainStatusWidget.test.tsx +109 -0
  524. package/src/plugins/qwickbrain/QwickbrainStatusWidget.tsx +52 -0
  525. package/src/plugins/qwickbrain/index.ts +6 -0
  526. package/src/plugins/qwickbrain/qwickbrain-plugin.ts +12 -36
  527. package/src/plugins/qwickbrain/types.ts +0 -1
  528. package/src/plugins/rate-limit/RateLimitManagementPage.test.tsx +58 -0
  529. package/src/plugins/rate-limit/RateLimitManagementPage.tsx +127 -0
  530. package/src/plugins/rate-limit/RateLimitStatusWidget.test.tsx +109 -0
  531. package/src/plugins/rate-limit/RateLimitStatusWidget.tsx +52 -0
  532. package/src/plugins/rate-limit/index.ts +6 -0
  533. package/src/plugins/rate-limit/rate-limit-plugin.ts +5 -5
  534. package/src/plugins/subscriptions/API_ROUTES.md +27 -0
  535. package/src/plugins/subscriptions/SubscriptionsManagementPage.test.tsx +58 -0
  536. package/src/plugins/subscriptions/SubscriptionsManagementPage.tsx +125 -0
  537. package/src/plugins/subscriptions/SubscriptionsStatusWidget.test.tsx +109 -0
  538. package/src/plugins/subscriptions/SubscriptionsStatusWidget.tsx +52 -0
  539. package/src/plugins/subscriptions/index.ts +6 -0
  540. package/src/plugins/subscriptions/subscriptions-plugin.ts +1 -1
  541. package/src/plugins/usage/API_ROUTES.md +24 -0
  542. package/src/plugins/usage/UsageManagementPage.test.tsx +58 -0
  543. package/src/plugins/usage/UsageManagementPage.tsx +93 -0
  544. package/src/plugins/usage/UsageStatusWidget.test.tsx +109 -0
  545. package/src/plugins/usage/UsageStatusWidget.tsx +52 -0
  546. package/src/plugins/usage/index.ts +6 -0
  547. package/src/plugins/usage/usage-plugin.ts +1 -1
  548. package/src/plugins/users/API_ROUTES.md +311 -0
  549. package/src/plugins/users/UsersManagementPage.test.tsx +58 -0
  550. package/src/plugins/users/UsersManagementPage.tsx +384 -0
  551. package/src/plugins/users/UsersStatusWidget.test.tsx +114 -0
  552. package/src/plugins/users/UsersStatusWidget.tsx +120 -0
  553. package/src/plugins/users/__tests__/users-plugin.test.ts +19 -18
  554. package/src/plugins/users/stores/postgres-store.ts +64 -55
  555. package/src/plugins/users/types.ts +8 -1
  556. package/src/plugins/users/users-plugin.ts +137 -3
  557. package/ui/src/App.tsx +13 -4
  558. package/ui/src/api/clientBuilder.ts +206 -0
  559. package/ui/src/api/controlPanelApi.ts +199 -169
  560. package/ui/src/api/index.ts +12 -0
  561. package/ui/src/api/types.ts +276 -0
  562. package/ui/src/components/ControlPanelApp.tsx +4 -5
  563. package/ui/src/components/auth/AcceptInvitationPage.tsx +151 -0
  564. package/ui/src/components/auth/LoginPage.tsx +122 -0
  565. package/ui/src/components/auth/PasswordResetConfirmPage.tsx +109 -0
  566. package/ui/src/components/auth/PasswordResetPage.tsx +95 -0
  567. package/ui/src/components/auth/SignupPage.tsx +140 -0
  568. package/ui/src/components/auth/VerifyEmailPage.tsx +38 -0
  569. package/ui/src/components/auth/__tests__/AcceptInvitationPage.test.tsx +201 -0
  570. package/ui/src/components/auth/__tests__/LoginPage.test.tsx +207 -0
  571. package/ui/src/components/auth/__tests__/PasswordResetConfirmPage.test.tsx +183 -0
  572. package/ui/src/components/auth/__tests__/PasswordResetPage.test.tsx +174 -0
  573. package/ui/src/components/auth/__tests__/SignupPage.test.tsx +210 -0
  574. package/ui/src/components/auth/__tests__/VerifyEmailPage.test.tsx +53 -0
  575. package/ui/src/components/auth/index.ts +26 -0
  576. package/ui/src/components/auth/shared/AuthError.tsx +28 -0
  577. package/ui/src/components/auth/shared/AuthLayout.tsx +42 -0
  578. package/ui/src/components/auth/shared/index.ts +9 -0
  579. package/ui/src/components/index.ts +15 -2
  580. package/ui/src/components/plugins/PluginConfigPanel.tsx +315 -0
  581. package/ui/src/components/plugins/PluginManagementPage.tsx +218 -0
  582. package/ui/src/components/plugins/PluginStatusWidget.tsx +158 -0
  583. package/ui/src/components/plugins/index.ts +20 -0
  584. package/ui/src/config/preferences.ts +18 -0
  585. package/ui/src/dashboard/builtInWidgets.tsx +15 -1
  586. package/ui/src/dashboard/widgets/CMSMaintenanceWidget.tsx +229 -0
  587. package/ui/src/dashboard/widgets/CMSStatusWidget.tsx +115 -0
  588. package/ui/src/dashboard/widgets/NotificationsStatsWidget.tsx +1 -1
  589. package/ui/src/dashboard/widgets/index.ts +2 -0
  590. package/ui/src/hooks/useJobStream.ts +194 -0
  591. package/ui/src/pages/APIKeysPage.tsx +262 -74
  592. package/ui/src/pages/ContentOpsJobsPage.tsx +422 -0
  593. package/ui/src/pages/MaintenancePage.tsx +27 -0
  594. package/ui/src/pages/NotificationsPage.tsx +1 -1
  595. package/ui/src/pages/PluginPage.tsx +3 -1
  596. package/ui/src/pages/PreferencesPage.tsx +240 -0
  597. package/ui/src/pages/__tests__/PreferencesPage.test.tsx +273 -0
  598. package/ui/src/pages/index.ts +15 -0
  599. package/ui/tsconfig.lib.json +4 -2
  600. package/dist/plugins/auth/adapter-wrapper.test.d.ts +0 -7
  601. package/dist/plugins/auth/adapter-wrapper.test.d.ts.map +0 -1
  602. package/dist/plugins/auth/adapter-wrapper.test.js +0 -303
  603. package/dist/plugins/auth/adapter-wrapper.test.js.map +0 -1
  604. package/dist/plugins/auth/auth-plugin.test.d.ts +0 -9
  605. package/dist/plugins/auth/auth-plugin.test.d.ts.map +0 -1
  606. package/dist/plugins/auth/auth-plugin.test.js +0 -280
  607. package/dist/plugins/auth/auth-plugin.test.js.map +0 -1
  608. package/dist/plugins/auth/config-store.test.d.ts +0 -7
  609. package/dist/plugins/auth/config-store.test.d.ts.map +0 -1
  610. package/dist/plugins/auth/config-store.test.js +0 -299
  611. package/dist/plugins/auth/config-store.test.js.map +0 -1
  612. package/dist/plugins/auth/supertokens-adapter.test.d.ts +0 -10
  613. package/dist/plugins/auth/supertokens-adapter.test.d.ts.map +0 -1
  614. package/dist/plugins/auth/supertokens-adapter.test.js +0 -486
  615. package/dist/plugins/auth/supertokens-adapter.test.js.map +0 -1
  616. package/dist/plugins/cache-plugin.test.d.ts +0 -8
  617. package/dist/plugins/cache-plugin.test.d.ts.map +0 -1
  618. package/dist/plugins/cache-plugin.test.js +0 -255
  619. package/dist/plugins/cache-plugin.test.js.map +0 -1
  620. package/dist/plugins/devices/__tests__/devices-plugin.test.d.ts +0 -11
  621. package/dist/plugins/devices/__tests__/devices-plugin.test.d.ts.map +0 -1
  622. package/dist/plugins/devices/__tests__/devices-plugin.test.js +0 -410
  623. package/dist/plugins/devices/__tests__/devices-plugin.test.js.map +0 -1
  624. package/dist/plugins/devices/__tests__/token-utils.test.d.ts +0 -7
  625. package/dist/plugins/devices/__tests__/token-utils.test.d.ts.map +0 -1
  626. package/dist/plugins/devices/__tests__/token-utils.test.js +0 -199
  627. package/dist/plugins/devices/__tests__/token-utils.test.js.map +0 -1
  628. package/dist/plugins/notifications/__tests__/notifications-manager.test.d.ts +0 -5
  629. package/dist/plugins/notifications/__tests__/notifications-manager.test.d.ts.map +0 -1
  630. package/dist/plugins/notifications/__tests__/notifications-manager.test.js +0 -470
  631. package/dist/plugins/notifications/__tests__/notifications-manager.test.js.map +0 -1
  632. package/dist/plugins/parental/__tests__/parental-plugin.test.d.ts +0 -12
  633. package/dist/plugins/parental/__tests__/parental-plugin.test.d.ts.map +0 -1
  634. package/dist/plugins/parental/__tests__/parental-plugin.test.js +0 -349
  635. package/dist/plugins/parental/__tests__/parental-plugin.test.js.map +0 -1
  636. package/dist/plugins/postgres-plugin.test.d.ts +0 -8
  637. package/dist/plugins/postgres-plugin.test.d.ts.map +0 -1
  638. package/dist/plugins/postgres-plugin.test.js +0 -186
  639. package/dist/plugins/postgres-plugin.test.js.map +0 -1
  640. package/dist/plugins/preferences/__tests__/deep-merge.test.d.ts +0 -7
  641. package/dist/plugins/preferences/__tests__/deep-merge.test.d.ts.map +0 -1
  642. package/dist/plugins/preferences/__tests__/deep-merge.test.js +0 -215
  643. package/dist/plugins/preferences/__tests__/deep-merge.test.js.map +0 -1
  644. package/dist/plugins/preferences/__tests__/preferences-plugin.test.d.ts +0 -7
  645. package/dist/plugins/preferences/__tests__/preferences-plugin.test.d.ts.map +0 -1
  646. package/dist/plugins/preferences/__tests__/preferences-plugin.test.js +0 -265
  647. package/dist/plugins/preferences/__tests__/preferences-plugin.test.js.map +0 -1
  648. package/dist/plugins/profiles/__tests__/profiles-plugin.test.d.ts +0 -11
  649. package/dist/plugins/profiles/__tests__/profiles-plugin.test.d.ts.map +0 -1
  650. package/dist/plugins/profiles/__tests__/profiles-plugin.test.js +0 -243
  651. package/dist/plugins/profiles/__tests__/profiles-plugin.test.js.map +0 -1
  652. package/dist/plugins/rate-limit/__tests__/rate-limit-plugin.test.d.ts +0 -7
  653. package/dist/plugins/rate-limit/__tests__/rate-limit-plugin.test.d.ts.map +0 -1
  654. package/dist/plugins/rate-limit/__tests__/rate-limit-plugin.test.js +0 -220
  655. package/dist/plugins/rate-limit/__tests__/rate-limit-plugin.test.js.map +0 -1
  656. package/dist/plugins/subscriptions/__tests__/subscriptions-plugin.test.d.ts +0 -11
  657. package/dist/plugins/subscriptions/__tests__/subscriptions-plugin.test.d.ts.map +0 -1
  658. package/dist/plugins/subscriptions/__tests__/subscriptions-plugin.test.js +0 -305
  659. package/dist/plugins/subscriptions/__tests__/subscriptions-plugin.test.js.map +0 -1
  660. package/dist/plugins/usage/__tests__/usage-plugin.test.d.ts +0 -11
  661. package/dist/plugins/usage/__tests__/usage-plugin.test.d.ts.map +0 -1
  662. package/dist/plugins/usage/__tests__/usage-plugin.test.js +0 -218
  663. package/dist/plugins/usage/__tests__/usage-plugin.test.js.map +0 -1
  664. package/dist/plugins/users/__tests__/postgres-store.test.d.ts +0 -10
  665. package/dist/plugins/users/__tests__/postgres-store.test.d.ts.map +0 -1
  666. package/dist/plugins/users/__tests__/postgres-store.test.js +0 -230
  667. package/dist/plugins/users/__tests__/postgres-store.test.js.map +0 -1
  668. package/dist/plugins/users/__tests__/users-plugin.test.d.ts +0 -9
  669. package/dist/plugins/users/__tests__/users-plugin.test.d.ts.map +0 -1
  670. package/dist/plugins/users/__tests__/users-plugin.test.js +0 -552
  671. package/dist/plugins/users/__tests__/users-plugin.test.js.map +0 -1
  672. package/dist-ui/assets/index-5nX8fM1a.js +0 -469
  673. package/dist-ui/assets/index-5nX8fM1a.js.map +0 -1
  674. package/dist-ui-lib/components/StatCard.d.ts +0 -16
  675. package/dist-ui-lib/pages/APIKeysPage.d.ts +0 -13
  676. package/dist-ui-lib/pages/ConfigPage.d.ts +0 -1
  677. package/dist-ui-lib/pages/DiagnosticsPage.d.ts +0 -1
  678. package/dist-ui-lib/pages/IntegrationsPage.d.ts +0 -1
  679. package/dist-ui-lib/pages/NotificationsPage.d.ts +0 -9
  680. package/dist-ui-lib/pages/PluginPage.d.ts +0 -15
  681. package/dist-ui-lib/pages/PluginsPage.d.ts +0 -1
  682. package/dist-ui-lib/pages/RateLimitPage.d.ts +0 -1
  683. package/ui/src/components/StatCard.tsx +0 -58
  684. /package/dist-ui-lib/{config → src/config}/AppConfig.d.ts +0 -0
  685. /package/dist-ui-lib/{dashboard → src/dashboard}/DashboardWidgetRegistry.d.ts +0 -0
  686. /package/dist-ui-lib/{dashboard → src/dashboard}/DashboardWidgetRenderer.d.ts +0 -0
  687. /package/dist-ui-lib/{dashboard → src/dashboard}/PluginWidgetRenderer.d.ts +0 -0
  688. /package/dist-ui-lib/{dashboard → src/dashboard}/WidgetComponentRegistry.d.ts +0 -0
  689. /package/dist-ui-lib/{dashboard → src/dashboard}/builtInWidgets.d.ts +0 -0
  690. /package/dist-ui-lib/{dashboard → src/dashboard}/index.d.ts +0 -0
  691. /package/dist-ui-lib/{dashboard → src/dashboard}/widgets/AuthStatusWidget.d.ts +0 -0
  692. /package/dist-ui-lib/{dashboard → src/dashboard}/widgets/IntegrationStatusWidget.d.ts +0 -0
  693. /package/dist-ui-lib/{dashboard → src/dashboard}/widgets/NotificationsStatsWidget.d.ts +0 -0
  694. /package/dist-ui-lib/{dashboard → src/dashboard}/widgets/ServiceHealthWidget.d.ts +0 -0
  695. /package/dist-ui-lib/{pages → src/pages}/AcceptInvitationPage.d.ts +0 -0
  696. /package/dist-ui-lib/{pages → src/pages}/AuthPage.d.ts +0 -0
  697. /package/dist-ui-lib/{pages → src/pages}/DashboardPage.d.ts +0 -0
  698. /package/dist-ui-lib/{pages → src/pages}/EntitlementsPage.d.ts +0 -0
  699. /package/dist-ui-lib/{pages → src/pages}/LogsPage.d.ts +0 -0
  700. /package/dist-ui-lib/{pages → src/pages}/NotFoundPage.d.ts +0 -0
  701. /package/dist-ui-lib/{pages → src/pages}/SystemPage.d.ts +0 -0
  702. /package/dist-ui-lib/{pages → src/pages}/UsersPage.d.ts +0 -0
  703. /package/dist-ui-lib/{utils → src/utils}/formatters.d.ts +0 -0
@@ -4,6 +4,9 @@
4
4
  * Communicates with the backend Express API
5
5
  */
6
6
 
7
+ import { buildClientFromManifest } from './clientBuilder.js';
8
+ import type { APIClient } from './types.js';
9
+
7
10
  export interface HealthCheck {
8
11
  status: 'healthy' | 'degraded' | 'unhealthy';
9
12
  latency?: number;
@@ -153,7 +156,7 @@ export interface ApiKey {
153
156
  name: string;
154
157
  key_prefix: string;
155
158
  key_type: 'm2m' | 'pat';
156
- scopes: Array<'read' | 'write' | 'admin'>;
159
+ scopes: string[]; // Phase 2: Support plugin-declared scopes
157
160
  last_used_at: string | null;
158
161
  expires_at: string | null;
159
162
  is_active: boolean;
@@ -172,17 +175,62 @@ export interface ApiKeysResponse {
172
175
  export interface CreateApiKeyRequest {
173
176
  name: string;
174
177
  key_type: 'm2m' | 'pat';
175
- scopes: Array<'read' | 'write' | 'admin'>;
178
+ scopes: string[]; // Phase 2: Support plugin-declared scopes
176
179
  expires_at?: string;
177
180
  }
178
181
 
179
182
  export interface UpdateApiKeyRequest {
180
183
  name?: string;
181
- scopes?: Array<'read' | 'write' | 'admin'>;
184
+ scopes?: string[]; // Phase 2: Support plugin-declared scopes
182
185
  expires_at?: string;
183
186
  is_active?: boolean;
184
187
  }
185
188
 
189
+ // Phase 2: Scope Management
190
+ export interface PluginScope {
191
+ name: string;
192
+ description: string;
193
+ category?: 'read' | 'write' | 'admin';
194
+ }
195
+
196
+ export interface PluginScopesGroup {
197
+ pluginId: string;
198
+ scopes: PluginScope[];
199
+ }
200
+
201
+ export interface AvailableScopesResponse {
202
+ scopes: PluginScopesGroup[];
203
+ }
204
+
205
+ // Phase 2: Usage Tracking
206
+ export interface UsageLogEntry {
207
+ id: string;
208
+ key_id: string;
209
+ endpoint: string;
210
+ method: string;
211
+ status_code?: number;
212
+ ip_address?: string;
213
+ user_agent?: string;
214
+ timestamp: string;
215
+ }
216
+
217
+ export interface UsageStats {
218
+ totalCalls: number;
219
+ lastUsed: string | null;
220
+ callsByStatus: Record<string, number>;
221
+ callsByEndpoint: Record<string, number>;
222
+ }
223
+
224
+ export interface KeyUsageResponse {
225
+ keyId: string;
226
+ keyName: string;
227
+ totalCalls: number;
228
+ lastUsed: string | null;
229
+ callsByStatus: Record<string, number>;
230
+ callsByEndpoint: Record<string, number>;
231
+ logs: UsageLogEntry[];
232
+ }
233
+
186
234
  // ==================
187
235
  // Entitlements API Types
188
236
  // ==================
@@ -489,19 +537,57 @@ export interface RateLimitConfigUpdateResponse {
489
537
  config: RateLimitConfig;
490
538
  }
491
539
 
540
+ export interface PreferencesResponse {
541
+ user_id: string;
542
+ preferences: Record<string, unknown>;
543
+ }
544
+
492
545
  class ControlPanelApi {
493
546
  private baseUrl: string;
547
+ private client: APIClient | null = null;
548
+ private clientPromise: Promise<APIClient> | null = null;
494
549
 
495
550
  constructor(baseUrl = '') {
496
551
  this.baseUrl = baseUrl;
497
552
  }
498
553
 
554
+ /**
555
+ * Ensure the API client is initialized.
556
+ * Lazy-loads the client on first use by fetching the manifest.
557
+ */
558
+ private async ensureClient(): Promise<APIClient> {
559
+ if (this.client) {
560
+ return this.client;
561
+ }
562
+
563
+ // If already fetching, wait for that promise
564
+ if (this.clientPromise) {
565
+ return this.clientPromise;
566
+ }
567
+
568
+ // Start fetching the client
569
+ this.clientPromise = buildClientFromManifest<APIClient>(this.baseUrl);
570
+
571
+ try {
572
+ this.client = await this.clientPromise;
573
+ return this.client;
574
+ } catch (error) {
575
+ // Reset promise so we can retry on next call
576
+ this.clientPromise = null;
577
+ throw error;
578
+ }
579
+ }
580
+
499
581
  /**
500
582
  * Set the base URL for API requests.
501
583
  * Call this when the control panel is mounted at a custom path.
584
+ * Invalidates the cached client since the manifest will be different.
502
585
  */
503
586
  setBaseUrl(baseUrl: string): void {
504
587
  this.baseUrl = baseUrl;
588
+ // Invalidate cached client
589
+ this.client = null;
590
+ this.clientPromise = null;
505
591
  }
506
592
 
507
593
  /**
@@ -591,37 +677,18 @@ class ControlPanelApi {
591
677
  page?: number;
592
678
  search?: string;
593
679
  } = {}): Promise<UsersResponse> {
594
- const params = new URLSearchParams();
595
- if (options.limit) params.set('limit', options.limit.toString());
596
- if (options.page) params.set('page', options.page.toString());
597
- if (options.search) params.set('q', options.search);
598
-
599
- const response = await this._fetch(`${this.baseUrl}/api/users?${params}`);
600
- if (!response.ok) {
601
- throw new Error(`Users request failed: ${response.statusText}`);
602
- }
603
- return response.json();
680
+ const client = await this.ensureClient();
681
+ return client.users.query(options);
604
682
  }
605
683
 
606
684
  async getUserById(id: string): Promise<User> {
607
- const response = await this._fetch(`${this.baseUrl}/api/users/${id}`);
608
- if (!response.ok) {
609
- throw new Error(`User request failed: ${response.statusText}`);
610
- }
611
- return response.json();
685
+ const client = await this.ensureClient();
686
+ return client.users.get(id);
612
687
  }
613
688
 
614
689
  async inviteUser(request: InviteUserRequest): Promise<InvitationResponse> {
615
- const response = await this._fetch(`${this.baseUrl}/api/users/invite`, {
616
- method: 'POST',
617
- headers: { 'Content-Type': 'application/json' },
618
- body: JSON.stringify(request),
619
- });
620
- if (!response.ok) {
621
- const error = await response.json().catch(() => ({}));
622
- throw new Error(error.error || `Invite user failed: ${response.statusText}`);
623
- }
624
- return response.json();
690
+ const client = await this.ensureClient();
691
+ return client.users.invite(request);
625
692
  }
626
693
 
627
694
  async acceptInvitation(token: string): Promise<AcceptInvitationResponse> {
@@ -650,11 +717,8 @@ class ControlPanelApi {
650
717
  // ==================
651
718
 
652
719
  async getBans(): Promise<BansResponse> {
653
- const response = await this._fetch(`${this.baseUrl}/api/bans`);
654
- if (!response.ok) {
655
- throw new Error(`Bans request failed: ${response.statusText}`);
656
- }
657
- return response.json();
720
+ const client = await this.ensureClient();
721
+ return client.bans.query();
658
722
  }
659
723
 
660
724
  async banUser(email: string, reason: string, expiresAt?: string): Promise<void> {
@@ -769,11 +833,8 @@ class ControlPanelApi {
769
833
  }
770
834
 
771
835
  async getEntitlementsStatus(): Promise<EntitlementsStatus> {
772
- const response = await this._fetch(`${this.baseUrl}/api/entitlements/status`);
773
- if (!response.ok) {
774
- throw new Error(`Entitlements status request failed: ${response.statusText}`);
775
- }
776
- return response.json();
836
+ const client = await this.ensureClient();
837
+ return client.entitlements.query();
777
838
  }
778
839
 
779
840
  // ==================
@@ -781,35 +842,23 @@ class ControlPanelApi {
781
842
  // ==================
782
843
 
783
844
  async getHealth(): Promise<HealthResponse> {
784
- const response = await this._fetch(`${this.baseUrl}/api/health`);
785
- if (!response.ok) {
786
- throw new Error(`Health check failed: ${response.statusText}`);
787
- }
788
- return response.json();
845
+ const client = await this.ensureClient();
846
+ return client.core.health();
789
847
  }
790
848
 
791
849
  async getInfo(): Promise<InfoResponse> {
792
- const response = await this._fetch(`${this.baseUrl}/api/info`);
793
- if (!response.ok) {
794
- throw new Error(`Info request failed: ${response.statusText}`);
795
- }
796
- return response.json();
850
+ const client = await this.ensureClient();
851
+ return client.core.info();
797
852
  }
798
853
 
799
854
  async getDiagnostics(): Promise<DiagnosticsResponse> {
800
- const response = await this._fetch(`${this.baseUrl}/api/diagnostics`);
801
- if (!response.ok) {
802
- throw new Error(`Diagnostics request failed: ${response.statusText}`);
803
- }
804
- return response.json();
855
+ const client = await this.ensureClient();
856
+ return client.core.diagnostics();
805
857
  }
806
858
 
807
859
  async getConfig(): Promise<ConfigResponse> {
808
- const response = await this._fetch(`${this.baseUrl}/api/config`);
809
- if (!response.ok) {
810
- throw new Error(`Config request failed: ${response.statusText}`);
811
- }
812
- return response.json();
860
+ const client = await this.ensureClient();
861
+ return client.config.query();
813
862
  }
814
863
 
815
864
  async getLogs(options: {
@@ -819,27 +868,13 @@ class ControlPanelApi {
819
868
  limit?: number;
820
869
  page?: number;
821
870
  } = {}): Promise<LogsResponse> {
822
- const params = new URLSearchParams();
823
- if (options.source) params.set('source', options.source);
824
- if (options.level) params.set('level', options.level);
825
- if (options.search) params.set('search', options.search);
826
- if (options.limit) params.set('limit', options.limit.toString());
827
- if (options.page) params.set('page', options.page.toString());
828
-
829
- const response = await this._fetch(`${this.baseUrl}/api/logs?${params}`);
830
- if (!response.ok) {
831
- throw new Error(`Logs request failed: ${response.statusText}`);
832
- }
833
- return response.json();
871
+ const client = await this.ensureClient();
872
+ return client.logs.query(options);
834
873
  }
835
874
 
836
875
  async getLogSources(): Promise<LogSource[]> {
837
- const response = await this._fetch(`${this.baseUrl}/api/logs/sources`);
838
- if (!response.ok) {
839
- throw new Error(`Log sources request failed: ${response.statusText}`);
840
- }
841
- const data = await response.json();
842
- return data.sources;
876
+ const client = await this.ensureClient();
877
+ return client.logs.sources();
843
878
  }
844
879
 
845
880
  // ==================
@@ -847,11 +882,8 @@ class ControlPanelApi {
847
882
  // ==================
848
883
 
849
884
  async getPlugins(): Promise<PluginsResponse> {
850
- const response = await this._fetch(`${this.baseUrl}/api/plugins`);
851
- if (!response.ok) {
852
- throw new Error(`Plugins request failed: ${response.statusText}`);
853
- }
854
- return response.json();
885
+ const client = await this.ensureClient();
886
+ return client.core.plugins();
855
887
  }
856
888
 
857
889
  async getPluginDetail(id: string): Promise<PluginDetailResponse> {
@@ -870,11 +902,8 @@ class ControlPanelApi {
870
902
  // ==================
871
903
 
872
904
  async getUiContributions(): Promise<UiContributionsResponse> {
873
- const response = await this._fetch(`${this.baseUrl}/api/ui-contributions`);
874
- if (!response.ok) {
875
- throw new Error(`UI contributions request failed: ${response.statusText}`);
876
- }
877
- return response.json();
905
+ const client = await this.ensureClient();
906
+ return client.core.uiContributions();
878
907
  }
879
908
 
880
909
  // ==================
@@ -882,42 +911,37 @@ class ControlPanelApi {
882
911
  // ==================
883
912
 
884
913
  async getAuthConfigStatus(): Promise<AuthConfigStatus> {
885
- const response = await this._fetch(`${this.baseUrl}/api/auth/config/status`);
886
- if (!response.ok) {
914
+ try {
915
+ const client = await this.ensureClient();
916
+ return await client.auth.status();
917
+ } catch (error) {
887
918
  // Return disabled state if endpoint not available
888
- if (response.status === 404) {
919
+ if (error instanceof Error && error.message.includes('404')) {
889
920
  return { state: 'disabled', adapter: null };
890
921
  }
891
- throw new Error(`Auth config status request failed: ${response.statusText}`);
922
+ throw error;
892
923
  }
893
- return response.json();
894
924
  }
895
925
 
896
926
  async getAuthConfig(): Promise<AuthConfigStatus> {
897
- const response = await this._fetch(`${this.baseUrl}/api/auth/config`);
898
- if (!response.ok) {
899
- if (response.status === 404) {
927
+ try {
928
+ const client = await this.ensureClient();
929
+ return await client.auth.config() as unknown as AuthConfigStatus;
930
+ } catch (error) {
931
+ // Return disabled state if endpoint not available
932
+ if (error instanceof Error && error.message.includes('404')) {
900
933
  return { state: 'disabled', adapter: null };
901
934
  }
902
- throw new Error(`Auth config request failed: ${response.statusText}`);
935
+ throw error;
903
936
  }
904
- return response.json();
905
937
  }
906
938
 
907
939
  /**
908
940
  * Update auth configuration (save to database for hot-reload)
909
941
  */
910
942
  async updateAuthConfig(request: UpdateAuthConfigRequest): Promise<{ success: boolean; message: string }> {
911
- const response = await this._fetch(`${this.baseUrl}/api/auth/config`, {
912
- method: 'PUT',
913
- headers: { 'Content-Type': 'application/json' },
914
- body: JSON.stringify(request),
915
- });
916
- if (!response.ok) {
917
- const error = await response.json().catch(() => ({}));
918
- throw new Error(error.error || `Auth config update failed: ${response.statusText}`);
919
- }
920
- return response.json();
943
+ const client = await this.ensureClient();
944
+ return client.auth.update(request) as unknown as { success: boolean; message: string };
921
945
  }
922
946
 
923
947
  /**
@@ -938,16 +962,8 @@ class ControlPanelApi {
938
962
  * Test auth provider connection without saving
939
963
  */
940
964
  async testAuthProvider(request: TestProviderRequest): Promise<TestProviderResponse> {
941
- const response = await this._fetch(`${this.baseUrl}/api/auth/test-provider`, {
942
- method: 'POST',
943
- headers: { 'Content-Type': 'application/json' },
944
- body: JSON.stringify(request),
945
- });
946
- if (!response.ok) {
947
- const error = await response.json().catch(() => ({}));
948
- throw new Error(error.error || `Provider test failed: ${response.statusText}`);
949
- }
950
- return response.json();
965
+ const client = await this.ensureClient();
966
+ return client.auth.test(request);
951
967
  }
952
968
 
953
969
  /**
@@ -970,24 +986,13 @@ class ControlPanelApi {
970
986
  // ==================
971
987
 
972
988
  async getRateLimitConfig(): Promise<RateLimitConfig> {
973
- const response = await this._fetch(`${this.baseUrl}/api/rate-limit/config`);
974
- if (!response.ok) {
975
- throw new Error(`Rate limit config request failed: ${response.statusText}`);
976
- }
977
- return response.json();
989
+ const client = await this.ensureClient();
990
+ return client.rateLimit.config() as unknown as RateLimitConfig;
978
991
  }
979
992
 
980
993
  async updateRateLimitConfig(updates: RateLimitConfigUpdateRequest): Promise<RateLimitConfigUpdateResponse> {
981
- const response = await this._fetch(`${this.baseUrl}/api/rate-limit/config`, {
982
- method: 'PUT',
983
- headers: { 'Content-Type': 'application/json' },
984
- body: JSON.stringify(updates),
985
- });
986
- if (!response.ok) {
987
- const error = await response.json().catch(() => ({}));
988
- throw new Error(error.error || `Rate limit config update failed: ${response.statusText}`);
989
- }
990
- return response.json();
994
+ const client = await this.ensureClient();
995
+ return client.rateLimit.update(updates);
991
996
  }
992
997
 
993
998
  // ==================
@@ -995,19 +1000,13 @@ class ControlPanelApi {
995
1000
  // ==================
996
1001
 
997
1002
  async getNotificationsStats(): Promise<NotificationsStatsResponse> {
998
- const response = await this._fetch(`${this.baseUrl}/api/notifications/stats`);
999
- if (!response.ok) {
1000
- throw new Error(`Notifications stats request failed: ${response.statusText}`);
1001
- }
1002
- return response.json();
1003
+ const client = await this.ensureClient();
1004
+ return client.notifications.stats();
1003
1005
  }
1004
1006
 
1005
1007
  async getNotificationsClients(): Promise<NotificationsClientsResponse> {
1006
- const response = await this._fetch(`${this.baseUrl}/api/notifications/clients`);
1007
- if (!response.ok) {
1008
- throw new Error(`Notifications clients request failed: ${response.statusText}`);
1009
- }
1010
- return response.json();
1008
+ const client = await this.ensureClient();
1009
+ return client.notifications.clients();
1011
1010
  }
1012
1011
 
1013
1012
  async disconnectNotificationsClient(clientId: string): Promise<{ success: boolean }> {
@@ -1037,54 +1036,85 @@ class ControlPanelApi {
1037
1036
  // ==================
1038
1037
 
1039
1038
  async getApiKeys(): Promise<ApiKeysResponse> {
1040
- const response = await this._fetch(`${this.baseUrl}/api/api-keys`);
1041
- if (!response.ok) {
1042
- throw new Error(`API keys request failed: ${response.statusText}`);
1043
- }
1044
- return response.json();
1039
+ const client = await this.ensureClient();
1040
+ return client.apiKeys.query();
1045
1041
  }
1046
1042
 
1047
1043
  async createApiKey(request: CreateApiKeyRequest): Promise<ApiKeyWithPlaintext> {
1048
- const response = await this._fetch(`${this.baseUrl}/api/api-keys`, {
1049
- method: 'POST',
1050
- headers: { 'Content-Type': 'application/json' },
1051
- body: JSON.stringify(request),
1052
- });
1053
- if (!response.ok) {
1054
- const error = await response.json().catch(() => ({}));
1055
- throw new Error(error.error || `API key creation failed: ${response.statusText}`);
1056
- }
1057
- return response.json();
1044
+ const client = await this.ensureClient();
1045
+ return client.apiKeys.create(request) as unknown as ApiKeyWithPlaintext;
1058
1046
  }
1059
1047
 
1060
1048
  async getApiKey(keyId: string): Promise<ApiKey> {
1061
- const response = await this._fetch(`${this.baseUrl}/api/api-keys/${encodeURIComponent(keyId)}`);
1062
- if (!response.ok) {
1063
- throw new Error(`API key request failed: ${response.statusText}`);
1064
- }
1065
- return response.json();
1049
+ const client = await this.ensureClient();
1050
+ return client.apiKeys.get(keyId);
1066
1051
  }
1067
1052
 
1068
1053
  async updateApiKey(keyId: string, updates: UpdateApiKeyRequest): Promise<ApiKey> {
1069
- const response = await this._fetch(`${this.baseUrl}/api/api-keys/${encodeURIComponent(keyId)}`, {
1054
+ const client = await this.ensureClient();
1055
+ return client.apiKeys.update(keyId, updates);
1056
+ }
1057
+
1058
+ async deleteApiKey(keyId: string): Promise<void> {
1059
+ const client = await this.ensureClient();
1060
+ return client.apiKeys.delete(keyId);
1061
+ }
1062
+
1063
+ // Phase 2: Scope Management
1064
+ async getAvailableScopes(): Promise<AvailableScopesResponse> {
1065
+ const client = await this.ensureClient();
1066
+ return client.apiKeys.scopes();
1067
+ }
1068
+
1069
+ // Phase 2: Usage Tracking
1070
+ async getKeyUsage(
1071
+ keyId: string,
1072
+ _params?: {
1073
+ limit?: number;
1074
+ offset?: number;
1075
+ since?: string;
1076
+ until?: string;
1077
+ endpoint?: string;
1078
+ method?: string;
1079
+ statusCode?: number;
1080
+ }
1081
+ ): Promise<KeyUsageResponse> {
1082
+ const client = await this.ensureClient();
1083
+ // Note: _params are ignored in auto-generated client - API expects them as query params
1084
+ // TODO: Verify if usage endpoint accepts query params and update client if needed
1085
+ return client.apiKeys.usage(keyId);
1086
+ }
1087
+
1088
+ // ============================================================================
1089
+ // Preferences API
1090
+ // ============================================================================
1091
+
1092
+ async getPreferences(): Promise<PreferencesResponse> {
1093
+ const client = await this.ensureClient();
1094
+ return client.preferences.query();
1095
+ }
1096
+
1097
+ async updatePreferences(preferences: Record<string, unknown>): Promise<PreferencesResponse> {
1098
+ const url = `${this.baseUrl}/api/preferences`;
1099
+ const response = await this._fetch(url, {
1070
1100
  method: 'PUT',
1071
1101
  headers: { 'Content-Type': 'application/json' },
1072
- body: JSON.stringify(updates),
1102
+ body: JSON.stringify(preferences),
1073
1103
  });
1074
1104
  if (!response.ok) {
1075
- const error = await response.json().catch(() => ({}));
1076
- throw new Error(error.error || `API key update failed: ${response.statusText}`);
1105
+ const error = await response.json().catch(() => ({ error: response.statusText }));
1106
+ throw new Error(error.error || `Failed to update preferences: ${response.statusText}`);
1077
1107
  }
1078
1108
  return response.json();
1079
1109
  }
1080
1110
 
1081
- async deleteApiKey(keyId: string): Promise<void> {
1082
- const response = await this._fetch(`${this.baseUrl}/api/api-keys/${encodeURIComponent(keyId)}`, {
1111
+ async deletePreferences(): Promise<void> {
1112
+ const url = `${this.baseUrl}/api/preferences`;
1113
+ const response = await this._fetch(url, {
1083
1114
  method: 'DELETE',
1084
1115
  });
1085
1116
  if (!response.ok) {
1086
- const error = await response.json().catch(() => ({}));
1087
- throw new Error(error.error || `API key deletion failed: ${response.statusText}`);
1117
+ throw new Error(`Failed to delete preferences: ${response.statusText}`);
1088
1118
  }
1089
1119
  }
1090
1120
  }
@@ -0,0 +1,12 @@
1
+ /**
2
+ * QwickApps Control Panel API Client
3
+ *
4
+ * Auto-generated typed API client from server manifest.
5
+ *
6
+ * Copyright (c) 2025 QwickApps.com. All rights reserved.
7
+ */
8
+
9
+ export { buildClientFromManifest } from './clientBuilder.js';
10
+ export type { ClientManifest, RouteManifestEntry } from './clientBuilder.js';
11
+ export type { APIClient } from './types.js';
12
+ export * from './controlPanelApi.js'; // Re-export all types for compatibility