@m5kdev/backend 0.8.7 → 0.8.9
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.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.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.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.trpc.d.mts +1 -1
- 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 +2 -1
- 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 +2 -1
- 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 +3 -2
- 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/types.d.mts +6 -6
- 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,312 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
require("../../../_virtual/_rolldown/runtime.cjs");
|
|
3
|
+
const require_src_modules_base_base_service = require("../base/base.service.cjs");
|
|
4
|
+
const require_src_modules_ai_ai_prompts = require("./ai.prompts.cjs");
|
|
5
|
+
let neverthrow = require("neverthrow");
|
|
6
|
+
let _m5kdev_commons_modules_ai_ai_constants = require("@m5kdev/commons/modules/ai/ai.constants");
|
|
7
|
+
let _m5kdev_commons_modules_ai_ai_utils = require("@m5kdev/commons/modules/ai/ai.utils");
|
|
8
|
+
let _mastra_core_request_context = require("@mastra/core/request-context");
|
|
9
|
+
let _mastra_rag = require("@mastra/rag");
|
|
10
|
+
let ai = require("ai");
|
|
11
|
+
let jsonrepair = require("jsonrepair");
|
|
12
|
+
//#region src/modules/ai/ai.service.ts
|
|
13
|
+
var AIService = class extends require_src_modules_base_base_service.BaseService {
|
|
14
|
+
helpers = { arrayToPseudoXML: _m5kdev_commons_modules_ai_ai_utils.arrayToPseudoXML };
|
|
15
|
+
mastra;
|
|
16
|
+
openrouter;
|
|
17
|
+
replicate;
|
|
18
|
+
options;
|
|
19
|
+
constructor(repositories, services, libs, options) {
|
|
20
|
+
super(repositories, services);
|
|
21
|
+
this.mastra = libs.mastra;
|
|
22
|
+
this.openrouter = libs.openrouter;
|
|
23
|
+
this.replicate = libs.replicate;
|
|
24
|
+
this.options = options;
|
|
25
|
+
}
|
|
26
|
+
getMastra() {
|
|
27
|
+
if (!this.mastra) throw new Error("Mastra is not available");
|
|
28
|
+
return this.mastra;
|
|
29
|
+
}
|
|
30
|
+
prepareModel(model) {
|
|
31
|
+
if (!this.openrouter) throw new Error("OpenRouter is not configured");
|
|
32
|
+
return this.openrouter.chat(model, { usage: { include: true } });
|
|
33
|
+
}
|
|
34
|
+
prepareEmbeddingModel(model) {
|
|
35
|
+
if (!this.openrouter) throw new Error("OpenRouter is not configured");
|
|
36
|
+
const openrouter = this.openrouter;
|
|
37
|
+
return openrouter.embeddingModel?.(model) ?? openrouter.textEmbeddingModel(model);
|
|
38
|
+
}
|
|
39
|
+
async agentUse(agent, options, ctx) {
|
|
40
|
+
return this.throwableAsync(async () => {
|
|
41
|
+
this.logger.info("AGENT USE");
|
|
42
|
+
const { prompt, messages, ...rest } = options;
|
|
43
|
+
const payload = messages || prompt;
|
|
44
|
+
if (!payload) return this.error("BAD_REQUEST", "No prompt or messages provided");
|
|
45
|
+
const requestContext = options.requestContext ?? new _mastra_core_request_context.RequestContext();
|
|
46
|
+
if (ctx?.actor) requestContext.set("userId", ctx.actor.userId);
|
|
47
|
+
if (ctx?.model) requestContext.set("model", ctx.model);
|
|
48
|
+
const result = await this.getMastra().getAgent(agent).generate(payload, {
|
|
49
|
+
...rest,
|
|
50
|
+
requestContext: rest.requestContext ?? requestContext
|
|
51
|
+
});
|
|
52
|
+
this.logger.info("AGENT USE DONE");
|
|
53
|
+
if (this.repository.aiUsage) {
|
|
54
|
+
const createUsageResult = await this.repository.aiUsage.create({
|
|
55
|
+
userId: ctx?.actor?.userId,
|
|
56
|
+
model: ctx?.model ?? "unknown",
|
|
57
|
+
provider: "openrouter",
|
|
58
|
+
feature: agent,
|
|
59
|
+
traceId: result.traceId,
|
|
60
|
+
inputTokens: result.usage.inputTokens,
|
|
61
|
+
outputTokens: result.usage.outputTokens,
|
|
62
|
+
totalTokens: result.usage.totalTokens,
|
|
63
|
+
cost: (result?.providerMetadata?.openrouter?.usage)?.cost ?? 0
|
|
64
|
+
});
|
|
65
|
+
if (createUsageResult.isErr()) return (0, neverthrow.err)(createUsageResult.error);
|
|
66
|
+
}
|
|
67
|
+
this.logger.info("AGENT USE CREATED USAGE");
|
|
68
|
+
return (0, neverthrow.ok)(result);
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
async agentText(agent, options, ctx) {
|
|
72
|
+
const result = await this.agentUse(agent, options, ctx);
|
|
73
|
+
if (result.isErr()) return this.error("SERVICE_UNAVAILABLE", "AI: Agent text failed", { cause: result.error });
|
|
74
|
+
return (0, neverthrow.ok)(result.value.text);
|
|
75
|
+
}
|
|
76
|
+
async agentTextResult(agent, options, ctx) {
|
|
77
|
+
const result = await this.agentUse(agent, options, ctx);
|
|
78
|
+
if (result.isErr()) return (0, neverthrow.err)(result.error);
|
|
79
|
+
return (0, neverthrow.ok)(result.value);
|
|
80
|
+
}
|
|
81
|
+
async agentObject(agent, options, ctx) {
|
|
82
|
+
const { schema, ...rest } = options;
|
|
83
|
+
const result = await this.agentUse(agent, {
|
|
84
|
+
...rest,
|
|
85
|
+
structuredOutput: { schema }
|
|
86
|
+
}, ctx);
|
|
87
|
+
if (result.isErr()) return this.error("SERVICE_UNAVAILABLE", "AI: Agent object failed", { cause: result.error });
|
|
88
|
+
return (0, neverthrow.ok)(result.value.object);
|
|
89
|
+
}
|
|
90
|
+
async agentObjectResult(agent, options, ctx) {
|
|
91
|
+
this.logger.info("AGENT OBJECT RESULT");
|
|
92
|
+
const { schema, ...rest } = options;
|
|
93
|
+
const result = await this.agentUse(agent, {
|
|
94
|
+
...rest,
|
|
95
|
+
structuredOutput: { schema }
|
|
96
|
+
}, ctx);
|
|
97
|
+
if (result.isErr()) return (0, neverthrow.err)(result.error);
|
|
98
|
+
this.logger.info("AGENT OBJECT RESULT DONE");
|
|
99
|
+
return (0, neverthrow.ok)({
|
|
100
|
+
...result.value,
|
|
101
|
+
object: result.value.object
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
async embedDocument(value, options, type = "text", model = _m5kdev_commons_modules_ai_ai_constants.OPENAI_TEXT_EMBEDDING_3_SMALL) {
|
|
105
|
+
return this.throwableAsync(async () => {
|
|
106
|
+
if (type === "text") {
|
|
107
|
+
const chunks = await _mastra_rag.MDocument.fromText(value).chunk(options ?? {
|
|
108
|
+
strategy: "recursive",
|
|
109
|
+
maxSize: 512,
|
|
110
|
+
overlap: 50,
|
|
111
|
+
separators: ["\n"]
|
|
112
|
+
});
|
|
113
|
+
const embeddings = await this.embedMany(chunks, model);
|
|
114
|
+
if (embeddings.isErr()) return (0, neverthrow.err)(embeddings.error);
|
|
115
|
+
return (0, neverthrow.ok)({
|
|
116
|
+
embeddings: embeddings.value.embeddings,
|
|
117
|
+
chunks
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
return this.error("BAD_REQUEST", "Unsupported document type");
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
async embed(text, model = _m5kdev_commons_modules_ai_ai_constants.OPENAI_TEXT_EMBEDDING_3_SMALL) {
|
|
124
|
+
return this.throwableAsync(async () => {
|
|
125
|
+
return (0, neverthrow.ok)(await (0, ai.embed)({
|
|
126
|
+
model: this.prepareEmbeddingModel(model),
|
|
127
|
+
value: text
|
|
128
|
+
}));
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
async embedMany(chunks, model = _m5kdev_commons_modules_ai_ai_constants.OPENAI_TEXT_EMBEDDING_3_SMALL) {
|
|
132
|
+
return this.throwableAsync(async () => {
|
|
133
|
+
return (0, neverthrow.ok)(await (0, ai.embedMany)({
|
|
134
|
+
model: this.prepareEmbeddingModel(model),
|
|
135
|
+
values: chunks.map((chunk) => chunk.text)
|
|
136
|
+
}));
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
async generateText(params) {
|
|
140
|
+
return this.throwableAsync(async () => {
|
|
141
|
+
const { removeMDash = this.options?.removeMDash ?? true, model, prompt, messages, ctx, retryAttempts = this.options?.retryAttempts ?? 0, retryModels = this.options?.retryModels ?? [], ...rest } = params;
|
|
142
|
+
const request = messages ? {
|
|
143
|
+
...rest,
|
|
144
|
+
model: this.prepareModel(model),
|
|
145
|
+
messages
|
|
146
|
+
} : {
|
|
147
|
+
...rest,
|
|
148
|
+
model: this.prepareModel(model),
|
|
149
|
+
prompt
|
|
150
|
+
};
|
|
151
|
+
try {
|
|
152
|
+
const result = await (0, ai.generateText)(request);
|
|
153
|
+
if (this.repository.aiUsage) {
|
|
154
|
+
const createUsageResult = await this.repository.aiUsage.create({
|
|
155
|
+
userId: ctx?.actor?.userId,
|
|
156
|
+
model,
|
|
157
|
+
provider: "openrouter",
|
|
158
|
+
feature: "generateText",
|
|
159
|
+
traceId: result.providerMetadata?.openrouter?.traceId?.toString(),
|
|
160
|
+
inputTokens: result.usage.inputTokens,
|
|
161
|
+
outputTokens: result.usage.outputTokens,
|
|
162
|
+
totalTokens: result.usage.totalTokens,
|
|
163
|
+
cost: (result?.providerMetadata?.openrouter?.usage)?.cost ?? 0
|
|
164
|
+
});
|
|
165
|
+
if (createUsageResult.isErr()) return (0, neverthrow.err)(createUsageResult.error);
|
|
166
|
+
}
|
|
167
|
+
return (0, neverthrow.ok)(removeMDash ? result.text.replace(/\u2013|\u2014/g, "-") : result.text);
|
|
168
|
+
} catch (error) {
|
|
169
|
+
if (retryAttempts <= 0) throw error;
|
|
170
|
+
this.logger.warn(`generateText failed, retrying (${retryAttempts} attempts left)`, {
|
|
171
|
+
model,
|
|
172
|
+
error
|
|
173
|
+
});
|
|
174
|
+
const delay = Math.min(1e3 * 2 ** ((this.options?.retryAttempts ?? 3) - retryAttempts), 1e4);
|
|
175
|
+
await new Promise((resolve) => setTimeout(resolve, delay));
|
|
176
|
+
const nextModel = retryModels?.[0] ?? model;
|
|
177
|
+
const nextRetryModels = retryModels ? [...retryModels.slice(1), model] : void 0;
|
|
178
|
+
return this.generateText({
|
|
179
|
+
...rest,
|
|
180
|
+
...messages ? { messages } : { prompt },
|
|
181
|
+
model: nextModel,
|
|
182
|
+
removeMDash,
|
|
183
|
+
ctx,
|
|
184
|
+
retryAttempts: retryAttempts - 1,
|
|
185
|
+
retryModels: nextRetryModels
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
async generateObject(params) {
|
|
191
|
+
const { model, schema, prompt, messages, repairAttempts = this.options?.repairAttempts ?? 0, repairModel = this.options?.repairModel ?? model, ctx, retryAttempts = this.options?.retryAttempts ?? 0, retryModels = this.options?.retryModels ?? [], ...rest } = params;
|
|
192
|
+
const request = messages ? {
|
|
193
|
+
...rest,
|
|
194
|
+
model: this.prepareModel(model),
|
|
195
|
+
messages,
|
|
196
|
+
output: ai.Output.object({ schema })
|
|
197
|
+
} : {
|
|
198
|
+
...rest,
|
|
199
|
+
model: this.prepareModel(model),
|
|
200
|
+
prompt,
|
|
201
|
+
output: ai.Output.object({ schema })
|
|
202
|
+
};
|
|
203
|
+
try {
|
|
204
|
+
const result = await (0, ai.generateText)(request);
|
|
205
|
+
if (this.repository.aiUsage) {
|
|
206
|
+
const createUsageResult = await this.repository.aiUsage.create({
|
|
207
|
+
userId: ctx?.actor?.userId,
|
|
208
|
+
model,
|
|
209
|
+
provider: "openrouter",
|
|
210
|
+
feature: "generateObject",
|
|
211
|
+
traceId: result.providerMetadata?.openrouter?.traceId?.toString(),
|
|
212
|
+
inputTokens: result.usage.inputTokens,
|
|
213
|
+
outputTokens: result.usage.outputTokens,
|
|
214
|
+
totalTokens: result.usage.totalTokens,
|
|
215
|
+
cost: (result?.providerMetadata?.openrouter?.usage)?.cost ?? 0
|
|
216
|
+
});
|
|
217
|
+
if (createUsageResult.isErr()) return (0, neverthrow.err)(createUsageResult.error);
|
|
218
|
+
}
|
|
219
|
+
return (0, neverthrow.ok)(result.output);
|
|
220
|
+
} catch (error) {
|
|
221
|
+
if (ai.NoObjectGeneratedError.isInstance(error)) {
|
|
222
|
+
if (this.repository.aiUsage) {
|
|
223
|
+
const createUsageResult = await this.repository.aiUsage.create({
|
|
224
|
+
userId: ctx?.actor?.userId,
|
|
225
|
+
model,
|
|
226
|
+
provider: "openrouter",
|
|
227
|
+
feature: "generateObject",
|
|
228
|
+
traceId: null,
|
|
229
|
+
inputTokens: error?.usage?.inputTokens,
|
|
230
|
+
outputTokens: error?.usage?.outputTokens,
|
|
231
|
+
totalTokens: error?.usage?.totalTokens,
|
|
232
|
+
cost: 0
|
|
233
|
+
});
|
|
234
|
+
if (createUsageResult.isErr()) return (0, neverthrow.err)(createUsageResult.error);
|
|
235
|
+
}
|
|
236
|
+
if (error.text) {
|
|
237
|
+
const repairedText = (0, jsonrepair.jsonrepair)(error.text);
|
|
238
|
+
const parsed = schema.safeParse(repairedText);
|
|
239
|
+
if (parsed.success) return (0, neverthrow.ok)(parsed.data);
|
|
240
|
+
if (repairAttempts === 0) return this.error("PARSE_ERROR", "AI: Agent object failed", { cause: error });
|
|
241
|
+
return this.generateObject({
|
|
242
|
+
...rest,
|
|
243
|
+
prompt: require_src_modules_ai_ai_prompts.repairJsonPrompt.compile({
|
|
244
|
+
text: error.text,
|
|
245
|
+
error: JSON.stringify(error.cause ?? "Unknown error")
|
|
246
|
+
}),
|
|
247
|
+
repairAttempts: repairAttempts - 1,
|
|
248
|
+
model: repairModel ?? model,
|
|
249
|
+
schema,
|
|
250
|
+
ctx
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
return this.error("PARSE_ERROR", "AI: Agent object failed without text", { cause: error });
|
|
254
|
+
}
|
|
255
|
+
if (retryAttempts <= 0) return this.error("BAD_REQUEST", "AI: Provider failed to generate object", { cause: error });
|
|
256
|
+
this.logger.warn(`generateObject failed, retrying (${retryAttempts} attempts left)`, {
|
|
257
|
+
model,
|
|
258
|
+
error
|
|
259
|
+
});
|
|
260
|
+
const delay = Math.min(1e3 * 2 ** ((this.options?.retryAttempts ?? 3) - retryAttempts), 1e4);
|
|
261
|
+
await new Promise((resolve) => setTimeout(resolve, delay));
|
|
262
|
+
const nextModel = retryModels?.[0] ?? model;
|
|
263
|
+
const nextRetryModels = retryModels ? [...retryModels.slice(1), model] : void 0;
|
|
264
|
+
return this.generateObject({
|
|
265
|
+
...rest,
|
|
266
|
+
...messages ? { messages } : { prompt },
|
|
267
|
+
model: nextModel,
|
|
268
|
+
schema,
|
|
269
|
+
repairAttempts,
|
|
270
|
+
repairModel,
|
|
271
|
+
ctx,
|
|
272
|
+
retryAttempts: retryAttempts - 1,
|
|
273
|
+
retryModels: nextRetryModels
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
async generateReplicate(model, options) {
|
|
278
|
+
return this.throwableAsync(async () => {
|
|
279
|
+
if (!this.replicate) return this.error("INTERNAL_SERVER_ERROR", "Replicate is not configured");
|
|
280
|
+
try {
|
|
281
|
+
return (0, neverthrow.ok)(await this.replicate.run(model, options));
|
|
282
|
+
} catch (error) {
|
|
283
|
+
return this.error("INTERNAL_SERVER_ERROR", void 0, { cause: error });
|
|
284
|
+
}
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
async generateTranscript(file_url) {
|
|
288
|
+
const output = await this.generateReplicate("thomasmol/whisper-diarization:1495a9cddc83b2203b0d8d3516e38b80fd1572ebc4bc5700ac1da56a9b3ed886", { input: { file_url } });
|
|
289
|
+
if (output.isErr()) return (0, neverthrow.err)(output.error);
|
|
290
|
+
try {
|
|
291
|
+
const { segments } = output.value;
|
|
292
|
+
return (0, neverthrow.ok)({
|
|
293
|
+
text: segments.map((segment) => segment.text).join(""),
|
|
294
|
+
metadata: segments
|
|
295
|
+
});
|
|
296
|
+
} catch (error) {
|
|
297
|
+
return this.error("INTERNAL_SERVER_ERROR", void 0, { cause: error });
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
async generateIdeogram(input) {
|
|
301
|
+
if (!this.service.ideogram) return this.error("INTERNAL_SERVER_ERROR", "Ideogram service is not available");
|
|
302
|
+
return this.service.ideogram.generate(input);
|
|
303
|
+
}
|
|
304
|
+
async getUsage(userId) {
|
|
305
|
+
if (!this.repository.aiUsage) return this.error("INTERNAL_SERVER_ERROR", "AI usage repository is not available");
|
|
306
|
+
return this.repository.aiUsage.getUsage(userId);
|
|
307
|
+
}
|
|
308
|
+
};
|
|
309
|
+
//#endregion
|
|
310
|
+
exports.AIService = AIService;
|
|
311
|
+
|
|
312
|
+
//# sourceMappingURL=ai.service.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ai.service.cjs","names":["BaseService","RequestContext","OPENAI_TEXT_EMBEDDING_3_SMALL","MDocument","Output","NoObjectGeneratedError","repairJsonPrompt"],"sources":["../../../../src/modules/ai/ai.service.ts"],"sourcesContent":["import { OPENAI_TEXT_EMBEDDING_3_SMALL } from \"@m5kdev/commons/modules/ai/ai.constants\";\r\nimport { arrayToPseudoXML } from \"@m5kdev/commons/modules/ai/ai.utils\";\r\nimport type { Mastra } from \"@mastra/core\";\r\nimport { RequestContext } from \"@mastra/core/request-context\";\r\nimport type { FullOutput, MastraModelOutput } from \"@mastra/core/stream\";\r\nimport { MDocument } from \"@mastra/rag\";\r\nimport type { OpenRouterProvider } from \"@openrouter/ai-sdk-provider\";\r\nimport {\r\n embed,\r\n embedMany,\r\n generateText,\r\n type ModelMessage,\r\n NoObjectGeneratedError,\r\n Output,\r\n} from \"ai\";\r\nimport { jsonrepair } from \"jsonrepair\";\r\nimport { err, ok } from \"neverthrow\";\r\nimport type Replicate from \"replicate\";\r\nimport type { ZodType, z } from \"zod\";\r\nimport type { RequiredServiceActor } from \"../base/base.actor\";\r\nimport type { ServerResultAsync } from \"../base/base.dto\";\r\nimport { BaseService } from \"../base/base.service\";\r\nimport { repairJsonPrompt } from \"./ai.prompts\";\r\nimport type { AiUsageRepository, AiUsageRow } from \"./ai.repository\";\r\nimport type { IdeogramV3GenerateInput, IdeogramV3GenerateOutput } from \"./ideogram/ideogram.dto\";\r\nimport type { IdeogramService } from \"./ideogram/ideogram.service\";\r\n\r\ntype MastraAgent = ReturnType<Mastra[\"getAgent\"]>;\r\ntype MastraAgentGenerateOptions = Parameters<MastraAgent[\"generate\"]>[1];\r\ntype MessageListInput = { role: \"user\" | \"assistant\" | \"system\"; content: string }[];\r\ntype GenerateTextParams = Parameters<typeof generateText>[0];\r\ntype GenerateTextInput =\r\n | { prompt: string | ModelMessage[]; messages?: never }\r\n | { messages: ModelMessage[]; prompt?: never };\r\ntype AIServiceActorContext = { actor: RequiredServiceActor<\"user\"> };\r\ntype AIServiceGenerateTextParams = Omit<GenerateTextParams, \"model\" | \"prompt\" | \"messages\"> &\r\n GenerateTextInput & {\r\n model: string;\r\n removeMDash?: boolean;\r\n ctx?: AIServiceActorContext;\r\n retryAttempts?: number;\r\n retryModels?: string[];\r\n };\r\ntype AIServiceGenerateObjectParams<T extends ZodType> = Omit<\r\n GenerateTextParams,\r\n \"model\" | \"prompt\" | \"messages\" | \"output\"\r\n> &\r\n GenerateTextInput & {\r\n model: string;\r\n schema: T;\r\n repairAttempts?: number;\r\n repairModel?: string;\r\n ctx?: AIServiceActorContext;\r\n retryAttempts?: number;\r\n retryModels?: string[];\r\n };\r\n\r\ntype AIServiceOptions = {\r\n retryAttempts?: number;\r\n retryModels?: string[];\r\n repairAttempts?: number;\r\n repairModel?: string;\r\n removeMDash?: boolean;\r\n};\r\n\r\nexport class AIService<MastraInstance extends Mastra> extends BaseService<\r\n { aiUsage?: AiUsageRepository },\r\n { ideogram?: IdeogramService }\r\n> {\r\n helpers = {\r\n arrayToPseudoXML,\r\n };\r\n\r\n mastra?: MastraInstance;\r\n openrouter?: OpenRouterProvider;\r\n replicate?: Replicate;\r\n options?: AIServiceOptions;\r\n\r\n constructor(\r\n repositories: { aiUsage?: AiUsageRepository },\r\n services: { ideogram?: IdeogramService },\r\n libs: { mastra?: MastraInstance; openrouter?: OpenRouterProvider; replicate?: Replicate },\r\n options?: AIServiceOptions\r\n ) {\r\n super(repositories, services);\r\n this.mastra = libs.mastra;\r\n this.openrouter = libs.openrouter;\r\n this.replicate = libs.replicate;\r\n this.options = options;\r\n }\r\n\r\n getMastra(): MastraInstance {\r\n if (!this.mastra) {\r\n throw new Error(\"Mastra is not available\");\r\n }\r\n return this.mastra;\r\n }\r\n\r\n prepareModel(model: string): ReturnType<OpenRouterProvider[\"chat\"]> {\r\n if (!this.openrouter) {\r\n throw new Error(\"OpenRouter is not configured\");\r\n }\r\n return this.openrouter.chat(model, {\r\n usage: {\r\n include: true,\r\n },\r\n });\r\n }\r\n\r\n prepareEmbeddingModel(model: string): ReturnType<OpenRouterProvider[\"textEmbeddingModel\"]> {\r\n if (!this.openrouter) {\r\n throw new Error(\"OpenRouter is not configured\");\r\n }\r\n const openrouter = this.openrouter as OpenRouterProvider & {\r\n embeddingModel?: (modelId: string) => unknown;\r\n };\r\n return (openrouter.embeddingModel?.(model) ??\r\n openrouter.textEmbeddingModel(model)) as ReturnType<OpenRouterProvider[\"textEmbeddingModel\"]>;\r\n }\r\n\r\n async agentUse(\r\n agent: string,\r\n options: MastraAgentGenerateOptions & { prompt?: string; messages?: MessageListInput },\r\n ctx?: AIServiceActorContext & { model?: string }\r\n ): ServerResultAsync<Awaited<ReturnType<MastraModelOutput<any>[\"getFullOutput\"]>>> {\r\n return this.throwableAsync(async () => {\r\n this.logger.info(\"AGENT USE\");\r\n const { prompt, messages, ...rest } = options;\r\n const payload = messages || prompt;\r\n if (!payload) return this.error(\"BAD_REQUEST\", \"No prompt or messages provided\");\r\n const requestContext = options.requestContext ?? new RequestContext();\r\n\r\n if (ctx?.actor) {\r\n requestContext.set(\"userId\", ctx.actor.userId);\r\n }\r\n if (ctx?.model) {\r\n requestContext.set(\"model\", ctx.model);\r\n }\r\n const mAgent = this.getMastra().getAgent(agent);\r\n\r\n const result = await mAgent.generate(payload as any, {\r\n ...rest,\r\n requestContext: rest.requestContext ?? requestContext,\r\n });\r\n this.logger.info(\"AGENT USE DONE\");\r\n if (this.repository.aiUsage) {\r\n const createUsageResult = await this.repository.aiUsage.create({\r\n userId: ctx?.actor?.userId,\r\n model: ctx?.model ?? \"unknown\",\r\n provider: \"openrouter\",\r\n feature: agent,\r\n traceId: result.traceId,\r\n inputTokens: result.usage.inputTokens,\r\n outputTokens: result.usage.outputTokens,\r\n totalTokens: result.usage.totalTokens,\r\n cost: (result?.providerMetadata?.openrouter?.usage as any)?.cost ?? 0,\r\n });\r\n if (createUsageResult.isErr()) return err(createUsageResult.error);\r\n }\r\n this.logger.info(\"AGENT USE CREATED USAGE\");\r\n return ok(result);\r\n });\r\n }\r\n\r\n async agentText(\r\n agent: string,\r\n options: MastraAgentGenerateOptions & { prompt?: string; messages?: MessageListInput },\r\n ctx?: AIServiceActorContext & { model?: string }\r\n ): ServerResultAsync<string> {\r\n const result = await this.agentUse(agent, options, ctx);\r\n if (result.isErr())\r\n return this.error(\"SERVICE_UNAVAILABLE\", \"AI: Agent text failed\", { cause: result.error });\r\n return ok(result.value.text);\r\n }\r\n\r\n async agentTextResult(\r\n agent: string,\r\n options: MastraAgentGenerateOptions & { prompt?: string; messages?: MessageListInput },\r\n ctx?: AIServiceActorContext & { model?: string }\r\n ): ServerResultAsync<FullOutput<any>> {\r\n const result = await this.agentUse(agent, options, ctx);\r\n if (result.isErr()) return err(result.error);\r\n return ok(result.value);\r\n }\r\n\r\n async agentObject<T extends ZodType<any>>(\r\n agent: string,\r\n options: MastraAgentGenerateOptions & {\r\n schema: T;\r\n prompt?: string;\r\n messages?: MessageListInput;\r\n },\r\n ctx?: AIServiceActorContext & { model?: string }\r\n ): ServerResultAsync<z.infer<T>> {\r\n const { schema, ...rest } = options;\r\n const result = await this.agentUse(agent, { ...rest, structuredOutput: { schema } }, ctx);\r\n if (result.isErr())\r\n return this.error(\"SERVICE_UNAVAILABLE\", \"AI: Agent object failed\", { cause: result.error });\r\n return ok(result.value.object as z.infer<T>);\r\n }\r\n\r\n async agentObjectResult<T extends ZodType<any>>(\r\n agent: string,\r\n options: MastraAgentGenerateOptions & {\r\n schema: T;\r\n prompt?: string;\r\n messages?: MessageListInput;\r\n },\r\n ctx?: AIServiceActorContext & { model?: string }\r\n ): ServerResultAsync<FullOutput<any> & { object: z.infer<T> }> {\r\n this.logger.info(\"AGENT OBJECT RESULT\");\r\n const { schema, ...rest } = options;\r\n const result = await this.agentUse(agent, { ...rest, structuredOutput: { schema } }, ctx);\r\n if (result.isErr()) return err(result.error);\r\n this.logger.info(\"AGENT OBJECT RESULT DONE\");\r\n return ok({ ...result.value, object: result.value.object as z.infer<T> });\r\n }\r\n\r\n async embedDocument(\r\n value: string,\r\n options?: Parameters<ReturnType<typeof MDocument.fromText>[\"chunk\"]>[0],\r\n type: \"text\" | \"markdown\" | \"html\" | \"json\" = \"text\",\r\n model: string = OPENAI_TEXT_EMBEDDING_3_SMALL\r\n ): ServerResultAsync<{ embeddings: number[][]; chunks: { text: string }[] }> {\r\n return this.throwableAsync(async () => {\r\n if (type === \"text\") {\r\n const doc = MDocument.fromText(value);\r\n const chunks = await doc.chunk(\r\n options ?? {\r\n strategy: \"recursive\",\r\n maxSize: 512,\r\n overlap: 50,\r\n separators: [\"\\n\"],\r\n }\r\n );\r\n const embeddings = await this.embedMany(chunks, model);\r\n if (embeddings.isErr()) return err(embeddings.error);\r\n return ok({ embeddings: embeddings.value.embeddings, chunks });\r\n }\r\n return this.error(\"BAD_REQUEST\", \"Unsupported document type\");\r\n });\r\n }\r\n\r\n async embed(\r\n text: string,\r\n model: string = OPENAI_TEXT_EMBEDDING_3_SMALL\r\n ): ServerResultAsync<{ embedding: number[] }> {\r\n return this.throwableAsync(async () => {\r\n const result = await embed({\r\n model: this.prepareEmbeddingModel(model),\r\n value: text,\r\n });\r\n return ok(result);\r\n });\r\n }\r\n\r\n async embedMany(\r\n chunks: { text: string }[],\r\n model: string = OPENAI_TEXT_EMBEDDING_3_SMALL\r\n ): ServerResultAsync<{ embeddings: number[][] }> {\r\n return this.throwableAsync(async () => {\r\n const result = await embedMany({\r\n model: this.prepareEmbeddingModel(model),\r\n values: chunks.map((chunk) => chunk.text),\r\n });\r\n return ok(result);\r\n });\r\n }\r\n\r\n async generateText(params: AIServiceGenerateTextParams): ServerResultAsync<string> {\r\n return this.throwableAsync(async () => {\r\n const {\r\n removeMDash = this.options?.removeMDash ?? true,\r\n model,\r\n prompt,\r\n messages,\r\n ctx,\r\n retryAttempts = this.options?.retryAttempts ?? 0,\r\n retryModels = this.options?.retryModels ?? [],\r\n ...rest\r\n } = params;\r\n const request = messages\r\n ? { ...rest, model: this.prepareModel(model), messages }\r\n : { ...rest, model: this.prepareModel(model), prompt };\r\n try {\r\n const result = await generateText(request);\r\n if (this.repository.aiUsage) {\r\n const createUsageResult = await this.repository.aiUsage.create({\r\n userId: ctx?.actor?.userId,\r\n model,\r\n provider: \"openrouter\",\r\n feature: \"generateText\",\r\n traceId: result.providerMetadata?.openrouter?.traceId?.toString(),\r\n inputTokens: result.usage.inputTokens,\r\n outputTokens: result.usage.outputTokens,\r\n totalTokens: result.usage.totalTokens,\r\n cost: (result?.providerMetadata?.openrouter?.usage as any)?.cost ?? 0,\r\n });\r\n if (createUsageResult.isErr()) return err(createUsageResult.error);\r\n }\r\n return ok(removeMDash ? result.text.replace(/\\u2013|\\u2014/g, \"-\") : result.text);\r\n } catch (error) {\r\n if (retryAttempts <= 0) throw error;\r\n this.logger.warn(`generateText failed, retrying (${retryAttempts} attempts left)`, {\r\n model,\r\n error,\r\n });\r\n // Exponential backoff: wait before retrying\r\n const delay = Math.min(\r\n 1000 * 2 ** ((this.options?.retryAttempts ?? 3) - retryAttempts),\r\n 10000\r\n );\r\n await new Promise<void>((resolve) => setTimeout(resolve, delay));\r\n const nextModel = retryModels?.[0] ?? model;\r\n const nextRetryModels = retryModels ? [...retryModels.slice(1), model] : undefined;\r\n return this.generateText({\r\n ...rest,\r\n ...(messages ? { messages } : { prompt: prompt! }),\r\n model: nextModel,\r\n removeMDash,\r\n ctx,\r\n retryAttempts: retryAttempts - 1,\r\n retryModels: nextRetryModels,\r\n } as AIServiceGenerateTextParams);\r\n }\r\n });\r\n }\r\n\r\n async generateObject<T extends ZodType>(\r\n params: AIServiceGenerateObjectParams<T>\r\n ): ServerResultAsync<z.infer<T>> {\r\n const {\r\n model,\r\n schema,\r\n prompt,\r\n messages,\r\n repairAttempts = this.options?.repairAttempts ?? 0,\r\n repairModel = this.options?.repairModel ?? model,\r\n ctx,\r\n retryAttempts = this.options?.retryAttempts ?? 0,\r\n retryModels = this.options?.retryModels ?? [],\r\n ...rest\r\n } = params;\r\n const request = messages\r\n ? {\r\n ...rest,\r\n model: this.prepareModel(model),\r\n messages,\r\n output: Output.object({ schema }),\r\n }\r\n : {\r\n ...rest,\r\n model: this.prepareModel(model),\r\n prompt,\r\n output: Output.object({ schema }),\r\n };\r\n try {\r\n const result = await generateText(request);\r\n if (this.repository.aiUsage) {\r\n const createUsageResult = await this.repository.aiUsage.create({\r\n userId: ctx?.actor?.userId,\r\n model,\r\n provider: \"openrouter\",\r\n feature: \"generateObject\",\r\n traceId: result.providerMetadata?.openrouter?.traceId?.toString(),\r\n inputTokens: result.usage.inputTokens,\r\n outputTokens: result.usage.outputTokens,\r\n totalTokens: result.usage.totalTokens,\r\n cost: (result?.providerMetadata?.openrouter?.usage as any)?.cost ?? 0,\r\n });\r\n if (createUsageResult.isErr()) return err(createUsageResult.error);\r\n }\r\n return ok(result.output as z.infer<T>);\r\n } catch (error) {\r\n if (NoObjectGeneratedError.isInstance(error)) {\r\n if (this.repository.aiUsage) {\r\n const createUsageResult = await this.repository.aiUsage.create({\r\n userId: ctx?.actor?.userId,\r\n model,\r\n provider: \"openrouter\",\r\n feature: \"generateObject\",\r\n traceId: null,\r\n inputTokens: error?.usage?.inputTokens,\r\n outputTokens: error?.usage?.outputTokens,\r\n totalTokens: error?.usage?.totalTokens,\r\n cost: 0,\r\n });\r\n if (createUsageResult.isErr()) return err(createUsageResult.error);\r\n }\r\n if (error.text) {\r\n const repairedText = jsonrepair(error.text);\r\n const parsed = schema.safeParse(repairedText);\r\n if (parsed.success) return ok(parsed.data);\r\n\r\n if (repairAttempts === 0)\r\n return this.error(\"PARSE_ERROR\", \"AI: Agent object failed\", { cause: error });\r\n\r\n return this.generateObject({\r\n ...rest,\r\n prompt: repairJsonPrompt.compile({\r\n text: error.text,\r\n error: JSON.stringify(error.cause ?? \"Unknown error\"),\r\n }),\r\n repairAttempts: repairAttempts - 1,\r\n model: repairModel ?? model,\r\n schema,\r\n ctx,\r\n });\r\n }\r\n return this.error(\"PARSE_ERROR\", \"AI: Agent object failed without text\", {\r\n cause: error,\r\n });\r\n }\r\n if (retryAttempts <= 0)\r\n return this.error(\"BAD_REQUEST\", \"AI: Provider failed to generate object\", {\r\n cause: error,\r\n });\r\n this.logger.warn(`generateObject failed, retrying (${retryAttempts} attempts left)`, {\r\n model,\r\n error,\r\n });\r\n // Exponential backoff: wait before retrying\r\n const delay = Math.min(\r\n 1000 * 2 ** ((this.options?.retryAttempts ?? 3) - retryAttempts),\r\n 10000\r\n );\r\n await new Promise<void>((resolve) => setTimeout(resolve, delay));\r\n const nextModel = retryModels?.[0] ?? model;\r\n const nextRetryModels = retryModels ? [...retryModels.slice(1), model] : undefined;\r\n return this.generateObject({\r\n ...rest,\r\n ...(messages ? { messages } : { prompt: prompt! }),\r\n model: nextModel,\r\n schema,\r\n repairAttempts,\r\n repairModel,\r\n ctx,\r\n retryAttempts: retryAttempts - 1,\r\n retryModels: nextRetryModels,\r\n } as AIServiceGenerateObjectParams<T>);\r\n }\r\n }\r\n\r\n async generateReplicate(\r\n model: Parameters<Replicate[\"run\"]>[0],\r\n options: Parameters<Replicate[\"run\"]>[1]\r\n ): ServerResultAsync<object> {\r\n return this.throwableAsync(async () => {\r\n if (!this.replicate) {\r\n return this.error(\"INTERNAL_SERVER_ERROR\", \"Replicate is not configured\");\r\n }\r\n try {\r\n return ok(await this.replicate.run(model, options));\r\n } catch (error) {\r\n return this.error(\"INTERNAL_SERVER_ERROR\", undefined, { cause: error });\r\n }\r\n });\r\n }\r\n\r\n async generateTranscript(\r\n file_url: string\r\n ): ServerResultAsync<{ text: string; metadata: unknown }> {\r\n const output = await this.generateReplicate(\r\n \"thomasmol/whisper-diarization:1495a9cddc83b2203b0d8d3516e38b80fd1572ebc4bc5700ac1da56a9b3ed886\",\r\n {\r\n input: {\r\n file_url,\r\n },\r\n }\r\n );\r\n\r\n if (output.isErr()) return err(output.error);\r\n\r\n try {\r\n const { segments } = output.value as { segments: { text: string }[] };\r\n return ok({ text: segments.map((segment) => segment.text).join(\"\"), metadata: segments });\r\n } catch (error) {\r\n return this.error(\"INTERNAL_SERVER_ERROR\", undefined, { cause: error });\r\n }\r\n }\r\n\r\n async generateIdeogram(\r\n input: IdeogramV3GenerateInput\r\n ): ServerResultAsync<IdeogramV3GenerateOutput> {\r\n if (!this.service.ideogram) {\r\n return this.error(\"INTERNAL_SERVER_ERROR\", \"Ideogram service is not available\");\r\n }\r\n return this.service.ideogram.generate(input);\r\n }\r\n\r\n async getUsage(\r\n userId: string\r\n ): ServerResultAsync<Pick<AiUsageRow, \"inputTokens\" | \"outputTokens\" | \"totalTokens\" | \"cost\">> {\r\n if (!this.repository.aiUsage) {\r\n return this.error(\"INTERNAL_SERVER_ERROR\", \"AI usage repository is not available\");\r\n }\r\n return this.repository.aiUsage.getUsage(userId);\r\n }\r\n}\r\n"],"mappings":"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"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { ServerResultAsync } from "../base/base.dto.cjs";
|
|
2
|
+
import { RequiredServiceActor } from "../base/base.actor.cjs";
|
|
3
|
+
import { BaseService } from "../base/base.service.cjs";
|
|
4
|
+
import { AiUsageRepository, AiUsageRow } from "./ai.repository.cjs";
|
|
5
|
+
import { IdeogramV3GenerateInput, IdeogramV3GenerateOutput } from "./ideogram/ideogram.dto.cjs";
|
|
6
|
+
import { IdeogramService } from "./ideogram/ideogram.service.cjs";
|
|
7
|
+
import { ZodType, z } from "zod";
|
|
8
|
+
import { arrayToPseudoXML } from "@m5kdev/commons/modules/ai/ai.utils";
|
|
9
|
+
import { Mastra } from "@mastra/core";
|
|
10
|
+
import { FullOutput, MastraModelOutput } from "@mastra/core/stream";
|
|
11
|
+
import { MDocument } from "@mastra/rag";
|
|
12
|
+
import { OpenRouterProvider } from "@openrouter/ai-sdk-provider";
|
|
13
|
+
import { ModelMessage, generateText } from "ai";
|
|
14
|
+
import Replicate from "replicate";
|
|
15
|
+
|
|
16
|
+
//#region src/modules/ai/ai.service.d.ts
|
|
17
|
+
type MastraAgent = ReturnType<Mastra["getAgent"]>;
|
|
18
|
+
type MastraAgentGenerateOptions = Parameters<MastraAgent["generate"]>[1];
|
|
19
|
+
type MessageListInput = {
|
|
20
|
+
role: "user" | "assistant" | "system";
|
|
21
|
+
content: string;
|
|
22
|
+
}[];
|
|
23
|
+
type GenerateTextParams = Parameters<typeof generateText>[0];
|
|
24
|
+
type GenerateTextInput = {
|
|
25
|
+
prompt: string | ModelMessage[];
|
|
26
|
+
messages?: never;
|
|
27
|
+
} | {
|
|
28
|
+
messages: ModelMessage[];
|
|
29
|
+
prompt?: never;
|
|
30
|
+
};
|
|
31
|
+
type AIServiceActorContext = {
|
|
32
|
+
actor: RequiredServiceActor<"user">;
|
|
33
|
+
};
|
|
34
|
+
type AIServiceGenerateTextParams = Omit<GenerateTextParams, "model" | "prompt" | "messages"> & GenerateTextInput & {
|
|
35
|
+
model: string;
|
|
36
|
+
removeMDash?: boolean;
|
|
37
|
+
ctx?: AIServiceActorContext;
|
|
38
|
+
retryAttempts?: number;
|
|
39
|
+
retryModels?: string[];
|
|
40
|
+
};
|
|
41
|
+
type AIServiceGenerateObjectParams<T extends ZodType> = Omit<GenerateTextParams, "model" | "prompt" | "messages" | "output"> & GenerateTextInput & {
|
|
42
|
+
model: string;
|
|
43
|
+
schema: T;
|
|
44
|
+
repairAttempts?: number;
|
|
45
|
+
repairModel?: string;
|
|
46
|
+
ctx?: AIServiceActorContext;
|
|
47
|
+
retryAttempts?: number;
|
|
48
|
+
retryModels?: string[];
|
|
49
|
+
};
|
|
50
|
+
type AIServiceOptions = {
|
|
51
|
+
retryAttempts?: number;
|
|
52
|
+
retryModels?: string[];
|
|
53
|
+
repairAttempts?: number;
|
|
54
|
+
repairModel?: string;
|
|
55
|
+
removeMDash?: boolean;
|
|
56
|
+
};
|
|
57
|
+
declare class AIService<MastraInstance extends Mastra> extends BaseService<{
|
|
58
|
+
aiUsage?: AiUsageRepository;
|
|
59
|
+
}, {
|
|
60
|
+
ideogram?: IdeogramService;
|
|
61
|
+
}> {
|
|
62
|
+
helpers: {
|
|
63
|
+
arrayToPseudoXML: typeof arrayToPseudoXML;
|
|
64
|
+
};
|
|
65
|
+
mastra?: MastraInstance;
|
|
66
|
+
openrouter?: OpenRouterProvider;
|
|
67
|
+
replicate?: Replicate;
|
|
68
|
+
options?: AIServiceOptions;
|
|
69
|
+
constructor(repositories: {
|
|
70
|
+
aiUsage?: AiUsageRepository;
|
|
71
|
+
}, services: {
|
|
72
|
+
ideogram?: IdeogramService;
|
|
73
|
+
}, libs: {
|
|
74
|
+
mastra?: MastraInstance;
|
|
75
|
+
openrouter?: OpenRouterProvider;
|
|
76
|
+
replicate?: Replicate;
|
|
77
|
+
}, options?: AIServiceOptions);
|
|
78
|
+
getMastra(): MastraInstance;
|
|
79
|
+
prepareModel(model: string): ReturnType<OpenRouterProvider["chat"]>;
|
|
80
|
+
prepareEmbeddingModel(model: string): ReturnType<OpenRouterProvider["textEmbeddingModel"]>;
|
|
81
|
+
agentUse(agent: string, options: MastraAgentGenerateOptions & {
|
|
82
|
+
prompt?: string;
|
|
83
|
+
messages?: MessageListInput;
|
|
84
|
+
}, ctx?: AIServiceActorContext & {
|
|
85
|
+
model?: string;
|
|
86
|
+
}): ServerResultAsync<Awaited<ReturnType<MastraModelOutput<any>["getFullOutput"]>>>;
|
|
87
|
+
agentText(agent: string, options: MastraAgentGenerateOptions & {
|
|
88
|
+
prompt?: string;
|
|
89
|
+
messages?: MessageListInput;
|
|
90
|
+
}, ctx?: AIServiceActorContext & {
|
|
91
|
+
model?: string;
|
|
92
|
+
}): ServerResultAsync<string>;
|
|
93
|
+
agentTextResult(agent: string, options: MastraAgentGenerateOptions & {
|
|
94
|
+
prompt?: string;
|
|
95
|
+
messages?: MessageListInput;
|
|
96
|
+
}, ctx?: AIServiceActorContext & {
|
|
97
|
+
model?: string;
|
|
98
|
+
}): ServerResultAsync<FullOutput<any>>;
|
|
99
|
+
agentObject<T extends ZodType<any>>(agent: string, options: MastraAgentGenerateOptions & {
|
|
100
|
+
schema: T;
|
|
101
|
+
prompt?: string;
|
|
102
|
+
messages?: MessageListInput;
|
|
103
|
+
}, ctx?: AIServiceActorContext & {
|
|
104
|
+
model?: string;
|
|
105
|
+
}): ServerResultAsync<z.infer<T>>;
|
|
106
|
+
agentObjectResult<T extends ZodType<any>>(agent: string, options: MastraAgentGenerateOptions & {
|
|
107
|
+
schema: T;
|
|
108
|
+
prompt?: string;
|
|
109
|
+
messages?: MessageListInput;
|
|
110
|
+
}, ctx?: AIServiceActorContext & {
|
|
111
|
+
model?: string;
|
|
112
|
+
}): ServerResultAsync<FullOutput<any> & {
|
|
113
|
+
object: z.infer<T>;
|
|
114
|
+
}>;
|
|
115
|
+
embedDocument(value: string, options?: Parameters<ReturnType<typeof MDocument.fromText>["chunk"]>[0], type?: "text" | "markdown" | "html" | "json", model?: string): ServerResultAsync<{
|
|
116
|
+
embeddings: number[][];
|
|
117
|
+
chunks: {
|
|
118
|
+
text: string;
|
|
119
|
+
}[];
|
|
120
|
+
}>;
|
|
121
|
+
embed(text: string, model?: string): ServerResultAsync<{
|
|
122
|
+
embedding: number[];
|
|
123
|
+
}>;
|
|
124
|
+
embedMany(chunks: {
|
|
125
|
+
text: string;
|
|
126
|
+
}[], model?: string): ServerResultAsync<{
|
|
127
|
+
embeddings: number[][];
|
|
128
|
+
}>;
|
|
129
|
+
generateText(params: AIServiceGenerateTextParams): ServerResultAsync<string>;
|
|
130
|
+
generateObject<T extends ZodType>(params: AIServiceGenerateObjectParams<T>): ServerResultAsync<z.infer<T>>;
|
|
131
|
+
generateReplicate(model: Parameters<Replicate["run"]>[0], options: Parameters<Replicate["run"]>[1]): ServerResultAsync<object>;
|
|
132
|
+
generateTranscript(file_url: string): ServerResultAsync<{
|
|
133
|
+
text: string;
|
|
134
|
+
metadata: unknown;
|
|
135
|
+
}>;
|
|
136
|
+
generateIdeogram(input: IdeogramV3GenerateInput): ServerResultAsync<IdeogramV3GenerateOutput>;
|
|
137
|
+
getUsage(userId: string): ServerResultAsync<Pick<AiUsageRow, "inputTokens" | "outputTokens" | "totalTokens" | "cost">>;
|
|
138
|
+
}
|
|
139
|
+
//#endregion
|
|
140
|
+
export { AIService };
|
|
141
|
+
//# sourceMappingURL=ai.service.d.cts.map
|
|
@@ -0,0 +1,19 @@
|
|
|
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
|
+
let zod = require("zod");
|
|
5
|
+
//#region src/modules/ai/ai.trpc.ts
|
|
6
|
+
function createAITRPC({ router, adminProcedure }, aiService) {
|
|
7
|
+
return router({ getUserUsage: adminProcedure.input(zod.z.object({ userId: zod.z.string() })).output(zod.z.object({
|
|
8
|
+
inputTokens: zod.z.number().nullable(),
|
|
9
|
+
outputTokens: zod.z.number().nullable(),
|
|
10
|
+
totalTokens: zod.z.number().nullable(),
|
|
11
|
+
cost: zod.z.number().nullable()
|
|
12
|
+
})).query(async ({ input }) => {
|
|
13
|
+
return require_src_utils_trpc.handleTRPCResult(await aiService.getUsage(input.userId));
|
|
14
|
+
}) });
|
|
15
|
+
}
|
|
16
|
+
//#endregion
|
|
17
|
+
exports.createAITRPC = createAITRPC;
|
|
18
|
+
|
|
19
|
+
//# sourceMappingURL=ai.trpc.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ai.trpc.cjs","names":["z","handleTRPCResult"],"sources":["../../../../src/modules/ai/ai.trpc.ts"],"sourcesContent":["import type { Mastra } from \"@mastra/core\";\r\nimport { z } from \"zod\";\r\nimport type { AIService } from \"./ai.service\";\r\nimport { handleTRPCResult, type TRPCMethods } from \"../../utils/trpc\";\r\n\r\nexport function createAITRPC<MastraInstance extends Mastra>(\r\n { router, adminProcedure }: TRPCMethods,\r\n aiService: AIService<MastraInstance>\r\n) {\r\n return router({\r\n getUserUsage: adminProcedure\r\n .input(z.object({ userId: z.string() }))\r\n .output(\r\n z.object({\r\n inputTokens: z.number().nullable(),\r\n outputTokens: z.number().nullable(),\r\n totalTokens: z.number().nullable(),\r\n cost: z.number().nullable(),\r\n })\r\n )\r\n .query(async ({ input }) => {\r\n return handleTRPCResult(await aiService.getUsage(input.userId));\r\n }),\r\n });\r\n}\r\n"],"mappings":";;;;;AAKA,SAAgB,aACd,EAAE,QAAQ,kBACV,WACA;AACA,QAAO,OAAO,EACZ,cAAc,eACX,MAAMA,IAAAA,EAAE,OAAO,EAAE,QAAQA,IAAAA,EAAE,QAAQ,EAAE,CAAC,CAAC,CACvC,OACCA,IAAAA,EAAE,OAAO;EACP,aAAaA,IAAAA,EAAE,QAAQ,CAAC,UAAU;EAClC,cAAcA,IAAAA,EAAE,QAAQ,CAAC,UAAU;EACnC,aAAaA,IAAAA,EAAE,QAAQ,CAAC,UAAU;EAClC,MAAMA,IAAAA,EAAE,QAAQ,CAAC,UAAU;EAC5B,CAAC,CACH,CACA,MAAM,OAAO,EAAE,YAAY;AAC1B,SAAOC,uBAAAA,iBAAiB,MAAM,UAAU,SAAS,MAAM,OAAO,CAAC;GAC/D,EACL,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Context, TRPCMethods } from "../../utils/trpc.cjs";
|
|
2
|
+
import { AIService } from "./ai.service.cjs";
|
|
3
|
+
import * as _$_trpc_server0 from "@trpc/server";
|
|
4
|
+
import { Mastra } from "@mastra/core";
|
|
5
|
+
|
|
6
|
+
//#region src/modules/ai/ai.trpc.d.ts
|
|
7
|
+
declare function createAITRPC<MastraInstance extends Mastra>({
|
|
8
|
+
router,
|
|
9
|
+
adminProcedure
|
|
10
|
+
}: TRPCMethods, aiService: AIService<MastraInstance>): _$_trpc_server0.TRPCBuiltRouter<{
|
|
11
|
+
ctx: Context;
|
|
12
|
+
meta: any;
|
|
13
|
+
errorShape: _$_trpc_server0.TRPCDefaultErrorShape;
|
|
14
|
+
transformer: true;
|
|
15
|
+
}, _$_trpc_server0.TRPCDecorateCreateRouterOptions<{
|
|
16
|
+
getUserUsage: _$_trpc_server0.TRPCQueryProcedure<{
|
|
17
|
+
input: {
|
|
18
|
+
userId: string;
|
|
19
|
+
};
|
|
20
|
+
output: {
|
|
21
|
+
inputTokens: number | null;
|
|
22
|
+
outputTokens: number | null;
|
|
23
|
+
totalTokens: number | null;
|
|
24
|
+
cost: number | null;
|
|
25
|
+
};
|
|
26
|
+
meta: any;
|
|
27
|
+
}>;
|
|
28
|
+
}>>;
|
|
29
|
+
//#endregion
|
|
30
|
+
export { createAITRPC };
|
|
31
|
+
//# sourceMappingURL=ai.trpc.d.cts.map
|