@venturialstd/workflow 0.1.152 → 0.1.154
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 +238 -238
- package/dist/constants/workflow.constant.d.ts +5 -0
- package/dist/constants/workflow.constant.d.ts.map +1 -1
- package/dist/constants/workflow.constant.js +7 -1
- package/dist/constants/workflow.constant.js.map +1 -1
- package/dist/entities/workflow-user.entity.d.ts +13 -0
- package/dist/entities/workflow-user.entity.d.ts.map +1 -0
- package/dist/entities/workflow-user.entity.js +87 -0
- package/dist/entities/workflow-user.entity.js.map +1 -0
- package/dist/gateways/workflow-realtime.gateway.d.ts +59 -0
- package/dist/gateways/workflow-realtime.gateway.d.ts.map +1 -0
- package/dist/gateways/workflow-realtime.gateway.js +189 -0
- package/dist/gateways/workflow-realtime.gateway.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/services/workflow-edge.service.d.ts +7 -1
- package/dist/services/workflow-edge.service.d.ts.map +1 -1
- package/dist/services/workflow-edge.service.js +29 -2
- package/dist/services/workflow-edge.service.js.map +1 -1
- package/dist/services/workflow-node.service.d.ts +7 -1
- package/dist/services/workflow-node.service.d.ts.map +1 -1
- package/dist/services/workflow-node.service.js +29 -2
- package/dist/services/workflow-node.service.js.map +1 -1
- package/dist/services/workflow-sse.service.d.ts +19 -1
- package/dist/services/workflow-sse.service.d.ts.map +1 -1
- package/dist/services/workflow-sse.service.js +24 -0
- package/dist/services/workflow-sse.service.js.map +1 -1
- package/dist/services/workflow-user.service.d.ts +20 -0
- package/dist/services/workflow-user.service.d.ts.map +1 -0
- package/dist/services/workflow-user.service.js +111 -0
- package/dist/services/workflow-user.service.js.map +1 -0
- package/dist/services/workflow.service.d.ts +6 -1
- package/dist/services/workflow.service.d.ts.map +1 -1
- package/dist/services/workflow.service.js +26 -4
- package/dist/services/workflow.service.js.map +1 -1
- package/dist/workflow-core.module.d.ts.map +1 -1
- package/dist/workflow-core.module.js +7 -0
- package/dist/workflow-core.module.js.map +1 -1
- package/package.json +111 -109
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { OnGatewayDisconnect } from '@nestjs/websockets';
|
|
2
|
+
import { Server } from 'socket.io';
|
|
3
|
+
import { WorkflowUserService } from '../services/workflow-user.service';
|
|
4
|
+
export interface SocketUser {
|
|
5
|
+
id: string;
|
|
6
|
+
email?: string;
|
|
7
|
+
name?: string;
|
|
8
|
+
}
|
|
9
|
+
export interface WorkflowJoinPayload {
|
|
10
|
+
workflowId: string;
|
|
11
|
+
}
|
|
12
|
+
export interface WorkflowNodePositionPayload {
|
|
13
|
+
nodeId: string;
|
|
14
|
+
position: {
|
|
15
|
+
x: number;
|
|
16
|
+
y: number;
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
export interface WorkflowNodeDataPayload {
|
|
20
|
+
nodeId: string;
|
|
21
|
+
data: Record<string, unknown>;
|
|
22
|
+
}
|
|
23
|
+
export interface WorkflowCursorPayload {
|
|
24
|
+
x: number;
|
|
25
|
+
y: number;
|
|
26
|
+
nodeId?: string | null;
|
|
27
|
+
viewport?: {
|
|
28
|
+
x: number;
|
|
29
|
+
y: number;
|
|
30
|
+
zoom: number;
|
|
31
|
+
} | null;
|
|
32
|
+
}
|
|
33
|
+
export declare class WorkflowRealtimeGateway implements OnGatewayDisconnect {
|
|
34
|
+
private readonly workflowUserService;
|
|
35
|
+
private readonly logger;
|
|
36
|
+
server: Server;
|
|
37
|
+
constructor(workflowUserService: WorkflowUserService);
|
|
38
|
+
private getUser;
|
|
39
|
+
private getRoomMeta;
|
|
40
|
+
handleJoin(payload: WorkflowJoinPayload, socket: any): Promise<{
|
|
41
|
+
event: string;
|
|
42
|
+
data: {
|
|
43
|
+
workflowId: string;
|
|
44
|
+
canEdit: boolean;
|
|
45
|
+
} | {
|
|
46
|
+
error: string;
|
|
47
|
+
};
|
|
48
|
+
}>;
|
|
49
|
+
handleNodePosition(payload: WorkflowNodePositionPayload, socket: any): Promise<void>;
|
|
50
|
+
handleNodeData(payload: WorkflowNodeDataPayload, socket: any): Promise<void>;
|
|
51
|
+
handleCursor(payload: WorkflowCursorPayload, socket: any): Promise<void>;
|
|
52
|
+
handleViewport(payload: {
|
|
53
|
+
x: number;
|
|
54
|
+
y: number;
|
|
55
|
+
zoom: number;
|
|
56
|
+
}, socket: any): Promise<void>;
|
|
57
|
+
handleDisconnect(socket: any): void;
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=workflow-realtime.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-realtime.gateway.d.ts","sourceRoot":"","sources":["../../src/gateways/workflow-realtime.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,EAKL,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAGnC,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAKxE,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAGD,MAAM,WAAW,mBAAmB;IAClC,UAAU,EAAE,MAAM,CAAC;CACpB;AAGD,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CACpC;AAGD,MAAM,WAAW,uBAAuB;IACtC,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC/B;AAGD,MAAM,WAAW,qBAAqB;IACpC,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,QAAQ,CAAC,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;CAC1D;AAQD,qBAIa,uBAAwB,YAAW,mBAAmB;IAMrD,OAAO,CAAC,QAAQ,CAAC,mBAAmB;IALhD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4C;IAGnE,MAAM,EAAG,MAAM,CAAC;gBAEa,mBAAmB,EAAE,mBAAmB;IAGrE,OAAO,CAAC,OAAO;IAKf,OAAO,CAAC,WAAW;IAKb,UAAU,CACC,OAAO,EAAE,mBAAmB,EAC3C,MAAM,EAAE,GAAG,GACV,OAAO,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE;YAAE,UAAU,EAAE,MAAM,CAAC;YAAC,OAAO,EAAE,OAAO,CAAA;SAAE,GAAG;YAAE,KAAK,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;IA4C3F,kBAAkB,CACP,OAAO,EAAE,2BAA2B,EACnD,MAAM,EAAE,GAAG,GACV,OAAO,CAAC,IAAI,CAAC;IAoBV,cAAc,CACH,OAAO,EAAE,uBAAuB,EAC/C,MAAM,EAAE,GAAG,GACV,OAAO,CAAC,IAAI,CAAC;IAoBV,YAAY,CACD,OAAO,EAAE,qBAAqB,EAC7C,MAAM,EAAE,GAAG,GACV,OAAO,CAAC,IAAI,CAAC;IAeV,cAAc,CACH,OAAO,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,EAC9D,MAAM,EAAE,GAAG,GACV,OAAO,CAAC,IAAI,CAAC;IAYhB,gBAAgB,CAAC,MAAM,EAAE,GAAG,GAAG,IAAI;CAQpC"}
|
|
@@ -0,0 +1,189 @@
|
|
|
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 WorkflowRealtimeGateway_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.WorkflowRealtimeGateway = void 0;
|
|
17
|
+
const websockets_1 = require("@nestjs/websockets");
|
|
18
|
+
const socket_io_1 = require("socket.io");
|
|
19
|
+
const common_1 = require("@nestjs/common");
|
|
20
|
+
const workflow_user_service_1 = require("../services/workflow-user.service");
|
|
21
|
+
const ROOM_PREFIX = 'workflow:';
|
|
22
|
+
let WorkflowRealtimeGateway = WorkflowRealtimeGateway_1 = class WorkflowRealtimeGateway {
|
|
23
|
+
workflowUserService;
|
|
24
|
+
logger = new common_1.Logger(WorkflowRealtimeGateway_1.name);
|
|
25
|
+
server;
|
|
26
|
+
constructor(workflowUserService) {
|
|
27
|
+
this.workflowUserService = workflowUserService;
|
|
28
|
+
}
|
|
29
|
+
getUser(socket) {
|
|
30
|
+
return socket.data?.user ?? null;
|
|
31
|
+
}
|
|
32
|
+
getRoomMeta(socket) {
|
|
33
|
+
return socket.data?.workflowRoom ?? null;
|
|
34
|
+
}
|
|
35
|
+
async handleJoin(payload, socket) {
|
|
36
|
+
const user = this.getUser(socket);
|
|
37
|
+
if (!user?.id) {
|
|
38
|
+
this.logger.warn('workflow:join without user');
|
|
39
|
+
return { event: 'workflow:join:error', data: { error: 'Unauthorized' } };
|
|
40
|
+
}
|
|
41
|
+
const { workflowId } = payload || {};
|
|
42
|
+
if (!workflowId || typeof workflowId !== 'string') {
|
|
43
|
+
return { event: 'workflow:join:error', data: { error: 'workflowId required' } };
|
|
44
|
+
}
|
|
45
|
+
try {
|
|
46
|
+
const canView = await this.workflowUserService.canView(workflowId, user.id);
|
|
47
|
+
if (!canView) {
|
|
48
|
+
return { event: 'workflow:join:error', data: { error: 'Forbidden' } };
|
|
49
|
+
}
|
|
50
|
+
const canEdit = await this.workflowUserService.canEdit(workflowId, user.id);
|
|
51
|
+
const room = ROOM_PREFIX + workflowId;
|
|
52
|
+
await socket.join(room);
|
|
53
|
+
socket.data.workflowRoom = { workflowId, canEdit };
|
|
54
|
+
this.logger.debug(`User ${user.id} joined workflow ${workflowId} (canEdit: ${canEdit})`);
|
|
55
|
+
socket.to(room).emit('workflow:user:joined', {
|
|
56
|
+
userId: user.id,
|
|
57
|
+
email: user.email,
|
|
58
|
+
name: user.name,
|
|
59
|
+
canEdit,
|
|
60
|
+
});
|
|
61
|
+
return {
|
|
62
|
+
event: 'workflow:joined',
|
|
63
|
+
data: { workflowId, canEdit },
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
catch (err) {
|
|
67
|
+
this.logger.error('workflow:join error', err);
|
|
68
|
+
return { event: 'workflow:join:error', data: { error: 'Server error' } };
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
async handleNodePosition(payload, socket) {
|
|
72
|
+
const roomMeta = this.getRoomMeta(socket);
|
|
73
|
+
const user = this.getUser(socket);
|
|
74
|
+
if (!roomMeta || !user)
|
|
75
|
+
return;
|
|
76
|
+
if (!roomMeta.canEdit)
|
|
77
|
+
return;
|
|
78
|
+
const { nodeId, position } = payload || {};
|
|
79
|
+
if (!nodeId || !position || typeof position.x !== 'number' || typeof position.y !== 'number')
|
|
80
|
+
return;
|
|
81
|
+
const room = ROOM_PREFIX + roomMeta.workflowId;
|
|
82
|
+
socket.to(room).emit('workflow:node:position', {
|
|
83
|
+
nodeId,
|
|
84
|
+
position,
|
|
85
|
+
userId: user.id,
|
|
86
|
+
userEmail: user.email,
|
|
87
|
+
userName: user.name,
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
async handleNodeData(payload, socket) {
|
|
91
|
+
const roomMeta = this.getRoomMeta(socket);
|
|
92
|
+
const user = this.getUser(socket);
|
|
93
|
+
if (!roomMeta || !user)
|
|
94
|
+
return;
|
|
95
|
+
if (!roomMeta.canEdit)
|
|
96
|
+
return;
|
|
97
|
+
const { nodeId, data } = payload || {};
|
|
98
|
+
if (!nodeId || !data || typeof data !== 'object')
|
|
99
|
+
return;
|
|
100
|
+
const room = ROOM_PREFIX + roomMeta.workflowId;
|
|
101
|
+
socket.to(room).emit('workflow:node:data', {
|
|
102
|
+
nodeId,
|
|
103
|
+
data,
|
|
104
|
+
userId: user.id,
|
|
105
|
+
userEmail: user.email,
|
|
106
|
+
userName: user.name,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
async handleCursor(payload, socket) {
|
|
110
|
+
const roomMeta = this.getRoomMeta(socket);
|
|
111
|
+
const user = this.getUser(socket);
|
|
112
|
+
if (!roomMeta || !user)
|
|
113
|
+
return;
|
|
114
|
+
const room = ROOM_PREFIX + roomMeta.workflowId;
|
|
115
|
+
socket.to(room).emit('workflow:cursor', {
|
|
116
|
+
userId: user.id,
|
|
117
|
+
userEmail: user.email,
|
|
118
|
+
userName: user.name,
|
|
119
|
+
...payload,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
async handleViewport(payload, socket) {
|
|
123
|
+
const roomMeta = this.getRoomMeta(socket);
|
|
124
|
+
const user = this.getUser(socket);
|
|
125
|
+
if (!roomMeta || !user)
|
|
126
|
+
return;
|
|
127
|
+
const room = ROOM_PREFIX + roomMeta.workflowId;
|
|
128
|
+
socket.to(room).emit('workflow:viewport', {
|
|
129
|
+
userId: user.id,
|
|
130
|
+
...payload,
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
handleDisconnect(socket) {
|
|
134
|
+
const roomMeta = this.getRoomMeta(socket);
|
|
135
|
+
const user = this.getUser(socket);
|
|
136
|
+
if (roomMeta && user) {
|
|
137
|
+
const room = ROOM_PREFIX + roomMeta.workflowId;
|
|
138
|
+
socket.to(room).emit('workflow:user:left', { userId: user.id });
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
exports.WorkflowRealtimeGateway = WorkflowRealtimeGateway;
|
|
143
|
+
__decorate([
|
|
144
|
+
(0, websockets_1.WebSocketServer)(),
|
|
145
|
+
__metadata("design:type", socket_io_1.Server)
|
|
146
|
+
], WorkflowRealtimeGateway.prototype, "server", void 0);
|
|
147
|
+
__decorate([
|
|
148
|
+
(0, websockets_1.SubscribeMessage)('workflow:join'),
|
|
149
|
+
__param(0, (0, websockets_1.MessageBody)()),
|
|
150
|
+
__metadata("design:type", Function),
|
|
151
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
152
|
+
__metadata("design:returntype", Promise)
|
|
153
|
+
], WorkflowRealtimeGateway.prototype, "handleJoin", null);
|
|
154
|
+
__decorate([
|
|
155
|
+
(0, websockets_1.SubscribeMessage)('workflow:node:position'),
|
|
156
|
+
__param(0, (0, websockets_1.MessageBody)()),
|
|
157
|
+
__metadata("design:type", Function),
|
|
158
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
159
|
+
__metadata("design:returntype", Promise)
|
|
160
|
+
], WorkflowRealtimeGateway.prototype, "handleNodePosition", null);
|
|
161
|
+
__decorate([
|
|
162
|
+
(0, websockets_1.SubscribeMessage)('workflow:node:data'),
|
|
163
|
+
__param(0, (0, websockets_1.MessageBody)()),
|
|
164
|
+
__metadata("design:type", Function),
|
|
165
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
166
|
+
__metadata("design:returntype", Promise)
|
|
167
|
+
], WorkflowRealtimeGateway.prototype, "handleNodeData", null);
|
|
168
|
+
__decorate([
|
|
169
|
+
(0, websockets_1.SubscribeMessage)('workflow:cursor'),
|
|
170
|
+
__param(0, (0, websockets_1.MessageBody)()),
|
|
171
|
+
__metadata("design:type", Function),
|
|
172
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
173
|
+
__metadata("design:returntype", Promise)
|
|
174
|
+
], WorkflowRealtimeGateway.prototype, "handleCursor", null);
|
|
175
|
+
__decorate([
|
|
176
|
+
(0, websockets_1.SubscribeMessage)('workflow:viewport'),
|
|
177
|
+
__param(0, (0, websockets_1.MessageBody)()),
|
|
178
|
+
__metadata("design:type", Function),
|
|
179
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
180
|
+
__metadata("design:returntype", Promise)
|
|
181
|
+
], WorkflowRealtimeGateway.prototype, "handleViewport", null);
|
|
182
|
+
exports.WorkflowRealtimeGateway = WorkflowRealtimeGateway = WorkflowRealtimeGateway_1 = __decorate([
|
|
183
|
+
(0, websockets_1.WebSocketGateway)({
|
|
184
|
+
cors: { origin: true },
|
|
185
|
+
namespace: '/workflow-realtime',
|
|
186
|
+
}),
|
|
187
|
+
__metadata("design:paramtypes", [workflow_user_service_1.WorkflowUserService])
|
|
188
|
+
], WorkflowRealtimeGateway);
|
|
189
|
+
//# sourceMappingURL=workflow-realtime.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-realtime.gateway.js","sourceRoot":"","sources":["../../src/gateways/workflow-realtime.gateway.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -8,6 +8,7 @@ export * from './entities/workflow-module-credential.entity';
|
|
|
8
8
|
export * from './entities/workflow-node.entity';
|
|
9
9
|
export * from './entities/workflow-node-execution.entity';
|
|
10
10
|
export * from './entities/workflow-session.entity';
|
|
11
|
+
export * from './entities/workflow-user.entity';
|
|
11
12
|
export * from './entities/workflow-webhook.entity';
|
|
12
13
|
export * from './controllers/workflow-module-credential.controller';
|
|
13
14
|
export * from './controllers/workflow-node.controller';
|
|
@@ -21,6 +22,7 @@ export * from './services/workflow-module-credential.service';
|
|
|
21
22
|
export * from './services/workflow-node.service';
|
|
22
23
|
export * from './services/workflow-node-execution.service';
|
|
23
24
|
export * from './services/workflow-session.service';
|
|
25
|
+
export * from './services/workflow-user.service';
|
|
24
26
|
export * from './services/workflow-webhook.service';
|
|
25
27
|
export * from './modules';
|
|
26
28
|
export * from './modules/ai/ai-nest.module';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,+BAA+B,CAAC;AAG9C,cAAc,QAAQ,CAAC;AAGvB,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iCAAiC,CAAC;AAChD,cAAc,sCAAsC,CAAC;AACrD,OAAO,EAAE,cAAc,IAAI,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AAC3F,cAAc,8CAA8C,CAAC;AAC7D,cAAc,iCAAiC,CAAC;AAChD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,oCAAoC,CAAC;AACnD,cAAc,oCAAoC,CAAC;AAGnD,cAAc,qDAAqD,CAAC;AACpE,cAAc,wCAAwC,CAAC;AACvD,cAAc,kDAAkD,CAAC;AAGjE,cAAc,6CAA6C,CAAC;AAC5D,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kCAAkC,CAAC;AACjD,cAAc,uCAAuC,CAAC;AACtD,cAAc,oCAAoC,CAAC;AACnD,cAAc,+CAA+C,CAAC;AAC9D,cAAc,kCAAkC,CAAC;AACjD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,qCAAqC,CAAC;AACpD,cAAc,qCAAqC,CAAC;AAGpD,cAAc,WAAW,CAAC;AAG1B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,uCAAuC,CAAC;AACtD,cAAc,+CAA+C,CAAC;AAC9D,cAAc,qCAAqC,CAAC;AACpD,cAAc,uCAAuC,CAAC;AACtD,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,+BAA+B,CAAC;AAG9C,cAAc,QAAQ,CAAC;AAGvB,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iCAAiC,CAAC;AAChD,cAAc,sCAAsC,CAAC;AACrD,OAAO,EAAE,cAAc,IAAI,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AAC3F,cAAc,8CAA8C,CAAC;AAC7D,cAAc,iCAAiC,CAAC;AAChD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,oCAAoC,CAAC;AACnD,cAAc,iCAAiC,CAAC;AAChD,cAAc,oCAAoC,CAAC;AAGnD,cAAc,qDAAqD,CAAC;AACpE,cAAc,wCAAwC,CAAC;AACvD,cAAc,kDAAkD,CAAC;AAGjE,cAAc,6CAA6C,CAAC;AAC5D,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kCAAkC,CAAC;AACjD,cAAc,uCAAuC,CAAC;AACtD,cAAc,oCAAoC,CAAC;AACnD,cAAc,+CAA+C,CAAC;AAC9D,cAAc,kCAAkC,CAAC;AACjD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,qCAAqC,CAAC;AACpD,cAAc,kCAAkC,CAAC;AACjD,cAAc,qCAAqC,CAAC;AAGpD,cAAc,WAAW,CAAC;AAG1B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,uCAAuC,CAAC;AACtD,cAAc,+CAA+C,CAAC;AAC9D,cAAc,qCAAqC,CAAC;AACpD,cAAc,uCAAuC,CAAC;AACtD,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -26,6 +26,7 @@ __exportStar(require("./entities/workflow-module-credential.entity"), exports);
|
|
|
26
26
|
__exportStar(require("./entities/workflow-node.entity"), exports);
|
|
27
27
|
__exportStar(require("./entities/workflow-node-execution.entity"), exports);
|
|
28
28
|
__exportStar(require("./entities/workflow-session.entity"), exports);
|
|
29
|
+
__exportStar(require("./entities/workflow-user.entity"), exports);
|
|
29
30
|
__exportStar(require("./entities/workflow-webhook.entity"), exports);
|
|
30
31
|
__exportStar(require("./controllers/workflow-module-credential.controller"), exports);
|
|
31
32
|
__exportStar(require("./controllers/workflow-node.controller"), exports);
|
|
@@ -39,6 +40,7 @@ __exportStar(require("./services/workflow-module-credential.service"), exports);
|
|
|
39
40
|
__exportStar(require("./services/workflow-node.service"), exports);
|
|
40
41
|
__exportStar(require("./services/workflow-node-execution.service"), exports);
|
|
41
42
|
__exportStar(require("./services/workflow-session.service"), exports);
|
|
43
|
+
__exportStar(require("./services/workflow-user.service"), exports);
|
|
42
44
|
__exportStar(require("./services/workflow-webhook.service"), exports);
|
|
43
45
|
__exportStar(require("./modules"), exports);
|
|
44
46
|
__exportStar(require("./modules/ai/ai-nest.module"), exports);
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,gEAA8C;AAG9C,yCAAuB;AAGvB,6DAA2C;AAC3C,kEAAgD;AAChD,uEAAqD;AACrD,4EAA2F;AAAlF,8HAAA,cAAc,OAAwB;AAC/C,+EAA6D;AAC7D,kEAAgD;AAChD,4EAA0D;AAC1D,qEAAmD;AACnD,qEAAmD;AAGnD,sFAAoE;AACpE,yEAAuD;AACvD,mFAAiE;AAGjE,8EAA4D;AAC5D,8DAA4C;AAC5C,mEAAiD;AACjD,wEAAsD;AACtD,qEAAmD;AACnD,gFAA8D;AAC9D,mEAAiD;AACjD,6EAA2D;AAC3D,sEAAoD;AACpD,sEAAoD;AAGpD,4CAA0B;AAG1B,8DAA4C;AAC5C,wEAAsD;AACtD,gFAA8D;AAC9D,sEAAoD;AACpD,wEAAsD;AACtD,oDAAkC;AAClC,yDAAuC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,gEAA8C;AAG9C,yCAAuB;AAGvB,6DAA2C;AAC3C,kEAAgD;AAChD,uEAAqD;AACrD,4EAA2F;AAAlF,8HAAA,cAAc,OAAwB;AAC/C,+EAA6D;AAC7D,kEAAgD;AAChD,4EAA0D;AAC1D,qEAAmD;AACnD,kEAAgD;AAChD,qEAAmD;AAGnD,sFAAoE;AACpE,yEAAuD;AACvD,mFAAiE;AAGjE,8EAA4D;AAC5D,8DAA4C;AAC5C,mEAAiD;AACjD,wEAAsD;AACtD,qEAAmD;AACnD,gFAA8D;AAC9D,mEAAiD;AACjD,6EAA2D;AAC3D,sEAAoD;AACpD,mEAAiD;AACjD,sEAAoD;AAGpD,4CAA0B;AAG1B,8DAA4C;AAC5C,wEAAsD;AACtD,gFAA8D;AAC9D,sEAAoD;AACpD,wEAAsD;AACtD,oDAAkC;AAClC,yDAAuC"}
|
|
@@ -1,9 +1,15 @@
|
|
|
1
|
+
import { CrudRequest } from '@dataui/crud';
|
|
1
2
|
import { TypeOrmCrudService } from '@dataui/crud-typeorm';
|
|
2
3
|
import { Repository } from 'typeorm';
|
|
3
4
|
import { WorkflowEdge } from '../entities/workflow-edge.entity';
|
|
5
|
+
import { WorkflowSSEService } from './workflow-sse.service';
|
|
4
6
|
export declare class WorkflowEdgeService extends TypeOrmCrudService<WorkflowEdge> {
|
|
5
7
|
readonly repo: Repository<WorkflowEdge>;
|
|
6
|
-
|
|
8
|
+
private readonly sseService;
|
|
9
|
+
constructor(repo: Repository<WorkflowEdge>, sseService: WorkflowSSEService);
|
|
10
|
+
createOne(req: CrudRequest, dto: Partial<WorkflowEdge>): Promise<WorkflowEdge>;
|
|
11
|
+
updateOne(req: CrudRequest, dto: Partial<WorkflowEdge>): Promise<WorkflowEdge>;
|
|
12
|
+
deleteOne(req: CrudRequest): Promise<void | WorkflowEdge>;
|
|
7
13
|
getEdgesByWorkflowId(workflowId: string): Promise<WorkflowEdge[]>;
|
|
8
14
|
getEdgeByEdgeId(workflowId: string, edgeId: string): Promise<WorkflowEdge>;
|
|
9
15
|
getEdgesBySourceNode(workflowId: string, sourceNodeId: string): Promise<WorkflowEdge[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-edge.service.d.ts","sourceRoot":"","sources":["../../src/services/workflow-edge.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;
|
|
1
|
+
{"version":3,"file":"workflow-edge.service.d.ts","sourceRoot":"","sources":["../../src/services/workflow-edge.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAE5D,qBACa,mBAAoB,SAAQ,kBAAkB,CAAC,YAAY,CAAC;aAGrD,IAAI,EAAE,UAAU,CAAC,YAAY,CAAC;IAC9C,OAAO,CAAC,QAAQ,CAAC,UAAU;gBADX,IAAI,EAAE,UAAU,CAAC,YAAY,CAAC,EAC7B,UAAU,EAAE,kBAAkB;IAK3C,SAAS,CAAC,GAAG,EAAE,WAAW,EAAE,GAAG,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,CAAC;IAQ9E,SAAS,CAAC,GAAG,EAAE,WAAW,EAAE,GAAG,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,CAAC;IAQ9E,SAAS,CAAC,GAAG,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,GAAG,YAAY,CAAC;IAUzD,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAIjE,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAU1E,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAIvF,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;CAG9F"}
|
|
@@ -18,11 +18,37 @@ const common_1 = require("@nestjs/common");
|
|
|
18
18
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
19
19
|
const typeorm_2 = require("typeorm");
|
|
20
20
|
const workflow_edge_entity_1 = require("../entities/workflow-edge.entity");
|
|
21
|
+
const workflow_sse_service_1 = require("./workflow-sse.service");
|
|
21
22
|
let WorkflowEdgeService = class WorkflowEdgeService extends crud_typeorm_1.TypeOrmCrudService {
|
|
22
23
|
repo;
|
|
23
|
-
|
|
24
|
+
sseService;
|
|
25
|
+
constructor(repo, sseService) {
|
|
24
26
|
super(repo);
|
|
25
27
|
this.repo = repo;
|
|
28
|
+
this.sseService = sseService;
|
|
29
|
+
}
|
|
30
|
+
async createOne(req, dto) {
|
|
31
|
+
const result = await super.createOne(req, dto);
|
|
32
|
+
if (result?.workflowId) {
|
|
33
|
+
this.sseService.emitEditorEdgesUpdated(result.workflowId);
|
|
34
|
+
}
|
|
35
|
+
return result;
|
|
36
|
+
}
|
|
37
|
+
async updateOne(req, dto) {
|
|
38
|
+
const result = await super.updateOne(req, dto);
|
|
39
|
+
if (result?.workflowId) {
|
|
40
|
+
this.sseService.emitEditorEdgesUpdated(result.workflowId);
|
|
41
|
+
}
|
|
42
|
+
return result;
|
|
43
|
+
}
|
|
44
|
+
async deleteOne(req) {
|
|
45
|
+
const found = await this.getOneOrFail(req, false);
|
|
46
|
+
const workflowId = found.workflowId;
|
|
47
|
+
const result = await super.deleteOne(req);
|
|
48
|
+
if (workflowId) {
|
|
49
|
+
this.sseService.emitEditorEdgesUpdated(workflowId);
|
|
50
|
+
}
|
|
51
|
+
return result;
|
|
26
52
|
}
|
|
27
53
|
async getEdgesByWorkflowId(workflowId) {
|
|
28
54
|
return this.repo.find({ where: { workflowId } });
|
|
@@ -47,6 +73,7 @@ exports.WorkflowEdgeService = WorkflowEdgeService;
|
|
|
47
73
|
exports.WorkflowEdgeService = WorkflowEdgeService = __decorate([
|
|
48
74
|
(0, common_1.Injectable)(),
|
|
49
75
|
__param(0, (0, typeorm_1.InjectRepository)(workflow_edge_entity_1.WorkflowEdge)),
|
|
50
|
-
__metadata("design:paramtypes", [typeorm_2.Repository
|
|
76
|
+
__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
77
|
+
workflow_sse_service_1.WorkflowSSEService])
|
|
51
78
|
], WorkflowEdgeService);
|
|
52
79
|
//# sourceMappingURL=workflow-edge.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-edge.service.js","sourceRoot":"","sources":["../../src/services/workflow-edge.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"workflow-edge.service.js","sourceRoot":"","sources":["../../src/services/workflow-edge.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,uDAA0D;AAC1D,2CAA+D;AAC/D,6CAAmD;AACnD,qCAAqC;AAErC,2EAAgE;AAChE,iEAA4D;AAGrD,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,iCAAgC;IAGrD;IACC;IAHnB,YAEkB,IAA8B,EAC7B,UAA8B;QAE/C,KAAK,CAAC,IAAI,CAAC,CAAC;QAHI,SAAI,GAAJ,IAAI,CAA0B;QAC7B,eAAU,GAAV,UAAU,CAAoB;IAGjD,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,GAAgB,EAAE,GAA0B;QAC1D,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/C,IAAI,MAAM,EAAE,UAAU,EAAE,CAAC;YACvB,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC5D,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,GAAgB,EAAE,GAA0B;QAC1D,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/C,IAAI,MAAM,EAAE,UAAU,EAAE,CAAC;YACvB,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC5D,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,GAAgB;QAC9B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAClD,MAAM,UAAU,GAAI,KAAsB,CAAC,UAAU,CAAC;QACtD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC;QACrD,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,UAAkB;QAC3C,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,UAAkB,EAAE,MAAc;QACtD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;YACnC,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE;SAC9B,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,0BAAiB,CAAC,iBAAiB,MAAM,4BAA4B,UAAU,GAAG,CAAC,CAAC;QAChG,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,UAAkB,EAAE,YAAoB;QACjE,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,CAAC,CAAC;IACzE,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,UAAkB,EAAE,YAAoB;QACjE,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,CAAC,CAAC;IACzE,CAAC;CACF,CAAA;AAxDY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,0BAAgB,EAAC,mCAAY,CAAC,CAAA;qCACT,oBAAU;QACH,yCAAkB;GAJtC,mBAAmB,CAwD/B"}
|
|
@@ -1,9 +1,15 @@
|
|
|
1
|
+
import { CrudRequest } from '@dataui/crud';
|
|
1
2
|
import { TypeOrmCrudService } from '@dataui/crud-typeorm';
|
|
2
3
|
import { Repository } from 'typeorm';
|
|
3
4
|
import { WorkflowNode } from '../entities/workflow-node.entity';
|
|
5
|
+
import { WorkflowSSEService } from './workflow-sse.service';
|
|
4
6
|
export declare class WorkflowNodeService extends TypeOrmCrudService<WorkflowNode> {
|
|
5
7
|
readonly repo: Repository<WorkflowNode>;
|
|
6
|
-
|
|
8
|
+
private readonly sseService;
|
|
9
|
+
constructor(repo: Repository<WorkflowNode>, sseService: WorkflowSSEService);
|
|
10
|
+
createOne(req: CrudRequest, dto: Partial<WorkflowNode>): Promise<WorkflowNode>;
|
|
11
|
+
updateOne(req: CrudRequest, dto: Partial<WorkflowNode>): Promise<WorkflowNode>;
|
|
12
|
+
deleteOne(req: CrudRequest): Promise<void | WorkflowNode>;
|
|
7
13
|
getNodesByWorkflowId(workflowId: string): Promise<WorkflowNode[]>;
|
|
8
14
|
getNodeByNodeId(workflowId: string, nodeId: string): Promise<WorkflowNode>;
|
|
9
15
|
updateNodeProperties(id: string, properties: Record<string, unknown>): Promise<WorkflowNode>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-node.service.d.ts","sourceRoot":"","sources":["../../src/services/workflow-node.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;
|
|
1
|
+
{"version":3,"file":"workflow-node.service.d.ts","sourceRoot":"","sources":["../../src/services/workflow-node.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAE5D,qBACa,mBAAoB,SAAQ,kBAAkB,CAAC,YAAY,CAAC;aAGrD,IAAI,EAAE,UAAU,CAAC,YAAY,CAAC;IAC9C,OAAO,CAAC,QAAQ,CAAC,UAAU;gBADX,IAAI,EAAE,UAAU,CAAC,YAAY,CAAC,EAC7B,UAAU,EAAE,kBAAkB;IAK3C,SAAS,CAAC,GAAG,EAAE,WAAW,EAAE,GAAG,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,CAAC;IAQ9E,SAAS,CAAC,GAAG,EAAE,WAAW,EAAE,GAAG,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,CAAC;IAQ9E,SAAS,CAAC,GAAG,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,GAAG,YAAY,CAAC;IAUzD,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAIjE,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAU1E,oBAAoB,CACxB,EAAE,EAAE,MAAM,EACV,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAClC,OAAO,CAAC,YAAY,CAAC;IAUlB,kBAAkB,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,YAAY,CAAC;CAShG"}
|
|
@@ -18,11 +18,37 @@ const common_1 = require("@nestjs/common");
|
|
|
18
18
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
19
19
|
const typeorm_2 = require("typeorm");
|
|
20
20
|
const workflow_node_entity_1 = require("../entities/workflow-node.entity");
|
|
21
|
+
const workflow_sse_service_1 = require("./workflow-sse.service");
|
|
21
22
|
let WorkflowNodeService = class WorkflowNodeService extends crud_typeorm_1.TypeOrmCrudService {
|
|
22
23
|
repo;
|
|
23
|
-
|
|
24
|
+
sseService;
|
|
25
|
+
constructor(repo, sseService) {
|
|
24
26
|
super(repo);
|
|
25
27
|
this.repo = repo;
|
|
28
|
+
this.sseService = sseService;
|
|
29
|
+
}
|
|
30
|
+
async createOne(req, dto) {
|
|
31
|
+
const result = await super.createOne(req, dto);
|
|
32
|
+
if (result?.workflowId) {
|
|
33
|
+
this.sseService.emitEditorNodesUpdated(result.workflowId);
|
|
34
|
+
}
|
|
35
|
+
return result;
|
|
36
|
+
}
|
|
37
|
+
async updateOne(req, dto) {
|
|
38
|
+
const result = await super.updateOne(req, dto);
|
|
39
|
+
if (result?.workflowId) {
|
|
40
|
+
this.sseService.emitEditorNodesUpdated(result.workflowId);
|
|
41
|
+
}
|
|
42
|
+
return result;
|
|
43
|
+
}
|
|
44
|
+
async deleteOne(req) {
|
|
45
|
+
const found = await this.getOneOrFail(req, false);
|
|
46
|
+
const workflowId = found.workflowId;
|
|
47
|
+
const result = await super.deleteOne(req);
|
|
48
|
+
if (workflowId) {
|
|
49
|
+
this.sseService.emitEditorNodesUpdated(workflowId);
|
|
50
|
+
}
|
|
51
|
+
return result;
|
|
26
52
|
}
|
|
27
53
|
async getNodesByWorkflowId(workflowId) {
|
|
28
54
|
return this.repo.find({ where: { workflowId } });
|
|
@@ -57,6 +83,7 @@ exports.WorkflowNodeService = WorkflowNodeService;
|
|
|
57
83
|
exports.WorkflowNodeService = WorkflowNodeService = __decorate([
|
|
58
84
|
(0, common_1.Injectable)(),
|
|
59
85
|
__param(0, (0, typeorm_1.InjectRepository)(workflow_node_entity_1.WorkflowNode)),
|
|
60
|
-
__metadata("design:paramtypes", [typeorm_2.Repository
|
|
86
|
+
__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
87
|
+
workflow_sse_service_1.WorkflowSSEService])
|
|
61
88
|
], WorkflowNodeService);
|
|
62
89
|
//# sourceMappingURL=workflow-node.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-node.service.js","sourceRoot":"","sources":["../../src/services/workflow-node.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"workflow-node.service.js","sourceRoot":"","sources":["../../src/services/workflow-node.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,10 +11,19 @@ export interface WorkflowExecutionEvent {
|
|
|
11
11
|
data?: unknown;
|
|
12
12
|
errorMessage?: string;
|
|
13
13
|
}
|
|
14
|
+
export interface WorkflowEditorEvent {
|
|
15
|
+
type: 'workflow.editor.nodes' | 'workflow.editor.edges' | 'workflow.editor.settings';
|
|
16
|
+
workflowId: string;
|
|
17
|
+
timestamp: Date;
|
|
18
|
+
data?: {
|
|
19
|
+
userId?: string;
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
export type WorkflowStreamEvent = WorkflowExecutionEvent | WorkflowEditorEvent;
|
|
14
23
|
export declare class WorkflowSSEService {
|
|
15
24
|
private eventSubjects;
|
|
16
25
|
private getEventSubject;
|
|
17
|
-
subscribe(workflowId: string): Observable<
|
|
26
|
+
subscribe(workflowId: string): Observable<WorkflowStreamEvent>;
|
|
18
27
|
emitWorkflowStarted(workflowId: string, workflowExecutionId: string, data?: unknown): void;
|
|
19
28
|
emitWorkflowCompleted(workflowId: string, workflowExecutionId: string, data?: unknown): void;
|
|
20
29
|
emitWorkflowFailed(workflowId: string, workflowExecutionId: string, errorMessage?: string, data?: unknown): void;
|
|
@@ -23,6 +32,15 @@ export declare class WorkflowSSEService {
|
|
|
23
32
|
emitNodeCompleted(workflowId: string, workflowExecutionId: string, nodeId: string, nodeLabel?: string, data?: unknown): void;
|
|
24
33
|
emitNodeFailed(workflowId: string, workflowExecutionId: string, nodeId: string, nodeLabel?: string, errorMessage?: string, data?: unknown): void;
|
|
25
34
|
private emit;
|
|
35
|
+
emitEditorNodesUpdated(workflowId: string, data?: {
|
|
36
|
+
userId?: string;
|
|
37
|
+
}): void;
|
|
38
|
+
emitEditorEdgesUpdated(workflowId: string, data?: {
|
|
39
|
+
userId?: string;
|
|
40
|
+
}): void;
|
|
41
|
+
emitEditorSettingsUpdated(workflowId: string, data?: {
|
|
42
|
+
userId?: string;
|
|
43
|
+
}): void;
|
|
26
44
|
cleanup(workflowId: string): void;
|
|
27
45
|
createEventStream(res: Response, workflowId: string): void;
|
|
28
46
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-sse.service.d.ts","sourceRoot":"","sources":["../../src/services/workflow-sse.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,UAAU,EAAW,MAAM,MAAM,CAAC;AAE3C,MAAM,WAAW,sBAAsB;IACrC,IAAI,EACA,kBAAkB,GAClB,oBAAoB,GACpB,iBAAiB,GACjB,cAAc,GACd,gBAAgB,GAChB,aAAa,GACb,cAAc,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,WAAW,CAAC;IACtE,SAAS,EAAE,IAAI,CAAC;IAChB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,qBACa,kBAAkB;IAC7B,OAAO,CAAC,aAAa,
|
|
1
|
+
{"version":3,"file":"workflow-sse.service.d.ts","sourceRoot":"","sources":["../../src/services/workflow-sse.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -112,6 +112,30 @@ let WorkflowSSEService = class WorkflowSSEService {
|
|
|
112
112
|
subject.next(event);
|
|
113
113
|
}
|
|
114
114
|
}
|
|
115
|
+
emitEditorNodesUpdated(workflowId, data) {
|
|
116
|
+
this.emit(workflowId, {
|
|
117
|
+
type: 'workflow.editor.nodes',
|
|
118
|
+
workflowId,
|
|
119
|
+
timestamp: new Date(),
|
|
120
|
+
data,
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
emitEditorEdgesUpdated(workflowId, data) {
|
|
124
|
+
this.emit(workflowId, {
|
|
125
|
+
type: 'workflow.editor.edges',
|
|
126
|
+
workflowId,
|
|
127
|
+
timestamp: new Date(),
|
|
128
|
+
data,
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
emitEditorSettingsUpdated(workflowId, data) {
|
|
132
|
+
this.emit(workflowId, {
|
|
133
|
+
type: 'workflow.editor.settings',
|
|
134
|
+
workflowId,
|
|
135
|
+
timestamp: new Date(),
|
|
136
|
+
data,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
115
139
|
cleanup(workflowId) {
|
|
116
140
|
const subject = this.eventSubjects.get(workflowId);
|
|
117
141
|
if (subject) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-sse.service.js","sourceRoot":"","sources":["../../src/services/workflow-sse.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAE5C,+BAA2C;
|
|
1
|
+
{"version":3,"file":"workflow-sse.service.js","sourceRoot":"","sources":["../../src/services/workflow-sse.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { TypeOrmCrudService } from '@dataui/crud-typeorm';
|
|
2
|
+
import { Repository } from 'typeorm';
|
|
3
|
+
import { WORKFLOW_USER_ROLE } from '../constants/workflow.constant';
|
|
4
|
+
import { WorkflowUser } from '../entities/workflow-user.entity';
|
|
5
|
+
export declare class WorkflowUserService extends TypeOrmCrudService<WorkflowUser> {
|
|
6
|
+
readonly repo: Repository<WorkflowUser>;
|
|
7
|
+
constructor(repo: Repository<WorkflowUser>);
|
|
8
|
+
getWorkflowsByUser(userId: string): Promise<WorkflowUser[]>;
|
|
9
|
+
getUsersByWorkflow(workflowId: string): Promise<WorkflowUser[]>;
|
|
10
|
+
getUserRole(workflowId: string, userId: string): Promise<WORKFLOW_USER_ROLE | null>;
|
|
11
|
+
hasPermission(workflowId: string, userId: string, requiredRole: WORKFLOW_USER_ROLE): Promise<boolean>;
|
|
12
|
+
verifyPermission(workflowId: string, userId: string, requiredRole: WORKFLOW_USER_ROLE): Promise<void>;
|
|
13
|
+
canView(workflowId: string, userId: string): Promise<boolean>;
|
|
14
|
+
canEdit(workflowId: string, userId: string): Promise<boolean>;
|
|
15
|
+
isOwner(workflowId: string, userId: string): Promise<boolean>;
|
|
16
|
+
shareWorkflow(workflowId: string, targetUserId: string, role: WORKFLOW_USER_ROLE, sharedBy: string): Promise<WorkflowUser>;
|
|
17
|
+
updateUserRole(workflowId: string, targetUserId: string, newRole: WORKFLOW_USER_ROLE, updatedBy: string): Promise<WorkflowUser>;
|
|
18
|
+
removeUserFromWorkflow(workflowId: string, targetUserId: string, removedBy: string): Promise<void>;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=workflow-user.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-user.service.d.ts","sourceRoot":"","sources":["../../src/services/workflow-user.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAEhE,qBACa,mBAAoB,SAAQ,kBAAkB,CAAC,YAAY,CAAC;aAGrD,IAAI,EAAE,UAAU,CAAC,YAAY,CAAC;gBAA9B,IAAI,EAAE,UAAU,CAAC,YAAY,CAAC;IAK1C,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAI3D,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAO/D,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;IAUnF,aAAa,CACjB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,kBAAkB,GAC/B,OAAO,CAAC,OAAO,CAAC;IAmBb,gBAAgB,CACpB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,kBAAkB,GAC/B,OAAO,CAAC,IAAI,CAAC;IAYV,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAO7D,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAO7D,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAQ7D,aAAa,CACjB,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,MAAM,EACpB,IAAI,EAAE,kBAAkB,EACxB,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC,YAAY,CAAC;IA+BlB,cAAc,CAClB,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,kBAAkB,EAC3B,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,YAAY,CAAC;IAsBlB,sBAAsB,CAC1B,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,MAAM,EACpB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,IAAI,CAAC;CAQjB"}
|