n8n 1.107.1 → 1.108.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/dist/auth/auth.service.js +2 -2
- package/dist/auth/auth.service.js.map +1 -1
- package/dist/build.tsbuildinfo +1 -1
- package/dist/commands/start.js +1 -0
- package/dist/commands/start.js.map +1 -1
- package/dist/commands/ttwf/generate.d.ts +2 -2
- package/dist/commands/worker.js +1 -1
- package/dist/commands/worker.js.map +1 -1
- package/dist/concurrency/concurrency-control.service.js +3 -2
- package/dist/concurrency/concurrency-control.service.js.map +1 -1
- package/dist/config/index.d.ts +0 -11
- package/dist/config/index.js +0 -9
- package/dist/config/index.js.map +1 -1
- package/dist/config/schema.d.ts +0 -46
- package/dist/config/schema.js +0 -46
- package/dist/config/schema.js.map +1 -1
- package/dist/controllers/telemetry.controller.d.ts +1 -1
- package/dist/controllers/telemetry.controller.js +8 -4
- package/dist/controllers/telemetry.controller.js.map +1 -1
- package/dist/load-nodes-and-credentials.d.ts +3 -2
- package/dist/load-nodes-and-credentials.js +7 -2
- package/dist/load-nodes-and-credentials.js.map +1 -1
- package/dist/modules/data-store/data-store-aggregate.controller.d.ts +11 -0
- package/dist/modules/data-store/data-store-aggregate.controller.js +41 -0
- package/dist/modules/data-store/data-store-aggregate.controller.js.map +1 -0
- package/dist/modules/data-store/data-store-aggregate.service.d.ts +17 -0
- package/dist/modules/data-store/data-store-aggregate.service.js +52 -0
- package/dist/modules/data-store/data-store-aggregate.service.js.map +1 -0
- package/dist/modules/data-store/data-store-column.entity.d.ts +9 -0
- package/dist/modules/data-store/data-store-column.entity.js +43 -0
- package/dist/modules/data-store/data-store-column.entity.js.map +1 -0
- package/dist/modules/data-store/data-store-column.repository.d.ts +13 -0
- package/dist/modules/data-store/data-store-column.repository.js +105 -0
- package/dist/modules/data-store/data-store-column.repository.js.map +1 -0
- package/dist/modules/data-store/data-store-rows.repository.d.ts +24 -0
- package/dist/modules/data-store/data-store-rows.repository.js +164 -0
- package/dist/modules/data-store/data-store-rows.repository.js.map +1 -0
- package/dist/modules/data-store/data-store.controller.d.ts +51 -0
- package/dist/modules/data-store/data-store.controller.js +344 -0
- package/dist/modules/data-store/data-store.controller.js.map +1 -0
- package/dist/modules/data-store/data-store.entity.d.ts +10 -0
- package/dist/modules/data-store/data-store.entity.js +50 -0
- package/dist/modules/data-store/data-store.entity.js.map +1 -0
- package/dist/modules/data-store/data-store.module.d.ts +7 -0
- package/dist/modules/data-store/data-store.module.js +79 -0
- package/dist/modules/data-store/data-store.module.js.map +1 -0
- package/dist/modules/data-store/data-store.repository.d.ts +27 -0
- package/dist/modules/data-store/data-store.repository.js +196 -0
- package/dist/modules/data-store/data-store.repository.js.map +1 -0
- package/dist/modules/data-store/data-store.service.d.ts +40 -0
- package/dist/modules/data-store/data-store.service.js +195 -0
- package/dist/modules/data-store/data-store.service.js.map +1 -0
- package/dist/modules/data-store/data-store.types.d.ts +1 -0
- package/dist/modules/data-store/data-store.types.js +3 -0
- package/dist/modules/data-store/data-store.types.js.map +1 -0
- package/dist/modules/data-store/errors/data-store-column-name-conflict.error.d.ts +4 -0
- package/dist/modules/data-store/errors/data-store-column-name-conflict.error.js +13 -0
- package/dist/modules/data-store/errors/data-store-column-name-conflict.error.js.map +1 -0
- package/dist/modules/data-store/errors/data-store-column-not-found.error.d.ts +4 -0
- package/dist/modules/data-store/errors/data-store-column-not-found.error.js +13 -0
- package/dist/modules/data-store/errors/data-store-column-not-found.error.js.map +1 -0
- package/dist/modules/data-store/errors/data-store-name-conflict.error.d.ts +4 -0
- package/dist/modules/data-store/errors/data-store-name-conflict.error.js +13 -0
- package/dist/modules/data-store/errors/data-store-name-conflict.error.js.map +1 -0
- package/dist/modules/data-store/errors/data-store-not-found.error.d.ts +4 -0
- package/dist/modules/data-store/errors/data-store-not-found.error.js +13 -0
- package/dist/modules/data-store/errors/data-store-not-found.error.js.map +1 -0
- package/dist/modules/data-store/errors/data-store-validation.error.d.ts +4 -0
- package/dist/modules/data-store/errors/data-store-validation.error.js +13 -0
- package/dist/modules/data-store/errors/data-store-validation.error.js.map +1 -0
- package/dist/modules/data-store/utils/sql-utils.d.ts +25 -0
- package/dist/modules/data-store/utils/sql-utils.js +208 -0
- package/dist/modules/data-store/utils/sql-utils.js.map +1 -0
- package/dist/scaling/scaling.service.js +2 -6
- package/dist/scaling/scaling.service.js.map +1 -1
- package/dist/services/frontend.service.js +1 -1
- package/dist/services/frontend.service.js.map +1 -1
- package/dist/services/jwt.service.d.ts +3 -2
- package/dist/services/jwt.service.js +6 -6
- package/dist/services/jwt.service.js.map +1 -1
- package/dist/services/public-api-key.service.d.ts +1 -2
- package/dist/services/public-api-key.service.js.map +1 -1
- package/dist/sso.ee/oidc/routes/oidc.controller.ee.js +1 -1
- package/dist/sso.ee/oidc/routes/oidc.controller.ee.js.map +1 -1
- package/dist/sso.ee/saml/routes/saml.controller.ee.js +1 -1
- package/dist/sso.ee/saml/routes/saml.controller.ee.js.map +1 -1
- package/dist/user-management/email/templates/project-shared.handlebars +1 -1
- package/dist/webhooks/webhook-helpers.js.map +1 -1
- package/package.json +16 -16
- package/templates/form-trigger.handlebars +127 -18
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { ListDataStoreQueryDto } from '@n8n/api-types';
|
|
2
|
+
import { Logger } from '@n8n/backend-common';
|
|
3
|
+
import { User } from '@n8n/db';
|
|
4
|
+
import { ProjectService } from '../../services/project.service.ee';
|
|
5
|
+
import { DataStoreRepository } from './data-store.repository';
|
|
6
|
+
export declare class DataStoreAggregateService {
|
|
7
|
+
private readonly dataStoreRepository;
|
|
8
|
+
private readonly projectService;
|
|
9
|
+
private readonly logger;
|
|
10
|
+
constructor(dataStoreRepository: DataStoreRepository, projectService: ProjectService, logger: Logger);
|
|
11
|
+
start(): Promise<void>;
|
|
12
|
+
shutdown(): Promise<void>;
|
|
13
|
+
getManyAndCount(user: User, options: ListDataStoreQueryDto): Promise<{
|
|
14
|
+
count: number;
|
|
15
|
+
data: import("./data-store.entity").DataStore[];
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
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.DataStoreAggregateService = void 0;
|
|
13
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
14
|
+
const di_1 = require("@n8n/di");
|
|
15
|
+
const project_service_ee_1 = require("../../services/project.service.ee");
|
|
16
|
+
const data_store_repository_1 = require("./data-store.repository");
|
|
17
|
+
let DataStoreAggregateService = class DataStoreAggregateService {
|
|
18
|
+
constructor(dataStoreRepository, projectService, logger) {
|
|
19
|
+
this.dataStoreRepository = dataStoreRepository;
|
|
20
|
+
this.projectService = projectService;
|
|
21
|
+
this.logger = logger;
|
|
22
|
+
this.logger = this.logger.scoped('data-store');
|
|
23
|
+
}
|
|
24
|
+
async start() { }
|
|
25
|
+
async shutdown() { }
|
|
26
|
+
async getManyAndCount(user, options) {
|
|
27
|
+
const projects = await this.projectService.getProjectRelationsForUser(user);
|
|
28
|
+
let projectIds = projects.map((x) => x.projectId);
|
|
29
|
+
if (options.filter?.projectId) {
|
|
30
|
+
const mask = [options.filter?.projectId].flat();
|
|
31
|
+
projectIds = projectIds.filter((x) => mask.includes(x));
|
|
32
|
+
}
|
|
33
|
+
if (projectIds.length === 0) {
|
|
34
|
+
return { count: 0, data: [] };
|
|
35
|
+
}
|
|
36
|
+
return await this.dataStoreRepository.getManyAndCount({
|
|
37
|
+
...options,
|
|
38
|
+
filter: {
|
|
39
|
+
...options.filter,
|
|
40
|
+
projectId: projectIds,
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
exports.DataStoreAggregateService = DataStoreAggregateService;
|
|
46
|
+
exports.DataStoreAggregateService = DataStoreAggregateService = __decorate([
|
|
47
|
+
(0, di_1.Service)(),
|
|
48
|
+
__metadata("design:paramtypes", [data_store_repository_1.DataStoreRepository,
|
|
49
|
+
project_service_ee_1.ProjectService,
|
|
50
|
+
backend_common_1.Logger])
|
|
51
|
+
], DataStoreAggregateService);
|
|
52
|
+
//# sourceMappingURL=data-store-aggregate.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-store-aggregate.service.js","sourceRoot":"","sources":["../../../src/modules/data-store/data-store-aggregate.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,wDAA6C;AAE7C,gCAAkC;AAElC,sEAA+D;AAE/D,mEAA8D;AAGvD,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IACrC,YACkB,mBAAwC,EACxC,cAA8B,EAC9B,MAAc;QAFd,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,WAAM,GAAN,MAAM,CAAQ;QAE/B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IAChD,CAAC;IACD,KAAK,CAAC,KAAK,KAAI,CAAC;IAChB,KAAK,CAAC,QAAQ,KAAI,CAAC;IAEnB,KAAK,CAAC,eAAe,CAAC,IAAU,EAAE,OAA8B;QAC/D,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,0BAA0B,CAAC,IAAI,CAAC,CAAC;QAC5E,IAAI,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QAClD,IAAI,OAAO,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC;YAC/B,MAAM,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,IAAI,EAAE,CAAC;YAChD,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QACzD,CAAC;QAED,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC7B,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC;QAC/B,CAAC;QAED,OAAO,MAAM,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC;YACrD,GAAG,OAAO;YACV,MAAM,EAAE;gBACP,GAAG,OAAO,CAAC,MAAM;gBACjB,SAAS,EAAE,UAAU;aACrB;SACD,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AA/BY,8DAAyB;oCAAzB,yBAAyB;IADrC,IAAA,YAAO,GAAE;qCAG8B,2CAAmB;QACxB,mCAAc;QACtB,uBAAM;GAJpB,yBAAyB,CA+BrC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { WithTimestampsAndStringId } from '@n8n/db';
|
|
2
|
+
import { type DataStore } from './data-store.entity';
|
|
3
|
+
export declare class DataStoreColumn extends WithTimestampsAndStringId {
|
|
4
|
+
dataStoreId: string;
|
|
5
|
+
name: string;
|
|
6
|
+
type: 'string' | 'number' | 'boolean' | 'date';
|
|
7
|
+
index: number;
|
|
8
|
+
dataStore: DataStore;
|
|
9
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
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.DataStoreColumn = void 0;
|
|
13
|
+
const db_1 = require("@n8n/db");
|
|
14
|
+
const typeorm_1 = require("@n8n/typeorm");
|
|
15
|
+
let DataStoreColumn = class DataStoreColumn extends db_1.WithTimestampsAndStringId {
|
|
16
|
+
};
|
|
17
|
+
exports.DataStoreColumn = DataStoreColumn;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, typeorm_1.Column)(),
|
|
20
|
+
__metadata("design:type", String)
|
|
21
|
+
], DataStoreColumn.prototype, "dataStoreId", void 0);
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, typeorm_1.Column)(),
|
|
24
|
+
__metadata("design:type", String)
|
|
25
|
+
], DataStoreColumn.prototype, "name", void 0);
|
|
26
|
+
__decorate([
|
|
27
|
+
(0, typeorm_1.Column)({ type: 'varchar' }),
|
|
28
|
+
__metadata("design:type", String)
|
|
29
|
+
], DataStoreColumn.prototype, "type", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, typeorm_1.Column)({ type: 'int' }),
|
|
32
|
+
__metadata("design:type", Number)
|
|
33
|
+
], DataStoreColumn.prototype, "index", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, typeorm_1.ManyToOne)('DataStore', 'columns'),
|
|
36
|
+
(0, typeorm_1.JoinColumn)({ name: 'dataStoreId' }),
|
|
37
|
+
__metadata("design:type", Function)
|
|
38
|
+
], DataStoreColumn.prototype, "dataStore", void 0);
|
|
39
|
+
exports.DataStoreColumn = DataStoreColumn = __decorate([
|
|
40
|
+
(0, typeorm_1.Entity)(),
|
|
41
|
+
(0, typeorm_1.Index)(['dataStoreId', 'name'], { unique: true })
|
|
42
|
+
], DataStoreColumn);
|
|
43
|
+
//# sourceMappingURL=data-store-column.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-store-column.entity.js","sourceRoot":"","sources":["../../../src/modules/data-store/data-store-column.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAoD;AACpD,0CAA4E;AAMrE,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,8BAAyB;CAgB7D,CAAA;AAhBY,0CAAe;AAE3B;IADC,IAAA,gBAAM,GAAE;;oDACW;AAGpB;IADC,IAAA,gBAAM,GAAE;;6CACI;AAGb;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;;6CACmB;AAG/C;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;;8CACV;AAId;IAFC,IAAA,mBAAS,EAAC,WAAW,EAAE,SAAS,CAAC;IACjC,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;;kDACf;0BAfT,eAAe;IAF3B,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,CAAC,aAAa,EAAE,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;GACpC,eAAe,CAgB3B"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { DataStoreCreateColumnSchema } from '@n8n/api-types';
|
|
2
|
+
import { DataSource, EntityManager, Repository } from '@n8n/typeorm';
|
|
3
|
+
import { DataStoreColumn } from './data-store-column.entity';
|
|
4
|
+
import { DataStoreRowsRepository } from './data-store-rows.repository';
|
|
5
|
+
export declare class DataStoreColumnRepository extends Repository<DataStoreColumn> {
|
|
6
|
+
private dataStoreRowsRepository;
|
|
7
|
+
constructor(dataSource: DataSource, dataStoreRowsRepository: DataStoreRowsRepository);
|
|
8
|
+
getColumns(rawDataStoreId: string, em?: EntityManager): Promise<DataStoreColumn[]>;
|
|
9
|
+
addColumn(dataStoreId: string, schema: DataStoreCreateColumnSchema): Promise<DataStoreColumn>;
|
|
10
|
+
deleteColumn(dataStoreId: string, column: DataStoreColumn): Promise<void>;
|
|
11
|
+
moveColumn(dataStoreId: string, column: DataStoreColumn, targetIndex: number): Promise<void>;
|
|
12
|
+
shiftColumns(rawDataStoreId: string, lowestIndex: number, delta: -1 | 1, em?: EntityManager): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,105 @@
|
|
|
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.DataStoreColumnRepository = void 0;
|
|
13
|
+
const di_1 = require("@n8n/di");
|
|
14
|
+
const typeorm_1 = require("@n8n/typeorm");
|
|
15
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
16
|
+
const data_store_column_entity_1 = require("./data-store-column.entity");
|
|
17
|
+
const data_store_rows_repository_1 = require("./data-store-rows.repository");
|
|
18
|
+
const data_store_column_name_conflict_error_1 = require("./errors/data-store-column-name-conflict.error");
|
|
19
|
+
const data_store_validation_error_1 = require("./errors/data-store-validation.error");
|
|
20
|
+
let DataStoreColumnRepository = class DataStoreColumnRepository extends typeorm_1.Repository {
|
|
21
|
+
constructor(dataSource, dataStoreRowsRepository) {
|
|
22
|
+
super(data_store_column_entity_1.DataStoreColumn, dataSource.manager);
|
|
23
|
+
this.dataStoreRowsRepository = dataStoreRowsRepository;
|
|
24
|
+
}
|
|
25
|
+
async getColumns(rawDataStoreId, em) {
|
|
26
|
+
const executor = em ?? this.manager;
|
|
27
|
+
const columns = await executor
|
|
28
|
+
.createQueryBuilder(data_store_column_entity_1.DataStoreColumn, 'dsc')
|
|
29
|
+
.where('dsc.dataStoreId = :dataStoreId', { dataStoreId: rawDataStoreId })
|
|
30
|
+
.getMany();
|
|
31
|
+
columns.sort((a, b) => a.index - b.index);
|
|
32
|
+
return columns;
|
|
33
|
+
}
|
|
34
|
+
async addColumn(dataStoreId, schema) {
|
|
35
|
+
return await this.manager.transaction(async (em) => {
|
|
36
|
+
const existingColumnMatch = await em.existsBy(data_store_column_entity_1.DataStoreColumn, {
|
|
37
|
+
name: schema.name,
|
|
38
|
+
dataStoreId,
|
|
39
|
+
});
|
|
40
|
+
if (existingColumnMatch) {
|
|
41
|
+
throw new data_store_column_name_conflict_error_1.DataStoreColumnNameConflictError(schema.name, dataStoreId);
|
|
42
|
+
}
|
|
43
|
+
if (schema.index === undefined) {
|
|
44
|
+
const columns = await this.getColumns(dataStoreId, em);
|
|
45
|
+
schema.index = columns.length;
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
await this.shiftColumns(dataStoreId, schema.index, 1, em);
|
|
49
|
+
}
|
|
50
|
+
const column = em.create(data_store_column_entity_1.DataStoreColumn, {
|
|
51
|
+
...schema,
|
|
52
|
+
dataStoreId,
|
|
53
|
+
});
|
|
54
|
+
await em.insert(data_store_column_entity_1.DataStoreColumn, column);
|
|
55
|
+
const queryRunner = em.queryRunner;
|
|
56
|
+
if (!queryRunner) {
|
|
57
|
+
throw new n8n_workflow_1.UnexpectedError('QueryRunner is not available');
|
|
58
|
+
}
|
|
59
|
+
await this.dataStoreRowsRepository.ensureTableAndAddColumn(dataStoreId, column, queryRunner, em.connection.options.type);
|
|
60
|
+
return column;
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
async deleteColumn(dataStoreId, column) {
|
|
64
|
+
await this.manager.transaction(async (em) => {
|
|
65
|
+
await em.remove(data_store_column_entity_1.DataStoreColumn, column);
|
|
66
|
+
await this.dataStoreRowsRepository.dropColumnFromTable(dataStoreId, column.name, em, em.connection.options.type);
|
|
67
|
+
await this.shiftColumns(dataStoreId, column.index, -1, em);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
async moveColumn(dataStoreId, column, targetIndex) {
|
|
71
|
+
await this.manager.transaction(async (em) => {
|
|
72
|
+
const columnCount = await em.countBy(data_store_column_entity_1.DataStoreColumn, { dataStoreId });
|
|
73
|
+
if (targetIndex < 0) {
|
|
74
|
+
throw new data_store_validation_error_1.DataStoreValidationError('tried to move column to negative index');
|
|
75
|
+
}
|
|
76
|
+
if (targetIndex >= columnCount) {
|
|
77
|
+
throw new data_store_validation_error_1.DataStoreValidationError('tried to move column to an index larger than column count');
|
|
78
|
+
}
|
|
79
|
+
await this.shiftColumns(dataStoreId, column.index, -1, em);
|
|
80
|
+
await this.shiftColumns(dataStoreId, targetIndex, 1, em);
|
|
81
|
+
await em.update(data_store_column_entity_1.DataStoreColumn, { id: column.id }, { index: targetIndex });
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
async shiftColumns(rawDataStoreId, lowestIndex, delta, em) {
|
|
85
|
+
const executor = em ?? this.manager;
|
|
86
|
+
await executor
|
|
87
|
+
.createQueryBuilder()
|
|
88
|
+
.update(data_store_column_entity_1.DataStoreColumn)
|
|
89
|
+
.set({
|
|
90
|
+
index: () => `index + ${delta}`,
|
|
91
|
+
})
|
|
92
|
+
.where('dataStoreId = :dataStoreId AND index >= :thresholdValue', {
|
|
93
|
+
dataStoreId: rawDataStoreId,
|
|
94
|
+
thresholdValue: lowestIndex,
|
|
95
|
+
})
|
|
96
|
+
.execute();
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
exports.DataStoreColumnRepository = DataStoreColumnRepository;
|
|
100
|
+
exports.DataStoreColumnRepository = DataStoreColumnRepository = __decorate([
|
|
101
|
+
(0, di_1.Service)(),
|
|
102
|
+
__metadata("design:paramtypes", [typeorm_1.DataSource,
|
|
103
|
+
data_store_rows_repository_1.DataStoreRowsRepository])
|
|
104
|
+
], DataStoreColumnRepository);
|
|
105
|
+
//# sourceMappingURL=data-store-column.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-store-column.repository.js","sourceRoot":"","sources":["../../../src/modules/data-store/data-store-column.repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { ListDataStoreContentQueryDto, DataStoreUserTableName, DataStoreRows, UpsertDataStoreRowsDto } from '@n8n/api-types';
|
|
2
|
+
import { DataSource, DataSourceOptions, EntityManager, QueryRunner } from '@n8n/typeorm';
|
|
3
|
+
import { DataStoreColumn } from './data-store-column.entity';
|
|
4
|
+
export declare class DataStoreRowsRepository {
|
|
5
|
+
private dataSource;
|
|
6
|
+
constructor(dataSource: DataSource);
|
|
7
|
+
insertRows(tableName: DataStoreUserTableName, rows: DataStoreRows, columns: DataStoreColumn[]): Promise<boolean>;
|
|
8
|
+
upsertRows(tableName: DataStoreUserTableName, dto: UpsertDataStoreRowsDto, columns: DataStoreColumn[]): Promise<boolean>;
|
|
9
|
+
deleteRows(tableName: DataStoreUserTableName, ids: number[]): Promise<boolean>;
|
|
10
|
+
createTableWithColumns(tableName: string, columns: DataStoreColumn[], queryRunner: QueryRunner): Promise<void>;
|
|
11
|
+
ensureTableAndAddColumn(dataStoreId: string, column: DataStoreColumn, queryRunner: QueryRunner, dbType: DataSourceOptions['type']): Promise<void>;
|
|
12
|
+
dropColumnFromTable(dataStoreId: string, columnName: string, em: EntityManager, dbType: DataSourceOptions['type']): Promise<void>;
|
|
13
|
+
getManyAndCount(dataStoreId: DataStoreUserTableName, dto: ListDataStoreContentQueryDto): Promise<{
|
|
14
|
+
count: number;
|
|
15
|
+
data: DataStoreRows;
|
|
16
|
+
}>;
|
|
17
|
+
getRowIds(dataStoreId: DataStoreUserTableName, dto: ListDataStoreContentQueryDto): Promise<number[]>;
|
|
18
|
+
private getManyQuery;
|
|
19
|
+
private applyFilters;
|
|
20
|
+
private applySorting;
|
|
21
|
+
private applySortingByField;
|
|
22
|
+
private applyPagination;
|
|
23
|
+
private fetchAndSplitRowsByExistence;
|
|
24
|
+
}
|
|
@@ -0,0 +1,164 @@
|
|
|
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.DataStoreRowsRepository = void 0;
|
|
13
|
+
const db_1 = require("@n8n/db");
|
|
14
|
+
const di_1 = require("@n8n/di");
|
|
15
|
+
const typeorm_1 = require("@n8n/typeorm");
|
|
16
|
+
const sql_utils_1 = require("./utils/sql-utils");
|
|
17
|
+
function getConditionAndParams(filter, index, dbType) {
|
|
18
|
+
const paramName = `filter_${index}`;
|
|
19
|
+
const column = `${(0, sql_utils_1.quoteIdentifier)('dataStore', dbType)}.${(0, sql_utils_1.quoteIdentifier)(filter.columnName, dbType)}`;
|
|
20
|
+
switch (filter.condition) {
|
|
21
|
+
case 'eq':
|
|
22
|
+
return [`${column} = :${paramName}`, { [paramName]: filter.value }];
|
|
23
|
+
case 'neq':
|
|
24
|
+
return [`${column} != :${paramName}`, { [paramName]: filter.value }];
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
let DataStoreRowsRepository = class DataStoreRowsRepository {
|
|
28
|
+
constructor(dataSource) {
|
|
29
|
+
this.dataSource = dataSource;
|
|
30
|
+
}
|
|
31
|
+
async insertRows(tableName, rows, columns) {
|
|
32
|
+
const dbType = this.dataSource.options.type;
|
|
33
|
+
await this.dataSource.query.apply(this.dataSource, (0, sql_utils_1.buildInsertQuery)(tableName, rows, columns, dbType));
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
async upsertRows(tableName, dto, columns) {
|
|
37
|
+
const dbType = this.dataSource.options.type;
|
|
38
|
+
const { rows, matchFields } = dto;
|
|
39
|
+
if (rows.length === 0) {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
const { rowsToInsert, rowsToUpdate } = await this.fetchAndSplitRowsByExistence(tableName, matchFields, rows);
|
|
43
|
+
if (rowsToInsert.length > 0) {
|
|
44
|
+
await this.insertRows(tableName, rowsToInsert, columns);
|
|
45
|
+
}
|
|
46
|
+
if (rowsToUpdate.length > 0) {
|
|
47
|
+
for (const row of rowsToUpdate) {
|
|
48
|
+
const [query, parameters] = (0, sql_utils_1.buildUpdateQuery)(tableName, row, columns, matchFields, dbType);
|
|
49
|
+
await this.dataSource.query(query, parameters);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return true;
|
|
53
|
+
}
|
|
54
|
+
async deleteRows(tableName, ids) {
|
|
55
|
+
if (ids.length === 0) {
|
|
56
|
+
return true;
|
|
57
|
+
}
|
|
58
|
+
const dbType = this.dataSource.options.type;
|
|
59
|
+
const quotedTableName = (0, sql_utils_1.quoteIdentifier)(tableName, dbType);
|
|
60
|
+
const placeholders = ids.map((_, index) => (0, sql_utils_1.getPlaceholder)(index + 1, dbType)).join(', ');
|
|
61
|
+
const query = `DELETE FROM ${quotedTableName} WHERE id IN (${placeholders})`;
|
|
62
|
+
await this.dataSource.query(query, ids);
|
|
63
|
+
return true;
|
|
64
|
+
}
|
|
65
|
+
async createTableWithColumns(tableName, columns, queryRunner) {
|
|
66
|
+
const dslColumns = [new db_1.DslColumn('id').int.autoGenerate2.primary, ...(0, sql_utils_1.toDslColumns)(columns)];
|
|
67
|
+
const createTable = new db_1.CreateTable(tableName, '', queryRunner);
|
|
68
|
+
createTable.withColumns.apply(createTable, dslColumns);
|
|
69
|
+
await createTable.execute(queryRunner);
|
|
70
|
+
}
|
|
71
|
+
async ensureTableAndAddColumn(dataStoreId, column, queryRunner, dbType) {
|
|
72
|
+
const tableName = (0, sql_utils_1.toTableName)(dataStoreId);
|
|
73
|
+
const tableExists = await queryRunner.hasTable(tableName);
|
|
74
|
+
if (!tableExists) {
|
|
75
|
+
await this.createTableWithColumns(tableName, [column], queryRunner);
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
await queryRunner.manager.query((0, sql_utils_1.addColumnQuery)(tableName, column, dbType));
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
async dropColumnFromTable(dataStoreId, columnName, em, dbType) {
|
|
82
|
+
await em.query((0, sql_utils_1.deleteColumnQuery)((0, sql_utils_1.toTableName)(dataStoreId), columnName, dbType));
|
|
83
|
+
}
|
|
84
|
+
async getManyAndCount(dataStoreId, dto) {
|
|
85
|
+
const [countQuery, query] = this.getManyQuery(dataStoreId, dto);
|
|
86
|
+
const data = await query.select('*').getRawMany();
|
|
87
|
+
const countResult = await countQuery.select('COUNT(*) as count').getRawOne();
|
|
88
|
+
const count = typeof countResult?.count === 'number' ? countResult.count : Number(countResult?.count) || 0;
|
|
89
|
+
return { count: count ?? -1, data };
|
|
90
|
+
}
|
|
91
|
+
async getRowIds(dataStoreId, dto) {
|
|
92
|
+
const [_, query] = this.getManyQuery(dataStoreId, dto);
|
|
93
|
+
const result = await query.select('dataStore.id').getRawMany();
|
|
94
|
+
return result;
|
|
95
|
+
}
|
|
96
|
+
getManyQuery(dataStoreTableName, dto) {
|
|
97
|
+
const query = this.dataSource.createQueryBuilder();
|
|
98
|
+
query.from(dataStoreTableName, 'dataStore');
|
|
99
|
+
this.applyFilters(query, dto);
|
|
100
|
+
const countQuery = query.clone().select('COUNT(*)');
|
|
101
|
+
this.applySorting(query, dto);
|
|
102
|
+
this.applyPagination(query, dto);
|
|
103
|
+
return [countQuery, query];
|
|
104
|
+
}
|
|
105
|
+
applyFilters(query, dto) {
|
|
106
|
+
const filters = dto.filter?.filters ?? [];
|
|
107
|
+
const filterType = dto.filter?.type ?? 'and';
|
|
108
|
+
const dbType = this.dataSource.options.type;
|
|
109
|
+
const conditionsAndParams = filters.map((filter, i) => getConditionAndParams(filter, i, dbType));
|
|
110
|
+
for (const [condition, params] of conditionsAndParams) {
|
|
111
|
+
if (filterType === 'or') {
|
|
112
|
+
query.orWhere(condition, params);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
query.andWhere(condition, params);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
applySorting(query, dto) {
|
|
120
|
+
if (!dto.sortBy) {
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
const [field, order] = dto.sortBy;
|
|
124
|
+
this.applySortingByField(query, field, order);
|
|
125
|
+
}
|
|
126
|
+
applySortingByField(query, field, direction) {
|
|
127
|
+
const dbType = this.dataSource.options.type;
|
|
128
|
+
const quotedField = `${(0, sql_utils_1.quoteIdentifier)('dataStore', dbType)}.${(0, sql_utils_1.quoteIdentifier)(field, dbType)}`;
|
|
129
|
+
query.orderBy(quotedField, direction);
|
|
130
|
+
}
|
|
131
|
+
applyPagination(query, dto) {
|
|
132
|
+
query.skip(dto.skip);
|
|
133
|
+
query.take(dto.take);
|
|
134
|
+
}
|
|
135
|
+
async fetchAndSplitRowsByExistence(tableName, matchFields, rows) {
|
|
136
|
+
const dbType = this.dataSource.options.type;
|
|
137
|
+
const whereClauses = [];
|
|
138
|
+
const params = [];
|
|
139
|
+
for (const row of rows) {
|
|
140
|
+
const clause = matchFields
|
|
141
|
+
.map((field) => {
|
|
142
|
+
params.push(row[field]);
|
|
143
|
+
return `${(0, sql_utils_1.quoteIdentifier)(field, dbType)} = ${(0, sql_utils_1.getPlaceholder)(params.length, dbType)}`;
|
|
144
|
+
})
|
|
145
|
+
.join(' AND ');
|
|
146
|
+
whereClauses.push(`(${clause})`);
|
|
147
|
+
}
|
|
148
|
+
const quotedFields = matchFields.map((field) => (0, sql_utils_1.quoteIdentifier)(field, dbType)).join(', ');
|
|
149
|
+
const quotedTableName = (0, sql_utils_1.quoteIdentifier)(tableName, dbType);
|
|
150
|
+
const query = `
|
|
151
|
+
SELECT ${quotedFields}
|
|
152
|
+
FROM ${quotedTableName}
|
|
153
|
+
WHERE ${whereClauses.join(' OR ')}
|
|
154
|
+
`;
|
|
155
|
+
const existing = await this.dataSource.query(query, params);
|
|
156
|
+
return (0, sql_utils_1.splitRowsByExistence)(existing, matchFields, rows);
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
exports.DataStoreRowsRepository = DataStoreRowsRepository;
|
|
160
|
+
exports.DataStoreRowsRepository = DataStoreRowsRepository = __decorate([
|
|
161
|
+
(0, di_1.Service)(),
|
|
162
|
+
__metadata("design:paramtypes", [typeorm_1.DataSource])
|
|
163
|
+
], DataStoreRowsRepository);
|
|
164
|
+
//# sourceMappingURL=data-store-rows.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-store-rows.repository.js","sourceRoot":"","sources":["../../../src/modules/data-store/data-store-rows.repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { AddDataStoreRowsDto, AddDataStoreColumnDto, CreateDataStoreDto, DeleteDataStoreRowsQueryDto, ListDataStoreContentQueryDto, ListDataStoreQueryDto, MoveDataStoreColumnDto, UpdateDataStoreDto, UpsertDataStoreRowsDto } from '@n8n/api-types';
|
|
2
|
+
import { AuthenticatedRequest } from '@n8n/db';
|
|
3
|
+
import { DataStoreService } from './data-store.service';
|
|
4
|
+
export declare class DataStoreController {
|
|
5
|
+
private readonly dataStoreService;
|
|
6
|
+
constructor(dataStoreService: DataStoreService);
|
|
7
|
+
createDataStore(req: AuthenticatedRequest<{
|
|
8
|
+
projectId: string;
|
|
9
|
+
}>, _res: Response, dto: CreateDataStoreDto): Promise<import("./data-store.entity").DataStore>;
|
|
10
|
+
listProjectDataStores(req: AuthenticatedRequest<{
|
|
11
|
+
projectId: string;
|
|
12
|
+
}>, _res: Response, payload: ListDataStoreQueryDto): Promise<{
|
|
13
|
+
count: number;
|
|
14
|
+
data: import("./data-store.entity").DataStore[];
|
|
15
|
+
}>;
|
|
16
|
+
updateDataStore(req: AuthenticatedRequest<{
|
|
17
|
+
projectId: string;
|
|
18
|
+
}>, _res: Response, dataStoreId: string, dto: UpdateDataStoreDto): Promise<boolean>;
|
|
19
|
+
deleteDataStore(req: AuthenticatedRequest<{
|
|
20
|
+
projectId: string;
|
|
21
|
+
}>, _res: Response, dataStoreId: string): Promise<boolean>;
|
|
22
|
+
getColumns(req: AuthenticatedRequest<{
|
|
23
|
+
projectId: string;
|
|
24
|
+
}>, _res: Response, dataStoreId: string): Promise<import("./data-store-column.entity").DataStoreColumn[]>;
|
|
25
|
+
addColumn(req: AuthenticatedRequest<{
|
|
26
|
+
projectId: string;
|
|
27
|
+
}>, _res: Response, dataStoreId: string, dto: AddDataStoreColumnDto): Promise<import("./data-store-column.entity").DataStoreColumn>;
|
|
28
|
+
deleteColumn(req: AuthenticatedRequest<{
|
|
29
|
+
projectId: string;
|
|
30
|
+
}>, _res: Response, dataStoreId: string, columnId: string): Promise<boolean>;
|
|
31
|
+
moveColumn(req: AuthenticatedRequest<{
|
|
32
|
+
projectId: string;
|
|
33
|
+
}>, _res: Response, dataStoreId: string, columnId: string, dto: MoveDataStoreColumnDto): Promise<boolean>;
|
|
34
|
+
getDataStoreRows(req: AuthenticatedRequest<{
|
|
35
|
+
projectId: string;
|
|
36
|
+
}>, _res: Response, dataStoreId: string, dto: ListDataStoreContentQueryDto): Promise<{
|
|
37
|
+
count: number;
|
|
38
|
+
data: {
|
|
39
|
+
[x: string]: import("@n8n/api-types").DataStoreColumnJsType | null;
|
|
40
|
+
}[];
|
|
41
|
+
}>;
|
|
42
|
+
appendDataStoreRows(req: AuthenticatedRequest<{
|
|
43
|
+
projectId: string;
|
|
44
|
+
}>, _res: Response, dataStoreId: string, dto: AddDataStoreRowsDto): Promise<boolean>;
|
|
45
|
+
upsertDataStoreRows(req: AuthenticatedRequest<{
|
|
46
|
+
projectId: string;
|
|
47
|
+
}>, _res: Response, dataStoreId: string, dto: UpsertDataStoreRowsDto): Promise<boolean>;
|
|
48
|
+
deleteDataStoreRows(req: AuthenticatedRequest<{
|
|
49
|
+
projectId: string;
|
|
50
|
+
}>, _res: Response, dataStoreId: string, dto: DeleteDataStoreRowsQueryDto): Promise<boolean>;
|
|
51
|
+
}
|