@goplusvn/core 0.1.1 → 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 (223) hide show
  1. package/package.json +30 -175
  2. package/dist/audit/index.d.mts +0 -115
  3. package/dist/audit/index.d.ts +0 -115
  4. package/dist/audit/index.js +0 -204
  5. package/dist/audit/index.js.map +0 -1
  6. package/dist/audit/index.mjs +0 -200
  7. package/dist/audit/index.mjs.map +0 -1
  8. package/dist/auth/index.d.mts +0 -86
  9. package/dist/auth/index.d.ts +0 -86
  10. package/dist/auth/index.js +0 -210
  11. package/dist/auth/index.js.map +0 -1
  12. package/dist/auth/index.mjs +0 -198
  13. package/dist/auth/index.mjs.map +0 -1
  14. package/dist/button-1dWvP9Ib.d.mts +0 -30
  15. package/dist/button-1dWvP9Ib.d.ts +0 -30
  16. package/dist/calendar-2QzdEo1z.d.mts +0 -20
  17. package/dist/calendar-2QzdEo1z.d.ts +0 -20
  18. package/dist/code-generation/index.d.mts +0 -30
  19. package/dist/code-generation/index.d.ts +0 -30
  20. package/dist/code-generation/index.js +0 -31
  21. package/dist/code-generation/index.js.map +0 -1
  22. package/dist/code-generation/index.mjs +0 -28
  23. package/dist/code-generation/index.mjs.map +0 -1
  24. package/dist/configs/index.d.mts +0 -175
  25. package/dist/configs/index.d.ts +0 -175
  26. package/dist/configs/index.js +0 -254
  27. package/dist/configs/index.js.map +0 -1
  28. package/dist/configs/index.mjs +0 -233
  29. package/dist/configs/index.mjs.map +0 -1
  30. package/dist/crud/index.d.mts +0 -646
  31. package/dist/crud/index.d.ts +0 -646
  32. package/dist/crud/index.js +0 -11772
  33. package/dist/crud/index.js.map +0 -1
  34. package/dist/crud/index.mjs +0 -11665
  35. package/dist/crud/index.mjs.map +0 -1
  36. package/dist/crud/server.d.mts +0 -20
  37. package/dist/crud/server.d.ts +0 -20
  38. package/dist/crud/server.js +0 -123
  39. package/dist/crud/server.js.map +0 -1
  40. package/dist/crud/server.mjs +0 -120
  41. package/dist/crud/server.mjs.map +0 -1
  42. package/dist/data-table-skeleton-12NA8Mjx.d.mts +0 -39
  43. package/dist/data-table-skeleton-12NA8Mjx.d.ts +0 -39
  44. package/dist/dialog-bKfjZMTd.d.mts +0 -22
  45. package/dist/dialog-bKfjZMTd.d.ts +0 -22
  46. package/dist/dynamic-icon-DrGIiu2N.d.mts +0 -10
  47. package/dist/dynamic-icon-DrGIiu2N.d.ts +0 -10
  48. package/dist/home/index.d.mts +0 -269
  49. package/dist/home/index.d.ts +0 -269
  50. package/dist/home/index.js +0 -1678
  51. package/dist/home/index.js.map +0 -1
  52. package/dist/home/index.mjs +0 -1635
  53. package/dist/home/index.mjs.map +0 -1
  54. package/dist/hooks/index.d.mts +0 -7
  55. package/dist/hooks/index.d.ts +0 -7
  56. package/dist/hooks/index.js +0 -8316
  57. package/dist/hooks/index.js.map +0 -1
  58. package/dist/hooks/index.mjs +0 -8255
  59. package/dist/hooks/index.mjs.map +0 -1
  60. package/dist/index-50hpiPrV.d.ts +0 -116
  61. package/dist/index-B9zQVEVi.d.mts +0 -116
  62. package/dist/index.d.mts +0 -5
  63. package/dist/index.d.ts +0 -5
  64. package/dist/index.js +0 -123
  65. package/dist/index.js.map +0 -1
  66. package/dist/index.mjs +0 -118
  67. package/dist/index.mjs.map +0 -1
  68. package/dist/infrastructure/index.d.mts +0 -423
  69. package/dist/infrastructure/index.d.ts +0 -423
  70. package/dist/infrastructure/index.js +0 -633
  71. package/dist/infrastructure/index.js.map +0 -1
  72. package/dist/infrastructure/index.mjs +0 -619
  73. package/dist/infrastructure/index.mjs.map +0 -1
  74. package/dist/label-DWTEkNPo.d.ts +0 -226
  75. package/dist/label-LPpdcoBx.d.mts +0 -226
  76. package/dist/layout/index.d.mts +0 -48
  77. package/dist/layout/index.d.ts +0 -48
  78. package/dist/layout/index.js +0 -117
  79. package/dist/layout/index.js.map +0 -1
  80. package/dist/layout/index.mjs +0 -90
  81. package/dist/layout/index.mjs.map +0 -1
  82. package/dist/navigation/index.d.mts +0 -16
  83. package/dist/navigation/index.d.ts +0 -16
  84. package/dist/navigation/index.js +0 -53
  85. package/dist/navigation/index.js.map +0 -1
  86. package/dist/navigation/index.mjs +0 -50
  87. package/dist/navigation/index.mjs.map +0 -1
  88. package/dist/notification/index.d.mts +0 -105
  89. package/dist/notification/index.d.ts +0 -105
  90. package/dist/notification/index.js +0 -278
  91. package/dist/notification/index.js.map +0 -1
  92. package/dist/notification/index.mjs +0 -274
  93. package/dist/notification/index.mjs.map +0 -1
  94. package/dist/organization/index.d.mts +0 -99
  95. package/dist/organization/index.d.ts +0 -99
  96. package/dist/organization/index.js +0 -360
  97. package/dist/organization/index.js.map +0 -1
  98. package/dist/organization/index.mjs +0 -352
  99. package/dist/organization/index.mjs.map +0 -1
  100. package/dist/plugin/index.d.mts +0 -83
  101. package/dist/plugin/index.d.ts +0 -83
  102. package/dist/plugin/index.js +0 -86
  103. package/dist/plugin/index.js.map +0 -1
  104. package/dist/plugin/index.mjs +0 -84
  105. package/dist/plugin/index.mjs.map +0 -1
  106. package/dist/providers/index.d.mts +0 -25
  107. package/dist/providers/index.d.ts +0 -25
  108. package/dist/providers/index.js +0 -84
  109. package/dist/providers/index.js.map +0 -1
  110. package/dist/providers/index.mjs +0 -77
  111. package/dist/providers/index.mjs.map +0 -1
  112. package/dist/rbac/index.d.mts +0 -226
  113. package/dist/rbac/index.d.ts +0 -226
  114. package/dist/rbac/index.js +0 -4784
  115. package/dist/rbac/index.js.map +0 -1
  116. package/dist/rbac/index.mjs +0 -4722
  117. package/dist/rbac/index.mjs.map +0 -1
  118. package/dist/rbac/permissions.d.mts +0 -26
  119. package/dist/rbac/permissions.d.ts +0 -26
  120. package/dist/rbac/permissions.js +0 -94
  121. package/dist/rbac/permissions.js.map +0 -1
  122. package/dist/rbac/permissions.mjs +0 -90
  123. package/dist/rbac/permissions.mjs.map +0 -1
  124. package/dist/rbac/server.d.mts +0 -1
  125. package/dist/rbac/server.d.ts +0 -1
  126. package/dist/rbac/server.js +0 -128
  127. package/dist/rbac/server.js.map +0 -1
  128. package/dist/rbac/server.mjs +0 -124
  129. package/dist/rbac/server.mjs.map +0 -1
  130. package/dist/schemas/index.d.mts +0 -1257
  131. package/dist/schemas/index.d.ts +0 -1257
  132. package/dist/schemas/index.js +0 -572
  133. package/dist/schemas/index.js.map +0 -1
  134. package/dist/schemas/index.mjs +0 -523
  135. package/dist/schemas/index.mjs.map +0 -1
  136. package/dist/server-QuYCTa89.d.mts +0 -83
  137. package/dist/server-QuYCTa89.d.ts +0 -83
  138. package/dist/sonner-C74GlRDQ.d.mts +0 -71
  139. package/dist/sonner-C74GlRDQ.d.ts +0 -71
  140. package/dist/status-BOXZgIqX.d.mts +0 -12
  141. package/dist/status-BOXZgIqX.d.ts +0 -12
  142. package/dist/system/index.d.mts +0 -77
  143. package/dist/system/index.d.ts +0 -77
  144. package/dist/system/index.js +0 -102
  145. package/dist/system/index.js.map +0 -1
  146. package/dist/system/index.mjs +0 -100
  147. package/dist/system/index.mjs.map +0 -1
  148. package/dist/tabs-C6FfBwPY.d.mts +0 -18
  149. package/dist/tabs-C6FfBwPY.d.ts +0 -18
  150. package/dist/tenant-provider-B8eC_Wpb.d.mts +0 -27
  151. package/dist/tenant-provider-B8eC_Wpb.d.ts +0 -27
  152. package/dist/types/index.d.mts +0 -469
  153. package/dist/types/index.d.ts +0 -469
  154. package/dist/types/index.js +0 -25
  155. package/dist/types/index.js.map +0 -1
  156. package/dist/types/index.mjs +0 -21
  157. package/dist/types/index.mjs.map +0 -1
  158. package/dist/ui/auth.d.mts +0 -39
  159. package/dist/ui/auth.d.ts +0 -39
  160. package/dist/ui/auth.js +0 -4941
  161. package/dist/ui/auth.js.map +0 -1
  162. package/dist/ui/auth.mjs +0 -4896
  163. package/dist/ui/auth.mjs.map +0 -1
  164. package/dist/ui/crud.d.mts +0 -2
  165. package/dist/ui/crud.d.ts +0 -2
  166. package/dist/ui/crud.js +0 -4
  167. package/dist/ui/crud.js.map +0 -1
  168. package/dist/ui/crud.mjs +0 -3
  169. package/dist/ui/crud.mjs.map +0 -1
  170. package/dist/ui/data-display.d.mts +0 -596
  171. package/dist/ui/data-display.d.ts +0 -596
  172. package/dist/ui/data-display.js +0 -5307
  173. package/dist/ui/data-display.js.map +0 -1
  174. package/dist/ui/data-display.mjs +0 -5212
  175. package/dist/ui/data-display.mjs.map +0 -1
  176. package/dist/ui/feedback.d.mts +0 -55
  177. package/dist/ui/feedback.d.ts +0 -55
  178. package/dist/ui/feedback.js +0 -2608
  179. package/dist/ui/feedback.js.map +0 -1
  180. package/dist/ui/feedback.mjs +0 -2526
  181. package/dist/ui/feedback.mjs.map +0 -1
  182. package/dist/ui/forms.d.mts +0 -309
  183. package/dist/ui/forms.d.ts +0 -309
  184. package/dist/ui/forms.js +0 -4656
  185. package/dist/ui/forms.js.map +0 -1
  186. package/dist/ui/forms.mjs +0 -4571
  187. package/dist/ui/forms.mjs.map +0 -1
  188. package/dist/ui/index.d.mts +0 -331
  189. package/dist/ui/index.d.ts +0 -331
  190. package/dist/ui/index.js +0 -16953
  191. package/dist/ui/index.js.map +0 -1
  192. package/dist/ui/index.mjs +0 -16598
  193. package/dist/ui/index.mjs.map +0 -1
  194. package/dist/ui/primitives/client.d.mts +0 -61
  195. package/dist/ui/primitives/client.d.ts +0 -61
  196. package/dist/ui/primitives/client.js +0 -3408
  197. package/dist/ui/primitives/client.js.map +0 -1
  198. package/dist/ui/primitives/client.mjs +0 -3256
  199. package/dist/ui/primitives/client.mjs.map +0 -1
  200. package/dist/ui/primitives.d.mts +0 -113
  201. package/dist/ui/primitives.d.ts +0 -113
  202. package/dist/ui/primitives.js +0 -3356
  203. package/dist/ui/primitives.js.map +0 -1
  204. package/dist/ui/primitives.mjs +0 -3227
  205. package/dist/ui/primitives.mjs.map +0 -1
  206. package/dist/user/index.d.mts +0 -228
  207. package/dist/user/index.d.ts +0 -228
  208. package/dist/user/index.js +0 -4306
  209. package/dist/user/index.js.map +0 -1
  210. package/dist/user/index.mjs +0 -4260
  211. package/dist/user/index.mjs.map +0 -1
  212. package/dist/utils/index.d.mts +0 -205
  213. package/dist/utils/index.d.ts +0 -205
  214. package/dist/utils/index.js +0 -574
  215. package/dist/utils/index.js.map +0 -1
  216. package/dist/utils/index.mjs +0 -514
  217. package/dist/utils/index.mjs.map +0 -1
  218. package/dist/workflow/index.d.mts +0 -40
  219. package/dist/workflow/index.d.ts +0 -40
  220. package/dist/workflow/index.js +0 -3710
  221. package/dist/workflow/index.js.map +0 -1
  222. package/dist/workflow/index.mjs +0 -3677
  223. package/dist/workflow/index.mjs.map +0 -1
@@ -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":"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","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 };
@@ -1,210 +0,0 @@
1
- 'use strict';
2
-
3
- // src/auth/auth-service.ts
4
- async function verifyPassword(password, hash) {
5
- try {
6
- const bcrypt = await import('bcryptjs');
7
- return bcrypt.compareSync(password, hash);
8
- } catch (error) {
9
- console.error("Error verifying password", error);
10
- return false;
11
- }
12
- }
13
- async function authenticateUser(db, email, password) {
14
- try {
15
- const user = await db.user.findUnique({
16
- where: { email: email.toLowerCase().trim() },
17
- select: {
18
- id: true,
19
- email: true,
20
- name: true,
21
- avatar: true,
22
- password: true,
23
- isActive: true
24
- }
25
- });
26
- if (!user) {
27
- throw new Error("Invalid email or password");
28
- }
29
- if (!user.isActive) {
30
- throw new Error("ACCOUNT_SUSPENDED");
31
- }
32
- if (!user.password) {
33
- throw new Error("Invalid email or password");
34
- }
35
- const isPasswordValid = await verifyPassword(password, user.password);
36
- if (!isPasswordValid) {
37
- throw new Error("Invalid email or password");
38
- }
39
- await db.user.update({
40
- where: { id: user.id },
41
- data: { lastLoginAt: /* @__PURE__ */ new Date() }
42
- });
43
- return {
44
- id: user.id,
45
- name: user.name || "",
46
- email: user.email,
47
- avatar: user.avatar || null,
48
- status: "ONLINE"
49
- };
50
- } catch (error) {
51
- if (error instanceof Error) {
52
- throw error;
53
- }
54
- throw new Error("Error signing in");
55
- }
56
- }
57
-
58
- // src/auth/index.ts
59
- var ADMIN_ROLE_CODE = "admin";
60
- var BYPASS_AUTH = process.env.BYPASS_AUTH === "true" || process.env.BYPASS_AUTH === "1";
61
- var ACTION_CODES = {
62
- create: "create",
63
- view: "view",
64
- update: "update",
65
- delete: "delete",
66
- export: "export",
67
- import: "import",
68
- approve: "approve",
69
- reject: "reject"
70
- };
71
- function getActionCode(action) {
72
- return ACTION_CODES[action] || action;
73
- }
74
- function getUserPermissions(session) {
75
- if (!session?.user) return [];
76
- const user = session.user;
77
- if (!user.permissions) {
78
- return [];
79
- }
80
- return user.permissions;
81
- }
82
- function getCrudPermissionsFromSession(session, entity) {
83
- if (BYPASS_AUTH) {
84
- return {
85
- create: true,
86
- view: true,
87
- update: true,
88
- delete: true,
89
- export: true,
90
- import: true,
91
- approve: true,
92
- reject: true
93
- };
94
- }
95
- if (!session?.user) {
96
- return {
97
- create: false,
98
- view: false,
99
- update: false,
100
- delete: false,
101
- export: false,
102
- import: false,
103
- approve: false,
104
- reject: false
105
- };
106
- }
107
- const user = session.user;
108
- if (!user.id) {
109
- return {
110
- create: false,
111
- view: false,
112
- update: false,
113
- delete: false,
114
- export: false,
115
- import: false,
116
- approve: false,
117
- reject: false
118
- };
119
- }
120
- const isAdmin2 = user.roles?.includes(ADMIN_ROLE_CODE) || user.roles?.includes("SUPER_ADMIN");
121
- if (isAdmin2) {
122
- return {
123
- create: true,
124
- view: true,
125
- update: true,
126
- delete: true,
127
- export: true,
128
- import: true,
129
- approve: true,
130
- reject: true
131
- };
132
- }
133
- const permissions = user.permissions || [];
134
- const permissionKeys = new Set(
135
- permissions.map((p) => `${p.resourceCode}:${p.actionCode}`)
136
- );
137
- const hasPermission2 = (action) => {
138
- const key = `${entity}:${action}`;
139
- return permissionKeys.has(key);
140
- };
141
- return {
142
- create: hasPermission2(getActionCode("create")),
143
- view: hasPermission2(getActionCode("view")),
144
- update: hasPermission2(getActionCode("update")),
145
- delete: hasPermission2(getActionCode("delete")),
146
- export: hasPermission2(getActionCode("export")),
147
- import: hasPermission2(getActionCode("import")),
148
- approve: hasPermission2(getActionCode("approve")),
149
- reject: hasPermission2(getActionCode("reject"))
150
- };
151
- }
152
- function checkPermission(session, resourceCode, actionCode) {
153
- if (BYPASS_AUTH) {
154
- return true;
155
- }
156
- if (!session?.user) return false;
157
- const user = session.user;
158
- if (!user.permissions || user.permissions.length === 0) {
159
- return false;
160
- }
161
- if (user.roles?.includes(ADMIN_ROLE_CODE) || user.roles?.includes("SUPER_ADMIN")) {
162
- return true;
163
- }
164
- return user.permissions.some(
165
- (p) => p.resourceCode === resourceCode && p.actionCode === actionCode
166
- );
167
- }
168
- function hasPermission(session, resourceCode, actionCode) {
169
- return checkPermission(session, resourceCode, actionCode);
170
- }
171
- function requirePermission(session, resourceCode, actionCode) {
172
- if (!checkPermission(session, resourceCode, actionCode)) {
173
- throw new Error(
174
- `Unauthorized: User does not have permission ${actionCode} on ${resourceCode}`
175
- );
176
- }
177
- }
178
- function hasRole(session, roleCode) {
179
- if (!session?.user) return false;
180
- const user = session.user;
181
- if (!user.roles) {
182
- return false;
183
- }
184
- return user.roles.includes(roleCode);
185
- }
186
- function hasAnyRole(session, roleCodes) {
187
- if (!session?.user) return false;
188
- const user = session.user;
189
- if (!user.roles) {
190
- return false;
191
- }
192
- return roleCodes.some((role) => user.roles.includes(role));
193
- }
194
- function isAdmin(session) {
195
- return hasRole(session, ADMIN_ROLE_CODE);
196
- }
197
-
198
- exports.authenticateUser = authenticateUser;
199
- exports.checkPermission = checkPermission;
200
- exports.getActionCode = getActionCode;
201
- exports.getCrudPermissionsFromSession = getCrudPermissionsFromSession;
202
- exports.getUserPermissions = getUserPermissions;
203
- exports.hasAnyRole = hasAnyRole;
204
- exports.hasPermission = hasPermission;
205
- exports.hasRole = hasRole;
206
- exports.isAdmin = isAdmin;
207
- exports.requirePermission = requirePermission;
208
- exports.verifyPassword = verifyPassword;
209
- //# sourceMappingURL=index.js.map
210
- //# sourceMappingURL=index.js.map