@loopstack/api 0.1.2 → 0.3.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/CHANGELOG.md +24 -0
- package/dist/controllers/config.controller.js +9 -2
- package/dist/controllers/config.controller.js.map +1 -1
- package/dist/dtos/pipeline-item.dto.d.ts +2 -2
- package/dist/dtos/pipeline-item.dto.js +3 -2
- package/dist/dtos/pipeline-item.dto.js.map +1 -1
- package/dist/dtos/pipeline.dto.d.ts +2 -2
- package/dist/dtos/pipeline.dto.js +3 -2
- package/dist/dtos/pipeline.dto.js.map +1 -1
- package/dist/dtos/project-item.dto.d.ts +2 -2
- package/dist/dtos/project-item.dto.js +1 -1
- package/dist/dtos/project.dto.d.ts +2 -2
- package/dist/dtos/project.dto.js +1 -1
- package/dist/dtos/workflow-item.dto.d.ts +2 -2
- package/dist/dtos/workflow-item.dto.js +6 -6
- package/dist/dtos/workflow-item.dto.js.map +1 -1
- package/dist/dtos/workflow.dto.d.ts +2 -2
- package/dist/dtos/workflow.dto.js +6 -6
- package/dist/dtos/workflow.dto.js.map +1 -1
- package/dist/services/processor-api.service.d.ts +3 -3
- package/dist/services/processor-api.service.js +11 -11
- package/dist/services/processor-api.service.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -3
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,29 @@
|
|
|
1
1
|
# @loopstack/api
|
|
2
2
|
|
|
3
|
+
## 0.3.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- Improved Document Handling, Template Expressions and added Config Includes
|
|
8
|
+
|
|
9
|
+
### Patch Changes
|
|
10
|
+
|
|
11
|
+
- Updated dependencies
|
|
12
|
+
- @loopstack/core@0.3.0
|
|
13
|
+
- @loopstack/shared@0.3.0
|
|
14
|
+
|
|
15
|
+
## 0.2.0
|
|
16
|
+
|
|
17
|
+
### Minor Changes
|
|
18
|
+
|
|
19
|
+
- Rework of Pipeline and Workflow processing including improvements for configuration schemas
|
|
20
|
+
|
|
21
|
+
### Patch Changes
|
|
22
|
+
|
|
23
|
+
- Updated dependencies
|
|
24
|
+
- @loopstack/core@0.2.0
|
|
25
|
+
- @loopstack/shared@0.2.0
|
|
26
|
+
|
|
3
27
|
## 0.1.2
|
|
4
28
|
|
|
5
29
|
### Patch Changes
|
|
@@ -20,6 +20,7 @@ const class_transformer_1 = require("class-transformer");
|
|
|
20
20
|
const pipeline_config_dto_1 = require("../dtos/pipeline-config.dto");
|
|
21
21
|
const workspace_config_dto_1 = require("../dtos/workspace-config.dto");
|
|
22
22
|
const jwt_auth_guard_1 = require("../guards/jwt-auth.guard");
|
|
23
|
+
const lodash_1 = require("lodash");
|
|
23
24
|
let ConfigController = class ConfigController {
|
|
24
25
|
configService;
|
|
25
26
|
constructor(configService) {
|
|
@@ -33,8 +34,14 @@ let ConfigController = class ConfigController {
|
|
|
33
34
|
}
|
|
34
35
|
getPipelineTypesByWorkspace(workspaceName) {
|
|
35
36
|
const pipelineTypes = this.configService.getAll('pipelines');
|
|
36
|
-
const filtered = pipelineTypes
|
|
37
|
-
|
|
37
|
+
const filtered = pipelineTypes
|
|
38
|
+
.filter((pipeline) => pipeline.config.type === 'root' && pipeline.config.workspace === workspaceName)
|
|
39
|
+
.map((pipeline) => ({
|
|
40
|
+
...pipeline.config,
|
|
41
|
+
name: `${pipeline.path}:${pipeline.name}`,
|
|
42
|
+
}));
|
|
43
|
+
const sorted = (0, lodash_1.sortBy)(filtered, 'title');
|
|
44
|
+
return (0, class_transformer_1.plainToInstance)(pipeline_config_dto_1.PipelineConfigDto, sorted, {
|
|
38
45
|
excludeExtraneousValues: true,
|
|
39
46
|
});
|
|
40
47
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.controller.js","sourceRoot":"","sources":["../../src/controllers/config.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,6CAOyB;AACzB,2CAA6F;AAE7F,0CAAuD;AACvD,yDAAoD;AACpD,qEAAgE;AAChE,uEAAkE;AAClE,6DAAwD;
|
|
1
|
+
{"version":3,"file":"config.controller.js","sourceRoot":"","sources":["../../src/controllers/config.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,6CAOyB;AACzB,2CAA6F;AAE7F,0CAAuD;AACvD,yDAAoD;AACpD,qEAAgE;AAChE,uEAAkE;AAClE,6DAAwD;AACxD,mCAAgC;AAMzB,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAEP;IAApB,YAAoB,aAAmC;QAAnC,kBAAa,GAAb,aAAa,CAAsB;IAAG,CAAC;IAO3D,iBAAiB;QACf,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAgB,YAAY,CAAC,CAAC;QAC1E,OAAO,IAAA,mCAAe,EAAC,yCAAkB,EAAE,UAAU,EAAE;YACrD,uBAAuB,EAAE,IAAI;SAC9B,CAAC,CAAC;IACL,CAAC;IAQD,2BAA2B,CAAyB,aAAqB;QACvE,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAe,WAAW,CAAC,CAAC;QAC3E,MAAM,QAAQ,GAAG,aAAa;aAC3B,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,MAAM,IAAI,QAAQ,CAAC,MAAM,CAAC,SAAS,KAAK,aAAa,CAAC;aACpG,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YAClB,GAAG,QAAQ,CAAC,MAAM;YAClB,IAAI,EAAE,GAAG,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI,EAAE;SAC1C,CAAC,CAAC,CAAC;QAEN,MAAM,MAAM,GAAG,IAAA,eAAM,EAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;QAExC,OAAO,IAAA,mCAAe,EAAC,uCAAiB,EAAE,MAAM,EAAE;YAChD,uBAAuB,EAAE,IAAI;SAC9B,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AArCY,4CAAgB;AAS3B;IALC,IAAA,YAAG,EAAC,YAAY,CAAC;IACjB,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,6CAA6C,EAAE,CAAC;IACxE,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,yCAAkB,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC1D,IAAA,iCAAuB,GAAE;IACzB,IAAA,kBAAS,EAAC,6BAAY,CAAC;;;;yDAMvB;AAQD;IANC,IAAA,YAAG,EAAC,qCAAqC,CAAC;IAC1C,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,qDAAqD,EAAE,CAAC;IAChF,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,gCAAgC,EAAE,CAAC;IAChG,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,uCAAiB,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IACzD,IAAA,iCAAuB,GAAE;IACzB,IAAA,kBAAS,EAAC,6BAAY,CAAC;IACK,WAAA,IAAA,cAAK,EAAC,eAAe,CAAC,CAAA;;;;mEAclD;2BApCU,gBAAgB;IAJ5B,IAAA,iBAAO,EAAC,eAAe,CAAC;IACxB,IAAA,wBAAc,EAAC,yCAAkB,EAAE,uCAAiB,CAAC;IACrD,IAAA,iBAAQ,EAAC,IAAI,uBAAc,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAClE,IAAA,mBAAU,EAAC,eAAe,CAAC;qCAGS,2BAAoB;GAF5C,gBAAgB,CAqC5B"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { PipelineEntity,
|
|
1
|
+
import { PipelineEntity, PipelineState } from '@loopstack/shared';
|
|
2
2
|
export declare class PipelineItemDto {
|
|
3
3
|
id: string;
|
|
4
4
|
model: string;
|
|
5
5
|
title: string;
|
|
6
6
|
labels: string[];
|
|
7
7
|
order: number;
|
|
8
|
-
status:
|
|
8
|
+
status: PipelineState;
|
|
9
9
|
createdAt: Date;
|
|
10
10
|
updatedAt: Date;
|
|
11
11
|
workspaceId: string;
|
|
@@ -8,6 +8,7 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
+
var _a;
|
|
11
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
13
|
exports.PipelineItemDto = void 0;
|
|
13
14
|
const class_transformer_1 = require("class-transformer");
|
|
@@ -75,11 +76,11 @@ __decorate([
|
|
|
75
76
|
__decorate([
|
|
76
77
|
(0, class_transformer_1.Expose)(),
|
|
77
78
|
(0, swagger_1.ApiProperty)({
|
|
78
|
-
enum: shared_1.
|
|
79
|
+
enum: shared_1.PipelineState,
|
|
79
80
|
enumName: 'PipelineStatus',
|
|
80
81
|
description: 'Current status of the pipeline',
|
|
81
82
|
}),
|
|
82
|
-
__metadata("design:type",
|
|
83
|
+
__metadata("design:type", typeof (_a = typeof shared_1.PipelineState !== "undefined" && shared_1.PipelineState) === "function" ? _a : Object)
|
|
83
84
|
], PipelineItemDto.prototype, "status", void 0);
|
|
84
85
|
__decorate([
|
|
85
86
|
(0, class_transformer_1.Expose)(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline-item.dto.js","sourceRoot":"","sources":["../../src/dtos/pipeline-item.dto.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pipeline-item.dto.js","sourceRoot":"","sources":["../../src/dtos/pipeline-item.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,yDAA4D;AAC5D,6CAA8C;AAC9C,8CAAkE;AAKlE,MAAa,eAAe;IAM1B,EAAE,CAAS;IAOX,KAAK,CAAS;IAOd,KAAK,CAAS;IAUd,MAAM,CAAW;IAOjB,KAAK,CAAS;IAQd,MAAM,CAAgB;IAQtB,SAAS,CAAO;IAQhB,SAAS,CAAO;IAOhB,WAAW,CAAS;IAOpB,MAAM,CAAC,MAAM,CAAC,QAAwB;QACpC,OAAO,IAAA,mCAAe,EAAC,eAAe,EAAE,QAAQ,EAAE;YAChD,uBAAuB,EAAE,IAAI;SAC9B,CAAC,CAAC;IACL,CAAC;CACF;AAhFD,0CAgFC;AA1EC;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,sCAAsC;KAChD,CAAC;;2CACS;AAOX;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,2CAA2C;QACxD,OAAO,EAAE,kBAAkB;KAC5B,CAAC;;8CACY;AAOd;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,+BAA+B;QAC5C,OAAO,EAAE,iBAAiB;KAC3B,CAAC;;8CACY;AAUd;IARC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,OAAO;QACb,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;QACzB,WAAW,EACT,oEAAoE;QACtE,OAAO,EAAE,CAAC,UAAU,EAAE,WAAW,CAAC;KACnC,CAAC;;+CACe;AAOjB;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,4CAA4C;QACzD,OAAO,EAAE,CAAC;KACX,CAAC;;8CACY;AAQd;IANC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,sBAAa;QACnB,QAAQ,EAAE,gBAAgB;QAC1B,WAAW,EAAE,gCAAgC;KAC9C,CAAC;kDACM,sBAAa,oBAAb,sBAAa;+CAAC;AAQtB;IANC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,IAAI;QACV,WAAW,EAAE,yCAAyC;QACtD,OAAO,EAAE,sBAAsB;KAChC,CAAC;8BACS,IAAI;kDAAC;AAQhB;IANC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,IAAI;QACV,WAAW,EAAE,8CAA8C;QAC3D,OAAO,EAAE,sBAAsB;KAChC,CAAC;8BACS,IAAI;kDAAC;AAOhB;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,yDAAyD;QACtE,OAAO,EAAE,sCAAsC;KAChD,CAAC;;oDACkB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PipelineEntity,
|
|
1
|
+
import { PipelineEntity, PipelineState } from '@loopstack/shared';
|
|
2
2
|
import { PipelineContextDto } from './pipeline-context.dto';
|
|
3
3
|
export declare class PipelineDto {
|
|
4
4
|
id: string;
|
|
@@ -6,7 +6,7 @@ export declare class PipelineDto {
|
|
|
6
6
|
title: string;
|
|
7
7
|
labels: string[];
|
|
8
8
|
order: number;
|
|
9
|
-
status:
|
|
9
|
+
status: PipelineState;
|
|
10
10
|
context: PipelineContextDto;
|
|
11
11
|
createdAt: Date;
|
|
12
12
|
updatedAt: Date;
|
|
@@ -8,6 +8,7 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
+
var _a;
|
|
11
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
13
|
exports.PipelineDto = void 0;
|
|
13
14
|
const class_transformer_1 = require("class-transformer");
|
|
@@ -78,11 +79,11 @@ __decorate([
|
|
|
78
79
|
__decorate([
|
|
79
80
|
(0, class_transformer_1.Expose)(),
|
|
80
81
|
(0, swagger_1.ApiProperty)({
|
|
81
|
-
enum: shared_1.
|
|
82
|
+
enum: shared_1.PipelineState,
|
|
82
83
|
enumName: 'PipelineStatus',
|
|
83
84
|
description: 'Current status of the pipeline',
|
|
84
85
|
}),
|
|
85
|
-
__metadata("design:type",
|
|
86
|
+
__metadata("design:type", typeof (_a = typeof shared_1.PipelineState !== "undefined" && shared_1.PipelineState) === "function" ? _a : Object)
|
|
86
87
|
], PipelineDto.prototype, "status", void 0);
|
|
87
88
|
__decorate([
|
|
88
89
|
(0, class_transformer_1.Expose)(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline.dto.js","sourceRoot":"","sources":["../../src/dtos/pipeline.dto.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pipeline.dto.js","sourceRoot":"","sources":["../../src/dtos/pipeline.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,yDAAqE;AACrE,6CAA8C;AAC9C,8CAAkE;AAClE,iEAA4D;AAK5D,MAAa,WAAW;IAMtB,EAAE,CAAS;IAOX,KAAK,CAAS;IAOd,KAAK,CAAS;IAUd,MAAM,CAAW;IAOjB,KAAK,CAAS;IAQd,MAAM,CAAgB;IAOtB,OAAO,CAAqB;IAQ5B,SAAS,CAAO;IAQhB,SAAS,CAAO;IAOhB,WAAW,CAAS;IAGpB,SAAS,CAAgB;IAOzB,MAAM,CAAC,MAAM,CAAC,QAAwB;QACpC,OAAO,IAAA,mCAAe,EAAC,WAAW,EAAE,QAAQ,EAAE;YAC5C,uBAAuB,EAAE,IAAI;SAC9B,CAAC,CAAC;IACL,CAAC;CACF;AA1FD,kCA0FC;AApFC;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,sCAAsC;KAChD,CAAC;;uCACS;AAOX;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,2CAA2C;QACxD,OAAO,EAAE,kBAAkB;KAC5B,CAAC;;0CACY;AAOd;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,+BAA+B;QAC5C,OAAO,EAAE,iBAAiB;KAC3B,CAAC;;0CACY;AAUd;IARC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,OAAO;QACb,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;QACzB,WAAW,EACT,oEAAoE;QACtE,OAAO,EAAE,CAAC,UAAU,EAAE,WAAW,CAAC;KACnC,CAAC;;2CACe;AAOjB;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,4CAA4C;QACzD,OAAO,EAAE,CAAC;KACX,CAAC;;0CACY;AAQd;IANC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,sBAAa;QACnB,QAAQ,EAAE,gBAAgB;QAC1B,WAAW,EAAE,gCAAgC;KAC9C,CAAC;kDACM,sBAAa,oBAAb,sBAAa;2CAAC;AAOtB;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,yCAAkB;QACxB,WAAW,EAAE,kDAAkD;KAChE,CAAC;8BACO,yCAAkB;4CAAC;AAQ5B;IANC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,IAAI;QACV,WAAW,EAAE,yCAAyC;QACtD,OAAO,EAAE,sBAAsB;KAChC,CAAC;8BACS,IAAI;8CAAC;AAQhB;IANC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,IAAI,EAAE,IAAI;QACV,WAAW,EAAE,8CAA8C;QAC3D,OAAO,EAAE,sBAAsB;KAChC,CAAC;8BACS,IAAI;8CAAC;AAOhB;IALC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,yDAAyD;QACtE,OAAO,EAAE,sCAAsC;KAChD,CAAC;;gDACkB;AAGpB;IADC,IAAA,2BAAO,GAAE;;8CACe"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { PipelineEntity,
|
|
1
|
+
import { PipelineEntity, PipelineState } from '@loopstack/shared';
|
|
2
2
|
export declare class ProjectItemDto {
|
|
3
3
|
id: string;
|
|
4
4
|
model: string;
|
|
5
5
|
title: string;
|
|
6
6
|
labels: string[];
|
|
7
7
|
order: number;
|
|
8
|
-
status:
|
|
8
|
+
status: PipelineState;
|
|
9
9
|
createdAt: Date;
|
|
10
10
|
updatedAt: Date;
|
|
11
11
|
workspaceId: string;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PipelineEntity,
|
|
1
|
+
import { PipelineEntity, PipelineState } from '@loopstack/shared';
|
|
2
2
|
import { ProjectContextDto } from './project-context.dto';
|
|
3
3
|
export declare class ProjectDto {
|
|
4
4
|
id: string;
|
|
@@ -6,7 +6,7 @@ export declare class ProjectDto {
|
|
|
6
6
|
title: string;
|
|
7
7
|
labels: string[];
|
|
8
8
|
order: number;
|
|
9
|
-
status:
|
|
9
|
+
status: PipelineState;
|
|
10
10
|
context: ProjectContextDto;
|
|
11
11
|
createdAt: Date;
|
|
12
12
|
updatedAt: Date;
|
package/dist/dtos/project.dto.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { WorkflowEntity, WorkflowStatePlaceInfoDto } from '@loopstack/shared';
|
|
1
|
+
import { PipelineState, WorkflowEntity, WorkflowStatePlaceInfoDto } from '@loopstack/shared';
|
|
2
2
|
export declare class WorkflowItemDto {
|
|
3
3
|
id: string;
|
|
4
4
|
name: string;
|
|
@@ -7,7 +7,7 @@ export declare class WorkflowItemDto {
|
|
|
7
7
|
labels: string[];
|
|
8
8
|
progress: number;
|
|
9
9
|
error: string | null;
|
|
10
|
-
|
|
10
|
+
status: PipelineState;
|
|
11
11
|
createdAt: Date;
|
|
12
12
|
updatedAt: Date;
|
|
13
13
|
place: string;
|
|
@@ -21,7 +21,7 @@ class WorkflowItemDto {
|
|
|
21
21
|
labels;
|
|
22
22
|
progress;
|
|
23
23
|
error;
|
|
24
|
-
|
|
24
|
+
status;
|
|
25
25
|
createdAt;
|
|
26
26
|
updatedAt;
|
|
27
27
|
place;
|
|
@@ -103,12 +103,12 @@ __decorate([
|
|
|
103
103
|
__decorate([
|
|
104
104
|
(0, class_transformer_1.Expose)(),
|
|
105
105
|
(0, swagger_1.ApiProperty)({
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
106
|
+
enum: shared_1.WorkflowState,
|
|
107
|
+
enumName: 'WorkflowState',
|
|
108
|
+
description: 'Current status of the workflow',
|
|
109
109
|
}),
|
|
110
|
-
__metadata("design:type",
|
|
111
|
-
], WorkflowItemDto.prototype, "
|
|
110
|
+
__metadata("design:type", String)
|
|
111
|
+
], WorkflowItemDto.prototype, "status", void 0);
|
|
112
112
|
__decorate([
|
|
113
113
|
(0, class_transformer_1.Expose)(),
|
|
114
114
|
(0, swagger_1.ApiProperty)({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-item.dto.js","sourceRoot":"","sources":["../../src/dtos/workflow-item.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAA4D;AAC5D,6CAAmE;AACnE,
|
|
1
|
+
{"version":3,"file":"workflow-item.dto.js","sourceRoot":"","sources":["../../src/dtos/workflow-item.dto.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { UISchemaType, WorkflowEntity, WorkflowStateHistoryDto, WorkflowStatePlaceInfoDto } from '@loopstack/shared';
|
|
1
|
+
import { PipelineState, UISchemaType, WorkflowEntity, WorkflowStateHistoryDto, WorkflowStatePlaceInfoDto } from '@loopstack/shared';
|
|
2
2
|
export declare class WorkflowDto {
|
|
3
3
|
id: string;
|
|
4
4
|
name: string;
|
|
@@ -7,7 +7,7 @@ export declare class WorkflowDto {
|
|
|
7
7
|
labels: string[];
|
|
8
8
|
progress: number;
|
|
9
9
|
error: string | null;
|
|
10
|
-
|
|
10
|
+
status: PipelineState;
|
|
11
11
|
place: string;
|
|
12
12
|
placeInfo: WorkflowStatePlaceInfoDto | null;
|
|
13
13
|
transitionHistory: WorkflowStateHistoryDto | null;
|
|
@@ -21,7 +21,7 @@ class WorkflowDto {
|
|
|
21
21
|
labels;
|
|
22
22
|
progress;
|
|
23
23
|
error;
|
|
24
|
-
|
|
24
|
+
status;
|
|
25
25
|
place;
|
|
26
26
|
placeInfo;
|
|
27
27
|
transitionHistory;
|
|
@@ -105,12 +105,12 @@ __decorate([
|
|
|
105
105
|
__decorate([
|
|
106
106
|
(0, class_transformer_1.Expose)(),
|
|
107
107
|
(0, swagger_1.ApiProperty)({
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
108
|
+
enum: shared_1.WorkflowState,
|
|
109
|
+
enumName: 'WorkflowState',
|
|
110
|
+
description: 'Current status of the workflow',
|
|
111
111
|
}),
|
|
112
|
-
__metadata("design:type",
|
|
113
|
-
], WorkflowDto.prototype, "
|
|
112
|
+
__metadata("design:type", String)
|
|
113
|
+
], WorkflowDto.prototype, "status", void 0);
|
|
114
114
|
__decorate([
|
|
115
115
|
(0, class_transformer_1.Expose)(),
|
|
116
116
|
(0, swagger_1.ApiProperty)({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow.dto.js","sourceRoot":"","sources":["../../src/dtos/workflow.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAA4D;AAC5D,6CAAmE;AACnE,
|
|
1
|
+
{"version":3,"file":"workflow.dto.js","sourceRoot":"","sources":["../../src/dtos/workflow.dto.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { Repository } from 'typeorm';
|
|
2
|
-
import { PipelineProcessorService } from '@loopstack/core';
|
|
3
2
|
import { RunPipelinePayloadDto } from '../dtos/run-pipeline-payload.dto';
|
|
4
3
|
import { PipelineEntity, WorkspaceEntity } from '@loopstack/shared';
|
|
4
|
+
import { RootProcessorService } from '@loopstack/core/dist/modules/workflow-processor/services/root-processor.service';
|
|
5
5
|
export declare class ProcessorApiService {
|
|
6
6
|
private pipelineEntityRepository;
|
|
7
7
|
private workspaceRepository;
|
|
8
|
-
private
|
|
9
|
-
constructor(pipelineEntityRepository: Repository<PipelineEntity>, workspaceRepository: Repository<WorkspaceEntity>,
|
|
8
|
+
private rootProcessorService;
|
|
9
|
+
constructor(pipelineEntityRepository: Repository<PipelineEntity>, workspaceRepository: Repository<WorkspaceEntity>, rootProcessorService: RootProcessorService);
|
|
10
10
|
processPipeline(pipelineId: string, user: string | null, payload: RunPipelinePayloadDto, options?: {
|
|
11
11
|
force?: boolean;
|
|
12
12
|
}): Promise<any>;
|
|
@@ -16,16 +16,16 @@ exports.ProcessorApiService = void 0;
|
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
18
18
|
const typeorm_2 = require("typeorm");
|
|
19
|
-
const core_1 = require("@loopstack/core");
|
|
20
19
|
const shared_1 = require("@loopstack/shared");
|
|
20
|
+
const root_processor_service_1 = require("@loopstack/core/dist/modules/workflow-processor/services/root-processor.service");
|
|
21
21
|
let ProcessorApiService = class ProcessorApiService {
|
|
22
22
|
pipelineEntityRepository;
|
|
23
23
|
workspaceRepository;
|
|
24
|
-
|
|
25
|
-
constructor(pipelineEntityRepository, workspaceRepository,
|
|
24
|
+
rootProcessorService;
|
|
25
|
+
constructor(pipelineEntityRepository, workspaceRepository, rootProcessorService) {
|
|
26
26
|
this.pipelineEntityRepository = pipelineEntityRepository;
|
|
27
27
|
this.workspaceRepository = workspaceRepository;
|
|
28
|
-
this.
|
|
28
|
+
this.rootProcessorService = rootProcessorService;
|
|
29
29
|
}
|
|
30
30
|
async processPipeline(pipelineId, user, payload, options) {
|
|
31
31
|
const pipeline = await this.pipelineEntityRepository.findOne({
|
|
@@ -41,16 +41,16 @@ let ProcessorApiService = class ProcessorApiService {
|
|
|
41
41
|
if (pipeline.workspace.isLocked && !options?.force) {
|
|
42
42
|
throw new common_1.ConflictException(`Pipeline with id ${pipelineId} is locked by another process. User force = true to override.`);
|
|
43
43
|
}
|
|
44
|
+
pipeline.status = shared_1.PipelineState.Running;
|
|
45
|
+
await this.pipelineEntityRepository.save(pipeline);
|
|
44
46
|
pipeline.workspace.isLocked = true;
|
|
45
47
|
await this.workspaceRepository.save(pipeline.workspace);
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
transition: payload.transition
|
|
50
|
-
});
|
|
48
|
+
const finalContext = await this.rootProcessorService.processRootPipeline(pipeline, payload);
|
|
49
|
+
pipeline.status = finalContext.error ? shared_1.PipelineState.Failed : (finalContext.stop ? shared_1.PipelineState.Paused : shared_1.PipelineState.Completed);
|
|
50
|
+
await this.pipelineEntityRepository.save(pipeline);
|
|
51
51
|
pipeline.workspace.isLocked = false;
|
|
52
52
|
await this.workspaceRepository.save(pipeline.workspace);
|
|
53
|
-
return
|
|
53
|
+
return finalContext;
|
|
54
54
|
}
|
|
55
55
|
};
|
|
56
56
|
exports.ProcessorApiService = ProcessorApiService;
|
|
@@ -60,6 +60,6 @@ exports.ProcessorApiService = ProcessorApiService = __decorate([
|
|
|
60
60
|
__param(1, (0, typeorm_1.InjectRepository)(shared_1.WorkspaceEntity)),
|
|
61
61
|
__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
62
62
|
typeorm_2.Repository,
|
|
63
|
-
|
|
63
|
+
root_processor_service_1.RootProcessorService])
|
|
64
64
|
], ProcessorApiService);
|
|
65
65
|
//# sourceMappingURL=processor-api.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"processor-api.service.js","sourceRoot":"","sources":["../../src/services/processor-api.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"processor-api.service.js","sourceRoot":"","sources":["../../src/services/processor-api.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAkF;AAClF,6CAAmD;AACnD,qCAA6C;AAE7C,8CAAmF;AACnF,4HAAuH;AAGhH,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAGpB;IAEA;IACA;IALV,YAEU,wBAAoD,EAEpD,mBAAgD,EAChD,oBAA0C;QAH1C,6BAAwB,GAAxB,wBAAwB,CAA4B;QAEpD,wBAAmB,GAAnB,mBAAmB,CAA6B;QAChD,yBAAoB,GAApB,oBAAoB,CAAsB;IACjD,CAAC;IAEJ,KAAK,CAAC,eAAe,CACnB,UAAkB,EAClB,IAAmB,EACnB,OAA8B,EAC9B,OAEC;QAED,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC;YAC3D,KAAK,EAAE;gBACL,EAAE,EAAE,UAAU;gBACd,SAAS,EAAE,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,IAAA,gBAAM,GAAE,CAAC,CAAC,CAAC,IAAI;aAC3C;YACD,SAAS,EAAE,CAAC,WAAW,CAAC;SACzB,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,0BAAiB,CAAC,oBAAoB,UAAU,aAAa,CAAC,CAAC;QAC3E,CAAC;QAED,IAAI,QAAQ,CAAC,SAAS,CAAC,QAAQ,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;YACnD,MAAM,IAAI,0BAAiB,CACzB,oBAAoB,UAAU,+DAA+D,CAC9F,CAAC;QACJ,CAAC;QAED,QAAQ,CAAC,MAAM,GAAG,sBAAa,CAAC,OAAO,CAAC;QACxC,MAAM,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEnD,QAAQ,CAAC,SAAS,CAAC,QAAQ,GAAG,IAAI,CAAC;QACnC,MAAM,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAExD,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,mBAAmB,CACtE,QAAQ,EACR,OAAO,CACR,CAAC;QAEF,QAAQ,CAAC,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,sBAAa,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,sBAAa,CAAC,MAAM,CAAC,CAAC,CAAC,sBAAa,CAAC,SAAS,CAAC,CAAC;QACnI,MAAM,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEnD,QAAQ,CAAC,SAAS,CAAC,QAAQ,GAAG,KAAK,CAAC;QACpC,MAAM,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAExD,OAAO,YAAY,CAAC;IACtB,CAAC;CACF,CAAA;AAtDY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,0BAAgB,EAAC,uBAAc,CAAC,CAAA;IAEhC,WAAA,IAAA,0BAAgB,EAAC,wBAAe,CAAC,CAAA;qCADA,oBAAU;QAEf,oBAAU;QACT,6CAAoB;GANzC,mBAAmB,CAsD/B"}
|