@m5kdev/backend 0.8.7 → 0.8.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_virtual/_rolldown/runtime.cjs +33 -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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +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.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter-base.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect-adapter.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/dialect.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-adapter.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-dialect.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mssql/mssql-introspector.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-adapter.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-dialect.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/mysql/mysql-introspector.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-adapter.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-dialect.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/postgres/postgres-introspector.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-adapter.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-dialect.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/dialect/sqlite/sqlite-introspector.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/expression/expression-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/index.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/kysely.d.cts +38 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/file-migration-provider.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/migration/migrator.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/binary-operation-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/delete-from-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/expression-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/group-by-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/insert-values-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/join-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/merge-into-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/reference-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/returning-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-from-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/select-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/set-operation-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/tuple-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/unary-operation-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/update-set-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/value-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/parser/with-parser.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/case-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/delete-query-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/having-interface.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/insert-query-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/join-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/merge-query-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/on-conflict-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/output-interface.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/returning-interface.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/select-query-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/update-query-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-builder/where-interface.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-creator.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/default-query-executor.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/noop-query-executor.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-base.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor-provider.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/query-executor/query-executor.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/raw-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/raw-builder/sql.d.cts +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.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-add-index-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-drop-constraint-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/alter-table-executor.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-index-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-schema-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-table-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-type-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/create-view-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-index-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-schema-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-table-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-type-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/drop-view-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/refresh-materialized-view-builder.d.cts +1 -0
- package/dist/node_modules/.pnpm/kysely@0.28.5/node_modules/kysely/dist/esm/schema/schema.d.cts +1 -0
- package/dist/src/lib/posthog.cjs +8 -0
- package/dist/src/lib/posthog.cjs.map +1 -0
- package/dist/src/lib/posthog.d.cts +7 -0
- package/dist/src/lib/sentry.cjs +11 -0
- package/dist/src/lib/sentry.cjs.map +1 -0
- package/dist/src/lib/sentry.d.cts +1 -0
- package/dist/src/modules/access/access.repository.cjs +26 -0
- package/dist/src/modules/access/access.repository.cjs.map +1 -0
- package/dist/src/modules/access/access.repository.d.cts +2352 -0
- package/dist/src/modules/access/access.service.cjs +42 -0
- package/dist/src/modules/access/access.service.cjs.map +1 -0
- package/dist/src/modules/access/access.service.d.cts +25 -0
- package/dist/src/modules/access/access.utils.cjs +23 -0
- package/dist/src/modules/access/access.utils.cjs.map +1 -0
- package/dist/src/modules/access/access.utils.d.cts +19 -0
- package/dist/src/modules/ai/ai.db.cjs +46 -0
- package/dist/src/modules/ai/ai.db.cjs.map +1 -0
- package/dist/src/modules/ai/ai.db.d.cts +401 -0
- package/dist/src/modules/ai/ai.prompt.cjs +33 -0
- package/dist/src/modules/ai/ai.prompt.cjs.map +1 -0
- package/dist/src/modules/ai/ai.prompt.d.cts +30 -0
- package/dist/src/modules/ai/ai.prompts.cjs +18 -0
- package/dist/src/modules/ai/ai.prompts.cjs.map +1 -0
- package/dist/src/modules/ai/ai.prompts.d.cts +10 -0
- package/dist/src/modules/ai/ai.repository.cjs +25 -0
- package/dist/src/modules/ai/ai.repository.cjs.map +1 -0
- package/dist/src/modules/ai/ai.repository.d.cts +428 -0
- package/dist/src/modules/ai/ai.router.cjs +0 -0
- package/dist/src/modules/ai/ai.router.d.cts +1 -0
- package/dist/src/modules/ai/ai.service.cjs +312 -0
- package/dist/src/modules/ai/ai.service.cjs.map +1 -0
- package/dist/src/modules/ai/ai.service.d.cts +141 -0
- package/dist/src/modules/ai/ai.trpc.cjs +19 -0
- package/dist/src/modules/ai/ai.trpc.cjs.map +1 -0
- package/dist/src/modules/ai/ai.trpc.d.cts +31 -0
- package/dist/src/modules/ai/ideogram/ideogram.constants.cjs +191 -0
- package/dist/src/modules/ai/ideogram/ideogram.constants.cjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.constants.d.cts +11 -0
- package/dist/src/modules/ai/ideogram/ideogram.dto.cjs +49 -0
- package/dist/src/modules/ai/ideogram/ideogram.dto.cjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.dto.d.cts +234 -0
- package/dist/src/modules/ai/ideogram/ideogram.prompt.cjs +862 -0
- package/dist/src/modules/ai/ideogram/ideogram.prompt.cjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.prompt.d.cts +7 -0
- package/dist/src/modules/ai/ideogram/ideogram.repository.cjs +34 -0
- package/dist/src/modules/ai/ideogram/ideogram.repository.cjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.repository.d.cts +11 -0
- package/dist/src/modules/ai/ideogram/ideogram.service.cjs +12 -0
- package/dist/src/modules/ai/ideogram/ideogram.service.cjs.map +1 -0
- package/dist/src/modules/ai/ideogram/ideogram.service.d.cts +14 -0
- package/dist/src/modules/auth/auth.db.cjs +187 -0
- package/dist/src/modules/auth/auth.db.cjs.map +1 -0
- package/dist/src/modules/auth/auth.db.d.cts +2341 -0
- package/dist/src/modules/auth/auth.dto.cjs +50 -0
- package/dist/src/modules/auth/auth.dto.cjs.map +1 -0
- package/dist/src/modules/auth/auth.dto.d.cts +70 -0
- package/dist/src/modules/auth/auth.dto.d.mts +2 -2
- package/dist/src/modules/auth/auth.lib.cjs +234 -0
- package/dist/src/modules/auth/auth.lib.cjs.map +1 -0
- package/dist/src/modules/auth/auth.lib.d.cts +4894 -0
- package/dist/src/modules/auth/auth.lib.d.mts +1 -1
- package/dist/src/modules/auth/auth.middleware.cjs +41 -0
- package/dist/src/modules/auth/auth.middleware.cjs.map +1 -0
- package/dist/src/modules/auth/auth.middleware.d.cts +619 -0
- package/dist/src/modules/auth/auth.repository.cjs +403 -0
- package/dist/src/modules/auth/auth.repository.cjs.map +1 -0
- package/dist/src/modules/auth/auth.repository.d.cts +2453 -0
- package/dist/src/modules/auth/auth.service.cjs +229 -0
- package/dist/src/modules/auth/auth.service.cjs.map +1 -0
- package/dist/src/modules/auth/auth.service.d.cts +105 -0
- package/dist/src/modules/auth/auth.trpc.cjs +110 -0
- package/dist/src/modules/auth/auth.trpc.cjs.map +1 -0
- package/dist/src/modules/auth/auth.trpc.d.cts +303 -0
- package/dist/src/modules/auth/auth.trpc.d.mts +6 -6
- package/dist/src/modules/auth/auth.utils.cjs +80 -0
- package/dist/src/modules/auth/auth.utils.cjs.map +1 -0
- package/dist/src/modules/auth/auth.utils.d.cts +2356 -0
- package/dist/src/modules/base/base.abstract.cjs +62 -0
- package/dist/src/modules/base/base.abstract.cjs.map +1 -0
- package/dist/src/modules/base/base.abstract.d.cts +29 -0
- package/dist/src/modules/base/base.actor.cjs +83 -0
- package/dist/src/modules/base/base.actor.cjs.map +1 -0
- package/dist/src/modules/base/base.actor.d.cts +73 -0
- package/dist/src/modules/base/base.dto.cjs +98 -0
- package/dist/src/modules/base/base.dto.cjs.map +1 -0
- package/dist/src/modules/base/base.dto.d.cts +67 -0
- package/dist/src/modules/base/base.grants.cjs +107 -0
- package/dist/src/modules/base/base.grants.cjs.map +1 -0
- package/dist/src/modules/base/base.grants.d.cts +28 -0
- package/dist/src/modules/base/base.procedure.cjs +255 -0
- package/dist/src/modules/base/base.procedure.cjs.map +1 -0
- package/dist/src/modules/base/base.procedure.d.cts +111 -0
- package/dist/src/modules/base/base.repository.cjs +269 -0
- package/dist/src/modules/base/base.repository.cjs.map +1 -0
- package/dist/src/modules/base/base.repository.d.cts +125 -0
- package/dist/src/modules/base/base.repository.d.mts +2 -0
- package/dist/src/modules/base/base.repository.mjs +12 -0
- package/dist/src/modules/base/base.repository.mjs.map +1 -1
- package/dist/src/modules/base/base.service.cjs +119 -0
- package/dist/src/modules/base/base.service.cjs.map +1 -0
- package/dist/src/modules/base/base.service.d.cts +44 -0
- package/dist/src/modules/base/base.types.cjs +0 -0
- package/dist/src/modules/base/base.types.d.cts +5 -0
- package/dist/src/modules/billing/billing.db.cjs +38 -0
- package/dist/src/modules/billing/billing.db.cjs.map +1 -0
- package/dist/src/modules/billing/billing.db.d.cts +371 -0
- package/dist/src/modules/billing/billing.repository.cjs +190 -0
- package/dist/src/modules/billing/billing.repository.cjs.map +1 -0
- package/dist/src/modules/billing/billing.repository.d.cts +2787 -0
- package/dist/src/modules/billing/billing.router.cjs +43 -0
- package/dist/src/modules/billing/billing.router.cjs.map +1 -0
- package/dist/src/modules/billing/billing.router.d.cts +9 -0
- package/dist/src/modules/billing/billing.service.cjs +127 -0
- package/dist/src/modules/billing/billing.service.cjs.map +1 -0
- package/dist/src/modules/billing/billing.service.d.cts +53 -0
- package/dist/src/modules/billing/billing.trpc.cjs +19 -0
- package/dist/src/modules/billing/billing.trpc.cjs.map +1 -0
- package/dist/src/modules/billing/billing.trpc.d.cts +48 -0
- package/dist/src/modules/clay/clay.repository.cjs +29 -0
- package/dist/src/modules/clay/clay.repository.cjs.map +1 -0
- package/dist/src/modules/clay/clay.repository.d.cts +10 -0
- package/dist/src/modules/clay/clay.service.cjs +24 -0
- package/dist/src/modules/clay/clay.service.cjs.map +1 -0
- package/dist/src/modules/clay/clay.service.d.cts +32 -0
- package/dist/src/modules/connect/connect.db.cjs +37 -0
- package/dist/src/modules/connect/connect.db.cjs.map +1 -0
- package/dist/src/modules/connect/connect.db.d.cts +362 -0
- package/dist/src/modules/connect/connect.dto.cjs +45 -0
- package/dist/src/modules/connect/connect.dto.cjs.map +1 -0
- package/dist/src/modules/connect/connect.dto.d.cts +79 -0
- package/dist/src/modules/connect/connect.dto.d.mts +2 -2
- package/dist/src/modules/connect/connect.linkedin.cjs +48 -0
- package/dist/src/modules/connect/connect.linkedin.cjs.map +1 -0
- package/dist/src/modules/connect/connect.linkedin.d.cts +7 -0
- package/dist/src/modules/connect/connect.oauth.cjs +153 -0
- package/dist/src/modules/connect/connect.oauth.cjs.map +1 -0
- package/dist/src/modules/connect/connect.oauth.d.cts +32 -0
- package/dist/src/modules/connect/connect.repository.cjs +42 -0
- package/dist/src/modules/connect/connect.repository.cjs.map +1 -0
- package/dist/src/modules/connect/connect.repository.d.cts +419 -0
- package/dist/src/modules/connect/connect.repository.d.mts +1 -1
- package/dist/src/modules/connect/connect.router.cjs +48 -0
- package/dist/src/modules/connect/connect.router.cjs.map +1 -0
- package/dist/src/modules/connect/connect.router.d.cts +9 -0
- package/dist/src/modules/connect/connect.service.cjs +90 -0
- package/dist/src/modules/connect/connect.service.cjs.map +1 -0
- package/dist/src/modules/connect/connect.service.d.cts +103 -0
- package/dist/src/modules/connect/connect.service.d.mts +2 -2
- package/dist/src/modules/connect/connect.trpc.cjs +18 -0
- package/dist/src/modules/connect/connect.trpc.cjs.map +1 -0
- package/dist/src/modules/connect/connect.trpc.d.cts +53 -0
- package/dist/src/modules/connect/connect.types.cjs +0 -0
- package/dist/src/modules/connect/connect.types.d.cts +29 -0
- package/dist/src/modules/crypto/crypto.db.cjs +26 -0
- package/dist/src/modules/crypto/crypto.db.cjs.map +1 -0
- package/dist/src/modules/crypto/crypto.db.d.cts +157 -0
- package/dist/src/modules/crypto/crypto.repository.cjs +9 -0
- package/dist/src/modules/crypto/crypto.repository.cjs.map +1 -0
- package/dist/src/modules/crypto/crypto.repository.d.cts +163 -0
- package/dist/src/modules/crypto/crypto.service.cjs +46 -0
- package/dist/src/modules/crypto/crypto.service.cjs.map +1 -0
- package/dist/src/modules/crypto/crypto.service.d.cts +15 -0
- package/dist/src/modules/email/email.service.cjs +107 -0
- package/dist/src/modules/email/email.service.cjs.map +1 -0
- package/dist/src/modules/email/email.service.d.cts +62 -0
- package/dist/src/modules/file/file.repository.cjs +74 -0
- package/dist/src/modules/file/file.repository.cjs.map +1 -0
- package/dist/src/modules/file/file.repository.d.cts +17 -0
- package/dist/src/modules/file/file.router.cjs +94 -0
- package/dist/src/modules/file/file.router.cjs.map +1 -0
- package/dist/src/modules/file/file.router.d.cts +7 -0
- package/dist/src/modules/file/file.service.cjs +120 -0
- package/dist/src/modules/file/file.service.cjs.map +1 -0
- package/dist/src/modules/file/file.service.d.cts +30 -0
- package/dist/src/modules/recurrence/recurrence.db.cjs +55 -0
- package/dist/src/modules/recurrence/recurrence.db.cjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.db.d.cts +568 -0
- package/dist/src/modules/recurrence/recurrence.repository.cjs +31 -0
- package/dist/src/modules/recurrence/recurrence.repository.cjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.repository.d.cts +588 -0
- package/dist/src/modules/recurrence/recurrence.service.cjs +66 -0
- package/dist/src/modules/recurrence/recurrence.service.cjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.service.d.cts +88 -0
- package/dist/src/modules/recurrence/recurrence.service.d.mts +3 -2
- package/dist/src/modules/recurrence/recurrence.service.mjs +1 -1
- package/dist/src/modules/recurrence/recurrence.service.mjs.map +1 -1
- package/dist/src/modules/recurrence/recurrence.trpc.cjs +46 -0
- package/dist/src/modules/recurrence/recurrence.trpc.cjs.map +1 -0
- package/dist/src/modules/recurrence/recurrence.trpc.d.cts +216 -0
- package/dist/src/modules/recurrence/recurrence.trpc.d.mts +1 -0
- package/dist/src/modules/social/social.dto.cjs +26 -0
- package/dist/src/modules/social/social.dto.cjs.map +1 -0
- package/dist/src/modules/social/social.dto.d.cts +39 -0
- package/dist/src/modules/social/social.linkedin.cjs +349 -0
- package/dist/src/modules/social/social.linkedin.cjs.map +1 -0
- package/dist/src/modules/social/social.linkedin.d.cts +15 -0
- package/dist/src/modules/social/social.service.cjs +57 -0
- package/dist/src/modules/social/social.service.cjs.map +1 -0
- package/dist/src/modules/social/social.service.d.cts +34 -0
- package/dist/src/modules/social/social.types.cjs +0 -0
- package/dist/src/modules/social/social.types.d.cts +40 -0
- package/dist/src/modules/tag/tag.db.cjs +43 -0
- package/dist/src/modules/tag/tag.db.cjs.map +1 -0
- package/dist/src/modules/tag/tag.db.d.cts +352 -0
- package/dist/src/modules/tag/tag.dto.cjs +15 -0
- package/dist/src/modules/tag/tag.dto.cjs.map +1 -0
- package/dist/src/modules/tag/tag.dto.d.cts +1025 -0
- package/dist/src/modules/tag/tag.repository.cjs +116 -0
- package/dist/src/modules/tag/tag.repository.cjs.map +1 -0
- package/dist/src/modules/tag/tag.repository.d.cts +394 -0
- package/dist/src/modules/tag/tag.service.cjs +48 -0
- package/dist/src/modules/tag/tag.service.cjs.map +1 -0
- package/dist/src/modules/tag/tag.service.d.cts +120 -0
- package/dist/src/modules/tag/tag.trpc.cjs +32 -0
- package/dist/src/modules/tag/tag.trpc.cjs.map +1 -0
- package/dist/src/modules/tag/tag.trpc.d.cts +174 -0
- package/dist/src/modules/tag/tag.trpc.d.mts +1 -0
- package/dist/src/modules/utils/applyPagination.cjs +16 -0
- package/dist/src/modules/utils/applyPagination.cjs.map +1 -0
- package/dist/src/modules/utils/applyPagination.d.cts +10 -0
- package/dist/src/modules/utils/applySorting.cjs +20 -0
- package/dist/src/modules/utils/applySorting.cjs.map +1 -0
- package/dist/src/modules/utils/applySorting.d.cts +13 -0
- package/dist/src/modules/utils/getConditionsFromFilters.cjs +152 -0
- package/dist/src/modules/utils/getConditionsFromFilters.cjs.map +1 -0
- package/dist/src/modules/utils/getConditionsFromFilters.d.cts +9 -0
- package/dist/src/modules/utils/getGlobalSearchCondition.cjs +30 -0
- package/dist/src/modules/utils/getGlobalSearchCondition.cjs.map +1 -0
- package/dist/src/modules/utils/getGlobalSearchCondition.d.cts +18 -0
- package/dist/src/modules/utils/getGlobalSearchCondition.d.mts +18 -0
- package/dist/src/modules/utils/getGlobalSearchCondition.mjs +26 -0
- package/dist/src/modules/utils/getGlobalSearchCondition.mjs.map +1 -0
- package/dist/src/modules/video/video.service.cjs +114 -0
- package/dist/src/modules/video/video.service.cjs.map +1 -0
- package/dist/src/modules/video/video.service.d.cts +12 -0
- package/dist/src/modules/video/video.service.mjs.map +1 -1
- package/dist/src/modules/webhook/webhook.constants.cjs +13 -0
- package/dist/src/modules/webhook/webhook.constants.cjs.map +1 -0
- package/dist/src/modules/webhook/webhook.constants.d.cts +12 -0
- package/dist/src/modules/webhook/webhook.db.cjs +19 -0
- package/dist/src/modules/webhook/webhook.db.cjs.map +1 -0
- package/dist/src/modules/webhook/webhook.db.d.cts +142 -0
- package/dist/src/modules/webhook/webhook.dto.cjs +11 -0
- package/dist/src/modules/webhook/webhook.dto.cjs.map +1 -0
- package/dist/src/modules/webhook/webhook.dto.d.cts +402 -0
- package/dist/src/modules/webhook/webhook.repository.cjs +52 -0
- package/dist/src/modules/webhook/webhook.repository.cjs.map +1 -0
- package/dist/src/modules/webhook/webhook.repository.d.cts +154 -0
- package/dist/src/modules/webhook/webhook.router.cjs +26 -0
- package/dist/src/modules/webhook/webhook.router.cjs.map +1 -0
- package/dist/src/modules/webhook/webhook.router.d.cts +8 -0
- package/dist/src/modules/webhook/webhook.service.cjs +61 -0
- package/dist/src/modules/webhook/webhook.service.cjs.map +1 -0
- package/dist/src/modules/webhook/webhook.service.d.cts +14 -0
- package/dist/src/modules/workflow/workflow.db.cjs +35 -0
- package/dist/src/modules/workflow/workflow.db.cjs.map +1 -0
- package/dist/src/modules/workflow/workflow.db.d.cts +302 -0
- package/dist/src/modules/workflow/workflow.repository.cjs +95 -0
- package/dist/src/modules/workflow/workflow.repository.cjs.map +1 -0
- package/dist/src/modules/workflow/workflow.repository.d.cts +371 -0
- package/dist/src/modules/workflow/workflow.service.cjs +41 -0
- package/dist/src/modules/workflow/workflow.service.cjs.map +1 -0
- package/dist/src/modules/workflow/workflow.service.d.cts +68 -0
- package/dist/src/modules/workflow/workflow.trpc.cjs +19 -0
- package/dist/src/modules/workflow/workflow.trpc.cjs.map +1 -0
- package/dist/src/modules/workflow/workflow.trpc.d.cts +65 -0
- package/dist/src/modules/workflow/workflow.types.cjs +0 -0
- package/dist/src/modules/workflow/workflow.types.d.cts +25 -0
- package/dist/src/modules/workflow/workflow.utils.cjs +185 -0
- package/dist/src/modules/workflow/workflow.utils.cjs.map +1 -0
- package/dist/src/modules/workflow/workflow.utils.d.cts +36 -0
- package/dist/src/types.cjs +12 -0
- package/dist/src/types.cjs.map +1 -0
- package/dist/src/types.d.cts +344 -0
- package/dist/src/utils/errors.cjs +101 -0
- package/dist/src/utils/errors.cjs.map +1 -0
- package/dist/src/utils/errors.d.cts +62 -0
- package/dist/src/utils/logger.cjs +13 -0
- package/dist/src/utils/logger.cjs.map +1 -0
- package/dist/src/utils/logger.d.cts +7 -0
- package/dist/src/utils/posthog.cjs +31 -0
- package/dist/src/utils/posthog.cjs.map +1 -0
- package/dist/src/utils/posthog.d.cts +17 -0
- package/dist/src/utils/trpc.cjs +156 -0
- package/dist/src/utils/trpc.cjs.map +1 -0
- package/dist/src/utils/trpc.d.cts +54 -0
- package/dist/src/utils/types.cjs +0 -0
- package/dist/src/utils/types.d.cts +9 -0
- package/package.json +171 -45
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
require("../../../_virtual/_rolldown/runtime.cjs");
|
|
3
|
+
const require_src_utils_errors = require("../../utils/errors.cjs");
|
|
4
|
+
const require_src_modules_base_base_actor = require("../base/base.actor.cjs");
|
|
5
|
+
const require_src_utils_posthog = require("../../utils/posthog.cjs");
|
|
6
|
+
const require_src_modules_base_base_service = require("../base/base.service.cjs");
|
|
7
|
+
let neverthrow = require("neverthrow");
|
|
8
|
+
//#region src/modules/auth/auth.service.ts
|
|
9
|
+
var AuthService = class extends require_src_modules_base_base_service.BaseService {
|
|
10
|
+
getBillingService() {
|
|
11
|
+
if (!("billing" in this.service)) return null;
|
|
12
|
+
return this.service.billing;
|
|
13
|
+
}
|
|
14
|
+
organizationActorFromCtx(ctx) {
|
|
15
|
+
try {
|
|
16
|
+
return (0, neverthrow.ok)(require_src_modules_base_base_actor.createActorFromContext({
|
|
17
|
+
user: ctx.user,
|
|
18
|
+
session: ctx.session
|
|
19
|
+
}, "organization"));
|
|
20
|
+
} catch (e) {
|
|
21
|
+
if (e instanceof require_src_utils_errors.ServerError) return (0, neverthrow.err)(e);
|
|
22
|
+
throw e;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
async getUserWaitlistCount(ctx) {
|
|
26
|
+
if (ctx.actor.userRole === "admin") return (0, neverthrow.ok)(0);
|
|
27
|
+
return this.repository.auth.getUserWaitlistCount(ctx.actor.userId);
|
|
28
|
+
}
|
|
29
|
+
async getOnboarding(ctx) {
|
|
30
|
+
return this.repository.auth.getOnboarding(ctx.actor.userId);
|
|
31
|
+
}
|
|
32
|
+
async setOnboarding(onboarding, ctx) {
|
|
33
|
+
require_src_utils_posthog.posthogCapture({
|
|
34
|
+
distinctId: ctx.actor.userId,
|
|
35
|
+
event: "onboarding_set",
|
|
36
|
+
properties: { onboarding }
|
|
37
|
+
});
|
|
38
|
+
return this.repository.auth.setOnboarding(ctx.actor.userId, onboarding);
|
|
39
|
+
}
|
|
40
|
+
async getPreferences(ctx) {
|
|
41
|
+
return this.repository.auth.getPreferences(ctx.actor.userId);
|
|
42
|
+
}
|
|
43
|
+
async setPreferences(preferences, ctx) {
|
|
44
|
+
require_src_utils_posthog.posthogCapture({
|
|
45
|
+
distinctId: ctx.actor.userId,
|
|
46
|
+
event: "preferences_set"
|
|
47
|
+
});
|
|
48
|
+
return this.repository.auth.setPreferences(ctx.actor.userId, preferences);
|
|
49
|
+
}
|
|
50
|
+
async getOrganizationPreferences(ctx) {
|
|
51
|
+
const org = this.organizationActorFromCtx(ctx);
|
|
52
|
+
if (org.isErr()) return (0, neverthrow.err)(org.error);
|
|
53
|
+
const actor = org.value;
|
|
54
|
+
return this.repository.auth.getOrganizationPreferences(actor.userId, actor.organizationId);
|
|
55
|
+
}
|
|
56
|
+
async setOrganizationPreferences(preferences, ctx) {
|
|
57
|
+
const org = this.organizationActorFromCtx(ctx);
|
|
58
|
+
if (org.isErr()) return (0, neverthrow.err)(org.error);
|
|
59
|
+
const actor = org.value;
|
|
60
|
+
require_src_utils_posthog.posthogCapture({
|
|
61
|
+
distinctId: actor.userId,
|
|
62
|
+
event: "organization_preferences_set",
|
|
63
|
+
properties: { organizationId: actor.organizationId }
|
|
64
|
+
});
|
|
65
|
+
return this.repository.auth.setOrganizationPreferences(actor.userId, actor.organizationId, preferences);
|
|
66
|
+
}
|
|
67
|
+
async getMetadata(ctx) {
|
|
68
|
+
return this.repository.auth.getMetadata(ctx.actor.userId);
|
|
69
|
+
}
|
|
70
|
+
async setMetadata(metadata, ctx) {
|
|
71
|
+
require_src_utils_posthog.posthogCapture({
|
|
72
|
+
distinctId: ctx.actor.userId,
|
|
73
|
+
event: "metadata_set"
|
|
74
|
+
});
|
|
75
|
+
return this.repository.auth.setMetadata(ctx.actor.userId, metadata);
|
|
76
|
+
}
|
|
77
|
+
async getFlags(ctx) {
|
|
78
|
+
return this.repository.auth.getFlags(ctx.actor.userId);
|
|
79
|
+
}
|
|
80
|
+
async getOrganizationFlags(ctx) {
|
|
81
|
+
const org = this.organizationActorFromCtx(ctx);
|
|
82
|
+
if (org.isErr()) return (0, neverthrow.err)(org.error);
|
|
83
|
+
const actor = org.value;
|
|
84
|
+
return this.repository.auth.getOrganizationFlags(actor.userId, actor.organizationId);
|
|
85
|
+
}
|
|
86
|
+
async setFlags(flags, ctx) {
|
|
87
|
+
require_src_utils_posthog.posthogCapture({
|
|
88
|
+
distinctId: ctx.actor.userId,
|
|
89
|
+
event: "flags_set"
|
|
90
|
+
});
|
|
91
|
+
return this.repository.auth.setFlags(ctx.actor.userId, flags);
|
|
92
|
+
}
|
|
93
|
+
async setOrganizationFlags(flags, ctx) {
|
|
94
|
+
const org = this.organizationActorFromCtx(ctx);
|
|
95
|
+
if (org.isErr()) return (0, neverthrow.err)(org.error);
|
|
96
|
+
const actor = org.value;
|
|
97
|
+
require_src_utils_posthog.posthogCapture({
|
|
98
|
+
distinctId: actor.userId,
|
|
99
|
+
event: "organization_flags_set",
|
|
100
|
+
properties: { organizationId: actor.organizationId }
|
|
101
|
+
});
|
|
102
|
+
return this.repository.auth.setOrganizationFlags(actor.userId, actor.organizationId, flags);
|
|
103
|
+
}
|
|
104
|
+
async listAdminWaitlist() {
|
|
105
|
+
return this.repository.auth.listAdminWaitlist();
|
|
106
|
+
}
|
|
107
|
+
async listWaitlist(ctx) {
|
|
108
|
+
return this.repository.auth.listWaitlist(ctx.actor.userId);
|
|
109
|
+
}
|
|
110
|
+
async addToWaitlist({ email }) {
|
|
111
|
+
return this.repository.auth.addToWaitlist(email);
|
|
112
|
+
}
|
|
113
|
+
async inviteFromWaitlist({ id }) {
|
|
114
|
+
const waitlist = await this.repository.auth.inviteFromWaitlist(id);
|
|
115
|
+
if (waitlist.isErr()) return (0, neverthrow.err)(waitlist.error);
|
|
116
|
+
if (!waitlist.value.code) return this.repository.auth.error("BAD_REQUEST");
|
|
117
|
+
if (!waitlist.value.email) return this.repository.auth.error("BAD_REQUEST");
|
|
118
|
+
await this.service.email.sendWaitlistInvite(waitlist.value.email, waitlist.value.code);
|
|
119
|
+
return (0, neverthrow.ok)(waitlist.value);
|
|
120
|
+
}
|
|
121
|
+
async inviteToWaitlist({ email, name }, ctx) {
|
|
122
|
+
const count = await this.repository.auth.getUserWaitlistCount(ctx.user.id);
|
|
123
|
+
if (count.isErr()) return (0, neverthrow.err)(count.error);
|
|
124
|
+
if (count.value >= 3) return this.repository.auth.error("BAD_REQUEST", "Run out of invites");
|
|
125
|
+
const waitlist = await this.repository.auth.inviteToWaitlist({
|
|
126
|
+
email,
|
|
127
|
+
userId: ctx.user.id,
|
|
128
|
+
name
|
|
129
|
+
});
|
|
130
|
+
if (waitlist.isErr()) return (0, neverthrow.err)(waitlist.error);
|
|
131
|
+
if (!waitlist.value.code) return this.repository.auth.error("BAD_REQUEST");
|
|
132
|
+
await this.service.email.sendWaitlistUserInvite(email, waitlist.value.code, ctx.user.name, name);
|
|
133
|
+
require_src_utils_posthog.posthogCapture({
|
|
134
|
+
distinctId: ctx.user.id,
|
|
135
|
+
event: "waitlist_invite_sent",
|
|
136
|
+
properties: {
|
|
137
|
+
email,
|
|
138
|
+
name
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
return (0, neverthrow.ok)(waitlist.value);
|
|
142
|
+
}
|
|
143
|
+
async createInvitationCode({ name }, ctx) {
|
|
144
|
+
require_src_utils_posthog.posthogCapture({
|
|
145
|
+
distinctId: ctx.actor.userId,
|
|
146
|
+
event: "waitlist_invitation_code_created",
|
|
147
|
+
properties: { name }
|
|
148
|
+
});
|
|
149
|
+
return this.repository.auth.createInvitationCode({
|
|
150
|
+
userId: ctx.actor.userId,
|
|
151
|
+
name
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
async joinWaitlist({ email }) {
|
|
155
|
+
const waitlist = await this.repository.auth.joinWaitlist(email);
|
|
156
|
+
if (waitlist.isErr()) return (0, neverthrow.err)(waitlist.error);
|
|
157
|
+
await this.service.email.sendWaitlistConfirmation(email);
|
|
158
|
+
return (0, neverthrow.ok)(waitlist.value);
|
|
159
|
+
}
|
|
160
|
+
async removeFromWaitlist({ id }) {
|
|
161
|
+
return this.repository.auth.removeFromWaitlist(id);
|
|
162
|
+
}
|
|
163
|
+
async validateWaitlistCode(code) {
|
|
164
|
+
return this.repository.auth.validateWaitlistCode(code);
|
|
165
|
+
}
|
|
166
|
+
async createAccountClaimCode({ userId, expiresInHours }) {
|
|
167
|
+
return this.repository.auth.createAccountClaimCode({
|
|
168
|
+
userId,
|
|
169
|
+
expiresInHours
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
async listAccountClaims() {
|
|
173
|
+
return this.repository.auth.listAccountClaims();
|
|
174
|
+
}
|
|
175
|
+
async getMyAccountClaimStatus(ctx) {
|
|
176
|
+
return this.repository.auth.findPendingAccountClaimForUser(ctx.actor.userId);
|
|
177
|
+
}
|
|
178
|
+
async setMyAccountClaimEmail({ email }, ctx) {
|
|
179
|
+
return this.repository.auth.setAccountClaimEmail({
|
|
180
|
+
userId: ctx.actor.userId,
|
|
181
|
+
email
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
async acceptMyAccountClaim(ctx) {
|
|
185
|
+
const pendingClaim = await this.repository.auth.findPendingAccountClaimForUser(ctx.user.id);
|
|
186
|
+
if (pendingClaim.isErr()) return (0, neverthrow.err)(pendingClaim.error);
|
|
187
|
+
const accepted = await this.repository.auth.acceptAccountClaim(ctx.user.id);
|
|
188
|
+
if (accepted.isErr()) return (0, neverthrow.err)(accepted.error);
|
|
189
|
+
if (pendingClaim.value) {
|
|
190
|
+
const billingService = this.getBillingService();
|
|
191
|
+
if (billingService) await billingService.createUserHook({ user: ctx.user });
|
|
192
|
+
}
|
|
193
|
+
return (0, neverthrow.ok)(accepted.value);
|
|
194
|
+
}
|
|
195
|
+
async generateAccountClaimMagicLink({ claimId, email }) {
|
|
196
|
+
const claim = await this.repository.auth.findAccountClaimById(claimId);
|
|
197
|
+
if (claim.isErr()) return (0, neverthrow.err)(claim.error);
|
|
198
|
+
if (!claim.value) return this.repository.auth.error("NOT_FOUND", "Claim not found");
|
|
199
|
+
if (!claim.value.claimUserId) return this.repository.auth.error("BAD_REQUEST", "Claim has no user");
|
|
200
|
+
if (claim.value.status !== "INVITED") return this.repository.auth.error("BAD_REQUEST", "Claim is not pending");
|
|
201
|
+
if (claim.value.expiresAt && claim.value.expiresAt < /* @__PURE__ */ new Date()) return this.repository.auth.error("BAD_REQUEST", "Claim is expired");
|
|
202
|
+
const targetEmail = email ?? claim.value.claimedEmail ?? void 0;
|
|
203
|
+
if (!targetEmail) return this.repository.auth.error("BAD_REQUEST", "Email required to generate magic link");
|
|
204
|
+
const setEmail = await this.repository.auth.setAccountClaimEmail({
|
|
205
|
+
userId: claim.value.claimUserId,
|
|
206
|
+
email: targetEmail
|
|
207
|
+
});
|
|
208
|
+
if (setEmail.isErr()) return (0, neverthrow.err)(setEmail.error);
|
|
209
|
+
if (!(await fetch(`${process.env.VITE_SERVER_URL}/api/auth/sign-in/magic-link`, {
|
|
210
|
+
method: "POST",
|
|
211
|
+
headers: { "content-type": "application/json" },
|
|
212
|
+
body: JSON.stringify({
|
|
213
|
+
email: targetEmail.toLowerCase(),
|
|
214
|
+
callbackURL: `${process.env.VITE_APP_URL}/claim-account?claim=${claimId}`
|
|
215
|
+
})
|
|
216
|
+
})).ok) return this.repository.auth.error("INTERNAL_SERVER_ERROR", "Failed to generate magic link");
|
|
217
|
+
const latest = await this.repository.auth.latestAccountClaimMagicLink(claimId);
|
|
218
|
+
if (latest.isErr()) return (0, neverthrow.err)(latest.error);
|
|
219
|
+
if (!latest.value) return this.repository.auth.error("INTERNAL_SERVER_ERROR");
|
|
220
|
+
return (0, neverthrow.ok)(latest.value);
|
|
221
|
+
}
|
|
222
|
+
async listAccountClaimMagicLinks({ claimId }) {
|
|
223
|
+
return this.repository.auth.listAccountClaimMagicLinks(claimId);
|
|
224
|
+
}
|
|
225
|
+
};
|
|
226
|
+
//#endregion
|
|
227
|
+
exports.AuthService = AuthService;
|
|
228
|
+
|
|
229
|
+
//# sourceMappingURL=auth.service.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.service.cjs","names":["BaseService","createActorFromContext","ServerError"],"sources":["../../../../src/modules/auth/auth.service.ts"],"sourcesContent":["import { err, ok } from \"neverthrow\";\r\nimport { posthogCapture } from \"../../utils/posthog\";\r\nimport { ServerError } from \"../../utils/errors\";\r\nimport type { Context } from \"../../utils/trpc\";\r\nimport { createActorFromContext, type OrganizationActor } from \"../base/base.actor\";\r\nimport type { ServerResult, ServerResultAsync } from \"../base/base.dto\";\r\nimport { BaseService } from \"../base/base.service\";\r\nimport type { BillingService } from \"../billing/billing.service\";\r\nimport type { EmailService } from \"../email/email.service\";\r\nimport type {\r\n AccountClaim,\r\n AccountClaimMagicLinkOutput,\r\n AccountClaimOutput,\r\n Waitlist,\r\n WaitlistOutput,\r\n} from \"./auth.dto\";\r\nimport type { AuthRepository } from \"./auth.repository\";\r\n\r\ntype AuthServiceDependencies =\r\n | { email: EmailService }\r\n | { email: EmailService; billing: BillingService };\r\n\r\nexport class AuthService extends BaseService<{ auth: AuthRepository }, AuthServiceDependencies> {\r\n private getBillingService(): BillingService | null {\r\n if (!(\"billing\" in this.service)) return null;\r\n return this.service.billing;\r\n }\r\n\r\n private organizationActorFromCtx(ctx: Context): ServerResult<OrganizationActor> {\r\n try {\r\n return ok(createActorFromContext({ user: ctx.user, session: ctx.session }, \"organization\"));\r\n } catch (e) {\r\n if (e instanceof ServerError) return err(e);\r\n throw e;\r\n }\r\n }\r\n\r\n async getUserWaitlistCount(ctx: Context): ServerResultAsync<number> {\r\n if (ctx.actor.userRole === \"admin\") return ok(0);\r\n return this.repository.auth.getUserWaitlistCount(ctx.actor.userId);\r\n }\r\n\r\n async getOnboarding(ctx: Context): ServerResultAsync<number> {\r\n return this.repository.auth.getOnboarding(ctx.actor.userId);\r\n }\r\n\r\n async setOnboarding(onboarding: number, ctx: Context): ServerResultAsync<number> {\r\n posthogCapture({\r\n distinctId: ctx.actor.userId,\r\n event: \"onboarding_set\",\r\n properties: {\r\n onboarding,\r\n },\r\n });\r\n return this.repository.auth.setOnboarding(ctx.actor.userId, onboarding);\r\n }\r\n\r\n async getPreferences(ctx: Context): ServerResultAsync<Record<string, unknown>> {\r\n return this.repository.auth.getPreferences(ctx.actor.userId);\r\n }\r\n\r\n async setPreferences(\r\n preferences: Record<string, unknown>,\r\n ctx: Context\r\n ): ServerResultAsync<Record<string, unknown>> {\r\n posthogCapture({\r\n distinctId: ctx.actor.userId,\r\n event: \"preferences_set\",\r\n });\r\n return this.repository.auth.setPreferences(ctx.actor.userId, preferences);\r\n }\r\n\r\n async getOrganizationPreferences(ctx: Context): ServerResultAsync<Record<string, unknown>> {\r\n const org = this.organizationActorFromCtx(ctx);\r\n if (org.isErr()) return err(org.error);\r\n const actor = org.value;\r\n\r\n return this.repository.auth.getOrganizationPreferences(actor.userId, actor.organizationId);\r\n }\r\n\r\n async setOrganizationPreferences(\r\n preferences: Record<string, unknown>,\r\n ctx: Context\r\n ): ServerResultAsync<Record<string, unknown>> {\r\n const org = this.organizationActorFromCtx(ctx);\r\n if (org.isErr()) return err(org.error);\r\n const actor = org.value;\r\n\r\n posthogCapture({\r\n distinctId: actor.userId,\r\n event: \"organization_preferences_set\",\r\n properties: {\r\n organizationId: actor.organizationId,\r\n },\r\n });\r\n\r\n return this.repository.auth.setOrganizationPreferences(\r\n actor.userId,\r\n actor.organizationId,\r\n preferences\r\n );\r\n }\r\n\r\n async getMetadata(ctx: Context): ServerResultAsync<Record<string, unknown>> {\r\n return this.repository.auth.getMetadata(ctx.actor.userId);\r\n }\r\n\r\n async setMetadata(metadata: Record<string, unknown>, ctx: Context): ServerResultAsync<Record<string, unknown>> {\r\n posthogCapture({\r\n distinctId: ctx.actor.userId,\r\n event: \"metadata_set\",\r\n });\r\n return this.repository.auth.setMetadata(ctx.actor.userId, metadata);\r\n }\r\n\r\n async getFlags(ctx: Context): ServerResultAsync<string[]> {\r\n return this.repository.auth.getFlags(ctx.actor.userId);\r\n }\r\n\r\n async getOrganizationFlags(ctx: Context): ServerResultAsync<string[]> {\r\n const org = this.organizationActorFromCtx(ctx);\r\n if (org.isErr()) return err(org.error);\r\n const actor = org.value;\r\n\r\n return this.repository.auth.getOrganizationFlags(actor.userId, actor.organizationId);\r\n }\r\n\r\n async setFlags(flags: string[], ctx: Context): ServerResultAsync<string[]> {\r\n posthogCapture({\r\n distinctId: ctx.actor.userId,\r\n event: \"flags_set\",\r\n });\r\n return this.repository.auth.setFlags(ctx.actor.userId, flags);\r\n }\r\n\r\n async setOrganizationFlags(flags: string[], ctx: Context): ServerResultAsync<string[]> {\r\n const org = this.organizationActorFromCtx(ctx);\r\n if (org.isErr()) return err(org.error);\r\n const actor = org.value;\r\n\r\n posthogCapture({\r\n distinctId: actor.userId,\r\n event: \"organization_flags_set\",\r\n properties: {\r\n organizationId: actor.organizationId,\r\n },\r\n });\r\n\r\n return this.repository.auth.setOrganizationFlags(actor.userId, actor.organizationId, flags);\r\n }\r\n\r\n async listAdminWaitlist(): ServerResultAsync<WaitlistOutput[]> {\r\n return this.repository.auth.listAdminWaitlist();\r\n }\r\n\r\n async listWaitlist(ctx: Context): ServerResultAsync<Waitlist[]> {\r\n return this.repository.auth.listWaitlist(ctx.actor.userId);\r\n }\r\n\r\n async addToWaitlist({ email }: { email: string }): ServerResultAsync<WaitlistOutput> {\r\n return this.repository.auth.addToWaitlist(email);\r\n }\r\n\r\n async inviteFromWaitlist({ id }: { id: string }): ServerResultAsync<Waitlist> {\r\n const waitlist = await this.repository.auth.inviteFromWaitlist(id);\r\n if (waitlist.isErr()) return err(waitlist.error);\r\n if (!waitlist.value.code) return this.repository.auth.error(\"BAD_REQUEST\");\r\n if (!waitlist.value.email) return this.repository.auth.error(\"BAD_REQUEST\");\r\n await this.service.email.sendWaitlistInvite(waitlist.value.email, waitlist.value.code);\r\n return ok(waitlist.value);\r\n }\r\n\r\n async inviteToWaitlist(\r\n { email, name }: { email: string; name?: string },\r\n ctx: Context\r\n ): ServerResultAsync<Waitlist> {\r\n const count = await this.repository.auth.getUserWaitlistCount(ctx.user.id);\r\n if (count.isErr()) return err(count.error);\r\n if (count.value >= 3) return this.repository.auth.error(\"BAD_REQUEST\", \"Run out of invites\");\r\n const waitlist = await this.repository.auth.inviteToWaitlist({\r\n email,\r\n userId: ctx.user.id,\r\n name,\r\n });\r\n if (waitlist.isErr()) return err(waitlist.error);\r\n if (!waitlist.value.code) return this.repository.auth.error(\"BAD_REQUEST\");\r\n await this.service.email.sendWaitlistUserInvite(\r\n email,\r\n waitlist.value.code,\r\n ctx.user.name,\r\n name\r\n );\r\n posthogCapture({\r\n distinctId: ctx.user.id,\r\n event: \"waitlist_invite_sent\",\r\n properties: {\r\n email,\r\n name,\r\n },\r\n });\r\n return ok(waitlist.value);\r\n }\r\n\r\n async createInvitationCode({ name }: { name?: string }, ctx: Context): ServerResultAsync<Waitlist> {\r\n posthogCapture({\r\n distinctId: ctx.actor.userId,\r\n event: \"waitlist_invitation_code_created\",\r\n properties: {\r\n name,\r\n },\r\n });\r\n return this.repository.auth.createInvitationCode({ userId: ctx.actor.userId, name });\r\n }\r\n\r\n async joinWaitlist({ email }: { email: string }): ServerResultAsync<WaitlistOutput> {\r\n const waitlist = await this.repository.auth.joinWaitlist(email);\r\n if (waitlist.isErr()) return err(waitlist.error);\r\n await this.service.email.sendWaitlistConfirmation(email);\r\n return ok(waitlist.value);\r\n }\r\n\r\n async removeFromWaitlist({ id }: { id: string }): ServerResultAsync<WaitlistOutput> {\r\n return this.repository.auth.removeFromWaitlist(id);\r\n }\r\n\r\n async validateWaitlistCode(code: string): ServerResultAsync<{ status: string }> {\r\n return this.repository.auth.validateWaitlistCode(code);\r\n }\r\n\r\n async createAccountClaimCode({\r\n userId,\r\n expiresInHours,\r\n }: {\r\n userId: string;\r\n expiresInHours?: number;\r\n }): ServerResultAsync<AccountClaim> {\r\n return this.repository.auth.createAccountClaimCode({ userId, expiresInHours });\r\n }\r\n\r\n async listAccountClaims(): ServerResultAsync<AccountClaimOutput[]> {\r\n return this.repository.auth.listAccountClaims();\r\n }\r\n\r\n async getMyAccountClaimStatus(ctx: Context): ServerResultAsync<AccountClaim | null> {\r\n return this.repository.auth.findPendingAccountClaimForUser(ctx.actor.userId);\r\n }\r\n\r\n async setMyAccountClaimEmail(\r\n { email }: { email: string },\r\n ctx: Context\r\n ): ServerResultAsync<{ status: boolean }> {\r\n return this.repository.auth.setAccountClaimEmail({ userId: ctx.actor.userId, email });\r\n }\r\n\r\n async acceptMyAccountClaim(ctx: Context): ServerResultAsync<{ status: boolean }> {\r\n const pendingClaim = await this.repository.auth.findPendingAccountClaimForUser(ctx.user.id);\r\n if (pendingClaim.isErr()) return err(pendingClaim.error);\r\n\r\n const accepted = await this.repository.auth.acceptAccountClaim(ctx.user.id);\r\n if (accepted.isErr()) return err(accepted.error);\r\n\r\n if (pendingClaim.value) {\r\n const billingService = this.getBillingService();\r\n if (billingService) {\r\n await billingService.createUserHook({ user: ctx.user });\r\n }\r\n }\r\n\r\n return ok(accepted.value);\r\n }\r\n\r\n async generateAccountClaimMagicLink({\r\n claimId,\r\n email,\r\n }: {\r\n claimId: string;\r\n email?: string;\r\n }): ServerResultAsync<AccountClaimMagicLinkOutput> {\r\n const claim = await this.repository.auth.findAccountClaimById(claimId);\r\n if (claim.isErr()) return err(claim.error);\r\n if (!claim.value) return this.repository.auth.error(\"NOT_FOUND\", \"Claim not found\");\r\n if (!claim.value.claimUserId)\r\n return this.repository.auth.error(\"BAD_REQUEST\", \"Claim has no user\");\r\n if (claim.value.status !== \"INVITED\") {\r\n return this.repository.auth.error(\"BAD_REQUEST\", \"Claim is not pending\");\r\n }\r\n if (claim.value.expiresAt && claim.value.expiresAt < new Date()) {\r\n return this.repository.auth.error(\"BAD_REQUEST\", \"Claim is expired\");\r\n }\r\n\r\n const targetEmail = email ?? claim.value.claimedEmail ?? undefined;\r\n if (!targetEmail) {\r\n return this.repository.auth.error(\"BAD_REQUEST\", \"Email required to generate magic link\");\r\n }\r\n\r\n const setEmail = await this.repository.auth.setAccountClaimEmail({\r\n userId: claim.value.claimUserId,\r\n email: targetEmail,\r\n });\r\n if (setEmail.isErr()) return err(setEmail.error);\r\n\r\n const response = await fetch(`${process.env.VITE_SERVER_URL}/api/auth/sign-in/magic-link`, {\r\n method: \"POST\",\r\n headers: {\r\n \"content-type\": \"application/json\",\r\n },\r\n body: JSON.stringify({\r\n email: targetEmail.toLowerCase(),\r\n callbackURL: `${process.env.VITE_APP_URL}/claim-account?claim=${claimId}`,\r\n }),\r\n });\r\n\r\n if (!response.ok) {\r\n return this.repository.auth.error(\"INTERNAL_SERVER_ERROR\", \"Failed to generate magic link\");\r\n }\r\n\r\n const latest = await this.repository.auth.latestAccountClaimMagicLink(claimId);\r\n if (latest.isErr()) return err(latest.error);\r\n if (!latest.value) return this.repository.auth.error(\"INTERNAL_SERVER_ERROR\");\r\n return ok(latest.value);\r\n }\r\n\r\n async listAccountClaimMagicLinks({\r\n claimId,\r\n }: {\r\n claimId: string;\r\n }): ServerResultAsync<AccountClaimMagicLinkOutput[]> {\r\n return this.repository.auth.listAccountClaimMagicLinks(claimId);\r\n }\r\n}\r\n"],"mappings":"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"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { ServerResultAsync } from "../base/base.dto.cjs";
|
|
2
|
+
import { Context } from "../../utils/trpc.cjs";
|
|
3
|
+
import { BillingService } from "../billing/billing.service.cjs";
|
|
4
|
+
import { EmailService } from "../email/email.service.cjs";
|
|
5
|
+
import { BaseService } from "../base/base.service.cjs";
|
|
6
|
+
import { AccountClaim, AccountClaimMagicLinkOutput, AccountClaimOutput, Waitlist, WaitlistOutput } from "./auth.dto.cjs";
|
|
7
|
+
import { AuthRepository } from "./auth.repository.cjs";
|
|
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.cts.map
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
require("../../../_virtual/_rolldown/runtime.cjs");
|
|
3
|
+
const require_src_utils_trpc = require("../../utils/trpc.cjs");
|
|
4
|
+
const require_src_modules_auth_auth_dto = require("./auth.dto.cjs");
|
|
5
|
+
let zod = require("zod");
|
|
6
|
+
//#region src/modules/auth/auth.trpc.ts
|
|
7
|
+
function createAuthTRPC({ router, publicProcedure, privateProcedure: procedure, adminProcedure }, authService) {
|
|
8
|
+
return router({
|
|
9
|
+
getUserWaitlistCount: procedure.output(zod.z.number()).query(async ({ ctx }) => {
|
|
10
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getUserWaitlistCount(ctx));
|
|
11
|
+
}),
|
|
12
|
+
createInvitationCode: procedure.input(zod.z.object({ name: zod.z.string().optional() })).output(require_src_modules_auth_auth_dto.waitlistSchema).mutation(async ({ input, ctx }) => {
|
|
13
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.createInvitationCode(input, ctx));
|
|
14
|
+
}),
|
|
15
|
+
createAccountClaimCode: adminProcedure.input(zod.z.object({
|
|
16
|
+
userId: zod.z.string(),
|
|
17
|
+
expiresInHours: zod.z.number().optional()
|
|
18
|
+
})).output(require_src_modules_auth_auth_dto.accountClaimSchema).mutation(async ({ input }) => {
|
|
19
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.createAccountClaimCode(input));
|
|
20
|
+
}),
|
|
21
|
+
listAccountClaims: adminProcedure.output(zod.z.array(require_src_modules_auth_auth_dto.accountClaimOutputSchema)).query(async () => {
|
|
22
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.listAccountClaims());
|
|
23
|
+
}),
|
|
24
|
+
generateAccountClaimMagicLink: adminProcedure.input(zod.z.object({
|
|
25
|
+
claimId: zod.z.string(),
|
|
26
|
+
email: zod.z.string().email().optional()
|
|
27
|
+
})).output(require_src_modules_auth_auth_dto.accountClaimMagicLinkOutputSchema).mutation(async ({ input }) => {
|
|
28
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.generateAccountClaimMagicLink(input));
|
|
29
|
+
}),
|
|
30
|
+
listAccountClaimMagicLinks: adminProcedure.input(zod.z.object({ claimId: zod.z.string() })).output(zod.z.array(require_src_modules_auth_auth_dto.accountClaimMagicLinkOutputSchema)).query(async ({ input }) => {
|
|
31
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.listAccountClaimMagicLinks(input));
|
|
32
|
+
}),
|
|
33
|
+
getMyAccountClaimStatus: procedure.output(require_src_modules_auth_auth_dto.accountClaimSchema.nullable()).query(async ({ ctx }) => {
|
|
34
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getMyAccountClaimStatus(ctx));
|
|
35
|
+
}),
|
|
36
|
+
setMyAccountClaimEmail: procedure.input(zod.z.object({ email: zod.z.string().email() })).output(zod.z.object({ status: zod.z.boolean() })).mutation(async ({ input, ctx }) => {
|
|
37
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.setMyAccountClaimEmail(input, ctx));
|
|
38
|
+
}),
|
|
39
|
+
acceptMyAccountClaim: procedure.output(zod.z.object({ status: zod.z.boolean() })).mutation(async ({ ctx }) => {
|
|
40
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.acceptMyAccountClaim(ctx));
|
|
41
|
+
}),
|
|
42
|
+
listWaitlist: procedure.output(zod.z.array(require_src_modules_auth_auth_dto.waitlistSchema)).query(async ({ ctx }) => {
|
|
43
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.listWaitlist(ctx));
|
|
44
|
+
}),
|
|
45
|
+
listAdminWaitlist: adminProcedure.output(zod.z.array(require_src_modules_auth_auth_dto.waitlistOutputSchema)).query(async () => {
|
|
46
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.listAdminWaitlist());
|
|
47
|
+
}),
|
|
48
|
+
addToWaitlist: adminProcedure.input(zod.z.object({ email: zod.z.string() })).output(require_src_modules_auth_auth_dto.waitlistOutputSchema).mutation(async ({ input }) => {
|
|
49
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.addToWaitlist(input));
|
|
50
|
+
}),
|
|
51
|
+
inviteToWaitlist: procedure.input(zod.z.object({
|
|
52
|
+
email: zod.z.string(),
|
|
53
|
+
name: zod.z.string().optional()
|
|
54
|
+
})).output(require_src_modules_auth_auth_dto.waitlistSchema).mutation(async ({ input, ctx }) => {
|
|
55
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.inviteToWaitlist(input, ctx));
|
|
56
|
+
}),
|
|
57
|
+
inviteFromWaitlist: adminProcedure.input(zod.z.object({ id: zod.z.string() })).output(require_src_modules_auth_auth_dto.waitlistOutputSchema).mutation(async ({ input }) => {
|
|
58
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.inviteFromWaitlist(input));
|
|
59
|
+
}),
|
|
60
|
+
removeFromWaitlist: adminProcedure.input(zod.z.object({ id: zod.z.string() })).output(require_src_modules_auth_auth_dto.waitlistOutputSchema).mutation(async ({ input }) => {
|
|
61
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.removeFromWaitlist(input));
|
|
62
|
+
}),
|
|
63
|
+
joinWaitlist: publicProcedure.input(zod.z.object({ email: zod.z.string() })).output(require_src_modules_auth_auth_dto.waitlistOutputSchema).mutation(async ({ input }) => {
|
|
64
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.joinWaitlist(input));
|
|
65
|
+
}),
|
|
66
|
+
getOnboarding: procedure.output(zod.z.number()).query(async ({ ctx }) => {
|
|
67
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getOnboarding(ctx));
|
|
68
|
+
}),
|
|
69
|
+
setOnboarding: procedure.input(zod.z.number()).output(zod.z.number()).mutation(async ({ ctx, input }) => {
|
|
70
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.setOnboarding(input, ctx));
|
|
71
|
+
}),
|
|
72
|
+
getPreferences: procedure.output(zod.z.record(zod.z.string(), zod.z.unknown())).query(async ({ ctx }) => {
|
|
73
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getPreferences(ctx));
|
|
74
|
+
}),
|
|
75
|
+
setPreferences: procedure.input(zod.z.record(zod.z.string(), zod.z.unknown())).output(zod.z.record(zod.z.string(), zod.z.unknown())).mutation(async ({ ctx, input }) => {
|
|
76
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.setPreferences(input, ctx));
|
|
77
|
+
}),
|
|
78
|
+
getOrganizationPreferences: procedure.output(zod.z.record(zod.z.string(), zod.z.unknown())).query(async ({ ctx }) => {
|
|
79
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getOrganizationPreferences(ctx));
|
|
80
|
+
}),
|
|
81
|
+
setOrganizationPreferences: procedure.input(zod.z.record(zod.z.string(), zod.z.unknown())).output(zod.z.record(zod.z.string(), zod.z.unknown())).mutation(async ({ ctx, input }) => {
|
|
82
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.setOrganizationPreferences(input, ctx));
|
|
83
|
+
}),
|
|
84
|
+
getMetadata: procedure.output(zod.z.record(zod.z.string(), zod.z.unknown())).query(async ({ ctx }) => {
|
|
85
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getMetadata(ctx));
|
|
86
|
+
}),
|
|
87
|
+
setMetadata: procedure.input(zod.z.record(zod.z.string(), zod.z.unknown())).output(zod.z.record(zod.z.string(), zod.z.unknown())).mutation(async ({ ctx, input }) => {
|
|
88
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.setMetadata(input, ctx));
|
|
89
|
+
}),
|
|
90
|
+
getFlags: procedure.output(zod.z.array(zod.z.string())).query(async ({ ctx }) => {
|
|
91
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getFlags(ctx));
|
|
92
|
+
}),
|
|
93
|
+
getOrganizationFlags: procedure.output(zod.z.array(zod.z.string())).query(async ({ ctx }) => {
|
|
94
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.getOrganizationFlags(ctx));
|
|
95
|
+
}),
|
|
96
|
+
setFlags: procedure.input(zod.z.array(zod.z.string())).output(zod.z.array(zod.z.string())).mutation(async ({ ctx, input }) => {
|
|
97
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.setFlags(input, ctx));
|
|
98
|
+
}),
|
|
99
|
+
setOrganizationFlags: procedure.input(zod.z.array(zod.z.string())).output(zod.z.array(zod.z.string())).mutation(async ({ ctx, input }) => {
|
|
100
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.setOrganizationFlags(input, ctx));
|
|
101
|
+
}),
|
|
102
|
+
validateWaitlistCode: publicProcedure.input(zod.z.object({ code: zod.z.string() })).output(zod.z.object({ status: zod.z.string() })).query(async ({ input }) => {
|
|
103
|
+
return require_src_utils_trpc.handleTRPCResult(await authService.validateWaitlistCode(input.code));
|
|
104
|
+
})
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
//#endregion
|
|
108
|
+
exports.createAuthTRPC = createAuthTRPC;
|
|
109
|
+
|
|
110
|
+
//# sourceMappingURL=auth.trpc.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.trpc.cjs","names":["z","handleTRPCResult","waitlistSchema","accountClaimSchema","accountClaimOutputSchema","accountClaimMagicLinkOutputSchema","waitlistOutputSchema"],"sources":["../../../../src/modules/auth/auth.trpc.ts"],"sourcesContent":["import { z } from \"zod\";\r\nimport { handleTRPCResult, type TRPCMethods } from \"../../utils/trpc\";\r\nimport {\r\n accountClaimMagicLinkOutputSchema,\r\n accountClaimOutputSchema,\r\n accountClaimSchema,\r\n waitlistOutputSchema,\r\n waitlistSchema,\r\n} from \"./auth.dto\";\r\nimport type { AuthService } from \"./auth.service\";\r\n\r\nexport function createAuthTRPC(\r\n { router, publicProcedure, privateProcedure: procedure, adminProcedure }: TRPCMethods,\r\n authService: AuthService\r\n) {\r\n return router({\r\n getUserWaitlistCount: procedure.output(z.number()).query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getUserWaitlistCount(ctx));\r\n }),\r\n\r\n createInvitationCode: procedure\r\n .input(z.object({ name: z.string().optional() }))\r\n .output(waitlistSchema)\r\n .mutation(async ({ input, ctx }) => {\r\n return handleTRPCResult(await authService.createInvitationCode(input, ctx));\r\n }),\r\n\r\n createAccountClaimCode: adminProcedure\r\n .input(\r\n z.object({\r\n userId: z.string(),\r\n expiresInHours: z.number().optional(),\r\n })\r\n )\r\n .output(accountClaimSchema)\r\n .mutation(async ({ input }) => {\r\n return handleTRPCResult(await authService.createAccountClaimCode(input));\r\n }),\r\n\r\n listAccountClaims: adminProcedure.output(z.array(accountClaimOutputSchema)).query(async () => {\r\n return handleTRPCResult(await authService.listAccountClaims());\r\n }),\r\n\r\n generateAccountClaimMagicLink: adminProcedure\r\n .input(\r\n z.object({\r\n claimId: z.string(),\r\n email: z.string().email().optional(),\r\n })\r\n )\r\n .output(accountClaimMagicLinkOutputSchema)\r\n .mutation(async ({ input }) => {\r\n return handleTRPCResult(await authService.generateAccountClaimMagicLink(input));\r\n }),\r\n\r\n listAccountClaimMagicLinks: adminProcedure\r\n .input(\r\n z.object({\r\n claimId: z.string(),\r\n })\r\n )\r\n .output(z.array(accountClaimMagicLinkOutputSchema))\r\n .query(async ({ input }) => {\r\n return handleTRPCResult(await authService.listAccountClaimMagicLinks(input));\r\n }),\r\n\r\n getMyAccountClaimStatus: procedure\r\n .output(accountClaimSchema.nullable())\r\n .query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getMyAccountClaimStatus(ctx));\r\n }),\r\n\r\n setMyAccountClaimEmail: procedure\r\n .input(\r\n z.object({\r\n email: z.string().email(),\r\n })\r\n )\r\n .output(z.object({ status: z.boolean() }))\r\n .mutation(async ({ input, ctx }) => {\r\n return handleTRPCResult(await authService.setMyAccountClaimEmail(input, ctx));\r\n }),\r\n\r\n acceptMyAccountClaim: procedure\r\n .output(z.object({ status: z.boolean() }))\r\n .mutation(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.acceptMyAccountClaim(ctx));\r\n }),\r\n\r\n listWaitlist: procedure.output(z.array(waitlistSchema)).query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.listWaitlist(ctx));\r\n }),\r\n\r\n listAdminWaitlist: adminProcedure.output(z.array(waitlistOutputSchema)).query(async () => {\r\n return handleTRPCResult(await authService.listAdminWaitlist());\r\n }),\r\n\r\n addToWaitlist: adminProcedure\r\n .input(\r\n z.object({\r\n email: z.string(),\r\n })\r\n )\r\n .output(waitlistOutputSchema)\r\n .mutation(async ({ input }) => {\r\n return handleTRPCResult(await authService.addToWaitlist(input));\r\n }),\r\n\r\n inviteToWaitlist: procedure\r\n .input(\r\n z.object({\r\n email: z.string(),\r\n name: z.string().optional(),\r\n })\r\n )\r\n .output(waitlistSchema)\r\n .mutation(async ({ input, ctx }) => {\r\n return handleTRPCResult(await authService.inviteToWaitlist(input, ctx));\r\n }),\r\n\r\n inviteFromWaitlist: adminProcedure\r\n .input(\r\n z.object({\r\n id: z.string(),\r\n })\r\n )\r\n .output(waitlistOutputSchema)\r\n .mutation(async ({ input }) => {\r\n return handleTRPCResult(await authService.inviteFromWaitlist(input));\r\n }),\r\n\r\n removeFromWaitlist: adminProcedure\r\n .input(\r\n z.object({\r\n id: z.string(),\r\n })\r\n )\r\n .output(waitlistOutputSchema)\r\n .mutation(async ({ input }) => {\r\n return handleTRPCResult(await authService.removeFromWaitlist(input));\r\n }),\r\n\r\n joinWaitlist: publicProcedure\r\n .input(\r\n z.object({\r\n email: z.string(),\r\n })\r\n )\r\n .output(waitlistOutputSchema)\r\n .mutation(async ({ input }) => {\r\n return handleTRPCResult(await authService.joinWaitlist(input));\r\n }),\r\n\r\n getOnboarding: procedure.output(z.number()).query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getOnboarding(ctx));\r\n }),\r\n\r\n setOnboarding: procedure\r\n .input(z.number())\r\n .output(z.number())\r\n .mutation(async ({ ctx, input }) => {\r\n return handleTRPCResult(await authService.setOnboarding(input, ctx));\r\n }),\r\n\r\n getPreferences: procedure.output(z.record(z.string(), z.unknown())).query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getPreferences(ctx));\r\n }),\r\n\r\n setPreferences: procedure\r\n .input(z.record(z.string(), z.unknown()))\r\n .output(z.record(z.string(), z.unknown()))\r\n .mutation(async ({ ctx, input }) => {\r\n return handleTRPCResult(await authService.setPreferences(input, ctx));\r\n }),\r\n\r\n getOrganizationPreferences: procedure\r\n .output(z.record(z.string(), z.unknown()))\r\n .query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getOrganizationPreferences(ctx));\r\n }),\r\n\r\n setOrganizationPreferences: procedure\r\n .input(z.record(z.string(), z.unknown()))\r\n .output(z.record(z.string(), z.unknown()))\r\n .mutation(async ({ ctx, input }) => {\r\n return handleTRPCResult(await authService.setOrganizationPreferences(input, ctx));\r\n }),\r\n\r\n getMetadata: procedure.output(z.record(z.string(), z.unknown())).query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getMetadata(ctx));\r\n }),\r\n\r\n setMetadata: procedure\r\n .input(z.record(z.string(), z.unknown()))\r\n .output(z.record(z.string(), z.unknown()))\r\n .mutation(async ({ ctx, input }) => {\r\n return handleTRPCResult(await authService.setMetadata(input, ctx));\r\n }),\r\n\r\n getFlags: procedure.output(z.array(z.string())).query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getFlags(ctx));\r\n }),\r\n\r\n getOrganizationFlags: procedure.output(z.array(z.string())).query(async ({ ctx }) => {\r\n return handleTRPCResult(await authService.getOrganizationFlags(ctx));\r\n }),\r\n\r\n setFlags: procedure\r\n .input(z.array(z.string()))\r\n .output(z.array(z.string()))\r\n .mutation(async ({ ctx, input }) => {\r\n return handleTRPCResult(await authService.setFlags(input, ctx));\r\n }),\r\n\r\n setOrganizationFlags: procedure\r\n .input(z.array(z.string()))\r\n .output(z.array(z.string()))\r\n .mutation(async ({ ctx, input }) => {\r\n return handleTRPCResult(await authService.setOrganizationFlags(input, ctx));\r\n }),\r\n\r\n validateWaitlistCode: publicProcedure\r\n .input(\r\n z.object({\r\n code: z.string(),\r\n })\r\n )\r\n .output(\r\n z.object({\r\n status: z.string(),\r\n })\r\n )\r\n .query(async ({ input }) => {\r\n return handleTRPCResult(await authService.validateWaitlistCode(input.code));\r\n }),\r\n });\r\n}\r\n"],"mappings":";;;;;;AAWA,SAAgB,eACd,EAAE,QAAQ,iBAAiB,kBAAkB,WAAW,kBACxD,aACA;AACA,QAAO,OAAO;EACZ,sBAAsB,UAAU,OAAOA,IAAAA,EAAE,QAAQ,CAAC,CAAC,MAAM,OAAO,EAAE,UAAU;AAC1E,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,qBAAqB,IAAI,CAAC;IACpE;EAEF,sBAAsB,UACnB,MAAMD,IAAAA,EAAE,OAAO,EAAE,MAAMA,IAAAA,EAAE,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC,CAChD,OAAOE,kCAAAA,eAAe,CACtB,SAAS,OAAO,EAAE,OAAO,UAAU;AAClC,UAAOD,uBAAAA,iBAAiB,MAAM,YAAY,qBAAqB,OAAO,IAAI,CAAC;IAC3E;EAEJ,wBAAwB,eACrB,MACCD,IAAAA,EAAE,OAAO;GACP,QAAQA,IAAAA,EAAE,QAAQ;GAClB,gBAAgBA,IAAAA,EAAE,QAAQ,CAAC,UAAU;GACtC,CAAC,CACH,CACA,OAAOG,kCAAAA,mBAAmB,CAC1B,SAAS,OAAO,EAAE,YAAY;AAC7B,UAAOF,uBAAAA,iBAAiB,MAAM,YAAY,uBAAuB,MAAM,CAAC;IACxE;EAEJ,mBAAmB,eAAe,OAAOD,IAAAA,EAAE,MAAMI,kCAAAA,yBAAyB,CAAC,CAAC,MAAM,YAAY;AAC5F,UAAOH,uBAAAA,iBAAiB,MAAM,YAAY,mBAAmB,CAAC;IAC9D;EAEF,+BAA+B,eAC5B,MACCD,IAAAA,EAAE,OAAO;GACP,SAASA,IAAAA,EAAE,QAAQ;GACnB,OAAOA,IAAAA,EAAE,QAAQ,CAAC,OAAO,CAAC,UAAU;GACrC,CAAC,CACH,CACA,OAAOK,kCAAAA,kCAAkC,CACzC,SAAS,OAAO,EAAE,YAAY;AAC7B,UAAOJ,uBAAAA,iBAAiB,MAAM,YAAY,8BAA8B,MAAM,CAAC;IAC/E;EAEJ,4BAA4B,eACzB,MACCD,IAAAA,EAAE,OAAO,EACP,SAASA,IAAAA,EAAE,QAAQ,EACpB,CAAC,CACH,CACA,OAAOA,IAAAA,EAAE,MAAMK,kCAAAA,kCAAkC,CAAC,CAClD,MAAM,OAAO,EAAE,YAAY;AAC1B,UAAOJ,uBAAAA,iBAAiB,MAAM,YAAY,2BAA2B,MAAM,CAAC;IAC5E;EAEJ,yBAAyB,UACtB,OAAOE,kCAAAA,mBAAmB,UAAU,CAAC,CACrC,MAAM,OAAO,EAAE,UAAU;AACxB,UAAOF,uBAAAA,iBAAiB,MAAM,YAAY,wBAAwB,IAAI,CAAC;IACvE;EAEJ,wBAAwB,UACrB,MACCD,IAAAA,EAAE,OAAO,EACP,OAAOA,IAAAA,EAAE,QAAQ,CAAC,OAAO,EAC1B,CAAC,CACH,CACA,OAAOA,IAAAA,EAAE,OAAO,EAAE,QAAQA,IAAAA,EAAE,SAAS,EAAE,CAAC,CAAC,CACzC,SAAS,OAAO,EAAE,OAAO,UAAU;AAClC,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,uBAAuB,OAAO,IAAI,CAAC;IAC7E;EAEJ,sBAAsB,UACnB,OAAOD,IAAAA,EAAE,OAAO,EAAE,QAAQA,IAAAA,EAAE,SAAS,EAAE,CAAC,CAAC,CACzC,SAAS,OAAO,EAAE,UAAU;AAC3B,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,qBAAqB,IAAI,CAAC;IACpE;EAEJ,cAAc,UAAU,OAAOD,IAAAA,EAAE,MAAME,kCAAAA,eAAe,CAAC,CAAC,MAAM,OAAO,EAAE,UAAU;AAC/E,UAAOD,uBAAAA,iBAAiB,MAAM,YAAY,aAAa,IAAI,CAAC;IAC5D;EAEF,mBAAmB,eAAe,OAAOD,IAAAA,EAAE,MAAMM,kCAAAA,qBAAqB,CAAC,CAAC,MAAM,YAAY;AACxF,UAAOL,uBAAAA,iBAAiB,MAAM,YAAY,mBAAmB,CAAC;IAC9D;EAEF,eAAe,eACZ,MACCD,IAAAA,EAAE,OAAO,EACP,OAAOA,IAAAA,EAAE,QAAQ,EAClB,CAAC,CACH,CACA,OAAOM,kCAAAA,qBAAqB,CAC5B,SAAS,OAAO,EAAE,YAAY;AAC7B,UAAOL,uBAAAA,iBAAiB,MAAM,YAAY,cAAc,MAAM,CAAC;IAC/D;EAEJ,kBAAkB,UACf,MACCD,IAAAA,EAAE,OAAO;GACP,OAAOA,IAAAA,EAAE,QAAQ;GACjB,MAAMA,IAAAA,EAAE,QAAQ,CAAC,UAAU;GAC5B,CAAC,CACH,CACA,OAAOE,kCAAAA,eAAe,CACtB,SAAS,OAAO,EAAE,OAAO,UAAU;AAClC,UAAOD,uBAAAA,iBAAiB,MAAM,YAAY,iBAAiB,OAAO,IAAI,CAAC;IACvE;EAEJ,oBAAoB,eACjB,MACCD,IAAAA,EAAE,OAAO,EACP,IAAIA,IAAAA,EAAE,QAAQ,EACf,CAAC,CACH,CACA,OAAOM,kCAAAA,qBAAqB,CAC5B,SAAS,OAAO,EAAE,YAAY;AAC7B,UAAOL,uBAAAA,iBAAiB,MAAM,YAAY,mBAAmB,MAAM,CAAC;IACpE;EAEJ,oBAAoB,eACjB,MACCD,IAAAA,EAAE,OAAO,EACP,IAAIA,IAAAA,EAAE,QAAQ,EACf,CAAC,CACH,CACA,OAAOM,kCAAAA,qBAAqB,CAC5B,SAAS,OAAO,EAAE,YAAY;AAC7B,UAAOL,uBAAAA,iBAAiB,MAAM,YAAY,mBAAmB,MAAM,CAAC;IACpE;EAEJ,cAAc,gBACX,MACCD,IAAAA,EAAE,OAAO,EACP,OAAOA,IAAAA,EAAE,QAAQ,EAClB,CAAC,CACH,CACA,OAAOM,kCAAAA,qBAAqB,CAC5B,SAAS,OAAO,EAAE,YAAY;AAC7B,UAAOL,uBAAAA,iBAAiB,MAAM,YAAY,aAAa,MAAM,CAAC;IAC9D;EAEJ,eAAe,UAAU,OAAOD,IAAAA,EAAE,QAAQ,CAAC,CAAC,MAAM,OAAO,EAAE,UAAU;AACnE,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,cAAc,IAAI,CAAC;IAC7D;EAEF,eAAe,UACZ,MAAMD,IAAAA,EAAE,QAAQ,CAAC,CACjB,OAAOA,IAAAA,EAAE,QAAQ,CAAC,CAClB,SAAS,OAAO,EAAE,KAAK,YAAY;AAClC,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,cAAc,OAAO,IAAI,CAAC;IACpE;EAEJ,gBAAgB,UAAU,OAAOD,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CAAC,MAAM,OAAO,EAAE,UAAU;AAC3F,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,eAAe,IAAI,CAAC;IAC9D;EAEF,gBAAgB,UACb,MAAMD,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CACxC,OAAOA,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CACzC,SAAS,OAAO,EAAE,KAAK,YAAY;AAClC,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,eAAe,OAAO,IAAI,CAAC;IACrE;EAEJ,4BAA4B,UACzB,OAAOD,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CACzC,MAAM,OAAO,EAAE,UAAU;AACxB,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,2BAA2B,IAAI,CAAC;IAC1E;EAEJ,4BAA4B,UACzB,MAAMD,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CACxC,OAAOA,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CACzC,SAAS,OAAO,EAAE,KAAK,YAAY;AAClC,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,2BAA2B,OAAO,IAAI,CAAC;IACjF;EAEJ,aAAa,UAAU,OAAOD,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CAAC,MAAM,OAAO,EAAE,UAAU;AACxF,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,YAAY,IAAI,CAAC;IAC3D;EAEF,aAAa,UACV,MAAMD,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CACxC,OAAOA,IAAAA,EAAE,OAAOA,IAAAA,EAAE,QAAQ,EAAEA,IAAAA,EAAE,SAAS,CAAC,CAAC,CACzC,SAAS,OAAO,EAAE,KAAK,YAAY;AAClC,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,YAAY,OAAO,IAAI,CAAC;IAClE;EAEJ,UAAU,UAAU,OAAOD,IAAAA,EAAE,MAAMA,IAAAA,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,OAAO,EAAE,UAAU;AACvE,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,SAAS,IAAI,CAAC;IACxD;EAEF,sBAAsB,UAAU,OAAOD,IAAAA,EAAE,MAAMA,IAAAA,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,OAAO,EAAE,UAAU;AACnF,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,qBAAqB,IAAI,CAAC;IACpE;EAEF,UAAU,UACP,MAAMD,IAAAA,EAAE,MAAMA,IAAAA,EAAE,QAAQ,CAAC,CAAC,CAC1B,OAAOA,IAAAA,EAAE,MAAMA,IAAAA,EAAE,QAAQ,CAAC,CAAC,CAC3B,SAAS,OAAO,EAAE,KAAK,YAAY;AAClC,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,SAAS,OAAO,IAAI,CAAC;IAC/D;EAEJ,sBAAsB,UACnB,MAAMD,IAAAA,EAAE,MAAMA,IAAAA,EAAE,QAAQ,CAAC,CAAC,CAC1B,OAAOA,IAAAA,EAAE,MAAMA,IAAAA,EAAE,QAAQ,CAAC,CAAC,CAC3B,SAAS,OAAO,EAAE,KAAK,YAAY;AAClC,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,qBAAqB,OAAO,IAAI,CAAC;IAC3E;EAEJ,sBAAsB,gBACnB,MACCD,IAAAA,EAAE,OAAO,EACP,MAAMA,IAAAA,EAAE,QAAQ,EACjB,CAAC,CACH,CACA,OACCA,IAAAA,EAAE,OAAO,EACP,QAAQA,IAAAA,EAAE,QAAQ,EACnB,CAAC,CACH,CACA,MAAM,OAAO,EAAE,YAAY;AAC1B,UAAOC,uBAAAA,iBAAiB,MAAM,YAAY,qBAAqB,MAAM,KAAK,CAAC;IAC3E;EACL,CAAC"}
|