n8n 1.107.4 → 1.108.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (90) hide show
  1. package/dist/auth/auth.service.js +2 -2
  2. package/dist/auth/auth.service.js.map +1 -1
  3. package/dist/build.tsbuildinfo +1 -1
  4. package/dist/commands/start.js +1 -0
  5. package/dist/commands/start.js.map +1 -1
  6. package/dist/commands/ttwf/generate.d.ts +2 -2
  7. package/dist/commands/worker.js +1 -1
  8. package/dist/commands/worker.js.map +1 -1
  9. package/dist/concurrency/concurrency-control.service.js +3 -2
  10. package/dist/concurrency/concurrency-control.service.js.map +1 -1
  11. package/dist/config/index.d.ts +0 -11
  12. package/dist/config/index.js +0 -9
  13. package/dist/config/index.js.map +1 -1
  14. package/dist/config/schema.d.ts +0 -46
  15. package/dist/config/schema.js +0 -46
  16. package/dist/config/schema.js.map +1 -1
  17. package/dist/controllers/telemetry.controller.d.ts +1 -1
  18. package/dist/controllers/telemetry.controller.js +8 -4
  19. package/dist/controllers/telemetry.controller.js.map +1 -1
  20. package/dist/load-nodes-and-credentials.d.ts +3 -2
  21. package/dist/load-nodes-and-credentials.js +7 -2
  22. package/dist/load-nodes-and-credentials.js.map +1 -1
  23. package/dist/modules/data-store/data-store-aggregate.controller.d.ts +11 -0
  24. package/dist/modules/data-store/data-store-aggregate.controller.js +41 -0
  25. package/dist/modules/data-store/data-store-aggregate.controller.js.map +1 -0
  26. package/dist/modules/data-store/data-store-aggregate.service.d.ts +17 -0
  27. package/dist/modules/data-store/data-store-aggregate.service.js +52 -0
  28. package/dist/modules/data-store/data-store-aggregate.service.js.map +1 -0
  29. package/dist/modules/data-store/data-store-column.entity.d.ts +9 -0
  30. package/dist/modules/data-store/data-store-column.entity.js +43 -0
  31. package/dist/modules/data-store/data-store-column.entity.js.map +1 -0
  32. package/dist/modules/data-store/data-store-column.repository.d.ts +13 -0
  33. package/dist/modules/data-store/data-store-column.repository.js +105 -0
  34. package/dist/modules/data-store/data-store-column.repository.js.map +1 -0
  35. package/dist/modules/data-store/data-store-rows.repository.d.ts +24 -0
  36. package/dist/modules/data-store/data-store-rows.repository.js +164 -0
  37. package/dist/modules/data-store/data-store-rows.repository.js.map +1 -0
  38. package/dist/modules/data-store/data-store.controller.d.ts +51 -0
  39. package/dist/modules/data-store/data-store.controller.js +344 -0
  40. package/dist/modules/data-store/data-store.controller.js.map +1 -0
  41. package/dist/modules/data-store/data-store.entity.d.ts +10 -0
  42. package/dist/modules/data-store/data-store.entity.js +50 -0
  43. package/dist/modules/data-store/data-store.entity.js.map +1 -0
  44. package/dist/modules/data-store/data-store.module.d.ts +7 -0
  45. package/dist/modules/data-store/data-store.module.js +79 -0
  46. package/dist/modules/data-store/data-store.module.js.map +1 -0
  47. package/dist/modules/data-store/data-store.repository.d.ts +27 -0
  48. package/dist/modules/data-store/data-store.repository.js +196 -0
  49. package/dist/modules/data-store/data-store.repository.js.map +1 -0
  50. package/dist/modules/data-store/data-store.service.d.ts +40 -0
  51. package/dist/modules/data-store/data-store.service.js +195 -0
  52. package/dist/modules/data-store/data-store.service.js.map +1 -0
  53. package/dist/modules/data-store/data-store.types.d.ts +1 -0
  54. package/dist/modules/data-store/data-store.types.js +3 -0
  55. package/dist/modules/data-store/data-store.types.js.map +1 -0
  56. package/dist/modules/data-store/errors/data-store-column-name-conflict.error.d.ts +4 -0
  57. package/dist/modules/data-store/errors/data-store-column-name-conflict.error.js +13 -0
  58. package/dist/modules/data-store/errors/data-store-column-name-conflict.error.js.map +1 -0
  59. package/dist/modules/data-store/errors/data-store-column-not-found.error.d.ts +4 -0
  60. package/dist/modules/data-store/errors/data-store-column-not-found.error.js +13 -0
  61. package/dist/modules/data-store/errors/data-store-column-not-found.error.js.map +1 -0
  62. package/dist/modules/data-store/errors/data-store-name-conflict.error.d.ts +4 -0
  63. package/dist/modules/data-store/errors/data-store-name-conflict.error.js +13 -0
  64. package/dist/modules/data-store/errors/data-store-name-conflict.error.js.map +1 -0
  65. package/dist/modules/data-store/errors/data-store-not-found.error.d.ts +4 -0
  66. package/dist/modules/data-store/errors/data-store-not-found.error.js +13 -0
  67. package/dist/modules/data-store/errors/data-store-not-found.error.js.map +1 -0
  68. package/dist/modules/data-store/errors/data-store-validation.error.d.ts +4 -0
  69. package/dist/modules/data-store/errors/data-store-validation.error.js +13 -0
  70. package/dist/modules/data-store/errors/data-store-validation.error.js.map +1 -0
  71. package/dist/modules/data-store/utils/sql-utils.d.ts +25 -0
  72. package/dist/modules/data-store/utils/sql-utils.js +208 -0
  73. package/dist/modules/data-store/utils/sql-utils.js.map +1 -0
  74. package/dist/scaling/scaling.service.js +2 -6
  75. package/dist/scaling/scaling.service.js.map +1 -1
  76. package/dist/services/frontend.service.js +1 -1
  77. package/dist/services/frontend.service.js.map +1 -1
  78. package/dist/services/jwt.service.d.ts +3 -2
  79. package/dist/services/jwt.service.js +6 -6
  80. package/dist/services/jwt.service.js.map +1 -1
  81. package/dist/services/public-api-key.service.d.ts +1 -2
  82. package/dist/services/public-api-key.service.js.map +1 -1
  83. package/dist/sso.ee/oidc/routes/oidc.controller.ee.js +1 -1
  84. package/dist/sso.ee/oidc/routes/oidc.controller.ee.js.map +1 -1
  85. package/dist/sso.ee/saml/routes/saml.controller.ee.js +1 -1
  86. package/dist/sso.ee/saml/routes/saml.controller.ee.js.map +1 -1
  87. package/dist/user-management/email/templates/project-shared.handlebars +1 -1
  88. package/dist/webhooks/webhook-helpers.js.map +1 -1
  89. package/package.json +15 -15
  90. 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
+ }