@m5kdev/backend 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 (294) hide show
  1. package/.cursor/rules/backend.mdc +70 -0
  2. package/.turbo/turbo-build.log +5 -0
  3. package/.turbo/turbo-check-types.log +5 -0
  4. package/.turbo/turbo-lint$colon$fix.log +255 -0
  5. package/CHANGELOG.md +19 -0
  6. package/dist/src/lib/posthog.d.ts +3 -0
  7. package/dist/src/lib/posthog.d.ts.map +1 -0
  8. package/dist/src/lib/posthog.js +7 -0
  9. package/dist/src/lib/sentry.d.ts +2 -0
  10. package/dist/src/lib/sentry.d.ts.map +1 -0
  11. package/dist/src/lib/sentry.js +9 -0
  12. package/dist/src/modules/access/access.repository.d.ts +2348 -0
  13. package/dist/src/modules/access/access.repository.d.ts.map +1 -0
  14. package/dist/src/modules/access/access.repository.js +32 -0
  15. package/dist/src/modules/access/access.service.d.ts +22 -0
  16. package/dist/src/modules/access/access.service.d.ts.map +1 -0
  17. package/dist/src/modules/access/access.service.js +51 -0
  18. package/dist/src/modules/access/access.test.d.ts +2 -0
  19. package/dist/src/modules/access/access.test.d.ts.map +1 -0
  20. package/dist/src/modules/access/access.test.js +182 -0
  21. package/dist/src/modules/access/access.utils.d.ts +17 -0
  22. package/dist/src/modules/access/access.utils.d.ts.map +1 -0
  23. package/dist/src/modules/access/access.utils.js +20 -0
  24. package/dist/src/modules/ai/ai.db.d.ts +396 -0
  25. package/dist/src/modules/ai/ai.db.d.ts.map +1 -0
  26. package/dist/src/modules/ai/ai.db.js +39 -0
  27. package/dist/src/modules/ai/ai.prompt.d.ts +28 -0
  28. package/dist/src/modules/ai/ai.prompt.d.ts.map +1 -0
  29. package/dist/src/modules/ai/ai.prompt.js +30 -0
  30. package/dist/src/modules/ai/ai.repository.d.ts +424 -0
  31. package/dist/src/modules/ai/ai.repository.d.ts.map +1 -0
  32. package/dist/src/modules/ai/ai.repository.js +26 -0
  33. package/dist/src/modules/ai/ai.router.d.ts +2 -0
  34. package/dist/src/modules/ai/ai.router.d.ts.map +1 -0
  35. package/dist/src/modules/ai/ai.router.js +132 -0
  36. package/dist/src/modules/ai/ai.service.d.ts +115 -0
  37. package/dist/src/modules/ai/ai.service.d.ts.map +1 -0
  38. package/dist/src/modules/ai/ai.service.js +207 -0
  39. package/dist/src/modules/ai/ai.trpc.d.ts +59 -0
  40. package/dist/src/modules/ai/ai.trpc.d.ts.map +1 -0
  41. package/dist/src/modules/ai/ai.trpc.js +20 -0
  42. package/dist/src/modules/ai/ideogram/ideogram.constants.d.ts +8 -0
  43. package/dist/src/modules/ai/ideogram/ideogram.constants.d.ts.map +1 -0
  44. package/dist/src/modules/ai/ideogram/ideogram.constants.js +167 -0
  45. package/dist/src/modules/ai/ideogram/ideogram.dto.d.ts +230 -0
  46. package/dist/src/modules/ai/ideogram/ideogram.dto.d.ts.map +1 -0
  47. package/dist/src/modules/ai/ideogram/ideogram.dto.js +49 -0
  48. package/dist/src/modules/ai/ideogram/ideogram.prompt.d.ts +3 -0
  49. package/dist/src/modules/ai/ideogram/ideogram.prompt.d.ts.map +1 -0
  50. package/dist/src/modules/ai/ideogram/ideogram.prompt.js +860 -0
  51. package/dist/src/modules/ai/ideogram/ideogram.repository.d.ts +7 -0
  52. package/dist/src/modules/ai/ideogram/ideogram.repository.d.ts.map +1 -0
  53. package/dist/src/modules/ai/ideogram/ideogram.repository.js +46 -0
  54. package/dist/src/modules/ai/ideogram/ideogram.service.d.ts +10 -0
  55. package/dist/src/modules/ai/ideogram/ideogram.service.d.ts.map +1 -0
  56. package/dist/src/modules/ai/ideogram/ideogram.service.js +11 -0
  57. package/dist/src/modules/auth/auth.db.d.ts +2336 -0
  58. package/dist/src/modules/auth/auth.db.d.ts.map +1 -0
  59. package/dist/src/modules/auth/auth.db.js +215 -0
  60. package/dist/src/modules/auth/auth.dto.d.ts +66 -0
  61. package/dist/src/modules/auth/auth.dto.d.ts.map +1 -0
  62. package/dist/src/modules/auth/auth.dto.js +38 -0
  63. package/dist/src/modules/auth/auth.lib.d.ts +4874 -0
  64. package/dist/src/modules/auth/auth.lib.d.ts.map +1 -0
  65. package/dist/src/modules/auth/auth.lib.js +284 -0
  66. package/dist/src/modules/auth/auth.middleware.d.ts +615 -0
  67. package/dist/src/modules/auth/auth.middleware.d.ts.map +1 -0
  68. package/dist/src/modules/auth/auth.middleware.js +52 -0
  69. package/dist/src/modules/auth/auth.repository.d.ts +2417 -0
  70. package/dist/src/modules/auth/auth.repository.d.ts.map +1 -0
  71. package/dist/src/modules/auth/auth.repository.js +541 -0
  72. package/dist/src/modules/auth/auth.service.d.ts +104 -0
  73. package/dist/src/modules/auth/auth.service.d.ts.map +1 -0
  74. package/dist/src/modules/auth/auth.service.js +201 -0
  75. package/dist/src/modules/auth/auth.trpc.d.ts +309 -0
  76. package/dist/src/modules/auth/auth.trpc.d.ts.map +1 -0
  77. package/dist/src/modules/auth/auth.trpc.js +157 -0
  78. package/dist/src/modules/auth/auth.utils.d.ts +2352 -0
  79. package/dist/src/modules/auth/auth.utils.d.ts.map +1 -0
  80. package/dist/src/modules/auth/auth.utils.js +97 -0
  81. package/dist/src/modules/base/base.abstract.d.ts +19 -0
  82. package/dist/src/modules/base/base.abstract.d.ts.map +1 -0
  83. package/dist/src/modules/base/base.abstract.js +53 -0
  84. package/dist/src/modules/base/base.dto.d.ts +70 -0
  85. package/dist/src/modules/base/base.dto.d.ts.map +1 -0
  86. package/dist/src/modules/base/base.dto.js +112 -0
  87. package/dist/src/modules/base/base.grants.d.ts +29 -0
  88. package/dist/src/modules/base/base.grants.d.ts.map +1 -0
  89. package/dist/src/modules/base/base.grants.js +123 -0
  90. package/dist/src/modules/base/base.grants.test.d.ts +2 -0
  91. package/dist/src/modules/base/base.grants.test.d.ts.map +1 -0
  92. package/dist/src/modules/base/base.grants.test.js +668 -0
  93. package/dist/src/modules/base/base.repository.d.ts +97 -0
  94. package/dist/src/modules/base/base.repository.d.ts.map +1 -0
  95. package/dist/src/modules/base/base.repository.js +307 -0
  96. package/dist/src/modules/base/base.service.d.ts +42 -0
  97. package/dist/src/modules/base/base.service.d.ts.map +1 -0
  98. package/dist/src/modules/base/base.service.js +109 -0
  99. package/dist/src/modules/base/base.types.d.ts +2 -0
  100. package/dist/src/modules/base/base.types.d.ts.map +1 -0
  101. package/dist/src/modules/base/base.types.js +2 -0
  102. package/dist/src/modules/billing/billing.db.d.ts +366 -0
  103. package/dist/src/modules/billing/billing.db.d.ts.map +1 -0
  104. package/dist/src/modules/billing/billing.db.js +29 -0
  105. package/dist/src/modules/billing/billing.repository.d.ts +2764 -0
  106. package/dist/src/modules/billing/billing.repository.d.ts.map +1 -0
  107. package/dist/src/modules/billing/billing.repository.js +235 -0
  108. package/dist/src/modules/billing/billing.router.d.ts +5 -0
  109. package/dist/src/modules/billing/billing.router.d.ts.map +1 -0
  110. package/dist/src/modules/billing/billing.router.js +56 -0
  111. package/dist/src/modules/billing/billing.service.d.ts +60 -0
  112. package/dist/src/modules/billing/billing.service.d.ts.map +1 -0
  113. package/dist/src/modules/billing/billing.service.js +147 -0
  114. package/dist/src/modules/billing/billing.trpc.d.ts +75 -0
  115. package/dist/src/modules/billing/billing.trpc.d.ts.map +1 -0
  116. package/dist/src/modules/billing/billing.trpc.js +17 -0
  117. package/dist/src/modules/clay/clay.repository.d.ts +6 -0
  118. package/dist/src/modules/clay/clay.repository.d.ts.map +1 -0
  119. package/dist/src/modules/clay/clay.repository.js +26 -0
  120. package/dist/src/modules/clay/clay.service.d.ts +29 -0
  121. package/dist/src/modules/clay/clay.service.d.ts.map +1 -0
  122. package/dist/src/modules/clay/clay.service.js +24 -0
  123. package/dist/src/modules/connect/connect.db.d.ts +357 -0
  124. package/dist/src/modules/connect/connect.db.d.ts.map +1 -0
  125. package/dist/src/modules/connect/connect.db.js +30 -0
  126. package/dist/src/modules/connect/connect.dto.d.ts +75 -0
  127. package/dist/src/modules/connect/connect.dto.d.ts.map +1 -0
  128. package/dist/src/modules/connect/connect.dto.js +36 -0
  129. package/dist/src/modules/connect/connect.linkedin.d.ts +3 -0
  130. package/dist/src/modules/connect/connect.linkedin.d.ts.map +1 -0
  131. package/dist/src/modules/connect/connect.linkedin.js +53 -0
  132. package/dist/src/modules/connect/connect.oauth.d.ts +28 -0
  133. package/dist/src/modules/connect/connect.oauth.d.ts.map +1 -0
  134. package/dist/src/modules/connect/connect.oauth.js +198 -0
  135. package/dist/src/modules/connect/connect.repository.d.ts +414 -0
  136. package/dist/src/modules/connect/connect.repository.d.ts.map +1 -0
  137. package/dist/src/modules/connect/connect.repository.js +54 -0
  138. package/dist/src/modules/connect/connect.router.d.ts +5 -0
  139. package/dist/src/modules/connect/connect.router.d.ts.map +1 -0
  140. package/dist/src/modules/connect/connect.router.js +54 -0
  141. package/dist/src/modules/connect/connect.service.d.ts +89 -0
  142. package/dist/src/modules/connect/connect.service.d.ts.map +1 -0
  143. package/dist/src/modules/connect/connect.service.js +114 -0
  144. package/dist/src/modules/connect/connect.trpc.d.ts +81 -0
  145. package/dist/src/modules/connect/connect.trpc.d.ts.map +1 -0
  146. package/dist/src/modules/connect/connect.trpc.js +21 -0
  147. package/dist/src/modules/connect/connect.types.d.ts +26 -0
  148. package/dist/src/modules/connect/connect.types.d.ts.map +1 -0
  149. package/dist/src/modules/connect/connect.types.js +2 -0
  150. package/dist/src/modules/crypto/crypto.db.d.ts +152 -0
  151. package/dist/src/modules/crypto/crypto.db.d.ts.map +1 -0
  152. package/dist/src/modules/crypto/crypto.db.js +17 -0
  153. package/dist/src/modules/crypto/crypto.repository.d.ts +160 -0
  154. package/dist/src/modules/crypto/crypto.repository.d.ts.map +1 -0
  155. package/dist/src/modules/crypto/crypto.repository.js +10 -0
  156. package/dist/src/modules/crypto/crypto.service.d.ts +11 -0
  157. package/dist/src/modules/crypto/crypto.service.d.ts.map +1 -0
  158. package/dist/src/modules/crypto/crypto.service.js +52 -0
  159. package/dist/src/modules/email/email.service.d.ts +57 -0
  160. package/dist/src/modules/email/email.service.d.ts.map +1 -0
  161. package/dist/src/modules/email/email.service.js +107 -0
  162. package/dist/src/modules/file/file.repository.d.ts +13 -0
  163. package/dist/src/modules/file/file.repository.d.ts.map +1 -0
  164. package/dist/src/modules/file/file.repository.js +79 -0
  165. package/dist/src/modules/file/file.router.d.ts +4 -0
  166. package/dist/src/modules/file/file.router.d.ts.map +1 -0
  167. package/dist/src/modules/file/file.router.js +99 -0
  168. package/dist/src/modules/file/file.service.d.ts +25 -0
  169. package/dist/src/modules/file/file.service.d.ts.map +1 -0
  170. package/dist/src/modules/file/file.service.js +150 -0
  171. package/dist/src/modules/recurrence/recurrence.db.d.ts +563 -0
  172. package/dist/src/modules/recurrence/recurrence.db.d.ts.map +1 -0
  173. package/dist/src/modules/recurrence/recurrence.db.js +66 -0
  174. package/dist/src/modules/recurrence/recurrence.repository.d.ts +585 -0
  175. package/dist/src/modules/recurrence/recurrence.repository.d.ts.map +1 -0
  176. package/dist/src/modules/recurrence/recurrence.repository.js +39 -0
  177. package/dist/src/modules/recurrence/recurrence.service.d.ts +30 -0
  178. package/dist/src/modules/recurrence/recurrence.service.d.ts.map +1 -0
  179. package/dist/src/modules/recurrence/recurrence.service.js +70 -0
  180. package/dist/src/modules/recurrence/recurrence.trpc.d.ts +243 -0
  181. package/dist/src/modules/recurrence/recurrence.trpc.d.ts.map +1 -0
  182. package/dist/src/modules/recurrence/recurrence.trpc.js +65 -0
  183. package/dist/src/modules/social/social.dto.d.ts +35 -0
  184. package/dist/src/modules/social/social.dto.d.ts.map +1 -0
  185. package/dist/src/modules/social/social.dto.js +18 -0
  186. package/dist/src/modules/social/social.linkedin.d.ts +11 -0
  187. package/dist/src/modules/social/social.linkedin.d.ts.map +1 -0
  188. package/dist/src/modules/social/social.linkedin.js +427 -0
  189. package/dist/src/modules/social/social.linkedin.test.d.ts +2 -0
  190. package/dist/src/modules/social/social.linkedin.test.d.ts.map +1 -0
  191. package/dist/src/modules/social/social.linkedin.test.js +235 -0
  192. package/dist/src/modules/social/social.service.d.ts +29 -0
  193. package/dist/src/modules/social/social.service.d.ts.map +1 -0
  194. package/dist/src/modules/social/social.service.js +76 -0
  195. package/dist/src/modules/social/social.types.d.ts +36 -0
  196. package/dist/src/modules/social/social.types.d.ts.map +1 -0
  197. package/dist/src/modules/social/social.types.js +2 -0
  198. package/dist/src/modules/tag/tag.db.d.ts +347 -0
  199. package/dist/src/modules/tag/tag.db.d.ts.map +1 -0
  200. package/dist/src/modules/tag/tag.db.js +42 -0
  201. package/dist/src/modules/tag/tag.dto.d.ts +1019 -0
  202. package/dist/src/modules/tag/tag.dto.d.ts.map +1 -0
  203. package/dist/src/modules/tag/tag.dto.js +9 -0
  204. package/dist/src/modules/tag/tag.repository.d.ts +384 -0
  205. package/dist/src/modules/tag/tag.repository.d.ts.map +1 -0
  206. package/dist/src/modules/tag/tag.repository.js +154 -0
  207. package/dist/src/modules/tag/tag.service.d.ts +36 -0
  208. package/dist/src/modules/tag/tag.service.d.ts.map +1 -0
  209. package/dist/src/modules/tag/tag.service.js +31 -0
  210. package/dist/src/modules/tag/tag.trpc.d.ts +191 -0
  211. package/dist/src/modules/tag/tag.trpc.d.ts.map +1 -0
  212. package/dist/src/modules/tag/tag.trpc.js +47 -0
  213. package/dist/src/modules/utils/applyPagination.d.ts +7 -0
  214. package/dist/src/modules/utils/applyPagination.d.ts.map +1 -0
  215. package/dist/src/modules/utils/applyPagination.js +16 -0
  216. package/dist/src/modules/utils/applySorting.d.ts +9 -0
  217. package/dist/src/modules/utils/applySorting.d.ts.map +1 -0
  218. package/dist/src/modules/utils/applySorting.js +18 -0
  219. package/dist/src/modules/utils/getConditionsFromFilters.d.ts +5 -0
  220. package/dist/src/modules/utils/getConditionsFromFilters.d.ts.map +1 -0
  221. package/dist/src/modules/utils/getConditionsFromFilters.js +200 -0
  222. package/dist/src/modules/video/video.service.d.ts +8 -0
  223. package/dist/src/modules/video/video.service.d.ts.map +1 -0
  224. package/dist/src/modules/video/video.service.js +84 -0
  225. package/dist/src/modules/webhook/webhook.constants.d.ts +9 -0
  226. package/dist/src/modules/webhook/webhook.constants.d.ts.map +1 -0
  227. package/dist/src/modules/webhook/webhook.constants.js +10 -0
  228. package/dist/src/modules/webhook/webhook.db.d.ts +137 -0
  229. package/dist/src/modules/webhook/webhook.db.d.ts.map +1 -0
  230. package/dist/src/modules/webhook/webhook.db.js +17 -0
  231. package/dist/src/modules/webhook/webhook.dto.d.ts +395 -0
  232. package/dist/src/modules/webhook/webhook.dto.d.ts.map +1 -0
  233. package/dist/src/modules/webhook/webhook.dto.js +7 -0
  234. package/dist/src/modules/webhook/webhook.repository.d.ts +149 -0
  235. package/dist/src/modules/webhook/webhook.repository.d.ts.map +1 -0
  236. package/dist/src/modules/webhook/webhook.repository.js +56 -0
  237. package/dist/src/modules/webhook/webhook.router.d.ts +4 -0
  238. package/dist/src/modules/webhook/webhook.router.d.ts.map +1 -0
  239. package/dist/src/modules/webhook/webhook.router.js +30 -0
  240. package/dist/src/modules/webhook/webhook.service.d.ts +10 -0
  241. package/dist/src/modules/webhook/webhook.service.d.ts.map +1 -0
  242. package/dist/src/modules/webhook/webhook.service.js +68 -0
  243. package/dist/src/modules/workflow/workflow.db.d.ts +297 -0
  244. package/dist/src/modules/workflow/workflow.db.d.ts.map +1 -0
  245. package/dist/src/modules/workflow/workflow.db.js +30 -0
  246. package/dist/src/modules/workflow/workflow.repository.d.ts +344 -0
  247. package/dist/src/modules/workflow/workflow.repository.d.ts.map +1 -0
  248. package/dist/src/modules/workflow/workflow.repository.js +105 -0
  249. package/dist/src/modules/workflow/workflow.service.d.ts +22 -0
  250. package/dist/src/modules/workflow/workflow.service.d.ts.map +1 -0
  251. package/dist/src/modules/workflow/workflow.service.js +37 -0
  252. package/dist/src/modules/workflow/workflow.trpc.d.ts +93 -0
  253. package/dist/src/modules/workflow/workflow.trpc.d.ts.map +1 -0
  254. package/dist/src/modules/workflow/workflow.trpc.js +21 -0
  255. package/dist/src/modules/workflow/workflow.types.d.ts +21 -0
  256. package/dist/src/modules/workflow/workflow.types.d.ts.map +1 -0
  257. package/dist/src/modules/workflow/workflow.types.js +2 -0
  258. package/dist/src/modules/workflow/workflow.utils.d.ts +22 -0
  259. package/dist/src/modules/workflow/workflow.utils.d.ts.map +1 -0
  260. package/dist/src/modules/workflow/workflow.utils.js +173 -0
  261. package/dist/src/test/stubs/utils.d.ts +3 -0
  262. package/dist/src/test/stubs/utils.d.ts.map +1 -0
  263. package/dist/src/test/stubs/utils.js +5 -0
  264. package/dist/src/trpc/context.d.ts +42 -0
  265. package/dist/src/trpc/context.d.ts.map +1 -0
  266. package/dist/src/trpc/context.js +17 -0
  267. package/dist/src/trpc/index.d.ts +4 -0
  268. package/dist/src/trpc/index.d.ts.map +1 -0
  269. package/dist/src/trpc/index.js +6 -0
  270. package/dist/src/trpc/procedures.d.ts +234 -0
  271. package/dist/src/trpc/procedures.d.ts.map +1 -0
  272. package/dist/src/trpc/procedures.js +32 -0
  273. package/dist/src/trpc/utils.d.ts +5 -0
  274. package/dist/src/trpc/utils.d.ts.map +1 -0
  275. package/dist/src/trpc/utils.js +20 -0
  276. package/dist/src/types.d.ts +486 -0
  277. package/dist/src/types.d.ts.map +1 -0
  278. package/dist/src/types.js +13 -0
  279. package/dist/src/utils/errors.d.ts +50 -0
  280. package/dist/src/utils/errors.d.ts.map +1 -0
  281. package/dist/src/utils/errors.js +104 -0
  282. package/dist/src/utils/logger.d.ts +2 -0
  283. package/dist/src/utils/logger.d.ts.map +1 -0
  284. package/dist/src/utils/logger.js +11 -0
  285. package/dist/src/utils/posthog.d.ts +14 -0
  286. package/dist/src/utils/posthog.d.ts.map +1 -0
  287. package/dist/src/utils/posthog.js +31 -0
  288. package/dist/src/utils/types.d.ts +5 -0
  289. package/dist/src/utils/types.d.ts.map +1 -0
  290. package/dist/src/utils/types.js +2 -0
  291. package/dist/tsconfig.tsbuildinfo +1 -0
  292. package/jest.config.ts +19 -0
  293. package/package.json +3 -6
  294. package/tsconfig.json +21 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"access.repository.d.ts","sourceRoot":"","sources":["../../../../src/modules/access/access.repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AccessRepository = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const drizzle_orm_1 = require("drizzle-orm");
6
+ const neverthrow_1 = require("neverthrow");
7
+ const auth = tslib_1.__importStar(require("#modules/auth/auth.db"));
8
+ const base_repository_1 = require("#modules/base/base.repository");
9
+ const schema = { ...auth };
10
+ class AccessRepository extends base_repository_1.BaseRepository {
11
+ async getOrganizationRole(userId, organizationId) {
12
+ return this.throwableAsync(async () => {
13
+ const [member] = await this.orm
14
+ .select({ role: schema.members.role })
15
+ .from(schema.members)
16
+ .where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema.members.organizationId, organizationId), (0, drizzle_orm_1.eq)(schema.members.userId, userId)))
17
+ .limit(1);
18
+ return (0, neverthrow_1.ok)(member?.role ?? "");
19
+ });
20
+ }
21
+ async getTeamRole(userId, teamId) {
22
+ return this.throwableAsync(async () => {
23
+ const [member] = await this.orm
24
+ .select({ role: schema.teamMembers.role })
25
+ .from(schema.teamMembers)
26
+ .where((0, drizzle_orm_1.and)((0, drizzle_orm_1.eq)(schema.teamMembers.teamId, teamId), (0, drizzle_orm_1.eq)(schema.teamMembers.userId, userId)))
27
+ .limit(1);
28
+ return (0, neverthrow_1.ok)(member?.role ?? "");
29
+ });
30
+ }
31
+ }
32
+ exports.AccessRepository = AccessRepository;
@@ -0,0 +1,22 @@
1
+ import type { Statements } from "better-auth/plugins/access";
2
+ import type { AccessRepository } from "#modules/access/access.repository";
3
+ import type { AccessControlRoles } from "#modules/access/access.utils";
4
+ import type { ServerResultAsync } from "#modules/base/base.dto";
5
+ import { BaseService } from "#modules/base/base.service";
6
+ type User = {
7
+ id: string;
8
+ role: string;
9
+ };
10
+ export declare class AccessService<T extends Statements> extends BaseService<{
11
+ access: AccessRepository;
12
+ }, never> {
13
+ acr: AccessControlRoles<T>;
14
+ constructor(repositories: {
15
+ access: AccessRepository;
16
+ }, acr: AccessControlRoles<T>);
17
+ authorize(level: "user" | "team" | "organization", role: string, request: any, connector?: "OR" | "AND"): boolean;
18
+ checkAccess(user: User, level: "team" | "organization", levelId: string, request: any, connector?: "OR" | "AND"): ServerResultAsync<boolean>;
19
+ hasAccess(user: User, level: "user" | "team" | "organization", levelId: string, request: any, connector?: "OR" | "AND"): ServerResultAsync<boolean>;
20
+ }
21
+ export {};
22
+ //# sourceMappingURL=access.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"access.service.d.ts","sourceRoot":"","sources":["../../../../src/modules/access/access.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAE7D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAEzD,KAAK,IAAI,GAAG;IACV,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,qBAAa,aAAa,CAAC,CAAC,SAAS,UAAU,CAAE,SAAQ,WAAW,CAClE;IAAE,MAAM,EAAE,gBAAgB,CAAA;CAAE,EAC5B,KAAK,CACN;IACC,GAAG,EAAE,kBAAkB,CAAC,CAAC,CAAC,CAAC;gBAEf,YAAY,EAAE;QAAE,MAAM,EAAE,gBAAgB,CAAA;KAAE,EAAE,GAAG,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAKlF,SAAS,CACP,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,cAAc,EACvC,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,GAAG,EACZ,SAAS,GAAE,IAAI,GAAG,KAAa;IAU3B,WAAW,CACf,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,MAAM,GAAG,cAAc,EAC9B,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,GAAG,EACZ,SAAS,GAAE,IAAI,GAAG,KAAa,GAC9B,iBAAiB,CAAC,OAAO,CAAC;IASvB,SAAS,CACb,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,cAAc,EACvC,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,GAAG,EACZ,SAAS,GAAE,IAAI,GAAG,KAAa,GAC9B,iBAAiB,CAAC,OAAO,CAAC;CAsB9B"}
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AccessService = void 0;
4
+ const neverthrow_1 = require("neverthrow");
5
+ const base_service_1 = require("#modules/base/base.service");
6
+ class AccessService extends base_service_1.BaseService {
7
+ acr;
8
+ constructor(repositories, acr) {
9
+ super(repositories);
10
+ this.acr = acr;
11
+ }
12
+ authorize(level, role, request, connector = "AND") {
13
+ try {
14
+ return !!this.acr[level][role].authorize(request, connector).success;
15
+ }
16
+ catch (error) {
17
+ console.error(error);
18
+ return false;
19
+ }
20
+ }
21
+ async checkAccess(user, level, levelId, request, connector = "AND") {
22
+ const role = level === "organization"
23
+ ? await this.repository.access.getOrganizationRole(user.id, levelId)
24
+ : await this.repository.access.getTeamRole(user.id, levelId);
25
+ if (role.isErr())
26
+ return (0, neverthrow_1.err)(role.error);
27
+ return (0, neverthrow_1.ok)(this.authorize(level, role.value, request, connector));
28
+ }
29
+ async hasAccess(user, level, levelId, request, connector = "AND") {
30
+ // FIXME: catch all admin user access for now
31
+ if (user.role === "admin")
32
+ return (0, neverthrow_1.ok)(true);
33
+ const userAccess = this.authorize("user", user.role, request, connector);
34
+ if (level === "user")
35
+ return (0, neverthrow_1.ok)(userAccess && user.id === levelId);
36
+ if (userAccess)
37
+ return (0, neverthrow_1.ok)(true);
38
+ const organizationAccess = await this.checkAccess(user, "organization", levelId, request, connector);
39
+ if (organizationAccess.isErr())
40
+ return (0, neverthrow_1.err)(organizationAccess.error);
41
+ if (level === "organization")
42
+ return organizationAccess;
43
+ if (organizationAccess.value)
44
+ return (0, neverthrow_1.ok)(true);
45
+ const teamAccess = await this.checkAccess(user, "team", levelId, request, connector);
46
+ if (teamAccess.isErr())
47
+ return (0, neverthrow_1.err)(teamAccess.error);
48
+ return teamAccess;
49
+ }
50
+ }
51
+ exports.AccessService = AccessService;
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=access.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"access.test.d.ts","sourceRoot":"","sources":["../../../../src/modules/access/access.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,182 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const client_1 = require("@libsql/client");
5
+ const libsql_1 = require("drizzle-orm/libsql");
6
+ const fs_1 = tslib_1.__importDefault(require("fs"));
7
+ const path_1 = tslib_1.__importDefault(require("path"));
8
+ const access_repository_1 = require("#modules/access/access.repository");
9
+ const access_service_1 = require("#modules/access/access.service");
10
+ const access_utils_1 = require("#modules/access/access.utils");
11
+ const authSchema = tslib_1.__importStar(require("#modules/auth/auth.db"));
12
+ describe("AccessService", () => {
13
+ const statements = {
14
+ project: ["create", "share", "update", "delete"],
15
+ };
16
+ const roleDefinitions = {
17
+ user: {
18
+ admin: { project: ["create", "share", "update"] },
19
+ },
20
+ team: {
21
+ admin: { project: ["create", "share", "update"] },
22
+ },
23
+ organization: {
24
+ admin: { project: ["create", "share", "update"] },
25
+ },
26
+ };
27
+ const acr = (0, access_utils_1.createAccessRoles)(statements, roleDefinitions);
28
+ // Minimal repository stub; not used by authorize() unit tests
29
+ const accessService = new access_service_1.AccessService({ access: {} }, acr);
30
+ describe("user level", () => {
31
+ it("allows defined action", () => {
32
+ expect(accessService.authorize("user", "admin", { project: ["create"] })).toBe(true);
33
+ });
34
+ it("denies undefined action", () => {
35
+ expect(accessService.authorize("user", "admin", { project: ["delete"] })).toBe(false);
36
+ });
37
+ it("handles AND vs OR connectors for multiple actions", () => {
38
+ // admin has create but not delete
39
+ expect(accessService.authorize("user", "admin", { project: ["create", "delete"] }, "AND")).toBe(false);
40
+ expect(accessService.authorize("user", "admin", { project: { actions: ["create", "delete"], connector: "OR" } }, "OR")).toBe(true);
41
+ });
42
+ });
43
+ describe("team level", () => {
44
+ it("allows defined action", () => {
45
+ expect(accessService.authorize("team", "admin", { project: ["share"] })).toBe(true);
46
+ });
47
+ it("denies undefined action", () => {
48
+ expect(accessService.authorize("team", "admin", { project: ["delete"] })).toBe(false);
49
+ });
50
+ });
51
+ describe("organization level", () => {
52
+ it("allows defined action", () => {
53
+ expect(accessService.authorize("organization", "admin", { project: ["update"] })).toBe(true);
54
+ });
55
+ it("denies undefined action", () => {
56
+ expect(accessService.authorize("organization", "admin", { project: ["delete"] })).toBe(false);
57
+ });
58
+ });
59
+ });
60
+ describe("AccessRepository (libsql local)", () => {
61
+ const dbFile = path_1.default.join(__dirname, "access.test.sqlite");
62
+ const url = `file:${dbFile}`;
63
+ const client = (0, client_1.createClient)({ url });
64
+ const orm = (0, libsql_1.drizzle)(client, { schema: authSchema });
65
+ const repo = new access_repository_1.AccessRepository({ orm, schema: authSchema }, {});
66
+ beforeAll(async () => {
67
+ // Create minimal tables required for tests
68
+ await client.execute(`
69
+ CREATE TABLE IF NOT EXISTS members (
70
+ id TEXT PRIMARY KEY,
71
+ organization_id TEXT NOT NULL,
72
+ user_id TEXT NOT NULL,
73
+ role TEXT NOT NULL
74
+ );
75
+ `);
76
+ await client.execute(`
77
+ CREATE TABLE IF NOT EXISTS teammembers (
78
+ id TEXT PRIMARY KEY,
79
+ team_id TEXT NOT NULL,
80
+ user_id TEXT NOT NULL,
81
+ role TEXT NOT NULL
82
+ );
83
+ `);
84
+ });
85
+ beforeEach(async () => {
86
+ await client.execute({
87
+ sql: "INSERT INTO members (id, organization_id, user_id, role) VALUES (?, ?, ?, ?)",
88
+ args: ["m1", "org1", "user1", "admin"],
89
+ });
90
+ await client.execute({
91
+ sql: "INSERT INTO teammembers (id, team_id, user_id, role) VALUES (?, ?, ?, ?)",
92
+ args: ["tm1", "team1", "user1", "admin"],
93
+ });
94
+ });
95
+ afterEach(async () => {
96
+ await client.execute("DELETE FROM members;");
97
+ await client.execute("DELETE FROM teammembers;");
98
+ });
99
+ afterAll(async () => {
100
+ try {
101
+ await client.close();
102
+ }
103
+ catch { }
104
+ try {
105
+ if (fs_1.default.existsSync(dbFile))
106
+ fs_1.default.unlinkSync(dbFile);
107
+ }
108
+ catch { }
109
+ });
110
+ it("returns organization role for user", async () => {
111
+ const res = await repo.getOrganizationRole("user1", "org1");
112
+ expect(res.isOk()).toBe(true);
113
+ if (res.isOk())
114
+ expect(res.value).toBe("admin");
115
+ });
116
+ it("returns team role for user", async () => {
117
+ const res = await repo.getTeamRole("user1", "team1");
118
+ expect(res.isOk()).toBe(true);
119
+ if (res.isOk())
120
+ expect(res.value).toBe("admin");
121
+ });
122
+ describe("AccessService.hasAccess (with repo)", () => {
123
+ const hasAccessStatements = {
124
+ project: ["create", "share", "update", "delete"],
125
+ };
126
+ const hasAccessRoles = {
127
+ user: {
128
+ member: { project: ["create"] },
129
+ },
130
+ team: {
131
+ manager: { project: ["share"] },
132
+ },
133
+ organization: {
134
+ manager: { project: ["update"] },
135
+ },
136
+ };
137
+ const acr2 = (0, access_utils_1.createAccessRoles)(hasAccessStatements, hasAccessRoles);
138
+ const service = new access_service_1.AccessService({ access: repo }, acr2);
139
+ it("admin override grants access", async () => {
140
+ const result = await service.hasAccess({ id: "any", role: "admin" }, "organization", "whatever", { project: ["delete"] });
141
+ expect(result.isOk()).toBe(true);
142
+ if (result.isOk())
143
+ expect(result.value).toBe(true);
144
+ });
145
+ it("user level access only for self and allowed action", async () => {
146
+ const allowSelf = await service.hasAccess({ id: "user2", role: "member" }, "user", "user2", {
147
+ project: ["create"],
148
+ });
149
+ expect(allowSelf.isOk()).toBe(true);
150
+ if (allowSelf.isOk())
151
+ expect(allowSelf.value).toBe(true);
152
+ const denyOther = await service.hasAccess({ id: "user2", role: "member" }, "user", "other", {
153
+ project: ["create"],
154
+ });
155
+ expect(denyOther.isOk()).toBe(true);
156
+ if (denyOther.isOk())
157
+ expect(denyOther.value).toBe(false);
158
+ });
159
+ it("organization membership grants access based on repo role", async () => {
160
+ await client.execute({
161
+ sql: "INSERT INTO members (id, organization_id, user_id, role) VALUES (?, ?, ?, ?)",
162
+ args: ["m2", "org2", "user2", "manager"],
163
+ });
164
+ const result = await service.hasAccess({ id: "user2", role: "member" }, "organization", "org2", { project: ["update"] });
165
+ expect(result.isOk()).toBe(true);
166
+ if (result.isOk())
167
+ expect(result.value).toBe(true);
168
+ });
169
+ it("team membership grants access based on repo role", async () => {
170
+ await client.execute({
171
+ sql: "INSERT INTO teammembers (id, team_id, user_id, role) VALUES (?, ?, ?, ?)",
172
+ args: ["tm2", "team2", "user2", "manager"],
173
+ });
174
+ const result = await service.hasAccess({ id: "user2", role: "member" }, "team", "team2", {
175
+ project: ["share"],
176
+ });
177
+ expect(result.isOk()).toBe(true);
178
+ if (result.isOk())
179
+ expect(result.value).toBe(true);
180
+ });
181
+ });
182
+ });
@@ -0,0 +1,17 @@
1
+ import { type AccessControl, type Role, type Statements, type Subset } from "better-auth/plugins/access";
2
+ export type AccessControlRoles<T extends Statements> = {
3
+ ac: AccessControl<T>;
4
+ user: Record<string, Role<Subset<keyof T, T>>>;
5
+ team: Record<string, Role<Subset<keyof T, T>>>;
6
+ organization: Record<string, Role<Subset<keyof T, T>>>;
7
+ };
8
+ export type RoleDefinition<T extends Statements> = {
9
+ [K in keyof T]?: T[K] extends readonly (infer A)[] ? readonly A[] : never;
10
+ };
11
+ export type RoleDefinitions<T extends Statements> = {
12
+ user: Record<string, RoleDefinition<T>>;
13
+ team: Record<string, RoleDefinition<T>>;
14
+ organization: Record<string, RoleDefinition<T>>;
15
+ };
16
+ export declare function createAccessRoles<T extends Statements>(statements: T, roleDefinitions: RoleDefinitions<T>): AccessControlRoles<T>;
17
+ //# sourceMappingURL=access.utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"access.utils.d.ts","sourceRoot":"","sources":["../../../../src/modules/access/access.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,aAAa,EAElB,KAAK,IAAI,EACT,KAAK,UAAU,EACf,KAAK,MAAM,EACZ,MAAM,4BAA4B,CAAC;AAEpC,MAAM,MAAM,kBAAkB,CAAC,CAAC,SAAS,UAAU,IAAI;IACrD,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;CACxD,CAAC;AAIF,MAAM,MAAM,cAAc,CAAC,CAAC,SAAS,UAAU,IAAI;KAChD,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,SAAS,CAAC,EAAE,GAAG,KAAK;CAC1E,CAAC;AAEF,MAAM,MAAM,eAAe,CAAC,CAAC,SAAS,UAAU,IAAI;IAClD,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;IACxC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;IACxC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;CACjD,CAAC;AAEF,wBAAgB,iBAAiB,CAAC,CAAC,SAAS,UAAU,EACpD,UAAU,EAAE,CAAC,EACb,eAAe,EAAE,eAAe,CAAC,CAAC,CAAC,GAClC,kBAAkB,CAAC,CAAC,CAAC,CAevB"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createAccessRoles = createAccessRoles;
4
+ const access_1 = require("better-auth/plugins/access");
5
+ function createAccessRoles(statements, roleDefinitions) {
6
+ const ac = (0, access_1.createAccessControl)(statements);
7
+ const user = {};
8
+ const team = {};
9
+ const organization = {};
10
+ for (const [roleName, roleStatements] of Object.entries(roleDefinitions.user)) {
11
+ user[roleName] = ac.newRole(roleStatements);
12
+ }
13
+ for (const [roleName, roleStatements] of Object.entries(roleDefinitions.team)) {
14
+ team[roleName] = ac.newRole(roleStatements);
15
+ }
16
+ for (const [roleName, roleStatements] of Object.entries(roleDefinitions.organization)) {
17
+ organization[roleName] = ac.newRole(roleStatements);
18
+ }
19
+ return { ac, user, team, organization };
20
+ }