@agentforge-io/nest 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +486 -0
- package/dist/agent-forge.module.d.ts +21 -0
- package/dist/agent-forge.module.js +144 -0
- package/dist/agent-forge.module.js.map +1 -0
- package/dist/auth/current-user.decorator.d.ts +8 -0
- package/dist/auth/current-user.decorator.js +9 -0
- package/dist/auth/current-user.decorator.js.map +1 -0
- package/dist/auth/public.decorator.d.ts +2 -0
- package/dist/auth/public.decorator.js +8 -0
- package/dist/auth/public.decorator.js.map +1 -0
- package/dist/constants.d.ts +2 -0
- package/dist/constants.js +9 -0
- package/dist/constants.js.map +1 -0
- package/dist/core/agent-runner.service.d.ts +1 -0
- package/dist/core/agent-runner.service.js +6 -0
- package/dist/core/agent-runner.service.js.map +1 -0
- package/dist/core/orchestrator.service.d.ts +2 -0
- package/dist/core/orchestrator.service.js +7 -0
- package/dist/core/orchestrator.service.js.map +1 -0
- package/dist/core/tool-registry.service.d.ts +1 -0
- package/dist/core/tool-registry.service.js +6 -0
- package/dist/core/tool-registry.service.js.map +1 -0
- package/dist/database/entities/auth-identity.entity.d.ts +1 -0
- package/dist/database/entities/auth-identity.entity.js +6 -0
- package/dist/database/entities/auth-identity.entity.js.map +1 -0
- package/dist/database/entities/conversation.entity.d.ts +1 -0
- package/dist/database/entities/conversation.entity.js +6 -0
- package/dist/database/entities/conversation.entity.js.map +1 -0
- package/dist/database/entities/email-token.entity.d.ts +1 -0
- package/dist/database/entities/email-token.entity.js +6 -0
- package/dist/database/entities/email-token.entity.js.map +1 -0
- package/dist/database/entities/index.d.ts +7 -0
- package/dist/database/entities/index.js +16 -0
- package/dist/database/entities/index.js.map +1 -0
- package/dist/database/entities/message.entity.d.ts +1 -0
- package/dist/database/entities/message.entity.js +6 -0
- package/dist/database/entities/message.entity.js.map +1 -0
- package/dist/database/entities/refresh-token.entity.d.ts +1 -0
- package/dist/database/entities/refresh-token.entity.js +6 -0
- package/dist/database/entities/refresh-token.entity.js.map +1 -0
- package/dist/database/entities/subscription.entity.d.ts +1 -0
- package/dist/database/entities/subscription.entity.js +6 -0
- package/dist/database/entities/subscription.entity.js.map +1 -0
- package/dist/database/entities/usage-record.entity.d.ts +1 -0
- package/dist/database/entities/usage-record.entity.js +6 -0
- package/dist/database/entities/usage-record.entity.js.map +1 -0
- package/dist/database/entities/user.entity.d.ts +1 -0
- package/dist/database/entities/user.entity.js +6 -0
- package/dist/database/entities/user.entity.js.map +1 -0
- package/dist/decorators/agent-tool.decorator.d.ts +21 -0
- package/dist/decorators/agent-tool.decorator.js +12 -0
- package/dist/decorators/agent-tool.decorator.js.map +1 -0
- package/dist/decorators/rate-limit.decorator.d.ts +9 -0
- package/dist/decorators/rate-limit.decorator.js +11 -0
- package/dist/decorators/rate-limit.decorator.js.map +1 -0
- package/dist/decorators/require-plan.decorator.d.ts +2 -0
- package/dist/decorators/require-plan.decorator.js +8 -0
- package/dist/decorators/require-plan.decorator.js.map +1 -0
- package/dist/filters/agentforge-exception.filter.d.ts +5 -0
- package/dist/filters/agentforge-exception.filter.js +40 -0
- package/dist/filters/agentforge-exception.filter.js.map +1 -0
- package/dist/guards/rate-limit.guard.d.ts +10 -0
- package/dist/guards/rate-limit.guard.js +73 -0
- package/dist/guards/rate-limit.guard.js.map +1 -0
- package/dist/guards/usage-limit.guard.d.ts +11 -0
- package/dist/guards/usage-limit.guard.js +57 -0
- package/dist/guards/usage-limit.guard.js.map +1 -0
- package/dist/index.d.ts +16 -0
- package/dist/index.js +35 -0
- package/dist/index.js.map +1 -0
- package/dist/interceptors/usage-tracking.interceptor.d.ts +6 -0
- package/dist/interceptors/usage-tracking.interceptor.js +30 -0
- package/dist/interceptors/usage-tracking.interceptor.js.map +1 -0
- package/dist/modules/admin/admin-plans.controller.d.ts +11 -0
- package/dist/modules/admin/admin-plans.controller.js +97 -0
- package/dist/modules/admin/admin-plans.controller.js.map +1 -0
- package/dist/modules/admin/admin-tenant-agents.controller.d.ts +61 -0
- package/dist/modules/admin/admin-tenant-agents.controller.js +424 -0
- package/dist/modules/admin/admin-tenant-agents.controller.js.map +1 -0
- package/dist/modules/admin/admin-tenant-billing.controller.d.ts +51 -0
- package/dist/modules/admin/admin-tenant-billing.controller.js +119 -0
- package/dist/modules/admin/admin-tenant-billing.controller.js.map +1 -0
- package/dist/modules/admin/admin-tenants.controller.d.ts +43 -0
- package/dist/modules/admin/admin-tenants.controller.js +178 -0
- package/dist/modules/admin/admin-tenants.controller.js.map +1 -0
- package/dist/modules/admin/admin-users.controller.d.ts +41 -0
- package/dist/modules/admin/admin-users.controller.js +121 -0
- package/dist/modules/admin/admin-users.controller.js.map +1 -0
- package/dist/modules/admin/admin.module.d.ts +2 -0
- package/dist/modules/admin/admin.module.js +26 -0
- package/dist/modules/admin/admin.module.js.map +1 -0
- package/dist/modules/admin/platform-admin.guard.d.ts +7 -0
- package/dist/modules/admin/platform-admin.guard.js +52 -0
- package/dist/modules/admin/platform-admin.guard.js.map +1 -0
- package/dist/modules/agent/agent.controller.d.ts +34 -0
- package/dist/modules/agent/agent.controller.js +178 -0
- package/dist/modules/agent/agent.controller.js.map +1 -0
- package/dist/modules/agent/agent.module.d.ts +2 -0
- package/dist/modules/agent/agent.module.js +23 -0
- package/dist/modules/agent/agent.module.js.map +1 -0
- package/dist/modules/agent/agent.service.d.ts +2 -0
- package/dist/modules/agent/agent.service.js +7 -0
- package/dist/modules/agent/agent.service.js.map +1 -0
- package/dist/modules/agent/dto/create-conversation.dto.d.ts +8 -0
- package/dist/modules/agent/dto/create-conversation.dto.js +48 -0
- package/dist/modules/agent/dto/create-conversation.dto.js.map +1 -0
- package/dist/modules/agent/dto/send-message.dto.d.ts +12 -0
- package/dist/modules/agent/dto/send-message.dto.js +42 -0
- package/dist/modules/agent/dto/send-message.dto.js.map +1 -0
- package/dist/modules/agent/in-memory-prepared-stream.store.d.ts +1 -0
- package/dist/modules/agent/in-memory-prepared-stream.store.js +6 -0
- package/dist/modules/agent/in-memory-prepared-stream.store.js.map +1 -0
- package/dist/modules/agent/prepared-stream.service.d.ts +1 -0
- package/dist/modules/agent/prepared-stream.service.js +7 -0
- package/dist/modules/agent/prepared-stream.service.js.map +1 -0
- package/dist/modules/agent/prepared-stream.types.d.ts +1 -0
- package/dist/modules/agent/prepared-stream.types.js +6 -0
- package/dist/modules/agent/prepared-stream.types.js.map +1 -0
- package/dist/modules/agent/redis-prepared-stream.store.d.ts +9 -0
- package/dist/modules/agent/redis-prepared-stream.store.js +48 -0
- package/dist/modules/agent/redis-prepared-stream.store.js.map +1 -0
- package/dist/modules/auth/auth.controller.d.ts +63 -0
- package/dist/modules/auth/auth.controller.js +255 -0
- package/dist/modules/auth/auth.controller.js.map +1 -0
- package/dist/modules/auth/auth.module.d.ts +4 -0
- package/dist/modules/auth/auth.module.js +71 -0
- package/dist/modules/auth/auth.module.js.map +1 -0
- package/dist/modules/auth/auth.service.d.ts +2 -0
- package/dist/modules/auth/auth.service.js +7 -0
- package/dist/modules/auth/auth.service.js.map +1 -0
- package/dist/modules/auth/decorators/current-user.decorator.d.ts +8 -0
- package/dist/modules/auth/decorators/current-user.decorator.js +12 -0
- package/dist/modules/auth/decorators/current-user.decorator.js.map +1 -0
- package/dist/modules/auth/decorators/public.decorator.d.ts +2 -0
- package/dist/modules/auth/decorators/public.decorator.js +8 -0
- package/dist/modules/auth/decorators/public.decorator.js.map +1 -0
- package/dist/modules/auth/dto/login.dto.d.ts +4 -0
- package/dist/modules/auth/dto/login.dto.js +29 -0
- package/dist/modules/auth/dto/login.dto.js.map +1 -0
- package/dist/modules/auth/dto/register.dto.d.ts +5 -0
- package/dist/modules/auth/dto/register.dto.js +36 -0
- package/dist/modules/auth/dto/register.dto.js.map +1 -0
- package/dist/modules/auth/guards/jwt-auth.guard.d.ts +9 -0
- package/dist/modules/auth/guards/jwt-auth.guard.js +37 -0
- package/dist/modules/auth/guards/jwt-auth.guard.js.map +1 -0
- package/dist/modules/auth/guards/local-auth.guard.d.ts +4 -0
- package/dist/modules/auth/guards/local-auth.guard.js +18 -0
- package/dist/modules/auth/guards/local-auth.guard.js.map +1 -0
- package/dist/modules/auth/guards/oauth-configured.guard.d.ts +11 -0
- package/dist/modules/auth/guards/oauth-configured.guard.js +51 -0
- package/dist/modules/auth/guards/oauth-configured.guard.js.map +1 -0
- package/dist/modules/auth/oauth.controller.d.ts +20 -0
- package/dist/modules/auth/oauth.controller.js +208 -0
- package/dist/modules/auth/oauth.controller.js.map +1 -0
- package/dist/modules/auth/refresh-token.service.d.ts +2 -0
- package/dist/modules/auth/refresh-token.service.js +7 -0
- package/dist/modules/auth/refresh-token.service.js.map +1 -0
- package/dist/modules/auth/strategies/github.strategy.d.ts +12 -0
- package/dist/modules/auth/strategies/github.strategy.js +57 -0
- package/dist/modules/auth/strategies/github.strategy.js.map +1 -0
- package/dist/modules/auth/strategies/google.strategy.d.ts +19 -0
- package/dist/modules/auth/strategies/google.strategy.js +56 -0
- package/dist/modules/auth/strategies/google.strategy.js.map +1 -0
- package/dist/modules/auth/strategies/jwt.strategy.d.ts +18 -0
- package/dist/modules/auth/strategies/jwt.strategy.js +49 -0
- package/dist/modules/auth/strategies/jwt.strategy.js.map +1 -0
- package/dist/modules/auth/strategies/local.strategy.d.ts +11 -0
- package/dist/modules/auth/strategies/local.strategy.js +31 -0
- package/dist/modules/auth/strategies/local.strategy.js.map +1 -0
- package/dist/modules/billing/adapters/billing-adapter.interface.d.ts +1 -0
- package/dist/modules/billing/adapters/billing-adapter.interface.js +6 -0
- package/dist/modules/billing/adapters/billing-adapter.interface.js.map +1 -0
- package/dist/modules/billing/adapters/stripe/stripe.adapter.d.ts +19 -0
- package/dist/modules/billing/adapters/stripe/stripe.adapter.js +118 -0
- package/dist/modules/billing/adapters/stripe/stripe.adapter.js.map +1 -0
- package/dist/modules/billing/billing.controller.d.ts +54 -0
- package/dist/modules/billing/billing.controller.js +180 -0
- package/dist/modules/billing/billing.controller.js.map +1 -0
- package/dist/modules/billing/billing.module.d.ts +2 -0
- package/dist/modules/billing/billing.module.js +57 -0
- package/dist/modules/billing/billing.module.js.map +1 -0
- package/dist/modules/billing/billing.service.d.ts +2 -0
- package/dist/modules/billing/billing.service.js +7 -0
- package/dist/modules/billing/billing.service.js.map +1 -0
- package/dist/modules/billing/usage.service.d.ts +2 -0
- package/dist/modules/billing/usage.service.js +6 -0
- package/dist/modules/billing/usage.service.js.map +1 -0
- package/dist/modules/connectors/connectors.controller.d.ts +16 -0
- package/dist/modules/connectors/connectors.controller.js +142 -0
- package/dist/modules/connectors/connectors.controller.js.map +1 -0
- package/dist/modules/connectors/connectors.module.d.ts +2 -0
- package/dist/modules/connectors/connectors.module.js +20 -0
- package/dist/modules/connectors/connectors.module.js.map +1 -0
- package/dist/modules/conversation/conversation.module.d.ts +2 -0
- package/dist/modules/conversation/conversation.module.js +17 -0
- package/dist/modules/conversation/conversation.module.js.map +1 -0
- package/dist/modules/conversation/conversation.service.d.ts +1 -0
- package/dist/modules/conversation/conversation.service.js +7 -0
- package/dist/modules/conversation/conversation.service.js.map +1 -0
- package/dist/modules/email/adapters/email-adapter.interface.d.ts +1 -0
- package/dist/modules/email/adapters/email-adapter.interface.js +6 -0
- package/dist/modules/email/adapters/email-adapter.interface.js.map +1 -0
- package/dist/modules/email/adapters/noop.adapter.d.ts +1 -0
- package/dist/modules/email/adapters/noop.adapter.js +6 -0
- package/dist/modules/email/adapters/noop.adapter.js.map +1 -0
- package/dist/modules/email/adapters/resend.adapter.d.ts +1 -0
- package/dist/modules/email/adapters/resend.adapter.js +6 -0
- package/dist/modules/email/adapters/resend.adapter.js.map +1 -0
- package/dist/modules/email/email.module.d.ts +2 -0
- package/dist/modules/email/email.module.js +17 -0
- package/dist/modules/email/email.module.js.map +1 -0
- package/dist/modules/email/email.service.d.ts +1 -0
- package/dist/modules/email/email.service.js +6 -0
- package/dist/modules/email/email.service.js.map +1 -0
- package/dist/modules/email/templates/transactional.template.d.ts +18 -0
- package/dist/modules/email/templates/transactional.template.js +43 -0
- package/dist/modules/email/templates/transactional.template.js.map +1 -0
- package/dist/modules/mcp/mcp-admin.controller.d.ts +35 -0
- package/dist/modules/mcp/mcp-admin.controller.js +111 -0
- package/dist/modules/mcp/mcp-admin.controller.js.map +1 -0
- package/dist/modules/mcp/mcp.module.d.ts +8 -0
- package/dist/modules/mcp/mcp.module.js +38 -0
- package/dist/modules/mcp/mcp.module.js.map +1 -0
- package/dist/modules/public-chat/public-chat.controller.d.ts +54 -0
- package/dist/modules/public-chat/public-chat.controller.js +279 -0
- package/dist/modules/public-chat/public-chat.controller.js.map +1 -0
- package/dist/modules/public-chat/public-chat.module.d.ts +2 -0
- package/dist/modules/public-chat/public-chat.module.js +20 -0
- package/dist/modules/public-chat/public-chat.module.js.map +1 -0
- package/dist/modules/queue/jobs.controller.d.ts +23 -0
- package/dist/modules/queue/jobs.controller.js +98 -0
- package/dist/modules/queue/jobs.controller.js.map +1 -0
- package/dist/modules/queue/processors/agent.processor.d.ts +12 -0
- package/dist/modules/queue/processors/agent.processor.js +65 -0
- package/dist/modules/queue/processors/agent.processor.js.map +1 -0
- package/dist/modules/queue/queue.module.d.ts +5 -0
- package/dist/modules/queue/queue.module.js +55 -0
- package/dist/modules/queue/queue.module.js.map +1 -0
- package/dist/modules/queue/queue.service.d.ts +15 -0
- package/dist/modules/queue/queue.service.js +86 -0
- package/dist/modules/queue/queue.service.js.map +1 -0
- package/dist/providers/repositories.providers.d.ts +3 -0
- package/dist/providers/repositories.providers.js +35 -0
- package/dist/providers/repositories.providers.js.map +1 -0
- package/dist/providers/services.providers.d.ts +4 -0
- package/dist/providers/services.providers.js +142 -0
- package/dist/providers/services.providers.js.map +1 -0
- package/dist/redis/redis.provider.d.ts +3 -0
- package/dist/redis/redis.provider.js +48 -0
- package/dist/redis/redis.provider.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.js +18 -0
- package/dist/types/index.js.map +1 -0
- package/package.json +63 -0
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.PlatformAdminGuard = exports.RequireUserSessionGuard = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
function isApiKey(req) {
|
|
12
|
+
return req.user?.isApiKey === true;
|
|
13
|
+
}
|
|
14
|
+
let RequireUserSessionGuard = class RequireUserSessionGuard {
|
|
15
|
+
canActivate(context) {
|
|
16
|
+
const req = context.switchToHttp().getRequest();
|
|
17
|
+
if (isApiKey(req)) {
|
|
18
|
+
throw new common_1.ForbiddenException({
|
|
19
|
+
error: 'admin_required',
|
|
20
|
+
message: 'Use end-user auth (JWT) for admin endpoints.',
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
exports.RequireUserSessionGuard = RequireUserSessionGuard;
|
|
27
|
+
exports.RequireUserSessionGuard = RequireUserSessionGuard = __decorate([
|
|
28
|
+
(0, common_1.Injectable)()
|
|
29
|
+
], RequireUserSessionGuard);
|
|
30
|
+
let PlatformAdminGuard = class PlatformAdminGuard {
|
|
31
|
+
canActivate(context) {
|
|
32
|
+
const req = context.switchToHttp().getRequest();
|
|
33
|
+
if (isApiKey(req)) {
|
|
34
|
+
throw new common_1.ForbiddenException({
|
|
35
|
+
error: 'admin_required',
|
|
36
|
+
message: 'Use end-user auth (JWT) for admin endpoints.',
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
if (!req.user?.isPlatformAdmin) {
|
|
40
|
+
throw new common_1.ForbiddenException({
|
|
41
|
+
error: 'platform_admin_required',
|
|
42
|
+
message: 'This endpoint manages the AgentForge instance — your account does not have platform-admin privileges.',
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
return true;
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.PlatformAdminGuard = PlatformAdminGuard;
|
|
49
|
+
exports.PlatformAdminGuard = PlatformAdminGuard = __decorate([
|
|
50
|
+
(0, common_1.Injectable)()
|
|
51
|
+
], PlatformAdminGuard);
|
|
52
|
+
//# sourceMappingURL=platform-admin.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-admin.guard.js","sourceRoot":"","sources":["../../../src/modules/admin/platform-admin.guard.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAKwB;AAMxB,SAAS,QAAQ,CAAC,GAAgB;IAChC,OAAO,GAAG,CAAC,IAAI,EAAE,QAAQ,KAAK,IAAI,CAAC;AACrC,CAAC;AASM,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;IAClC,WAAW,CAAC,OAAyB;QACnC,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAe,CAAC;QAC7D,IAAI,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAClB,MAAM,IAAI,2BAAkB,CAAC;gBAC3B,KAAK,EAAE,gBAAgB;gBACvB,OAAO,EAAE,8CAA8C;aACxD,CAAC,CAAC;QACL,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AAXY,0DAAuB;kCAAvB,uBAAuB;IADnC,IAAA,mBAAU,GAAE;GACA,uBAAuB,CAWnC;AAQM,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC7B,WAAW,CAAC,OAAyB;QACnC,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAe,CAAC;QAE7D,IAAI,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAClB,MAAM,IAAI,2BAAkB,CAAC;gBAC3B,KAAK,EAAE,gBAAgB;gBACvB,OAAO,EAAE,8CAA8C;aACxD,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,eAAe,EAAE,CAAC;YAC/B,MAAM,IAAI,2BAAkB,CAAC;gBAC3B,KAAK,EAAE,yBAAyB;gBAChC,OAAO,EACL,uGAAuG;aAC1G,CAAC,CAAC;QACL,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AArBY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;GACA,kBAAkB,CAqB9B"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { MessageEvent } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import { AgentService } from './agent.service';
|
|
4
|
+
import { PreparedStreamService } from './prepared-stream.service';
|
|
5
|
+
import { ToolRegistryService } from '@agentforge-io/core';
|
|
6
|
+
import { CreateConversationDto } from './dto/create-conversation.dto';
|
|
7
|
+
import { SendMessageDto } from './dto/send-message.dto';
|
|
8
|
+
export declare class AgentController {
|
|
9
|
+
private readonly agentService;
|
|
10
|
+
private readonly preparedStream;
|
|
11
|
+
private readonly toolRegistry;
|
|
12
|
+
constructor(agentService: AgentService, preparedStream: PreparedStreamService, toolRegistry: ToolRegistryService);
|
|
13
|
+
listTools(): import("@agentforge-io/core/dist/services/tool-registry.service").ToolDescription[];
|
|
14
|
+
listAgents(userId?: string): import("@agentforge-io/core").AgentDefinition[];
|
|
15
|
+
getAgent(agentId: string): import("@agentforge-io/core").AgentDefinition;
|
|
16
|
+
createConversation(dto: CreateConversationDto, userId: string): Promise<{
|
|
17
|
+
conversation: import("@agentforge-io/core").Conversation;
|
|
18
|
+
firstResponse: import("@agentforge-io/core").AgentResponse;
|
|
19
|
+
} | {
|
|
20
|
+
conversation: import("@agentforge-io/core").Conversation;
|
|
21
|
+
firstResponse?: undefined;
|
|
22
|
+
}>;
|
|
23
|
+
listConversations(userId: string, agentId?: string, limit?: string, offset?: string): Promise<import("@agentforge-io/core").Conversation[]>;
|
|
24
|
+
getConversation(conversationId: string, userId: string): Promise<import("@agentforge-io/core").ConversationHistory>;
|
|
25
|
+
sendMessage(conversationId: string, dto: SendMessageDto, userId: string): Promise<import("@agentforge-io/core").AgentResponse>;
|
|
26
|
+
prepareStream(conversationId: string, body: {
|
|
27
|
+
content: string;
|
|
28
|
+
}, userId: string): Promise<{
|
|
29
|
+
streamId: string;
|
|
30
|
+
expiresAt: Date;
|
|
31
|
+
}>;
|
|
32
|
+
streamMessage(conversationId: string, streamId: string, userId: string): Observable<MessageEvent>;
|
|
33
|
+
private runPreparedStream;
|
|
34
|
+
}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AgentController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
18
|
+
const rxjs_1 = require("rxjs");
|
|
19
|
+
const operators_1 = require("rxjs/operators");
|
|
20
|
+
const agent_service_1 = require("./agent.service");
|
|
21
|
+
const prepared_stream_service_1 = require("./prepared-stream.service");
|
|
22
|
+
const core_1 = require("@agentforge-io/core");
|
|
23
|
+
const create_conversation_dto_1 = require("./dto/create-conversation.dto");
|
|
24
|
+
const send_message_dto_1 = require("./dto/send-message.dto");
|
|
25
|
+
const current_user_decorator_1 = require("../../auth/current-user.decorator");
|
|
26
|
+
let AgentController = class AgentController {
|
|
27
|
+
constructor(agentService, preparedStream, toolRegistry) {
|
|
28
|
+
this.agentService = agentService;
|
|
29
|
+
this.preparedStream = preparedStream;
|
|
30
|
+
this.toolRegistry = toolRegistry;
|
|
31
|
+
}
|
|
32
|
+
listTools() {
|
|
33
|
+
return this.toolRegistry.describe();
|
|
34
|
+
}
|
|
35
|
+
listAgents(userId) {
|
|
36
|
+
return this.agentService.listAgents(userId);
|
|
37
|
+
}
|
|
38
|
+
getAgent(agentId) {
|
|
39
|
+
return this.agentService.getAgent(agentId);
|
|
40
|
+
}
|
|
41
|
+
createConversation(dto, userId) {
|
|
42
|
+
return this.agentService.createConversation({ ...dto, userId });
|
|
43
|
+
}
|
|
44
|
+
listConversations(userId, agentId, limit, offset) {
|
|
45
|
+
return this.agentService.listConversations(userId, {
|
|
46
|
+
agentId,
|
|
47
|
+
limit: limit ? parseInt(limit) : undefined,
|
|
48
|
+
offset: offset ? parseInt(offset) : undefined,
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
getConversation(conversationId, userId) {
|
|
52
|
+
return this.agentService.getConversation(conversationId, userId);
|
|
53
|
+
}
|
|
54
|
+
sendMessage(conversationId, dto, userId) {
|
|
55
|
+
return this.agentService.sendMessage({ conversationId, userId, content: dto.content, overrides: dto.overrides });
|
|
56
|
+
}
|
|
57
|
+
async prepareStream(conversationId, body, userId) {
|
|
58
|
+
if (!body?.content || typeof body.content !== 'string') {
|
|
59
|
+
throw new common_1.BadRequestException('content is required');
|
|
60
|
+
}
|
|
61
|
+
return this.preparedStream.prepare({
|
|
62
|
+
userId,
|
|
63
|
+
conversationId,
|
|
64
|
+
content: body.content,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
streamMessage(conversationId, streamId, userId) {
|
|
68
|
+
if (!streamId)
|
|
69
|
+
throw new common_1.BadRequestException('streamId is required');
|
|
70
|
+
return (0, rxjs_1.from)(this.runPreparedStream(streamId, userId, conversationId)).pipe((0, operators_1.map)((chunk) => ({ data: JSON.stringify(chunk) })));
|
|
71
|
+
}
|
|
72
|
+
async *runPreparedStream(streamId, userId, conversationId) {
|
|
73
|
+
const payload = await this.preparedStream.consume({ streamId, userId, conversationId });
|
|
74
|
+
yield* this.agentService.streamMessage({
|
|
75
|
+
conversationId,
|
|
76
|
+
userId,
|
|
77
|
+
content: payload.content,
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
exports.AgentController = AgentController;
|
|
82
|
+
__decorate([
|
|
83
|
+
(0, common_1.Get)('tools'),
|
|
84
|
+
(0, swagger_1.ApiOperation)({
|
|
85
|
+
summary: 'List every tool registered in the runtime ToolRegistry. The admin UI ' +
|
|
86
|
+
'uses this to populate the per-agent "tools enabled" picker so users ' +
|
|
87
|
+
'select from real names rather than free-text strings.',
|
|
88
|
+
}),
|
|
89
|
+
__metadata("design:type", Function),
|
|
90
|
+
__metadata("design:paramtypes", []),
|
|
91
|
+
__metadata("design:returntype", void 0)
|
|
92
|
+
], AgentController.prototype, "listTools", null);
|
|
93
|
+
__decorate([
|
|
94
|
+
(0, common_1.Get)('agents'),
|
|
95
|
+
(0, swagger_1.ApiOperation)({ summary: 'List available agents' }),
|
|
96
|
+
__param(0, (0, current_user_decorator_1.CurrentUser)('userId')),
|
|
97
|
+
__metadata("design:type", Function),
|
|
98
|
+
__metadata("design:paramtypes", [String]),
|
|
99
|
+
__metadata("design:returntype", void 0)
|
|
100
|
+
], AgentController.prototype, "listAgents", null);
|
|
101
|
+
__decorate([
|
|
102
|
+
(0, common_1.Get)('agents/:agentId'),
|
|
103
|
+
(0, swagger_1.ApiOperation)({ summary: 'Get agent details' }),
|
|
104
|
+
__param(0, (0, common_1.Param)('agentId')),
|
|
105
|
+
__metadata("design:type", Function),
|
|
106
|
+
__metadata("design:paramtypes", [String]),
|
|
107
|
+
__metadata("design:returntype", void 0)
|
|
108
|
+
], AgentController.prototype, "getAgent", null);
|
|
109
|
+
__decorate([
|
|
110
|
+
(0, common_1.Post)('conversations'),
|
|
111
|
+
(0, swagger_1.ApiOperation)({ summary: 'Create a new conversation' }),
|
|
112
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.CREATED),
|
|
113
|
+
__param(0, (0, common_1.Body)()),
|
|
114
|
+
__param(1, (0, current_user_decorator_1.CurrentUser)('userId')),
|
|
115
|
+
__metadata("design:type", Function),
|
|
116
|
+
__metadata("design:paramtypes", [create_conversation_dto_1.CreateConversationDto, String]),
|
|
117
|
+
__metadata("design:returntype", void 0)
|
|
118
|
+
], AgentController.prototype, "createConversation", null);
|
|
119
|
+
__decorate([
|
|
120
|
+
(0, common_1.Get)('conversations'),
|
|
121
|
+
(0, swagger_1.ApiOperation)({ summary: 'List conversations for the authenticated user' }),
|
|
122
|
+
__param(0, (0, current_user_decorator_1.CurrentUser)('userId')),
|
|
123
|
+
__param(1, (0, common_1.Query)('agentId')),
|
|
124
|
+
__param(2, (0, common_1.Query)('limit')),
|
|
125
|
+
__param(3, (0, common_1.Query)('offset')),
|
|
126
|
+
__metadata("design:type", Function),
|
|
127
|
+
__metadata("design:paramtypes", [String, String, String, String]),
|
|
128
|
+
__metadata("design:returntype", void 0)
|
|
129
|
+
], AgentController.prototype, "listConversations", null);
|
|
130
|
+
__decorate([
|
|
131
|
+
(0, common_1.Get)('conversations/:conversationId'),
|
|
132
|
+
(0, swagger_1.ApiOperation)({ summary: 'Get a conversation with full history' }),
|
|
133
|
+
__param(0, (0, common_1.Param)('conversationId')),
|
|
134
|
+
__param(1, (0, current_user_decorator_1.CurrentUser)('userId')),
|
|
135
|
+
__metadata("design:type", Function),
|
|
136
|
+
__metadata("design:paramtypes", [String, String]),
|
|
137
|
+
__metadata("design:returntype", void 0)
|
|
138
|
+
], AgentController.prototype, "getConversation", null);
|
|
139
|
+
__decorate([
|
|
140
|
+
(0, common_1.Post)('conversations/:conversationId/messages'),
|
|
141
|
+
(0, swagger_1.ApiOperation)({ summary: 'Send a message to the agent (sync or async)' }),
|
|
142
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.OK),
|
|
143
|
+
__param(0, (0, common_1.Param)('conversationId')),
|
|
144
|
+
__param(1, (0, common_1.Body)()),
|
|
145
|
+
__param(2, (0, current_user_decorator_1.CurrentUser)('userId')),
|
|
146
|
+
__metadata("design:type", Function),
|
|
147
|
+
__metadata("design:paramtypes", [String, send_message_dto_1.SendMessageDto, String]),
|
|
148
|
+
__metadata("design:returntype", void 0)
|
|
149
|
+
], AgentController.prototype, "sendMessage", null);
|
|
150
|
+
__decorate([
|
|
151
|
+
(0, common_1.Post)('conversations/:conversationId/messages/stream'),
|
|
152
|
+
(0, swagger_1.ApiOperation)({ summary: 'Prepare a streaming message — returns a single-use streamId' }),
|
|
153
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.CREATED),
|
|
154
|
+
__param(0, (0, common_1.Param)('conversationId')),
|
|
155
|
+
__param(1, (0, common_1.Body)()),
|
|
156
|
+
__param(2, (0, current_user_decorator_1.CurrentUser)('userId')),
|
|
157
|
+
__metadata("design:type", Function),
|
|
158
|
+
__metadata("design:paramtypes", [String, Object, String]),
|
|
159
|
+
__metadata("design:returntype", Promise)
|
|
160
|
+
], AgentController.prototype, "prepareStream", null);
|
|
161
|
+
__decorate([
|
|
162
|
+
(0, common_1.Sse)('conversations/:conversationId/stream'),
|
|
163
|
+
(0, swagger_1.ApiOperation)({ summary: 'Consume a prepared streamId and stream the response via SSE' }),
|
|
164
|
+
__param(0, (0, common_1.Param)('conversationId')),
|
|
165
|
+
__param(1, (0, common_1.Query)('streamId')),
|
|
166
|
+
__param(2, (0, current_user_decorator_1.CurrentUser)('userId')),
|
|
167
|
+
__metadata("design:type", Function),
|
|
168
|
+
__metadata("design:paramtypes", [String, String, String]),
|
|
169
|
+
__metadata("design:returntype", rxjs_1.Observable)
|
|
170
|
+
], AgentController.prototype, "streamMessage", null);
|
|
171
|
+
exports.AgentController = AgentController = __decorate([
|
|
172
|
+
(0, swagger_1.ApiTags)('Agents'),
|
|
173
|
+
(0, common_1.Controller)(),
|
|
174
|
+
__metadata("design:paramtypes", [agent_service_1.AgentService,
|
|
175
|
+
prepared_stream_service_1.PreparedStreamService,
|
|
176
|
+
core_1.ToolRegistryService])
|
|
177
|
+
], AgentController);
|
|
178
|
+
//# sourceMappingURL=agent.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent.controller.js","sourceRoot":"","sources":["../../../src/modules/agent/agent.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AgentModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const agent_controller_1 = require("./agent.controller");
|
|
12
|
+
const jobs_controller_1 = require("../queue/jobs.controller");
|
|
13
|
+
const conversation_module_1 = require("../conversation/conversation.module");
|
|
14
|
+
let AgentModule = class AgentModule {
|
|
15
|
+
};
|
|
16
|
+
exports.AgentModule = AgentModule;
|
|
17
|
+
exports.AgentModule = AgentModule = __decorate([
|
|
18
|
+
(0, common_1.Module)({
|
|
19
|
+
imports: [conversation_module_1.ConversationModule],
|
|
20
|
+
controllers: [agent_controller_1.AgentController, jobs_controller_1.JobsController],
|
|
21
|
+
})
|
|
22
|
+
], AgentModule);
|
|
23
|
+
//# sourceMappingURL=agent.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent.module.js","sourceRoot":"","sources":["../../../src/modules/agent/agent.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,yDAAqD;AACrD,8DAA0D;AAC1D,6EAAyE;AAgBlE,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IAJvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,wCAAkB,CAAC;QAC7B,WAAW,EAAE,CAAC,kCAAe,EAAE,gCAAc,CAAC;KAC/C,CAAC;GACW,WAAW,CAAG"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AgentForbiddenError = exports.AgentService = void 0;
|
|
4
|
+
var core_1 = require("@agentforge-io/core");
|
|
5
|
+
Object.defineProperty(exports, "AgentService", { enumerable: true, get: function () { return core_1.AgentService; } });
|
|
6
|
+
Object.defineProperty(exports, "AgentForbiddenError", { enumerable: true, get: function () { return core_1.AgentForbiddenError; } });
|
|
7
|
+
//# sourceMappingURL=agent.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent.service.js","sourceRoot":"","sources":["../../../src/modules/agent/agent.service.ts"],"names":[],"mappings":";;;AAAA,4CAAwE;AAA/D,oGAAA,YAAY,OAAA;AAAE,2GAAA,mBAAmB,OAAA"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.CreateConversationDto = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
15
|
+
class CreateConversationDto {
|
|
16
|
+
}
|
|
17
|
+
exports.CreateConversationDto = CreateConversationDto;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, swagger_1.ApiProperty)({ description: 'ID of the agent to converse with' }),
|
|
20
|
+
(0, class_validator_1.IsString)(),
|
|
21
|
+
(0, class_validator_1.IsNotEmpty)(),
|
|
22
|
+
__metadata("design:type", String)
|
|
23
|
+
], CreateConversationDto.prototype, "agentId", void 0);
|
|
24
|
+
__decorate([
|
|
25
|
+
(0, swagger_1.ApiProperty)({ required: false, description: 'Conversation title' }),
|
|
26
|
+
(0, class_validator_1.IsOptional)(),
|
|
27
|
+
(0, class_validator_1.IsString)(),
|
|
28
|
+
__metadata("design:type", String)
|
|
29
|
+
], CreateConversationDto.prototype, "title", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, swagger_1.ApiProperty)({ required: false, description: 'Optional first message to send immediately' }),
|
|
32
|
+
(0, class_validator_1.IsOptional)(),
|
|
33
|
+
(0, class_validator_1.IsString)(),
|
|
34
|
+
__metadata("design:type", String)
|
|
35
|
+
], CreateConversationDto.prototype, "initialMessage", void 0);
|
|
36
|
+
__decorate([
|
|
37
|
+
(0, swagger_1.ApiProperty)({ required: false, description: 'Run initial message in background queue' }),
|
|
38
|
+
(0, class_validator_1.IsOptional)(),
|
|
39
|
+
(0, class_validator_1.IsBoolean)(),
|
|
40
|
+
__metadata("design:type", Boolean)
|
|
41
|
+
], CreateConversationDto.prototype, "async", void 0);
|
|
42
|
+
__decorate([
|
|
43
|
+
(0, swagger_1.ApiProperty)({ required: false }),
|
|
44
|
+
(0, class_validator_1.IsOptional)(),
|
|
45
|
+
(0, class_validator_1.IsObject)(),
|
|
46
|
+
__metadata("design:type", Object)
|
|
47
|
+
], CreateConversationDto.prototype, "metadata", void 0);
|
|
48
|
+
//# sourceMappingURL=create-conversation.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-conversation.dto.js","sourceRoot":"","sources":["../../../../src/modules/agent/dto/create-conversation.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAwF;AACxF,6CAA8C;AAE9C,MAAa,qBAAqB;CAgCjC;AAhCD,sDAgCC;AArBC;IAHC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,kCAAkC,EAAE,CAAC;IAChE,IAAA,0BAAQ,GAAE;IACV,IAAA,4BAAU,GAAE;;sDACI;AAKjB;IAHC,IAAA,qBAAW,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,oBAAoB,EAAE,CAAC;IACnE,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;oDACI;AAKf;IAHC,IAAA,qBAAW,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,4CAA4C,EAAE,CAAC;IAC3F,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;6DACa;AAKxB;IAHC,IAAA,qBAAW,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,yCAAyC,EAAE,CAAC;IACxF,IAAA,4BAAU,GAAE;IACZ,IAAA,2BAAS,GAAE;;oDACI;AAKhB;IAHC,IAAA,qBAAW,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAChC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;uDACwB"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.SendMessageDto = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
15
|
+
class SendMessageDto {
|
|
16
|
+
}
|
|
17
|
+
exports.SendMessageDto = SendMessageDto;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, swagger_1.ApiProperty)(),
|
|
20
|
+
(0, class_validator_1.IsString)(),
|
|
21
|
+
(0, class_validator_1.IsNotEmpty)(),
|
|
22
|
+
__metadata("design:type", String)
|
|
23
|
+
], SendMessageDto.prototype, "content", void 0);
|
|
24
|
+
__decorate([
|
|
25
|
+
(0, swagger_1.ApiProperty)({ required: false, description: 'Run in background queue' }),
|
|
26
|
+
(0, class_validator_1.IsOptional)(),
|
|
27
|
+
(0, class_validator_1.IsBoolean)(),
|
|
28
|
+
__metadata("design:type", Boolean)
|
|
29
|
+
], SendMessageDto.prototype, "async", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, swagger_1.ApiProperty)({ required: false, description: 'Stream the response (Server-Sent Events)' }),
|
|
32
|
+
(0, class_validator_1.IsOptional)(),
|
|
33
|
+
(0, class_validator_1.IsBoolean)(),
|
|
34
|
+
__metadata("design:type", Boolean)
|
|
35
|
+
], SendMessageDto.prototype, "stream", void 0);
|
|
36
|
+
__decorate([
|
|
37
|
+
(0, swagger_1.ApiProperty)({ required: false }),
|
|
38
|
+
(0, class_validator_1.IsOptional)(),
|
|
39
|
+
(0, class_validator_1.IsObject)(),
|
|
40
|
+
__metadata("design:type", Object)
|
|
41
|
+
], SendMessageDto.prototype, "overrides", void 0);
|
|
42
|
+
//# sourceMappingURL=send-message.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"send-message.dto.js","sourceRoot":"","sources":["../../../../src/modules/agent/dto/send-message.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAwF;AACxF,6CAA8C;AAE9C,MAAa,cAAc;CA4B1B;AA5BD,wCA4BC;AArBC;IAHC,IAAA,qBAAW,GAAE;IACb,IAAA,0BAAQ,GAAE;IACV,IAAA,4BAAU,GAAE;;+CACI;AAKjB;IAHC,IAAA,qBAAW,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,yBAAyB,EAAE,CAAC;IACxE,IAAA,4BAAU,GAAE;IACZ,IAAA,2BAAS,GAAE;;6CACI;AAKhB;IAHC,IAAA,qBAAW,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,0CAA0C,EAAE,CAAC;IACzF,IAAA,4BAAU,GAAE;IACZ,IAAA,2BAAS,GAAE;;8CACK;AAKjB;IAHC,IAAA,qBAAW,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAChC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;iDAMT"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { InMemoryPreparedStreamStore } from '@agentforge-io/core';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InMemoryPreparedStreamStore = void 0;
|
|
4
|
+
var core_1 = require("@agentforge-io/core");
|
|
5
|
+
Object.defineProperty(exports, "InMemoryPreparedStreamStore", { enumerable: true, get: function () { return core_1.InMemoryPreparedStreamStore; } });
|
|
6
|
+
//# sourceMappingURL=in-memory-prepared-stream.store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"in-memory-prepared-stream.store.js","sourceRoot":"","sources":["../../../src/modules/agent/in-memory-prepared-stream.store.ts"],"names":[],"mappings":";;;AAAA,4CAAkE;AAAzD,mHAAA,2BAA2B,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { PreparedStreamService, PreparedStreamError } from '@agentforge-io/core';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PreparedStreamError = exports.PreparedStreamService = void 0;
|
|
4
|
+
var core_1 = require("@agentforge-io/core");
|
|
5
|
+
Object.defineProperty(exports, "PreparedStreamService", { enumerable: true, get: function () { return core_1.PreparedStreamService; } });
|
|
6
|
+
Object.defineProperty(exports, "PreparedStreamError", { enumerable: true, get: function () { return core_1.PreparedStreamError; } });
|
|
7
|
+
//# sourceMappingURL=prepared-stream.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepared-stream.service.js","sourceRoot":"","sources":["../../../src/modules/agent/prepared-stream.service.ts"],"names":[],"mappings":";;;AAAA,4CAAiF;AAAxE,6GAAA,qBAAqB,OAAA;AAAE,2GAAA,mBAAmB,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { PREPARED_STREAM_STORE, type PreparedStreamStore, type PreparedStreamPayload, } from '@agentforge-io/core';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PREPARED_STREAM_STORE = void 0;
|
|
4
|
+
var core_1 = require("@agentforge-io/core");
|
|
5
|
+
Object.defineProperty(exports, "PREPARED_STREAM_STORE", { enumerable: true, get: function () { return core_1.PREPARED_STREAM_STORE; } });
|
|
6
|
+
//# sourceMappingURL=prepared-stream.types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepared-stream.types.js","sourceRoot":"","sources":["../../../src/modules/agent/prepared-stream.types.ts"],"names":[],"mappings":";;;AAEA,4CAI6B;AAH3B,6GAAA,qBAAqB,OAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Redis } from 'ioredis';
|
|
2
|
+
import type { PreparedStreamPayload, PreparedStreamStore } from './prepared-stream.types';
|
|
3
|
+
export declare class RedisPreparedStreamStore implements PreparedStreamStore {
|
|
4
|
+
private readonly redis;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
constructor(redis: Redis);
|
|
7
|
+
put(streamId: string, payload: PreparedStreamPayload, ttlMs: number): Promise<void>;
|
|
8
|
+
takeOnce(streamId: string): Promise<PreparedStreamPayload | null>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var RedisPreparedStreamStore_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.RedisPreparedStreamStore = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const redis_provider_1 = require("../../redis/redis.provider");
|
|
19
|
+
const KEY_PREFIX = 'af:ps:';
|
|
20
|
+
let RedisPreparedStreamStore = RedisPreparedStreamStore_1 = class RedisPreparedStreamStore {
|
|
21
|
+
constructor(redis) {
|
|
22
|
+
this.redis = redis;
|
|
23
|
+
this.logger = new common_1.Logger(RedisPreparedStreamStore_1.name);
|
|
24
|
+
}
|
|
25
|
+
async put(streamId, payload, ttlMs) {
|
|
26
|
+
await this.redis.set(KEY_PREFIX + streamId, JSON.stringify(payload), 'PX', ttlMs);
|
|
27
|
+
}
|
|
28
|
+
async takeOnce(streamId) {
|
|
29
|
+
const raw = (await this.redis.call('GETDEL', KEY_PREFIX + streamId));
|
|
30
|
+
if (!raw)
|
|
31
|
+
return null;
|
|
32
|
+
try {
|
|
33
|
+
const parsed = JSON.parse(raw);
|
|
34
|
+
return { ...parsed, expiresAt: new Date(parsed.expiresAt) };
|
|
35
|
+
}
|
|
36
|
+
catch (err) {
|
|
37
|
+
this.logger.warn(`Failed to parse prepared-stream payload: ${err.message}`);
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
exports.RedisPreparedStreamStore = RedisPreparedStreamStore;
|
|
43
|
+
exports.RedisPreparedStreamStore = RedisPreparedStreamStore = RedisPreparedStreamStore_1 = __decorate([
|
|
44
|
+
(0, common_1.Injectable)(),
|
|
45
|
+
__param(0, (0, common_1.Inject)(redis_provider_1.AGENTFORGE_REDIS_CLIENT)),
|
|
46
|
+
__metadata("design:paramtypes", [Function])
|
|
47
|
+
], RedisPreparedStreamStore);
|
|
48
|
+
//# sourceMappingURL=redis-prepared-stream.store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis-prepared-stream.store.js","sourceRoot":"","sources":["../../../src/modules/agent/redis-prepared-stream.store.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA4D;AAE5D,+DAAqE;AAGrE,MAAM,UAAU,GAAG,QAAQ,CAAC;AASrB,IAAM,wBAAwB,gCAA9B,MAAM,wBAAwB;IAGnC,YAA6C,KAA6B;QAAZ,UAAK,GAAL,KAAK,CAAO;QAFzD,WAAM,GAAG,IAAI,eAAM,CAAC,0BAAwB,CAAC,IAAI,CAAC,CAAC;IAES,CAAC;IAE9E,KAAK,CAAC,GAAG,CAAC,QAAgB,EAAE,OAA8B,EAAE,KAAa;QACvE,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,GAAG,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACpF,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,QAAgB;QAG7B,MAAM,GAAG,GAAG,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,GAAG,QAAQ,CAAC,CAAkB,CAAC;QACtF,IAAI,CAAC,GAAG;YAAE,OAAO,IAAI,CAAC;QACtB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAA0B,CAAC;YACxD,OAAO,EAAE,GAAG,MAAM,EAAE,SAAS,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;QAC9D,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4CAA6C,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;YACvF,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;CACF,CAAA;AAtBY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,mBAAU,GAAE;IAIE,WAAA,IAAA,eAAM,EAAC,wCAAuB,CAAC,CAAA;;GAHjC,wBAAwB,CAsBpC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import type { Request, Response } from 'express';
|
|
2
|
+
import { AuthService } from './auth.service';
|
|
3
|
+
import { RegisterDto } from './dto/register.dto';
|
|
4
|
+
import { LoginDto } from './dto/login.dto';
|
|
5
|
+
import { AuthUser } from './decorators/current-user.decorator';
|
|
6
|
+
import type { AgentForgeConfig } from '../../types';
|
|
7
|
+
export declare class AuthController {
|
|
8
|
+
private readonly config;
|
|
9
|
+
private readonly auth;
|
|
10
|
+
constructor(config: AgentForgeConfig, auth: AuthService);
|
|
11
|
+
register(dto: RegisterDto, req: Request, res: Response): Promise<{
|
|
12
|
+
accessToken: string;
|
|
13
|
+
user: {
|
|
14
|
+
id: string;
|
|
15
|
+
email?: string;
|
|
16
|
+
name?: string;
|
|
17
|
+
};
|
|
18
|
+
}>;
|
|
19
|
+
login(dto: LoginDto, req: Request, res: Response): Promise<{
|
|
20
|
+
accessToken: string;
|
|
21
|
+
user: {
|
|
22
|
+
id: string;
|
|
23
|
+
email?: string;
|
|
24
|
+
name?: string;
|
|
25
|
+
};
|
|
26
|
+
}>;
|
|
27
|
+
refresh(req: Request, res: Response): Promise<{
|
|
28
|
+
accessToken: string;
|
|
29
|
+
user: {
|
|
30
|
+
id: string;
|
|
31
|
+
email?: string;
|
|
32
|
+
name?: string;
|
|
33
|
+
};
|
|
34
|
+
}>;
|
|
35
|
+
logout(req: Request, res: Response): Promise<void>;
|
|
36
|
+
logoutAll(userId: string, res: Response): Promise<void>;
|
|
37
|
+
me(user: AuthUser): AuthUser;
|
|
38
|
+
verifyEmail(body: {
|
|
39
|
+
token: string;
|
|
40
|
+
}): Promise<{
|
|
41
|
+
userId: string;
|
|
42
|
+
}>;
|
|
43
|
+
resendVerification(userId: string): Promise<void>;
|
|
44
|
+
requestPasswordReset(body: {
|
|
45
|
+
email: string;
|
|
46
|
+
}): Promise<{
|
|
47
|
+
ok: boolean;
|
|
48
|
+
}>;
|
|
49
|
+
resetPassword(body: {
|
|
50
|
+
token: string;
|
|
51
|
+
password: string;
|
|
52
|
+
}): Promise<{
|
|
53
|
+
ok: boolean;
|
|
54
|
+
}>;
|
|
55
|
+
private accessCookieName;
|
|
56
|
+
private refreshCookieName;
|
|
57
|
+
private cookieSecure;
|
|
58
|
+
private metaFrom;
|
|
59
|
+
private setSessionCookies;
|
|
60
|
+
private clearSessionCookies;
|
|
61
|
+
private publicResult;
|
|
62
|
+
private parseAccessTtlMs;
|
|
63
|
+
}
|