@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,86 @@
|
|
|
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 QueueService_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.QueueService = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const bullmq_1 = require("@nestjs/bullmq");
|
|
19
|
+
const bullmq_2 = require("bullmq");
|
|
20
|
+
const crypto_1 = require("crypto");
|
|
21
|
+
const constants_1 = require("../../constants");
|
|
22
|
+
let QueueService = QueueService_1 = class QueueService {
|
|
23
|
+
constructor(queue) {
|
|
24
|
+
this.queue = queue;
|
|
25
|
+
this.logger = new common_1.Logger(QueueService_1.name);
|
|
26
|
+
}
|
|
27
|
+
async enqueue(payload, opts = {}) {
|
|
28
|
+
const jobId = opts.jobId ?? payload.jobId ?? (0, crypto_1.randomUUID)();
|
|
29
|
+
await this.queue.add('agent-turn', { ...payload, jobId, messageId: payload.messageId ?? jobId }, {
|
|
30
|
+
jobId,
|
|
31
|
+
priority: opts.priority ?? 0,
|
|
32
|
+
attempts: opts.attempts ?? 3,
|
|
33
|
+
backoff: { type: 'exponential', delay: 2000 },
|
|
34
|
+
removeOnComplete: 100,
|
|
35
|
+
removeOnFail: 50,
|
|
36
|
+
});
|
|
37
|
+
const waiting = await this.queue.getWaitingCount();
|
|
38
|
+
const estimatedWait = waiting * 5000;
|
|
39
|
+
this.logger.debug(`Enqueued job ${jobId} for user ${payload.userId} (${waiting} waiting)`);
|
|
40
|
+
return { jobId, estimatedWait };
|
|
41
|
+
}
|
|
42
|
+
async getJobStatus(jobId) {
|
|
43
|
+
const job = await this.queue.getJob(jobId);
|
|
44
|
+
if (!job)
|
|
45
|
+
return { status: 'not_found' };
|
|
46
|
+
const state = await job.getState();
|
|
47
|
+
const progress = typeof job.progress === 'number' ? job.progress : 0;
|
|
48
|
+
if (state === 'completed') {
|
|
49
|
+
return { status: 'completed', progress: 100, result: job.returnvalue };
|
|
50
|
+
}
|
|
51
|
+
if (state === 'failed') {
|
|
52
|
+
return { status: 'failed', progress, error: job.failedReason };
|
|
53
|
+
}
|
|
54
|
+
if (state === 'active') {
|
|
55
|
+
return { status: 'active', progress };
|
|
56
|
+
}
|
|
57
|
+
return { status: 'waiting', progress: 0 };
|
|
58
|
+
}
|
|
59
|
+
async cancelJob(jobId) {
|
|
60
|
+
const job = await this.queue.getJob(jobId);
|
|
61
|
+
if (!job)
|
|
62
|
+
return false;
|
|
63
|
+
const state = await job.getState();
|
|
64
|
+
if (state === 'waiting' || state === 'delayed') {
|
|
65
|
+
await job.remove();
|
|
66
|
+
return true;
|
|
67
|
+
}
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
async getMetrics() {
|
|
71
|
+
const [waiting, active, completed, failed] = await Promise.all([
|
|
72
|
+
this.queue.getWaitingCount(),
|
|
73
|
+
this.queue.getActiveCount(),
|
|
74
|
+
this.queue.getCompletedCount(),
|
|
75
|
+
this.queue.getFailedCount(),
|
|
76
|
+
]);
|
|
77
|
+
return { waiting, active, completed, failed };
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
exports.QueueService = QueueService;
|
|
81
|
+
exports.QueueService = QueueService = QueueService_1 = __decorate([
|
|
82
|
+
(0, common_1.Injectable)(),
|
|
83
|
+
__param(0, (0, bullmq_1.InjectQueue)(constants_1.AGENT_QUEUE_NAME)),
|
|
84
|
+
__metadata("design:paramtypes", [bullmq_2.Queue])
|
|
85
|
+
], QueueService);
|
|
86
|
+
//# sourceMappingURL=queue.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.service.js","sourceRoot":"","sources":["../../../src/modules/queue/queue.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.repositoryTokens = exports.repositoryProviders = void 0;
|
|
4
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
5
|
+
const core_1 = require("@agentforge-io/core");
|
|
6
|
+
const typeorm_2 = require("@agentforge-io/typeorm");
|
|
7
|
+
exports.repositoryProviders = [
|
|
8
|
+
{
|
|
9
|
+
provide: core_1.CONVERSATION_REPOSITORY,
|
|
10
|
+
inject: [(0, typeorm_1.getDataSourceToken)()],
|
|
11
|
+
useFactory: (ds) => new typeorm_2.TypeOrmConversationRepository(ds),
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
provide: core_1.MESSAGE_REPOSITORY,
|
|
15
|
+
inject: [(0, typeorm_1.getDataSourceToken)()],
|
|
16
|
+
useFactory: (ds) => new typeorm_2.TypeOrmMessageRepository(ds),
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
provide: core_1.CHAT_TOKEN_REPOSITORY,
|
|
20
|
+
inject: [(0, typeorm_1.getDataSourceToken)()],
|
|
21
|
+
useFactory: (ds) => new typeorm_2.TypeOrmChatTokenRepository(ds),
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
provide: core_1.MCP_SERVER_REPOSITORY,
|
|
25
|
+
inject: [(0, typeorm_1.getDataSourceToken)()],
|
|
26
|
+
useFactory: (ds) => new typeorm_2.TypeOrmMcpServerRepository(ds),
|
|
27
|
+
},
|
|
28
|
+
];
|
|
29
|
+
exports.repositoryTokens = [
|
|
30
|
+
core_1.CONVERSATION_REPOSITORY,
|
|
31
|
+
core_1.MESSAGE_REPOSITORY,
|
|
32
|
+
core_1.CHAT_TOKEN_REPOSITORY,
|
|
33
|
+
core_1.MCP_SERVER_REPOSITORY,
|
|
34
|
+
];
|
|
35
|
+
//# sourceMappingURL=repositories.providers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repositories.providers.js","sourceRoot":"","sources":["../../src/providers/repositories.providers.ts"],"names":[],"mappings":";;;AACA,6CAAqD;AAErD,8CAK6B;AAC7B,oDAKgC;AAOnB,QAAA,mBAAmB,GAAe;IAC7C;QACE,OAAO,EAAE,8BAAuB;QAChC,MAAM,EAAE,CAAC,IAAA,4BAAkB,GAAE,CAAC;QAC9B,UAAU,EAAE,CAAC,EAAc,EAAE,EAAE,CAAC,IAAI,uCAA6B,CAAC,EAAE,CAAC;KACtE;IACD;QACE,OAAO,EAAE,yBAAkB;QAC3B,MAAM,EAAE,CAAC,IAAA,4BAAkB,GAAE,CAAC;QAC9B,UAAU,EAAE,CAAC,EAAc,EAAE,EAAE,CAAC,IAAI,kCAAwB,CAAC,EAAE,CAAC;KACjE;IACD;QACE,OAAO,EAAE,4BAAqB;QAC9B,MAAM,EAAE,CAAC,IAAA,4BAAkB,GAAE,CAAC;QAC9B,UAAU,EAAE,CAAC,EAAc,EAAE,EAAE,CAAC,IAAI,oCAA0B,CAAC,EAAE,CAAC;KACnE;IACD;QACE,OAAO,EAAE,4BAAqB;QAC9B,MAAM,EAAE,CAAC,IAAA,4BAAkB,GAAE,CAAC;QAC9B,UAAU,EAAE,CAAC,EAAc,EAAE,EAAE,CAAC,IAAI,oCAA0B,CAAC,EAAE,CAAC;KACnE;CACF,CAAC;AAEW,QAAA,gBAAgB,GAAG;IAC9B,8BAAuB;IACvB,yBAAkB;IAClB,4BAAqB;IACrB,4BAAqB;CACtB,CAAC"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AGENT_RESOLVER = exports.TOOLS_TOKEN = void 0;
|
|
4
|
+
exports.createServiceProviders = createServiceProviders;
|
|
5
|
+
const common_1 = require("@nestjs/common");
|
|
6
|
+
const core_1 = require("@agentforge-io/core");
|
|
7
|
+
const constants_1 = require("../constants");
|
|
8
|
+
const redis_prepared_stream_store_1 = require("../modules/agent/redis-prepared-stream.store");
|
|
9
|
+
const redis_provider_1 = require("../redis/redis.provider");
|
|
10
|
+
const TOOLS_INJECTION_TOKEN = 'AGENTFORGE_INITIAL_TOOLS';
|
|
11
|
+
exports.TOOLS_TOKEN = TOOLS_INJECTION_TOKEN;
|
|
12
|
+
exports.AGENT_RESOLVER = 'AGENT_RESOLVER';
|
|
13
|
+
function createServiceProviders() {
|
|
14
|
+
return [
|
|
15
|
+
{
|
|
16
|
+
provide: core_1.ToolRegistryService,
|
|
17
|
+
inject: [{ token: TOOLS_INJECTION_TOKEN, optional: true }],
|
|
18
|
+
useFactory: (tools) => new core_1.ToolRegistryService({
|
|
19
|
+
logger: nestLogger('ToolRegistry'),
|
|
20
|
+
initialTools: tools ?? [],
|
|
21
|
+
}),
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
provide: core_1.AgentRunnerService,
|
|
25
|
+
inject: [core_1.AGENT_FORGE_CONFIG, core_1.ToolRegistryService],
|
|
26
|
+
useFactory: (cfg, tr) => new core_1.AgentRunnerService(cfg.anthropic, tr, { logger: nestLogger('AgentRunner') }),
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
provide: core_1.OrchestratorService,
|
|
30
|
+
inject: [core_1.AGENT_FORGE_CONFIG, core_1.AgentRunnerService],
|
|
31
|
+
useFactory: (cfg, runner) => new core_1.OrchestratorService(cfg.anthropic, runner, {
|
|
32
|
+
agents: cfg.agents ?? [],
|
|
33
|
+
logger: nestLogger('Orchestrator'),
|
|
34
|
+
}),
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
provide: core_1.PREPARED_STREAM_STORE,
|
|
38
|
+
inject: [{ token: redis_provider_1.AGENTFORGE_REDIS_CLIENT, optional: true }],
|
|
39
|
+
useFactory: async (redis) => {
|
|
40
|
+
const log = nestLogger('PreparedStreamStore');
|
|
41
|
+
if (!redis) {
|
|
42
|
+
log.log('Using in-memory prepared-stream store (no Redis configured)');
|
|
43
|
+
return new core_1.InMemoryPreparedStreamStore();
|
|
44
|
+
}
|
|
45
|
+
try {
|
|
46
|
+
await redis.ping();
|
|
47
|
+
log.log('Using Redis-backed prepared-stream store');
|
|
48
|
+
return new redis_prepared_stream_store_1.RedisPreparedStreamStore(redis);
|
|
49
|
+
}
|
|
50
|
+
catch (err) {
|
|
51
|
+
log.warn(`Redis unreachable (${err.message}); falling back to in-memory store.`);
|
|
52
|
+
redis.disconnect();
|
|
53
|
+
return new core_1.InMemoryPreparedStreamStore();
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
provide: core_1.PreparedStreamService,
|
|
59
|
+
inject: [core_1.PREPARED_STREAM_STORE],
|
|
60
|
+
useFactory: (store) => new core_1.PreparedStreamService(store),
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
provide: core_1.RATE_LIMITER,
|
|
64
|
+
inject: [{ token: redis_provider_1.AGENTFORGE_REDIS_CLIENT, optional: true }],
|
|
65
|
+
useFactory: async (redis) => {
|
|
66
|
+
const log = nestLogger('RateLimiter');
|
|
67
|
+
if (!redis) {
|
|
68
|
+
log.log('Using in-memory rate limiter (no Redis configured)');
|
|
69
|
+
return new core_1.InMemoryRateLimiter();
|
|
70
|
+
}
|
|
71
|
+
try {
|
|
72
|
+
await redis.ping();
|
|
73
|
+
log.log('Using Redis-backed rate limiter');
|
|
74
|
+
return new core_1.RedisRateLimiter(redis);
|
|
75
|
+
}
|
|
76
|
+
catch (err) {
|
|
77
|
+
log.warn(`Redis unreachable (${err.message}); falling back to in-memory rate limiter.`);
|
|
78
|
+
return new core_1.InMemoryRateLimiter();
|
|
79
|
+
}
|
|
80
|
+
},
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
provide: core_1.ConversationService,
|
|
84
|
+
inject: [core_1.CONVERSATION_REPOSITORY, core_1.MESSAGE_REPOSITORY],
|
|
85
|
+
useFactory: (conv, msg) => new core_1.ConversationService(conv, msg),
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
provide: core_1.AgentService,
|
|
89
|
+
inject: [
|
|
90
|
+
core_1.AGENT_FORGE_CONFIG,
|
|
91
|
+
core_1.AgentRunnerService,
|
|
92
|
+
core_1.ConversationService,
|
|
93
|
+
{ token: exports.AGENT_RESOLVER, optional: true },
|
|
94
|
+
{ token: constants_1.AGENT_FORGE_HOOKS, optional: true },
|
|
95
|
+
{ token: core_1.ConnectorRegistryService, optional: true },
|
|
96
|
+
],
|
|
97
|
+
useFactory: (cfg, runner, conversations, resolver, hooks, connectorRegistry) => new core_1.AgentService(cfg.agents ?? [], runner, conversations, resolver, hooks, connectorRegistry),
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
provide: core_1.AgentJobWorker,
|
|
101
|
+
inject: [
|
|
102
|
+
core_1.OrchestratorService,
|
|
103
|
+
core_1.ConversationService,
|
|
104
|
+
{ token: constants_1.AGENT_FORGE_HOOKS, optional: true },
|
|
105
|
+
],
|
|
106
|
+
useFactory: (orchestrator, conversations, hooks) => new core_1.AgentJobWorker(orchestrator, conversations, {
|
|
107
|
+
logger: nestLogger('AgentJobWorker'),
|
|
108
|
+
hooks,
|
|
109
|
+
}),
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
provide: core_1.JOB_QUEUE,
|
|
113
|
+
inject: [core_1.AgentJobWorker],
|
|
114
|
+
useFactory: (worker) => new core_1.InMemoryJobQueue((payload, ctx) => worker.process(payload, ctx)),
|
|
115
|
+
},
|
|
116
|
+
{
|
|
117
|
+
provide: core_1.ChatTokenService,
|
|
118
|
+
inject: [core_1.CHAT_TOKEN_REPOSITORY],
|
|
119
|
+
useFactory: (repo) => new core_1.ChatTokenService(repo),
|
|
120
|
+
},
|
|
121
|
+
{
|
|
122
|
+
provide: core_1.McpClientService,
|
|
123
|
+
inject: [core_1.ToolRegistryService],
|
|
124
|
+
useFactory: (registry) => new core_1.McpClientService(registry, { logger: nestLogger('McpClient') }),
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
provide: core_1.McpServerService,
|
|
128
|
+
inject: [core_1.MCP_SERVER_REPOSITORY, core_1.McpClientService],
|
|
129
|
+
useFactory: (repo, client) => new core_1.McpServerService(repo, client),
|
|
130
|
+
},
|
|
131
|
+
];
|
|
132
|
+
}
|
|
133
|
+
function nestLogger(ctx) {
|
|
134
|
+
const l = new common_1.Logger(ctx);
|
|
135
|
+
return {
|
|
136
|
+
log: (m) => l.log(m),
|
|
137
|
+
warn: (m) => l.warn(m),
|
|
138
|
+
debug: (m) => l.debug(m),
|
|
139
|
+
error: (m) => l.error(m),
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
//# sourceMappingURL=services.providers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"services.providers.js","sourceRoot":"","sources":["../../src/providers/services.providers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.redisClientProvider = exports.AGENTFORGE_REDIS_CLIENT = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const ioredis_1 = require("ioredis");
|
|
6
|
+
const constants_1 = require("../constants");
|
|
7
|
+
exports.AGENTFORGE_REDIS_CLIENT = Symbol('AGENTFORGE_REDIS_CLIENT');
|
|
8
|
+
exports.redisClientProvider = {
|
|
9
|
+
provide: exports.AGENTFORGE_REDIS_CLIENT,
|
|
10
|
+
inject: [constants_1.AGENT_FORGE_CONFIG],
|
|
11
|
+
useFactory: (config) => {
|
|
12
|
+
const redis = config.redis;
|
|
13
|
+
if (!redis)
|
|
14
|
+
return null;
|
|
15
|
+
const logger = new common_1.Logger('AgentForgeRedis');
|
|
16
|
+
const client = createRedisClient(redis);
|
|
17
|
+
let lastWarn = 0;
|
|
18
|
+
client.on('error', (err) => {
|
|
19
|
+
const now = Date.now();
|
|
20
|
+
if (now - lastWarn > 5_000) {
|
|
21
|
+
logger.warn(`Redis error: ${err.message}`);
|
|
22
|
+
lastWarn = now;
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
client.once('connect', () => logger.log('Connected to Redis'));
|
|
26
|
+
return client;
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
function createRedisClient(redis) {
|
|
30
|
+
if (redis.url) {
|
|
31
|
+
const url = redis.url.match(/^rediss?:\/\//) ? redis.url : `redis://${redis.url}`;
|
|
32
|
+
return new ioredis_1.default(url, {
|
|
33
|
+
lazyConnect: false,
|
|
34
|
+
maxRetriesPerRequest: 3,
|
|
35
|
+
enableReadyCheck: true,
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
return new ioredis_1.default({
|
|
39
|
+
host: redis.host,
|
|
40
|
+
port: redis.port,
|
|
41
|
+
password: redis.password,
|
|
42
|
+
db: redis.db,
|
|
43
|
+
tls: redis.tls ? {} : undefined,
|
|
44
|
+
lazyConnect: false,
|
|
45
|
+
maxRetriesPerRequest: 3,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=redis.provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.provider.js","sourceRoot":"","sources":["../../src/redis/redis.provider.ts"],"names":[],"mappings":";;;AAAA,2CAAuD;AACvD,qCAA8C;AAC9C,4CAAkD;AAGrC,QAAA,uBAAuB,GAAG,MAAM,CAAC,yBAAyB,CAAC,CAAC;AAO5D,QAAA,mBAAmB,GAAa;IAC3C,OAAO,EAAE,+BAAuB;IAChC,MAAM,EAAE,CAAC,8BAAkB,CAAC;IAC5B,UAAU,EAAE,CAAC,MAAwB,EAAgB,EAAE;QACrD,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAC3B,IAAI,CAAC,KAAK;YAAE,OAAO,IAAI,CAAC;QAExB,MAAM,MAAM,GAAG,IAAI,eAAM,CAAC,iBAAiB,CAAC,CAAC;QAC7C,MAAM,MAAM,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAGxC,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;YACzB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,IAAI,GAAG,GAAG,QAAQ,GAAG,KAAK,EAAE,CAAC;gBAC3B,MAAM,CAAC,IAAI,CAAC,gBAAgB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;gBAC3C,QAAQ,GAAG,GAAG,CAAC;YACjB,CAAC;QACH,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,CAAC;QAE/D,OAAO,MAAM,CAAC;IAChB,CAAC;CACF,CAAC;AAEF,SAAS,iBAAiB,CAAC,KAAkB;IAC3C,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;QACd,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,KAAK,CAAC,GAAG,EAAE,CAAC;QAClF,OAAO,IAAI,iBAAO,CAAC,GAAG,EAAE;YACtB,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,CAAC;YACvB,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;IACL,CAAC;IACD,OAAO,IAAI,iBAAO,CAAC;QACjB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,EAAE,EAAE,KAAK,CAAC,EAAE;QACZ,GAAG,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS;QAC/B,WAAW,EAAE,KAAK;QAClB,oBAAoB,EAAE,CAAC;KACxB,CAAC,CAAC;AACL,CAAC"}
|