@m5kdev/backend 0.8.6 → 0.8.8

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 (383) hide show
  1. package/dist/_virtual/_rolldown/runtime.cjs +33 -0
  2. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/api/index.d.cts +1 -0
  3. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/adapter/factory.d.cts +1 -0
  4. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/adapter/get-field-attributes.d.cts +1 -0
  5. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/adapter/get-id-field.d.cts +1 -0
  6. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/adapter/index.d.cts +1 -0
  7. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/adapter/types.d.cts +1 -0
  8. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/get-tables.d.cts +1 -0
  9. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/index.d.cts +1 -0
  10. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/schema/account.d.cts +1 -0
  11. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/schema/rate-limit.d.cts +1 -0
  12. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/schema/session.d.cts +1 -0
  13. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/schema/shared.d.cts +1 -0
  14. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/schema/user.d.cts +1 -0
  15. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/db/schema/verification.d.cts +1 -0
  16. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/index.d.cts +1 -0
  17. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/social-providers/index.d.cts +1 -0
  18. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/types/context.d.cts +1 -0
  19. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/types/helper.d.cts +7 -0
  20. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/types/init-options.d.cts +1 -0
  21. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/types/plugin-client.d.cts +1 -0
  22. package/dist/node_modules/.pnpm/@better-auth_core@1.4.18_@better-auth_utils@0.3.0_@better-fetch_fetch@1.1.21_better-cal_347838d331444e5371f256b914727290/node_modules/@better-auth/core/dist/types/plugin.d.cts +1 -0
  23. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter-base.d.cts +1 -0
  24. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter.d.cts +1 -0
  25. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect.d.cts +1 -0
  26. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-adapter.d.cts +1 -0
  27. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-dialect.d.cts +1 -0
  28. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-introspector.d.cts +1 -0
  29. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-adapter.d.cts +1 -0
  30. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-dialect.d.cts +1 -0
  31. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-introspector.d.cts +1 -0
  32. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-adapter.d.cts +1 -0
  33. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-dialect.d.cts +1 -0
  34. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-introspector.d.cts +1 -0
  35. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-adapter.d.cts +1 -0
  36. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-dialect.d.cts +1 -0
  37. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-introspector.d.cts +1 -0
  38. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/expression/expression-builder.d.cts +1 -0
  39. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/index.d.cts +1 -0
  40. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/kysely.d.cts +38 -0
  41. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/file-migration-provider.d.cts +1 -0
  42. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/migrator.d.cts +1 -0
  43. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/binary-operation-parser.d.cts +1 -0
  44. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/delete-from-parser.d.cts +1 -0
  45. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/expression-parser.d.cts +1 -0
  46. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/group-by-parser.d.cts +1 -0
  47. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/insert-values-parser.d.cts +1 -0
  48. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/join-parser.d.cts +1 -0
  49. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/merge-into-parser.d.cts +1 -0
  50. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/reference-parser.d.cts +1 -0
  51. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/returning-parser.d.cts +1 -0
  52. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-from-parser.d.cts +1 -0
  53. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-parser.d.cts +1 -0
  54. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/set-operation-parser.d.cts +1 -0
  55. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/tuple-parser.d.cts +1 -0
  56. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/unary-operation-parser.d.cts +1 -0
  57. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-parser.d.cts +1 -0
  58. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-set-parser.d.cts +1 -0
  59. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/value-parser.d.cts +1 -0
  60. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/with-parser.d.cts +1 -0
  61. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/case-builder.d.cts +1 -0
  62. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/delete-query-builder.d.cts +1 -0
  63. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/having-interface.d.cts +1 -0
  64. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/insert-query-builder.d.cts +1 -0
  65. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/join-builder.d.cts +1 -0
  66. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/merge-query-builder.d.cts +1 -0
  67. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/on-conflict-builder.d.cts +1 -0
  68. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/output-interface.d.cts +1 -0
  69. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/returning-interface.d.cts +1 -0
  70. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/select-query-builder.d.cts +1 -0
  71. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/update-query-builder.d.cts +1 -0
  72. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/where-interface.d.cts +1 -0
  73. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-creator.d.cts +1 -0
  74. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/default-query-executor.d.cts +1 -0
  75. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/noop-query-executor.d.cts +1 -0
  76. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-base.d.cts +1 -0
  77. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-provider.d.cts +1 -0
  78. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor.d.cts +1 -0
  79. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/raw-builder.d.cts +1 -0
  80. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/sql.d.cts +1 -0
  81. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-add-foreign-key-constraint-builder.d.cts +1 -0
  82. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-add-index-builder.d.cts +1 -0
  83. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-builder.d.cts +1 -0
  84. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-drop-constraint-builder.d.cts +1 -0
  85. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-executor.d.cts +1 -0
  86. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-index-builder.d.cts +1 -0
  87. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-schema-builder.d.cts +1 -0
  88. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-table-builder.d.cts +1 -0
  89. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-type-builder.d.cts +1 -0
  90. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-view-builder.d.cts +1 -0
  91. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-index-builder.d.cts +1 -0
  92. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-schema-builder.d.cts +1 -0
  93. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-table-builder.d.cts +1 -0
  94. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-type-builder.d.cts +1 -0
  95. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-view-builder.d.cts +1 -0
  96. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/refresh-materialized-view-builder.d.cts +1 -0
  97. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/schema.d.cts +1 -0
  98. package/dist/src/lib/posthog.cjs +8 -0
  99. package/dist/src/lib/posthog.cjs.map +1 -0
  100. package/dist/src/lib/posthog.d.cts +7 -0
  101. package/dist/src/lib/sentry.cjs +11 -0
  102. package/dist/src/lib/sentry.cjs.map +1 -0
  103. package/dist/src/lib/sentry.d.cts +1 -0
  104. package/dist/src/modules/access/access.repository.cjs +26 -0
  105. package/dist/src/modules/access/access.repository.cjs.map +1 -0
  106. package/dist/src/modules/access/access.repository.d.cts +2352 -0
  107. package/dist/src/modules/access/access.service.cjs +42 -0
  108. package/dist/src/modules/access/access.service.cjs.map +1 -0
  109. package/dist/src/modules/access/access.service.d.cts +25 -0
  110. package/dist/src/modules/access/access.utils.cjs +23 -0
  111. package/dist/src/modules/access/access.utils.cjs.map +1 -0
  112. package/dist/src/modules/access/access.utils.d.cts +19 -0
  113. package/dist/src/modules/ai/ai.db.cjs +46 -0
  114. package/dist/src/modules/ai/ai.db.cjs.map +1 -0
  115. package/dist/src/modules/ai/ai.db.d.cts +401 -0
  116. package/dist/src/modules/ai/ai.prompt.cjs +33 -0
  117. package/dist/src/modules/ai/ai.prompt.cjs.map +1 -0
  118. package/dist/src/modules/ai/ai.prompt.d.cts +30 -0
  119. package/dist/src/modules/ai/ai.prompts.cjs +18 -0
  120. package/dist/src/modules/ai/ai.prompts.cjs.map +1 -0
  121. package/dist/src/modules/ai/ai.prompts.d.cts +10 -0
  122. package/dist/src/modules/ai/ai.repository.cjs +25 -0
  123. package/dist/src/modules/ai/ai.repository.cjs.map +1 -0
  124. package/dist/src/modules/ai/ai.repository.d.cts +428 -0
  125. package/dist/src/modules/ai/ai.router.cjs +0 -0
  126. package/dist/src/modules/ai/ai.router.d.cts +1 -0
  127. package/dist/src/modules/ai/ai.service.cjs +312 -0
  128. package/dist/src/modules/ai/ai.service.cjs.map +1 -0
  129. package/dist/src/modules/ai/ai.service.d.cts +141 -0
  130. package/dist/src/modules/ai/ai.trpc.cjs +19 -0
  131. package/dist/src/modules/ai/ai.trpc.cjs.map +1 -0
  132. package/dist/src/modules/ai/ai.trpc.d.cts +31 -0
  133. package/dist/src/modules/ai/ideogram/ideogram.constants.cjs +191 -0
  134. package/dist/src/modules/ai/ideogram/ideogram.constants.cjs.map +1 -0
  135. package/dist/src/modules/ai/ideogram/ideogram.constants.d.cts +11 -0
  136. package/dist/src/modules/ai/ideogram/ideogram.dto.cjs +49 -0
  137. package/dist/src/modules/ai/ideogram/ideogram.dto.cjs.map +1 -0
  138. package/dist/src/modules/ai/ideogram/ideogram.dto.d.cts +234 -0
  139. package/dist/src/modules/ai/ideogram/ideogram.prompt.cjs +862 -0
  140. package/dist/src/modules/ai/ideogram/ideogram.prompt.cjs.map +1 -0
  141. package/dist/src/modules/ai/ideogram/ideogram.prompt.d.cts +7 -0
  142. package/dist/src/modules/ai/ideogram/ideogram.repository.cjs +34 -0
  143. package/dist/src/modules/ai/ideogram/ideogram.repository.cjs.map +1 -0
  144. package/dist/src/modules/ai/ideogram/ideogram.repository.d.cts +11 -0
  145. package/dist/src/modules/ai/ideogram/ideogram.service.cjs +12 -0
  146. package/dist/src/modules/ai/ideogram/ideogram.service.cjs.map +1 -0
  147. package/dist/src/modules/ai/ideogram/ideogram.service.d.cts +14 -0
  148. package/dist/src/modules/auth/auth.db.cjs +187 -0
  149. package/dist/src/modules/auth/auth.db.cjs.map +1 -0
  150. package/dist/src/modules/auth/auth.db.d.cts +2341 -0
  151. package/dist/src/modules/auth/auth.dto.cjs +50 -0
  152. package/dist/src/modules/auth/auth.dto.cjs.map +1 -0
  153. package/dist/src/modules/auth/auth.dto.d.cts +70 -0
  154. package/dist/src/modules/auth/auth.lib.cjs +234 -0
  155. package/dist/src/modules/auth/auth.lib.cjs.map +1 -0
  156. package/dist/src/modules/auth/auth.lib.d.cts +4894 -0
  157. package/dist/src/modules/auth/auth.middleware.cjs +41 -0
  158. package/dist/src/modules/auth/auth.middleware.cjs.map +1 -0
  159. package/dist/src/modules/auth/auth.middleware.d.cts +619 -0
  160. package/dist/src/modules/auth/auth.repository.cjs +403 -0
  161. package/dist/src/modules/auth/auth.repository.cjs.map +1 -0
  162. package/dist/src/modules/auth/auth.repository.d.cts +2453 -0
  163. package/dist/src/modules/auth/auth.service.cjs +229 -0
  164. package/dist/src/modules/auth/auth.service.cjs.map +1 -0
  165. package/dist/src/modules/auth/auth.service.d.cts +105 -0
  166. package/dist/src/modules/auth/auth.trpc.cjs +110 -0
  167. package/dist/src/modules/auth/auth.trpc.cjs.map +1 -0
  168. package/dist/src/modules/auth/auth.trpc.d.cts +303 -0
  169. package/dist/src/modules/auth/auth.utils.cjs +80 -0
  170. package/dist/src/modules/auth/auth.utils.cjs.map +1 -0
  171. package/dist/src/modules/auth/auth.utils.d.cts +2356 -0
  172. package/dist/src/modules/base/base.abstract.cjs +62 -0
  173. package/dist/src/modules/base/base.abstract.cjs.map +1 -0
  174. package/dist/src/modules/base/base.abstract.d.cts +29 -0
  175. package/dist/src/modules/base/base.actor.cjs +83 -0
  176. package/dist/src/modules/base/base.actor.cjs.map +1 -0
  177. package/dist/src/modules/base/base.actor.d.cts +73 -0
  178. package/dist/src/modules/base/base.dto.cjs +98 -0
  179. package/dist/src/modules/base/base.dto.cjs.map +1 -0
  180. package/dist/src/modules/base/base.dto.d.cts +67 -0
  181. package/dist/src/modules/base/base.grants.cjs +107 -0
  182. package/dist/src/modules/base/base.grants.cjs.map +1 -0
  183. package/dist/src/modules/base/base.grants.d.cts +28 -0
  184. package/dist/src/modules/base/base.procedure.cjs +255 -0
  185. package/dist/src/modules/base/base.procedure.cjs.map +1 -0
  186. package/dist/src/modules/base/base.procedure.d.cts +111 -0
  187. package/dist/src/modules/base/base.repository.cjs +269 -0
  188. package/dist/src/modules/base/base.repository.cjs.map +1 -0
  189. package/dist/src/modules/base/base.repository.d.cts +125 -0
  190. package/dist/src/modules/base/base.repository.d.mts +2 -0
  191. package/dist/src/modules/base/base.repository.mjs +12 -0
  192. package/dist/src/modules/base/base.repository.mjs.map +1 -1
  193. package/dist/src/modules/base/base.service.cjs +119 -0
  194. package/dist/src/modules/base/base.service.cjs.map +1 -0
  195. package/dist/src/modules/base/base.service.d.cts +44 -0
  196. package/dist/src/modules/base/base.types.cjs +0 -0
  197. package/dist/src/modules/base/base.types.d.cts +5 -0
  198. package/dist/src/modules/billing/billing.db.cjs +38 -0
  199. package/dist/src/modules/billing/billing.db.cjs.map +1 -0
  200. package/dist/src/modules/billing/billing.db.d.cts +371 -0
  201. package/dist/src/modules/billing/billing.repository.cjs +190 -0
  202. package/dist/src/modules/billing/billing.repository.cjs.map +1 -0
  203. package/dist/src/modules/billing/billing.repository.d.cts +2787 -0
  204. package/dist/src/modules/billing/billing.repository.d.mts +11 -11
  205. package/dist/src/modules/billing/billing.router.cjs +43 -0
  206. package/dist/src/modules/billing/billing.router.cjs.map +1 -0
  207. package/dist/src/modules/billing/billing.router.d.cts +9 -0
  208. package/dist/src/modules/billing/billing.service.cjs +127 -0
  209. package/dist/src/modules/billing/billing.service.cjs.map +1 -0
  210. package/dist/src/modules/billing/billing.service.d.cts +53 -0
  211. package/dist/src/modules/billing/billing.service.d.mts +7 -7
  212. package/dist/src/modules/billing/billing.trpc.cjs +19 -0
  213. package/dist/src/modules/billing/billing.trpc.cjs.map +1 -0
  214. package/dist/src/modules/billing/billing.trpc.d.cts +48 -0
  215. package/dist/src/modules/clay/clay.repository.cjs +29 -0
  216. package/dist/src/modules/clay/clay.repository.cjs.map +1 -0
  217. package/dist/src/modules/clay/clay.repository.d.cts +10 -0
  218. package/dist/src/modules/clay/clay.service.cjs +24 -0
  219. package/dist/src/modules/clay/clay.service.cjs.map +1 -0
  220. package/dist/src/modules/clay/clay.service.d.cts +32 -0
  221. package/dist/src/modules/connect/connect.db.cjs +37 -0
  222. package/dist/src/modules/connect/connect.db.cjs.map +1 -0
  223. package/dist/src/modules/connect/connect.db.d.cts +362 -0
  224. package/dist/src/modules/connect/connect.dto.cjs +45 -0
  225. package/dist/src/modules/connect/connect.dto.cjs.map +1 -0
  226. package/dist/src/modules/connect/connect.dto.d.cts +79 -0
  227. package/dist/src/modules/connect/connect.linkedin.cjs +48 -0
  228. package/dist/src/modules/connect/connect.linkedin.cjs.map +1 -0
  229. package/dist/src/modules/connect/connect.linkedin.d.cts +7 -0
  230. package/dist/src/modules/connect/connect.oauth.cjs +153 -0
  231. package/dist/src/modules/connect/connect.oauth.cjs.map +1 -0
  232. package/dist/src/modules/connect/connect.oauth.d.cts +32 -0
  233. package/dist/src/modules/connect/connect.repository.cjs +42 -0
  234. package/dist/src/modules/connect/connect.repository.cjs.map +1 -0
  235. package/dist/src/modules/connect/connect.repository.d.cts +419 -0
  236. package/dist/src/modules/connect/connect.router.cjs +48 -0
  237. package/dist/src/modules/connect/connect.router.cjs.map +1 -0
  238. package/dist/src/modules/connect/connect.router.d.cts +9 -0
  239. package/dist/src/modules/connect/connect.service.cjs +90 -0
  240. package/dist/src/modules/connect/connect.service.cjs.map +1 -0
  241. package/dist/src/modules/connect/connect.service.d.cts +103 -0
  242. package/dist/src/modules/connect/connect.trpc.cjs +18 -0
  243. package/dist/src/modules/connect/connect.trpc.cjs.map +1 -0
  244. package/dist/src/modules/connect/connect.trpc.d.cts +53 -0
  245. package/dist/src/modules/connect/connect.types.cjs +0 -0
  246. package/dist/src/modules/connect/connect.types.d.cts +29 -0
  247. package/dist/src/modules/crypto/crypto.db.cjs +26 -0
  248. package/dist/src/modules/crypto/crypto.db.cjs.map +1 -0
  249. package/dist/src/modules/crypto/crypto.db.d.cts +157 -0
  250. package/dist/src/modules/crypto/crypto.repository.cjs +9 -0
  251. package/dist/src/modules/crypto/crypto.repository.cjs.map +1 -0
  252. package/dist/src/modules/crypto/crypto.repository.d.cts +163 -0
  253. package/dist/src/modules/crypto/crypto.service.cjs +46 -0
  254. package/dist/src/modules/crypto/crypto.service.cjs.map +1 -0
  255. package/dist/src/modules/crypto/crypto.service.d.cts +15 -0
  256. package/dist/src/modules/email/email.service.cjs +107 -0
  257. package/dist/src/modules/email/email.service.cjs.map +1 -0
  258. package/dist/src/modules/email/email.service.d.cts +62 -0
  259. package/dist/src/modules/file/file.repository.cjs +74 -0
  260. package/dist/src/modules/file/file.repository.cjs.map +1 -0
  261. package/dist/src/modules/file/file.repository.d.cts +17 -0
  262. package/dist/src/modules/file/file.router.cjs +94 -0
  263. package/dist/src/modules/file/file.router.cjs.map +1 -0
  264. package/dist/src/modules/file/file.router.d.cts +7 -0
  265. package/dist/src/modules/file/file.service.cjs +120 -0
  266. package/dist/src/modules/file/file.service.cjs.map +1 -0
  267. package/dist/src/modules/file/file.service.d.cts +30 -0
  268. package/dist/src/modules/recurrence/recurrence.db.cjs +55 -0
  269. package/dist/src/modules/recurrence/recurrence.db.cjs.map +1 -0
  270. package/dist/src/modules/recurrence/recurrence.db.d.cts +568 -0
  271. package/dist/src/modules/recurrence/recurrence.repository.cjs +31 -0
  272. package/dist/src/modules/recurrence/recurrence.repository.cjs.map +1 -0
  273. package/dist/src/modules/recurrence/recurrence.repository.d.cts +588 -0
  274. package/dist/src/modules/recurrence/recurrence.service.cjs +66 -0
  275. package/dist/src/modules/recurrence/recurrence.service.cjs.map +1 -0
  276. package/dist/src/modules/recurrence/recurrence.service.d.cts +88 -0
  277. package/dist/src/modules/recurrence/recurrence.service.d.mts +2 -1
  278. package/dist/src/modules/recurrence/recurrence.service.mjs +1 -1
  279. package/dist/src/modules/recurrence/recurrence.service.mjs.map +1 -1
  280. package/dist/src/modules/recurrence/recurrence.trpc.cjs +46 -0
  281. package/dist/src/modules/recurrence/recurrence.trpc.cjs.map +1 -0
  282. package/dist/src/modules/recurrence/recurrence.trpc.d.cts +216 -0
  283. package/dist/src/modules/recurrence/recurrence.trpc.d.mts +2 -1
  284. package/dist/src/modules/social/social.dto.cjs +26 -0
  285. package/dist/src/modules/social/social.dto.cjs.map +1 -0
  286. package/dist/src/modules/social/social.dto.d.cts +39 -0
  287. package/dist/src/modules/social/social.linkedin.cjs +349 -0
  288. package/dist/src/modules/social/social.linkedin.cjs.map +1 -0
  289. package/dist/src/modules/social/social.linkedin.d.cts +15 -0
  290. package/dist/src/modules/social/social.service.cjs +57 -0
  291. package/dist/src/modules/social/social.service.cjs.map +1 -0
  292. package/dist/src/modules/social/social.service.d.cts +34 -0
  293. package/dist/src/modules/social/social.types.cjs +0 -0
  294. package/dist/src/modules/social/social.types.d.cts +40 -0
  295. package/dist/src/modules/tag/tag.db.cjs +43 -0
  296. package/dist/src/modules/tag/tag.db.cjs.map +1 -0
  297. package/dist/src/modules/tag/tag.db.d.cts +352 -0
  298. package/dist/src/modules/tag/tag.dto.cjs +15 -0
  299. package/dist/src/modules/tag/tag.dto.cjs.map +1 -0
  300. package/dist/src/modules/tag/tag.dto.d.cts +1025 -0
  301. package/dist/src/modules/tag/tag.repository.cjs +116 -0
  302. package/dist/src/modules/tag/tag.repository.cjs.map +1 -0
  303. package/dist/src/modules/tag/tag.repository.d.cts +394 -0
  304. package/dist/src/modules/tag/tag.service.cjs +48 -0
  305. package/dist/src/modules/tag/tag.service.cjs.map +1 -0
  306. package/dist/src/modules/tag/tag.service.d.cts +120 -0
  307. package/dist/src/modules/tag/tag.trpc.cjs +32 -0
  308. package/dist/src/modules/tag/tag.trpc.cjs.map +1 -0
  309. package/dist/src/modules/tag/tag.trpc.d.cts +174 -0
  310. package/dist/src/modules/tag/tag.trpc.d.mts +3 -2
  311. package/dist/src/modules/utils/applyPagination.cjs +16 -0
  312. package/dist/src/modules/utils/applyPagination.cjs.map +1 -0
  313. package/dist/src/modules/utils/applyPagination.d.cts +10 -0
  314. package/dist/src/modules/utils/applySorting.cjs +20 -0
  315. package/dist/src/modules/utils/applySorting.cjs.map +1 -0
  316. package/dist/src/modules/utils/applySorting.d.cts +13 -0
  317. package/dist/src/modules/utils/getConditionsFromFilters.cjs +152 -0
  318. package/dist/src/modules/utils/getConditionsFromFilters.cjs.map +1 -0
  319. package/dist/src/modules/utils/getConditionsFromFilters.d.cts +9 -0
  320. package/dist/src/modules/utils/getGlobalSearchCondition.cjs +30 -0
  321. package/dist/src/modules/utils/getGlobalSearchCondition.cjs.map +1 -0
  322. package/dist/src/modules/utils/getGlobalSearchCondition.d.cts +18 -0
  323. package/dist/src/modules/utils/getGlobalSearchCondition.d.mts +18 -0
  324. package/dist/src/modules/utils/getGlobalSearchCondition.mjs +26 -0
  325. package/dist/src/modules/utils/getGlobalSearchCondition.mjs.map +1 -0
  326. package/dist/src/modules/video/video.service.cjs +114 -0
  327. package/dist/src/modules/video/video.service.cjs.map +1 -0
  328. package/dist/src/modules/video/video.service.d.cts +12 -0
  329. package/dist/src/modules/video/video.service.mjs +73 -13
  330. package/dist/src/modules/video/video.service.mjs.map +1 -1
  331. package/dist/src/modules/webhook/webhook.constants.cjs +13 -0
  332. package/dist/src/modules/webhook/webhook.constants.cjs.map +1 -0
  333. package/dist/src/modules/webhook/webhook.constants.d.cts +12 -0
  334. package/dist/src/modules/webhook/webhook.db.cjs +19 -0
  335. package/dist/src/modules/webhook/webhook.db.cjs.map +1 -0
  336. package/dist/src/modules/webhook/webhook.db.d.cts +142 -0
  337. package/dist/src/modules/webhook/webhook.dto.cjs +11 -0
  338. package/dist/src/modules/webhook/webhook.dto.cjs.map +1 -0
  339. package/dist/src/modules/webhook/webhook.dto.d.cts +402 -0
  340. package/dist/src/modules/webhook/webhook.repository.cjs +52 -0
  341. package/dist/src/modules/webhook/webhook.repository.cjs.map +1 -0
  342. package/dist/src/modules/webhook/webhook.repository.d.cts +154 -0
  343. package/dist/src/modules/webhook/webhook.router.cjs +26 -0
  344. package/dist/src/modules/webhook/webhook.router.cjs.map +1 -0
  345. package/dist/src/modules/webhook/webhook.router.d.cts +8 -0
  346. package/dist/src/modules/webhook/webhook.service.cjs +61 -0
  347. package/dist/src/modules/webhook/webhook.service.cjs.map +1 -0
  348. package/dist/src/modules/webhook/webhook.service.d.cts +14 -0
  349. package/dist/src/modules/workflow/workflow.db.cjs +35 -0
  350. package/dist/src/modules/workflow/workflow.db.cjs.map +1 -0
  351. package/dist/src/modules/workflow/workflow.db.d.cts +302 -0
  352. package/dist/src/modules/workflow/workflow.repository.cjs +95 -0
  353. package/dist/src/modules/workflow/workflow.repository.cjs.map +1 -0
  354. package/dist/src/modules/workflow/workflow.repository.d.cts +371 -0
  355. package/dist/src/modules/workflow/workflow.service.cjs +41 -0
  356. package/dist/src/modules/workflow/workflow.service.cjs.map +1 -0
  357. package/dist/src/modules/workflow/workflow.service.d.cts +68 -0
  358. package/dist/src/modules/workflow/workflow.trpc.cjs +19 -0
  359. package/dist/src/modules/workflow/workflow.trpc.cjs.map +1 -0
  360. package/dist/src/modules/workflow/workflow.trpc.d.cts +65 -0
  361. package/dist/src/modules/workflow/workflow.types.cjs +0 -0
  362. package/dist/src/modules/workflow/workflow.types.d.cts +25 -0
  363. package/dist/src/modules/workflow/workflow.utils.cjs +185 -0
  364. package/dist/src/modules/workflow/workflow.utils.cjs.map +1 -0
  365. package/dist/src/modules/workflow/workflow.utils.d.cts +36 -0
  366. package/dist/src/types.cjs +12 -0
  367. package/dist/src/types.cjs.map +1 -0
  368. package/dist/src/types.d.cts +344 -0
  369. package/dist/src/utils/errors.cjs +101 -0
  370. package/dist/src/utils/errors.cjs.map +1 -0
  371. package/dist/src/utils/errors.d.cts +62 -0
  372. package/dist/src/utils/logger.cjs +13 -0
  373. package/dist/src/utils/logger.cjs.map +1 -0
  374. package/dist/src/utils/logger.d.cts +7 -0
  375. package/dist/src/utils/posthog.cjs +31 -0
  376. package/dist/src/utils/posthog.cjs.map +1 -0
  377. package/dist/src/utils/posthog.d.cts +17 -0
  378. package/dist/src/utils/trpc.cjs +156 -0
  379. package/dist/src/utils/trpc.cjs.map +1 -0
  380. package/dist/src/utils/trpc.d.cts +54 -0
  381. package/dist/src/utils/types.cjs +0 -0
  382. package/dist/src/utils/types.d.cts +9 -0
  383. package/package.json +171 -47
@@ -0,0 +1,403 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ require("../../../_virtual/_rolldown/runtime.cjs");
3
+ const require_src_modules_auth_auth_db = require("./auth.db.cjs");
4
+ const require_src_modules_base_base_repository = require("../base/base.repository.cjs");
5
+ let drizzle_orm = require("drizzle-orm");
6
+ let neverthrow = require("neverthrow");
7
+ let uuid = require("uuid");
8
+ //#region src/modules/auth/auth.repository.ts
9
+ ({ ...require_src_modules_auth_auth_db.auth_db_exports });
10
+ function parseOrganizationMetadata(metadata) {
11
+ if (!metadata) return {};
12
+ if (typeof metadata === "string") try {
13
+ const parsed = JSON.parse(metadata);
14
+ if (parsed && typeof parsed === "object" && !Array.isArray(parsed)) return parsed;
15
+ return {};
16
+ } catch {
17
+ return {};
18
+ }
19
+ if (typeof metadata === "object" && !Array.isArray(metadata)) return metadata;
20
+ return {};
21
+ }
22
+ function normalizeOrganizationPreferences(value) {
23
+ if (value && typeof value === "object" && !Array.isArray(value)) return value;
24
+ return {};
25
+ }
26
+ function normalizeOrganizationFlags(value) {
27
+ if (!Array.isArray(value)) return [];
28
+ return value.filter((item) => typeof item === "string");
29
+ }
30
+ var AuthRepository = class extends require_src_modules_base_base_repository.BaseRepository {
31
+ async getOrganizationMetadataForMember(userId, organizationId, tx) {
32
+ const [organization] = await (tx ?? this.orm).select({ metadata: this.schema.organizations.metadata }).from(this.schema.organizations).innerJoin(this.schema.members, (0, drizzle_orm.eq)(this.schema.members.organizationId, this.schema.organizations.id)).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.organizations.id, organizationId), (0, drizzle_orm.eq)(this.schema.members.userId, userId))).limit(1);
33
+ if (!organization) return null;
34
+ return parseOrganizationMetadata(organization.metadata);
35
+ }
36
+ async getUserWaitlistCount(userId, tx) {
37
+ return this.throwableAsync(async () => {
38
+ const [waitlist] = await (tx ?? this.orm).select({ count: (0, drizzle_orm.count)() }).from(this.schema.waitlist).where((0, drizzle_orm.eq)(this.schema.waitlist.userId, userId));
39
+ return (0, neverthrow.ok)(waitlist.count ?? 0);
40
+ });
41
+ }
42
+ async getOnboarding(userId, tx) {
43
+ return this.throwableAsync(async () => {
44
+ const [user] = await (tx ?? this.orm).select({ onboarding: this.schema.users.onboarding }).from(this.schema.users).where((0, drizzle_orm.eq)(this.schema.users.id, userId)).limit(1);
45
+ if (!user) return this.error("FORBIDDEN");
46
+ return (0, neverthrow.ok)(user.onboarding ?? 0);
47
+ });
48
+ }
49
+ async setOnboarding(userId, onboarding, tx) {
50
+ return this.throwableAsync(async () => {
51
+ await (tx ?? this.orm).update(this.schema.users).set({ onboarding }).where((0, drizzle_orm.eq)(this.schema.users.id, userId));
52
+ return (0, neverthrow.ok)(onboarding);
53
+ });
54
+ }
55
+ async getPreferences(userId, tx) {
56
+ return this.throwableAsync(async () => {
57
+ const [user] = await (tx ?? this.orm).select({ preferences: this.schema.users.preferences }).from(this.schema.users).where((0, drizzle_orm.eq)(this.schema.users.id, userId)).limit(1);
58
+ if (!user) return this.error("FORBIDDEN");
59
+ return (0, neverthrow.ok)(user.preferences ? JSON.parse(user.preferences) : {});
60
+ });
61
+ }
62
+ async setPreferences(userId, preferences, tx) {
63
+ return this.throwableAsync(async () => {
64
+ await (tx ?? this.orm).update(this.schema.users).set({ preferences: JSON.stringify(preferences) }).where((0, drizzle_orm.eq)(this.schema.users.id, userId));
65
+ return (0, neverthrow.ok)(preferences);
66
+ });
67
+ }
68
+ async getOrganizationPreferences(userId, organizationId, tx) {
69
+ return this.throwableAsync(async () => {
70
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
71
+ if (!metadata) return this.error("FORBIDDEN");
72
+ return (0, neverthrow.ok)(normalizeOrganizationPreferences(metadata.preferences));
73
+ });
74
+ }
75
+ async setOrganizationPreferences(userId, organizationId, preferences, tx) {
76
+ return this.throwableAsync(async () => {
77
+ const db = tx ?? this.orm;
78
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
79
+ if (!metadata) return this.error("FORBIDDEN");
80
+ await db.update(this.schema.organizations).set({ metadata: JSON.stringify({
81
+ ...metadata,
82
+ preferences
83
+ }) }).where((0, drizzle_orm.eq)(this.schema.organizations.id, organizationId));
84
+ return (0, neverthrow.ok)(preferences);
85
+ });
86
+ }
87
+ async getMetadata(userId, tx) {
88
+ return this.throwableAsync(async () => {
89
+ const [user] = await (tx ?? this.orm).select({ metadata: this.schema.users.metadata }).from(this.schema.users).where((0, drizzle_orm.eq)(this.schema.users.id, userId)).limit(1);
90
+ if (!user) return this.error("FORBIDDEN");
91
+ return (0, neverthrow.ok)(user.metadata);
92
+ });
93
+ }
94
+ async setMetadata(userId, metadata, tx) {
95
+ return this.throwableAsync(async () => {
96
+ const db = tx ?? this.orm;
97
+ const [user] = await db.select({ metadata: this.schema.users.metadata }).from(this.schema.users).where((0, drizzle_orm.eq)(this.schema.users.id, userId)).limit(1);
98
+ if (!user) return this.error("FORBIDDEN");
99
+ await db.update(this.schema.users).set({ metadata: {
100
+ ...user.metadata,
101
+ ...metadata
102
+ } }).where((0, drizzle_orm.eq)(this.schema.users.id, userId));
103
+ return (0, neverthrow.ok)(metadata);
104
+ });
105
+ }
106
+ async getFlags(userId, tx) {
107
+ return this.throwableAsync(async () => {
108
+ const [user] = await (tx ?? this.orm).select({ flags: this.schema.users.flags }).from(this.schema.users).where((0, drizzle_orm.eq)(this.schema.users.id, userId)).limit(1);
109
+ if (!user) return this.error("FORBIDDEN");
110
+ return (0, neverthrow.ok)(user.flags ? JSON.parse(user.flags) : []);
111
+ });
112
+ }
113
+ async getOrganizationFlags(userId, organizationId, tx) {
114
+ return this.throwableAsync(async () => {
115
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
116
+ if (!metadata) return this.error("FORBIDDEN");
117
+ return (0, neverthrow.ok)(normalizeOrganizationFlags(metadata.flags));
118
+ });
119
+ }
120
+ async setFlags(userId, flags, tx) {
121
+ return this.throwableAsync(async () => {
122
+ await (tx ?? this.orm).update(this.schema.users).set({ flags: JSON.stringify(flags) }).where((0, drizzle_orm.eq)(this.schema.users.id, userId));
123
+ return (0, neverthrow.ok)(flags);
124
+ });
125
+ }
126
+ async setOrganizationFlags(userId, organizationId, flags, tx) {
127
+ return this.throwableAsync(async () => {
128
+ const db = tx ?? this.orm;
129
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
130
+ if (!metadata) return this.error("FORBIDDEN");
131
+ await db.update(this.schema.organizations).set({ metadata: JSON.stringify({
132
+ ...metadata,
133
+ flags
134
+ }) }).where((0, drizzle_orm.eq)(this.schema.organizations.id, organizationId));
135
+ return (0, neverthrow.ok)(flags);
136
+ });
137
+ }
138
+ async listAdminWaitlist(tx) {
139
+ return this.throwableAsync(async () => {
140
+ return (0, neverthrow.ok)(await (tx ?? this.orm).select({
141
+ id: this.schema.waitlist.id,
142
+ name: this.schema.waitlist.name,
143
+ email: this.schema.waitlist.email,
144
+ createdAt: this.schema.waitlist.createdAt,
145
+ updatedAt: this.schema.waitlist.updatedAt,
146
+ status: this.schema.waitlist.status
147
+ }).from(this.schema.waitlist).where((0, drizzle_orm.eq)(this.schema.waitlist.type, "WAITLIST")).orderBy((0, drizzle_orm.desc)(this.schema.waitlist.createdAt)));
148
+ });
149
+ }
150
+ async listWaitlist(userId, tx) {
151
+ return this.throwableAsync(async () => {
152
+ return (0, neverthrow.ok)(await (tx ?? this.orm).select().from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.userId, userId), (0, drizzle_orm.eq)(this.schema.waitlist.type, "WAITLIST"))));
153
+ });
154
+ }
155
+ async addToWaitlist(email, tx) {
156
+ return this.throwableAsync(async () => {
157
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({ email }).returning();
158
+ return (0, neverthrow.ok)(waitlist);
159
+ });
160
+ }
161
+ async inviteFromWaitlist(id, tx) {
162
+ return this.throwableAsync(async () => {
163
+ const [waitlist] = await (tx ?? this.orm).update(this.schema.waitlist).set({
164
+ status: "INVITED",
165
+ code: (0, uuid.v4)(),
166
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * 24 * 14)
167
+ }).where((0, drizzle_orm.eq)(this.schema.waitlist.id, id)).returning();
168
+ return (0, neverthrow.ok)(waitlist);
169
+ });
170
+ }
171
+ async inviteToWaitlist({ email, userId, name }, tx) {
172
+ return this.throwableAsync(async () => {
173
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({
174
+ email,
175
+ name,
176
+ status: "INVITED",
177
+ code: (0, uuid.v4)(),
178
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * 24),
179
+ userId
180
+ }).returning();
181
+ return (0, neverthrow.ok)(waitlist);
182
+ });
183
+ }
184
+ async createInvitationCode({ userId, name }, tx) {
185
+ return this.throwableAsync(async () => {
186
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({
187
+ name,
188
+ status: "INVITED",
189
+ code: (0, uuid.v4)(),
190
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * 24),
191
+ userId
192
+ }).returning();
193
+ return (0, neverthrow.ok)(waitlist);
194
+ });
195
+ }
196
+ async joinWaitlist(email, tx) {
197
+ return this.throwableAsync(async () => {
198
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({ email }).returning();
199
+ return (0, neverthrow.ok)(waitlist);
200
+ });
201
+ }
202
+ async removeFromWaitlist(id, tx) {
203
+ return this.throwableAsync(async () => {
204
+ const [waitlist] = await (tx ?? this.orm).update(this.schema.waitlist).set({ status: "REMOVED" }).where((0, drizzle_orm.eq)(this.schema.waitlist.id, id)).returning();
205
+ return (0, neverthrow.ok)(waitlist);
206
+ });
207
+ }
208
+ async validateWaitlistCode(code, tx) {
209
+ return this.throwableAsync(async () => {
210
+ const [waitlist] = await (tx ?? this.orm).select().from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.code, code), (0, drizzle_orm.eq)(this.schema.waitlist.type, "WAITLIST"))).limit(1);
211
+ if (!waitlist) return (0, neverthrow.ok)({ status: "NOT_FOUND" });
212
+ if (waitlist.expiresAt && waitlist.expiresAt < /* @__PURE__ */ new Date()) return (0, neverthrow.ok)({ status: "EXPIRED" });
213
+ if (waitlist.status !== "INVITED") return (0, neverthrow.ok)({ status: "INVALID" });
214
+ return (0, neverthrow.ok)({ status: "VALID" });
215
+ });
216
+ }
217
+ async createAccountClaimCode({ userId, expiresInHours = 336 }, tx) {
218
+ return this.throwableAsync(async () => {
219
+ const [claim] = await (tx ?? this.orm).insert(this.schema.waitlist).values({
220
+ type: "ACCOUNT_CLAIM",
221
+ claimUserId: userId,
222
+ code: (0, uuid.v4)(),
223
+ status: "INVITED",
224
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * expiresInHours)
225
+ }).returning();
226
+ return (0, neverthrow.ok)(claim);
227
+ });
228
+ }
229
+ async createClaimableProvisionedUser({ name, email, metadata = {}, onboarding = 0, role = "user", expiresInHours = 336 }) {
230
+ return this.throwableAsync(async () => {
231
+ const normalizedEmail = email.toLowerCase();
232
+ const [existingUser] = await this.orm.select({ id: this.schema.users.id }).from(this.schema.users).where((0, drizzle_orm.eq)(this.schema.users.email, normalizedEmail)).limit(1);
233
+ if (existingUser) return this.error("CONFLICT", "Email already in use");
234
+ return (0, neverthrow.ok)(await this.orm.transaction(async (tx) => {
235
+ const [user] = await tx.insert(this.schema.users).values({
236
+ name,
237
+ email: normalizedEmail,
238
+ emailVerified: false,
239
+ role,
240
+ onboarding,
241
+ metadata
242
+ }).returning();
243
+ if (!user) throw new Error("Failed to create user");
244
+ const organizationId = (0, uuid.v4)();
245
+ const [organization] = await tx.insert(this.schema.organizations).values({
246
+ id: organizationId,
247
+ name: organizationId,
248
+ slug: organizationId
249
+ }).returning();
250
+ if (!organization) throw new Error("Failed to create organization");
251
+ const [member] = await tx.insert(this.schema.members).values({
252
+ userId: user.id,
253
+ organizationId: organization.id,
254
+ role: "owner"
255
+ }).returning();
256
+ if (!member) throw new Error("Failed to create organization membership");
257
+ const [team] = await tx.insert(this.schema.teams).values({
258
+ name: organization.id,
259
+ organizationId: organization.id
260
+ }).returning();
261
+ if (!team) throw new Error("Failed to create team");
262
+ const [teamMember] = await tx.insert(this.schema.teamMembers).values({
263
+ userId: user.id,
264
+ teamId: team.id,
265
+ role: "owner"
266
+ }).returning();
267
+ if (!teamMember) throw new Error("Failed to create team membership");
268
+ const [claim] = await tx.insert(this.schema.waitlist).values({
269
+ type: "ACCOUNT_CLAIM",
270
+ claimUserId: user.id,
271
+ code: (0, uuid.v4)(),
272
+ status: "INVITED",
273
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * expiresInHours)
274
+ }).returning();
275
+ if (!claim) throw new Error("Failed to create account claim");
276
+ return {
277
+ user,
278
+ claim
279
+ };
280
+ }));
281
+ });
282
+ }
283
+ async listAccountClaims(tx) {
284
+ return this.throwableAsync(async () => {
285
+ return (0, neverthrow.ok)(await (tx ?? this.orm).select({
286
+ id: this.schema.waitlist.id,
287
+ claimUserId: this.schema.waitlist.claimUserId,
288
+ status: this.schema.waitlist.status,
289
+ expiresAt: this.schema.waitlist.expiresAt,
290
+ claimedAt: this.schema.waitlist.claimedAt,
291
+ claimedEmail: this.schema.waitlist.claimedEmail,
292
+ createdAt: this.schema.waitlist.createdAt,
293
+ updatedAt: this.schema.waitlist.updatedAt
294
+ }).from(this.schema.waitlist).where((0, drizzle_orm.eq)(this.schema.waitlist.type, "ACCOUNT_CLAIM")).orderBy((0, drizzle_orm.desc)(this.schema.waitlist.createdAt)));
295
+ });
296
+ }
297
+ async validateAccountClaimCode(code, tx) {
298
+ return this.throwableAsync(async () => {
299
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.code, code), (0, drizzle_orm.eq)(this.schema.waitlist.type, "ACCOUNT_CLAIM"))).limit(1);
300
+ if (!claim) return (0, neverthrow.ok)({ status: "NOT_FOUND" });
301
+ if (claim.expiresAt && claim.expiresAt < /* @__PURE__ */ new Date()) return (0, neverthrow.ok)({ status: "EXPIRED" });
302
+ if (claim.status !== "INVITED") return (0, neverthrow.ok)({ status: "INVALID" });
303
+ return (0, neverthrow.ok)({ status: "VALID" });
304
+ });
305
+ }
306
+ async findAccountClaimByCode(code, tx) {
307
+ return this.throwableAsync(async () => {
308
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.code, code), (0, drizzle_orm.eq)(this.schema.waitlist.type, "ACCOUNT_CLAIM"), (0, drizzle_orm.eq)(this.schema.waitlist.status, "INVITED"), (0, drizzle_orm.gte)(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).limit(1);
309
+ return (0, neverthrow.ok)(claim ?? null);
310
+ });
311
+ }
312
+ async findAccountClaimById(id, tx) {
313
+ return this.throwableAsync(async () => {
314
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.id, id), (0, drizzle_orm.eq)(this.schema.waitlist.type, "ACCOUNT_CLAIM"))).limit(1);
315
+ return (0, neverthrow.ok)(claim ?? null);
316
+ });
317
+ }
318
+ async findPendingAccountClaimForUser(userId, tx) {
319
+ return this.throwableAsync(async () => {
320
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.type, "ACCOUNT_CLAIM"), (0, drizzle_orm.eq)(this.schema.waitlist.claimUserId, userId), (0, drizzle_orm.eq)(this.schema.waitlist.status, "INVITED"), (0, drizzle_orm.gte)(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).orderBy((0, drizzle_orm.desc)(this.schema.waitlist.createdAt)).limit(1);
321
+ return (0, neverthrow.ok)(claim ?? null);
322
+ });
323
+ }
324
+ async setAccountClaimEmail({ userId, email }, tx) {
325
+ return this.throwableAsync(async () => {
326
+ const db = tx ?? this.orm;
327
+ const normalizedEmail = email.toLowerCase();
328
+ const [existingUser] = await db.select({ id: this.schema.users.id }).from(this.schema.users).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.users.email, normalizedEmail), (0, drizzle_orm.ne)(this.schema.users.id, userId))).limit(1);
329
+ if (existingUser) return this.error("BAD_REQUEST", "Email is already in use");
330
+ const [claim] = await db.select({ id: this.schema.waitlist.id }).from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.type, "ACCOUNT_CLAIM"), (0, drizzle_orm.eq)(this.schema.waitlist.claimUserId, userId), (0, drizzle_orm.eq)(this.schema.waitlist.status, "INVITED"), (0, drizzle_orm.gte)(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).orderBy((0, drizzle_orm.desc)(this.schema.waitlist.createdAt)).limit(1);
331
+ if (!claim) return this.error("BAD_REQUEST", "No pending claim found");
332
+ await db.update(this.schema.users).set({
333
+ email: normalizedEmail,
334
+ emailVerified: false,
335
+ updatedAt: /* @__PURE__ */ new Date()
336
+ }).where((0, drizzle_orm.eq)(this.schema.users.id, userId));
337
+ await db.update(this.schema.waitlist).set({
338
+ claimedEmail: normalizedEmail,
339
+ updatedAt: /* @__PURE__ */ new Date()
340
+ }).where((0, drizzle_orm.eq)(this.schema.waitlist.id, claim.id));
341
+ return (0, neverthrow.ok)({ status: true });
342
+ });
343
+ }
344
+ async acceptAccountClaim(userId, tx) {
345
+ return this.throwableAsync(async () => {
346
+ const db = tx ?? this.orm;
347
+ const [claim] = await db.select({ id: this.schema.waitlist.id }).from(this.schema.waitlist).where((0, drizzle_orm.and)((0, drizzle_orm.eq)(this.schema.waitlist.type, "ACCOUNT_CLAIM"), (0, drizzle_orm.eq)(this.schema.waitlist.claimUserId, userId), (0, drizzle_orm.eq)(this.schema.waitlist.status, "INVITED"), (0, drizzle_orm.gte)(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).orderBy((0, drizzle_orm.desc)(this.schema.waitlist.createdAt)).limit(1);
348
+ if (!claim) return (0, neverthrow.ok)({ status: true });
349
+ const [user] = await db.select({ email: this.schema.users.email }).from(this.schema.users).where((0, drizzle_orm.eq)(this.schema.users.id, userId)).limit(1);
350
+ await db.update(this.schema.waitlist).set({
351
+ status: "ACCEPTED",
352
+ claimedAt: /* @__PURE__ */ new Date(),
353
+ claimedEmail: user?.email ?? null,
354
+ updatedAt: /* @__PURE__ */ new Date()
355
+ }).where((0, drizzle_orm.eq)(this.schema.waitlist.id, claim.id));
356
+ return (0, neverthrow.ok)({ status: true });
357
+ });
358
+ }
359
+ async createAccountClaimMagicLink({ claimId, userId, email, token, url, expiresAt }, tx) {
360
+ return this.throwableAsync(async () => {
361
+ const [link] = await (tx ?? this.orm).insert(this.schema.accountClaimMagicLinks).values({
362
+ claimId,
363
+ userId,
364
+ email,
365
+ token,
366
+ url,
367
+ expiresAt: expiresAt ?? null
368
+ }).returning();
369
+ return (0, neverthrow.ok)(link);
370
+ });
371
+ }
372
+ async listAccountClaimMagicLinks(claimId, tx) {
373
+ return this.throwableAsync(async () => {
374
+ return (0, neverthrow.ok)(await (tx ?? this.orm).select({
375
+ id: this.schema.accountClaimMagicLinks.id,
376
+ claimId: this.schema.accountClaimMagicLinks.claimId,
377
+ userId: this.schema.accountClaimMagicLinks.userId,
378
+ email: this.schema.accountClaimMagicLinks.email,
379
+ url: this.schema.accountClaimMagicLinks.url,
380
+ expiresAt: this.schema.accountClaimMagicLinks.expiresAt,
381
+ createdAt: this.schema.accountClaimMagicLinks.createdAt
382
+ }).from(this.schema.accountClaimMagicLinks).where((0, drizzle_orm.eq)(this.schema.accountClaimMagicLinks.claimId, claimId)).orderBy((0, drizzle_orm.desc)(this.schema.accountClaimMagicLinks.createdAt)));
383
+ });
384
+ }
385
+ async latestAccountClaimMagicLink(claimId, tx) {
386
+ return this.throwableAsync(async () => {
387
+ const [link] = await (tx ?? this.orm).select({
388
+ id: this.schema.accountClaimMagicLinks.id,
389
+ claimId: this.schema.accountClaimMagicLinks.claimId,
390
+ userId: this.schema.accountClaimMagicLinks.userId,
391
+ email: this.schema.accountClaimMagicLinks.email,
392
+ url: this.schema.accountClaimMagicLinks.url,
393
+ expiresAt: this.schema.accountClaimMagicLinks.expiresAt,
394
+ createdAt: this.schema.accountClaimMagicLinks.createdAt
395
+ }).from(this.schema.accountClaimMagicLinks).where((0, drizzle_orm.eq)(this.schema.accountClaimMagicLinks.claimId, claimId)).orderBy((0, drizzle_orm.desc)(this.schema.accountClaimMagicLinks.createdAt)).limit(1);
396
+ return (0, neverthrow.ok)(link ?? null);
397
+ });
398
+ }
399
+ };
400
+ //#endregion
401
+ exports.AuthRepository = AuthRepository;
402
+
403
+ //# sourceMappingURL=auth.repository.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.repository.cjs","names":["auth","BaseRepository"],"sources":["../../../../src/modules/auth/auth.repository.ts"],"sourcesContent":["import { and, count, desc, eq, gte, ne } from \"drizzle-orm\";\r\nimport type { LibSQLDatabase } from \"drizzle-orm/libsql\";\r\nimport { ok } from \"neverthrow\";\r\nimport { v4 as uuidv4 } from \"uuid\";\r\nimport type { ServerResultAsync } from \"../base/base.dto\";\r\nimport { BaseRepository } from \"../base/base.repository\";\r\nimport * as auth from \"./auth.db\";\r\nimport type {\r\n AccountClaim,\r\n AccountClaimMagicLink,\r\n AccountClaimMagicLinkOutput,\r\n AccountClaimOutput,\r\n Waitlist,\r\n WaitlistOutput,\r\n} from \"./auth.dto\";\r\n\r\nconst schema = { ...auth };\r\ntype Schema = typeof schema;\r\ntype Orm = LibSQLDatabase<Schema>;\r\ntype UserRow = typeof auth.users.$inferSelect;\r\ntype OrganizationMetadata = Record<string, unknown> & {\r\n preferences?: Record<string, unknown>;\r\n flags?: string[];\r\n};\r\n\r\nfunction parseOrganizationMetadata(\r\n metadata: string | Record<string, unknown> | null | undefined\r\n): OrganizationMetadata {\r\n if (!metadata) return {};\r\n if (typeof metadata === \"string\") {\r\n try {\r\n const parsed = JSON.parse(metadata) as unknown;\r\n if (parsed && typeof parsed === \"object\" && !Array.isArray(parsed)) {\r\n return parsed as OrganizationMetadata;\r\n }\r\n return {};\r\n } catch {\r\n return {};\r\n }\r\n }\r\n if (typeof metadata === \"object\" && !Array.isArray(metadata)) {\r\n return metadata as OrganizationMetadata;\r\n }\r\n return {};\r\n}\r\n\r\nfunction normalizeOrganizationPreferences(value: unknown): Record<string, unknown> {\r\n if (value && typeof value === \"object\" && !Array.isArray(value)) {\r\n return value as Record<string, unknown>;\r\n }\r\n return {};\r\n}\r\n\r\nfunction normalizeOrganizationFlags(value: unknown): string[] {\r\n if (!Array.isArray(value)) return [];\r\n return value.filter((item): item is string => typeof item === \"string\");\r\n}\r\n\r\nexport class AuthRepository extends BaseRepository<Orm, Schema, Record<string, never>> {\r\n private async getOrganizationMetadataForMember(\r\n userId: string,\r\n organizationId: string,\r\n tx?: Orm\r\n ): Promise<OrganizationMetadata | null> {\r\n const db = tx ?? this.orm;\r\n const [organization] = await db\r\n .select({ metadata: this.schema.organizations.metadata })\r\n .from(this.schema.organizations)\r\n .innerJoin(\r\n this.schema.members,\r\n eq(this.schema.members.organizationId, this.schema.organizations.id)\r\n )\r\n .where(\r\n and(\r\n eq(this.schema.organizations.id, organizationId),\r\n eq(this.schema.members.userId, userId)\r\n )\r\n )\r\n .limit(1);\r\n\r\n if (!organization) return null;\r\n return parseOrganizationMetadata(organization.metadata);\r\n }\r\n\r\n async getUserWaitlistCount(userId: string, tx?: Orm): ServerResultAsync<number> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db\r\n .select({ count: count() })\r\n .from(this.schema.waitlist)\r\n .where(eq(this.schema.waitlist.userId, userId));\r\n\r\n return ok(waitlist.count ?? 0);\r\n });\r\n }\r\n\r\n async getOnboarding(userId: string, tx?: Orm): ServerResultAsync<number> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [user] = await db\r\n .select({ onboarding: this.schema.users.onboarding })\r\n .from(this.schema.users)\r\n .where(eq(this.schema.users.id, userId))\r\n .limit(1);\r\n if (!user) return this.error(\"FORBIDDEN\");\r\n\r\n return ok(user.onboarding ?? 0);\r\n });\r\n }\r\n\r\n async setOnboarding(userId: string, onboarding: number, tx?: Orm): ServerResultAsync<number> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n await db\r\n .update(this.schema.users)\r\n .set({ onboarding })\r\n .where(eq(this.schema.users.id, userId));\r\n return ok(onboarding);\r\n });\r\n }\r\n\r\n async getPreferences(userId: string, tx?: Orm): ServerResultAsync<Record<string, unknown>> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [user] = await db\r\n .select({ preferences: this.schema.users.preferences })\r\n .from(this.schema.users)\r\n .where(eq(this.schema.users.id, userId))\r\n .limit(1);\r\n if (!user) return this.error(\"FORBIDDEN\");\r\n const json = user.preferences\r\n ? (JSON.parse(user.preferences) as Record<string, unknown>)\r\n : {};\r\n return ok(json);\r\n });\r\n }\r\n\r\n async setPreferences(\r\n userId: string,\r\n preferences: Record<string, unknown>,\r\n tx?: Orm\r\n ): ServerResultAsync<Record<string, unknown>> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n await db\r\n .update(this.schema.users)\r\n .set({ preferences: JSON.stringify(preferences) })\r\n .where(eq(this.schema.users.id, userId));\r\n return ok(preferences);\r\n });\r\n }\r\n\r\n async getOrganizationPreferences(\r\n userId: string,\r\n organizationId: string,\r\n tx?: Orm\r\n ): ServerResultAsync<Record<string, unknown>> {\r\n return this.throwableAsync(async () => {\r\n const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);\r\n if (!metadata) return this.error(\"FORBIDDEN\");\r\n\r\n return ok(normalizeOrganizationPreferences(metadata.preferences));\r\n });\r\n }\r\n\r\n async setOrganizationPreferences(\r\n userId: string,\r\n organizationId: string,\r\n preferences: Record<string, unknown>,\r\n tx?: Orm\r\n ): ServerResultAsync<Record<string, unknown>> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);\r\n if (!metadata) return this.error(\"FORBIDDEN\");\r\n\r\n await db\r\n .update(this.schema.organizations)\r\n .set({\r\n metadata: JSON.stringify({\r\n ...metadata,\r\n preferences,\r\n }),\r\n })\r\n .where(eq(this.schema.organizations.id, organizationId));\r\n\r\n return ok(preferences);\r\n });\r\n }\r\n\r\n async getMetadata(userId: string, tx?: Orm): ServerResultAsync<Record<string, unknown>> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [user] = await db\r\n .select({ metadata: this.schema.users.metadata })\r\n .from(this.schema.users)\r\n .where(eq(this.schema.users.id, userId))\r\n .limit(1);\r\n if (!user) return this.error(\"FORBIDDEN\");\r\n\r\n return ok(user.metadata);\r\n });\r\n }\r\n\r\n async setMetadata(\r\n userId: string,\r\n metadata: Record<string, unknown>,\r\n tx?: Orm\r\n ): ServerResultAsync<Record<string, unknown>> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [user] = await db\r\n .select({ metadata: this.schema.users.metadata })\r\n .from(this.schema.users)\r\n .where(eq(this.schema.users.id, userId))\r\n .limit(1);\r\n if (!user) return this.error(\"FORBIDDEN\");\r\n await db\r\n .update(this.schema.users)\r\n .set({\r\n metadata: {\r\n ...user.metadata,\r\n ...metadata,\r\n },\r\n })\r\n .where(eq(this.schema.users.id, userId));\r\n return ok(metadata);\r\n });\r\n }\r\n\r\n async getFlags(userId: string, tx?: Orm): ServerResultAsync<string[]> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [user] = await db\r\n .select({ flags: this.schema.users.flags })\r\n .from(this.schema.users)\r\n .where(eq(this.schema.users.id, userId))\r\n .limit(1);\r\n if (!user) return this.error(\"FORBIDDEN\");\r\n const json = user.flags ? (JSON.parse(user.flags) as string[]) : [];\r\n\r\n return ok(json);\r\n });\r\n }\r\n\r\n async getOrganizationFlags(\r\n userId: string,\r\n organizationId: string,\r\n tx?: Orm\r\n ): ServerResultAsync<string[]> {\r\n return this.throwableAsync(async () => {\r\n const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);\r\n if (!metadata) return this.error(\"FORBIDDEN\");\r\n\r\n return ok(normalizeOrganizationFlags(metadata.flags));\r\n });\r\n }\r\n\r\n async setFlags(userId: string, flags: string[], tx?: Orm): ServerResultAsync<string[]> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n await db\r\n .update(this.schema.users)\r\n .set({ flags: JSON.stringify(flags) })\r\n .where(eq(this.schema.users.id, userId));\r\n return ok(flags);\r\n });\r\n }\r\n\r\n async setOrganizationFlags(\r\n userId: string,\r\n organizationId: string,\r\n flags: string[],\r\n tx?: Orm\r\n ): ServerResultAsync<string[]> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);\r\n if (!metadata) return this.error(\"FORBIDDEN\");\r\n\r\n await db\r\n .update(this.schema.organizations)\r\n .set({\r\n metadata: JSON.stringify({\r\n ...metadata,\r\n flags,\r\n }),\r\n })\r\n .where(eq(this.schema.organizations.id, organizationId));\r\n\r\n return ok(flags);\r\n });\r\n }\r\n\r\n async listAdminWaitlist(tx?: Orm): ServerResultAsync<WaitlistOutput[]> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const waitlist = await db\r\n .select({\r\n id: this.schema.waitlist.id,\r\n name: this.schema.waitlist.name,\r\n email: this.schema.waitlist.email,\r\n createdAt: this.schema.waitlist.createdAt,\r\n updatedAt: this.schema.waitlist.updatedAt,\r\n status: this.schema.waitlist.status,\r\n })\r\n .from(this.schema.waitlist)\r\n .where(eq(this.schema.waitlist.type, \"WAITLIST\"))\r\n .orderBy(desc(this.schema.waitlist.createdAt));\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async listWaitlist(userId: string, tx?: Orm): ServerResultAsync<Waitlist[]> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const waitlist = await db\r\n .select()\r\n .from(this.schema.waitlist)\r\n .where(\r\n and(eq(this.schema.waitlist.userId, userId), eq(this.schema.waitlist.type, \"WAITLIST\"))\r\n );\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async addToWaitlist(email: string, tx?: Orm): ServerResultAsync<WaitlistOutput> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db.insert(this.schema.waitlist).values({ email }).returning();\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async inviteFromWaitlist(id: string, tx?: Orm): ServerResultAsync<Waitlist> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db\r\n .update(this.schema.waitlist)\r\n .set({\r\n status: \"INVITED\",\r\n code: uuidv4(),\r\n expiresAt: new Date(Date.now() + 1000 * 60 * 60 * 24 * 14),\r\n })\r\n .where(eq(this.schema.waitlist.id, id))\r\n .returning();\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async inviteToWaitlist(\r\n { email, userId, name }: { email: string; userId: string; name?: string },\r\n tx?: Orm\r\n ): ServerResultAsync<Waitlist> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db\r\n .insert(this.schema.waitlist)\r\n .values({\r\n email,\r\n name,\r\n status: \"INVITED\",\r\n code: uuidv4(),\r\n expiresAt: new Date(Date.now() + 1000 * 60 * 60 * 24),\r\n userId: userId,\r\n })\r\n .returning();\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async createInvitationCode(\r\n { userId, name }: { userId: string; name?: string },\r\n tx?: Orm\r\n ): ServerResultAsync<Waitlist> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db\r\n .insert(this.schema.waitlist)\r\n .values({\r\n name,\r\n status: \"INVITED\",\r\n code: uuidv4(),\r\n expiresAt: new Date(Date.now() + 1000 * 60 * 60 * 24),\r\n userId: userId,\r\n })\r\n .returning();\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async joinWaitlist(email: string, tx?: Orm): ServerResultAsync<WaitlistOutput> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db.insert(this.schema.waitlist).values({ email }).returning();\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async removeFromWaitlist(id: string, tx?: Orm): ServerResultAsync<WaitlistOutput> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db\r\n .update(this.schema.waitlist)\r\n .set({ status: \"REMOVED\" })\r\n .where(eq(this.schema.waitlist.id, id))\r\n .returning();\r\n return ok(waitlist);\r\n });\r\n }\r\n\r\n async validateWaitlistCode(code: string, tx?: Orm): ServerResultAsync<{ status: string }> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [waitlist] = await db\r\n .select()\r\n .from(this.schema.waitlist)\r\n .where(and(eq(this.schema.waitlist.code, code), eq(this.schema.waitlist.type, \"WAITLIST\")))\r\n .limit(1);\r\n if (!waitlist) return ok({ status: \"NOT_FOUND\" });\r\n if (waitlist.expiresAt && waitlist.expiresAt < new Date()) return ok({ status: \"EXPIRED\" });\r\n if (waitlist.status !== \"INVITED\") return ok({ status: \"INVALID\" });\r\n return ok({ status: \"VALID\" });\r\n });\r\n }\r\n\r\n async createAccountClaimCode(\r\n { userId, expiresInHours = 24 * 14 }: { userId: string; expiresInHours?: number },\r\n tx?: Orm\r\n ): ServerResultAsync<AccountClaim> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [claim] = await db\r\n .insert(this.schema.waitlist)\r\n .values({\r\n type: \"ACCOUNT_CLAIM\",\r\n claimUserId: userId,\r\n code: uuidv4(),\r\n status: \"INVITED\",\r\n expiresAt: new Date(Date.now() + 1000 * 60 * 60 * expiresInHours),\r\n })\r\n .returning();\r\n return ok(claim);\r\n });\r\n }\r\n\r\n async createClaimableProvisionedUser({\r\n name,\r\n email,\r\n metadata = {},\r\n onboarding = 0,\r\n role = \"user\",\r\n expiresInHours = 24 * 14,\r\n }: {\r\n name: string;\r\n email: string;\r\n metadata?: Record<string, unknown>;\r\n onboarding?: number;\r\n role?: \"user\" | \"admin\" | \"agent\";\r\n expiresInHours?: number;\r\n }): ServerResultAsync<{ user: UserRow; claim: AccountClaim }> {\r\n return this.throwableAsync(async () => {\r\n const normalizedEmail = email.toLowerCase();\r\n const [existingUser] = await this.orm\r\n .select({ id: this.schema.users.id })\r\n .from(this.schema.users)\r\n .where(eq(this.schema.users.email, normalizedEmail))\r\n .limit(1);\r\n if (existingUser) {\r\n return this.error(\"CONFLICT\", \"Email already in use\");\r\n }\r\n\r\n const created = await this.orm.transaction(async (tx) => {\r\n const [user] = await tx\r\n .insert(this.schema.users)\r\n .values({\r\n name,\r\n email: normalizedEmail,\r\n emailVerified: false,\r\n role,\r\n onboarding,\r\n metadata,\r\n })\r\n .returning();\r\n if (!user) throw new Error(\"Failed to create user\");\r\n\r\n const organizationId = uuidv4();\r\n const [organization] = await tx\r\n .insert(this.schema.organizations)\r\n .values({\r\n id: organizationId,\r\n name: organizationId,\r\n slug: organizationId,\r\n })\r\n .returning();\r\n if (!organization) throw new Error(\"Failed to create organization\");\r\n\r\n const [member] = await tx\r\n .insert(this.schema.members)\r\n .values({\r\n userId: user.id,\r\n organizationId: organization.id,\r\n role: \"owner\",\r\n })\r\n .returning();\r\n if (!member) throw new Error(\"Failed to create organization membership\");\r\n\r\n const [team] = await tx\r\n .insert(this.schema.teams)\r\n .values({\r\n name: organization.id,\r\n organizationId: organization.id,\r\n })\r\n .returning();\r\n if (!team) throw new Error(\"Failed to create team\");\r\n\r\n const [teamMember] = await tx\r\n .insert(this.schema.teamMembers)\r\n .values({\r\n userId: user.id,\r\n teamId: team.id,\r\n role: \"owner\",\r\n })\r\n .returning();\r\n if (!teamMember) throw new Error(\"Failed to create team membership\");\r\n\r\n const [claim] = await tx\r\n .insert(this.schema.waitlist)\r\n .values({\r\n type: \"ACCOUNT_CLAIM\",\r\n claimUserId: user.id,\r\n code: uuidv4(),\r\n status: \"INVITED\",\r\n expiresAt: new Date(Date.now() + 1000 * 60 * 60 * expiresInHours),\r\n })\r\n .returning();\r\n if (!claim) throw new Error(\"Failed to create account claim\");\r\n\r\n return { user, claim };\r\n });\r\n\r\n return ok(created);\r\n });\r\n }\r\n\r\n async listAccountClaims(tx?: Orm): ServerResultAsync<AccountClaimOutput[]> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const claims = await db\r\n .select({\r\n id: this.schema.waitlist.id,\r\n claimUserId: this.schema.waitlist.claimUserId,\r\n status: this.schema.waitlist.status,\r\n expiresAt: this.schema.waitlist.expiresAt,\r\n claimedAt: this.schema.waitlist.claimedAt,\r\n claimedEmail: this.schema.waitlist.claimedEmail,\r\n createdAt: this.schema.waitlist.createdAt,\r\n updatedAt: this.schema.waitlist.updatedAt,\r\n })\r\n .from(this.schema.waitlist)\r\n .where(eq(this.schema.waitlist.type, \"ACCOUNT_CLAIM\"))\r\n .orderBy(desc(this.schema.waitlist.createdAt));\r\n return ok(claims);\r\n });\r\n }\r\n\r\n async validateAccountClaimCode(code: string, tx?: Orm): ServerResultAsync<{ status: string }> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [claim] = await db\r\n .select()\r\n .from(this.schema.waitlist)\r\n .where(\r\n and(eq(this.schema.waitlist.code, code), eq(this.schema.waitlist.type, \"ACCOUNT_CLAIM\"))\r\n )\r\n .limit(1);\r\n if (!claim) return ok({ status: \"NOT_FOUND\" });\r\n if (claim.expiresAt && claim.expiresAt < new Date()) return ok({ status: \"EXPIRED\" });\r\n if (claim.status !== \"INVITED\") return ok({ status: \"INVALID\" });\r\n return ok({ status: \"VALID\" });\r\n });\r\n }\r\n\r\n async findAccountClaimByCode(code: string, tx?: Orm): ServerResultAsync<AccountClaim | null> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [claim] = await db\r\n .select()\r\n .from(this.schema.waitlist)\r\n .where(\r\n and(\r\n eq(this.schema.waitlist.code, code),\r\n eq(this.schema.waitlist.type, \"ACCOUNT_CLAIM\"),\r\n eq(this.schema.waitlist.status, \"INVITED\"),\r\n gte(this.schema.waitlist.expiresAt, new Date())\r\n )\r\n )\r\n .limit(1);\r\n return ok(claim ?? null);\r\n });\r\n }\r\n\r\n async findAccountClaimById(id: string, tx?: Orm): ServerResultAsync<AccountClaim | null> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [claim] = await db\r\n .select()\r\n .from(this.schema.waitlist)\r\n .where(and(eq(this.schema.waitlist.id, id), eq(this.schema.waitlist.type, \"ACCOUNT_CLAIM\")))\r\n .limit(1);\r\n return ok(claim ?? null);\r\n });\r\n }\r\n\r\n async findPendingAccountClaimForUser(\r\n userId: string,\r\n tx?: Orm\r\n ): ServerResultAsync<AccountClaim | null> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [claim] = await db\r\n .select()\r\n .from(this.schema.waitlist)\r\n .where(\r\n and(\r\n eq(this.schema.waitlist.type, \"ACCOUNT_CLAIM\"),\r\n eq(this.schema.waitlist.claimUserId, userId),\r\n eq(this.schema.waitlist.status, \"INVITED\"),\r\n gte(this.schema.waitlist.expiresAt, new Date())\r\n )\r\n )\r\n .orderBy(desc(this.schema.waitlist.createdAt))\r\n .limit(1);\r\n return ok(claim ?? null);\r\n });\r\n }\r\n\r\n async setAccountClaimEmail(\r\n { userId, email }: { userId: string; email: string },\r\n tx?: Orm\r\n ): ServerResultAsync<{ status: boolean }> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const normalizedEmail = email.toLowerCase();\r\n const [existingUser] = await db\r\n .select({ id: this.schema.users.id })\r\n .from(this.schema.users)\r\n .where(and(eq(this.schema.users.email, normalizedEmail), ne(this.schema.users.id, userId)))\r\n .limit(1);\r\n if (existingUser) {\r\n return this.error(\"BAD_REQUEST\", \"Email is already in use\");\r\n }\r\n\r\n const [claim] = await db\r\n .select({ id: this.schema.waitlist.id })\r\n .from(this.schema.waitlist)\r\n .where(\r\n and(\r\n eq(this.schema.waitlist.type, \"ACCOUNT_CLAIM\"),\r\n eq(this.schema.waitlist.claimUserId, userId),\r\n eq(this.schema.waitlist.status, \"INVITED\"),\r\n gte(this.schema.waitlist.expiresAt, new Date())\r\n )\r\n )\r\n .orderBy(desc(this.schema.waitlist.createdAt))\r\n .limit(1);\r\n if (!claim) {\r\n return this.error(\"BAD_REQUEST\", \"No pending claim found\");\r\n }\r\n\r\n await db\r\n .update(this.schema.users)\r\n .set({\r\n email: normalizedEmail,\r\n emailVerified: false,\r\n updatedAt: new Date(),\r\n })\r\n .where(eq(this.schema.users.id, userId));\r\n\r\n await db\r\n .update(this.schema.waitlist)\r\n .set({\r\n claimedEmail: normalizedEmail,\r\n updatedAt: new Date(),\r\n })\r\n .where(eq(this.schema.waitlist.id, claim.id));\r\n\r\n return ok({ status: true });\r\n });\r\n }\r\n\r\n async acceptAccountClaim(userId: string, tx?: Orm): ServerResultAsync<{ status: boolean }> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [claim] = await db\r\n .select({ id: this.schema.waitlist.id })\r\n .from(this.schema.waitlist)\r\n .where(\r\n and(\r\n eq(this.schema.waitlist.type, \"ACCOUNT_CLAIM\"),\r\n eq(this.schema.waitlist.claimUserId, userId),\r\n eq(this.schema.waitlist.status, \"INVITED\"),\r\n gte(this.schema.waitlist.expiresAt, new Date())\r\n )\r\n )\r\n .orderBy(desc(this.schema.waitlist.createdAt))\r\n .limit(1);\r\n if (!claim) return ok({ status: true });\r\n\r\n const [user] = await db\r\n .select({ email: this.schema.users.email })\r\n .from(this.schema.users)\r\n .where(eq(this.schema.users.id, userId))\r\n .limit(1);\r\n\r\n await db\r\n .update(this.schema.waitlist)\r\n .set({\r\n status: \"ACCEPTED\",\r\n claimedAt: new Date(),\r\n claimedEmail: user?.email ?? null,\r\n updatedAt: new Date(),\r\n })\r\n .where(eq(this.schema.waitlist.id, claim.id));\r\n return ok({ status: true });\r\n });\r\n }\r\n\r\n async createAccountClaimMagicLink(\r\n {\r\n claimId,\r\n userId,\r\n email,\r\n token,\r\n url,\r\n expiresAt,\r\n }: {\r\n claimId: string;\r\n userId: string;\r\n email: string;\r\n token: string;\r\n url: string;\r\n expiresAt?: Date;\r\n },\r\n tx?: Orm\r\n ): ServerResultAsync<AccountClaimMagicLink> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [link] = await db\r\n .insert(this.schema.accountClaimMagicLinks)\r\n .values({\r\n claimId,\r\n userId,\r\n email,\r\n token,\r\n url,\r\n expiresAt: expiresAt ?? null,\r\n })\r\n .returning();\r\n return ok(link);\r\n });\r\n }\r\n\r\n async listAccountClaimMagicLinks(\r\n claimId: string,\r\n tx?: Orm\r\n ): ServerResultAsync<AccountClaimMagicLinkOutput[]> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const links = await db\r\n .select({\r\n id: this.schema.accountClaimMagicLinks.id,\r\n claimId: this.schema.accountClaimMagicLinks.claimId,\r\n userId: this.schema.accountClaimMagicLinks.userId,\r\n email: this.schema.accountClaimMagicLinks.email,\r\n url: this.schema.accountClaimMagicLinks.url,\r\n expiresAt: this.schema.accountClaimMagicLinks.expiresAt,\r\n createdAt: this.schema.accountClaimMagicLinks.createdAt,\r\n })\r\n .from(this.schema.accountClaimMagicLinks)\r\n .where(eq(this.schema.accountClaimMagicLinks.claimId, claimId))\r\n .orderBy(desc(this.schema.accountClaimMagicLinks.createdAt));\r\n return ok(links);\r\n });\r\n }\r\n\r\n async latestAccountClaimMagicLink(\r\n claimId: string,\r\n tx?: Orm\r\n ): ServerResultAsync<AccountClaimMagicLinkOutput | null> {\r\n return this.throwableAsync(async () => {\r\n const db = tx ?? this.orm;\r\n const [link] = await db\r\n .select({\r\n id: this.schema.accountClaimMagicLinks.id,\r\n claimId: this.schema.accountClaimMagicLinks.claimId,\r\n userId: this.schema.accountClaimMagicLinks.userId,\r\n email: this.schema.accountClaimMagicLinks.email,\r\n url: this.schema.accountClaimMagicLinks.url,\r\n expiresAt: this.schema.accountClaimMagicLinks.expiresAt,\r\n createdAt: this.schema.accountClaimMagicLinks.createdAt,\r\n })\r\n .from(this.schema.accountClaimMagicLinks)\r\n .where(eq(this.schema.accountClaimMagicLinks.claimId, claimId))\r\n .orderBy(desc(this.schema.accountClaimMagicLinks.createdAt))\r\n .limit(1);\r\n return ok(link ?? null);\r\n });\r\n }\r\n}\r\n"],"mappings":"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"}