@jmruthers/pace-core 0.5.75 → 0.5.77

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 (507) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/{RBACService-C4udt_Zp.d.ts → AuthService-SBHZQtCH.d.ts} +5 -118
  3. package/dist/{DataTable-ntgmhO2W.d.ts → DataTable-BE0OXZKQ.d.ts} +9 -2
  4. package/dist/DataTable-QCNCV6IK.js +157 -0
  5. package/dist/{PublicLoadingSpinner-BKNBT6b6.d.ts → PublicLoadingSpinner-CnUaz0vG.d.ts} +33 -19
  6. package/dist/{UnifiedAuthProvider-Bj6YCf7c.d.ts → UnifiedAuthProvider-B391Aqum.d.ts} +42 -45
  7. package/dist/{UnifiedAuthProvider-3NKDOSOK.js → UnifiedAuthProvider-Z2FWNW7O.js} +4 -5
  8. package/dist/{api-DDMUKIUD.js → api-KG4A2X7P.js} +9 -3
  9. package/dist/{audit-6TOCAMKO.js → audit-65VNHEV2.js} +2 -2
  10. package/dist/{chunk-2DFZ432F.js → chunk-7PX43UYN.js} +197 -629
  11. package/dist/chunk-7PX43UYN.js.map +1 -0
  12. package/dist/{chunk-DAXLNIDY.js → chunk-C4RQ3GQA.js} +108 -32
  13. package/dist/chunk-C4RQ3GQA.js.map +1 -0
  14. package/dist/{chunk-LW7MMEAQ.js → chunk-CRKP3HXI.js} +2 -2
  15. package/dist/{chunk-XLZ7U46Z.js → chunk-CVMVPYAL.js} +9 -60
  16. package/dist/chunk-CVMVPYAL.js.map +1 -0
  17. package/dist/{chunk-CY3AHGO4.js → chunk-DDPG7FCX.js} +3395 -3254
  18. package/dist/chunk-DDPG7FCX.js.map +1 -0
  19. package/dist/{chunk-URUTVZ7N.js → chunk-DVHZ5L55.js} +2 -2
  20. package/dist/{chunk-5BSLGBYI.js → chunk-JCQZ6LA7.js} +2 -8
  21. package/dist/{chunk-5BSLGBYI.js.map → chunk-JCQZ6LA7.js.map} +1 -1
  22. package/dist/{chunk-WN6XJWOS.js → chunk-JDQ7T3QB.js} +256 -743
  23. package/dist/chunk-JDQ7T3QB.js.map +1 -0
  24. package/dist/{chunk-ZTT2AXMX.js → chunk-LMYTEMUH.js} +153 -132
  25. package/dist/chunk-LMYTEMUH.js.map +1 -0
  26. package/dist/{chunk-33PHABLB.js → chunk-NKT2DLZI.js} +13 -130
  27. package/dist/chunk-NKT2DLZI.js.map +1 -0
  28. package/dist/chunk-PUKTJMRT.js +732 -0
  29. package/dist/chunk-PUKTJMRT.js.map +1 -0
  30. package/dist/{chunk-B2WTCLCV.js → chunk-Q7APDV6H.js} +18 -8
  31. package/dist/chunk-Q7APDV6H.js.map +1 -0
  32. package/dist/{chunk-FGMFQSHX.js → chunk-S63MFSY6.js} +500 -551
  33. package/dist/chunk-S63MFSY6.js.map +1 -0
  34. package/dist/{chunk-NTNILOBC.js → chunk-TLD5BEU6.js} +4 -4
  35. package/dist/chunk-WUXCWRL6.js +20 -0
  36. package/dist/chunk-WUXCWRL6.js.map +1 -0
  37. package/dist/{chunk-YNUBMSMV.js → chunk-YCKPEMJA.js} +186 -263
  38. package/dist/chunk-YCKPEMJA.js.map +1 -0
  39. package/dist/{chunk-A4FUBC7B.js → chunk-Z3T6RK3K.js} +2 -4
  40. package/dist/{chunk-A4FUBC7B.js.map → chunk-Z3T6RK3K.js.map} +1 -1
  41. package/dist/components.d.ts +6 -6
  42. package/dist/components.js +17 -20
  43. package/dist/components.js.map +1 -1
  44. package/dist/{database-C3Szpi5J.d.ts → database-BXAfr2Y_.d.ts} +18 -0
  45. package/dist/hooks.d.ts +21 -44
  46. package/dist/hooks.js +12 -13
  47. package/dist/hooks.js.map +1 -1
  48. package/dist/index.d.ts +19 -27
  49. package/dist/index.js +27 -33
  50. package/dist/index.js.map +1 -1
  51. package/dist/{organisation-BtshODVF.d.ts → organisation-D6qRDtbF.d.ts} +1 -1
  52. package/dist/providers.d.ts +7 -21
  53. package/dist/providers.js +3 -10
  54. package/dist/rbac/index.d.ts +118 -215
  55. package/dist/rbac/index.js +18 -18
  56. package/dist/{types-CGX9Vyf5.d.ts → types-BDg1mAGG.d.ts} +36 -6
  57. package/dist/types.d.ts +3 -3
  58. package/dist/types.js +61 -18
  59. package/dist/types.js.map +1 -1
  60. package/dist/{unified-CM7T0aTK.d.ts → unified-DQ4VcT7H.d.ts} +1 -1
  61. package/dist/{usePublicRouteParams-B-CumWRc.d.ts → usePublicRouteParams-BlgwXweB.d.ts} +3 -3
  62. package/dist/utils.d.ts +2 -2
  63. package/dist/utils.js +52 -9
  64. package/dist/utils.js.map +1 -1
  65. package/docs/CONTENT_AUDIT_REPORT.md +253 -0
  66. package/docs/DOCUMENTATION_AUDIT.md +172 -0
  67. package/docs/README.md +142 -147
  68. package/docs/STYLE_GUIDE.md +37 -0
  69. package/docs/api/classes/ColumnFactory.md +17 -17
  70. package/docs/api/classes/ErrorBoundary.md +1 -1
  71. package/docs/api/classes/InvalidScopeError.md +4 -4
  72. package/docs/api/classes/MissingUserContextError.md +4 -4
  73. package/docs/api/classes/OrganisationContextRequiredError.md +4 -4
  74. package/docs/api/classes/PermissionDeniedError.md +5 -5
  75. package/docs/api/classes/PublicErrorBoundary.md +1 -1
  76. package/docs/api/classes/RBACAuditManager.md +8 -8
  77. package/docs/api/classes/RBACCache.md +35 -5
  78. package/docs/api/classes/RBACEngine.md +49 -20
  79. package/docs/api/classes/RBACError.md +4 -4
  80. package/docs/api/classes/RBACNotInitializedError.md +4 -4
  81. package/docs/api/classes/SecureSupabaseClient.md +1 -1
  82. package/docs/api/classes/StorageUtils.md +1 -1
  83. package/docs/api/enums/FileCategory.md +1 -1
  84. package/docs/api/interfaces/AggregateConfig.md +4 -4
  85. package/docs/api/interfaces/ButtonProps.md +1 -1
  86. package/docs/api/interfaces/CardProps.md +1 -1
  87. package/docs/api/interfaces/ColorPalette.md +1 -1
  88. package/docs/api/interfaces/ColorShade.md +1 -1
  89. package/docs/api/interfaces/DataAccessRecord.md +1 -1
  90. package/docs/api/interfaces/DataRecord.md +11 -0
  91. package/docs/api/interfaces/DataTableAction.md +65 -29
  92. package/docs/api/interfaces/DataTableColumn.md +36 -23
  93. package/docs/api/interfaces/DataTableProps.md +80 -38
  94. package/docs/api/interfaces/DataTableToolbarButton.md +7 -7
  95. package/docs/api/interfaces/EmptyStateConfig.md +5 -5
  96. package/docs/api/interfaces/EnhancedNavigationMenuProps.md +1 -1
  97. package/docs/api/interfaces/EventLogoProps.md +1 -1
  98. package/docs/api/interfaces/FileDisplayProps.md +1 -1
  99. package/docs/api/interfaces/FileMetadata.md +1 -1
  100. package/docs/api/interfaces/FileReference.md +1 -1
  101. package/docs/api/interfaces/FileSizeLimits.md +1 -1
  102. package/docs/api/interfaces/FileUploadOptions.md +1 -1
  103. package/docs/api/interfaces/FileUploadProps.md +1 -1
  104. package/docs/api/interfaces/FooterProps.md +1 -1
  105. package/docs/api/interfaces/InactivityWarningModalProps.md +1 -1
  106. package/docs/api/interfaces/InputProps.md +1 -1
  107. package/docs/api/interfaces/LabelProps.md +1 -1
  108. package/docs/api/interfaces/LoginFormProps.md +1 -1
  109. package/docs/api/interfaces/NavigationAccessRecord.md +11 -11
  110. package/docs/api/interfaces/NavigationContextType.md +9 -9
  111. package/docs/api/interfaces/NavigationGuardProps.md +1 -1
  112. package/docs/api/interfaces/NavigationItem.md +1 -1
  113. package/docs/api/interfaces/NavigationMenuProps.md +1 -1
  114. package/docs/api/interfaces/NavigationProviderProps.md +7 -7
  115. package/docs/api/interfaces/Organisation.md +1 -1
  116. package/docs/api/interfaces/OrganisationContextType.md +1 -1
  117. package/docs/api/interfaces/OrganisationMembership.md +1 -1
  118. package/docs/api/interfaces/OrganisationProviderProps.md +1 -1
  119. package/docs/api/interfaces/OrganisationSecurityError.md +1 -1
  120. package/docs/api/interfaces/PaceAppLayoutProps.md +1 -1
  121. package/docs/api/interfaces/PaceLoginPageProps.md +16 -3
  122. package/docs/api/interfaces/PageAccessRecord.md +1 -1
  123. package/docs/api/interfaces/PagePermissionContextType.md +1 -1
  124. package/docs/api/interfaces/PagePermissionGuardProps.md +2 -2
  125. package/docs/api/interfaces/PagePermissionProviderProps.md +1 -1
  126. package/docs/api/interfaces/PaletteData.md +1 -1
  127. package/docs/api/interfaces/PermissionEnforcerProps.md +4 -4
  128. package/docs/api/interfaces/PublicErrorBoundaryProps.md +1 -1
  129. package/docs/api/interfaces/PublicErrorBoundaryState.md +1 -1
  130. package/docs/api/interfaces/PublicLoadingSpinnerProps.md +1 -1
  131. package/docs/api/interfaces/PublicPageFooterProps.md +1 -1
  132. package/docs/api/interfaces/PublicPageHeaderProps.md +1 -1
  133. package/docs/api/interfaces/PublicPageLayoutProps.md +1 -1
  134. package/docs/api/interfaces/RBACConfig.md +1 -1
  135. package/docs/api/interfaces/RBACLogger.md +1 -1
  136. package/docs/api/interfaces/RoleBasedRouterContextType.md +1 -1
  137. package/docs/api/interfaces/RoleBasedRouterProps.md +1 -1
  138. package/docs/api/interfaces/RouteAccessRecord.md +2 -2
  139. package/docs/api/interfaces/RouteConfig.md +2 -2
  140. package/docs/api/interfaces/SecureDataContextType.md +1 -1
  141. package/docs/api/interfaces/SecureDataProviderProps.md +1 -1
  142. package/docs/api/interfaces/StorageConfig.md +1 -1
  143. package/docs/api/interfaces/StorageFileInfo.md +1 -1
  144. package/docs/api/interfaces/StorageFileMetadata.md +1 -1
  145. package/docs/api/interfaces/StorageListOptions.md +1 -1
  146. package/docs/api/interfaces/StorageListResult.md +1 -1
  147. package/docs/api/interfaces/StorageUploadOptions.md +1 -1
  148. package/docs/api/interfaces/StorageUploadResult.md +1 -1
  149. package/docs/api/interfaces/StorageUrlOptions.md +1 -1
  150. package/docs/api/interfaces/StyleImport.md +1 -1
  151. package/docs/api/interfaces/SwitchProps.md +1 -1
  152. package/docs/api/interfaces/ToastActionElement.md +1 -1
  153. package/docs/api/interfaces/ToastProps.md +1 -1
  154. package/docs/api/interfaces/UnifiedAuthContextType.md +94 -521
  155. package/docs/api/interfaces/UnifiedAuthProviderProps.md +16 -16
  156. package/docs/api/interfaces/UseInactivityTrackerOptions.md +1 -1
  157. package/docs/api/interfaces/UseInactivityTrackerReturn.md +1 -1
  158. package/docs/api/interfaces/UsePublicEventLogoOptions.md +1 -1
  159. package/docs/api/interfaces/UsePublicEventLogoReturn.md +1 -1
  160. package/docs/api/interfaces/UsePublicEventOptions.md +1 -1
  161. package/docs/api/interfaces/UsePublicEventReturn.md +1 -1
  162. package/docs/api/interfaces/UsePublicRouteParamsReturn.md +1 -1
  163. package/docs/api/interfaces/UseResolvedScopeOptions.md +47 -0
  164. package/docs/api/interfaces/UseResolvedScopeReturn.md +47 -0
  165. package/docs/api/interfaces/UserEventAccess.md +11 -11
  166. package/docs/api/interfaces/UserMenuProps.md +1 -1
  167. package/docs/api/interfaces/UserProfile.md +1 -1
  168. package/docs/api/modules.md +303 -275
  169. package/docs/api-reference/components.md +193 -0
  170. package/docs/api-reference/hooks.md +265 -0
  171. package/docs/api-reference/providers.md +32 -7
  172. package/docs/api-reference/types.md +6 -0
  173. package/docs/api-reference/utilities.md +207 -0
  174. package/docs/architecture/README.md +6 -0
  175. package/docs/{database-schema-requirements.md → architecture/database-schema-requirements.md} +6 -0
  176. package/docs/architecture/rbac-security-architecture.md +258 -0
  177. package/docs/architecture/services.md +9 -1
  178. package/docs/best-practices/README.md +26 -0
  179. package/docs/best-practices/accessibility.md +572 -0
  180. package/docs/{common-patterns.md → best-practices/common-patterns.md} +6 -0
  181. package/docs/best-practices/deployment.md +6 -0
  182. package/docs/best-practices/performance.md +475 -2
  183. package/docs/best-practices/security.md +6 -0
  184. package/docs/best-practices/testing.md +6 -0
  185. package/docs/core-concepts/authentication.md +21 -7
  186. package/docs/core-concepts/events.md +6 -0
  187. package/docs/core-concepts/organisations.md +6 -0
  188. package/docs/core-concepts/permissions.md +6 -0
  189. package/docs/core-concepts/rbac-system.md +6 -0
  190. package/docs/documentation-index.md +121 -182
  191. package/docs/{consuming-app-vite-config.md → getting-started/consuming-app-vite-config.md} +6 -0
  192. package/docs/getting-started/documentation-index.md +40 -0
  193. package/docs/getting-started/examples/README.md +878 -35
  194. package/docs/{faq.md → getting-started/faq.md} +7 -1
  195. package/docs/getting-started/installation-guide.md +6 -0
  196. package/docs/{quick-reference.md → getting-started/quick-reference.md} +6 -0
  197. package/docs/implementation-guides/app-layout.md +6 -0
  198. package/docs/implementation-guides/authentication.md +1021 -0
  199. package/docs/implementation-guides/component-styling.md +416 -0
  200. package/docs/implementation-guides/data-tables.md +1264 -2076
  201. package/docs/implementation-guides/dynamic-colors.md +6 -0
  202. package/docs/implementation-guides/event-theming-summary.md +6 -0
  203. package/docs/{file-reference-system.md → implementation-guides/file-reference-system.md} +6 -0
  204. package/docs/implementation-guides/file-upload-storage.md +6 -0
  205. package/docs/implementation-guides/forms.md +6 -0
  206. package/docs/implementation-guides/inactivity-tracking.md +6 -0
  207. package/docs/implementation-guides/navigation.md +6 -0
  208. package/docs/implementation-guides/organisation-security.md +6 -0
  209. package/docs/implementation-guides/permission-enforcement.md +6 -0
  210. package/docs/implementation-guides/public-pages-advanced.md +6 -0
  211. package/docs/implementation-guides/public-pages.md +6 -0
  212. package/docs/migration/MIGRATION_GUIDE.md +827 -351
  213. package/docs/migration/README.md +7 -1
  214. package/docs/migration/organisation-context-timing-fix.md +6 -0
  215. package/docs/migration/rbac-migration.md +44 -1
  216. package/docs/migration/service-architecture.md +6 -0
  217. package/docs/migration/v0.4.15-tailwind-scanning.md +6 -0
  218. package/docs/migration/v0.4.16-css-first-approach.md +6 -0
  219. package/docs/migration/v0.4.17-source-path-fix.md +6 -0
  220. package/docs/rbac/README-rbac-rls-integration.md +6 -0
  221. package/docs/rbac/README.md +6 -0
  222. package/docs/rbac/advanced-patterns.md +6 -0
  223. package/docs/rbac/api-reference.md +7 -1
  224. package/docs/rbac/breaking-changes-v3.md +222 -0
  225. package/docs/rbac/examples/rbac-rls-integration-example.md +6 -0
  226. package/docs/rbac/examples.md +6 -0
  227. package/docs/rbac/getting-started.md +6 -0
  228. package/docs/rbac/migration-guide.md +260 -0
  229. package/docs/rbac/quick-start.md +6 -0
  230. package/docs/rbac/rbac-rls-integration.md +6 -0
  231. package/docs/rbac/super-admin-guide.md +6 -0
  232. package/docs/rbac/troubleshooting.md +6 -0
  233. package/docs/security/README.md +6 -0
  234. package/docs/security/checklist.md +6 -0
  235. package/docs/styles/README.md +7 -1
  236. package/docs/{usage.md → styles/usage.md} +6 -0
  237. package/docs/testing/README.md +6 -0
  238. package/docs/{visual-testing.md → testing/visual-testing.md} +6 -0
  239. package/docs/troubleshooting/README.md +387 -5
  240. package/docs/troubleshooting/cake-page-permission-guard-issue-summary.md +6 -0
  241. package/docs/troubleshooting/common-issues.md +6 -0
  242. package/docs/troubleshooting/database-view-compatibility.md +6 -0
  243. package/docs/troubleshooting/organisation-context-setup.md +6 -0
  244. package/docs/troubleshooting/react-hooks-issue-analysis.md +6 -0
  245. package/docs/troubleshooting/styling-issues.md +6 -0
  246. package/docs/troubleshooting/tailwind-content-scanning.md +6 -0
  247. package/package.json +1 -1
  248. package/src/__tests__/TEST_GUIDE_CURSOR.md +290 -0
  249. package/src/__tests__/helpers/__tests__/test-providers.test.tsx +2 -1
  250. package/src/__tests__/helpers/supabaseMock.ts +48 -2
  251. package/src/__tests__/helpers/test-providers.tsx +3 -53
  252. package/src/components/DataTable/DataTable.test.tsx +319 -0
  253. package/src/components/DataTable/DataTable.tsx +32 -11
  254. package/src/components/DataTable/__tests__/{DataTable.comprehensive.test.tsx → DataTable.comprehensive.test.tsx.skip} +6 -4
  255. package/src/components/DataTable/__tests__/DataTable.default-state.test.tsx +17 -6
  256. package/src/components/DataTable/__tests__/{DataTable.test.tsx → DataTable.test.tsx.skip} +6 -4
  257. package/src/components/DataTable/__tests__/DataTableCore.test.tsx +96 -10
  258. package/src/components/DataTable/__tests__/a11y.basic.test.tsx +601 -0
  259. package/src/components/DataTable/__tests__/keyboard.test.tsx +615 -0
  260. package/src/components/DataTable/__tests__/pagination.modes.test.tsx +639 -0
  261. package/src/components/DataTable/__tests__/ssr.strict-mode.test.tsx.skip +330 -0
  262. package/src/components/DataTable/components/AccessDeniedPage.tsx +2 -2
  263. package/src/components/DataTable/components/ActionButtons.tsx +88 -104
  264. package/src/components/DataTable/components/DataTableCore.tsx +442 -665
  265. package/src/components/DataTable/components/DataTableErrorBoundary.tsx +4 -2
  266. package/src/components/DataTable/components/DataTableModals.tsx +22 -1
  267. package/src/components/DataTable/components/EditableRow.tsx +69 -84
  268. package/src/components/DataTable/components/EmptyState.tsx +5 -1
  269. package/src/components/DataTable/components/ImportModal.tsx +65 -36
  270. package/src/components/DataTable/components/PaginationControls.tsx +40 -100
  271. package/src/components/DataTable/components/UnifiedTableBody.tsx +222 -278
  272. package/src/components/DataTable/components/index.ts +1 -2
  273. package/src/components/DataTable/context/DataTableContext.tsx +1 -1
  274. package/src/components/DataTable/context/__tests__/DataTableContext.test.tsx +208 -275
  275. package/src/components/DataTable/core/ColumnFactory.ts +5 -0
  276. package/src/components/DataTable/core/index.ts +1 -8
  277. package/src/components/DataTable/examples/HierarchicalActionsExample.tsx +12 -10
  278. package/src/components/DataTable/examples/HierarchicalExample.tsx +1 -1
  279. package/src/components/DataTable/examples/InitialPageSizeExample.tsx +1 -0
  280. package/src/components/DataTable/examples/PerformanceExample.tsx +1 -0
  281. package/src/components/DataTable/hooks/__tests__/useColumnOrderPersistence.test.ts +521 -0
  282. package/src/components/DataTable/hooks/__tests__/useColumnReordering.test.ts +570 -0
  283. package/src/components/DataTable/hooks/__tests__/useColumnVisibilityPersistence.test.ts +167 -0
  284. package/src/components/DataTable/hooks/__tests__/useHierarchicalState.test.ts +214 -0
  285. package/src/components/DataTable/hooks/__tests__/useTableColumns.test.ts +224 -0
  286. package/src/components/DataTable/hooks/index.ts +13 -0
  287. package/src/components/DataTable/hooks/useColumnOrderPersistence.ts +32 -15
  288. package/src/components/DataTable/hooks/useColumnReordering.ts +1 -0
  289. package/src/components/DataTable/hooks/useColumnVisibilityPersistence.ts +102 -0
  290. package/src/components/DataTable/hooks/useDataTableConfiguration.ts +89 -0
  291. package/src/components/DataTable/hooks/useDataTableDataPipeline.ts +117 -0
  292. package/src/components/DataTable/hooks/useDataTablePermissions.ts +193 -0
  293. package/src/components/DataTable/hooks/useDataTableState.ts +51 -17
  294. package/src/components/DataTable/hooks/useEffectiveColumnOrder.ts +33 -0
  295. package/src/components/DataTable/hooks/useHierarchicalState.ts +41 -9
  296. package/src/components/DataTable/hooks/useKeyboardNavigation.ts +447 -0
  297. package/src/components/DataTable/hooks/useServerSideDataEffect.ts +94 -0
  298. package/src/components/DataTable/hooks/useTableColumns.ts +156 -0
  299. package/src/components/DataTable/hooks/useTableHandlers.ts +174 -0
  300. package/src/components/DataTable/index.ts +13 -12
  301. package/src/components/DataTable/types.ts +129 -9
  302. package/src/components/DataTable/utils/__tests__/COVERAGE_NOTE.md +89 -0
  303. package/src/components/DataTable/utils/__tests__/exportUtils.test.ts +162 -28
  304. package/src/components/DataTable/utils/__tests__/flexibleImport.test.ts +573 -0
  305. package/src/components/DataTable/utils/__tests__/hierarchicalSorting.test.ts +247 -0
  306. package/src/components/DataTable/utils/__tests__/hierarchicalUtils.test.ts +8 -6
  307. package/src/components/DataTable/utils/__tests__/performanceUtils.test.ts +466 -0
  308. package/src/components/DataTable/utils/__tests__/rowUtils.test.ts +251 -0
  309. package/src/components/DataTable/utils/a11yUtils.ts +244 -0
  310. package/src/components/DataTable/utils/debugTools.ts +47 -21
  311. package/src/components/DataTable/utils/errorHandling.ts +52 -460
  312. package/src/components/DataTable/utils/exportUtils.ts +157 -28
  313. package/src/components/DataTable/utils/flexibleImport.ts +202 -32
  314. package/src/components/DataTable/utils/hierarchicalSorting.ts +50 -3
  315. package/src/components/DataTable/utils/hierarchicalUtils.ts +167 -34
  316. package/src/components/DataTable/utils/index.ts +7 -0
  317. package/src/components/DataTable/utils/paginationUtils.ts +350 -0
  318. package/src/components/DataTable/utils/rowUtils.ts +69 -0
  319. package/src/components/EventSelector/EventSelector.test.tsx +672 -0
  320. package/src/components/Label/__tests__/Label.test.tsx +434 -0
  321. package/src/components/NavigationMenu/NavigationMenu.test.tsx +19 -24
  322. package/src/components/NavigationMenu/NavigationMenu.tsx +19 -8
  323. package/src/components/PaceAppLayout/__tests__/PaceAppLayout.security.test.tsx +1 -23
  324. package/src/components/PaceLoginPage/PaceLoginPage.test.tsx +56 -6
  325. package/src/components/PaceLoginPage/PaceLoginPage.tsx +137 -13
  326. package/src/components/PublicLayout/__tests__/PublicPageContextChecker.test.tsx +190 -0
  327. package/src/components/PublicLayout/__tests__/PublicPageDebugger.test.tsx +185 -0
  328. package/src/components/PublicLayout/__tests__/PublicPageHeader.test.tsx +1 -1
  329. package/src/components/PublicLayout/__tests__/PublicPageProvider.test.tsx +313 -0
  330. package/src/components/Select/Select.test.tsx +143 -120
  331. package/src/components/Select/Select.tsx +48 -212
  332. package/src/components/Select/hooks.ts +36 -1
  333. package/src/components/Select/index.ts +2 -1
  334. package/src/components/examples/PermissionExample.tsx +173 -0
  335. package/src/examples/CorrectPublicPageImplementation.tsx +301 -0
  336. package/src/examples/PublicEventPage.tsx +274 -0
  337. package/src/examples/PublicPageApp.tsx +308 -0
  338. package/src/examples/PublicPageUsageExample.tsx +216 -0
  339. package/src/hooks/__tests__/useOrganisationPermissions.unit.test.tsx +12 -1
  340. package/src/hooks/__tests__/useOrganisationSecurity.unit.test.tsx +129 -17
  341. package/src/hooks/__tests__/useRBAC.unit.test.ts +151 -846
  342. package/src/hooks/useOrganisationPermissions.test.ts +42 -18
  343. package/src/hooks/useOrganisationPermissions.ts +12 -6
  344. package/src/hooks/useOrganisationSecurity.test.ts +138 -85
  345. package/src/hooks/useOrganisationSecurity.ts +41 -10
  346. package/src/hooks/useSecureDataAccess.test.ts +32 -29
  347. package/src/index.ts +0 -1
  348. package/src/providers/AuthProvider.simplified.tsx +880 -0
  349. package/src/providers/UnifiedAuthProvider.test.simple.tsx +8 -8
  350. package/src/providers/__tests__/ProviderLifecycle.test.tsx +341 -0
  351. package/src/providers/__tests__/UnifiedAuthProvider.test.tsx +29 -19
  352. package/src/providers/index.ts +0 -1
  353. package/src/providers/services/EventServiceProvider.tsx +19 -15
  354. package/src/providers/services/InactivityServiceProvider.tsx +19 -15
  355. package/src/providers/services/OrganisationServiceProvider.tsx +19 -15
  356. package/src/providers/services/UnifiedAuthProvider.tsx +156 -127
  357. package/src/providers/services/__tests__/AuthServiceProvider.integration.test.tsx +1 -1
  358. package/src/providers/services/__tests__/UnifiedAuthProvider.integration.test.tsx +3 -3
  359. package/src/rbac/README.md +1 -1
  360. package/src/rbac/__tests__/adapters.comprehensive.test.tsx +25 -27
  361. package/src/rbac/__tests__/auth-rbac-security.integration.test.tsx +313 -0
  362. package/src/rbac/__tests__/engine.comprehensive.test.ts +114 -348
  363. package/src/rbac/__tests__/rbac-engine-core-logic.test.ts +28 -110
  364. package/src/rbac/__tests__/rbac-engine-simplified.test.ts +33 -85
  365. package/src/rbac/__tests__/scenarios.user-role.test.tsx +2 -2
  366. package/src/rbac/adapters.tsx +26 -69
  367. package/src/rbac/api.test.ts +90 -27
  368. package/src/rbac/api.ts +61 -10
  369. package/src/rbac/audit.test.ts +33 -38
  370. package/src/rbac/audit.ts +21 -6
  371. package/src/rbac/cache.ts +33 -1
  372. package/src/rbac/components/NavigationGuard.tsx +11 -11
  373. package/src/rbac/components/NavigationProvider.test.tsx +11 -5
  374. package/src/rbac/components/NavigationProvider.tsx +37 -13
  375. package/src/rbac/components/PagePermissionGuard.tsx +111 -50
  376. package/src/rbac/components/PagePermissionProvider.tsx +5 -5
  377. package/src/rbac/components/PermissionEnforcer.tsx +11 -11
  378. package/src/rbac/components/RoleBasedRouter.tsx +5 -5
  379. package/src/rbac/components/SecureDataProvider.tsx +5 -5
  380. package/src/rbac/components/__tests__/NavigationGuard.test.tsx +8 -8
  381. package/src/rbac/components/__tests__/PagePermissionGuard.test.tsx +14 -14
  382. package/src/rbac/components/__tests__/PermissionEnforcer.test.tsx +12 -12
  383. package/src/rbac/components/__tests__/RoleBasedRouter.test.tsx +6 -6
  384. package/src/rbac/engine.test.simple.ts +19 -13
  385. package/src/rbac/engine.test.ts +1 -0
  386. package/src/rbac/engine.ts +330 -766
  387. package/src/rbac/errors.ts +156 -0
  388. package/src/rbac/hooks/__tests__/usePermissions.integration.test.ts +437 -0
  389. package/src/rbac/hooks/index.ts +2 -0
  390. package/src/rbac/hooks/usePermissions.ts +32 -10
  391. package/src/rbac/hooks/useRBAC.test.ts +126 -512
  392. package/src/rbac/hooks/useRBAC.ts +147 -193
  393. package/src/rbac/hooks/useResolvedScope.ts +244 -0
  394. package/src/rbac/index.ts +7 -4
  395. package/src/rbac/security.ts +109 -18
  396. package/src/rbac/types.ts +12 -1
  397. package/src/services/AuthService.ts +2 -15
  398. package/src/services/EventService.ts +26 -46
  399. package/src/services/OrganisationService.ts +51 -31
  400. package/src/services/__tests__/AuthService.test.ts +1 -1
  401. package/src/services/__tests__/EventService.test.ts +1 -1
  402. package/src/services/__tests__/InactivityService.lifecycle.test.ts +411 -0
  403. package/src/services/__tests__/OrganisationService.pagination.test.ts +375 -0
  404. package/src/services/__tests__/OrganisationService.test.ts +1 -1
  405. package/src/styles/base.css +208 -0
  406. package/src/styles/semantic.css +24 -0
  407. package/src/types/__tests__/README.md +114 -0
  408. package/src/types/__tests__/validation.test.ts +731 -0
  409. package/src/types/database.generated.ts +7347 -0
  410. package/src/types/database.ts +20 -0
  411. package/src/utils/__tests__/file-reference.test.ts +383 -0
  412. package/src/utils/__tests__/performanceBenchmark.test.ts +175 -0
  413. package/src/utils/appNameResolver.test.ts +54 -0
  414. package/src/utils/logger.ts +179 -0
  415. package/src/utils/organisationContext.ts +11 -4
  416. package/src/utils/storage/__tests__/helpers.unit.test.ts +6 -2
  417. package/src/validation/__tests__/csrf.unit.test.ts +63 -0
  418. package/src/validation/__tests__/passwordSchema.unit.test.ts +105 -0
  419. package/dist/DataTable-HWZQGASI.js +0 -102
  420. package/dist/appNameResolver-UURKN7NF.js +0 -22
  421. package/dist/audit-6TOCAMKO.js.map +0 -1
  422. package/dist/chunk-2CHATWBF.js +0 -523
  423. package/dist/chunk-2CHATWBF.js.map +0 -1
  424. package/dist/chunk-2DFZ432F.js.map +0 -1
  425. package/dist/chunk-33PHABLB.js.map +0 -1
  426. package/dist/chunk-B2WTCLCV.js.map +0 -1
  427. package/dist/chunk-CY3AHGO4.js.map +0 -1
  428. package/dist/chunk-DAXLNIDY.js.map +0 -1
  429. package/dist/chunk-FGMFQSHX.js.map +0 -1
  430. package/dist/chunk-TYHR5X4W.js +0 -33
  431. package/dist/chunk-TYHR5X4W.js.map +0 -1
  432. package/dist/chunk-ULBI5JGB.js +0 -109
  433. package/dist/chunk-ULBI5JGB.js.map +0 -1
  434. package/dist/chunk-WN6XJWOS.js.map +0 -1
  435. package/dist/chunk-XLZ7U46Z.js.map +0 -1
  436. package/dist/chunk-YNUBMSMV.js.map +0 -1
  437. package/dist/chunk-ZTT2AXMX.js.map +0 -1
  438. package/dist/eventContext-BBA42P6G.js +0 -14
  439. package/dist/eventContext-BBA42P6G.js.map +0 -1
  440. package/docs/DOCUMENTATION_CHECKLIST.md +0 -281
  441. package/docs/api/interfaces/RBACContextType.md +0 -468
  442. package/docs/api/interfaces/RBACProviderProps.md +0 -107
  443. package/docs/breaking-changes.md +0 -179
  444. package/docs/consuming-app-example.md +0 -290
  445. package/docs/documentation-style-checklist.md +0 -294
  446. package/docs/examples/navigation-menu-auth-fix.md +0 -344
  447. package/docs/getting-started/examples/basic-auth-app.md +0 -520
  448. package/docs/getting-started/examples/full-featured-app.md +0 -616
  449. package/docs/getting-started/quick-start.md +0 -426
  450. package/docs/implementation-guides/datatable-filtering.md +0 -313
  451. package/docs/implementation-guides/datatable-rbac-usage.md +0 -317
  452. package/docs/implementation-guides/hierarchical-datatable.md +0 -850
  453. package/docs/implementation-guides/large-datasets.md +0 -281
  454. package/docs/implementation-guides/performance.md +0 -403
  455. package/docs/migration/quick-migration-guide.md +0 -320
  456. package/docs/migration-guide.md +0 -193
  457. package/docs/migration-guides/unified-auth-provider-mandatory-timeouts.md +0 -226
  458. package/docs/performance/README.md +0 -551
  459. package/docs/style-guide.md +0 -925
  460. package/docs/troubleshooting/authentication-issues.md +0 -334
  461. package/docs/troubleshooting/debugging.md +0 -1117
  462. package/docs/troubleshooting/migration.md +0 -918
  463. package/src/__tests__/hooks/usePermissions.test.ts +0 -261
  464. package/src/components/DataTable/components/DataTableBody.tsx +0 -488
  465. package/src/components/DataTable/components/DraggableColumnHeader.tsx +0 -144
  466. package/src/components/DataTable/components/VirtualizedDataTable.tsx +0 -515
  467. package/src/components/DataTable/core/ActionManager.ts +0 -235
  468. package/src/components/DataTable/core/ColumnManager.ts +0 -215
  469. package/src/components/DataTable/core/DataManager.ts +0 -188
  470. package/src/components/DataTable/core/DataTableContext.tsx +0 -181
  471. package/src/components/DataTable/core/LocalDataAdapter.ts +0 -264
  472. package/src/components/DataTable/core/PluginRegistry.ts +0 -229
  473. package/src/components/DataTable/core/StateManager.ts +0 -311
  474. package/src/components/DataTable/core/__tests__/ActionManager.test.ts +0 -634
  475. package/src/components/DataTable/core/__tests__/ColumnManager.test.ts +0 -193
  476. package/src/components/DataTable/core/__tests__/DataManager.test.ts +0 -519
  477. package/src/components/DataTable/core/__tests__/StateManager.test.ts +0 -714
  478. package/src/components/DataTable/core/interfaces.ts +0 -338
  479. package/src/components/PaceAppLayout/__tests__/PaceAppLayout.rbac.test.tsx +0 -574
  480. package/src/components/Select/Select.bug-test.tsx +0 -69
  481. package/src/components/Select/Select.refactored.tsx +0 -497
  482. package/src/hooks/__tests__/ServiceHooks.test.tsx +0 -613
  483. package/src/hooks/services/usePermissions.ts +0 -70
  484. package/src/hooks/services/useRBACService.ts +0 -30
  485. package/src/hooks/usePermissionCheck.ts +0 -150
  486. package/src/providers/__tests__/ServiceProviders.test.tsx +0 -477
  487. package/src/providers/services/RBACServiceProvider.tsx +0 -79
  488. package/src/rbac/__tests__/integration.authflow.test.tsx +0 -119
  489. package/src/rbac/__tests__/integration.navigation.test.tsx +0 -69
  490. package/src/rbac/__tests__/integration.securedata.test.tsx +0 -92
  491. package/src/rbac/__tests__/integration.smoke.test.tsx +0 -73
  492. package/src/rbac/providers/RBACProvider.tsx +0 -645
  493. package/src/rbac/providers/__tests__/RBACProvider.integration.test.tsx +0 -688
  494. package/src/rbac/providers/__tests__/RBACProvider.test.tsx +0 -1186
  495. package/src/rbac/providers/index.ts +0 -11
  496. package/src/services/RBACService.ts +0 -522
  497. package/src/services/__tests__/RBACService.test.ts +0 -492
  498. package/src/services/interfaces/IRBACService.ts +0 -62
  499. package/src/utils/appNameResolver.test 2.ts +0 -494
  500. /package/dist/{DataTable-HWZQGASI.js.map → DataTable-QCNCV6IK.js.map} +0 -0
  501. /package/dist/{UnifiedAuthProvider-3NKDOSOK.js.map → UnifiedAuthProvider-Z2FWNW7O.js.map} +0 -0
  502. /package/dist/{api-DDMUKIUD.js.map → api-KG4A2X7P.js.map} +0 -0
  503. /package/dist/{appNameResolver-UURKN7NF.js.map → audit-65VNHEV2.js.map} +0 -0
  504. /package/dist/{chunk-LW7MMEAQ.js.map → chunk-CRKP3HXI.js.map} +0 -0
  505. /package/dist/{chunk-URUTVZ7N.js.map → chunk-DVHZ5L55.js.map} +0 -0
  506. /package/dist/{chunk-NTNILOBC.js.map → chunk-TLD5BEU6.js.map} +0 -0
  507. /package/docs/{app.css.example → styles/app.css.example} +0 -0
@@ -1,3 +1,9 @@
1
+ ---
2
+ lastUpdated: 2025-10-29T22:43:00+11:00
3
+ version: 0.5.76
4
+ reviewedBy: content-audit
5
+ ---
6
+
1
7
  # Utilities API Reference
2
8
 
3
9
  This section provides detailed documentation for all utility functions in `@jmruthers/pace-core`.
@@ -378,6 +384,207 @@ import { sanitizeFormData } from '@jmruthers/pace-core';
378
384
  const sanitizedData = sanitizeFormData(formData);
379
385
  ```
380
386
 
387
+ ## Utility Functions
388
+
389
+ ### cn (ClassName Merge)
390
+
391
+ Utility for merging Tailwind CSS classes with conflict resolution.
392
+
393
+ ```typescript
394
+ function cn(...inputs: ClassValue[]): string;
395
+ ```
396
+
397
+ #### Usage
398
+
399
+ ```typescript
400
+ import { cn } from '@jmruthers/pace-core';
401
+
402
+ // Merge classes
403
+ cn('px-4 py-2', 'bg-main-500', 'hover:bg-main-600')
404
+
405
+ // Conditional classes
406
+ cn('base-class', isActive && 'active-class', isDisabled && 'disabled-class')
407
+
408
+ // Override conflicts (last one wins)
409
+ cn('px-4', 'px-2') // Returns 'px-2'
410
+ ```
411
+
412
+ ### formatCurrency
413
+
414
+ Format a number as currency.
415
+
416
+ ```typescript
417
+ function formatCurrency(
418
+ value: number,
419
+ currencyCode?: string,
420
+ locale?: string
421
+ ): string;
422
+ ```
423
+
424
+ #### Usage
425
+
426
+ ```typescript
427
+ import { formatCurrency } from '@jmruthers/pace-core';
428
+
429
+ formatCurrency(1234.56) // '$1,234.56'
430
+ formatCurrency(1234.56, 'EUR') // '€1,234.56'
431
+ formatCurrency(1234.56, 'USD', 'en-AU') // '$1,234.56'
432
+ ```
433
+
434
+ ### formatNumber
435
+
436
+ Format a number with custom Intl.NumberFormat options.
437
+
438
+ ```typescript
439
+ function formatNumber(
440
+ value: number,
441
+ options?: Intl.NumberFormatOptions,
442
+ locale?: string
443
+ ): string;
444
+ ```
445
+
446
+ #### Usage
447
+
448
+ ```typescript
449
+ import { formatNumber } from '@jmruthers/pace-core';
450
+
451
+ formatNumber(1234.56, { minimumFractionDigits: 2, maximumFractionDigits: 2 })
452
+ formatNumber(1234.56, { style: 'decimal', minimumFractionDigits: 0 })
453
+ ```
454
+
455
+ ### formatPercent
456
+
457
+ Format a number as a percentage.
458
+
459
+ ```typescript
460
+ function formatPercent(
461
+ value: number,
462
+ locale?: string,
463
+ decimals?: number
464
+ ): string;
465
+ ```
466
+
467
+ #### Usage
468
+
469
+ ```typescript
470
+ import { formatPercent } from '@jmruthers/pace-core';
471
+
472
+ formatPercent(45.5) // '45.5%'
473
+ formatPercent(45.5, 'en-US', 2) // '45.50%'
474
+ ```
475
+
476
+ ### formatCompactNumber
477
+
478
+ Format large numbers with K, M, B abbreviations.
479
+
480
+ ```typescript
481
+ function formatCompactNumber(value: number, locale?: string): string;
482
+ ```
483
+
484
+ #### Usage
485
+
486
+ ```typescript
487
+ import { formatCompactNumber } from '@jmruthers/pace-core';
488
+
489
+ formatCompactNumber(1000) // '1K'
490
+ formatCompactNumber(1500000) // '1.5M'
491
+ formatCompactNumber(2300000000) // '2.3B'
492
+ ```
493
+
494
+ ### formatFileSize
495
+
496
+ Format file size in bytes to human-readable string.
497
+
498
+ ```typescript
499
+ function formatFileSize(bytes: number): string;
500
+ ```
501
+
502
+ #### Usage
503
+
504
+ ```typescript
505
+ import { formatFileSize } from '@jmruthers/pace-core';
506
+
507
+ formatFileSize(1024) // '1 KB'
508
+ formatFileSize(1048576) // '1 MB'
509
+ formatFileSize(0) // '0 Bytes'
510
+ ```
511
+
512
+ ### App Configuration Utilities
513
+
514
+ #### setAppConfig
515
+
516
+ Set the current application configuration.
517
+
518
+ ```typescript
519
+ function setAppConfig(config: AppConfig): void;
520
+
521
+ interface AppConfig {
522
+ appName: string;
523
+ appId: string;
524
+ }
525
+ ```
526
+
527
+ #### Usage
528
+
529
+ ```typescript
530
+ import { setAppConfig } from '@jmruthers/pace-core';
531
+
532
+ setAppConfig({
533
+ appName: 'My App',
534
+ appId: 'my-app-id'
535
+ });
536
+ ```
537
+
538
+ #### getAppConfig
539
+
540
+ Get the current application configuration.
541
+
542
+ ```typescript
543
+ function getAppConfig(): AppConfig;
544
+ ```
545
+
546
+ #### Usage
547
+
548
+ ```typescript
549
+ import { getAppConfig } from '@jmruthers/pace-core';
550
+
551
+ const config = getAppConfig();
552
+ console.log(config.appName); // 'My App'
553
+ console.log(config.appId); // 'my-app-id'
554
+ ```
555
+
556
+ #### getCurrentAppName
557
+
558
+ Get the current app name.
559
+
560
+ ```typescript
561
+ function getCurrentAppName(): string;
562
+ ```
563
+
564
+ #### Usage
565
+
566
+ ```typescript
567
+ import { getCurrentAppName } from '@jmruthers/pace-core';
568
+
569
+ const appName = getCurrentAppName(); // 'My App'
570
+ ```
571
+
572
+ #### getCurrentAppId
573
+
574
+ Get the current app ID.
575
+
576
+ ```typescript
577
+ function getCurrentAppId(): string;
578
+ ```
579
+
580
+ #### Usage
581
+
582
+ ```typescript
583
+ import { getCurrentAppId } from '@jmruthers/pace-core';
584
+
585
+ const appId = getCurrentAppId(); // 'my-app-id'
586
+ ```
587
+
381
588
  ## Date and Time Utilities
382
589
 
383
590
  ### formatDate
@@ -1,3 +1,9 @@
1
+ ---
2
+ lastUpdated: 2025-10-29T22:43:00+11:00
3
+ version: 0.5.76
4
+ reviewedBy: content-audit
5
+ ---
6
+
1
7
  # PACE Core Architecture
2
8
 
3
9
  This document provides a comprehensive overview of the PACE Core architecture, including system design, component relationships, and architectural decisions. This is the single source of truth for PACE Core's architectural documentation.
@@ -1,3 +1,9 @@
1
+ ---
2
+ lastUpdated: 2025-10-29T22:43:00+11:00
3
+ version: 0.5.76
4
+ reviewedBy: content-audit
5
+ ---
6
+
1
7
  # Database Schema Requirements
2
8
 
3
9
  This document outlines the required database tables and schema for the `@jmruthers/pace-core` package to function correctly.
@@ -0,0 +1,258 @@
1
+ ---
2
+ lastUpdated: 2025-10-29T22:43:00+11:00
3
+ version: 0.5.76
4
+ reviewedBy: content-audit
5
+ ---
6
+
7
+ # RBAC Security Architecture
8
+
9
+ **Last Updated**: 2024
10
+
11
+ ## Overview
12
+
13
+ This document describes the security architecture of the RBAC (Role-Based Access Control) system in `@jmruthers/pace-core`. The system is designed with **defense in depth** and **fail-secure** principles.
14
+
15
+ ## Architecture Principles
16
+
17
+ ### 1. Database-First Authority
18
+
19
+ **Principle**: The database is the single source of truth for all permission decisions. Client-side metadata is never trusted.
20
+
21
+ **Implementation**:
22
+ - All permission checks query the database via secure RPC functions
23
+ - Super admin status is checked via `rbac_global_roles` table, never from `user_metadata`
24
+ - Organisation membership is validated via `rbac_organisation_roles` table
25
+ - Event access is validated via `rbac_event_app_roles` table
26
+
27
+ **Security Benefit**: Prevents privilege escalation by spoofing `user_metadata`.
28
+
29
+ ### 2. Organisation Context Enforcement
30
+
31
+ **Principle**: All permission checks require organisation context and are scoped to that context.
32
+
33
+ **Implementation**:
34
+ - Every permission check includes `organisationId` as a required parameter
35
+ - Database queries automatically filter by `organisationId` via RLS policies
36
+ - Organisation membership is validated before any permission resolution
37
+
38
+ **Security Benefit**: Prevents cross-tenant data leakage.
39
+
40
+ ### 3. Row-Level Security (RLS)
41
+
42
+ **Principle**: Database-level policies enforce data isolation at the lowest level.
43
+
44
+ **Implementation**:
45
+ - All RBAC tables have RLS policies that restrict access to the user's organisation
46
+ - Policies use `auth.uid()` for automatic context injection
47
+ - Super admins bypass RLS via `auth.jwt() ->> 'global_role' = 'super_admin'`
48
+
49
+ **Security Benefit**: Even if application logic fails, the database prevents unauthorized access.
50
+
51
+ ### 4. Fail-Secure Design
52
+
53
+ **Principle**: On any error, ambiguity, or uncertainty, access is denied.
54
+
55
+ **Implementation**:
56
+ - Permission check errors return `false` (denied)
57
+ - Missing organisation context returns `false` (denied)
58
+ - Invalid input returns `false` (denied)
59
+ - Database errors return `false` (denied)
60
+
61
+ **Security Benefit**: Minimizes impact of bugs or vulnerabilities.
62
+
63
+ ### 5. Deny-Override-Allow Precedence
64
+
65
+ **Principle**: Denials always override allows. If a user is explicitly denied a permission, no allow can override it.
66
+
67
+ **Implementation**:
68
+ ```typescript
69
+ // Permission resolution order:
70
+ // 1. Check for explicit deny
71
+ // 2. If no deny, check for allow
72
+ // 3. If neither, deny by default
73
+ ```
74
+
75
+ **Security Benefit**: Explicit deny is never accidentally overridden by a more permissive role.
76
+
77
+ ## Security Layers
78
+
79
+ ### Layer 1: Input Validation
80
+
81
+ **Location**: `packages/core/src/rbac/security.ts`
82
+
83
+ Validates and sanitizes all inputs before processing:
84
+ - Permission string format: `operation:resource` (e.g., "read:users")
85
+ - UUID format validation for all IDs
86
+ - Organisation ID presence and format
87
+ - Input sanitization to prevent injection attacks
88
+
89
+ ### Layer 2: Rate Limiting
90
+
91
+ **Location**: `packages/core/src/rbac/security.ts`
92
+
93
+ Prevents abuse with configurable rate limits:
94
+ - Max requests per minute per user
95
+ - Suspicious activity detection
96
+ - Automatic blocking after threshold
97
+
98
+ ### Layer 3: Permission Resolution
99
+
100
+ **Location**: `packages/core/src/rbac/engine.ts`
101
+
102
+ Database-backed permission resolution:
103
+ - Check explicit denies
104
+ - Check explicit allows
105
+ - Check role-based permissions
106
+ - Check organisation membership
107
+ - Check event access (if applicable)
108
+
109
+ ### Layer 4: Row-Level Security
110
+
111
+ **Location**: Supabase database policies
112
+
113
+ Database-level enforcement that applies even if application logic is bypassed:
114
+ - Automatic context filtering by `organisationId`
115
+ - User-specific data access via `auth.uid()`
116
+ - Super admin bypass via JWT claims
117
+
118
+ ### Layer 5: Audit Logging
119
+
120
+ **Location**: `packages/core/src/rbac/engine.ts`
121
+
122
+ Comprehensive logging for security analysis:
123
+ - All permission checks are logged
124
+ - Denials are logged with full context
125
+ - Rate limit violations are logged
126
+ - Security events are logged with severity levels
127
+
128
+ ## Security Features
129
+
130
+ ### Super Admin Checks
131
+
132
+ Super admin status is **never** checked from client-provided metadata. It is always queried from the database:
133
+
134
+ ```typescript
135
+ // ✅ CORRECT: Database query
136
+ const { data } = await supabase
137
+ .from('rbac_global_roles')
138
+ .select('role')
139
+ .eq('user_id', userId)
140
+ .eq('role', 'super_admin')
141
+ .limit(1);
142
+ const isSuperAdmin = data && data.length > 0;
143
+
144
+ // ❌ WRONG: Client metadata (spoofable)
145
+ const isSuperAdmin = user.user_metadata?.globalRole === 'super_admin';
146
+ ```
147
+
148
+ ### Organisation Context Validation
149
+
150
+ Every permission check validates organisation membership:
151
+
152
+ ```typescript
153
+ // 1. Check organisation membership
154
+ const membership = await supabase
155
+ .from('rbac_organisation_roles')
156
+ .select('organisation_id, role, status')
157
+ .eq('user_id', userId)
158
+ .eq('organisation_id', organisationId)
159
+ .eq('status', 'active')
160
+ .single();
161
+
162
+ if (!membership) {
163
+ return false; // Fail-secure: deny if not a member
164
+ }
165
+ ```
166
+
167
+ ### Permission Cache Security
168
+
169
+ Caching improves performance but must be secure:
170
+ - Cache keys include `userId` and `organisationId` to prevent cross-user leaks
171
+ - Cache is invalidated on role changes via Supabase realtime
172
+ - Cache TTL is short (60 seconds) to limit stale data exposure
173
+
174
+ ## Threat Model
175
+
176
+ ### Threat 1: Privilege Escalation
177
+
178
+ **Attack**: User modifies client-side `user_metadata` to claim super admin role.
179
+
180
+ **Mitigation**: Super admin status is always checked via database query, never from metadata.
181
+
182
+ **Status**: ✅ Mitigated
183
+
184
+ ### Threat 2: Cross-Organisation Data Leakage
185
+
186
+ **Attack**: User requests data with a different `organisationId` than their membership.
187
+
188
+ **Mitigation**: RLS policies and application-level checks ensure users can only access their organisation's data.
189
+
190
+ **Status**: ✅ Mitigated
191
+
192
+ ### Threat 3: Cache-Based Attacks
193
+
194
+ **Attack**: Malicious user exploits cache to access another user's permissions.
195
+
196
+ **Mitigation**: Cache keys include `userId`, preventing cross-user access. Cache invalidation on changes.
197
+
198
+ **Status**: ✅ Mitigated
199
+
200
+ ### Threat 4: Race Conditions
201
+
202
+ **Attack**: Exploiting concurrent permission checks to bypass security.
203
+
204
+ **Mitigation**: Rate limiting and atomic database transactions prevent race conditions.
205
+
206
+ **Status**: ✅ Mitigated
207
+
208
+ ### Threat 5: Injection Attacks
209
+
210
+ **Attack**: Injecting malicious data into permission checks.
211
+
212
+ **Mitigation**: Input validation and sanitization, parameterized queries only.
213
+
214
+ **Status**: ✅ Mitigated
215
+
216
+ ## Security Best Practices
217
+
218
+ ### For Developers
219
+
220
+ 1. **Always provide organisation context**: Never call permission checks without `organisationId`
221
+ 2. **Use `useRBAC()` hook**: This hook enforces security by default
222
+ 3. **Never trust client data**: Always re-validate on the server
223
+ 4. **Use `PagePermissionGuard`**: Declarative permission checks reduce bugs
224
+ 5. **Log security events**: Use audit logging for suspicious activity
225
+
226
+ ### For Security Reviewers
227
+
228
+ 1. **Review RLS policies**: Ensure all tables have proper RLS policies
229
+ 2. **Check cache invalidation**: Verify cache clears on all role changes
230
+ 3. **Audit super admin checks**: Ensure no code path uses `user_metadata` for super admin
231
+ 4. **Test fail-secure behavior**: Verify errors result in denial, not approval
232
+ 5. **Review rate limiting**: Ensure limits are appropriate for the application
233
+
234
+ ## Compliance
235
+
236
+ ### GDPR
237
+
238
+ - ✅ Data access is logged with user context
239
+ - ✅ Organisation data is isolated via RLS
240
+ - ✅ Right to be forgotten is supported via user deletion
241
+
242
+ ### SOC 2
243
+
244
+ - ✅ Access control is enforced at multiple layers
245
+ - ✅ Audit logging is comprehensive
246
+ - ✅ Changes to permissions are tracked
247
+
248
+ ### ISO 27001
249
+
250
+ - ✅ Defense in depth architecture
251
+ - ✅ Fail-secure design
252
+ - ✅ Principle of least privilege
253
+
254
+ ## References
255
+
256
+ - [RBAC Implementation](rbac-implementation.md)
257
+ - [RLS Policies](../migration/rls-policies.md)
258
+ - [Security Testing](../testing/security-testing.md)
@@ -1,3 +1,9 @@
1
+ ---
2
+ lastUpdated: 2025-10-29T22:43:00+11:00
3
+ version: 0.5.76
4
+ reviewedBy: content-audit
5
+ ---
6
+
1
7
  # Service Architecture Documentation
2
8
 
3
9
  ## Overview
@@ -11,11 +17,13 @@ The pace-core library now uses a service-based architecture that follows SOLID p
11
17
  The service layer contains pure TypeScript classes that handle business logic without any React dependencies:
12
18
 
13
19
  - **AuthService**: Authentication operations (sign in, sign out, session management)
14
- - **RBACService**: Role and permission management
20
+ - **RBACService**: Role and permission management ⚠️ **DEPRECATED** - Use RBAC Engine instead
15
21
  - **OrganisationService**: Organisation management and selection
16
22
  - **EventService**: Event management and selection
17
23
  - **InactivityService**: User inactivity tracking
18
24
 
25
+ > **⚠️ Note**: RBACService is deprecated in favor of the new RBAC system. Use `useRBAC()` from `@jmruthers/pace-core/rbac` instead.
26
+
19
27
  ### Provider Layer (React Context)
20
28
 
21
29
  Each service has its own React provider that:
@@ -1,3 +1,9 @@
1
+ ---
2
+ lastUpdated: 2025-10-29T22:43:00+11:00
3
+ version: 0.5.76
4
+ reviewedBy: content-audit
5
+ ---
6
+
1
7
  # Best Practices
2
8
 
3
9
  > **🎯 Build Better Apps** | [Security](#security) | [Performance](#performance) | [Testing](#testing) | [Deployment](#deployment)
@@ -16,6 +22,26 @@ Comprehensive best practices for building secure, performant, and maintainable a
16
22
  - [Accessibility](#-accessibility)
17
23
  - [Maintenance](#-maintenance)
18
24
 
25
+ ## Core Topics
26
+
27
+ ### Security
28
+ - [**Security Best Practices**](./security.md) - Security guidelines and secure coding patterns
29
+
30
+ ### Accessibility
31
+ - [**Accessibility Guide**](./accessibility.md) - WCAG compliance and inclusive design
32
+
33
+ ### Performance
34
+ - [**Performance Optimization**](./performance.md) - Basic optimization strategies
35
+ - [**Advanced Performance**](./performance-expansion.md) - Advanced optimization techniques
36
+
37
+ ### Testing
38
+ - [**Testing Best Practices**](./testing.md) - Testing strategies and patterns
39
+
40
+ ### Deployment
41
+ - [**Deployment Guide**](./deployment.md) - Production deployment guidelines
42
+
43
+ ---
44
+
19
45
  ## 🔒 Security Best Practices
20
46
 
21
47
  ### Authentication & Authorization