@m5kdev/backend 0.6.0 → 0.8.0
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.
- package/dist/_virtual/_rolldown/runtime.mjs +13 -0
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter-base.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-adapter.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-dialect.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-introspector.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-adapter.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-dialect.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-introspector.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-adapter.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-dialect.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-introspector.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-adapter.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-dialect.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-introspector.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/expression/expression-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/index.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/kysely.d.mts +38 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/file-migration-provider.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/migrator.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/binary-operation-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/delete-from-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/expression-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/group-by-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/insert-values-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/join-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/merge-into-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/reference-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/returning-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-from-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/set-operation-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/tuple-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/unary-operation-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-set-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/value-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/with-parser.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/case-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/delete-query-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/having-interface.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/insert-query-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/join-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/merge-query-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/on-conflict-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/output-interface.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/returning-interface.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/select-query-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/update-query-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/where-interface.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-creator.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/default-query-executor.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/noop-query-executor.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-base.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-provider.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/raw-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/sql.d.mts +1 -0
- 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
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-add-index-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-drop-constraint-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-executor.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-index-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-schema-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-table-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-type-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-view-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-index-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-schema-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-table-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-type-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-view-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/refresh-materialized-view-builder.d.mts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/schema.d.mts +1 -0
- package/dist/src/lib/posthog.d.mts +7 -0
- package/dist/src/lib/posthog.mjs +7 -0
- package/dist/src/lib/posthog.mjs.map +1 -0
- package/dist/src/lib/sentry.d.mts +1 -0
- package/dist/src/lib/sentry.mjs +10 -0
- package/dist/src/lib/sentry.mjs.map +1 -0
- package/dist/src/modules/access/access.repository.d.mts +2352 -0
- package/dist/src/modules/access/access.repository.mjs +24 -0
- package/dist/src/modules/access/access.repository.mjs.map +1 -0
- package/dist/src/modules/access/access.service.d.mts +25 -0
- package/dist/src/modules/access/access.service.mjs +40 -0
- package/dist/src/modules/access/access.service.mjs.map +1 -0
- package/dist/src/modules/access/access.utils.d.mts +19 -0
- package/dist/src/modules/access/access.utils.mjs +21 -0
- package/dist/src/modules/access/access.utils.mjs.map +1 -0
- package/dist/src/modules/ai/ai.db.d.mts +401 -0
- package/dist/src/modules/ai/ai.db.mjs +38 -0
- package/dist/src/modules/ai/ai.db.mjs.map +1 -0
- package/dist/src/modules/ai/ai.prompt.d.mts +30 -0
- package/dist/src/modules/ai/ai.prompt.mjs +30 -0
- package/dist/src/modules/ai/ai.prompt.mjs.map +1 -0
- package/dist/src/modules/ai/ai.prompts.d.mts +10 -0
- package/dist/src/modules/ai/{ai.prompts.js → ai.prompts.mjs} +17 -15
- package/dist/src/modules/ai/ai.prompts.mjs.map +1 -0
- package/dist/src/modules/ai/ai.repository.d.mts +428 -0
- package/dist/src/modules/ai/ai.repository.mjs +23 -0
- package/dist/src/modules/ai/ai.repository.mjs.map +1 -0
- package/dist/src/modules/ai/ai.router.d.mts +1 -0
- package/dist/src/modules/ai/ai.service.d.mts +128 -0
- package/dist/src/modules/ai/ai.service.mjs +267 -0
- package/dist/src/modules/ai/ai.service.mjs.map +1 -0
- package/dist/src/modules/ai/ai.trpc.d.mts +31 -0
- package/dist/src/modules/ai/ai.trpc.mjs +17 -0
- package/dist/src/modules/ai/ai.trpc.mjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.constants.d.mts +11 -0
- package/dist/src/modules/ai/ideogram/ideogram.constants.mjs +184 -0
- package/dist/src/modules/ai/ideogram/ideogram.constants.mjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.dto.d.mts +234 -0
- package/dist/src/modules/ai/ideogram/ideogram.dto.mjs +45 -0
- package/dist/src/modules/ai/ideogram/ideogram.dto.mjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.prompt.d.mts +7 -0
- package/dist/src/modules/ai/ideogram/{ideogram.prompt.js → ideogram.prompt.mjs} +861 -859
- package/dist/src/modules/ai/ideogram/ideogram.prompt.mjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.repository.d.mts +11 -0
- package/dist/src/modules/ai/ideogram/ideogram.repository.mjs +32 -0
- package/dist/src/modules/ai/ideogram/ideogram.repository.mjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.service.d.mts +14 -0
- package/dist/src/modules/ai/ideogram/ideogram.service.mjs +11 -0
- package/dist/src/modules/ai/ideogram/ideogram.service.mjs.map +1 -0
- package/dist/src/modules/auth/auth.db.d.mts +2341 -0
- package/dist/src/modules/auth/auth.db.mjs +169 -0
- package/dist/src/modules/auth/auth.db.mjs.map +1 -0
- package/dist/src/modules/auth/auth.dto.d.mts +70 -0
- package/dist/src/modules/auth/auth.dto.mjs +43 -0
- package/dist/src/modules/auth/auth.dto.mjs.map +1 -0
- package/dist/src/modules/auth/auth.lib.d.mts +4894 -0
- package/dist/src/modules/auth/auth.lib.mjs +232 -0
- package/dist/src/modules/auth/auth.lib.mjs.map +1 -0
- package/dist/src/modules/auth/auth.middleware.d.mts +619 -0
- package/dist/src/modules/auth/auth.middleware.mjs +38 -0
- package/dist/src/modules/auth/auth.middleware.mjs.map +1 -0
- package/dist/src/modules/auth/auth.repository.d.mts +2453 -0
- package/dist/src/modules/auth/auth.repository.mjs +401 -0
- package/dist/src/modules/auth/auth.repository.mjs.map +1 -0
- package/dist/src/modules/auth/auth.service.d.mts +105 -0
- package/dist/src/modules/auth/auth.service.mjs +227 -0
- package/dist/src/modules/auth/auth.service.mjs.map +1 -0
- package/dist/src/modules/auth/auth.trpc.d.mts +303 -0
- package/dist/src/modules/auth/auth.trpc.mjs +108 -0
- package/dist/src/modules/auth/auth.trpc.mjs.map +1 -0
- package/dist/src/modules/auth/auth.utils.d.mts +2356 -0
- package/dist/src/modules/auth/auth.utils.mjs +77 -0
- package/dist/src/modules/auth/auth.utils.mjs.map +1 -0
- package/dist/src/modules/base/base.abstract.d.mts +29 -0
- package/dist/src/modules/base/base.abstract.mjs +60 -0
- package/dist/src/modules/base/base.abstract.mjs.map +1 -0
- package/dist/src/modules/base/base.actor.d.mts +73 -0
- package/dist/src/modules/base/base.actor.mjs +78 -0
- package/dist/src/modules/base/base.actor.mjs.map +1 -0
- package/dist/src/modules/base/base.dto.d.mts +67 -0
- package/dist/src/modules/base/base.dto.mjs +79 -0
- package/dist/src/modules/base/base.dto.mjs.map +1 -0
- package/dist/src/modules/base/base.grants.d.mts +28 -0
- package/dist/src/modules/base/base.grants.mjs +103 -0
- package/dist/src/modules/base/base.grants.mjs.map +1 -0
- package/dist/src/modules/base/base.procedure.d.mts +111 -0
- package/dist/src/modules/base/base.procedure.mjs +252 -0
- package/dist/src/modules/base/base.procedure.mjs.map +1 -0
- package/dist/src/modules/base/base.repository.d.mts +123 -0
- package/dist/src/modules/base/base.repository.mjs +250 -0
- package/dist/src/modules/base/base.repository.mjs.map +1 -0
- package/dist/src/modules/base/base.service.d.mts +44 -0
- package/dist/src/modules/base/base.service.mjs +116 -0
- package/dist/src/modules/base/base.service.mjs.map +1 -0
- package/dist/src/modules/base/base.types.d.mts +5 -0
- package/dist/src/modules/billing/billing.db.d.mts +371 -0
- package/dist/src/modules/billing/billing.db.mjs +31 -0
- package/dist/src/modules/billing/billing.db.mjs.map +1 -0
- package/dist/src/modules/billing/billing.repository.d.mts +2787 -0
- package/dist/src/modules/billing/billing.repository.mjs +188 -0
- package/dist/src/modules/billing/billing.repository.mjs.map +1 -0
- package/dist/src/modules/billing/billing.router.d.mts +9 -0
- package/dist/src/modules/billing/billing.router.mjs +40 -0
- package/dist/src/modules/billing/billing.router.mjs.map +1 -0
- package/dist/src/modules/billing/billing.service.d.mts +53 -0
- package/dist/src/modules/billing/billing.service.mjs +125 -0
- package/dist/src/modules/billing/billing.service.mjs.map +1 -0
- package/dist/src/modules/billing/billing.trpc.d.mts +29 -0
- package/dist/src/modules/billing/billing.trpc.mjs +17 -0
- package/dist/src/modules/billing/billing.trpc.mjs.map +1 -0
- package/dist/src/modules/clay/clay.repository.d.mts +10 -0
- package/dist/src/modules/clay/clay.repository.mjs +27 -0
- package/dist/src/modules/clay/clay.repository.mjs.map +1 -0
- package/dist/src/modules/clay/clay.service.d.mts +32 -0
- package/dist/src/modules/clay/clay.service.mjs +23 -0
- package/dist/src/modules/clay/clay.service.mjs.map +1 -0
- package/dist/src/modules/connect/connect.db.d.mts +362 -0
- package/dist/src/modules/connect/connect.db.mjs +30 -0
- package/dist/src/modules/connect/connect.db.mjs.map +1 -0
- package/dist/src/modules/connect/connect.dto.d.mts +79 -0
- package/dist/src/modules/connect/connect.dto.mjs +38 -0
- package/dist/src/modules/connect/connect.dto.mjs.map +1 -0
- package/dist/src/modules/connect/connect.linkedin.d.mts +7 -0
- package/dist/src/modules/connect/connect.linkedin.mjs +47 -0
- package/dist/src/modules/connect/connect.linkedin.mjs.map +1 -0
- package/dist/src/modules/connect/connect.oauth.d.mts +32 -0
- package/dist/src/modules/connect/connect.oauth.mjs +145 -0
- package/dist/src/modules/connect/connect.oauth.mjs.map +1 -0
- package/dist/src/modules/connect/connect.repository.d.mts +419 -0
- package/dist/src/modules/connect/connect.repository.mjs +40 -0
- package/dist/src/modules/connect/connect.repository.mjs.map +1 -0
- package/dist/src/modules/connect/connect.router.d.mts +9 -0
- package/dist/src/modules/connect/connect.router.mjs +46 -0
- package/dist/src/modules/connect/connect.router.mjs.map +1 -0
- package/dist/src/modules/connect/connect.service.d.mts +103 -0
- package/dist/src/modules/connect/connect.service.mjs +88 -0
- package/dist/src/modules/connect/connect.service.mjs.map +1 -0
- package/dist/src/modules/connect/connect.trpc.d.mts +53 -0
- package/dist/src/modules/connect/connect.trpc.mjs +17 -0
- package/dist/src/modules/connect/connect.trpc.mjs.map +1 -0
- package/dist/src/modules/connect/connect.types.d.mts +29 -0
- package/dist/src/modules/crypto/crypto.db.d.mts +157 -0
- package/dist/src/modules/crypto/crypto.db.mjs +19 -0
- package/dist/src/modules/crypto/crypto.db.mjs.map +1 -0
- package/dist/src/modules/crypto/crypto.repository.d.mts +163 -0
- package/dist/src/modules/crypto/crypto.repository.mjs +9 -0
- package/dist/src/modules/crypto/crypto.repository.mjs.map +1 -0
- package/dist/src/modules/crypto/crypto.service.d.mts +15 -0
- package/dist/src/modules/crypto/crypto.service.mjs +40 -0
- package/dist/src/modules/crypto/crypto.service.mjs.map +1 -0
- package/dist/src/modules/email/email.service.d.mts +62 -0
- package/dist/src/modules/email/email.service.mjs +105 -0
- package/dist/src/modules/email/email.service.mjs.map +1 -0
- package/dist/src/modules/file/file.repository.d.mts +17 -0
- package/dist/src/modules/file/file.repository.mjs +72 -0
- package/dist/src/modules/file/file.repository.mjs.map +1 -0
- package/dist/src/modules/file/{file.router.d.ts → file.router.d.mts} +4 -0
- package/dist/src/modules/file/file.router.mjs +88 -0
- package/dist/src/modules/file/file.router.mjs.map +1 -0
- package/dist/src/modules/file/file.service.d.mts +30 -0
- package/dist/src/modules/file/file.service.mjs +117 -0
- package/dist/src/modules/file/file.service.mjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.db.d.mts +568 -0
- package/dist/src/modules/recurrence/recurrence.db.mjs +47 -0
- package/dist/src/modules/recurrence/recurrence.db.mjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.repository.d.mts +588 -0
- package/dist/src/modules/recurrence/recurrence.repository.mjs +28 -0
- package/dist/src/modules/recurrence/recurrence.repository.mjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.service.d.mts +51 -0
- package/dist/src/modules/recurrence/recurrence.service.mjs +64 -0
- package/dist/src/modules/recurrence/recurrence.service.mjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.trpc.d.mts +65 -0
- package/dist/src/modules/recurrence/recurrence.trpc.mjs +44 -0
- package/dist/src/modules/recurrence/recurrence.trpc.mjs.map +1 -0
- package/dist/src/modules/social/social.dto.d.mts +39 -0
- package/dist/src/modules/social/social.dto.mjs +22 -0
- package/dist/src/modules/social/social.dto.mjs.map +1 -0
- package/dist/src/modules/social/{social.linkedin.d.ts → social.linkedin.d.mts} +8 -3
- package/dist/src/modules/social/social.linkedin.mjs +346 -0
- package/dist/src/modules/social/social.linkedin.mjs.map +1 -0
- package/dist/src/modules/social/social.service.d.mts +34 -0
- package/dist/src/modules/social/social.service.mjs +55 -0
- package/dist/src/modules/social/social.service.mjs.map +1 -0
- package/dist/src/modules/social/social.types.d.mts +40 -0
- package/dist/src/modules/tag/tag.db.d.mts +352 -0
- package/dist/src/modules/tag/tag.db.mjs +35 -0
- package/dist/src/modules/tag/tag.db.mjs.map +1 -0
- package/dist/src/modules/tag/tag.dto.d.mts +1025 -0
- package/dist/src/modules/tag/tag.dto.mjs +11 -0
- package/dist/src/modules/tag/tag.dto.mjs.map +1 -0
- package/dist/src/modules/tag/tag.repository.d.mts +394 -0
- package/dist/src/modules/tag/tag.repository.mjs +114 -0
- package/dist/src/modules/tag/tag.repository.mjs.map +1 -0
- package/dist/src/modules/tag/tag.service.d.mts +93 -0
- package/dist/src/modules/tag/tag.service.mjs +47 -0
- package/dist/src/modules/tag/tag.service.mjs.map +1 -0
- package/dist/src/modules/tag/tag.trpc.d.mts +109 -0
- package/dist/src/modules/tag/tag.trpc.mjs +30 -0
- package/dist/src/modules/tag/tag.trpc.mjs.map +1 -0
- package/dist/src/modules/utils/{applyPagination.d.ts → applyPagination.d.mts} +5 -1
- package/dist/src/modules/utils/applyPagination.mjs +15 -0
- package/dist/src/modules/utils/applyPagination.mjs.map +1 -0
- package/dist/src/modules/utils/applySorting.d.mts +13 -0
- package/dist/src/modules/utils/applySorting.mjs +18 -0
- package/dist/src/modules/utils/applySorting.mjs.map +1 -0
- package/dist/src/modules/utils/getConditionsFromFilters.d.mts +9 -0
- package/dist/src/modules/utils/getConditionsFromFilters.mjs +150 -0
- package/dist/src/modules/utils/getConditionsFromFilters.mjs.map +1 -0
- package/dist/src/modules/video/video.service.d.mts +12 -0
- package/dist/src/modules/video/video.service.mjs +50 -0
- package/dist/src/modules/video/video.service.mjs.map +1 -0
- package/dist/src/modules/webhook/webhook.constants.d.mts +12 -0
- package/dist/src/modules/webhook/webhook.constants.mjs +12 -0
- package/dist/src/modules/webhook/webhook.constants.mjs.map +1 -0
- package/dist/src/modules/webhook/webhook.db.d.mts +142 -0
- package/dist/src/modules/webhook/webhook.db.mjs +17 -0
- package/dist/src/modules/webhook/webhook.db.mjs.map +1 -0
- package/dist/src/modules/webhook/webhook.dto.d.mts +402 -0
- package/dist/src/modules/webhook/webhook.dto.mjs +9 -0
- package/dist/src/modules/webhook/webhook.dto.mjs.map +1 -0
- package/dist/src/modules/webhook/webhook.repository.d.mts +154 -0
- package/dist/src/modules/webhook/webhook.repository.mjs +50 -0
- package/dist/src/modules/webhook/webhook.repository.mjs.map +1 -0
- package/dist/src/modules/webhook/webhook.router.d.mts +8 -0
- package/dist/src/modules/webhook/webhook.router.mjs +23 -0
- package/dist/src/modules/webhook/webhook.router.mjs.map +1 -0
- package/dist/src/modules/webhook/webhook.service.d.mts +14 -0
- package/dist/src/modules/webhook/webhook.service.mjs +59 -0
- package/dist/src/modules/webhook/webhook.service.mjs.map +1 -0
- package/dist/src/modules/workflow/workflow.db.d.mts +302 -0
- package/dist/src/modules/workflow/workflow.db.mjs +28 -0
- package/dist/src/modules/workflow/workflow.db.mjs.map +1 -0
- package/dist/src/modules/workflow/workflow.repository.d.mts +371 -0
- package/dist/src/modules/workflow/workflow.repository.mjs +93 -0
- package/dist/src/modules/workflow/workflow.repository.mjs.map +1 -0
- package/dist/src/modules/workflow/workflow.service.d.mts +31 -0
- package/dist/src/modules/workflow/workflow.service.mjs +40 -0
- package/dist/src/modules/workflow/workflow.service.mjs.map +1 -0
- package/dist/src/modules/workflow/workflow.trpc.d.mts +28 -0
- package/dist/src/modules/workflow/workflow.trpc.mjs +17 -0
- package/dist/src/modules/workflow/workflow.trpc.mjs.map +1 -0
- package/dist/src/modules/workflow/workflow.types.d.mts +25 -0
- package/dist/src/modules/workflow/workflow.utils.d.mts +36 -0
- package/dist/src/modules/workflow/workflow.utils.mjs +181 -0
- package/dist/src/modules/workflow/workflow.utils.mjs.map +1 -0
- package/dist/src/types.d.mts +346 -0
- package/dist/src/types.mjs +13 -0
- package/dist/src/types.mjs.map +1 -0
- package/dist/src/utils/errors.d.mts +62 -0
- package/dist/src/utils/errors.mjs +96 -0
- package/dist/src/utils/errors.mjs.map +1 -0
- package/dist/src/utils/logger.d.mts +7 -0
- package/dist/src/utils/logger.mjs +10 -0
- package/dist/src/utils/logger.mjs.map +1 -0
- package/dist/src/utils/posthog.d.mts +17 -0
- package/dist/src/utils/posthog.mjs +25 -0
- package/dist/src/utils/posthog.mjs.map +1 -0
- package/dist/src/utils/trpc.d.mts +54 -0
- package/dist/src/utils/trpc.mjs +146 -0
- package/dist/src/utils/trpc.mjs.map +1 -0
- package/dist/src/utils/types.d.mts +9 -0
- package/package.json +5 -4
- package/dist/src/lib/posthog.d.ts +0 -2
- package/dist/src/lib/posthog.js +0 -7
- package/dist/src/lib/sentry.js +0 -9
- package/dist/src/modules/access/access.repository.d.ts +0 -2347
- package/dist/src/modules/access/access.repository.js +0 -32
- package/dist/src/modules/access/access.service.d.ts +0 -21
- package/dist/src/modules/access/access.service.js +0 -51
- package/dist/src/modules/access/access.test.js +0 -182
- package/dist/src/modules/access/access.utils.d.ts +0 -16
- package/dist/src/modules/access/access.utils.js +0 -20
- package/dist/src/modules/ai/ai.db.d.ts +0 -395
- package/dist/src/modules/ai/ai.db.js +0 -39
- package/dist/src/modules/ai/ai.prompt.d.ts +0 -26
- package/dist/src/modules/ai/ai.prompt.js +0 -30
- package/dist/src/modules/ai/ai.prompts.d.ts +0 -5
- package/dist/src/modules/ai/ai.repository.d.ts +0 -423
- package/dist/src/modules/ai/ai.repository.js +0 -26
- package/dist/src/modules/ai/ai.router.js +0 -132
- package/dist/src/modules/ai/ai.service.d.ts +0 -127
- package/dist/src/modules/ai/ai.service.js +0 -297
- package/dist/src/modules/ai/ai.trpc.d.ts +0 -22
- package/dist/src/modules/ai/ai.trpc.js +0 -20
- package/dist/src/modules/ai/ideogram/ideogram.constants.d.ts +0 -7
- package/dist/src/modules/ai/ideogram/ideogram.constants.js +0 -167
- package/dist/src/modules/ai/ideogram/ideogram.dto.d.ts +0 -229
- package/dist/src/modules/ai/ideogram/ideogram.dto.js +0 -49
- package/dist/src/modules/ai/ideogram/ideogram.prompt.d.ts +0 -2
- package/dist/src/modules/ai/ideogram/ideogram.repository.d.ts +0 -6
- package/dist/src/modules/ai/ideogram/ideogram.repository.js +0 -46
- package/dist/src/modules/ai/ideogram/ideogram.service.d.ts +0 -9
- package/dist/src/modules/ai/ideogram/ideogram.service.js +0 -11
- package/dist/src/modules/auth/auth.db.d.ts +0 -2335
- package/dist/src/modules/auth/auth.db.js +0 -215
- package/dist/src/modules/auth/auth.dto.d.ts +0 -65
- package/dist/src/modules/auth/auth.dto.js +0 -38
- package/dist/src/modules/auth/auth.lib.d.ts +0 -4873
- package/dist/src/modules/auth/auth.lib.js +0 -284
- package/dist/src/modules/auth/auth.middleware.d.ts +0 -614
- package/dist/src/modules/auth/auth.middleware.js +0 -52
- package/dist/src/modules/auth/auth.repository.d.ts +0 -2421
- package/dist/src/modules/auth/auth.repository.js +0 -636
- package/dist/src/modules/auth/auth.service.d.ts +0 -108
- package/dist/src/modules/auth/auth.service.js +0 -246
- package/dist/src/modules/auth/auth.trpc.d.ts +0 -292
- package/dist/src/modules/auth/auth.trpc.js +0 -179
- package/dist/src/modules/auth/auth.utils.d.ts +0 -2351
- package/dist/src/modules/auth/auth.utils.js +0 -97
- package/dist/src/modules/base/base.abstract.d.ts +0 -19
- package/dist/src/modules/base/base.abstract.js +0 -62
- package/dist/src/modules/base/base.dto.d.ts +0 -69
- package/dist/src/modules/base/base.dto.js +0 -112
- package/dist/src/modules/base/base.grants.d.ts +0 -28
- package/dist/src/modules/base/base.grants.js +0 -123
- package/dist/src/modules/base/base.grants.test.js +0 -668
- package/dist/src/modules/base/base.procedure.d.ts +0 -112
- package/dist/src/modules/base/base.procedure.js +0 -289
- package/dist/src/modules/base/base.repository.d.ts +0 -97
- package/dist/src/modules/base/base.repository.js +0 -317
- package/dist/src/modules/base/base.service.d.ts +0 -52
- package/dist/src/modules/base/base.service.js +0 -116
- package/dist/src/modules/base/base.service.test.js +0 -415
- package/dist/src/modules/base/base.types.d.ts +0 -1
- package/dist/src/modules/base/base.types.js +0 -2
- package/dist/src/modules/billing/billing.db.d.ts +0 -365
- package/dist/src/modules/billing/billing.db.js +0 -29
- package/dist/src/modules/billing/billing.repository.d.ts +0 -2763
- package/dist/src/modules/billing/billing.repository.js +0 -235
- package/dist/src/modules/billing/billing.router.d.ts +0 -4
- package/dist/src/modules/billing/billing.router.js +0 -56
- package/dist/src/modules/billing/billing.service.d.ts +0 -59
- package/dist/src/modules/billing/billing.service.js +0 -147
- package/dist/src/modules/billing/billing.trpc.d.ts +0 -38
- package/dist/src/modules/billing/billing.trpc.js +0 -17
- package/dist/src/modules/clay/clay.repository.d.ts +0 -5
- package/dist/src/modules/clay/clay.repository.js +0 -26
- package/dist/src/modules/clay/clay.service.d.ts +0 -28
- package/dist/src/modules/clay/clay.service.js +0 -24
- package/dist/src/modules/connect/connect.db.d.ts +0 -356
- package/dist/src/modules/connect/connect.db.js +0 -30
- package/dist/src/modules/connect/connect.dto.d.ts +0 -74
- package/dist/src/modules/connect/connect.dto.js +0 -36
- package/dist/src/modules/connect/connect.linkedin.d.ts +0 -2
- package/dist/src/modules/connect/connect.linkedin.js +0 -53
- package/dist/src/modules/connect/connect.oauth.d.ts +0 -27
- package/dist/src/modules/connect/connect.oauth.js +0 -198
- package/dist/src/modules/connect/connect.repository.d.ts +0 -413
- package/dist/src/modules/connect/connect.repository.js +0 -54
- package/dist/src/modules/connect/connect.router.d.ts +0 -4
- package/dist/src/modules/connect/connect.router.js +0 -54
- package/dist/src/modules/connect/connect.service.d.ts +0 -88
- package/dist/src/modules/connect/connect.service.js +0 -114
- package/dist/src/modules/connect/connect.trpc.d.ts +0 -44
- package/dist/src/modules/connect/connect.trpc.js +0 -21
- package/dist/src/modules/connect/connect.types.d.ts +0 -25
- package/dist/src/modules/connect/connect.types.js +0 -2
- package/dist/src/modules/crypto/crypto.db.d.ts +0 -151
- package/dist/src/modules/crypto/crypto.db.js +0 -17
- package/dist/src/modules/crypto/crypto.repository.d.ts +0 -159
- package/dist/src/modules/crypto/crypto.repository.js +0 -10
- package/dist/src/modules/crypto/crypto.service.d.ts +0 -10
- package/dist/src/modules/crypto/crypto.service.js +0 -52
- package/dist/src/modules/email/email.service.d.ts +0 -56
- package/dist/src/modules/email/email.service.js +0 -106
- package/dist/src/modules/file/file.repository.d.ts +0 -12
- package/dist/src/modules/file/file.repository.js +0 -79
- package/dist/src/modules/file/file.router.js +0 -99
- package/dist/src/modules/file/file.service.d.ts +0 -24
- package/dist/src/modules/file/file.service.js +0 -150
- package/dist/src/modules/recurrence/recurrence.db.d.ts +0 -562
- package/dist/src/modules/recurrence/recurrence.db.js +0 -66
- package/dist/src/modules/recurrence/recurrence.repository.d.ts +0 -584
- package/dist/src/modules/recurrence/recurrence.repository.js +0 -39
- package/dist/src/modules/recurrence/recurrence.service.d.ts +0 -50
- package/dist/src/modules/recurrence/recurrence.service.js +0 -69
- package/dist/src/modules/recurrence/recurrence.trpc.d.ts +0 -206
- package/dist/src/modules/recurrence/recurrence.trpc.js +0 -65
- package/dist/src/modules/social/social.dto.d.ts +0 -34
- package/dist/src/modules/social/social.dto.js +0 -18
- package/dist/src/modules/social/social.linkedin.js +0 -427
- package/dist/src/modules/social/social.linkedin.test.js +0 -235
- package/dist/src/modules/social/social.service.d.ts +0 -28
- package/dist/src/modules/social/social.service.js +0 -76
- package/dist/src/modules/social/social.types.d.ts +0 -35
- package/dist/src/modules/social/social.types.js +0 -2
- package/dist/src/modules/tag/tag.db.d.ts +0 -346
- package/dist/src/modules/tag/tag.db.js +0 -42
- package/dist/src/modules/tag/tag.dto.d.ts +0 -1018
- package/dist/src/modules/tag/tag.dto.js +0 -9
- package/dist/src/modules/tag/tag.repository.d.ts +0 -383
- package/dist/src/modules/tag/tag.repository.js +0 -156
- package/dist/src/modules/tag/tag.service.d.ts +0 -109
- package/dist/src/modules/tag/tag.service.js +0 -42
- package/dist/src/modules/tag/tag.trpc.d.ts +0 -164
- package/dist/src/modules/tag/tag.trpc.js +0 -53
- package/dist/src/modules/utils/applyPagination.js +0 -16
- package/dist/src/modules/utils/applySorting.d.ts +0 -8
- package/dist/src/modules/utils/applySorting.js +0 -18
- package/dist/src/modules/utils/getConditionsFromFilters.d.ts +0 -4
- package/dist/src/modules/utils/getConditionsFromFilters.js +0 -200
- package/dist/src/modules/video/video.service.d.ts +0 -7
- package/dist/src/modules/video/video.service.js +0 -84
- package/dist/src/modules/webhook/webhook.constants.d.ts +0 -8
- package/dist/src/modules/webhook/webhook.constants.js +0 -10
- package/dist/src/modules/webhook/webhook.db.d.ts +0 -136
- package/dist/src/modules/webhook/webhook.db.js +0 -17
- package/dist/src/modules/webhook/webhook.dto.d.ts +0 -394
- package/dist/src/modules/webhook/webhook.dto.js +0 -7
- package/dist/src/modules/webhook/webhook.repository.d.ts +0 -148
- package/dist/src/modules/webhook/webhook.repository.js +0 -56
- package/dist/src/modules/webhook/webhook.router.d.ts +0 -3
- package/dist/src/modules/webhook/webhook.router.js +0 -30
- package/dist/src/modules/webhook/webhook.service.d.ts +0 -9
- package/dist/src/modules/webhook/webhook.service.js +0 -68
- package/dist/src/modules/workflow/workflow.db.d.ts +0 -296
- package/dist/src/modules/workflow/workflow.db.js +0 -30
- package/dist/src/modules/workflow/workflow.repository.d.ts +0 -343
- package/dist/src/modules/workflow/workflow.repository.js +0 -105
- package/dist/src/modules/workflow/workflow.service.d.ts +0 -21
- package/dist/src/modules/workflow/workflow.service.js +0 -37
- package/dist/src/modules/workflow/workflow.trpc.d.ts +0 -56
- package/dist/src/modules/workflow/workflow.trpc.js +0 -21
- package/dist/src/modules/workflow/workflow.types.d.ts +0 -20
- package/dist/src/modules/workflow/workflow.types.js +0 -2
- package/dist/src/modules/workflow/workflow.utils.d.ts +0 -21
- package/dist/src/modules/workflow/workflow.utils.js +0 -173
- package/dist/src/test/stubs/utils.d.ts +0 -2
- package/dist/src/test/stubs/utils.js +0 -5
- package/dist/src/trpc/context.d.ts +0 -41
- package/dist/src/trpc/context.js +0 -17
- package/dist/src/trpc/index.d.ts +0 -3
- package/dist/src/trpc/index.js +0 -6
- package/dist/src/trpc/procedures.d.ts +0 -233
- package/dist/src/trpc/procedures.js +0 -32
- package/dist/src/trpc/utils.d.ts +0 -4
- package/dist/src/trpc/utils.js +0 -20
- package/dist/src/types.d.ts +0 -358
- package/dist/src/types.js +0 -12
- package/dist/src/utils/errors.d.ts +0 -49
- package/dist/src/utils/errors.js +0 -104
- package/dist/src/utils/logger.d.ts +0 -1
- package/dist/src/utils/logger.js +0 -11
- package/dist/src/utils/posthog.d.ts +0 -13
- package/dist/src/utils/posthog.js +0 -31
- package/dist/src/utils/trpc.d.ts +0 -58
- package/dist/src/utils/trpc.js +0 -63
- package/dist/src/utils/types.d.ts +0 -4
- package/dist/src/utils/types.js +0 -2
- package/dist/tsconfig.tsbuildinfo +0 -1
- /package/dist/src/{lib/sentry.d.ts → modules/ai/ai.router.mjs} +0 -0
- /package/dist/src/modules/{access/access.test.d.ts → base/base.types.mjs} +0 -0
- /package/dist/src/modules/{ai/ai.router.d.ts → connect/connect.types.mjs} +0 -0
- /package/dist/src/modules/{base/base.grants.test.d.ts → social/social.types.mjs} +0 -0
- /package/dist/src/modules/{base/base.service.test.d.ts → workflow/workflow.types.mjs} +0 -0
- /package/dist/src/{modules/social/social.linkedin.test.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":"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"}
|
|
@@ -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
|