@goplusvn/core 0.1.0 → 0.1.2

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 (591) hide show
  1. package/package.json +31 -175
  2. package/src/assets/erp_wallpaper.png +0 -0
  3. package/src/assets/goeat_logo.png +0 -0
  4. package/src/audit/audit-manager.ts +139 -0
  5. package/src/audit/index.ts +11 -0
  6. package/src/audit/memory-audit-logger.ts +86 -0
  7. package/src/audit/types.ts +50 -0
  8. package/src/auth/auth-service.ts +97 -0
  9. package/src/auth/index.ts +266 -0
  10. package/src/code-generation/index.ts +69 -0
  11. package/src/configs/auth-routes.ts +17 -0
  12. package/src/configs/crud.ts +136 -0
  13. package/src/configs/data/navigations.ts +781 -0
  14. package/src/configs/data/oauth-links.ts +10 -0
  15. package/src/configs/entities/material-categories.config.ts +125 -0
  16. package/src/configs/i18n.ts +12 -0
  17. package/src/configs/index.ts +26 -0
  18. package/src/configs/status.ts +25 -0
  19. package/src/configs/themes.ts +100 -0
  20. package/src/crud/components/crud-bulk-actions.tsx +91 -0
  21. package/src/crud/components/crud-card-view.tsx +241 -0
  22. package/src/crud/components/crud-context.tsx +122 -0
  23. package/src/crud/components/crud-delete-dialog.tsx +145 -0
  24. package/src/crud/components/crud-dialog.tsx +406 -0
  25. package/src/crud/components/crud-empty-state.tsx +104 -0
  26. package/src/crud/components/crud-export-button.tsx +170 -0
  27. package/src/crud/components/crud-field-renderer.tsx +653 -0
  28. package/src/crud/components/crud-filter-chips.tsx +102 -0
  29. package/src/crud/components/crud-filters/checkbox-filter.tsx +97 -0
  30. package/src/crud/components/crud-filters/datetime-filter.tsx +83 -0
  31. package/src/crud/components/crud-filters/filter-builder.tsx +66 -0
  32. package/src/crud/components/crud-filters/index.tsx +76 -0
  33. package/src/crud/components/crud-filters/radio-filter.tsx +86 -0
  34. package/src/crud/components/crud-filters/select-filter.tsx +141 -0
  35. package/src/crud/components/crud-filters/text-filter.tsx +86 -0
  36. package/src/crud/components/crud-form.tsx +642 -0
  37. package/src/crud/components/crud-import-dialog.tsx +440 -0
  38. package/src/crud/components/crud-infinite-scroll.tsx +116 -0
  39. package/src/crud/components/crud-page.tsx +1017 -0
  40. package/src/crud/components/crud-provider.tsx +277 -0
  41. package/src/crud/components/crud-row-actions.tsx +189 -0
  42. package/src/crud/components/crud-search.tsx +82 -0
  43. package/src/crud/components/crud-sheet.tsx +336 -0
  44. package/src/crud/components/crud-table-skeleton.tsx +26 -0
  45. package/src/crud/components/crud-table-toolbar.tsx +91 -0
  46. package/src/crud/components/crud-table.tsx +352 -0
  47. package/src/crud/components/crud-virtual-table.tsx +55 -0
  48. package/src/crud/components/index.tsx +20 -0
  49. package/src/crud/crud-filters/checkbox-filter.tsx +87 -0
  50. package/src/crud/crud-filters/datetime-filter.tsx +82 -0
  51. package/src/crud/crud-filters/filter-builder.tsx +64 -0
  52. package/src/crud/crud-filters/index.tsx +78 -0
  53. package/src/crud/crud-filters/radio-filter.tsx +79 -0
  54. package/src/crud/crud-filters/select-filter.tsx +148 -0
  55. package/src/crud/crud-filters/text-filter.tsx +81 -0
  56. package/src/crud/index.ts +43 -0
  57. package/src/crud/lib/crud-service.test.ts +334 -0
  58. package/src/crud/lib/crud-service.ts +358 -0
  59. package/src/crud/lib/crud-utils.test.ts +354 -0
  60. package/src/crud/lib/crud-utils.ts +299 -0
  61. package/src/crud/lib/crud-validator.ts +247 -0
  62. package/src/crud/lib/data-loader.ts +234 -0
  63. package/src/crud/lib/field-calculator.ts +241 -0
  64. package/src/crud/lib/field-formatter.ts +240 -0
  65. package/src/crud/lib/import-export-service.test.ts +290 -0
  66. package/src/crud/lib/import-export-service.ts +352 -0
  67. package/src/crud/lib/import-server-utils.ts +109 -0
  68. package/src/crud/lib/lazy-loader.ts +241 -0
  69. package/src/crud/lib/parse-filters.ts +85 -0
  70. package/src/crud/lib/permissions.ts +52 -0
  71. package/src/crud/lib/serialize-config.ts +60 -0
  72. package/src/crud/lib/stream-loader.ts +145 -0
  73. package/src/crud/lib/translate-config.ts +335 -0
  74. package/src/crud/lib/types.ts +11 -0
  75. package/src/crud/pages/entity-crud-page.tsx +144 -0
  76. package/src/crud/server.ts +8 -0
  77. package/src/home/constants.tsx +142 -0
  78. package/src/home/feature-showcase.tsx +171 -0
  79. package/src/home/home-page.tsx +191 -0
  80. package/src/home/hooks/index.ts +1 -0
  81. package/src/home/hooks/useWidgetPreferences.ts +167 -0
  82. package/src/home/index.ts +33 -0
  83. package/src/home/quick-access-dialog.tsx +271 -0
  84. package/src/home/quick-access-menu.tsx +267 -0
  85. package/src/home/types.ts +140 -0
  86. package/src/home/welcome-card.tsx +92 -0
  87. package/src/home/widget-container.tsx +258 -0
  88. package/src/home/widgets/base-widget.tsx +200 -0
  89. package/src/home/widgets/customers-widget.tsx +74 -0
  90. package/src/home/widgets/index.ts +6 -0
  91. package/src/home/widgets/orders-widget.tsx +87 -0
  92. package/src/home/widgets/revenue-widget.tsx +71 -0
  93. package/src/home/widgets/stock-widget.tsx +109 -0
  94. package/src/hooks/index.tsx +598 -0
  95. package/src/hooks/use-tenant.test.tsx +30 -0
  96. package/src/hooks/use-tenant.ts +5 -0
  97. package/src/index.ts +17 -0
  98. package/src/infrastructure/__tests__/architecture-verification.spec.ts +103 -0
  99. package/src/infrastructure/api-service.ts +317 -0
  100. package/src/infrastructure/cache/cache-manager.ts +107 -0
  101. package/src/infrastructure/cache/cache.ts +120 -0
  102. package/src/infrastructure/cache/index.ts +8 -0
  103. package/src/infrastructure/cache/types.ts +48 -0
  104. package/src/infrastructure/cron/cron-manager.ts +239 -0
  105. package/src/infrastructure/cron/index.ts +6 -0
  106. package/src/infrastructure/cron/types.ts +41 -0
  107. package/src/infrastructure/event-bus/event-bus.ts +145 -0
  108. package/src/infrastructure/event-bus/index.ts +2 -0
  109. package/src/infrastructure/event-bus/types.ts +22 -0
  110. package/src/infrastructure/index.ts +32 -0
  111. package/src/infrastructure/lock/decorators.ts +67 -0
  112. package/src/infrastructure/lock/index.ts +2 -0
  113. package/src/infrastructure/lock/lock-manager.ts +33 -0
  114. package/src/infrastructure/logger/index.ts +2 -0
  115. package/src/infrastructure/logger/logger.ts +96 -0
  116. package/src/infrastructure/logger/types.ts +25 -0
  117. package/src/layout/index.tsx +185 -0
  118. package/src/navigation/index.ts +91 -0
  119. package/src/notification/index.ts +14 -0
  120. package/src/notification/notification-service.ts +120 -0
  121. package/src/notification/storage/in-memory.ts +56 -0
  122. package/src/notification/storage/index.ts +1 -0
  123. package/src/notification/types.ts +51 -0
  124. package/src/organization/branch-service.ts +299 -0
  125. package/src/organization/branches.config.ts +154 -0
  126. package/src/organization/index.ts +5 -0
  127. package/src/plugin/apps-registry.ts +97 -0
  128. package/src/plugin/index.ts +5 -0
  129. package/src/plugin/types.ts +41 -0
  130. package/src/providers/index.tsx +109 -0
  131. package/src/providers/tenant-provider.tsx +45 -0
  132. package/src/rbac/components/roles/role-card.tsx +158 -0
  133. package/src/rbac/components/roles/role-stats-cards.tsx +29 -0
  134. package/src/rbac/components/roles/role-toolbar.tsx +123 -0
  135. package/src/rbac/hooks/use-role-operations.ts +159 -0
  136. package/src/rbac/hooks/use-roles-data.ts +59 -0
  137. package/src/rbac/index.ts +297 -0
  138. package/src/rbac/lib/permission-helpers.ts +63 -0
  139. package/src/rbac/pages/action-list-page.tsx +25 -0
  140. package/src/rbac/pages/resource-list-page.tsx +25 -0
  141. package/src/rbac/pages/role-list-page.tsx +378 -0
  142. package/src/rbac/permission-service.ts +140 -0
  143. package/src/rbac/permissions.ts +135 -0
  144. package/src/rbac/resource-service.ts +115 -0
  145. package/src/rbac/resource-validator.ts +119 -0
  146. package/src/rbac/role-service.ts +165 -0
  147. package/src/rbac/server.ts +16 -0
  148. package/src/rbac/types.ts +38 -0
  149. package/src/schemas/action.schema.ts +66 -0
  150. package/src/schemas/branch.schema.ts +52 -0
  151. package/src/schemas/coming-soon-schema.ts +9 -0
  152. package/src/schemas/company.schema.ts +44 -0
  153. package/src/schemas/forgot-passward-schema.ts +9 -0
  154. package/src/schemas/index.ts +30 -0
  155. package/src/schemas/material-category.schema.ts +43 -0
  156. package/src/schemas/material-pricing.schema.ts +74 -0
  157. package/src/schemas/material.schema.ts +76 -0
  158. package/src/schemas/materials.ts +52 -0
  159. package/src/schemas/new-passward-schema.ts +15 -0
  160. package/src/schemas/partner-company.schema.ts +149 -0
  161. package/src/schemas/register-schema.ts +36 -0
  162. package/src/schemas/resource.schema.ts +133 -0
  163. package/src/schemas/role.schema.ts +11 -0
  164. package/src/schemas/sign-in-schema.ts +24 -0
  165. package/src/schemas/supplier-pricing.schema.ts +15 -0
  166. package/src/schemas/supplier.schema.ts +120 -0
  167. package/src/schemas/system-category-group.schema.ts +67 -0
  168. package/src/schemas/system-category.schema.ts +77 -0
  169. package/src/schemas/system-config.schema.ts +118 -0
  170. package/src/schemas/uom.schema.ts +75 -0
  171. package/src/schemas/user-supplier.schema.ts +179 -0
  172. package/src/schemas/user.schema.ts +18 -0
  173. package/src/schemas/verify-email-schema.ts +9 -0
  174. package/src/schemas/warehouse.schema.ts +49 -0
  175. package/src/system/components/categories/category-list.tsx +529 -0
  176. package/src/system/components/categories/category-manager.tsx +89 -0
  177. package/src/system/components/categories/group-sidebar.tsx +308 -0
  178. package/src/system/components/settings/setting-dialogs.tsx +197 -0
  179. package/src/system/components/settings/setting-field.tsx +291 -0
  180. package/src/system/components/settings/setting-form-dialog.tsx +308 -0
  181. package/src/system/components/settings/settings-groups.ts +80 -0
  182. package/src/system/components/settings/settings-search.tsx +71 -0
  183. package/src/system/components/settings/settings-section.tsx +74 -0
  184. package/src/system/components/settings/settings-sidebar.tsx +81 -0
  185. package/src/system/constants.ts +3 -0
  186. package/src/system/index.ts +150 -0
  187. package/src/system/job-manager.ts +176 -0
  188. package/src/system/pages/components/categories/category-list.tsx +537 -0
  189. package/src/system/pages/components/categories/category-manager.tsx +90 -0
  190. package/src/system/pages/components/categories/group-sidebar.tsx +311 -0
  191. package/src/system/pages/components/settings/sales-rules-settings.tsx +222 -0
  192. package/src/system/pages/components/settings/setting-dialogs.tsx +197 -0
  193. package/src/system/pages/components/settings/setting-field.tsx +292 -0
  194. package/src/system/pages/components/settings/setting-form-dialog.tsx +308 -0
  195. package/src/system/pages/components/settings/settings-groups.ts +87 -0
  196. package/src/system/pages/components/settings/settings-page.tsx +372 -0
  197. package/src/system/pages/components/settings/settings-search.tsx +71 -0
  198. package/src/system/pages/components/settings/settings-section.tsx +74 -0
  199. package/src/system/pages/components/settings/settings-sidebar.tsx +81 -0
  200. package/src/system/pages/components/settings/system-settings.tsx +244 -0
  201. package/src/system/pages/system-category-page.tsx +15 -0
  202. package/src/system/pages/system-settings-page.tsx +380 -0
  203. package/src/system/schemas/system-category-group.schema.ts +46 -0
  204. package/src/system/schemas/system-category.schema.ts +56 -0
  205. package/src/system/services/settings-service.ts +127 -0
  206. package/src/system/services/system-category-service.ts +63 -0
  207. package/src/system/types.ts +45 -0
  208. package/src/types/index.ts +703 -0
  209. package/src/ui/auth/auth-layout.tsx +135 -0
  210. package/src/ui/auth/forgot-password-form.tsx +98 -0
  211. package/src/ui/auth/index.tsx +7 -0
  212. package/src/ui/auth/new-password-form.tsx +107 -0
  213. package/src/ui/auth/oauth-links.tsx +30 -0
  214. package/src/ui/auth/register-form.tsx +202 -0
  215. package/src/ui/auth/sign-in-form.tsx +238 -0
  216. package/src/ui/auth/verify-email-form.tsx +104 -0
  217. package/src/ui/crud/index.tsx +10 -0
  218. package/src/ui/data-display/accordion.tsx +65 -0
  219. package/src/ui/data-display/aspect-ratio.tsx +11 -0
  220. package/src/ui/data-display/avatar.tsx +163 -0
  221. package/src/ui/data-display/bento-grid.tsx +77 -0
  222. package/src/ui/data-display/carousel.tsx +249 -0
  223. package/src/ui/data-display/chart.tsx +363 -0
  224. package/src/ui/data-display/code-block-highlight.tsx +54 -0
  225. package/src/ui/data-display/collapsible.tsx +42 -0
  226. package/src/ui/data-display/compact-stat-bar.tsx +149 -0
  227. package/src/ui/data-display/data-table/data-table-context.tsx +255 -0
  228. package/src/ui/data-display/data-table/data-table-empty-state.tsx +133 -0
  229. package/src/ui/data-display/data-table/data-table-skeleton.tsx +145 -0
  230. package/src/ui/data-display/data-table/data-table-toolbar.tsx +353 -0
  231. package/src/ui/data-display/data-table/data-table.tsx +597 -0
  232. package/src/ui/data-display/data-table/index.ts +44 -0
  233. package/src/ui/data-display/data-table-column-header.tsx +75 -0
  234. package/src/ui/data-display/data-table-pagination.tsx +130 -0
  235. package/src/ui/data-display/data-table-view-options.tsx +59 -0
  236. package/src/ui/data-display/formatted-number-input.tsx +210 -0
  237. package/src/ui/data-display/highlight.tsx +20 -0
  238. package/src/ui/data-display/hover-card.tsx +48 -0
  239. package/src/ui/data-display/index.tsx +50 -0
  240. package/src/ui/data-display/iphone-15-pro.tsx +114 -0
  241. package/src/ui/data-display/kanban/index.ts +4 -0
  242. package/src/ui/data-display/kanban/kanban-board.tsx +192 -0
  243. package/src/ui/data-display/kanban/kanban-column.tsx +74 -0
  244. package/src/ui/data-display/kanban/kanban-item.tsx +50 -0
  245. package/src/ui/data-display/kanban/kanban-types.ts +21 -0
  246. package/src/ui/data-display/kpi-card.tsx +68 -0
  247. package/src/ui/data-display/media-grid.tsx +110 -0
  248. package/src/ui/data-display/safari.tsx +175 -0
  249. package/src/ui/data-display/show-more-text.tsx +55 -0
  250. package/src/ui/data-display/tabs.tsx +68 -0
  251. package/src/ui/data-display/timeline.tsx +256 -0
  252. package/src/ui/feedback/alert.tsx +60 -0
  253. package/src/ui/feedback/context-menu.tsx +245 -0
  254. package/src/ui/feedback/drawer.tsx +132 -0
  255. package/src/ui/feedback/error-dialog.tsx +273 -0
  256. package/src/ui/feedback/index.tsx +183 -0
  257. package/src/ui/feedback/progress.tsx +32 -0
  258. package/src/ui/feedback/sheet.tsx +148 -0
  259. package/src/ui/feedback/sonner.tsx +36 -0
  260. package/src/ui/forms/command.tsx +157 -0
  261. package/src/ui/forms/date-picker.tsx +73 -0
  262. package/src/ui/forms/date-range-picker.tsx +76 -0
  263. package/src/ui/forms/date-time-picker.tsx +109 -0
  264. package/src/ui/forms/editor/editor-menu-bar.tsx +394 -0
  265. package/src/ui/forms/editor/index.tsx +130 -0
  266. package/src/ui/forms/editor/multi-select-example.tsx +1234 -0
  267. package/src/ui/forms/emoji-picker.tsx +109 -0
  268. package/src/ui/forms/file-dropzone.tsx +169 -0
  269. package/src/ui/forms/file-thumbnail.tsx +29 -0
  270. package/src/ui/forms/index.tsx +201 -0
  271. package/src/ui/forms/input-file.tsx +99 -0
  272. package/src/ui/forms/input-group.tsx +46 -0
  273. package/src/ui/forms/input-otp.tsx +81 -0
  274. package/src/ui/forms/input-phone.tsx +172 -0
  275. package/src/ui/forms/input-spin.tsx +116 -0
  276. package/src/ui/forms/input-tags.tsx +219 -0
  277. package/src/ui/forms/input-time.tsx +42 -0
  278. package/src/ui/forms/multi-select.tsx +629 -0
  279. package/src/ui/forms/multiple-date-picker.tsx +74 -0
  280. package/src/ui/forms/radio-group.tsx +42 -0
  281. package/src/ui/forms/rating.tsx +158 -0
  282. package/src/ui/forms/time-picker.tsx +57 -0
  283. package/src/ui/index.tsx +17 -0
  284. package/src/ui/layout/animated-list.tsx +77 -0
  285. package/src/ui/layout/animated-sidebar.tsx +294 -0
  286. package/src/ui/layout/command-menu.tsx +355 -0
  287. package/src/ui/layout/customizer.tsx +324 -0
  288. package/src/ui/layout/footer.tsx +43 -0
  289. package/src/ui/layout/full-screen-toggle.tsx +52 -0
  290. package/src/ui/layout/header-breadcrumb.tsx +77 -0
  291. package/src/ui/layout/horizontal-layout-header.tsx +83 -0
  292. package/src/ui/layout/horizontal-layout.tsx +50 -0
  293. package/src/ui/layout/index.tsx +25 -0
  294. package/src/ui/layout/language-dropdown.tsx +103 -0
  295. package/src/ui/layout/logo.tsx +63 -0
  296. package/src/ui/layout/main-layout.tsx +57 -0
  297. package/src/ui/layout/mode-dropdown.tsx +58 -0
  298. package/src/ui/layout/notification-dropdown.tsx +127 -0
  299. package/src/ui/layout/page-tabs.tsx +306 -0
  300. package/src/ui/layout/route-cache.tsx +214 -0
  301. package/src/ui/layout/sidebar-group-icon-menu.tsx +195 -0
  302. package/src/ui/layout/sidebar.tsx +279 -0
  303. package/src/ui/layout/tab-content-cache.tsx +201 -0
  304. package/src/ui/layout/tab-navigation-provider.tsx +536 -0
  305. package/src/ui/layout/toggle-mobile-sidebar.tsx +33 -0
  306. package/src/ui/layout/top-bar-header-menubar.tsx +412 -0
  307. package/src/ui/layout/user-dropdown.tsx +188 -0
  308. package/src/ui/layout/vertical-layout-header.tsx +65 -0
  309. package/src/ui/layout/vertical-layout.tsx +47 -0
  310. package/src/ui/management/audit-log-page.tsx +209 -0
  311. package/src/ui/management/cache-management.tsx +349 -0
  312. package/src/ui/management/index.ts +3 -0
  313. package/src/ui/management/job-management.tsx +308 -0
  314. package/src/ui/pages/not-found.tsx +30 -0
  315. package/src/ui/primitives/badge.tsx +66 -0
  316. package/src/ui/primitives/breadcrumb.tsx +103 -0
  317. package/src/ui/primitives/button.tsx +129 -0
  318. package/src/ui/primitives/calendar.tsx +74 -0
  319. package/src/ui/primitives/card.tsx +86 -0
  320. package/src/ui/primitives/checkbox.tsx +31 -0
  321. package/src/ui/primitives/client.ts +30 -0
  322. package/src/ui/primitives/combobox.tsx +290 -0
  323. package/src/ui/primitives/dialog.tsx +121 -0
  324. package/src/ui/primitives/dropdown-menu.tsx +239 -0
  325. package/src/ui/primitives/dynamic-icon.tsx +24 -0
  326. package/src/ui/primitives/index.tsx +134 -0
  327. package/src/ui/primitives/input-number.tsx +131 -0
  328. package/src/ui/primitives/input.tsx +22 -0
  329. package/src/ui/primitives/keyboard.tsx +23 -0
  330. package/src/ui/primitives/label.tsx +24 -0
  331. package/src/ui/primitives/menubar.tsx +262 -0
  332. package/src/ui/primitives/navigation-menu.tsx +157 -0
  333. package/src/ui/primitives/pagination.tsx +118 -0
  334. package/src/ui/primitives/popover.tsx +56 -0
  335. package/src/ui/primitives/prefetch-link.tsx +60 -0
  336. package/src/ui/primitives/resizable.tsx +59 -0
  337. package/src/ui/primitives/scroll-area.tsx +63 -0
  338. package/src/ui/primitives/select.tsx +172 -0
  339. package/src/ui/primitives/separator.tsx +51 -0
  340. package/src/ui/primitives/sidebar.tsx +844 -0
  341. package/src/ui/primitives/slider.tsx +27 -0
  342. package/src/ui/primitives/status-badge.tsx +47 -0
  343. package/src/ui/primitives/sticky-layout.tsx +50 -0
  344. package/src/ui/primitives/switch.tsx +29 -0
  345. package/src/ui/primitives/table.tsx +116 -0
  346. package/src/ui/primitives/tabs.tsx +55 -0
  347. package/src/ui/primitives/toggle-group.tsx +70 -0
  348. package/src/ui/primitives/toggle.tsx +47 -0
  349. package/src/ui/primitives/tooltip.tsx +59 -0
  350. package/src/user/components/dangerous-zone.tsx +34 -0
  351. package/src/user/components/delete-account-form.tsx +40 -0
  352. package/src/user/components/index.ts +4 -0
  353. package/src/user/components/profile-info-form.tsx +390 -0
  354. package/src/user/components/profile-info.tsx +32 -0
  355. package/src/user/components/unified-profile-dialog.tsx +1019 -0
  356. package/src/user/components/user-stats.tsx +27 -0
  357. package/src/user/components/user-toolbar.tsx +137 -0
  358. package/src/user/components/users-card-view.tsx +253 -0
  359. package/src/user/index.ts +11 -0
  360. package/src/user/pages/user-list-page.tsx +234 -0
  361. package/src/user/pages/users-client-page.tsx +385 -0
  362. package/src/user/profile-page.tsx +19 -0
  363. package/src/user/schemas.ts +68 -0
  364. package/src/user/types.ts +34 -0
  365. package/src/user/user-service.ts +538 -0
  366. package/src/utils/index.ts +906 -0
  367. package/src/workflow/activity-timeline.tsx +412 -0
  368. package/src/workflow/approval-workflow.tsx +31 -0
  369. package/src/workflow/index.ts +2 -0
  370. package/dist/audit/index.d.mts +0 -115
  371. package/dist/audit/index.d.ts +0 -115
  372. package/dist/audit/index.js +0 -204
  373. package/dist/audit/index.js.map +0 -1
  374. package/dist/audit/index.mjs +0 -200
  375. package/dist/audit/index.mjs.map +0 -1
  376. package/dist/auth/index.d.mts +0 -86
  377. package/dist/auth/index.d.ts +0 -86
  378. package/dist/auth/index.js +0 -210
  379. package/dist/auth/index.js.map +0 -1
  380. package/dist/auth/index.mjs +0 -198
  381. package/dist/auth/index.mjs.map +0 -1
  382. package/dist/button-1dWvP9Ib.d.mts +0 -30
  383. package/dist/button-1dWvP9Ib.d.ts +0 -30
  384. package/dist/calendar-2QzdEo1z.d.mts +0 -20
  385. package/dist/calendar-2QzdEo1z.d.ts +0 -20
  386. package/dist/code-generation/index.d.mts +0 -30
  387. package/dist/code-generation/index.d.ts +0 -30
  388. package/dist/code-generation/index.js +0 -31
  389. package/dist/code-generation/index.js.map +0 -1
  390. package/dist/code-generation/index.mjs +0 -28
  391. package/dist/code-generation/index.mjs.map +0 -1
  392. package/dist/configs/index.d.mts +0 -175
  393. package/dist/configs/index.d.ts +0 -175
  394. package/dist/configs/index.js +0 -254
  395. package/dist/configs/index.js.map +0 -1
  396. package/dist/configs/index.mjs +0 -233
  397. package/dist/configs/index.mjs.map +0 -1
  398. package/dist/crud/index.d.mts +0 -646
  399. package/dist/crud/index.d.ts +0 -646
  400. package/dist/crud/index.js +0 -11772
  401. package/dist/crud/index.js.map +0 -1
  402. package/dist/crud/index.mjs +0 -11665
  403. package/dist/crud/index.mjs.map +0 -1
  404. package/dist/crud/server.d.mts +0 -20
  405. package/dist/crud/server.d.ts +0 -20
  406. package/dist/crud/server.js +0 -123
  407. package/dist/crud/server.js.map +0 -1
  408. package/dist/crud/server.mjs +0 -120
  409. package/dist/crud/server.mjs.map +0 -1
  410. package/dist/data-table-skeleton-12NA8Mjx.d.mts +0 -39
  411. package/dist/data-table-skeleton-12NA8Mjx.d.ts +0 -39
  412. package/dist/dialog-bKfjZMTd.d.mts +0 -22
  413. package/dist/dialog-bKfjZMTd.d.ts +0 -22
  414. package/dist/dynamic-icon-DrGIiu2N.d.mts +0 -10
  415. package/dist/dynamic-icon-DrGIiu2N.d.ts +0 -10
  416. package/dist/home/index.d.mts +0 -269
  417. package/dist/home/index.d.ts +0 -269
  418. package/dist/home/index.js +0 -1678
  419. package/dist/home/index.js.map +0 -1
  420. package/dist/home/index.mjs +0 -1635
  421. package/dist/home/index.mjs.map +0 -1
  422. package/dist/hooks/index.d.mts +0 -7
  423. package/dist/hooks/index.d.ts +0 -7
  424. package/dist/hooks/index.js +0 -8316
  425. package/dist/hooks/index.js.map +0 -1
  426. package/dist/hooks/index.mjs +0 -8255
  427. package/dist/hooks/index.mjs.map +0 -1
  428. package/dist/index-50hpiPrV.d.ts +0 -116
  429. package/dist/index-B9zQVEVi.d.mts +0 -116
  430. package/dist/index.d.mts +0 -5
  431. package/dist/index.d.ts +0 -5
  432. package/dist/index.js +0 -123
  433. package/dist/index.js.map +0 -1
  434. package/dist/index.mjs +0 -118
  435. package/dist/index.mjs.map +0 -1
  436. package/dist/infrastructure/index.d.mts +0 -423
  437. package/dist/infrastructure/index.d.ts +0 -423
  438. package/dist/infrastructure/index.js +0 -633
  439. package/dist/infrastructure/index.js.map +0 -1
  440. package/dist/infrastructure/index.mjs +0 -619
  441. package/dist/infrastructure/index.mjs.map +0 -1
  442. package/dist/label-DWTEkNPo.d.ts +0 -226
  443. package/dist/label-LPpdcoBx.d.mts +0 -226
  444. package/dist/layout/index.d.mts +0 -48
  445. package/dist/layout/index.d.ts +0 -48
  446. package/dist/layout/index.js +0 -117
  447. package/dist/layout/index.js.map +0 -1
  448. package/dist/layout/index.mjs +0 -90
  449. package/dist/layout/index.mjs.map +0 -1
  450. package/dist/navigation/index.d.mts +0 -16
  451. package/dist/navigation/index.d.ts +0 -16
  452. package/dist/navigation/index.js +0 -53
  453. package/dist/navigation/index.js.map +0 -1
  454. package/dist/navigation/index.mjs +0 -50
  455. package/dist/navigation/index.mjs.map +0 -1
  456. package/dist/notification/index.d.mts +0 -105
  457. package/dist/notification/index.d.ts +0 -105
  458. package/dist/notification/index.js +0 -278
  459. package/dist/notification/index.js.map +0 -1
  460. package/dist/notification/index.mjs +0 -274
  461. package/dist/notification/index.mjs.map +0 -1
  462. package/dist/organization/index.d.mts +0 -99
  463. package/dist/organization/index.d.ts +0 -99
  464. package/dist/organization/index.js +0 -360
  465. package/dist/organization/index.js.map +0 -1
  466. package/dist/organization/index.mjs +0 -352
  467. package/dist/organization/index.mjs.map +0 -1
  468. package/dist/plugin/index.d.mts +0 -83
  469. package/dist/plugin/index.d.ts +0 -83
  470. package/dist/plugin/index.js +0 -86
  471. package/dist/plugin/index.js.map +0 -1
  472. package/dist/plugin/index.mjs +0 -84
  473. package/dist/plugin/index.mjs.map +0 -1
  474. package/dist/providers/index.d.mts +0 -25
  475. package/dist/providers/index.d.ts +0 -25
  476. package/dist/providers/index.js +0 -84
  477. package/dist/providers/index.js.map +0 -1
  478. package/dist/providers/index.mjs +0 -77
  479. package/dist/providers/index.mjs.map +0 -1
  480. package/dist/rbac/index.d.mts +0 -226
  481. package/dist/rbac/index.d.ts +0 -226
  482. package/dist/rbac/index.js +0 -4784
  483. package/dist/rbac/index.js.map +0 -1
  484. package/dist/rbac/index.mjs +0 -4722
  485. package/dist/rbac/index.mjs.map +0 -1
  486. package/dist/rbac/permissions.d.mts +0 -26
  487. package/dist/rbac/permissions.d.ts +0 -26
  488. package/dist/rbac/permissions.js +0 -94
  489. package/dist/rbac/permissions.js.map +0 -1
  490. package/dist/rbac/permissions.mjs +0 -90
  491. package/dist/rbac/permissions.mjs.map +0 -1
  492. package/dist/rbac/server.d.mts +0 -1
  493. package/dist/rbac/server.d.ts +0 -1
  494. package/dist/rbac/server.js +0 -128
  495. package/dist/rbac/server.js.map +0 -1
  496. package/dist/rbac/server.mjs +0 -124
  497. package/dist/rbac/server.mjs.map +0 -1
  498. package/dist/schemas/index.d.mts +0 -1257
  499. package/dist/schemas/index.d.ts +0 -1257
  500. package/dist/schemas/index.js +0 -572
  501. package/dist/schemas/index.js.map +0 -1
  502. package/dist/schemas/index.mjs +0 -523
  503. package/dist/schemas/index.mjs.map +0 -1
  504. package/dist/server-QuYCTa89.d.mts +0 -83
  505. package/dist/server-QuYCTa89.d.ts +0 -83
  506. package/dist/sonner-C74GlRDQ.d.mts +0 -71
  507. package/dist/sonner-C74GlRDQ.d.ts +0 -71
  508. package/dist/status-BOXZgIqX.d.mts +0 -12
  509. package/dist/status-BOXZgIqX.d.ts +0 -12
  510. package/dist/system/index.d.mts +0 -77
  511. package/dist/system/index.d.ts +0 -77
  512. package/dist/system/index.js +0 -102
  513. package/dist/system/index.js.map +0 -1
  514. package/dist/system/index.mjs +0 -100
  515. package/dist/system/index.mjs.map +0 -1
  516. package/dist/tabs-C6FfBwPY.d.mts +0 -18
  517. package/dist/tabs-C6FfBwPY.d.ts +0 -18
  518. package/dist/tenant-provider-B8eC_Wpb.d.mts +0 -27
  519. package/dist/tenant-provider-B8eC_Wpb.d.ts +0 -27
  520. package/dist/types/index.d.mts +0 -469
  521. package/dist/types/index.d.ts +0 -469
  522. package/dist/types/index.js +0 -25
  523. package/dist/types/index.js.map +0 -1
  524. package/dist/types/index.mjs +0 -21
  525. package/dist/types/index.mjs.map +0 -1
  526. package/dist/ui/auth.d.mts +0 -39
  527. package/dist/ui/auth.d.ts +0 -39
  528. package/dist/ui/auth.js +0 -4941
  529. package/dist/ui/auth.js.map +0 -1
  530. package/dist/ui/auth.mjs +0 -4896
  531. package/dist/ui/auth.mjs.map +0 -1
  532. package/dist/ui/crud.d.mts +0 -2
  533. package/dist/ui/crud.d.ts +0 -2
  534. package/dist/ui/crud.js +0 -4
  535. package/dist/ui/crud.js.map +0 -1
  536. package/dist/ui/crud.mjs +0 -3
  537. package/dist/ui/crud.mjs.map +0 -1
  538. package/dist/ui/data-display.d.mts +0 -596
  539. package/dist/ui/data-display.d.ts +0 -596
  540. package/dist/ui/data-display.js +0 -5307
  541. package/dist/ui/data-display.js.map +0 -1
  542. package/dist/ui/data-display.mjs +0 -5212
  543. package/dist/ui/data-display.mjs.map +0 -1
  544. package/dist/ui/feedback.d.mts +0 -55
  545. package/dist/ui/feedback.d.ts +0 -55
  546. package/dist/ui/feedback.js +0 -2608
  547. package/dist/ui/feedback.js.map +0 -1
  548. package/dist/ui/feedback.mjs +0 -2526
  549. package/dist/ui/feedback.mjs.map +0 -1
  550. package/dist/ui/forms.d.mts +0 -309
  551. package/dist/ui/forms.d.ts +0 -309
  552. package/dist/ui/forms.js +0 -4656
  553. package/dist/ui/forms.js.map +0 -1
  554. package/dist/ui/forms.mjs +0 -4571
  555. package/dist/ui/forms.mjs.map +0 -1
  556. package/dist/ui/index.d.mts +0 -331
  557. package/dist/ui/index.d.ts +0 -331
  558. package/dist/ui/index.js +0 -16953
  559. package/dist/ui/index.js.map +0 -1
  560. package/dist/ui/index.mjs +0 -16598
  561. package/dist/ui/index.mjs.map +0 -1
  562. package/dist/ui/primitives/client.d.mts +0 -61
  563. package/dist/ui/primitives/client.d.ts +0 -61
  564. package/dist/ui/primitives/client.js +0 -3408
  565. package/dist/ui/primitives/client.js.map +0 -1
  566. package/dist/ui/primitives/client.mjs +0 -3256
  567. package/dist/ui/primitives/client.mjs.map +0 -1
  568. package/dist/ui/primitives.d.mts +0 -113
  569. package/dist/ui/primitives.d.ts +0 -113
  570. package/dist/ui/primitives.js +0 -3356
  571. package/dist/ui/primitives.js.map +0 -1
  572. package/dist/ui/primitives.mjs +0 -3227
  573. package/dist/ui/primitives.mjs.map +0 -1
  574. package/dist/user/index.d.mts +0 -228
  575. package/dist/user/index.d.ts +0 -228
  576. package/dist/user/index.js +0 -4306
  577. package/dist/user/index.js.map +0 -1
  578. package/dist/user/index.mjs +0 -4260
  579. package/dist/user/index.mjs.map +0 -1
  580. package/dist/utils/index.d.mts +0 -205
  581. package/dist/utils/index.d.ts +0 -205
  582. package/dist/utils/index.js +0 -574
  583. package/dist/utils/index.js.map +0 -1
  584. package/dist/utils/index.mjs +0 -514
  585. package/dist/utils/index.mjs.map +0 -1
  586. package/dist/workflow/index.d.mts +0 -40
  587. package/dist/workflow/index.d.ts +0 -40
  588. package/dist/workflow/index.js +0 -3710
  589. package/dist/workflow/index.js.map +0 -1
  590. package/dist/workflow/index.mjs +0 -3677
  591. package/dist/workflow/index.mjs.map +0 -1
@@ -1,204 +0,0 @@
1
- 'use strict';
2
-
3
- // src/infrastructure/logger/logger.ts
4
- var LOG_LEVELS = {
5
- trace: 0,
6
- debug: 1,
7
- info: 2,
8
- warn: 3,
9
- error: 4
10
- };
11
- function getLogLevel() {
12
- const envLevel = process.env.LOG_LEVEL?.toLowerCase();
13
- if (envLevel && LOG_LEVELS[envLevel] !== void 0) {
14
- return envLevel;
15
- }
16
- return process.env.NODE_ENV === "production" ? "info" : "debug";
17
- }
18
- function formatMessage(level, name, message, context) {
19
- const timestamp = (/* @__PURE__ */ new Date()).toISOString();
20
- const contextStr = context ? ` ${JSON.stringify(context)}` : "";
21
- return `${timestamp} [${level.toUpperCase()}] [${name}] ${message}${contextStr}`;
22
- }
23
- function shouldLog(level, minLevel) {
24
- return LOG_LEVELS[level] >= LOG_LEVELS[minLevel];
25
- }
26
- var ConsoleLogger = class {
27
- constructor(options = {}) {
28
- this.name = options.name || "App";
29
- this.level = options.level || getLogLevel();
30
- }
31
- trace(message, context) {
32
- if (shouldLog("trace", this.level)) {
33
- console.log(formatMessage("trace", this.name, message, context));
34
- }
35
- }
36
- debug(message, context) {
37
- if (shouldLog("debug", this.level)) {
38
- console.log(formatMessage("debug", this.name, message, context));
39
- }
40
- }
41
- info(message, context) {
42
- if (shouldLog("info", this.level)) {
43
- console.info(formatMessage("info", this.name, message, context));
44
- }
45
- }
46
- warn(message, context) {
47
- if (shouldLog("warn", this.level)) {
48
- console.warn(formatMessage("warn", this.name, message, context));
49
- }
50
- }
51
- error(message, context) {
52
- if (shouldLog("error", this.level)) {
53
- console.error(formatMessage("error", this.name, message, context));
54
- }
55
- }
56
- };
57
- function createLogger(nameOrOptions = {}) {
58
- const options = typeof nameOrOptions === "string" ? { name: nameOrOptions } : nameOrOptions;
59
- return new ConsoleLogger(options);
60
- }
61
- createLogger("App");
62
-
63
- // src/audit/memory-audit-logger.ts
64
- var MemoryAuditLogger = class {
65
- constructor(maxLogs = 1e3) {
66
- this.logs = [];
67
- this.maxLogs = maxLogs;
68
- }
69
- async log(entry) {
70
- this.logs.unshift(entry);
71
- if (this.logs.length > this.maxLogs) {
72
- this.logs = this.logs.slice(0, this.maxLogs);
73
- }
74
- }
75
- /**
76
- * Get logs with filtering
77
- */
78
- getLogs(filter = {}) {
79
- let filtered = this.logs;
80
- if (filter.fromDate) {
81
- filtered = filtered.filter((log) => log.createdAt >= filter.fromDate);
82
- }
83
- if (filter.toDate) {
84
- filtered = filtered.filter((log) => log.createdAt <= filter.toDate);
85
- }
86
- if (filter.userId) {
87
- filtered = filtered.filter((log) => log.userId === filter.userId);
88
- }
89
- if (filter.action) {
90
- filtered = filtered.filter((log) => log.action === filter.action);
91
- }
92
- if (filter.resource) {
93
- filtered = filtered.filter((log) => log.resource === filter.resource);
94
- }
95
- if (filter.type) {
96
- filtered = filtered.filter((log) => {
97
- if (filter.type === "error") return (log.status || 200) >= 400;
98
- if (filter.type === "warning")
99
- return (log.status || 200) >= 300 && (log.status || 200) < 400;
100
- return (log.status || 200) < 300;
101
- });
102
- }
103
- const offset = filter.offset || 0;
104
- const limit = filter.limit || 50;
105
- return filtered.slice(offset, offset + limit);
106
- }
107
- /**
108
- * Clear all logs
109
- */
110
- clear() {
111
- this.logs = [];
112
- }
113
- };
114
-
115
- // src/audit/audit-manager.ts
116
- var logger2 = createLogger("AuditManager");
117
- var ConsoleAuditLogger = class {
118
- async log(entry) {
119
- logger2.info(`AUDIT: ${entry.action} ${entry.resource}`, {
120
- id: entry.id,
121
- resourceId: entry.resourceId,
122
- userId: entry.userId,
123
- changes: entry.changes
124
- });
125
- }
126
- };
127
- var AuditManagerImpl = class {
128
- constructor(options = {}) {
129
- this.auditLogger = options.logger || new MemoryAuditLogger();
130
- this.registeredActions = new Set(
131
- options.actions || ["create", "update", "delete", "login", "logout"]
132
- );
133
- }
134
- /** Set custom audit logger */
135
- setLogger(auditLogger) {
136
- this.auditLogger = auditLogger;
137
- }
138
- /** Register action for automatic auditing */
139
- registerAction(action) {
140
- this.registeredActions.add(action);
141
- }
142
- /** Check if action is registered for auditing */
143
- isRegistered(action) {
144
- return this.registeredActions.has(action);
145
- }
146
- /** Log an audit entry */
147
- async log(input) {
148
- const entry = {
149
- id: crypto.randomUUID(),
150
- ...input,
151
- createdAt: /* @__PURE__ */ new Date()
152
- };
153
- try {
154
- await this.auditLogger.log(entry);
155
- } catch (error) {
156
- logger2.error("Failed to log audit entry", { error: String(error) });
157
- }
158
- }
159
- /**
160
- * Get logs if the logger supports it (specifically MemoryAuditLogger)
161
- */
162
- getLogs(filter = {}) {
163
- if ("getLogs" in this.auditLogger) {
164
- return this.auditLogger.getLogs(filter);
165
- }
166
- return [];
167
- }
168
- /** Create middleware for automatic API route auditing */
169
- middleware() {
170
- return async (ctx, next) => {
171
- const startTime = Date.now();
172
- let error = null;
173
- try {
174
- await next();
175
- } catch (e) {
176
- error = e;
177
- throw e;
178
- } finally {
179
- if (ctx.action && this.isRegistered(ctx.action.actionName)) {
180
- await this.log({
181
- action: ctx.action.actionName,
182
- resource: ctx.action.resourceName,
183
- userId: ctx.state?.currentUser?.id,
184
- roleName: ctx.state?.currentRole,
185
- ip: ctx.request?.ip,
186
- userAgent: ctx.request?.header?.["user-agent"],
187
- status: ctx.status || (error ? 500 : 200),
188
- metadata: {
189
- duration: Date.now() - startTime,
190
- ...error && { error: error.message }
191
- }
192
- });
193
- }
194
- }
195
- };
196
- }
197
- };
198
- var auditManager = new AuditManagerImpl();
199
-
200
- exports.AuditManagerImpl = AuditManagerImpl;
201
- exports.ConsoleAuditLogger = ConsoleAuditLogger;
202
- exports.auditManager = auditManager;
203
- //# sourceMappingURL=index.js.map
204
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/infrastructure/logger/logger.ts","../../src/audit/memory-audit-logger.ts","../../src/audit/audit-manager.ts"],"names":["logger"],"mappings":"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","file":"index.js","sourcesContent":["import type { Logger, LoggerOptions, LogContext, LogLevel } from \"./types\";\n\nconst LOG_LEVELS: Record<LogLevel, number> = {\n trace: 0,\n debug: 1,\n info: 2,\n warn: 3,\n error: 4,\n};\n\nfunction getLogLevel(): LogLevel {\n const envLevel = process.env.LOG_LEVEL?.toLowerCase() as LogLevel;\n if (envLevel && LOG_LEVELS[envLevel] !== undefined) {\n return envLevel;\n }\n return process.env.NODE_ENV === \"production\" ? \"info\" : \"debug\";\n}\n\nfunction formatMessage(\n level: LogLevel,\n name: string,\n message: string,\n context?: LogContext,\n): string {\n const timestamp = new Date().toISOString();\n const contextStr = context ? ` ${JSON.stringify(context)}` : \"\";\n return `${timestamp} [${level.toUpperCase()}] [${name}] ${message}${contextStr}`;\n}\n\nfunction shouldLog(level: LogLevel, minLevel: LogLevel): boolean {\n return LOG_LEVELS[level] >= LOG_LEVELS[minLevel];\n}\n\nclass ConsoleLogger implements Logger {\n private name: string;\n private level: LogLevel;\n\n constructor(options: LoggerOptions = {}) {\n this.name = options.name || \"App\";\n this.level = options.level || getLogLevel();\n }\n\n trace(message: string, context?: LogContext): void {\n if (shouldLog(\"trace\", this.level)) {\n console.log(formatMessage(\"trace\", this.name, message, context));\n }\n }\n\n debug(message: string, context?: LogContext): void {\n if (shouldLog(\"debug\", this.level)) {\n console.log(formatMessage(\"debug\", this.name, message, context));\n }\n }\n\n info(message: string, context?: LogContext): void {\n if (shouldLog(\"info\", this.level)) {\n console.info(formatMessage(\"info\", this.name, message, context));\n }\n }\n\n warn(message: string, context?: LogContext): void {\n if (shouldLog(\"warn\", this.level)) {\n console.warn(formatMessage(\"warn\", this.name, message, context));\n }\n }\n\n error(message: string, context?: LogContext): void {\n if (shouldLog(\"error\", this.level)) {\n console.error(formatMessage(\"error\", this.name, message, context));\n }\n }\n}\n\n/**\n * Create a logger instance with the given name/options\n *\n * @example\n * ```typescript\n * import { createLogger } from '@goerp/core/infrastructure';\n *\n * const logger = createLogger('OrderService');\n * logger.info('Order created', { orderId: '123' });\n * logger.error('Payment failed', { error: err.message });\n * ```\n */\nexport function createLogger(\n nameOrOptions: string | LoggerOptions = {},\n): Logger {\n const options =\n typeof nameOrOptions === \"string\" ? { name: nameOrOptions } : nameOrOptions;\n\n return new ConsoleLogger(options);\n}\n\n// Default app logger\nexport const logger = createLogger(\"App\");\n","import type { AuditLog, AuditLogger } from \"./types\";\n\n/**\n * Filter options for retrieving audit logs\n */\nexport interface AuditLogFilter {\n fromDate?: Date;\n toDate?: Date;\n userId?: string;\n action?: string;\n resource?: string;\n type?: \"info\" | \"warning\" | \"error\";\n limit?: number;\n offset?: number;\n}\n\n/**\n * In-memory audit logger that supports retrieval\n */\nexport class MemoryAuditLogger implements AuditLogger {\n private logs: AuditLog[] = [];\n private readonly maxLogs: number;\n\n constructor(maxLogs = 1000) {\n this.maxLogs = maxLogs;\n }\n\n async log(entry: AuditLog): Promise<void> {\n // Add to beginning of array\n this.logs.unshift(entry);\n\n // Trim if exceeds max size\n if (this.logs.length > this.maxLogs) {\n this.logs = this.logs.slice(0, this.maxLogs);\n }\n }\n\n /**\n * Get logs with filtering\n */\n getLogs(filter: AuditLogFilter = {}): AuditLog[] {\n let filtered = this.logs;\n\n if (filter.fromDate) {\n filtered = filtered.filter((log) => log.createdAt >= filter.fromDate!);\n }\n\n if (filter.toDate) {\n filtered = filtered.filter((log) => log.createdAt <= filter.toDate!);\n }\n\n if (filter.userId) {\n filtered = filtered.filter((log) => log.userId === filter.userId);\n }\n\n if (filter.action) {\n filtered = filtered.filter((log) => log.action === filter.action);\n }\n\n if (filter.resource) {\n filtered = filtered.filter((log) => log.resource === filter.resource);\n }\n\n // \"type\" filter is a fuzzy mapping based on status code or action name for demo purposes\n if (filter.type) {\n filtered = filtered.filter((log) => {\n if (filter.type === \"error\") return (log.status || 200) >= 400;\n if (filter.type === \"warning\")\n return (log.status || 200) >= 300 && (log.status || 200) < 400;\n return (log.status || 200) < 300;\n });\n }\n\n const offset = filter.offset || 0;\n const limit = filter.limit || 50;\n\n return filtered.slice(offset, offset + limit);\n }\n\n /**\n * Clear all logs\n */\n clear(): void {\n this.logs = [];\n }\n}\n","import type {\n AuditLog,\n AuditLogger,\n AuditManagerOptions,\n CreateAuditInput,\n} from \"./types\";\nimport { createLogger } from \"../infrastructure/logger\";\nimport { MemoryAuditLogger } from \"./memory-audit-logger\";\n\nconst logger = createLogger(\"AuditManager\");\n\n/**\n * Console-based audit logger (default)\n * In production, replace with database or external service\n */\nclass ConsoleAuditLogger implements AuditLogger {\n async log(entry: AuditLog): Promise<void> {\n logger.info(`AUDIT: ${entry.action} ${entry.resource}`, {\n id: entry.id,\n resourceId: entry.resourceId,\n userId: entry.userId,\n changes: entry.changes,\n });\n }\n}\n\n/**\n * AuditManager - tracks actions for compliance and debugging\n *\n * @example\n * ```typescript\n * import { auditManager } from '@goerp/core/audit';\n *\n * // Log an action\n * await auditManager.log({\n * action: 'update',\n * resource: 'purchase-order',\n * resourceId: '123',\n * userId: session.user.id,\n * changes: { status: { old: 'pending', new: 'approved' } }\n * });\n * ```\n */\nclass AuditManagerImpl {\n private auditLogger: AuditLogger;\n private registeredActions: Set<string>;\n\n constructor(options: AuditManagerOptions = {}) {\n this.auditLogger = options.logger || new MemoryAuditLogger();\n this.registeredActions = new Set(\n options.actions || [\"create\", \"update\", \"delete\", \"login\", \"logout\"],\n );\n }\n\n /** Set custom audit logger */\n setLogger(auditLogger: AuditLogger): void {\n this.auditLogger = auditLogger;\n }\n\n /** Register action for automatic auditing */\n registerAction(action: string): void {\n this.registeredActions.add(action);\n }\n\n /** Check if action is registered for auditing */\n isRegistered(action: string): boolean {\n return this.registeredActions.has(action);\n }\n\n /** Log an audit entry */\n async log(input: CreateAuditInput): Promise<void> {\n const entry: AuditLog = {\n id: crypto.randomUUID(),\n ...input,\n createdAt: new Date(),\n };\n\n try {\n await this.auditLogger.log(entry);\n } catch (error) {\n logger.error(\"Failed to log audit entry\", { error: String(error) });\n }\n }\n\n /**\n * Get logs if the logger supports it (specifically MemoryAuditLogger)\n */\n getLogs(filter: any = {}): AuditLog[] {\n if (\"getLogs\" in this.auditLogger) {\n return (this.auditLogger as any).getLogs(filter);\n }\n return [];\n }\n\n /** Create middleware for automatic API route auditing */\n middleware() {\n return async (\n ctx: {\n action?: { actionName: string; resourceName: string };\n state?: { currentUser?: { id: string }; currentRole?: string };\n request?: { ip?: string; header?: Record<string, string> };\n status?: number;\n },\n next: () => Promise<void>,\n ): Promise<void> => {\n const startTime = Date.now();\n let error: Error | null = null;\n\n try {\n await next();\n } catch (e) {\n error = e as Error;\n throw e;\n } finally {\n if (ctx.action && this.isRegistered(ctx.action.actionName)) {\n await this.log({\n action: ctx.action.actionName,\n resource: ctx.action.resourceName,\n userId: ctx.state?.currentUser?.id,\n roleName: ctx.state?.currentRole,\n ip: ctx.request?.ip,\n userAgent: ctx.request?.header?.[\"user-agent\"],\n status: ctx.status || (error ? 500 : 200),\n metadata: {\n duration: Date.now() - startTime,\n ...(error && { error: error.message }),\n },\n });\n }\n }\n };\n }\n}\n\n// Singleton instance\nexport const auditManager = new AuditManagerImpl();\n\n// Export class for testing\nexport { AuditManagerImpl, ConsoleAuditLogger, MemoryAuditLogger };\n"]}
@@ -1,200 +0,0 @@
1
- // src/infrastructure/logger/logger.ts
2
- var LOG_LEVELS = {
3
- trace: 0,
4
- debug: 1,
5
- info: 2,
6
- warn: 3,
7
- error: 4
8
- };
9
- function getLogLevel() {
10
- const envLevel = process.env.LOG_LEVEL?.toLowerCase();
11
- if (envLevel && LOG_LEVELS[envLevel] !== void 0) {
12
- return envLevel;
13
- }
14
- return process.env.NODE_ENV === "production" ? "info" : "debug";
15
- }
16
- function formatMessage(level, name, message, context) {
17
- const timestamp = (/* @__PURE__ */ new Date()).toISOString();
18
- const contextStr = context ? ` ${JSON.stringify(context)}` : "";
19
- return `${timestamp} [${level.toUpperCase()}] [${name}] ${message}${contextStr}`;
20
- }
21
- function shouldLog(level, minLevel) {
22
- return LOG_LEVELS[level] >= LOG_LEVELS[minLevel];
23
- }
24
- var ConsoleLogger = class {
25
- constructor(options = {}) {
26
- this.name = options.name || "App";
27
- this.level = options.level || getLogLevel();
28
- }
29
- trace(message, context) {
30
- if (shouldLog("trace", this.level)) {
31
- console.log(formatMessage("trace", this.name, message, context));
32
- }
33
- }
34
- debug(message, context) {
35
- if (shouldLog("debug", this.level)) {
36
- console.log(formatMessage("debug", this.name, message, context));
37
- }
38
- }
39
- info(message, context) {
40
- if (shouldLog("info", this.level)) {
41
- console.info(formatMessage("info", this.name, message, context));
42
- }
43
- }
44
- warn(message, context) {
45
- if (shouldLog("warn", this.level)) {
46
- console.warn(formatMessage("warn", this.name, message, context));
47
- }
48
- }
49
- error(message, context) {
50
- if (shouldLog("error", this.level)) {
51
- console.error(formatMessage("error", this.name, message, context));
52
- }
53
- }
54
- };
55
- function createLogger(nameOrOptions = {}) {
56
- const options = typeof nameOrOptions === "string" ? { name: nameOrOptions } : nameOrOptions;
57
- return new ConsoleLogger(options);
58
- }
59
- createLogger("App");
60
-
61
- // src/audit/memory-audit-logger.ts
62
- var MemoryAuditLogger = class {
63
- constructor(maxLogs = 1e3) {
64
- this.logs = [];
65
- this.maxLogs = maxLogs;
66
- }
67
- async log(entry) {
68
- this.logs.unshift(entry);
69
- if (this.logs.length > this.maxLogs) {
70
- this.logs = this.logs.slice(0, this.maxLogs);
71
- }
72
- }
73
- /**
74
- * Get logs with filtering
75
- */
76
- getLogs(filter = {}) {
77
- let filtered = this.logs;
78
- if (filter.fromDate) {
79
- filtered = filtered.filter((log) => log.createdAt >= filter.fromDate);
80
- }
81
- if (filter.toDate) {
82
- filtered = filtered.filter((log) => log.createdAt <= filter.toDate);
83
- }
84
- if (filter.userId) {
85
- filtered = filtered.filter((log) => log.userId === filter.userId);
86
- }
87
- if (filter.action) {
88
- filtered = filtered.filter((log) => log.action === filter.action);
89
- }
90
- if (filter.resource) {
91
- filtered = filtered.filter((log) => log.resource === filter.resource);
92
- }
93
- if (filter.type) {
94
- filtered = filtered.filter((log) => {
95
- if (filter.type === "error") return (log.status || 200) >= 400;
96
- if (filter.type === "warning")
97
- return (log.status || 200) >= 300 && (log.status || 200) < 400;
98
- return (log.status || 200) < 300;
99
- });
100
- }
101
- const offset = filter.offset || 0;
102
- const limit = filter.limit || 50;
103
- return filtered.slice(offset, offset + limit);
104
- }
105
- /**
106
- * Clear all logs
107
- */
108
- clear() {
109
- this.logs = [];
110
- }
111
- };
112
-
113
- // src/audit/audit-manager.ts
114
- var logger2 = createLogger("AuditManager");
115
- var ConsoleAuditLogger = class {
116
- async log(entry) {
117
- logger2.info(`AUDIT: ${entry.action} ${entry.resource}`, {
118
- id: entry.id,
119
- resourceId: entry.resourceId,
120
- userId: entry.userId,
121
- changes: entry.changes
122
- });
123
- }
124
- };
125
- var AuditManagerImpl = class {
126
- constructor(options = {}) {
127
- this.auditLogger = options.logger || new MemoryAuditLogger();
128
- this.registeredActions = new Set(
129
- options.actions || ["create", "update", "delete", "login", "logout"]
130
- );
131
- }
132
- /** Set custom audit logger */
133
- setLogger(auditLogger) {
134
- this.auditLogger = auditLogger;
135
- }
136
- /** Register action for automatic auditing */
137
- registerAction(action) {
138
- this.registeredActions.add(action);
139
- }
140
- /** Check if action is registered for auditing */
141
- isRegistered(action) {
142
- return this.registeredActions.has(action);
143
- }
144
- /** Log an audit entry */
145
- async log(input) {
146
- const entry = {
147
- id: crypto.randomUUID(),
148
- ...input,
149
- createdAt: /* @__PURE__ */ new Date()
150
- };
151
- try {
152
- await this.auditLogger.log(entry);
153
- } catch (error) {
154
- logger2.error("Failed to log audit entry", { error: String(error) });
155
- }
156
- }
157
- /**
158
- * Get logs if the logger supports it (specifically MemoryAuditLogger)
159
- */
160
- getLogs(filter = {}) {
161
- if ("getLogs" in this.auditLogger) {
162
- return this.auditLogger.getLogs(filter);
163
- }
164
- return [];
165
- }
166
- /** Create middleware for automatic API route auditing */
167
- middleware() {
168
- return async (ctx, next) => {
169
- const startTime = Date.now();
170
- let error = null;
171
- try {
172
- await next();
173
- } catch (e) {
174
- error = e;
175
- throw e;
176
- } finally {
177
- if (ctx.action && this.isRegistered(ctx.action.actionName)) {
178
- await this.log({
179
- action: ctx.action.actionName,
180
- resource: ctx.action.resourceName,
181
- userId: ctx.state?.currentUser?.id,
182
- roleName: ctx.state?.currentRole,
183
- ip: ctx.request?.ip,
184
- userAgent: ctx.request?.header?.["user-agent"],
185
- status: ctx.status || (error ? 500 : 200),
186
- metadata: {
187
- duration: Date.now() - startTime,
188
- ...error && { error: error.message }
189
- }
190
- });
191
- }
192
- }
193
- };
194
- }
195
- };
196
- var auditManager = new AuditManagerImpl();
197
-
198
- export { AuditManagerImpl, ConsoleAuditLogger, auditManager };
199
- //# sourceMappingURL=index.mjs.map
200
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/infrastructure/logger/logger.ts","../../src/audit/memory-audit-logger.ts","../../src/audit/audit-manager.ts"],"names":["logger"],"mappings":";AAEA,IAAM,UAAA,GAAuC;AAAA,EAC3C,KAAA,EAAO,CAAA;AAAA,EACP,KAAA,EAAO,CAAA;AAAA,EACP,IAAA,EAAM,CAAA;AAAA,EACN,IAAA,EAAM,CAAA;AAAA,EACN,KAAA,EAAO;AACT,CAAA;AAEA,SAAS,WAAA,GAAwB;AAC/B,EAAA,MAAM,QAAA,GAAW,OAAA,CAAQ,GAAA,CAAI,SAAA,EAAW,WAAA,EAAY;AACpD,EAAA,IAAI,QAAA,IAAY,UAAA,CAAW,QAAQ,CAAA,KAAM,MAAA,EAAW;AAClD,IAAA,OAAO,QAAA;AAAA,EACT;AACA,EAAA,OAAO,OAAA,CAAQ,GAAA,CAAI,QAAA,KAAa,YAAA,GAAe,MAAA,GAAS,OAAA;AAC1D;AAEA,SAAS,aAAA,CACP,KAAA,EACA,IAAA,EACA,OAAA,EACA,OAAA,EACQ;AACR,EAAA,MAAM,SAAA,GAAA,iBAAY,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AACzC,EAAA,MAAM,aAAa,OAAA,GAAU,CAAA,CAAA,EAAI,KAAK,SAAA,CAAU,OAAO,CAAC,CAAA,CAAA,GAAK,EAAA;AAC7D,EAAA,OAAO,CAAA,EAAG,SAAS,CAAA,EAAA,EAAK,KAAA,CAAM,WAAA,EAAa,CAAA,GAAA,EAAM,IAAI,CAAA,EAAA,EAAK,OAAO,CAAA,EAAG,UAAU,CAAA,CAAA;AAChF;AAEA,SAAS,SAAA,CAAU,OAAiB,QAAA,EAA6B;AAC/D,EAAA,OAAO,UAAA,CAAW,KAAK,CAAA,IAAK,UAAA,CAAW,QAAQ,CAAA;AACjD;AAEA,IAAM,gBAAN,MAAsC;AAAA,EAIpC,WAAA,CAAY,OAAA,GAAyB,EAAC,EAAG;AACvC,IAAA,IAAA,CAAK,IAAA,GAAO,QAAQ,IAAA,IAAQ,KAAA;AAC5B,IAAA,IAAA,CAAK,KAAA,GAAQ,OAAA,CAAQ,KAAA,IAAS,WAAA,EAAY;AAAA,EAC5C;AAAA,EAEA,KAAA,CAAM,SAAiB,OAAA,EAA4B;AACjD,IAAA,IAAI,SAAA,CAAU,OAAA,EAAS,IAAA,CAAK,KAAK,CAAA,EAAG;AAClC,MAAA,OAAA,CAAQ,IAAI,aAAA,CAAc,OAAA,EAAS,KAAK,IAAA,EAAM,OAAA,EAAS,OAAO,CAAC,CAAA;AAAA,IACjE;AAAA,EACF;AAAA,EAEA,KAAA,CAAM,SAAiB,OAAA,EAA4B;AACjD,IAAA,IAAI,SAAA,CAAU,OAAA,EAAS,IAAA,CAAK,KAAK,CAAA,EAAG;AAClC,MAAA,OAAA,CAAQ,IAAI,aAAA,CAAc,OAAA,EAAS,KAAK,IAAA,EAAM,OAAA,EAAS,OAAO,CAAC,CAAA;AAAA,IACjE;AAAA,EACF;AAAA,EAEA,IAAA,CAAK,SAAiB,OAAA,EAA4B;AAChD,IAAA,IAAI,SAAA,CAAU,MAAA,EAAQ,IAAA,CAAK,KAAK,CAAA,EAAG;AACjC,MAAA,OAAA,CAAQ,KAAK,aAAA,CAAc,MAAA,EAAQ,KAAK,IAAA,EAAM,OAAA,EAAS,OAAO,CAAC,CAAA;AAAA,IACjE;AAAA,EACF;AAAA,EAEA,IAAA,CAAK,SAAiB,OAAA,EAA4B;AAChD,IAAA,IAAI,SAAA,CAAU,MAAA,EAAQ,IAAA,CAAK,KAAK,CAAA,EAAG;AACjC,MAAA,OAAA,CAAQ,KAAK,aAAA,CAAc,MAAA,EAAQ,KAAK,IAAA,EAAM,OAAA,EAAS,OAAO,CAAC,CAAA;AAAA,IACjE;AAAA,EACF;AAAA,EAEA,KAAA,CAAM,SAAiB,OAAA,EAA4B;AACjD,IAAA,IAAI,SAAA,CAAU,OAAA,EAAS,IAAA,CAAK,KAAK,CAAA,EAAG;AAClC,MAAA,OAAA,CAAQ,MAAM,aAAA,CAAc,OAAA,EAAS,KAAK,IAAA,EAAM,OAAA,EAAS,OAAO,CAAC,CAAA;AAAA,IACnE;AAAA,EACF;AACF,CAAA;AAcO,SAAS,YAAA,CACd,aAAA,GAAwC,EAAC,EACjC;AACR,EAAA,MAAM,UACJ,OAAO,aAAA,KAAkB,WAAW,EAAE,IAAA,EAAM,eAAc,GAAI,aAAA;AAEhE,EAAA,OAAO,IAAI,cAAc,OAAO,CAAA;AAClC;AAGsB,aAAa,KAAK;;;AC5EjC,IAAM,oBAAN,MAA+C;AAAA,EAIpD,WAAA,CAAY,UAAU,GAAA,EAAM;AAH5B,IAAA,IAAA,CAAQ,OAAmB,EAAC;AAI1B,IAAA,IAAA,CAAK,OAAA,GAAU,OAAA;AAAA,EACjB;AAAA,EAEA,MAAM,IAAI,KAAA,EAAgC;AAExC,IAAA,IAAA,CAAK,IAAA,CAAK,QAAQ,KAAK,CAAA;AAGvB,IAAA,IAAI,IAAA,CAAK,IAAA,CAAK,MAAA,GAAS,IAAA,CAAK,OAAA,EAAS;AACnC,MAAA,IAAA,CAAK,OAAO,IAAA,CAAK,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,KAAK,OAAO,CAAA;AAAA,IAC7C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,OAAA,CAAQ,MAAA,GAAyB,EAAC,EAAe;AAC/C,IAAA,IAAI,WAAW,IAAA,CAAK,IAAA;AAEpB,IAAA,IAAI,OAAO,QAAA,EAAU;AACnB,MAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,QAAQ,GAAA,CAAI,SAAA,IAAa,OAAO,QAAS,CAAA;AAAA,IACvE;AAEA,IAAA,IAAI,OAAO,MAAA,EAAQ;AACjB,MAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,QAAQ,GAAA,CAAI,SAAA,IAAa,OAAO,MAAO,CAAA;AAAA,IACrE;AAEA,IAAA,IAAI,OAAO,MAAA,EAAQ;AACjB,MAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,QAAQ,GAAA,CAAI,MAAA,KAAW,OAAO,MAAM,CAAA;AAAA,IAClE;AAEA,IAAA,IAAI,OAAO,MAAA,EAAQ;AACjB,MAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,QAAQ,GAAA,CAAI,MAAA,KAAW,OAAO,MAAM,CAAA;AAAA,IAClE;AAEA,IAAA,IAAI,OAAO,QAAA,EAAU;AACnB,MAAA,QAAA,GAAW,SAAS,MAAA,CAAO,CAAC,QAAQ,GAAA,CAAI,QAAA,KAAa,OAAO,QAAQ,CAAA;AAAA,IACtE;AAGA,IAAA,IAAI,OAAO,IAAA,EAAM;AACf,MAAA,QAAA,GAAW,QAAA,CAAS,MAAA,CAAO,CAAC,GAAA,KAAQ;AAClC,QAAA,IAAI,OAAO,IAAA,KAAS,OAAA,EAAS,OAAA,CAAQ,GAAA,CAAI,UAAU,GAAA,KAAQ,GAAA;AAC3D,QAAA,IAAI,OAAO,IAAA,KAAS,SAAA;AAClB,UAAA,OAAA,CAAQ,IAAI,MAAA,IAAU,GAAA,KAAQ,GAAA,IAAA,CAAQ,GAAA,CAAI,UAAU,GAAA,IAAO,GAAA;AAC7D,QAAA,OAAA,CAAQ,GAAA,CAAI,UAAU,GAAA,IAAO,GAAA;AAAA,MAC/B,CAAC,CAAA;AAAA,IACH;AAEA,IAAA,MAAM,MAAA,GAAS,OAAO,MAAA,IAAU,CAAA;AAChC,IAAA,MAAM,KAAA,GAAQ,OAAO,KAAA,IAAS,EAAA;AAE9B,IAAA,OAAO,QAAA,CAAS,KAAA,CAAM,MAAA,EAAQ,MAAA,GAAS,KAAK,CAAA;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA,EAKA,KAAA,GAAc;AACZ,IAAA,IAAA,CAAK,OAAO,EAAC;AAAA,EACf;AACF,CAAA;;;AC5EA,IAAMA,OAAAA,GAAS,aAAa,cAAc,CAAA;AAM1C,IAAM,qBAAN,MAAgD;AAAA,EAC9C,MAAM,IAAI,KAAA,EAAgC;AACxC,IAAAA,OAAAA,CAAO,KAAK,CAAA,OAAA,EAAU,KAAA,CAAM,MAAM,CAAA,CAAA,EAAI,KAAA,CAAM,QAAQ,CAAA,CAAA,EAAI;AAAA,MACtD,IAAI,KAAA,CAAM,EAAA;AAAA,MACV,YAAY,KAAA,CAAM,UAAA;AAAA,MAClB,QAAQ,KAAA,CAAM,MAAA;AAAA,MACd,SAAS,KAAA,CAAM;AAAA,KAChB,CAAA;AAAA,EACH;AACF;AAmBA,IAAM,mBAAN,MAAuB;AAAA,EAIrB,WAAA,CAAY,OAAA,GAA+B,EAAC,EAAG;AAC7C,IAAA,IAAA,CAAK,WAAA,GAAc,OAAA,CAAQ,MAAA,IAAU,IAAI,iBAAA,EAAkB;AAC3D,IAAA,IAAA,CAAK,oBAAoB,IAAI,GAAA;AAAA,MAC3B,QAAQ,OAAA,IAAW,CAAC,UAAU,QAAA,EAAU,QAAA,EAAU,SAAS,QAAQ;AAAA,KACrE;AAAA,EACF;AAAA;AAAA,EAGA,UAAU,WAAA,EAAgC;AACxC,IAAA,IAAA,CAAK,WAAA,GAAc,WAAA;AAAA,EACrB;AAAA;AAAA,EAGA,eAAe,MAAA,EAAsB;AACnC,IAAA,IAAA,CAAK,iBAAA,CAAkB,IAAI,MAAM,CAAA;AAAA,EACnC;AAAA;AAAA,EAGA,aAAa,MAAA,EAAyB;AACpC,IAAA,OAAO,IAAA,CAAK,iBAAA,CAAkB,GAAA,CAAI,MAAM,CAAA;AAAA,EAC1C;AAAA;AAAA,EAGA,MAAM,IAAI,KAAA,EAAwC;AAChD,IAAA,MAAM,KAAA,GAAkB;AAAA,MACtB,EAAA,EAAI,OAAO,UAAA,EAAW;AAAA,MACtB,GAAG,KAAA;AAAA,MACH,SAAA,sBAAe,IAAA;AAAK,KACtB;AAEA,IAAA,IAAI;AACF,MAAA,MAAM,IAAA,CAAK,WAAA,CAAY,GAAA,CAAI,KAAK,CAAA;AAAA,IAClC,SAAS,KAAA,EAAO;AACd,MAAAA,OAAAA,CAAO,MAAM,2BAAA,EAA6B,EAAE,OAAO,MAAA,CAAO,KAAK,GAAG,CAAA;AAAA,IACpE;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,OAAA,CAAQ,MAAA,GAAc,EAAC,EAAe;AACpC,IAAA,IAAI,SAAA,IAAa,KAAK,WAAA,EAAa;AACjC,MAAA,OAAQ,IAAA,CAAK,WAAA,CAAoB,OAAA,CAAQ,MAAM,CAAA;AAAA,IACjD;AACA,IAAA,OAAO,EAAC;AAAA,EACV;AAAA;AAAA,EAGA,UAAA,GAAa;AACX,IAAA,OAAO,OACL,KAMA,IAAA,KACkB;AAClB,MAAA,MAAM,SAAA,GAAY,KAAK,GAAA,EAAI;AAC3B,MAAA,IAAI,KAAA,GAAsB,IAAA;AAE1B,MAAA,IAAI;AACF,QAAA,MAAM,IAAA,EAAK;AAAA,MACb,SAAS,CAAA,EAAG;AACV,QAAA,KAAA,GAAQ,CAAA;AACR,QAAA,MAAM,CAAA;AAAA,MACR,CAAA,SAAE;AACA,QAAA,IAAI,IAAI,MAAA,IAAU,IAAA,CAAK,aAAa,GAAA,CAAI,MAAA,CAAO,UAAU,CAAA,EAAG;AAC1D,UAAA,MAAM,KAAK,GAAA,CAAI;AAAA,YACb,MAAA,EAAQ,IAAI,MAAA,CAAO,UAAA;AAAA,YACnB,QAAA,EAAU,IAAI,MAAA,CAAO,YAAA;AAAA,YACrB,MAAA,EAAQ,GAAA,CAAI,KAAA,EAAO,WAAA,EAAa,EAAA;AAAA,YAChC,QAAA,EAAU,IAAI,KAAA,EAAO,WAAA;AAAA,YACrB,EAAA,EAAI,IAAI,OAAA,EAAS,EAAA;AAAA,YACjB,SAAA,EAAW,GAAA,CAAI,OAAA,EAAS,MAAA,GAAS,YAAY,CAAA;AAAA,YAC7C,MAAA,EAAQ,GAAA,CAAI,MAAA,KAAW,KAAA,GAAQ,GAAA,GAAM,GAAA,CAAA;AAAA,YACrC,QAAA,EAAU;AAAA,cACR,QAAA,EAAU,IAAA,CAAK,GAAA,EAAI,GAAI,SAAA;AAAA,cACvB,GAAI,KAAA,IAAS,EAAE,KAAA,EAAO,MAAM,OAAA;AAAQ;AACtC,WACD,CAAA;AAAA,QACH;AAAA,MACF;AAAA,IACF,CAAA;AAAA,EACF;AACF;AAGO,IAAM,YAAA,GAAe,IAAI,gBAAA","file":"index.mjs","sourcesContent":["import type { Logger, LoggerOptions, LogContext, LogLevel } from \"./types\";\n\nconst LOG_LEVELS: Record<LogLevel, number> = {\n trace: 0,\n debug: 1,\n info: 2,\n warn: 3,\n error: 4,\n};\n\nfunction getLogLevel(): LogLevel {\n const envLevel = process.env.LOG_LEVEL?.toLowerCase() as LogLevel;\n if (envLevel && LOG_LEVELS[envLevel] !== undefined) {\n return envLevel;\n }\n return process.env.NODE_ENV === \"production\" ? \"info\" : \"debug\";\n}\n\nfunction formatMessage(\n level: LogLevel,\n name: string,\n message: string,\n context?: LogContext,\n): string {\n const timestamp = new Date().toISOString();\n const contextStr = context ? ` ${JSON.stringify(context)}` : \"\";\n return `${timestamp} [${level.toUpperCase()}] [${name}] ${message}${contextStr}`;\n}\n\nfunction shouldLog(level: LogLevel, minLevel: LogLevel): boolean {\n return LOG_LEVELS[level] >= LOG_LEVELS[minLevel];\n}\n\nclass ConsoleLogger implements Logger {\n private name: string;\n private level: LogLevel;\n\n constructor(options: LoggerOptions = {}) {\n this.name = options.name || \"App\";\n this.level = options.level || getLogLevel();\n }\n\n trace(message: string, context?: LogContext): void {\n if (shouldLog(\"trace\", this.level)) {\n console.log(formatMessage(\"trace\", this.name, message, context));\n }\n }\n\n debug(message: string, context?: LogContext): void {\n if (shouldLog(\"debug\", this.level)) {\n console.log(formatMessage(\"debug\", this.name, message, context));\n }\n }\n\n info(message: string, context?: LogContext): void {\n if (shouldLog(\"info\", this.level)) {\n console.info(formatMessage(\"info\", this.name, message, context));\n }\n }\n\n warn(message: string, context?: LogContext): void {\n if (shouldLog(\"warn\", this.level)) {\n console.warn(formatMessage(\"warn\", this.name, message, context));\n }\n }\n\n error(message: string, context?: LogContext): void {\n if (shouldLog(\"error\", this.level)) {\n console.error(formatMessage(\"error\", this.name, message, context));\n }\n }\n}\n\n/**\n * Create a logger instance with the given name/options\n *\n * @example\n * ```typescript\n * import { createLogger } from '@goerp/core/infrastructure';\n *\n * const logger = createLogger('OrderService');\n * logger.info('Order created', { orderId: '123' });\n * logger.error('Payment failed', { error: err.message });\n * ```\n */\nexport function createLogger(\n nameOrOptions: string | LoggerOptions = {},\n): Logger {\n const options =\n typeof nameOrOptions === \"string\" ? { name: nameOrOptions } : nameOrOptions;\n\n return new ConsoleLogger(options);\n}\n\n// Default app logger\nexport const logger = createLogger(\"App\");\n","import type { AuditLog, AuditLogger } from \"./types\";\n\n/**\n * Filter options for retrieving audit logs\n */\nexport interface AuditLogFilter {\n fromDate?: Date;\n toDate?: Date;\n userId?: string;\n action?: string;\n resource?: string;\n type?: \"info\" | \"warning\" | \"error\";\n limit?: number;\n offset?: number;\n}\n\n/**\n * In-memory audit logger that supports retrieval\n */\nexport class MemoryAuditLogger implements AuditLogger {\n private logs: AuditLog[] = [];\n private readonly maxLogs: number;\n\n constructor(maxLogs = 1000) {\n this.maxLogs = maxLogs;\n }\n\n async log(entry: AuditLog): Promise<void> {\n // Add to beginning of array\n this.logs.unshift(entry);\n\n // Trim if exceeds max size\n if (this.logs.length > this.maxLogs) {\n this.logs = this.logs.slice(0, this.maxLogs);\n }\n }\n\n /**\n * Get logs with filtering\n */\n getLogs(filter: AuditLogFilter = {}): AuditLog[] {\n let filtered = this.logs;\n\n if (filter.fromDate) {\n filtered = filtered.filter((log) => log.createdAt >= filter.fromDate!);\n }\n\n if (filter.toDate) {\n filtered = filtered.filter((log) => log.createdAt <= filter.toDate!);\n }\n\n if (filter.userId) {\n filtered = filtered.filter((log) => log.userId === filter.userId);\n }\n\n if (filter.action) {\n filtered = filtered.filter((log) => log.action === filter.action);\n }\n\n if (filter.resource) {\n filtered = filtered.filter((log) => log.resource === filter.resource);\n }\n\n // \"type\" filter is a fuzzy mapping based on status code or action name for demo purposes\n if (filter.type) {\n filtered = filtered.filter((log) => {\n if (filter.type === \"error\") return (log.status || 200) >= 400;\n if (filter.type === \"warning\")\n return (log.status || 200) >= 300 && (log.status || 200) < 400;\n return (log.status || 200) < 300;\n });\n }\n\n const offset = filter.offset || 0;\n const limit = filter.limit || 50;\n\n return filtered.slice(offset, offset + limit);\n }\n\n /**\n * Clear all logs\n */\n clear(): void {\n this.logs = [];\n }\n}\n","import type {\n AuditLog,\n AuditLogger,\n AuditManagerOptions,\n CreateAuditInput,\n} from \"./types\";\nimport { createLogger } from \"../infrastructure/logger\";\nimport { MemoryAuditLogger } from \"./memory-audit-logger\";\n\nconst logger = createLogger(\"AuditManager\");\n\n/**\n * Console-based audit logger (default)\n * In production, replace with database or external service\n */\nclass ConsoleAuditLogger implements AuditLogger {\n async log(entry: AuditLog): Promise<void> {\n logger.info(`AUDIT: ${entry.action} ${entry.resource}`, {\n id: entry.id,\n resourceId: entry.resourceId,\n userId: entry.userId,\n changes: entry.changes,\n });\n }\n}\n\n/**\n * AuditManager - tracks actions for compliance and debugging\n *\n * @example\n * ```typescript\n * import { auditManager } from '@goerp/core/audit';\n *\n * // Log an action\n * await auditManager.log({\n * action: 'update',\n * resource: 'purchase-order',\n * resourceId: '123',\n * userId: session.user.id,\n * changes: { status: { old: 'pending', new: 'approved' } }\n * });\n * ```\n */\nclass AuditManagerImpl {\n private auditLogger: AuditLogger;\n private registeredActions: Set<string>;\n\n constructor(options: AuditManagerOptions = {}) {\n this.auditLogger = options.logger || new MemoryAuditLogger();\n this.registeredActions = new Set(\n options.actions || [\"create\", \"update\", \"delete\", \"login\", \"logout\"],\n );\n }\n\n /** Set custom audit logger */\n setLogger(auditLogger: AuditLogger): void {\n this.auditLogger = auditLogger;\n }\n\n /** Register action for automatic auditing */\n registerAction(action: string): void {\n this.registeredActions.add(action);\n }\n\n /** Check if action is registered for auditing */\n isRegistered(action: string): boolean {\n return this.registeredActions.has(action);\n }\n\n /** Log an audit entry */\n async log(input: CreateAuditInput): Promise<void> {\n const entry: AuditLog = {\n id: crypto.randomUUID(),\n ...input,\n createdAt: new Date(),\n };\n\n try {\n await this.auditLogger.log(entry);\n } catch (error) {\n logger.error(\"Failed to log audit entry\", { error: String(error) });\n }\n }\n\n /**\n * Get logs if the logger supports it (specifically MemoryAuditLogger)\n */\n getLogs(filter: any = {}): AuditLog[] {\n if (\"getLogs\" in this.auditLogger) {\n return (this.auditLogger as any).getLogs(filter);\n }\n return [];\n }\n\n /** Create middleware for automatic API route auditing */\n middleware() {\n return async (\n ctx: {\n action?: { actionName: string; resourceName: string };\n state?: { currentUser?: { id: string }; currentRole?: string };\n request?: { ip?: string; header?: Record<string, string> };\n status?: number;\n },\n next: () => Promise<void>,\n ): Promise<void> => {\n const startTime = Date.now();\n let error: Error | null = null;\n\n try {\n await next();\n } catch (e) {\n error = e as Error;\n throw e;\n } finally {\n if (ctx.action && this.isRegistered(ctx.action.actionName)) {\n await this.log({\n action: ctx.action.actionName,\n resource: ctx.action.resourceName,\n userId: ctx.state?.currentUser?.id,\n roleName: ctx.state?.currentRole,\n ip: ctx.request?.ip,\n userAgent: ctx.request?.header?.[\"user-agent\"],\n status: ctx.status || (error ? 500 : 200),\n metadata: {\n duration: Date.now() - startTime,\n ...(error && { error: error.message }),\n },\n });\n }\n }\n };\n }\n}\n\n// Singleton instance\nexport const auditManager = new AuditManagerImpl();\n\n// Export class for testing\nexport { AuditManagerImpl, ConsoleAuditLogger, MemoryAuditLogger };\n"]}
@@ -1,86 +0,0 @@
1
- import { Session } from 'next-auth';
2
-
3
- interface AuthPrismaClient {
4
- user: any;
5
- }
6
- declare function verifyPassword(password: string, hash: string): Promise<boolean>;
7
- interface AuthenticatedUser {
8
- id: string;
9
- email: string | null;
10
- name: string;
11
- avatar: string | null;
12
- status: string;
13
- }
14
- interface AuthError {
15
- message: string;
16
- email?: string;
17
- }
18
- /**
19
- * Authenticate user with email and password
20
- * Returns user data if successful, throws error if failed
21
- */
22
- declare function authenticateUser(db: AuthPrismaClient, email: string, password: string): Promise<AuthenticatedUser>;
23
-
24
- interface Permission {
25
- resourceCode: string;
26
- actionCode: string;
27
- }
28
- interface ExtendedUser {
29
- id: string;
30
- name?: string | null;
31
- email?: string | null;
32
- image?: string | null;
33
- roles?: string[];
34
- permissions?: Permission[];
35
- }
36
- interface UserSession {
37
- user: ExtendedUser;
38
- }
39
- interface CrudPermissionResult {
40
- create: boolean;
41
- view: boolean;
42
- update: boolean;
43
- delete: boolean;
44
- export: boolean;
45
- import: boolean;
46
- approve: boolean;
47
- reject: boolean;
48
- }
49
- /**
50
- * Get action code from action name
51
- */
52
- declare function getActionCode(action: string): string;
53
- /**
54
- * Get all permissions from session
55
- */
56
- declare function getUserPermissions(session: Session | null): Permission[];
57
- /**
58
- * Get CRUD permissions from session for a specific entity
59
- */
60
- declare function getCrudPermissionsFromSession(session: Session | null, entity: string): CrudPermissionResult;
61
- /**
62
- * Check if user has a specific permission
63
- */
64
- declare function checkPermission(session: Session | null, resourceCode: string, actionCode: string): boolean;
65
- /**
66
- * Alias for checkPermission
67
- */
68
- declare function hasPermission(session: Session | null, resourceCode: string, actionCode: string): boolean;
69
- /**
70
- * Require permission - throw error if not authorized
71
- */
72
- declare function requirePermission(session: Session | null, resourceCode: string, actionCode: string): void;
73
- /**
74
- * Check if user has a specific role
75
- */
76
- declare function hasRole(session: Session | null, roleCode: string): boolean;
77
- /**
78
- * Check if user has any of the specified roles
79
- */
80
- declare function hasAnyRole(session: Session | null, roleCodes: string[]): boolean;
81
- /**
82
- * Check if user is admin
83
- */
84
- declare function isAdmin(session: Session | null): boolean;
85
-
86
- export { type AuthError, type AuthPrismaClient, type AuthenticatedUser, type CrudPermissionResult, type ExtendedUser, type Permission, type UserSession, authenticateUser, checkPermission, getActionCode, getCrudPermissionsFromSession, getUserPermissions, hasAnyRole, hasPermission, hasRole, isAdmin, requirePermission, verifyPassword };
@@ -1,86 +0,0 @@
1
- import { Session } from 'next-auth';
2
-
3
- interface AuthPrismaClient {
4
- user: any;
5
- }
6
- declare function verifyPassword(password: string, hash: string): Promise<boolean>;
7
- interface AuthenticatedUser {
8
- id: string;
9
- email: string | null;
10
- name: string;
11
- avatar: string | null;
12
- status: string;
13
- }
14
- interface AuthError {
15
- message: string;
16
- email?: string;
17
- }
18
- /**
19
- * Authenticate user with email and password
20
- * Returns user data if successful, throws error if failed
21
- */
22
- declare function authenticateUser(db: AuthPrismaClient, email: string, password: string): Promise<AuthenticatedUser>;
23
-
24
- interface Permission {
25
- resourceCode: string;
26
- actionCode: string;
27
- }
28
- interface ExtendedUser {
29
- id: string;
30
- name?: string | null;
31
- email?: string | null;
32
- image?: string | null;
33
- roles?: string[];
34
- permissions?: Permission[];
35
- }
36
- interface UserSession {
37
- user: ExtendedUser;
38
- }
39
- interface CrudPermissionResult {
40
- create: boolean;
41
- view: boolean;
42
- update: boolean;
43
- delete: boolean;
44
- export: boolean;
45
- import: boolean;
46
- approve: boolean;
47
- reject: boolean;
48
- }
49
- /**
50
- * Get action code from action name
51
- */
52
- declare function getActionCode(action: string): string;
53
- /**
54
- * Get all permissions from session
55
- */
56
- declare function getUserPermissions(session: Session | null): Permission[];
57
- /**
58
- * Get CRUD permissions from session for a specific entity
59
- */
60
- declare function getCrudPermissionsFromSession(session: Session | null, entity: string): CrudPermissionResult;
61
- /**
62
- * Check if user has a specific permission
63
- */
64
- declare function checkPermission(session: Session | null, resourceCode: string, actionCode: string): boolean;
65
- /**
66
- * Alias for checkPermission
67
- */
68
- declare function hasPermission(session: Session | null, resourceCode: string, actionCode: string): boolean;
69
- /**
70
- * Require permission - throw error if not authorized
71
- */
72
- declare function requirePermission(session: Session | null, resourceCode: string, actionCode: string): void;
73
- /**
74
- * Check if user has a specific role
75
- */
76
- declare function hasRole(session: Session | null, roleCode: string): boolean;
77
- /**
78
- * Check if user has any of the specified roles
79
- */
80
- declare function hasAnyRole(session: Session | null, roleCodes: string[]): boolean;
81
- /**
82
- * Check if user is admin
83
- */
84
- declare function isAdmin(session: Session | null): boolean;
85
-
86
- export { type AuthError, type AuthPrismaClient, type AuthenticatedUser, type CrudPermissionResult, type ExtendedUser, type Permission, type UserSession, authenticateUser, checkPermission, getActionCode, getCrudPermissionsFromSession, getUserPermissions, hasAnyRole, hasPermission, hasRole, isAdmin, requirePermission, verifyPassword };