devchain-cli 0.2.1 → 0.3.1
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 +2 -0
- package/dist/cli.js +199 -42
- package/dist/drizzle/0018_whole_zodiak.sql +43 -0
- package/dist/drizzle/0019_flat_avengers.sql +3 -0
- package/dist/drizzle/0020_statuses_mcp_hidden.sql +1 -0
- package/dist/drizzle/meta/0018_snapshot.json +2920 -0
- package/dist/drizzle/meta/0019_snapshot.json +2943 -0
- package/dist/drizzle/meta/0020_snapshot.json +2951 -0
- package/dist/drizzle/meta/_journal.json +21 -0
- package/dist/server/app.module.js +11 -1
- package/dist/server/app.module.js.map +1 -1
- package/dist/server/common/config/env.config.d.ts +1 -0
- package/dist/server/common/config/env.config.js +4 -0
- package/dist/server/common/config/env.config.js.map +1 -1
- package/dist/server/common/filters/http-exception.filter.js +24 -1
- package/dist/server/common/filters/http-exception.filter.js.map +1 -1
- package/dist/server/common/logging/logger.js +4 -3
- package/dist/server/common/logging/logger.js.map +1 -1
- package/dist/server/main.js +0 -3
- package/dist/server/main.js.map +1 -1
- package/dist/server/modules/agents/agents.module.js +2 -1
- package/dist/server/modules/agents/agents.module.js.map +1 -1
- package/dist/server/modules/agents/controllers/agents.controller.d.ts +17 -2
- package/dist/server/modules/agents/controllers/agents.controller.js +84 -3
- package/dist/server/modules/agents/controllers/agents.controller.js.map +1 -1
- package/dist/server/modules/chat/dtos/chat.dto.d.ts +18 -18
- package/dist/server/modules/chat/services/invite-template.util.js +1 -1
- package/dist/server/modules/chat/services/invite-template.util.js.map +1 -1
- package/dist/server/modules/core/controllers/health.controller.d.ts +1 -0
- package/dist/server/modules/core/controllers/health.controller.js +23 -0
- package/dist/server/modules/core/controllers/health.controller.js.map +1 -1
- package/dist/server/modules/events/catalog/index.d.ts +40 -0
- package/dist/server/modules/events/catalog/index.js +2 -0
- package/dist/server/modules/events/catalog/index.js.map +1 -1
- package/dist/server/modules/events/catalog/terminal.watcher.triggered.d.ts +45 -0
- package/dist/server/modules/events/catalog/terminal.watcher.triggered.js +22 -0
- package/dist/server/modules/events/catalog/terminal.watcher.triggered.js.map +1 -0
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.d.ts +1 -0
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js +30 -12
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js.map +1 -1
- package/dist/server/modules/mcp/constants.js +5 -1
- package/dist/server/modules/mcp/constants.js.map +1 -1
- package/dist/server/modules/mcp/controllers/mcp-http.controller.js +78 -77
- package/dist/server/modules/mcp/controllers/mcp-http.controller.js.map +1 -1
- package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js +78 -77
- package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js.map +1 -1
- package/dist/server/modules/mcp/dtos/mcp.dto.d.ts +125 -97
- package/dist/server/modules/mcp/dtos/mcp.dto.js +23 -26
- package/dist/server/modules/mcp/dtos/mcp.dto.js.map +1 -1
- package/dist/server/modules/mcp/services/instructions-resolver.d.ts +3 -0
- package/dist/server/modules/mcp/services/instructions-resolver.js +83 -2
- package/dist/server/modules/mcp/services/instructions-resolver.js.map +1 -1
- package/dist/server/modules/mcp/services/mcp.service.d.ts +3 -2
- package/dist/server/modules/mcp/services/mcp.service.js +549 -263
- package/dist/server/modules/mcp/services/mcp.service.js.map +1 -1
- package/dist/server/modules/projects/controllers/projects.controller.d.ts +42 -0
- package/dist/server/modules/projects/controllers/projects.controller.js +11 -0
- package/dist/server/modules/projects/controllers/projects.controller.js.map +1 -1
- package/dist/server/modules/projects/projects.module.js +2 -1
- package/dist/server/modules/projects/projects.module.js.map +1 -1
- package/dist/server/modules/projects/services/projects.service.d.ts +47 -1
- package/dist/server/modules/projects/services/projects.service.js +278 -22
- package/dist/server/modules/projects/services/projects.service.js.map +1 -1
- package/dist/server/modules/prompts/controllers/prompts.controller.d.ts +1 -1
- package/dist/server/modules/prompts/controllers/prompts.controller.js +26 -4
- package/dist/server/modules/prompts/controllers/prompts.controller.js.map +1 -1
- package/dist/server/modules/sessions/utils/template-renderer.js +1 -0
- package/dist/server/modules/sessions/utils/template-renderer.js.map +1 -1
- package/dist/server/modules/statuses/controllers/statuses.controller.js +2 -0
- package/dist/server/modules/statuses/controllers/statuses.controller.js.map +1 -1
- package/dist/server/modules/storage/db/schema.d.ts +613 -0
- package/dist/server/modules/storage/db/schema.js +50 -1
- package/dist/server/modules/storage/db/schema.js.map +1 -1
- package/dist/server/modules/storage/interfaces/storage.interface.d.ts +40 -2
- package/dist/server/modules/storage/interfaces/storage.interface.js.map +1 -1
- package/dist/server/modules/storage/local/local-storage.service.d.ts +18 -3
- package/dist/server/modules/storage/local/local-storage.service.js +407 -11
- package/dist/server/modules/storage/local/local-storage.service.js.map +1 -1
- package/dist/server/modules/storage/models/domain.models.d.ts +59 -1
- package/dist/server/modules/subscribers/actions/action.interface.d.ts +67 -0
- package/dist/server/modules/subscribers/actions/action.interface.js +3 -0
- package/dist/server/modules/subscribers/actions/action.interface.js.map +1 -0
- package/dist/server/modules/subscribers/actions/actions.registry.d.ts +7 -0
- package/dist/server/modules/subscribers/actions/actions.registry.js +37 -0
- package/dist/server/modules/subscribers/actions/actions.registry.js.map +1 -0
- package/dist/server/modules/subscribers/actions/restart-agent.action.d.ts +8 -0
- package/dist/server/modules/subscribers/actions/restart-agent.action.js +119 -0
- package/dist/server/modules/subscribers/actions/restart-agent.action.js.map +1 -0
- package/dist/server/modules/subscribers/actions/send-message.action.d.ts +2 -0
- package/dist/server/modules/subscribers/actions/send-message.action.js +83 -0
- package/dist/server/modules/subscribers/actions/send-message.action.js.map +1 -0
- package/dist/server/modules/subscribers/controllers/actions.controller.d.ts +6 -0
- package/dist/server/modules/subscribers/controllers/actions.controller.js +51 -0
- package/dist/server/modules/subscribers/controllers/actions.controller.js.map +1 -0
- package/dist/server/modules/subscribers/controllers/subscribers.controller.d.ts +17 -0
- package/dist/server/modules/subscribers/controllers/subscribers.controller.js +178 -0
- package/dist/server/modules/subscribers/controllers/subscribers.controller.js.map +1 -0
- package/dist/server/modules/subscribers/dtos/subscriber.dto.d.ts +251 -0
- package/dist/server/modules/subscribers/dtos/subscriber.dto.js +68 -0
- package/dist/server/modules/subscribers/dtos/subscriber.dto.js.map +1 -0
- package/dist/server/modules/subscribers/events/event-fields-catalog.d.ts +19 -0
- package/dist/server/modules/subscribers/events/event-fields-catalog.js +98 -0
- package/dist/server/modules/subscribers/events/event-fields-catalog.js.map +1 -0
- package/dist/server/modules/subscribers/services/automation-scheduler.service.d.ts +49 -0
- package/dist/server/modules/subscribers/services/automation-scheduler.service.js +300 -0
- package/dist/server/modules/subscribers/services/automation-scheduler.service.js.map +1 -0
- package/dist/server/modules/subscribers/services/subscriber-executor.service.d.ts +77 -0
- package/dist/server/modules/subscribers/services/subscriber-executor.service.js +576 -0
- package/dist/server/modules/subscribers/services/subscriber-executor.service.js.map +1 -0
- package/dist/server/modules/subscribers/services/subscribers.service.d.ts +14 -0
- package/dist/server/modules/subscribers/services/subscribers.service.js +70 -0
- package/dist/server/modules/subscribers/services/subscribers.service.js.map +1 -0
- package/dist/server/modules/subscribers/subscribers.module.d.ts +2 -0
- package/dist/server/modules/subscribers/subscribers.module.js +36 -0
- package/dist/server/modules/subscribers/subscribers.module.js.map +1 -0
- package/dist/server/modules/terminal/services/tmux.service.js +9 -6
- package/dist/server/modules/terminal/services/tmux.service.js.map +1 -1
- package/dist/server/modules/watchers/controllers/watchers.controller.d.ts +16 -0
- package/dist/server/modules/watchers/controllers/watchers.controller.js +180 -0
- package/dist/server/modules/watchers/controllers/watchers.controller.js.map +1 -0
- package/dist/server/modules/watchers/dtos/watcher.dto.d.ts +206 -0
- package/dist/server/modules/watchers/dtos/watcher.dto.js +54 -0
- package/dist/server/modules/watchers/dtos/watcher.dto.js.map +1 -0
- package/dist/server/modules/watchers/services/watcher-runner.service.d.ts +68 -0
- package/dist/server/modules/watchers/services/watcher-runner.service.js +477 -0
- package/dist/server/modules/watchers/services/watcher-runner.service.js.map +1 -0
- package/dist/server/modules/watchers/services/watchers.service.d.ts +29 -0
- package/dist/server/modules/watchers/services/watchers.service.js +98 -0
- package/dist/server/modules/watchers/services/watchers.service.js.map +1 -0
- package/dist/server/modules/watchers/watchers.module.d.ts +2 -0
- package/dist/server/modules/watchers/watchers.module.js +34 -0
- package/dist/server/modules/watchers/watchers.module.js.map +1 -0
- package/dist/server/templates/claude-codex-advanced.json +377 -0
- package/dist/server/templates/claude-opus.json +29 -25
- package/dist/server/templates/simple-codex.json +29 -25
- package/dist/server/test-setup-node.d.ts +1 -0
- package/dist/server/test-setup-node.js +8 -0
- package/dist/server/test-setup-node.js.map +1 -0
- package/dist/server/test-setup.js +2 -0
- package/dist/server/test-setup.js.map +1 -1
- package/dist/server/tsconfig.tsbuildinfo +1 -1
- package/dist/server/ui/assets/index-C9GXCjnF.js +700 -0
- package/dist/server/ui/assets/index-o0FbZg-1.css +32 -0
- package/dist/server/ui/index.html +2 -2
- package/dist/templates/claude-codex-advanced.json +377 -0
- package/dist/templates/claude-opus.json +29 -25
- package/dist/templates/simple-codex.json +29 -25
- package/package.json +58 -27
- package/dist/server/templates/codex-claude.json +0 -178
- package/dist/server/ui/assets/index-5Xb7jFMJ.js +0 -641
- package/dist/server/ui/assets/index-CbYIbCQV.css +0 -32
- package/dist/templates/codex-claude.json +0 -178
|
@@ -0,0 +1,300 @@
|
|
|
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.AutomationSchedulerService = void 0;
|
|
13
|
+
exports.compareScheduledTasks = compareScheduledTasks;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
16
|
+
const logger = (0, logger_1.createLogger)('AutomationSchedulerService');
|
|
17
|
+
const DEFAULT_CONCURRENCY = {
|
|
18
|
+
maxGlobal: 4,
|
|
19
|
+
maxPerAgent: 1,
|
|
20
|
+
maxPerGroup: 1,
|
|
21
|
+
};
|
|
22
|
+
const BLOCKED_RECHECK_DELAY_MS = 50;
|
|
23
|
+
function compareScheduledTasks(a, b) {
|
|
24
|
+
if (a.runAt !== b.runAt) {
|
|
25
|
+
return a.runAt - b.runAt;
|
|
26
|
+
}
|
|
27
|
+
if (a.priority !== b.priority) {
|
|
28
|
+
return b.priority - a.priority;
|
|
29
|
+
}
|
|
30
|
+
if (a.position !== b.position) {
|
|
31
|
+
return a.position - b.position;
|
|
32
|
+
}
|
|
33
|
+
return a.createdAt.localeCompare(b.createdAt);
|
|
34
|
+
}
|
|
35
|
+
let AutomationSchedulerService = class AutomationSchedulerService {
|
|
36
|
+
constructor() {
|
|
37
|
+
this.queue = [];
|
|
38
|
+
this.wakeTimer = null;
|
|
39
|
+
this.executingTasks = new Set();
|
|
40
|
+
this.executingByAgent = new Map();
|
|
41
|
+
this.executingByGroup = new Map();
|
|
42
|
+
this.concurrency = { ...DEFAULT_CONCURRENCY };
|
|
43
|
+
this.isShuttingDown = false;
|
|
44
|
+
logger.info('AutomationSchedulerService initialized');
|
|
45
|
+
}
|
|
46
|
+
onModuleDestroy() {
|
|
47
|
+
logger.info('AutomationSchedulerService shutting down');
|
|
48
|
+
this.isShuttingDown = true;
|
|
49
|
+
this.clearWakeTimer();
|
|
50
|
+
this.queue = [];
|
|
51
|
+
}
|
|
52
|
+
setConcurrency(config) {
|
|
53
|
+
this.concurrency = { ...this.concurrency, ...config };
|
|
54
|
+
logger.debug({ concurrency: this.concurrency }, 'Concurrency configuration updated');
|
|
55
|
+
}
|
|
56
|
+
getConcurrency() {
|
|
57
|
+
return { ...this.concurrency };
|
|
58
|
+
}
|
|
59
|
+
schedule(task) {
|
|
60
|
+
if (this.isShuttingDown) {
|
|
61
|
+
logger.warn({ taskId: task.taskId }, 'Ignoring schedule during shutdown');
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
this.insertSorted(task);
|
|
65
|
+
logger.debug({
|
|
66
|
+
taskId: task.taskId,
|
|
67
|
+
subscriberId: task.subscriberId,
|
|
68
|
+
runAt: new Date(task.runAt).toISOString(),
|
|
69
|
+
priority: task.priority,
|
|
70
|
+
position: task.position,
|
|
71
|
+
groupKey: task.groupKey,
|
|
72
|
+
queueLength: this.queue.length,
|
|
73
|
+
}, 'Task scheduled');
|
|
74
|
+
this.scheduleNextWake();
|
|
75
|
+
}
|
|
76
|
+
cancel(taskId) {
|
|
77
|
+
const index = this.queue.findIndex((t) => t.taskId === taskId);
|
|
78
|
+
if (index === -1) {
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
this.queue.splice(index, 1);
|
|
82
|
+
logger.debug({ taskId }, 'Task cancelled');
|
|
83
|
+
this.scheduleNextWake();
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
cancelBySubscriber(subscriberId) {
|
|
87
|
+
const before = this.queue.length;
|
|
88
|
+
this.queue = this.queue.filter((t) => t.subscriberId !== subscriberId);
|
|
89
|
+
const cancelled = before - this.queue.length;
|
|
90
|
+
if (cancelled > 0) {
|
|
91
|
+
logger.debug({ subscriberId, cancelled }, 'Tasks cancelled for subscriber');
|
|
92
|
+
this.scheduleNextWake();
|
|
93
|
+
}
|
|
94
|
+
return cancelled;
|
|
95
|
+
}
|
|
96
|
+
getQueueLength() {
|
|
97
|
+
return this.queue.length;
|
|
98
|
+
}
|
|
99
|
+
getExecutingCount() {
|
|
100
|
+
return this.executingTasks.size;
|
|
101
|
+
}
|
|
102
|
+
isExecuting(taskId) {
|
|
103
|
+
return this.executingTasks.has(taskId);
|
|
104
|
+
}
|
|
105
|
+
insertSorted(task) {
|
|
106
|
+
let low = 0;
|
|
107
|
+
let high = this.queue.length;
|
|
108
|
+
while (low < high) {
|
|
109
|
+
const mid = (low + high) >>> 1;
|
|
110
|
+
if (compareScheduledTasks(this.queue[mid], task) <= 0) {
|
|
111
|
+
low = mid + 1;
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
high = mid;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
this.queue.splice(low, 0, task);
|
|
118
|
+
}
|
|
119
|
+
clearWakeTimer() {
|
|
120
|
+
if (this.wakeTimer) {
|
|
121
|
+
clearTimeout(this.wakeTimer);
|
|
122
|
+
this.wakeTimer = null;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
scheduleNextWake() {
|
|
126
|
+
this.clearWakeTimer();
|
|
127
|
+
if (this.isShuttingDown || this.queue.length === 0) {
|
|
128
|
+
return;
|
|
129
|
+
}
|
|
130
|
+
const now = Date.now();
|
|
131
|
+
const nextTask = this.queue[0];
|
|
132
|
+
const delay = Math.max(0, nextTask.runAt - now);
|
|
133
|
+
const timer = setTimeout(() => {
|
|
134
|
+
this.wakeTimer = null;
|
|
135
|
+
this.processDueTasks();
|
|
136
|
+
}, delay);
|
|
137
|
+
if (typeof timer.unref === 'function') {
|
|
138
|
+
timer.unref();
|
|
139
|
+
}
|
|
140
|
+
this.wakeTimer = timer;
|
|
141
|
+
logger.debug({
|
|
142
|
+
nextTaskId: nextTask.taskId,
|
|
143
|
+
delay,
|
|
144
|
+
runAt: new Date(nextTask.runAt).toISOString(),
|
|
145
|
+
}, 'Wake timer scheduled');
|
|
146
|
+
}
|
|
147
|
+
processDueTasks() {
|
|
148
|
+
if (this.isShuttingDown) {
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
const now = Date.now();
|
|
152
|
+
let tasksStarted = 0;
|
|
153
|
+
let tasksBlocked = 0;
|
|
154
|
+
while (this.queue.length > 0) {
|
|
155
|
+
const task = this.queue[0];
|
|
156
|
+
if (task.runAt > now) {
|
|
157
|
+
break;
|
|
158
|
+
}
|
|
159
|
+
if (!this.canExecute(task)) {
|
|
160
|
+
tasksBlocked++;
|
|
161
|
+
let foundRunnable = false;
|
|
162
|
+
for (let i = 1; i < this.queue.length && this.queue[i].runAt <= now; i++) {
|
|
163
|
+
if (this.canExecute(this.queue[i])) {
|
|
164
|
+
const runnableTask = this.queue.splice(i, 1)[0];
|
|
165
|
+
this.executeTask(runnableTask);
|
|
166
|
+
tasksStarted++;
|
|
167
|
+
foundRunnable = true;
|
|
168
|
+
break;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
if (!foundRunnable) {
|
|
172
|
+
break;
|
|
173
|
+
}
|
|
174
|
+
continue;
|
|
175
|
+
}
|
|
176
|
+
this.queue.shift();
|
|
177
|
+
this.executeTask(task);
|
|
178
|
+
tasksStarted++;
|
|
179
|
+
}
|
|
180
|
+
logger.debug({
|
|
181
|
+
tasksStarted,
|
|
182
|
+
tasksBlocked,
|
|
183
|
+
queueRemaining: this.queue.length,
|
|
184
|
+
executing: this.executingTasks.size,
|
|
185
|
+
}, 'processDueTasks completed');
|
|
186
|
+
if (tasksBlocked > 0 && this.queue.length > 0 && this.queue[0].runAt <= now) {
|
|
187
|
+
const timer = setTimeout(() => {
|
|
188
|
+
this.wakeTimer = null;
|
|
189
|
+
this.processDueTasks();
|
|
190
|
+
}, BLOCKED_RECHECK_DELAY_MS);
|
|
191
|
+
if (typeof timer.unref === 'function') {
|
|
192
|
+
timer.unref();
|
|
193
|
+
}
|
|
194
|
+
this.wakeTimer = timer;
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
this.scheduleNextWake();
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
canExecute(task) {
|
|
201
|
+
if (this.executingTasks.size >= this.concurrency.maxGlobal) {
|
|
202
|
+
return false;
|
|
203
|
+
}
|
|
204
|
+
if (task.agentId) {
|
|
205
|
+
const agentCount = this.executingByAgent.get(task.agentId) ?? 0;
|
|
206
|
+
if (agentCount >= this.concurrency.maxPerAgent) {
|
|
207
|
+
return false;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
const groupCount = this.executingByGroup.get(task.groupKey) ?? 0;
|
|
211
|
+
if (groupCount >= this.concurrency.maxPerGroup) {
|
|
212
|
+
return false;
|
|
213
|
+
}
|
|
214
|
+
return true;
|
|
215
|
+
}
|
|
216
|
+
executeTask(task) {
|
|
217
|
+
this.executingTasks.add(task.taskId);
|
|
218
|
+
if (task.agentId) {
|
|
219
|
+
this.executingByAgent.set(task.agentId, (this.executingByAgent.get(task.agentId) ?? 0) + 1);
|
|
220
|
+
}
|
|
221
|
+
this.executingByGroup.set(task.groupKey, (this.executingByGroup.get(task.groupKey) ?? 0) + 1);
|
|
222
|
+
logger.info({
|
|
223
|
+
taskId: task.taskId,
|
|
224
|
+
subscriberId: task.subscriberId,
|
|
225
|
+
groupKey: task.groupKey,
|
|
226
|
+
agentId: task.agentId,
|
|
227
|
+
globalConcurrency: this.executingTasks.size,
|
|
228
|
+
}, 'Executing task');
|
|
229
|
+
task
|
|
230
|
+
.execute()
|
|
231
|
+
.then((result) => {
|
|
232
|
+
logger.debug({
|
|
233
|
+
taskId: task.taskId,
|
|
234
|
+
subscriberId: task.subscriberId,
|
|
235
|
+
success: result.success,
|
|
236
|
+
}, 'Task execution completed');
|
|
237
|
+
})
|
|
238
|
+
.catch((error) => {
|
|
239
|
+
logger.error({
|
|
240
|
+
taskId: task.taskId,
|
|
241
|
+
subscriberId: task.subscriberId,
|
|
242
|
+
error: error instanceof Error ? error.message : String(error),
|
|
243
|
+
}, 'Task execution failed');
|
|
244
|
+
})
|
|
245
|
+
.finally(() => {
|
|
246
|
+
this.releaseTask(task);
|
|
247
|
+
if (!this.isShuttingDown && this.queue.length > 0 && !this.wakeTimer) {
|
|
248
|
+
const now = Date.now();
|
|
249
|
+
if (this.queue[0].runAt <= now) {
|
|
250
|
+
const timer = setTimeout(() => {
|
|
251
|
+
this.wakeTimer = null;
|
|
252
|
+
this.processDueTasks();
|
|
253
|
+
}, 0);
|
|
254
|
+
if (typeof timer.unref === 'function') {
|
|
255
|
+
timer.unref();
|
|
256
|
+
}
|
|
257
|
+
this.wakeTimer = timer;
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
});
|
|
261
|
+
}
|
|
262
|
+
releaseTask(task) {
|
|
263
|
+
this.executingTasks.delete(task.taskId);
|
|
264
|
+
if (task.agentId) {
|
|
265
|
+
const agentCount = this.executingByAgent.get(task.agentId) ?? 1;
|
|
266
|
+
if (agentCount <= 1) {
|
|
267
|
+
this.executingByAgent.delete(task.agentId);
|
|
268
|
+
}
|
|
269
|
+
else {
|
|
270
|
+
this.executingByAgent.set(task.agentId, agentCount - 1);
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
const groupCount = this.executingByGroup.get(task.groupKey) ?? 1;
|
|
274
|
+
if (groupCount <= 1) {
|
|
275
|
+
this.executingByGroup.delete(task.groupKey);
|
|
276
|
+
}
|
|
277
|
+
else {
|
|
278
|
+
this.executingByGroup.set(task.groupKey, groupCount - 1);
|
|
279
|
+
}
|
|
280
|
+
logger.debug({
|
|
281
|
+
taskId: task.taskId,
|
|
282
|
+
globalConcurrency: this.executingTasks.size,
|
|
283
|
+
}, 'Task released');
|
|
284
|
+
}
|
|
285
|
+
_getQueue() {
|
|
286
|
+
return [...this.queue];
|
|
287
|
+
}
|
|
288
|
+
_processDueTasks() {
|
|
289
|
+
this.processDueTasks();
|
|
290
|
+
}
|
|
291
|
+
_hasWakeTimer() {
|
|
292
|
+
return this.wakeTimer !== null;
|
|
293
|
+
}
|
|
294
|
+
};
|
|
295
|
+
exports.AutomationSchedulerService = AutomationSchedulerService;
|
|
296
|
+
exports.AutomationSchedulerService = AutomationSchedulerService = __decorate([
|
|
297
|
+
(0, common_1.Injectable)(),
|
|
298
|
+
__metadata("design:paramtypes", [])
|
|
299
|
+
], AutomationSchedulerService);
|
|
300
|
+
//# sourceMappingURL=automation-scheduler.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"automation-scheduler.service.js","sourceRoot":"","sources":["../../../../src/modules/subscribers/services/automation-scheduler.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { OnModuleInit, OnModuleDestroy } from '@nestjs/common';
|
|
2
|
+
import { EventEmitter2 } from '@nestjs/event-emitter';
|
|
3
|
+
import { type StorageService } from '../../storage/interfaces/storage.interface';
|
|
4
|
+
import type { Subscriber, EventFilter, ActionInput } from '../../storage/models/domain.models';
|
|
5
|
+
import { TmuxService } from '../../terminal/services/tmux.service';
|
|
6
|
+
import { SessionsService } from '../../sessions/services/sessions.service';
|
|
7
|
+
import { SessionCoordinatorService } from '../../sessions/services/session-coordinator.service';
|
|
8
|
+
import { TerminalSendCoordinatorService } from '../../terminal/services/terminal-send-coordinator.service';
|
|
9
|
+
import { EventLogService } from '../../events/services/event-log.service';
|
|
10
|
+
import { AutomationSchedulerService } from './automation-scheduler.service';
|
|
11
|
+
export interface SubscriberExecutionResult {
|
|
12
|
+
subscriberId: string;
|
|
13
|
+
subscriberName: string;
|
|
14
|
+
actionType: string;
|
|
15
|
+
success: boolean;
|
|
16
|
+
message?: string;
|
|
17
|
+
error?: string;
|
|
18
|
+
durationMs: number;
|
|
19
|
+
skipped?: boolean;
|
|
20
|
+
skipReason?: 'deleted' | 'disabled' | 'filter_not_matched' | 'cooldown' | 'action_not_found' | 'session_error';
|
|
21
|
+
}
|
|
22
|
+
export interface EventScheduleResult {
|
|
23
|
+
eventName: string;
|
|
24
|
+
subscribersMatched: number;
|
|
25
|
+
subscribersScheduled: number;
|
|
26
|
+
subscribersSkipped: number;
|
|
27
|
+
scheduledTasks: Array<{
|
|
28
|
+
subscriberId: string;
|
|
29
|
+
subscriberName: string;
|
|
30
|
+
runAtIso: string;
|
|
31
|
+
delayMs: number;
|
|
32
|
+
groupKey: string;
|
|
33
|
+
priority: number;
|
|
34
|
+
position: number;
|
|
35
|
+
}>;
|
|
36
|
+
skippedSubscribers: Array<{
|
|
37
|
+
subscriberId: string;
|
|
38
|
+
subscriberName: string;
|
|
39
|
+
reason: string;
|
|
40
|
+
}>;
|
|
41
|
+
}
|
|
42
|
+
export interface SubscribableEventPayload {
|
|
43
|
+
projectId: string;
|
|
44
|
+
sessionId?: string;
|
|
45
|
+
agentId?: string | null;
|
|
46
|
+
[key: string]: unknown;
|
|
47
|
+
}
|
|
48
|
+
export declare class SubscriberExecutorService implements OnModuleInit, OnModuleDestroy {
|
|
49
|
+
private readonly storage;
|
|
50
|
+
private readonly tmuxService;
|
|
51
|
+
private readonly sessionsService;
|
|
52
|
+
private readonly sessionCoordinator;
|
|
53
|
+
private readonly sendCoordinator;
|
|
54
|
+
private readonly eventLogService;
|
|
55
|
+
private readonly eventEmitter;
|
|
56
|
+
private readonly scheduler;
|
|
57
|
+
private readonly logger;
|
|
58
|
+
private subscriberLastExec;
|
|
59
|
+
private eventHandler;
|
|
60
|
+
constructor(storage: StorageService, tmuxService: TmuxService, sessionsService: SessionsService, sessionCoordinator: SessionCoordinatorService, sendCoordinator: TerminalSendCoordinatorService, eventLogService: EventLogService, eventEmitter: EventEmitter2, scheduler: AutomationSchedulerService);
|
|
61
|
+
onModuleInit(): Promise<void>;
|
|
62
|
+
onModuleDestroy(): void;
|
|
63
|
+
private resolveProjectId;
|
|
64
|
+
private scheduleEventProcessing;
|
|
65
|
+
private executeSubscriberForTask;
|
|
66
|
+
handleEvent(eventName: string, payload: SubscribableEventPayload): Promise<EventScheduleResult | null>;
|
|
67
|
+
getSubscribableEventNames(): string[];
|
|
68
|
+
matchesFilter(filter: EventFilter, payload: SubscribableEventPayload): boolean;
|
|
69
|
+
getPayloadField(payload: SubscribableEventPayload, field: string): unknown;
|
|
70
|
+
private getNestedValue;
|
|
71
|
+
interpolateTemplate(template: string, templateContext: Record<string, unknown>): string;
|
|
72
|
+
resolveInputs(inputMappings: Record<string, ActionInput>, payload: SubscribableEventPayload, templateVars?: Record<string, unknown>): Record<string, unknown>;
|
|
73
|
+
executeSubscriber(subscriber: Subscriber, eventName: string, payload: SubscribableEventPayload): Promise<SubscriberExecutionResult>;
|
|
74
|
+
isOnCooldown(subscriberId: string, sessionId: string, cooldownMs: number): boolean;
|
|
75
|
+
setCooldown(subscriberId: string, sessionId: string): void;
|
|
76
|
+
clearCooldown(subscriberId: string, sessionId: string): void;
|
|
77
|
+
}
|