@m5kdev/backend 0.7.0 → 0.8.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 (559) hide show
  1. package/dist/_virtual/_rolldown/runtime.mjs +13 -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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +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.mts +1 -0
  23. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter-base.d.mts +1 -0
  24. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter.d.mts +1 -0
  25. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect.d.mts +1 -0
  26. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-adapter.d.mts +1 -0
  27. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-dialect.d.mts +1 -0
  28. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-introspector.d.mts +1 -0
  29. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-adapter.d.mts +1 -0
  30. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-dialect.d.mts +1 -0
  31. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-introspector.d.mts +1 -0
  32. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-adapter.d.mts +1 -0
  33. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-dialect.d.mts +1 -0
  34. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-introspector.d.mts +1 -0
  35. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-adapter.d.mts +1 -0
  36. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-dialect.d.mts +1 -0
  37. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-introspector.d.mts +1 -0
  38. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/expression/expression-builder.d.mts +1 -0
  39. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/index.d.mts +1 -0
  40. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/kysely.d.mts +38 -0
  41. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/file-migration-provider.d.mts +1 -0
  42. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/migrator.d.mts +1 -0
  43. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/binary-operation-parser.d.mts +1 -0
  44. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/delete-from-parser.d.mts +1 -0
  45. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/expression-parser.d.mts +1 -0
  46. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/group-by-parser.d.mts +1 -0
  47. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/insert-values-parser.d.mts +1 -0
  48. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/join-parser.d.mts +1 -0
  49. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/merge-into-parser.d.mts +1 -0
  50. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/reference-parser.d.mts +1 -0
  51. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/returning-parser.d.mts +1 -0
  52. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-from-parser.d.mts +1 -0
  53. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-parser.d.mts +1 -0
  54. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/set-operation-parser.d.mts +1 -0
  55. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/tuple-parser.d.mts +1 -0
  56. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/unary-operation-parser.d.mts +1 -0
  57. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-parser.d.mts +1 -0
  58. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-set-parser.d.mts +1 -0
  59. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/value-parser.d.mts +1 -0
  60. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/with-parser.d.mts +1 -0
  61. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/case-builder.d.mts +1 -0
  62. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/delete-query-builder.d.mts +1 -0
  63. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/having-interface.d.mts +1 -0
  64. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/insert-query-builder.d.mts +1 -0
  65. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/join-builder.d.mts +1 -0
  66. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/merge-query-builder.d.mts +1 -0
  67. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/on-conflict-builder.d.mts +1 -0
  68. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/output-interface.d.mts +1 -0
  69. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/returning-interface.d.mts +1 -0
  70. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/select-query-builder.d.mts +1 -0
  71. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/update-query-builder.d.mts +1 -0
  72. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/where-interface.d.mts +1 -0
  73. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-creator.d.mts +1 -0
  74. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/default-query-executor.d.mts +1 -0
  75. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/noop-query-executor.d.mts +1 -0
  76. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-base.d.mts +1 -0
  77. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-provider.d.mts +1 -0
  78. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor.d.mts +1 -0
  79. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/raw-builder.d.mts +1 -0
  80. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/sql.d.mts +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.mts +1 -0
  82. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-add-index-builder.d.mts +1 -0
  83. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-builder.d.mts +1 -0
  84. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-drop-constraint-builder.d.mts +1 -0
  85. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-executor.d.mts +1 -0
  86. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-index-builder.d.mts +1 -0
  87. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-schema-builder.d.mts +1 -0
  88. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-table-builder.d.mts +1 -0
  89. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-type-builder.d.mts +1 -0
  90. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-view-builder.d.mts +1 -0
  91. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-index-builder.d.mts +1 -0
  92. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-schema-builder.d.mts +1 -0
  93. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-table-builder.d.mts +1 -0
  94. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-type-builder.d.mts +1 -0
  95. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-view-builder.d.mts +1 -0
  96. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/refresh-materialized-view-builder.d.mts +1 -0
  97. package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/schema.d.mts +1 -0
  98. package/dist/src/lib/posthog.d.mts +7 -0
  99. package/dist/src/lib/posthog.mjs +7 -0
  100. package/dist/src/lib/posthog.mjs.map +1 -0
  101. package/dist/src/lib/sentry.d.mts +1 -0
  102. package/dist/src/lib/sentry.mjs +10 -0
  103. package/dist/src/lib/sentry.mjs.map +1 -0
  104. package/dist/src/modules/access/access.repository.d.mts +2352 -0
  105. package/dist/src/modules/access/access.repository.mjs +24 -0
  106. package/dist/src/modules/access/access.repository.mjs.map +1 -0
  107. package/dist/src/modules/access/access.service.d.mts +25 -0
  108. package/dist/src/modules/access/access.service.mjs +40 -0
  109. package/dist/src/modules/access/access.service.mjs.map +1 -0
  110. package/dist/src/modules/access/access.utils.d.mts +19 -0
  111. package/dist/src/modules/access/access.utils.mjs +21 -0
  112. package/dist/src/modules/access/access.utils.mjs.map +1 -0
  113. package/dist/src/modules/ai/ai.db.d.mts +401 -0
  114. package/dist/src/modules/ai/ai.db.mjs +38 -0
  115. package/dist/src/modules/ai/ai.db.mjs.map +1 -0
  116. package/dist/src/modules/ai/ai.prompt.d.mts +30 -0
  117. package/dist/src/modules/ai/ai.prompt.mjs +30 -0
  118. package/dist/src/modules/ai/ai.prompt.mjs.map +1 -0
  119. package/dist/src/modules/ai/ai.prompts.d.mts +10 -0
  120. package/dist/src/modules/ai/{ai.prompts.js → ai.prompts.mjs} +17 -15
  121. package/dist/src/modules/ai/ai.prompts.mjs.map +1 -0
  122. package/dist/src/modules/ai/ai.repository.d.mts +428 -0
  123. package/dist/src/modules/ai/ai.repository.mjs +23 -0
  124. package/dist/src/modules/ai/ai.repository.mjs.map +1 -0
  125. package/dist/src/modules/ai/ai.router.d.mts +1 -0
  126. package/dist/src/modules/ai/ai.service.d.mts +129 -0
  127. package/dist/src/modules/ai/ai.service.mjs +267 -0
  128. package/dist/src/modules/ai/ai.service.mjs.map +1 -0
  129. package/dist/src/modules/ai/ai.trpc.d.mts +31 -0
  130. package/dist/src/modules/ai/ai.trpc.mjs +17 -0
  131. package/dist/src/modules/ai/ai.trpc.mjs.map +1 -0
  132. package/dist/src/modules/ai/ideogram/ideogram.constants.d.mts +11 -0
  133. package/dist/src/modules/ai/ideogram/ideogram.constants.mjs +184 -0
  134. package/dist/src/modules/ai/ideogram/ideogram.constants.mjs.map +1 -0
  135. package/dist/src/modules/ai/ideogram/ideogram.dto.d.mts +234 -0
  136. package/dist/src/modules/ai/ideogram/ideogram.dto.mjs +45 -0
  137. package/dist/src/modules/ai/ideogram/ideogram.dto.mjs.map +1 -0
  138. package/dist/src/modules/ai/ideogram/ideogram.prompt.d.mts +7 -0
  139. package/dist/src/modules/ai/ideogram/{ideogram.prompt.js → ideogram.prompt.mjs} +861 -859
  140. package/dist/src/modules/ai/ideogram/ideogram.prompt.mjs.map +1 -0
  141. package/dist/src/modules/ai/ideogram/ideogram.repository.d.mts +11 -0
  142. package/dist/src/modules/ai/ideogram/ideogram.repository.mjs +32 -0
  143. package/dist/src/modules/ai/ideogram/ideogram.repository.mjs.map +1 -0
  144. package/dist/src/modules/ai/ideogram/ideogram.service.d.mts +14 -0
  145. package/dist/src/modules/ai/ideogram/ideogram.service.mjs +11 -0
  146. package/dist/src/modules/ai/ideogram/ideogram.service.mjs.map +1 -0
  147. package/dist/src/modules/auth/auth.db.d.mts +2341 -0
  148. package/dist/src/modules/auth/auth.db.mjs +169 -0
  149. package/dist/src/modules/auth/auth.db.mjs.map +1 -0
  150. package/dist/src/modules/auth/auth.dto.d.mts +70 -0
  151. package/dist/src/modules/auth/auth.dto.mjs +43 -0
  152. package/dist/src/modules/auth/auth.dto.mjs.map +1 -0
  153. package/dist/src/modules/auth/auth.lib.d.mts +4894 -0
  154. package/dist/src/modules/auth/auth.lib.mjs +232 -0
  155. package/dist/src/modules/auth/auth.lib.mjs.map +1 -0
  156. package/dist/src/modules/auth/auth.middleware.d.mts +619 -0
  157. package/dist/src/modules/auth/auth.middleware.mjs +38 -0
  158. package/dist/src/modules/auth/auth.middleware.mjs.map +1 -0
  159. package/dist/src/modules/auth/auth.repository.d.mts +2453 -0
  160. package/dist/src/modules/auth/auth.repository.mjs +401 -0
  161. package/dist/src/modules/auth/auth.repository.mjs.map +1 -0
  162. package/dist/src/modules/auth/auth.service.d.mts +105 -0
  163. package/dist/src/modules/auth/auth.service.mjs +227 -0
  164. package/dist/src/modules/auth/auth.service.mjs.map +1 -0
  165. package/dist/src/modules/auth/auth.trpc.d.mts +303 -0
  166. package/dist/src/modules/auth/auth.trpc.mjs +108 -0
  167. package/dist/src/modules/auth/auth.trpc.mjs.map +1 -0
  168. package/dist/src/modules/auth/auth.utils.d.mts +2356 -0
  169. package/dist/src/modules/auth/auth.utils.mjs +77 -0
  170. package/dist/src/modules/auth/auth.utils.mjs.map +1 -0
  171. package/dist/src/modules/base/base.abstract.d.mts +29 -0
  172. package/dist/src/modules/base/base.abstract.mjs +60 -0
  173. package/dist/src/modules/base/base.abstract.mjs.map +1 -0
  174. package/dist/src/modules/base/base.actor.d.mts +73 -0
  175. package/dist/src/modules/base/base.actor.mjs +78 -0
  176. package/dist/src/modules/base/base.actor.mjs.map +1 -0
  177. package/dist/src/modules/base/base.dto.d.mts +67 -0
  178. package/dist/src/modules/base/base.dto.mjs +79 -0
  179. package/dist/src/modules/base/base.dto.mjs.map +1 -0
  180. package/dist/src/modules/base/base.grants.d.mts +28 -0
  181. package/dist/src/modules/base/base.grants.mjs +103 -0
  182. package/dist/src/modules/base/base.grants.mjs.map +1 -0
  183. package/dist/src/modules/base/base.procedure.d.mts +111 -0
  184. package/dist/src/modules/base/base.procedure.mjs +252 -0
  185. package/dist/src/modules/base/base.procedure.mjs.map +1 -0
  186. package/dist/src/modules/base/base.repository.d.mts +123 -0
  187. package/dist/src/modules/base/base.repository.mjs +250 -0
  188. package/dist/src/modules/base/base.repository.mjs.map +1 -0
  189. package/dist/src/modules/base/base.service.d.mts +44 -0
  190. package/dist/src/modules/base/base.service.mjs +116 -0
  191. package/dist/src/modules/base/base.service.mjs.map +1 -0
  192. package/dist/src/modules/base/base.types.d.mts +5 -0
  193. package/dist/src/modules/billing/billing.db.d.mts +371 -0
  194. package/dist/src/modules/billing/billing.db.mjs +31 -0
  195. package/dist/src/modules/billing/billing.db.mjs.map +1 -0
  196. package/dist/src/modules/billing/billing.repository.d.mts +2787 -0
  197. package/dist/src/modules/billing/billing.repository.mjs +188 -0
  198. package/dist/src/modules/billing/billing.repository.mjs.map +1 -0
  199. package/dist/src/modules/billing/billing.router.d.mts +9 -0
  200. package/dist/src/modules/billing/billing.router.mjs +40 -0
  201. package/dist/src/modules/billing/billing.router.mjs.map +1 -0
  202. package/dist/src/modules/billing/billing.service.d.mts +53 -0
  203. package/dist/src/modules/billing/billing.service.mjs +125 -0
  204. package/dist/src/modules/billing/billing.service.mjs.map +1 -0
  205. package/dist/src/modules/billing/billing.trpc.d.mts +48 -0
  206. package/dist/src/modules/billing/billing.trpc.mjs +17 -0
  207. package/dist/src/modules/billing/billing.trpc.mjs.map +1 -0
  208. package/dist/src/modules/clay/clay.repository.d.mts +10 -0
  209. package/dist/src/modules/clay/clay.repository.mjs +27 -0
  210. package/dist/src/modules/clay/clay.repository.mjs.map +1 -0
  211. package/dist/src/modules/clay/clay.service.d.mts +32 -0
  212. package/dist/src/modules/clay/clay.service.mjs +23 -0
  213. package/dist/src/modules/clay/clay.service.mjs.map +1 -0
  214. package/dist/src/modules/connect/connect.db.d.mts +362 -0
  215. package/dist/src/modules/connect/connect.db.mjs +30 -0
  216. package/dist/src/modules/connect/connect.db.mjs.map +1 -0
  217. package/dist/src/modules/connect/connect.dto.d.mts +79 -0
  218. package/dist/src/modules/connect/connect.dto.mjs +38 -0
  219. package/dist/src/modules/connect/connect.dto.mjs.map +1 -0
  220. package/dist/src/modules/connect/connect.linkedin.d.mts +7 -0
  221. package/dist/src/modules/connect/connect.linkedin.mjs +47 -0
  222. package/dist/src/modules/connect/connect.linkedin.mjs.map +1 -0
  223. package/dist/src/modules/connect/connect.oauth.d.mts +32 -0
  224. package/dist/src/modules/connect/connect.oauth.mjs +145 -0
  225. package/dist/src/modules/connect/connect.oauth.mjs.map +1 -0
  226. package/dist/src/modules/connect/connect.repository.d.mts +419 -0
  227. package/dist/src/modules/connect/connect.repository.mjs +40 -0
  228. package/dist/src/modules/connect/connect.repository.mjs.map +1 -0
  229. package/dist/src/modules/connect/connect.router.d.mts +9 -0
  230. package/dist/src/modules/connect/connect.router.mjs +46 -0
  231. package/dist/src/modules/connect/connect.router.mjs.map +1 -0
  232. package/dist/src/modules/connect/connect.service.d.mts +103 -0
  233. package/dist/src/modules/connect/connect.service.mjs +88 -0
  234. package/dist/src/modules/connect/connect.service.mjs.map +1 -0
  235. package/dist/src/modules/connect/connect.trpc.d.mts +53 -0
  236. package/dist/src/modules/connect/connect.trpc.mjs +17 -0
  237. package/dist/src/modules/connect/connect.trpc.mjs.map +1 -0
  238. package/dist/src/modules/connect/connect.types.d.mts +29 -0
  239. package/dist/src/modules/crypto/crypto.db.d.mts +157 -0
  240. package/dist/src/modules/crypto/crypto.db.mjs +19 -0
  241. package/dist/src/modules/crypto/crypto.db.mjs.map +1 -0
  242. package/dist/src/modules/crypto/crypto.repository.d.mts +163 -0
  243. package/dist/src/modules/crypto/crypto.repository.mjs +9 -0
  244. package/dist/src/modules/crypto/crypto.repository.mjs.map +1 -0
  245. package/dist/src/modules/crypto/crypto.service.d.mts +15 -0
  246. package/dist/src/modules/crypto/crypto.service.mjs +40 -0
  247. package/dist/src/modules/crypto/crypto.service.mjs.map +1 -0
  248. package/dist/src/modules/email/email.service.d.mts +62 -0
  249. package/dist/src/modules/email/email.service.mjs +105 -0
  250. package/dist/src/modules/email/email.service.mjs.map +1 -0
  251. package/dist/src/modules/file/file.repository.d.mts +17 -0
  252. package/dist/src/modules/file/file.repository.mjs +72 -0
  253. package/dist/src/modules/file/file.repository.mjs.map +1 -0
  254. package/dist/src/modules/file/{file.router.d.ts → file.router.d.mts} +4 -0
  255. package/dist/src/modules/file/file.router.mjs +88 -0
  256. package/dist/src/modules/file/file.router.mjs.map +1 -0
  257. package/dist/src/modules/file/file.service.d.mts +30 -0
  258. package/dist/src/modules/file/file.service.mjs +117 -0
  259. package/dist/src/modules/file/file.service.mjs.map +1 -0
  260. package/dist/src/modules/recurrence/recurrence.db.d.mts +568 -0
  261. package/dist/src/modules/recurrence/recurrence.db.mjs +47 -0
  262. package/dist/src/modules/recurrence/recurrence.db.mjs.map +1 -0
  263. package/dist/src/modules/recurrence/recurrence.repository.d.mts +588 -0
  264. package/dist/src/modules/recurrence/recurrence.repository.mjs +28 -0
  265. package/dist/src/modules/recurrence/recurrence.repository.mjs.map +1 -0
  266. package/dist/src/modules/recurrence/recurrence.service.d.mts +87 -0
  267. package/dist/src/modules/recurrence/recurrence.service.mjs +64 -0
  268. package/dist/src/modules/recurrence/recurrence.service.mjs.map +1 -0
  269. package/dist/src/modules/recurrence/recurrence.trpc.d.mts +215 -0
  270. package/dist/src/modules/recurrence/recurrence.trpc.mjs +44 -0
  271. package/dist/src/modules/recurrence/recurrence.trpc.mjs.map +1 -0
  272. package/dist/src/modules/social/social.dto.d.mts +39 -0
  273. package/dist/src/modules/social/social.dto.mjs +22 -0
  274. package/dist/src/modules/social/social.dto.mjs.map +1 -0
  275. package/dist/src/modules/social/{social.linkedin.d.ts → social.linkedin.d.mts} +8 -3
  276. package/dist/src/modules/social/social.linkedin.mjs +346 -0
  277. package/dist/src/modules/social/social.linkedin.mjs.map +1 -0
  278. package/dist/src/modules/social/social.service.d.mts +34 -0
  279. package/dist/src/modules/social/social.service.mjs +55 -0
  280. package/dist/src/modules/social/social.service.mjs.map +1 -0
  281. package/dist/src/modules/social/social.types.d.mts +40 -0
  282. package/dist/src/modules/tag/tag.db.d.mts +352 -0
  283. package/dist/src/modules/tag/tag.db.mjs +35 -0
  284. package/dist/src/modules/tag/tag.db.mjs.map +1 -0
  285. package/dist/src/modules/tag/tag.dto.d.mts +1025 -0
  286. package/dist/src/modules/tag/tag.dto.mjs +11 -0
  287. package/dist/src/modules/tag/tag.dto.mjs.map +1 -0
  288. package/dist/src/modules/tag/tag.repository.d.mts +394 -0
  289. package/dist/src/modules/tag/tag.repository.mjs +114 -0
  290. package/dist/src/modules/tag/tag.repository.mjs.map +1 -0
  291. package/dist/src/modules/tag/tag.service.d.mts +120 -0
  292. package/dist/src/modules/tag/tag.service.mjs +47 -0
  293. package/dist/src/modules/tag/tag.service.mjs.map +1 -0
  294. package/dist/src/modules/tag/tag.trpc.d.mts +173 -0
  295. package/dist/src/modules/tag/tag.trpc.mjs +30 -0
  296. package/dist/src/modules/tag/tag.trpc.mjs.map +1 -0
  297. package/dist/src/modules/utils/{applyPagination.d.ts → applyPagination.d.mts} +5 -1
  298. package/dist/src/modules/utils/applyPagination.mjs +15 -0
  299. package/dist/src/modules/utils/applyPagination.mjs.map +1 -0
  300. package/dist/src/modules/utils/applySorting.d.mts +13 -0
  301. package/dist/src/modules/utils/applySorting.mjs +18 -0
  302. package/dist/src/modules/utils/applySorting.mjs.map +1 -0
  303. package/dist/src/modules/utils/getConditionsFromFilters.d.mts +9 -0
  304. package/dist/src/modules/utils/getConditionsFromFilters.mjs +150 -0
  305. package/dist/src/modules/utils/getConditionsFromFilters.mjs.map +1 -0
  306. package/dist/src/modules/video/video.service.d.mts +12 -0
  307. package/dist/src/modules/video/video.service.mjs +50 -0
  308. package/dist/src/modules/video/video.service.mjs.map +1 -0
  309. package/dist/src/modules/webhook/webhook.constants.d.mts +12 -0
  310. package/dist/src/modules/webhook/webhook.constants.mjs +12 -0
  311. package/dist/src/modules/webhook/webhook.constants.mjs.map +1 -0
  312. package/dist/src/modules/webhook/webhook.db.d.mts +142 -0
  313. package/dist/src/modules/webhook/webhook.db.mjs +17 -0
  314. package/dist/src/modules/webhook/webhook.db.mjs.map +1 -0
  315. package/dist/src/modules/webhook/webhook.dto.d.mts +402 -0
  316. package/dist/src/modules/webhook/webhook.dto.mjs +9 -0
  317. package/dist/src/modules/webhook/webhook.dto.mjs.map +1 -0
  318. package/dist/src/modules/webhook/webhook.repository.d.mts +154 -0
  319. package/dist/src/modules/webhook/webhook.repository.mjs +50 -0
  320. package/dist/src/modules/webhook/webhook.repository.mjs.map +1 -0
  321. package/dist/src/modules/webhook/webhook.router.d.mts +8 -0
  322. package/dist/src/modules/webhook/webhook.router.mjs +23 -0
  323. package/dist/src/modules/webhook/webhook.router.mjs.map +1 -0
  324. package/dist/src/modules/webhook/webhook.service.d.mts +14 -0
  325. package/dist/src/modules/webhook/webhook.service.mjs +59 -0
  326. package/dist/src/modules/webhook/webhook.service.mjs.map +1 -0
  327. package/dist/src/modules/workflow/workflow.db.d.mts +302 -0
  328. package/dist/src/modules/workflow/workflow.db.mjs +28 -0
  329. package/dist/src/modules/workflow/workflow.db.mjs.map +1 -0
  330. package/dist/src/modules/workflow/workflow.repository.d.mts +371 -0
  331. package/dist/src/modules/workflow/workflow.repository.mjs +93 -0
  332. package/dist/src/modules/workflow/workflow.repository.mjs.map +1 -0
  333. package/dist/src/modules/workflow/workflow.service.d.mts +68 -0
  334. package/dist/src/modules/workflow/workflow.service.mjs +40 -0
  335. package/dist/src/modules/workflow/workflow.service.mjs.map +1 -0
  336. package/dist/src/modules/workflow/workflow.trpc.d.mts +65 -0
  337. package/dist/src/modules/workflow/workflow.trpc.mjs +17 -0
  338. package/dist/src/modules/workflow/workflow.trpc.mjs.map +1 -0
  339. package/dist/src/modules/workflow/workflow.types.d.mts +25 -0
  340. package/dist/src/modules/workflow/workflow.utils.d.mts +36 -0
  341. package/dist/src/modules/workflow/workflow.utils.mjs +181 -0
  342. package/dist/src/modules/workflow/workflow.utils.mjs.map +1 -0
  343. package/dist/src/types.d.mts +344 -0
  344. package/dist/src/types.mjs +11 -0
  345. package/dist/src/types.mjs.map +1 -0
  346. package/dist/src/utils/errors.d.mts +62 -0
  347. package/dist/src/utils/errors.mjs +96 -0
  348. package/dist/src/utils/errors.mjs.map +1 -0
  349. package/dist/src/utils/logger.d.mts +7 -0
  350. package/dist/src/utils/logger.mjs +10 -0
  351. package/dist/src/utils/logger.mjs.map +1 -0
  352. package/dist/src/utils/posthog.d.mts +17 -0
  353. package/dist/src/utils/posthog.mjs +25 -0
  354. package/dist/src/utils/posthog.mjs.map +1 -0
  355. package/dist/src/utils/trpc.d.mts +54 -0
  356. package/dist/src/utils/trpc.mjs +146 -0
  357. package/dist/src/utils/trpc.mjs.map +1 -0
  358. package/dist/src/utils/types.d.mts +9 -0
  359. package/package.json +47 -46
  360. package/dist/src/lib/posthog.d.ts +0 -2
  361. package/dist/src/lib/posthog.js +0 -7
  362. package/dist/src/lib/sentry.d.ts +0 -1
  363. package/dist/src/lib/sentry.js +0 -9
  364. package/dist/src/modules/access/access.repository.d.ts +0 -2347
  365. package/dist/src/modules/access/access.repository.js +0 -32
  366. package/dist/src/modules/access/access.service.d.ts +0 -21
  367. package/dist/src/modules/access/access.service.js +0 -51
  368. package/dist/src/modules/access/access.test.d.ts +0 -1
  369. package/dist/src/modules/access/access.test.js +0 -182
  370. package/dist/src/modules/access/access.utils.d.ts +0 -16
  371. package/dist/src/modules/access/access.utils.js +0 -20
  372. package/dist/src/modules/ai/ai.db.d.ts +0 -395
  373. package/dist/src/modules/ai/ai.db.js +0 -39
  374. package/dist/src/modules/ai/ai.prompt.d.ts +0 -26
  375. package/dist/src/modules/ai/ai.prompt.js +0 -30
  376. package/dist/src/modules/ai/ai.prompts.d.ts +0 -5
  377. package/dist/src/modules/ai/ai.repository.d.ts +0 -423
  378. package/dist/src/modules/ai/ai.repository.js +0 -26
  379. package/dist/src/modules/ai/ai.router.js +0 -132
  380. package/dist/src/modules/ai/ai.service.d.ts +0 -125
  381. package/dist/src/modules/ai/ai.service.js +0 -297
  382. package/dist/src/modules/ai/ai.trpc.d.ts +0 -22
  383. package/dist/src/modules/ai/ai.trpc.js +0 -20
  384. package/dist/src/modules/ai/ideogram/ideogram.constants.d.ts +0 -7
  385. package/dist/src/modules/ai/ideogram/ideogram.constants.js +0 -167
  386. package/dist/src/modules/ai/ideogram/ideogram.dto.d.ts +0 -229
  387. package/dist/src/modules/ai/ideogram/ideogram.dto.js +0 -49
  388. package/dist/src/modules/ai/ideogram/ideogram.prompt.d.ts +0 -2
  389. package/dist/src/modules/ai/ideogram/ideogram.repository.d.ts +0 -6
  390. package/dist/src/modules/ai/ideogram/ideogram.repository.js +0 -46
  391. package/dist/src/modules/ai/ideogram/ideogram.service.d.ts +0 -9
  392. package/dist/src/modules/ai/ideogram/ideogram.service.js +0 -11
  393. package/dist/src/modules/auth/auth.db.d.ts +0 -2335
  394. package/dist/src/modules/auth/auth.db.js +0 -215
  395. package/dist/src/modules/auth/auth.dto.d.ts +0 -65
  396. package/dist/src/modules/auth/auth.dto.js +0 -38
  397. package/dist/src/modules/auth/auth.lib.d.ts +0 -4869
  398. package/dist/src/modules/auth/auth.lib.js +0 -284
  399. package/dist/src/modules/auth/auth.middleware.d.ts +0 -614
  400. package/dist/src/modules/auth/auth.middleware.js +0 -52
  401. package/dist/src/modules/auth/auth.repository.d.ts +0 -2421
  402. package/dist/src/modules/auth/auth.repository.js +0 -636
  403. package/dist/src/modules/auth/auth.service.d.ts +0 -78
  404. package/dist/src/modules/auth/auth.service.js +0 -259
  405. package/dist/src/modules/auth/auth.trpc.d.ts +0 -292
  406. package/dist/src/modules/auth/auth.trpc.js +0 -179
  407. package/dist/src/modules/auth/auth.utils.d.ts +0 -2351
  408. package/dist/src/modules/auth/auth.utils.js +0 -97
  409. package/dist/src/modules/base/base.abstract.d.ts +0 -19
  410. package/dist/src/modules/base/base.abstract.js +0 -62
  411. package/dist/src/modules/base/base.actor.d.ts +0 -68
  412. package/dist/src/modules/base/base.actor.js +0 -99
  413. package/dist/src/modules/base/base.actor.test.js +0 -58
  414. package/dist/src/modules/base/base.dto.d.ts +0 -69
  415. package/dist/src/modules/base/base.dto.js +0 -112
  416. package/dist/src/modules/base/base.grants.d.ts +0 -24
  417. package/dist/src/modules/base/base.grants.js +0 -135
  418. package/dist/src/modules/base/base.grants.test.js +0 -639
  419. package/dist/src/modules/base/base.procedure.d.ts +0 -109
  420. package/dist/src/modules/base/base.procedure.js +0 -301
  421. package/dist/src/modules/base/base.repository.d.ts +0 -97
  422. package/dist/src/modules/base/base.repository.js +0 -317
  423. package/dist/src/modules/base/base.service.d.ts +0 -40
  424. package/dist/src/modules/base/base.service.js +0 -123
  425. package/dist/src/modules/base/base.service.test.js +0 -443
  426. package/dist/src/modules/base/base.types.d.ts +0 -1
  427. package/dist/src/modules/base/base.types.js +0 -2
  428. package/dist/src/modules/billing/billing.db.d.ts +0 -365
  429. package/dist/src/modules/billing/billing.db.js +0 -29
  430. package/dist/src/modules/billing/billing.repository.d.ts +0 -2763
  431. package/dist/src/modules/billing/billing.repository.js +0 -235
  432. package/dist/src/modules/billing/billing.router.d.ts +0 -4
  433. package/dist/src/modules/billing/billing.router.js +0 -56
  434. package/dist/src/modules/billing/billing.service.d.ts +0 -38
  435. package/dist/src/modules/billing/billing.service.js +0 -147
  436. package/dist/src/modules/billing/billing.trpc.d.ts +0 -38
  437. package/dist/src/modules/billing/billing.trpc.js +0 -15
  438. package/dist/src/modules/clay/clay.repository.d.ts +0 -5
  439. package/dist/src/modules/clay/clay.repository.js +0 -26
  440. package/dist/src/modules/clay/clay.service.d.ts +0 -28
  441. package/dist/src/modules/clay/clay.service.js +0 -24
  442. package/dist/src/modules/connect/connect.db.d.ts +0 -356
  443. package/dist/src/modules/connect/connect.db.js +0 -30
  444. package/dist/src/modules/connect/connect.dto.d.ts +0 -74
  445. package/dist/src/modules/connect/connect.dto.js +0 -36
  446. package/dist/src/modules/connect/connect.linkedin.d.ts +0 -2
  447. package/dist/src/modules/connect/connect.linkedin.js +0 -53
  448. package/dist/src/modules/connect/connect.oauth.d.ts +0 -27
  449. package/dist/src/modules/connect/connect.oauth.js +0 -198
  450. package/dist/src/modules/connect/connect.repository.d.ts +0 -413
  451. package/dist/src/modules/connect/connect.repository.js +0 -54
  452. package/dist/src/modules/connect/connect.router.d.ts +0 -4
  453. package/dist/src/modules/connect/connect.router.js +0 -54
  454. package/dist/src/modules/connect/connect.service.d.ts +0 -96
  455. package/dist/src/modules/connect/connect.service.js +0 -116
  456. package/dist/src/modules/connect/connect.trpc.d.ts +0 -44
  457. package/dist/src/modules/connect/connect.trpc.js +0 -21
  458. package/dist/src/modules/connect/connect.types.d.ts +0 -25
  459. package/dist/src/modules/connect/connect.types.js +0 -2
  460. package/dist/src/modules/crypto/crypto.db.d.ts +0 -151
  461. package/dist/src/modules/crypto/crypto.db.js +0 -17
  462. package/dist/src/modules/crypto/crypto.repository.d.ts +0 -159
  463. package/dist/src/modules/crypto/crypto.repository.js +0 -10
  464. package/dist/src/modules/crypto/crypto.service.d.ts +0 -10
  465. package/dist/src/modules/crypto/crypto.service.js +0 -52
  466. package/dist/src/modules/email/email.service.d.ts +0 -56
  467. package/dist/src/modules/email/email.service.js +0 -106
  468. package/dist/src/modules/file/file.repository.d.ts +0 -12
  469. package/dist/src/modules/file/file.repository.js +0 -79
  470. package/dist/src/modules/file/file.router.js +0 -99
  471. package/dist/src/modules/file/file.service.d.ts +0 -24
  472. package/dist/src/modules/file/file.service.js +0 -150
  473. package/dist/src/modules/recurrence/recurrence.db.d.ts +0 -562
  474. package/dist/src/modules/recurrence/recurrence.db.js +0 -66
  475. package/dist/src/modules/recurrence/recurrence.repository.d.ts +0 -584
  476. package/dist/src/modules/recurrence/recurrence.repository.js +0 -39
  477. package/dist/src/modules/recurrence/recurrence.service.d.ts +0 -80
  478. package/dist/src/modules/recurrence/recurrence.service.js +0 -72
  479. package/dist/src/modules/recurrence/recurrence.trpc.d.ts +0 -206
  480. package/dist/src/modules/recurrence/recurrence.trpc.js +0 -65
  481. package/dist/src/modules/social/social.dto.d.ts +0 -34
  482. package/dist/src/modules/social/social.dto.js +0 -18
  483. package/dist/src/modules/social/social.linkedin.js +0 -427
  484. package/dist/src/modules/social/social.linkedin.test.js +0 -235
  485. package/dist/src/modules/social/social.service.d.ts +0 -27
  486. package/dist/src/modules/social/social.service.js +0 -76
  487. package/dist/src/modules/social/social.types.d.ts +0 -35
  488. package/dist/src/modules/social/social.types.js +0 -2
  489. package/dist/src/modules/tag/tag.db.d.ts +0 -346
  490. package/dist/src/modules/tag/tag.db.js +0 -42
  491. package/dist/src/modules/tag/tag.dto.d.ts +0 -1018
  492. package/dist/src/modules/tag/tag.dto.js +0 -9
  493. package/dist/src/modules/tag/tag.repository.d.ts +0 -383
  494. package/dist/src/modules/tag/tag.repository.js +0 -156
  495. package/dist/src/modules/tag/tag.service.d.ts +0 -113
  496. package/dist/src/modules/tag/tag.service.js +0 -42
  497. package/dist/src/modules/tag/tag.trpc.d.ts +0 -164
  498. package/dist/src/modules/tag/tag.trpc.js +0 -53
  499. package/dist/src/modules/utils/applyPagination.js +0 -16
  500. package/dist/src/modules/utils/applySorting.d.ts +0 -8
  501. package/dist/src/modules/utils/applySorting.js +0 -18
  502. package/dist/src/modules/utils/getConditionsFromFilters.d.ts +0 -4
  503. package/dist/src/modules/utils/getConditionsFromFilters.js +0 -200
  504. package/dist/src/modules/video/video.service.d.ts +0 -7
  505. package/dist/src/modules/video/video.service.js +0 -84
  506. package/dist/src/modules/webhook/webhook.constants.d.ts +0 -8
  507. package/dist/src/modules/webhook/webhook.constants.js +0 -10
  508. package/dist/src/modules/webhook/webhook.db.d.ts +0 -136
  509. package/dist/src/modules/webhook/webhook.db.js +0 -17
  510. package/dist/src/modules/webhook/webhook.dto.d.ts +0 -394
  511. package/dist/src/modules/webhook/webhook.dto.js +0 -7
  512. package/dist/src/modules/webhook/webhook.repository.d.ts +0 -148
  513. package/dist/src/modules/webhook/webhook.repository.js +0 -56
  514. package/dist/src/modules/webhook/webhook.router.d.ts +0 -3
  515. package/dist/src/modules/webhook/webhook.router.js +0 -30
  516. package/dist/src/modules/webhook/webhook.service.d.ts +0 -9
  517. package/dist/src/modules/webhook/webhook.service.js +0 -68
  518. package/dist/src/modules/workflow/workflow.db.d.ts +0 -296
  519. package/dist/src/modules/workflow/workflow.db.js +0 -30
  520. package/dist/src/modules/workflow/workflow.repository.d.ts +0 -343
  521. package/dist/src/modules/workflow/workflow.repository.js +0 -105
  522. package/dist/src/modules/workflow/workflow.service.d.ts +0 -61
  523. package/dist/src/modules/workflow/workflow.service.js +0 -37
  524. package/dist/src/modules/workflow/workflow.trpc.d.ts +0 -56
  525. package/dist/src/modules/workflow/workflow.trpc.js +0 -21
  526. package/dist/src/modules/workflow/workflow.types.d.ts +0 -20
  527. package/dist/src/modules/workflow/workflow.types.js +0 -2
  528. package/dist/src/modules/workflow/workflow.utils.d.ts +0 -21
  529. package/dist/src/modules/workflow/workflow.utils.js +0 -173
  530. package/dist/src/test/stubs/utils.d.ts +0 -2
  531. package/dist/src/test/stubs/utils.js +0 -5
  532. package/dist/src/trpc/context.d.ts +0 -41
  533. package/dist/src/trpc/context.js +0 -17
  534. package/dist/src/trpc/index.d.ts +0 -3
  535. package/dist/src/trpc/index.js +0 -6
  536. package/dist/src/trpc/procedures.d.ts +0 -233
  537. package/dist/src/trpc/procedures.js +0 -32
  538. package/dist/src/trpc/utils.d.ts +0 -4
  539. package/dist/src/trpc/utils.js +0 -20
  540. package/dist/src/types.d.ts +0 -358
  541. package/dist/src/types.js +0 -12
  542. package/dist/src/utils/errors.d.ts +0 -49
  543. package/dist/src/utils/errors.js +0 -104
  544. package/dist/src/utils/logger.d.ts +0 -1
  545. package/dist/src/utils/logger.js +0 -11
  546. package/dist/src/utils/posthog.d.ts +0 -13
  547. package/dist/src/utils/posthog.js +0 -31
  548. package/dist/src/utils/trpc.d.ts +0 -48
  549. package/dist/src/utils/trpc.js +0 -158
  550. package/dist/src/utils/trpc.test.js +0 -154
  551. package/dist/src/utils/types.d.ts +0 -4
  552. package/dist/src/utils/types.js +0 -2
  553. package/dist/tsconfig.tsbuildinfo +0 -1
  554. /package/dist/src/{utils/trpc.test.d.ts → modules/ai/ai.router.mjs} +0 -0
  555. /package/dist/src/modules/{social/social.linkedin.test.d.ts → base/base.types.mjs} +0 -0
  556. /package/dist/src/modules/{base/base.service.test.d.ts → connect/connect.types.mjs} +0 -0
  557. /package/dist/src/modules/{base/base.grants.test.d.ts → social/social.types.mjs} +0 -0
  558. /package/dist/src/modules/{base/base.actor.test.d.ts → workflow/workflow.types.mjs} +0 -0
  559. /package/dist/src/{modules/ai/ai.router.d.ts → utils/types.mjs} +0 -0
@@ -0,0 +1,401 @@
1
+ import { auth_db_exports } from "./auth.db.mjs";
2
+ import { BaseRepository } from "../base/base.repository.mjs";
3
+ import { and, count, desc, eq, gte, ne } from "drizzle-orm";
4
+ import { ok } from "neverthrow";
5
+ import { v4 } from "uuid";
6
+ //#region src/modules/auth/auth.repository.ts
7
+ ({ ...auth_db_exports });
8
+ function parseOrganizationMetadata(metadata) {
9
+ if (!metadata) return {};
10
+ if (typeof metadata === "string") try {
11
+ const parsed = JSON.parse(metadata);
12
+ if (parsed && typeof parsed === "object" && !Array.isArray(parsed)) return parsed;
13
+ return {};
14
+ } catch {
15
+ return {};
16
+ }
17
+ if (typeof metadata === "object" && !Array.isArray(metadata)) return metadata;
18
+ return {};
19
+ }
20
+ function normalizeOrganizationPreferences(value) {
21
+ if (value && typeof value === "object" && !Array.isArray(value)) return value;
22
+ return {};
23
+ }
24
+ function normalizeOrganizationFlags(value) {
25
+ if (!Array.isArray(value)) return [];
26
+ return value.filter((item) => typeof item === "string");
27
+ }
28
+ var AuthRepository = class extends BaseRepository {
29
+ async getOrganizationMetadataForMember(userId, organizationId, tx) {
30
+ const [organization] = await (tx ?? this.orm).select({ metadata: this.schema.organizations.metadata }).from(this.schema.organizations).innerJoin(this.schema.members, eq(this.schema.members.organizationId, this.schema.organizations.id)).where(and(eq(this.schema.organizations.id, organizationId), eq(this.schema.members.userId, userId))).limit(1);
31
+ if (!organization) return null;
32
+ return parseOrganizationMetadata(organization.metadata);
33
+ }
34
+ async getUserWaitlistCount(userId, tx) {
35
+ return this.throwableAsync(async () => {
36
+ const [waitlist] = await (tx ?? this.orm).select({ count: count() }).from(this.schema.waitlist).where(eq(this.schema.waitlist.userId, userId));
37
+ return ok(waitlist.count ?? 0);
38
+ });
39
+ }
40
+ async getOnboarding(userId, tx) {
41
+ return this.throwableAsync(async () => {
42
+ const [user] = await (tx ?? this.orm).select({ onboarding: this.schema.users.onboarding }).from(this.schema.users).where(eq(this.schema.users.id, userId)).limit(1);
43
+ if (!user) return this.error("FORBIDDEN");
44
+ return ok(user.onboarding ?? 0);
45
+ });
46
+ }
47
+ async setOnboarding(userId, onboarding, tx) {
48
+ return this.throwableAsync(async () => {
49
+ await (tx ?? this.orm).update(this.schema.users).set({ onboarding }).where(eq(this.schema.users.id, userId));
50
+ return ok(onboarding);
51
+ });
52
+ }
53
+ async getPreferences(userId, tx) {
54
+ return this.throwableAsync(async () => {
55
+ const [user] = await (tx ?? this.orm).select({ preferences: this.schema.users.preferences }).from(this.schema.users).where(eq(this.schema.users.id, userId)).limit(1);
56
+ if (!user) return this.error("FORBIDDEN");
57
+ return ok(user.preferences ? JSON.parse(user.preferences) : {});
58
+ });
59
+ }
60
+ async setPreferences(userId, preferences, tx) {
61
+ return this.throwableAsync(async () => {
62
+ await (tx ?? this.orm).update(this.schema.users).set({ preferences: JSON.stringify(preferences) }).where(eq(this.schema.users.id, userId));
63
+ return ok(preferences);
64
+ });
65
+ }
66
+ async getOrganizationPreferences(userId, organizationId, tx) {
67
+ return this.throwableAsync(async () => {
68
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
69
+ if (!metadata) return this.error("FORBIDDEN");
70
+ return ok(normalizeOrganizationPreferences(metadata.preferences));
71
+ });
72
+ }
73
+ async setOrganizationPreferences(userId, organizationId, preferences, tx) {
74
+ return this.throwableAsync(async () => {
75
+ const db = tx ?? this.orm;
76
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
77
+ if (!metadata) return this.error("FORBIDDEN");
78
+ await db.update(this.schema.organizations).set({ metadata: JSON.stringify({
79
+ ...metadata,
80
+ preferences
81
+ }) }).where(eq(this.schema.organizations.id, organizationId));
82
+ return ok(preferences);
83
+ });
84
+ }
85
+ async getMetadata(userId, tx) {
86
+ return this.throwableAsync(async () => {
87
+ const [user] = await (tx ?? this.orm).select({ metadata: this.schema.users.metadata }).from(this.schema.users).where(eq(this.schema.users.id, userId)).limit(1);
88
+ if (!user) return this.error("FORBIDDEN");
89
+ return ok(user.metadata);
90
+ });
91
+ }
92
+ async setMetadata(userId, metadata, tx) {
93
+ return this.throwableAsync(async () => {
94
+ const db = tx ?? this.orm;
95
+ const [user] = await db.select({ metadata: this.schema.users.metadata }).from(this.schema.users).where(eq(this.schema.users.id, userId)).limit(1);
96
+ if (!user) return this.error("FORBIDDEN");
97
+ await db.update(this.schema.users).set({ metadata: {
98
+ ...user.metadata,
99
+ ...metadata
100
+ } }).where(eq(this.schema.users.id, userId));
101
+ return ok(metadata);
102
+ });
103
+ }
104
+ async getFlags(userId, tx) {
105
+ return this.throwableAsync(async () => {
106
+ const [user] = await (tx ?? this.orm).select({ flags: this.schema.users.flags }).from(this.schema.users).where(eq(this.schema.users.id, userId)).limit(1);
107
+ if (!user) return this.error("FORBIDDEN");
108
+ return ok(user.flags ? JSON.parse(user.flags) : []);
109
+ });
110
+ }
111
+ async getOrganizationFlags(userId, organizationId, tx) {
112
+ return this.throwableAsync(async () => {
113
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
114
+ if (!metadata) return this.error("FORBIDDEN");
115
+ return ok(normalizeOrganizationFlags(metadata.flags));
116
+ });
117
+ }
118
+ async setFlags(userId, flags, tx) {
119
+ return this.throwableAsync(async () => {
120
+ await (tx ?? this.orm).update(this.schema.users).set({ flags: JSON.stringify(flags) }).where(eq(this.schema.users.id, userId));
121
+ return ok(flags);
122
+ });
123
+ }
124
+ async setOrganizationFlags(userId, organizationId, flags, tx) {
125
+ return this.throwableAsync(async () => {
126
+ const db = tx ?? this.orm;
127
+ const metadata = await this.getOrganizationMetadataForMember(userId, organizationId, tx);
128
+ if (!metadata) return this.error("FORBIDDEN");
129
+ await db.update(this.schema.organizations).set({ metadata: JSON.stringify({
130
+ ...metadata,
131
+ flags
132
+ }) }).where(eq(this.schema.organizations.id, organizationId));
133
+ return ok(flags);
134
+ });
135
+ }
136
+ async listAdminWaitlist(tx) {
137
+ return this.throwableAsync(async () => {
138
+ return ok(await (tx ?? this.orm).select({
139
+ id: this.schema.waitlist.id,
140
+ name: this.schema.waitlist.name,
141
+ email: this.schema.waitlist.email,
142
+ createdAt: this.schema.waitlist.createdAt,
143
+ updatedAt: this.schema.waitlist.updatedAt,
144
+ status: this.schema.waitlist.status
145
+ }).from(this.schema.waitlist).where(eq(this.schema.waitlist.type, "WAITLIST")).orderBy(desc(this.schema.waitlist.createdAt)));
146
+ });
147
+ }
148
+ async listWaitlist(userId, tx) {
149
+ return this.throwableAsync(async () => {
150
+ return ok(await (tx ?? this.orm).select().from(this.schema.waitlist).where(and(eq(this.schema.waitlist.userId, userId), eq(this.schema.waitlist.type, "WAITLIST"))));
151
+ });
152
+ }
153
+ async addToWaitlist(email, tx) {
154
+ return this.throwableAsync(async () => {
155
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({ email }).returning();
156
+ return ok(waitlist);
157
+ });
158
+ }
159
+ async inviteFromWaitlist(id, tx) {
160
+ return this.throwableAsync(async () => {
161
+ const [waitlist] = await (tx ?? this.orm).update(this.schema.waitlist).set({
162
+ status: "INVITED",
163
+ code: v4(),
164
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * 24 * 14)
165
+ }).where(eq(this.schema.waitlist.id, id)).returning();
166
+ return ok(waitlist);
167
+ });
168
+ }
169
+ async inviteToWaitlist({ email, userId, name }, tx) {
170
+ return this.throwableAsync(async () => {
171
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({
172
+ email,
173
+ name,
174
+ status: "INVITED",
175
+ code: v4(),
176
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * 24),
177
+ userId
178
+ }).returning();
179
+ return ok(waitlist);
180
+ });
181
+ }
182
+ async createInvitationCode({ userId, name }, tx) {
183
+ return this.throwableAsync(async () => {
184
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({
185
+ name,
186
+ status: "INVITED",
187
+ code: v4(),
188
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * 24),
189
+ userId
190
+ }).returning();
191
+ return ok(waitlist);
192
+ });
193
+ }
194
+ async joinWaitlist(email, tx) {
195
+ return this.throwableAsync(async () => {
196
+ const [waitlist] = await (tx ?? this.orm).insert(this.schema.waitlist).values({ email }).returning();
197
+ return ok(waitlist);
198
+ });
199
+ }
200
+ async removeFromWaitlist(id, tx) {
201
+ return this.throwableAsync(async () => {
202
+ const [waitlist] = await (tx ?? this.orm).update(this.schema.waitlist).set({ status: "REMOVED" }).where(eq(this.schema.waitlist.id, id)).returning();
203
+ return ok(waitlist);
204
+ });
205
+ }
206
+ async validateWaitlistCode(code, tx) {
207
+ return this.throwableAsync(async () => {
208
+ const [waitlist] = await (tx ?? this.orm).select().from(this.schema.waitlist).where(and(eq(this.schema.waitlist.code, code), eq(this.schema.waitlist.type, "WAITLIST"))).limit(1);
209
+ if (!waitlist) return ok({ status: "NOT_FOUND" });
210
+ if (waitlist.expiresAt && waitlist.expiresAt < /* @__PURE__ */ new Date()) return ok({ status: "EXPIRED" });
211
+ if (waitlist.status !== "INVITED") return ok({ status: "INVALID" });
212
+ return ok({ status: "VALID" });
213
+ });
214
+ }
215
+ async createAccountClaimCode({ userId, expiresInHours = 336 }, tx) {
216
+ return this.throwableAsync(async () => {
217
+ const [claim] = await (tx ?? this.orm).insert(this.schema.waitlist).values({
218
+ type: "ACCOUNT_CLAIM",
219
+ claimUserId: userId,
220
+ code: v4(),
221
+ status: "INVITED",
222
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * expiresInHours)
223
+ }).returning();
224
+ return ok(claim);
225
+ });
226
+ }
227
+ async createClaimableProvisionedUser({ name, email, metadata = {}, onboarding = 0, role = "user", expiresInHours = 336 }) {
228
+ return this.throwableAsync(async () => {
229
+ const normalizedEmail = email.toLowerCase();
230
+ const [existingUser] = await this.orm.select({ id: this.schema.users.id }).from(this.schema.users).where(eq(this.schema.users.email, normalizedEmail)).limit(1);
231
+ if (existingUser) return this.error("CONFLICT", "Email already in use");
232
+ return ok(await this.orm.transaction(async (tx) => {
233
+ const [user] = await tx.insert(this.schema.users).values({
234
+ name,
235
+ email: normalizedEmail,
236
+ emailVerified: false,
237
+ role,
238
+ onboarding,
239
+ metadata
240
+ }).returning();
241
+ if (!user) throw new Error("Failed to create user");
242
+ const organizationId = v4();
243
+ const [organization] = await tx.insert(this.schema.organizations).values({
244
+ id: organizationId,
245
+ name: organizationId,
246
+ slug: organizationId
247
+ }).returning();
248
+ if (!organization) throw new Error("Failed to create organization");
249
+ const [member] = await tx.insert(this.schema.members).values({
250
+ userId: user.id,
251
+ organizationId: organization.id,
252
+ role: "owner"
253
+ }).returning();
254
+ if (!member) throw new Error("Failed to create organization membership");
255
+ const [team] = await tx.insert(this.schema.teams).values({
256
+ name: organization.id,
257
+ organizationId: organization.id
258
+ }).returning();
259
+ if (!team) throw new Error("Failed to create team");
260
+ const [teamMember] = await tx.insert(this.schema.teamMembers).values({
261
+ userId: user.id,
262
+ teamId: team.id,
263
+ role: "owner"
264
+ }).returning();
265
+ if (!teamMember) throw new Error("Failed to create team membership");
266
+ const [claim] = await tx.insert(this.schema.waitlist).values({
267
+ type: "ACCOUNT_CLAIM",
268
+ claimUserId: user.id,
269
+ code: v4(),
270
+ status: "INVITED",
271
+ expiresAt: new Date(Date.now() + 1e3 * 60 * 60 * expiresInHours)
272
+ }).returning();
273
+ if (!claim) throw new Error("Failed to create account claim");
274
+ return {
275
+ user,
276
+ claim
277
+ };
278
+ }));
279
+ });
280
+ }
281
+ async listAccountClaims(tx) {
282
+ return this.throwableAsync(async () => {
283
+ return ok(await (tx ?? this.orm).select({
284
+ id: this.schema.waitlist.id,
285
+ claimUserId: this.schema.waitlist.claimUserId,
286
+ status: this.schema.waitlist.status,
287
+ expiresAt: this.schema.waitlist.expiresAt,
288
+ claimedAt: this.schema.waitlist.claimedAt,
289
+ claimedEmail: this.schema.waitlist.claimedEmail,
290
+ createdAt: this.schema.waitlist.createdAt,
291
+ updatedAt: this.schema.waitlist.updatedAt
292
+ }).from(this.schema.waitlist).where(eq(this.schema.waitlist.type, "ACCOUNT_CLAIM")).orderBy(desc(this.schema.waitlist.createdAt)));
293
+ });
294
+ }
295
+ async validateAccountClaimCode(code, tx) {
296
+ return this.throwableAsync(async () => {
297
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where(and(eq(this.schema.waitlist.code, code), eq(this.schema.waitlist.type, "ACCOUNT_CLAIM"))).limit(1);
298
+ if (!claim) return ok({ status: "NOT_FOUND" });
299
+ if (claim.expiresAt && claim.expiresAt < /* @__PURE__ */ new Date()) return ok({ status: "EXPIRED" });
300
+ if (claim.status !== "INVITED") return ok({ status: "INVALID" });
301
+ return ok({ status: "VALID" });
302
+ });
303
+ }
304
+ async findAccountClaimByCode(code, tx) {
305
+ return this.throwableAsync(async () => {
306
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where(and(eq(this.schema.waitlist.code, code), eq(this.schema.waitlist.type, "ACCOUNT_CLAIM"), eq(this.schema.waitlist.status, "INVITED"), gte(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).limit(1);
307
+ return ok(claim ?? null);
308
+ });
309
+ }
310
+ async findAccountClaimById(id, tx) {
311
+ return this.throwableAsync(async () => {
312
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where(and(eq(this.schema.waitlist.id, id), eq(this.schema.waitlist.type, "ACCOUNT_CLAIM"))).limit(1);
313
+ return ok(claim ?? null);
314
+ });
315
+ }
316
+ async findPendingAccountClaimForUser(userId, tx) {
317
+ return this.throwableAsync(async () => {
318
+ const [claim] = await (tx ?? this.orm).select().from(this.schema.waitlist).where(and(eq(this.schema.waitlist.type, "ACCOUNT_CLAIM"), eq(this.schema.waitlist.claimUserId, userId), eq(this.schema.waitlist.status, "INVITED"), gte(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).orderBy(desc(this.schema.waitlist.createdAt)).limit(1);
319
+ return ok(claim ?? null);
320
+ });
321
+ }
322
+ async setAccountClaimEmail({ userId, email }, tx) {
323
+ return this.throwableAsync(async () => {
324
+ const db = tx ?? this.orm;
325
+ const normalizedEmail = email.toLowerCase();
326
+ const [existingUser] = await db.select({ id: this.schema.users.id }).from(this.schema.users).where(and(eq(this.schema.users.email, normalizedEmail), ne(this.schema.users.id, userId))).limit(1);
327
+ if (existingUser) return this.error("BAD_REQUEST", "Email is already in use");
328
+ const [claim] = await db.select({ id: this.schema.waitlist.id }).from(this.schema.waitlist).where(and(eq(this.schema.waitlist.type, "ACCOUNT_CLAIM"), eq(this.schema.waitlist.claimUserId, userId), eq(this.schema.waitlist.status, "INVITED"), gte(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).orderBy(desc(this.schema.waitlist.createdAt)).limit(1);
329
+ if (!claim) return this.error("BAD_REQUEST", "No pending claim found");
330
+ await db.update(this.schema.users).set({
331
+ email: normalizedEmail,
332
+ emailVerified: false,
333
+ updatedAt: /* @__PURE__ */ new Date()
334
+ }).where(eq(this.schema.users.id, userId));
335
+ await db.update(this.schema.waitlist).set({
336
+ claimedEmail: normalizedEmail,
337
+ updatedAt: /* @__PURE__ */ new Date()
338
+ }).where(eq(this.schema.waitlist.id, claim.id));
339
+ return ok({ status: true });
340
+ });
341
+ }
342
+ async acceptAccountClaim(userId, tx) {
343
+ return this.throwableAsync(async () => {
344
+ const db = tx ?? this.orm;
345
+ const [claim] = await db.select({ id: this.schema.waitlist.id }).from(this.schema.waitlist).where(and(eq(this.schema.waitlist.type, "ACCOUNT_CLAIM"), eq(this.schema.waitlist.claimUserId, userId), eq(this.schema.waitlist.status, "INVITED"), gte(this.schema.waitlist.expiresAt, /* @__PURE__ */ new Date()))).orderBy(desc(this.schema.waitlist.createdAt)).limit(1);
346
+ if (!claim) return ok({ status: true });
347
+ const [user] = await db.select({ email: this.schema.users.email }).from(this.schema.users).where(eq(this.schema.users.id, userId)).limit(1);
348
+ await db.update(this.schema.waitlist).set({
349
+ status: "ACCEPTED",
350
+ claimedAt: /* @__PURE__ */ new Date(),
351
+ claimedEmail: user?.email ?? null,
352
+ updatedAt: /* @__PURE__ */ new Date()
353
+ }).where(eq(this.schema.waitlist.id, claim.id));
354
+ return ok({ status: true });
355
+ });
356
+ }
357
+ async createAccountClaimMagicLink({ claimId, userId, email, token, url, expiresAt }, tx) {
358
+ return this.throwableAsync(async () => {
359
+ const [link] = await (tx ?? this.orm).insert(this.schema.accountClaimMagicLinks).values({
360
+ claimId,
361
+ userId,
362
+ email,
363
+ token,
364
+ url,
365
+ expiresAt: expiresAt ?? null
366
+ }).returning();
367
+ return ok(link);
368
+ });
369
+ }
370
+ async listAccountClaimMagicLinks(claimId, tx) {
371
+ return this.throwableAsync(async () => {
372
+ return ok(await (tx ?? this.orm).select({
373
+ id: this.schema.accountClaimMagicLinks.id,
374
+ claimId: this.schema.accountClaimMagicLinks.claimId,
375
+ userId: this.schema.accountClaimMagicLinks.userId,
376
+ email: this.schema.accountClaimMagicLinks.email,
377
+ url: this.schema.accountClaimMagicLinks.url,
378
+ expiresAt: this.schema.accountClaimMagicLinks.expiresAt,
379
+ createdAt: this.schema.accountClaimMagicLinks.createdAt
380
+ }).from(this.schema.accountClaimMagicLinks).where(eq(this.schema.accountClaimMagicLinks.claimId, claimId)).orderBy(desc(this.schema.accountClaimMagicLinks.createdAt)));
381
+ });
382
+ }
383
+ async latestAccountClaimMagicLink(claimId, tx) {
384
+ return this.throwableAsync(async () => {
385
+ const [link] = await (tx ?? this.orm).select({
386
+ id: this.schema.accountClaimMagicLinks.id,
387
+ claimId: this.schema.accountClaimMagicLinks.claimId,
388
+ userId: this.schema.accountClaimMagicLinks.userId,
389
+ email: this.schema.accountClaimMagicLinks.email,
390
+ url: this.schema.accountClaimMagicLinks.url,
391
+ expiresAt: this.schema.accountClaimMagicLinks.expiresAt,
392
+ createdAt: this.schema.accountClaimMagicLinks.createdAt
393
+ }).from(this.schema.accountClaimMagicLinks).where(eq(this.schema.accountClaimMagicLinks.claimId, claimId)).orderBy(desc(this.schema.accountClaimMagicLinks.createdAt)).limit(1);
394
+ return ok(link ?? null);
395
+ });
396
+ }
397
+ };
398
+ //#endregion
399
+ export { AuthRepository };
400
+
401
+ //# sourceMappingURL=auth.repository.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.repository.mjs","names":["auth","uuidv4"],"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":";;;;;;CAgBe,EAAE,GAAGA,iBAAM;AAS1B,SAAS,0BACP,UACsB;AACtB,KAAI,CAAC,SAAU,QAAO,EAAE;AACxB,KAAI,OAAO,aAAa,SACtB,KAAI;EACF,MAAM,SAAS,KAAK,MAAM,SAAS;AACnC,MAAI,UAAU,OAAO,WAAW,YAAY,CAAC,MAAM,QAAQ,OAAO,CAChE,QAAO;AAET,SAAO,EAAE;SACH;AACN,SAAO,EAAE;;AAGb,KAAI,OAAO,aAAa,YAAY,CAAC,MAAM,QAAQ,SAAS,CAC1D,QAAO;AAET,QAAO,EAAE;;AAGX,SAAS,iCAAiC,OAAyC;AACjF,KAAI,SAAS,OAAO,UAAU,YAAY,CAAC,MAAM,QAAQ,MAAM,CAC7D,QAAO;AAET,QAAO,EAAE;;AAGX,SAAS,2BAA2B,OAA0B;AAC5D,KAAI,CAAC,MAAM,QAAQ,MAAM,CAAE,QAAO,EAAE;AACpC,QAAO,MAAM,QAAQ,SAAyB,OAAO,SAAS,SAAS;;AAGzE,IAAa,iBAAb,cAAoC,eAAmD;CACrF,MAAc,iCACZ,QACA,gBACA,IACsC;EAEtC,MAAM,CAAC,gBAAgB,OADZ,MAAM,KAAK,KAEnB,OAAO,EAAE,UAAU,KAAK,OAAO,cAAc,UAAU,CAAC,CACxD,KAAK,KAAK,OAAO,cAAc,CAC/B,UACC,KAAK,OAAO,SACZ,GAAG,KAAK,OAAO,QAAQ,gBAAgB,KAAK,OAAO,cAAc,GAAG,CACrE,CACA,MACC,IACE,GAAG,KAAK,OAAO,cAAc,IAAI,eAAe,EAChD,GAAG,KAAK,OAAO,QAAQ,QAAQ,OAAO,CACvC,CACF,CACA,MAAM,EAAE;AAEX,MAAI,CAAC,aAAc,QAAO;AAC1B,SAAO,0BAA0B,aAAa,SAAS;;CAGzD,MAAM,qBAAqB,QAAgB,IAAqC;AAC9E,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KAEnB,OAAO,EAAE,OAAO,OAAO,EAAE,CAAC,CAC1B,KAAK,KAAK,OAAO,SAAS,CAC1B,MAAM,GAAG,KAAK,OAAO,SAAS,QAAQ,OAAO,CAAC;AAEjD,UAAO,GAAG,SAAS,SAAS,EAAE;IAC9B;;CAGJ,MAAM,cAAc,QAAgB,IAAqC;AACvE,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,QAAQ,OADJ,MAAM,KAAK,KAEnB,OAAO,EAAE,YAAY,KAAK,OAAO,MAAM,YAAY,CAAC,CACpD,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC,CACvC,MAAM,EAAE;AACX,OAAI,CAAC,KAAM,QAAO,KAAK,MAAM,YAAY;AAEzC,UAAO,GAAG,KAAK,cAAc,EAAE;IAC/B;;CAGJ,MAAM,cAAc,QAAgB,YAAoB,IAAqC;AAC3F,SAAO,KAAK,eAAe,YAAY;AAErC,UADW,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,MAAM,CACzB,IAAI,EAAE,YAAY,CAAC,CACnB,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC;AAC1C,UAAO,GAAG,WAAW;IACrB;;CAGJ,MAAM,eAAe,QAAgB,IAAsD;AACzF,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,QAAQ,OADJ,MAAM,KAAK,KAEnB,OAAO,EAAE,aAAa,KAAK,OAAO,MAAM,aAAa,CAAC,CACtD,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC,CACvC,MAAM,EAAE;AACX,OAAI,CAAC,KAAM,QAAO,KAAK,MAAM,YAAY;AAIzC,UAAO,GAHM,KAAK,cACb,KAAK,MAAM,KAAK,YAAY,GAC7B,EAAE,CACS;IACf;;CAGJ,MAAM,eACJ,QACA,aACA,IAC4C;AAC5C,SAAO,KAAK,eAAe,YAAY;AAErC,UADW,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,MAAM,CACzB,IAAI,EAAE,aAAa,KAAK,UAAU,YAAY,EAAE,CAAC,CACjD,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC;AAC1C,UAAO,GAAG,YAAY;IACtB;;CAGJ,MAAM,2BACJ,QACA,gBACA,IAC4C;AAC5C,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,WAAW,MAAM,KAAK,iCAAiC,QAAQ,gBAAgB,GAAG;AACxF,OAAI,CAAC,SAAU,QAAO,KAAK,MAAM,YAAY;AAE7C,UAAO,GAAG,iCAAiC,SAAS,YAAY,CAAC;IACjE;;CAGJ,MAAM,2BACJ,QACA,gBACA,aACA,IAC4C;AAC5C,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,KAAK,MAAM,KAAK;GACtB,MAAM,WAAW,MAAM,KAAK,iCAAiC,QAAQ,gBAAgB,GAAG;AACxF,OAAI,CAAC,SAAU,QAAO,KAAK,MAAM,YAAY;AAE7C,SAAM,GACH,OAAO,KAAK,OAAO,cAAc,CACjC,IAAI,EACH,UAAU,KAAK,UAAU;IACvB,GAAG;IACH;IACD,CAAC,EACH,CAAC,CACD,MAAM,GAAG,KAAK,OAAO,cAAc,IAAI,eAAe,CAAC;AAE1D,UAAO,GAAG,YAAY;IACtB;;CAGJ,MAAM,YAAY,QAAgB,IAAsD;AACtF,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,QAAQ,OADJ,MAAM,KAAK,KAEnB,OAAO,EAAE,UAAU,KAAK,OAAO,MAAM,UAAU,CAAC,CAChD,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC,CACvC,MAAM,EAAE;AACX,OAAI,CAAC,KAAM,QAAO,KAAK,MAAM,YAAY;AAEzC,UAAO,GAAG,KAAK,SAAS;IACxB;;CAGJ,MAAM,YACJ,QACA,UACA,IAC4C;AAC5C,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,KAAK,MAAM,KAAK;GACtB,MAAM,CAAC,QAAQ,MAAM,GAClB,OAAO,EAAE,UAAU,KAAK,OAAO,MAAM,UAAU,CAAC,CAChD,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC,CACvC,MAAM,EAAE;AACX,OAAI,CAAC,KAAM,QAAO,KAAK,MAAM,YAAY;AACzC,SAAM,GACH,OAAO,KAAK,OAAO,MAAM,CACzB,IAAI,EACH,UAAU;IACR,GAAG,KAAK;IACR,GAAG;IACJ,EACF,CAAC,CACD,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC;AAC1C,UAAO,GAAG,SAAS;IACnB;;CAGJ,MAAM,SAAS,QAAgB,IAAuC;AACpE,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,QAAQ,OADJ,MAAM,KAAK,KAEnB,OAAO,EAAE,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC,CAC1C,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC,CACvC,MAAM,EAAE;AACX,OAAI,CAAC,KAAM,QAAO,KAAK,MAAM,YAAY;AAGzC,UAAO,GAFM,KAAK,QAAS,KAAK,MAAM,KAAK,MAAM,GAAgB,EAAE,CAEpD;IACf;;CAGJ,MAAM,qBACJ,QACA,gBACA,IAC6B;AAC7B,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,WAAW,MAAM,KAAK,iCAAiC,QAAQ,gBAAgB,GAAG;AACxF,OAAI,CAAC,SAAU,QAAO,KAAK,MAAM,YAAY;AAE7C,UAAO,GAAG,2BAA2B,SAAS,MAAM,CAAC;IACrD;;CAGJ,MAAM,SAAS,QAAgB,OAAiB,IAAuC;AACrF,SAAO,KAAK,eAAe,YAAY;AAErC,UADW,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,MAAM,CACzB,IAAI,EAAE,OAAO,KAAK,UAAU,MAAM,EAAE,CAAC,CACrC,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC;AAC1C,UAAO,GAAG,MAAM;IAChB;;CAGJ,MAAM,qBACJ,QACA,gBACA,OACA,IAC6B;AAC7B,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,KAAK,MAAM,KAAK;GACtB,MAAM,WAAW,MAAM,KAAK,iCAAiC,QAAQ,gBAAgB,GAAG;AACxF,OAAI,CAAC,SAAU,QAAO,KAAK,MAAM,YAAY;AAE7C,SAAM,GACH,OAAO,KAAK,OAAO,cAAc,CACjC,IAAI,EACH,UAAU,KAAK,UAAU;IACvB,GAAG;IACH;IACD,CAAC,EACH,CAAC,CACD,MAAM,GAAG,KAAK,OAAO,cAAc,IAAI,eAAe,CAAC;AAE1D,UAAO,GAAG,MAAM;IAChB;;CAGJ,MAAM,kBAAkB,IAA+C;AACrE,SAAO,KAAK,eAAe,YAAY;AAcrC,UAAO,GAZU,OADN,MAAM,KAAK,KAEnB,OAAO;IACN,IAAI,KAAK,OAAO,SAAS;IACzB,MAAM,KAAK,OAAO,SAAS;IAC3B,OAAO,KAAK,OAAO,SAAS;IAC5B,WAAW,KAAK,OAAO,SAAS;IAChC,WAAW,KAAK,OAAO,SAAS;IAChC,QAAQ,KAAK,OAAO,SAAS;IAC9B,CAAC,CACD,KAAK,KAAK,OAAO,SAAS,CAC1B,MAAM,GAAG,KAAK,OAAO,SAAS,MAAM,WAAW,CAAC,CAChD,QAAQ,KAAK,KAAK,OAAO,SAAS,UAAU,CAAC,CAC7B;IACnB;;CAGJ,MAAM,aAAa,QAAgB,IAAyC;AAC1E,SAAO,KAAK,eAAe,YAAY;AAQrC,UAAO,GANU,OADN,MAAM,KAAK,KAEnB,QAAQ,CACR,KAAK,KAAK,OAAO,SAAS,CAC1B,MACC,IAAI,GAAG,KAAK,OAAO,SAAS,QAAQ,OAAO,EAAE,GAAG,KAAK,OAAO,SAAS,MAAM,WAAW,CAAC,CACxF,CACgB;IACnB;;CAGJ,MAAM,cAAc,OAAe,IAA6C;AAC9E,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KACM,OAAO,KAAK,OAAO,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,WAAW;AACtF,UAAO,GAAG,SAAS;IACnB;;CAGJ,MAAM,mBAAmB,IAAY,IAAuC;AAC1E,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,SAAS,CAC5B,IAAI;IACH,QAAQ;IACR,MAAMC,IAAQ;IACd,WAAW,IAAI,KAAK,KAAK,KAAK,GAAG,MAAO,KAAK,KAAK,KAAK,GAAG;IAC3D,CAAC,CACD,MAAM,GAAG,KAAK,OAAO,SAAS,IAAI,GAAG,CAAC,CACtC,WAAW;AACd,UAAO,GAAG,SAAS;IACnB;;CAGJ,MAAM,iBACJ,EAAE,OAAO,QAAQ,QACjB,IAC6B;AAC7B,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,SAAS,CAC5B,OAAO;IACN;IACA;IACA,QAAQ;IACR,MAAMA,IAAQ;IACd,WAAW,IAAI,KAAK,KAAK,KAAK,GAAG,MAAO,KAAK,KAAK,GAAG;IAC7C;IACT,CAAC,CACD,WAAW;AACd,UAAO,GAAG,SAAS;IACnB;;CAGJ,MAAM,qBACJ,EAAE,QAAQ,QACV,IAC6B;AAC7B,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,SAAS,CAC5B,OAAO;IACN;IACA,QAAQ;IACR,MAAMA,IAAQ;IACd,WAAW,IAAI,KAAK,KAAK,KAAK,GAAG,MAAO,KAAK,KAAK,GAAG;IAC7C;IACT,CAAC,CACD,WAAW;AACd,UAAO,GAAG,SAAS;IACnB;;CAGJ,MAAM,aAAa,OAAe,IAA6C;AAC7E,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KACM,OAAO,KAAK,OAAO,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,WAAW;AACtF,UAAO,GAAG,SAAS;IACnB;;CAGJ,MAAM,mBAAmB,IAAY,IAA6C;AAChF,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,SAAS,CAC5B,IAAI,EAAE,QAAQ,WAAW,CAAC,CAC1B,MAAM,GAAG,KAAK,OAAO,SAAS,IAAI,GAAG,CAAC,CACtC,WAAW;AACd,UAAO,GAAG,SAAS;IACnB;;CAGJ,MAAM,qBAAqB,MAAc,IAAiD;AACxF,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,YAAY,OADR,MAAM,KAAK,KAEnB,QAAQ,CACR,KAAK,KAAK,OAAO,SAAS,CAC1B,MAAM,IAAI,GAAG,KAAK,OAAO,SAAS,MAAM,KAAK,EAAE,GAAG,KAAK,OAAO,SAAS,MAAM,WAAW,CAAC,CAAC,CAC1F,MAAM,EAAE;AACX,OAAI,CAAC,SAAU,QAAO,GAAG,EAAE,QAAQ,aAAa,CAAC;AACjD,OAAI,SAAS,aAAa,SAAS,4BAAY,IAAI,MAAM,CAAE,QAAO,GAAG,EAAE,QAAQ,WAAW,CAAC;AAC3F,OAAI,SAAS,WAAW,UAAW,QAAO,GAAG,EAAE,QAAQ,WAAW,CAAC;AACnE,UAAO,GAAG,EAAE,QAAQ,SAAS,CAAC;IAC9B;;CAGJ,MAAM,uBACJ,EAAE,QAAQ,iBAAiB,OAC3B,IACiC;AACjC,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,SAAS,OADL,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,SAAS,CAC5B,OAAO;IACN,MAAM;IACN,aAAa;IACb,MAAMA,IAAQ;IACd,QAAQ;IACR,WAAW,IAAI,KAAK,KAAK,KAAK,GAAG,MAAO,KAAK,KAAK,eAAe;IAClE,CAAC,CACD,WAAW;AACd,UAAO,GAAG,MAAM;IAChB;;CAGJ,MAAM,+BAA+B,EACnC,MACA,OACA,WAAW,EAAE,EACb,aAAa,GACb,OAAO,QACP,iBAAiB,OAQ2C;AAC5D,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,kBAAkB,MAAM,aAAa;GAC3C,MAAM,CAAC,gBAAgB,MAAM,KAAK,IAC/B,OAAO,EAAE,IAAI,KAAK,OAAO,MAAM,IAAI,CAAC,CACpC,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,GAAG,KAAK,OAAO,MAAM,OAAO,gBAAgB,CAAC,CACnD,MAAM,EAAE;AACX,OAAI,aACF,QAAO,KAAK,MAAM,YAAY,uBAAuB;AAwEvD,UAAO,GArES,MAAM,KAAK,IAAI,YAAY,OAAO,OAAO;IACvD,MAAM,CAAC,QAAQ,MAAM,GAClB,OAAO,KAAK,OAAO,MAAM,CACzB,OAAO;KACN;KACA,OAAO;KACP,eAAe;KACf;KACA;KACA;KACD,CAAC,CACD,WAAW;AACd,QAAI,CAAC,KAAM,OAAM,IAAI,MAAM,wBAAwB;IAEnD,MAAM,iBAAiBA,IAAQ;IAC/B,MAAM,CAAC,gBAAgB,MAAM,GAC1B,OAAO,KAAK,OAAO,cAAc,CACjC,OAAO;KACN,IAAI;KACJ,MAAM;KACN,MAAM;KACP,CAAC,CACD,WAAW;AACd,QAAI,CAAC,aAAc,OAAM,IAAI,MAAM,gCAAgC;IAEnE,MAAM,CAAC,UAAU,MAAM,GACpB,OAAO,KAAK,OAAO,QAAQ,CAC3B,OAAO;KACN,QAAQ,KAAK;KACb,gBAAgB,aAAa;KAC7B,MAAM;KACP,CAAC,CACD,WAAW;AACd,QAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,2CAA2C;IAExE,MAAM,CAAC,QAAQ,MAAM,GAClB,OAAO,KAAK,OAAO,MAAM,CACzB,OAAO;KACN,MAAM,aAAa;KACnB,gBAAgB,aAAa;KAC9B,CAAC,CACD,WAAW;AACd,QAAI,CAAC,KAAM,OAAM,IAAI,MAAM,wBAAwB;IAEnD,MAAM,CAAC,cAAc,MAAM,GACxB,OAAO,KAAK,OAAO,YAAY,CAC/B,OAAO;KACN,QAAQ,KAAK;KACb,QAAQ,KAAK;KACb,MAAM;KACP,CAAC,CACD,WAAW;AACd,QAAI,CAAC,WAAY,OAAM,IAAI,MAAM,mCAAmC;IAEpE,MAAM,CAAC,SAAS,MAAM,GACnB,OAAO,KAAK,OAAO,SAAS,CAC5B,OAAO;KACN,MAAM;KACN,aAAa,KAAK;KAClB,MAAMA,IAAQ;KACd,QAAQ;KACR,WAAW,IAAI,KAAK,KAAK,KAAK,GAAG,MAAO,KAAK,KAAK,eAAe;KAClE,CAAC,CACD,WAAW;AACd,QAAI,CAAC,MAAO,OAAM,IAAI,MAAM,iCAAiC;AAE7D,WAAO;KAAE;KAAM;KAAO;KACtB,CAEgB;IAClB;;CAGJ,MAAM,kBAAkB,IAAmD;AACzE,SAAO,KAAK,eAAe,YAAY;AAgBrC,UAAO,GAdQ,OADJ,MAAM,KAAK,KAEnB,OAAO;IACN,IAAI,KAAK,OAAO,SAAS;IACzB,aAAa,KAAK,OAAO,SAAS;IAClC,QAAQ,KAAK,OAAO,SAAS;IAC7B,WAAW,KAAK,OAAO,SAAS;IAChC,WAAW,KAAK,OAAO,SAAS;IAChC,cAAc,KAAK,OAAO,SAAS;IACnC,WAAW,KAAK,OAAO,SAAS;IAChC,WAAW,KAAK,OAAO,SAAS;IACjC,CAAC,CACD,KAAK,KAAK,OAAO,SAAS,CAC1B,MAAM,GAAG,KAAK,OAAO,SAAS,MAAM,gBAAgB,CAAC,CACrD,QAAQ,KAAK,KAAK,OAAO,SAAS,UAAU,CAAC,CAC/B;IACjB;;CAGJ,MAAM,yBAAyB,MAAc,IAAiD;AAC5F,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,SAAS,OADL,MAAM,KAAK,KAEnB,QAAQ,CACR,KAAK,KAAK,OAAO,SAAS,CAC1B,MACC,IAAI,GAAG,KAAK,OAAO,SAAS,MAAM,KAAK,EAAE,GAAG,KAAK,OAAO,SAAS,MAAM,gBAAgB,CAAC,CACzF,CACA,MAAM,EAAE;AACX,OAAI,CAAC,MAAO,QAAO,GAAG,EAAE,QAAQ,aAAa,CAAC;AAC9C,OAAI,MAAM,aAAa,MAAM,4BAAY,IAAI,MAAM,CAAE,QAAO,GAAG,EAAE,QAAQ,WAAW,CAAC;AACrF,OAAI,MAAM,WAAW,UAAW,QAAO,GAAG,EAAE,QAAQ,WAAW,CAAC;AAChE,UAAO,GAAG,EAAE,QAAQ,SAAS,CAAC;IAC9B;;CAGJ,MAAM,uBAAuB,MAAc,IAAkD;AAC3F,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,SAAS,OADL,MAAM,KAAK,KAEnB,QAAQ,CACR,KAAK,KAAK,OAAO,SAAS,CAC1B,MACC,IACE,GAAG,KAAK,OAAO,SAAS,MAAM,KAAK,EACnC,GAAG,KAAK,OAAO,SAAS,MAAM,gBAAgB,EAC9C,GAAG,KAAK,OAAO,SAAS,QAAQ,UAAU,EAC1C,IAAI,KAAK,OAAO,SAAS,2BAAW,IAAI,MAAM,CAAC,CAChD,CACF,CACA,MAAM,EAAE;AACX,UAAO,GAAG,SAAS,KAAK;IACxB;;CAGJ,MAAM,qBAAqB,IAAY,IAAkD;AACvF,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,SAAS,OADL,MAAM,KAAK,KAEnB,QAAQ,CACR,KAAK,KAAK,OAAO,SAAS,CAC1B,MAAM,IAAI,GAAG,KAAK,OAAO,SAAS,IAAI,GAAG,EAAE,GAAG,KAAK,OAAO,SAAS,MAAM,gBAAgB,CAAC,CAAC,CAC3F,MAAM,EAAE;AACX,UAAO,GAAG,SAAS,KAAK;IACxB;;CAGJ,MAAM,+BACJ,QACA,IACwC;AACxC,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,SAAS,OADL,MAAM,KAAK,KAEnB,QAAQ,CACR,KAAK,KAAK,OAAO,SAAS,CAC1B,MACC,IACE,GAAG,KAAK,OAAO,SAAS,MAAM,gBAAgB,EAC9C,GAAG,KAAK,OAAO,SAAS,aAAa,OAAO,EAC5C,GAAG,KAAK,OAAO,SAAS,QAAQ,UAAU,EAC1C,IAAI,KAAK,OAAO,SAAS,2BAAW,IAAI,MAAM,CAAC,CAChD,CACF,CACA,QAAQ,KAAK,KAAK,OAAO,SAAS,UAAU,CAAC,CAC7C,MAAM,EAAE;AACX,UAAO,GAAG,SAAS,KAAK;IACxB;;CAGJ,MAAM,qBACJ,EAAE,QAAQ,SACV,IACwC;AACxC,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,KAAK,MAAM,KAAK;GACtB,MAAM,kBAAkB,MAAM,aAAa;GAC3C,MAAM,CAAC,gBAAgB,MAAM,GAC1B,OAAO,EAAE,IAAI,KAAK,OAAO,MAAM,IAAI,CAAC,CACpC,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,IAAI,GAAG,KAAK,OAAO,MAAM,OAAO,gBAAgB,EAAE,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC,CAAC,CAC1F,MAAM,EAAE;AACX,OAAI,aACF,QAAO,KAAK,MAAM,eAAe,0BAA0B;GAG7D,MAAM,CAAC,SAAS,MAAM,GACnB,OAAO,EAAE,IAAI,KAAK,OAAO,SAAS,IAAI,CAAC,CACvC,KAAK,KAAK,OAAO,SAAS,CAC1B,MACC,IACE,GAAG,KAAK,OAAO,SAAS,MAAM,gBAAgB,EAC9C,GAAG,KAAK,OAAO,SAAS,aAAa,OAAO,EAC5C,GAAG,KAAK,OAAO,SAAS,QAAQ,UAAU,EAC1C,IAAI,KAAK,OAAO,SAAS,2BAAW,IAAI,MAAM,CAAC,CAChD,CACF,CACA,QAAQ,KAAK,KAAK,OAAO,SAAS,UAAU,CAAC,CAC7C,MAAM,EAAE;AACX,OAAI,CAAC,MACH,QAAO,KAAK,MAAM,eAAe,yBAAyB;AAG5D,SAAM,GACH,OAAO,KAAK,OAAO,MAAM,CACzB,IAAI;IACH,OAAO;IACP,eAAe;IACf,2BAAW,IAAI,MAAM;IACtB,CAAC,CACD,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC;AAE1C,SAAM,GACH,OAAO,KAAK,OAAO,SAAS,CAC5B,IAAI;IACH,cAAc;IACd,2BAAW,IAAI,MAAM;IACtB,CAAC,CACD,MAAM,GAAG,KAAK,OAAO,SAAS,IAAI,MAAM,GAAG,CAAC;AAE/C,UAAO,GAAG,EAAE,QAAQ,MAAM,CAAC;IAC3B;;CAGJ,MAAM,mBAAmB,QAAgB,IAAkD;AACzF,SAAO,KAAK,eAAe,YAAY;GACrC,MAAM,KAAK,MAAM,KAAK;GACtB,MAAM,CAAC,SAAS,MAAM,GACnB,OAAO,EAAE,IAAI,KAAK,OAAO,SAAS,IAAI,CAAC,CACvC,KAAK,KAAK,OAAO,SAAS,CAC1B,MACC,IACE,GAAG,KAAK,OAAO,SAAS,MAAM,gBAAgB,EAC9C,GAAG,KAAK,OAAO,SAAS,aAAa,OAAO,EAC5C,GAAG,KAAK,OAAO,SAAS,QAAQ,UAAU,EAC1C,IAAI,KAAK,OAAO,SAAS,2BAAW,IAAI,MAAM,CAAC,CAChD,CACF,CACA,QAAQ,KAAK,KAAK,OAAO,SAAS,UAAU,CAAC,CAC7C,MAAM,EAAE;AACX,OAAI,CAAC,MAAO,QAAO,GAAG,EAAE,QAAQ,MAAM,CAAC;GAEvC,MAAM,CAAC,QAAQ,MAAM,GAClB,OAAO,EAAE,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC,CAC1C,KAAK,KAAK,OAAO,MAAM,CACvB,MAAM,GAAG,KAAK,OAAO,MAAM,IAAI,OAAO,CAAC,CACvC,MAAM,EAAE;AAEX,SAAM,GACH,OAAO,KAAK,OAAO,SAAS,CAC5B,IAAI;IACH,QAAQ;IACR,2BAAW,IAAI,MAAM;IACrB,cAAc,MAAM,SAAS;IAC7B,2BAAW,IAAI,MAAM;IACtB,CAAC,CACD,MAAM,GAAG,KAAK,OAAO,SAAS,IAAI,MAAM,GAAG,CAAC;AAC/C,UAAO,GAAG,EAAE,QAAQ,MAAM,CAAC;IAC3B;;CAGJ,MAAM,4BACJ,EACE,SACA,QACA,OACA,OACA,KACA,aASF,IAC0C;AAC1C,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,QAAQ,OADJ,MAAM,KAAK,KAEnB,OAAO,KAAK,OAAO,uBAAuB,CAC1C,OAAO;IACN;IACA;IACA;IACA;IACA;IACA,WAAW,aAAa;IACzB,CAAC,CACD,WAAW;AACd,UAAO,GAAG,KAAK;IACf;;CAGJ,MAAM,2BACJ,SACA,IACkD;AAClD,SAAO,KAAK,eAAe,YAAY;AAerC,UAAO,GAbO,OADH,MAAM,KAAK,KAEnB,OAAO;IACN,IAAI,KAAK,OAAO,uBAAuB;IACvC,SAAS,KAAK,OAAO,uBAAuB;IAC5C,QAAQ,KAAK,OAAO,uBAAuB;IAC3C,OAAO,KAAK,OAAO,uBAAuB;IAC1C,KAAK,KAAK,OAAO,uBAAuB;IACxC,WAAW,KAAK,OAAO,uBAAuB;IAC9C,WAAW,KAAK,OAAO,uBAAuB;IAC/C,CAAC,CACD,KAAK,KAAK,OAAO,uBAAuB,CACxC,MAAM,GAAG,KAAK,OAAO,uBAAuB,SAAS,QAAQ,CAAC,CAC9D,QAAQ,KAAK,KAAK,OAAO,uBAAuB,UAAU,CAAC,CAC9C;IAChB;;CAGJ,MAAM,4BACJ,SACA,IACuD;AACvD,SAAO,KAAK,eAAe,YAAY;GAErC,MAAM,CAAC,QAAQ,OADJ,MAAM,KAAK,KAEnB,OAAO;IACN,IAAI,KAAK,OAAO,uBAAuB;IACvC,SAAS,KAAK,OAAO,uBAAuB;IAC5C,QAAQ,KAAK,OAAO,uBAAuB;IAC3C,OAAO,KAAK,OAAO,uBAAuB;IAC1C,KAAK,KAAK,OAAO,uBAAuB;IACxC,WAAW,KAAK,OAAO,uBAAuB;IAC9C,WAAW,KAAK,OAAO,uBAAuB;IAC/C,CAAC,CACD,KAAK,KAAK,OAAO,uBAAuB,CACxC,MAAM,GAAG,KAAK,OAAO,uBAAuB,SAAS,QAAQ,CAAC,CAC9D,QAAQ,KAAK,KAAK,OAAO,uBAAuB,UAAU,CAAC,CAC3D,MAAM,EAAE;AACX,UAAO,GAAG,QAAQ,KAAK;IACvB"}
@@ -0,0 +1,105 @@
1
+ import { ServerResultAsync } from "../base/base.dto.mjs";
2
+ import { Context } from "../../utils/trpc.mjs";
3
+ import { BillingService } from "../billing/billing.service.mjs";
4
+ import { EmailService } from "../email/email.service.mjs";
5
+ import { BaseService } from "../base/base.service.mjs";
6
+ import { AccountClaim, AccountClaimMagicLinkOutput, AccountClaimOutput, Waitlist, WaitlistOutput } from "./auth.dto.mjs";
7
+ import { AuthRepository } from "./auth.repository.mjs";
8
+
9
+ //#region src/modules/auth/auth.service.d.ts
10
+ type AuthServiceDependencies = {
11
+ email: EmailService;
12
+ } | {
13
+ email: EmailService;
14
+ billing: BillingService;
15
+ };
16
+ declare class AuthService extends BaseService<{
17
+ auth: AuthRepository;
18
+ }, AuthServiceDependencies> {
19
+ private getBillingService;
20
+ private organizationActorFromCtx;
21
+ getUserWaitlistCount(ctx: Context): ServerResultAsync<number>;
22
+ getOnboarding(ctx: Context): ServerResultAsync<number>;
23
+ setOnboarding(onboarding: number, ctx: Context): ServerResultAsync<number>;
24
+ getPreferences(ctx: Context): ServerResultAsync<Record<string, unknown>>;
25
+ setPreferences(preferences: Record<string, unknown>, ctx: Context): ServerResultAsync<Record<string, unknown>>;
26
+ getOrganizationPreferences(ctx: Context): ServerResultAsync<Record<string, unknown>>;
27
+ setOrganizationPreferences(preferences: Record<string, unknown>, ctx: Context): ServerResultAsync<Record<string, unknown>>;
28
+ getMetadata(ctx: Context): ServerResultAsync<Record<string, unknown>>;
29
+ setMetadata(metadata: Record<string, unknown>, ctx: Context): ServerResultAsync<Record<string, unknown>>;
30
+ getFlags(ctx: Context): ServerResultAsync<string[]>;
31
+ getOrganizationFlags(ctx: Context): ServerResultAsync<string[]>;
32
+ setFlags(flags: string[], ctx: Context): ServerResultAsync<string[]>;
33
+ setOrganizationFlags(flags: string[], ctx: Context): ServerResultAsync<string[]>;
34
+ listAdminWaitlist(): ServerResultAsync<WaitlistOutput[]>;
35
+ listWaitlist(ctx: Context): ServerResultAsync<Waitlist[]>;
36
+ addToWaitlist({
37
+ email
38
+ }: {
39
+ email: string;
40
+ }): ServerResultAsync<WaitlistOutput>;
41
+ inviteFromWaitlist({
42
+ id
43
+ }: {
44
+ id: string;
45
+ }): ServerResultAsync<Waitlist>;
46
+ inviteToWaitlist({
47
+ email,
48
+ name
49
+ }: {
50
+ email: string;
51
+ name?: string;
52
+ }, ctx: Context): ServerResultAsync<Waitlist>;
53
+ createInvitationCode({
54
+ name
55
+ }: {
56
+ name?: string;
57
+ }, ctx: Context): ServerResultAsync<Waitlist>;
58
+ joinWaitlist({
59
+ email
60
+ }: {
61
+ email: string;
62
+ }): ServerResultAsync<WaitlistOutput>;
63
+ removeFromWaitlist({
64
+ id
65
+ }: {
66
+ id: string;
67
+ }): ServerResultAsync<WaitlistOutput>;
68
+ validateWaitlistCode(code: string): ServerResultAsync<{
69
+ status: string;
70
+ }>;
71
+ createAccountClaimCode({
72
+ userId,
73
+ expiresInHours
74
+ }: {
75
+ userId: string;
76
+ expiresInHours?: number;
77
+ }): ServerResultAsync<AccountClaim>;
78
+ listAccountClaims(): ServerResultAsync<AccountClaimOutput[]>;
79
+ getMyAccountClaimStatus(ctx: Context): ServerResultAsync<AccountClaim | null>;
80
+ setMyAccountClaimEmail({
81
+ email
82
+ }: {
83
+ email: string;
84
+ }, ctx: Context): ServerResultAsync<{
85
+ status: boolean;
86
+ }>;
87
+ acceptMyAccountClaim(ctx: Context): ServerResultAsync<{
88
+ status: boolean;
89
+ }>;
90
+ generateAccountClaimMagicLink({
91
+ claimId,
92
+ email
93
+ }: {
94
+ claimId: string;
95
+ email?: string;
96
+ }): ServerResultAsync<AccountClaimMagicLinkOutput>;
97
+ listAccountClaimMagicLinks({
98
+ claimId
99
+ }: {
100
+ claimId: string;
101
+ }): ServerResultAsync<AccountClaimMagicLinkOutput[]>;
102
+ }
103
+ //#endregion
104
+ export { AuthService };
105
+ //# sourceMappingURL=auth.service.d.mts.map