@n8n/db 0.19.1 → 0.20.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/build.tsbuildinfo +1 -1
- package/dist/entities/index.d.ts +1 -5
- package/dist/entities/index.js +1 -7
- package/dist/entities/index.js.map +1 -1
- package/dist/entities/user.js +7 -13
- package/dist/entities/user.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/migrations/dsl/column.d.ts +1 -0
- package/dist/migrations/dsl/column.js +15 -0
- package/dist/migrations/dsl/column.js.map +1 -1
- package/dist/repositories/index.d.ts +0 -2
- package/dist/repositories/index.js +1 -5
- package/dist/repositories/index.js.map +1 -1
- package/dist/utils/is-valid-email.d.ts +1 -0
- package/dist/utils/is-valid-email.js +8 -0
- package/dist/utils/is-valid-email.js.map +1 -0
- package/package.json +9 -8
- package/dist/entities/installed-nodes.d.ts +0 -7
- package/dist/entities/installed-nodes.js +0 -38
- package/dist/entities/installed-nodes.js.map +0 -1
- package/dist/entities/installed-packages.d.ts +0 -9
- package/dist/entities/installed-packages.js +0 -42
- package/dist/entities/installed-packages.js.map +0 -1
- package/dist/repositories/installed-nodes.repository.d.ts +0 -5
- package/dist/repositories/installed-nodes.repository.js +0 -26
- package/dist/repositories/installed-nodes.repository.js.map +0 -1
- package/dist/repositories/installed-packages.repository.d.ts +0 -9
- package/dist/repositories/installed-packages.repository.js +0 -54
- package/dist/repositories/installed-packages.repository.js.map +0 -1
package/dist/entities/index.d.ts
CHANGED
|
@@ -11,8 +11,6 @@ import { ExecutionEntity } from './execution-entity';
|
|
|
11
11
|
import { ExecutionMetadata } from './execution-metadata';
|
|
12
12
|
import { Folder } from './folder';
|
|
13
13
|
import { FolderTagMapping } from './folder-tag-mapping';
|
|
14
|
-
import { InstalledNodes } from './installed-nodes';
|
|
15
|
-
import { InstalledPackages } from './installed-packages';
|
|
16
14
|
import { InvalidAuthToken } from './invalid-auth-token';
|
|
17
15
|
import { ProcessedData } from './processed-data';
|
|
18
16
|
import { Project } from './project';
|
|
@@ -32,11 +30,9 @@ import { WorkflowEntity } from './workflow-entity';
|
|
|
32
30
|
import { WorkflowHistory } from './workflow-history';
|
|
33
31
|
import { WorkflowStatistics } from './workflow-statistics';
|
|
34
32
|
import { WorkflowTagMapping } from './workflow-tag-mapping';
|
|
35
|
-
export { EventDestinations,
|
|
33
|
+
export { EventDestinations, InvalidAuthToken, ProcessedData, Settings, Variables, ApiKey, WebhookEntity, AuthIdentity, CredentialsEntity, Folder, Project, ProjectRelation, Role, Scope, SharedCredentials, SharedWorkflow, TagEntity, User, WorkflowEntity, WorkflowStatistics, WorkflowTagMapping, FolderTagMapping, AuthProviderSyncHistory, WorkflowHistory, ExecutionData, ExecutionMetadata, AnnotationTagEntity, ExecutionAnnotation, AnnotationTagMapping, TestRun, TestCaseExecution, ExecutionEntity, };
|
|
36
34
|
export declare const entities: {
|
|
37
35
|
EventDestinations: typeof EventDestinations;
|
|
38
|
-
InstalledNodes: typeof InstalledNodes;
|
|
39
|
-
InstalledPackages: typeof InstalledPackages;
|
|
40
36
|
InvalidAuthToken: typeof InvalidAuthToken;
|
|
41
37
|
ProcessedData: typeof ProcessedData;
|
|
42
38
|
Settings: typeof Settings;
|
package/dist/entities/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.entities = exports.ExecutionEntity = exports.TestCaseExecution = exports.TestRun = exports.AnnotationTagMapping = exports.ExecutionAnnotation = exports.AnnotationTagEntity = exports.ExecutionMetadata = exports.ExecutionData = exports.WorkflowHistory = exports.AuthProviderSyncHistory = exports.FolderTagMapping = exports.WorkflowTagMapping = exports.WorkflowStatistics = exports.WorkflowEntity = exports.User = exports.TagEntity = exports.SharedWorkflow = exports.SharedCredentials = exports.Scope = exports.Role = exports.ProjectRelation = exports.Project = exports.Folder = exports.CredentialsEntity = exports.AuthIdentity = exports.WebhookEntity = exports.ApiKey = exports.Variables = exports.Settings = exports.ProcessedData = exports.InvalidAuthToken = exports.
|
|
3
|
+
exports.entities = exports.ExecutionEntity = exports.TestCaseExecution = exports.TestRun = exports.AnnotationTagMapping = exports.ExecutionAnnotation = exports.AnnotationTagEntity = exports.ExecutionMetadata = exports.ExecutionData = exports.WorkflowHistory = exports.AuthProviderSyncHistory = exports.FolderTagMapping = exports.WorkflowTagMapping = exports.WorkflowStatistics = exports.WorkflowEntity = exports.User = exports.TagEntity = exports.SharedWorkflow = exports.SharedCredentials = exports.Scope = exports.Role = exports.ProjectRelation = exports.Project = exports.Folder = exports.CredentialsEntity = exports.AuthIdentity = exports.WebhookEntity = exports.ApiKey = exports.Variables = exports.Settings = exports.ProcessedData = exports.InvalidAuthToken = exports.EventDestinations = void 0;
|
|
4
4
|
const annotation_tag_entity_ee_1 = require("./annotation-tag-entity.ee");
|
|
5
5
|
Object.defineProperty(exports, "AnnotationTagEntity", { enumerable: true, get: function () { return annotation_tag_entity_ee_1.AnnotationTagEntity; } });
|
|
6
6
|
const annotation_tag_mapping_ee_1 = require("./annotation-tag-mapping.ee");
|
|
@@ -27,10 +27,6 @@ const folder_1 = require("./folder");
|
|
|
27
27
|
Object.defineProperty(exports, "Folder", { enumerable: true, get: function () { return folder_1.Folder; } });
|
|
28
28
|
const folder_tag_mapping_1 = require("./folder-tag-mapping");
|
|
29
29
|
Object.defineProperty(exports, "FolderTagMapping", { enumerable: true, get: function () { return folder_tag_mapping_1.FolderTagMapping; } });
|
|
30
|
-
const installed_nodes_1 = require("./installed-nodes");
|
|
31
|
-
Object.defineProperty(exports, "InstalledNodes", { enumerable: true, get: function () { return installed_nodes_1.InstalledNodes; } });
|
|
32
|
-
const installed_packages_1 = require("./installed-packages");
|
|
33
|
-
Object.defineProperty(exports, "InstalledPackages", { enumerable: true, get: function () { return installed_packages_1.InstalledPackages; } });
|
|
34
30
|
const invalid_auth_token_1 = require("./invalid-auth-token");
|
|
35
31
|
Object.defineProperty(exports, "InvalidAuthToken", { enumerable: true, get: function () { return invalid_auth_token_1.InvalidAuthToken; } });
|
|
36
32
|
const processed_data_1 = require("./processed-data");
|
|
@@ -71,8 +67,6 @@ const workflow_tag_mapping_1 = require("./workflow-tag-mapping");
|
|
|
71
67
|
Object.defineProperty(exports, "WorkflowTagMapping", { enumerable: true, get: function () { return workflow_tag_mapping_1.WorkflowTagMapping; } });
|
|
72
68
|
exports.entities = {
|
|
73
69
|
EventDestinations: event_destinations_1.EventDestinations,
|
|
74
|
-
InstalledNodes: installed_nodes_1.InstalledNodes,
|
|
75
|
-
InstalledPackages: installed_packages_1.InstalledPackages,
|
|
76
70
|
InvalidAuthToken: invalid_auth_token_1.InvalidAuthToken,
|
|
77
71
|
ProcessedData: processed_data_1.ProcessedData,
|
|
78
72
|
Settings: settings_1.Settings,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/entities/index.ts"],"names":[],"mappings":";;;AAAA,yEAAiE;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/entities/index.ts"],"names":[],"mappings":"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"}
|
package/dist/entities/user.js
CHANGED
|
@@ -11,14 +11,18 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.User = void 0;
|
|
13
13
|
const typeorm_1 = require("@n8n/typeorm");
|
|
14
|
-
const class_validator_1 = require("class-validator");
|
|
15
14
|
const abstract_entity_1 = require("./abstract-entity");
|
|
15
|
+
const is_valid_email_1 = require("../utils/is-valid-email");
|
|
16
16
|
const transformers_1 = require("../utils/transformers");
|
|
17
|
-
const no_url_validator_1 = require("../utils/validators/no-url.validator");
|
|
18
|
-
const no_xss_validator_1 = require("../utils/validators/no-xss.validator");
|
|
19
17
|
let User = class User extends abstract_entity_1.WithTimestamps {
|
|
20
18
|
preUpsertHook() {
|
|
21
19
|
this.email = this.email?.toLowerCase() ?? null;
|
|
20
|
+
if (this.email !== null && this.email !== undefined) {
|
|
21
|
+
const result = (0, is_valid_email_1.isValidEmail)(this.email);
|
|
22
|
+
if (!result) {
|
|
23
|
+
throw new Error(`Cannot save user <${this.email}>: Provided email is invalid`);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
22
26
|
}
|
|
23
27
|
computeIsPending() {
|
|
24
28
|
this.isPending = this.password === null && this.role !== 'global:owner';
|
|
@@ -55,28 +59,18 @@ __decorate([
|
|
|
55
59
|
transformer: transformers_1.lowerCaser,
|
|
56
60
|
}),
|
|
57
61
|
(0, typeorm_1.Index)({ unique: true }),
|
|
58
|
-
(0, class_validator_1.IsEmail)(),
|
|
59
62
|
__metadata("design:type", String)
|
|
60
63
|
], User.prototype, "email", void 0);
|
|
61
64
|
__decorate([
|
|
62
65
|
(0, typeorm_1.Column)({ length: 32, nullable: true }),
|
|
63
|
-
(0, no_xss_validator_1.NoXss)(),
|
|
64
|
-
(0, no_url_validator_1.NoUrl)(),
|
|
65
|
-
(0, class_validator_1.IsString)({ message: 'First name must be of type string.' }),
|
|
66
|
-
(0, class_validator_1.Length)(1, 32, { message: 'First name must be $constraint1 to $constraint2 characters long.' }),
|
|
67
66
|
__metadata("design:type", String)
|
|
68
67
|
], User.prototype, "firstName", void 0);
|
|
69
68
|
__decorate([
|
|
70
69
|
(0, typeorm_1.Column)({ length: 32, nullable: true }),
|
|
71
|
-
(0, no_xss_validator_1.NoXss)(),
|
|
72
|
-
(0, no_url_validator_1.NoUrl)(),
|
|
73
|
-
(0, class_validator_1.IsString)({ message: 'Last name must be of type string.' }),
|
|
74
|
-
(0, class_validator_1.Length)(1, 32, { message: 'Last name must be $constraint1 to $constraint2 characters long.' }),
|
|
75
70
|
__metadata("design:type", String)
|
|
76
71
|
], User.prototype, "lastName", void 0);
|
|
77
72
|
__decorate([
|
|
78
73
|
(0, typeorm_1.Column)({ type: String, nullable: true }),
|
|
79
|
-
(0, class_validator_1.IsString)({ message: 'Password must be of type string.' }),
|
|
80
74
|
__metadata("design:type", Object)
|
|
81
75
|
], User.prototype, "password", void 0);
|
|
82
76
|
__decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../src/entities/user.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,0CAUsB;
|
|
1
|
+
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../src/entities/user.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export { WithStringId, WithTimestamps, WithTimestampsAndStringId, jsonColumnType, datetimeColumnType, dbType, JsonColumn, DateTimeColumn, } from './entities/abstract-entity';
|
|
2
2
|
export { generateNanoId } from './utils/generators';
|
|
3
3
|
export { isStringArray } from './utils/is-string-array';
|
|
4
|
+
export { isValidEmail } from './utils/is-valid-email';
|
|
4
5
|
export { separate } from './utils/separate';
|
|
5
6
|
export { sql } from './utils/sql';
|
|
6
7
|
export { idStringifier, lowerCaser, objectRetriever, sqlite } from './utils/transformers';
|
package/dist/index.js
CHANGED
|
@@ -14,7 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.AuthRolesService = exports.DbConnectionOptions = exports.DbConnection = exports.wrapMigration = exports.postgresMigrations = exports.mysqlMigrations = exports.sqliteMigrations = exports.CreateTable = exports.DslColumn = exports.NoUrl = exports.NoXss = exports.sqlite = exports.objectRetriever = exports.lowerCaser = exports.idStringifier = exports.sql = exports.separate = exports.isStringArray = exports.generateNanoId = exports.DateTimeColumn = exports.JsonColumn = exports.dbType = exports.datetimeColumnType = exports.jsonColumnType = exports.WithTimestampsAndStringId = exports.WithTimestamps = exports.WithStringId = void 0;
|
|
17
|
+
exports.AuthRolesService = exports.DbConnectionOptions = exports.DbConnection = exports.wrapMigration = exports.postgresMigrations = exports.mysqlMigrations = exports.sqliteMigrations = exports.CreateTable = exports.DslColumn = exports.NoUrl = exports.NoXss = exports.sqlite = exports.objectRetriever = exports.lowerCaser = exports.idStringifier = exports.sql = exports.separate = exports.isValidEmail = exports.isStringArray = exports.generateNanoId = exports.DateTimeColumn = exports.JsonColumn = exports.dbType = exports.datetimeColumnType = exports.jsonColumnType = exports.WithTimestampsAndStringId = exports.WithTimestamps = exports.WithStringId = void 0;
|
|
18
18
|
var abstract_entity_1 = require("./entities/abstract-entity");
|
|
19
19
|
Object.defineProperty(exports, "WithStringId", { enumerable: true, get: function () { return abstract_entity_1.WithStringId; } });
|
|
20
20
|
Object.defineProperty(exports, "WithTimestamps", { enumerable: true, get: function () { return abstract_entity_1.WithTimestamps; } });
|
|
@@ -28,6 +28,8 @@ var generators_1 = require("./utils/generators");
|
|
|
28
28
|
Object.defineProperty(exports, "generateNanoId", { enumerable: true, get: function () { return generators_1.generateNanoId; } });
|
|
29
29
|
var is_string_array_1 = require("./utils/is-string-array");
|
|
30
30
|
Object.defineProperty(exports, "isStringArray", { enumerable: true, get: function () { return is_string_array_1.isStringArray; } });
|
|
31
|
+
var is_valid_email_1 = require("./utils/is-valid-email");
|
|
32
|
+
Object.defineProperty(exports, "isValidEmail", { enumerable: true, get: function () { return is_valid_email_1.isValidEmail; } });
|
|
31
33
|
var separate_1 = require("./utils/separate");
|
|
32
34
|
Object.defineProperty(exports, "separate", { enumerable: true, get: function () { return separate_1.separate; } });
|
|
33
35
|
var sql_1 = require("./utils/sql");
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,8DASoC;AARnC,+GAAA,YAAY,OAAA;AACZ,iHAAA,cAAc,OAAA;AACd,4HAAA,yBAAyB,OAAA;AACzB,iHAAA,cAAc,OAAA;AACd,qHAAA,kBAAkB,OAAA;AAClB,yGAAA,MAAM,OAAA;AACN,6GAAA,UAAU,OAAA;AACV,iHAAA,cAAc,OAAA;AAGf,iDAAoD;AAA3C,4GAAA,cAAc,OAAA;AACvB,2DAAwD;AAA/C,gHAAA,aAAa,OAAA;AACtB,6CAA4C;AAAnC,oGAAA,QAAQ,OAAA;AACjB,mCAAkC;AAAzB,0FAAA,GAAG,OAAA;AACZ,qDAA0F;AAAjF,6GAAA,aAAa,OAAA;AAAE,0GAAA,UAAU,OAAA;AAAE,+GAAA,eAAe,OAAA;AAAE,sGAAA,MAAM,OAAA;AAE3D,6CAA2B;AAC3B,sDAAoC;AACpC,wEAA4D;AAAnD,yGAAA,KAAK,OAAA;AACd,wEAA4D;AAAnD,yGAAA,KAAK,OAAA;AAEd,iDAA+B;AAC/B,gDAA8B;AAE9B,kDAA8D;AAArD,mGAAA,MAAM,OAAa;AAC5B,gDAAqD;AAA5C,oGAAA,WAAW,OAAA;AACpB,8CAAuD;AAA9C,0GAAA,gBAAgB,OAAA;AACzB,gDAAuD;AAA9C,0GAAA,eAAe,OAAA;AACxB,sDAA6D;AAApD,gHAAA,kBAAkB,OAAA;AAE3B,oEAA+D;AAAtD,kHAAA,aAAa,OAAA;AACtB,+DAA6C;AAC7C,4DAA0D;AAAjD,6GAAA,YAAY,OAAA;AACrB,4EAAyE;AAAhE,4HAAA,mBAAmB,OAAA;AAE5B,oEAAiE;AAAxD,sHAAA,gBAAgB,OAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,8DASoC;AARnC,+GAAA,YAAY,OAAA;AACZ,iHAAA,cAAc,OAAA;AACd,4HAAA,yBAAyB,OAAA;AACzB,iHAAA,cAAc,OAAA;AACd,qHAAA,kBAAkB,OAAA;AAClB,yGAAA,MAAM,OAAA;AACN,6GAAA,UAAU,OAAA;AACV,iHAAA,cAAc,OAAA;AAGf,iDAAoD;AAA3C,4GAAA,cAAc,OAAA;AACvB,2DAAwD;AAA/C,gHAAA,aAAa,OAAA;AACtB,yDAAsD;AAA7C,8GAAA,YAAY,OAAA;AACrB,6CAA4C;AAAnC,oGAAA,QAAQ,OAAA;AACjB,mCAAkC;AAAzB,0FAAA,GAAG,OAAA;AACZ,qDAA0F;AAAjF,6GAAA,aAAa,OAAA;AAAE,0GAAA,UAAU,OAAA;AAAE,+GAAA,eAAe,OAAA;AAAE,sGAAA,MAAM,OAAA;AAE3D,6CAA2B;AAC3B,sDAAoC;AACpC,wEAA4D;AAAnD,yGAAA,KAAK,OAAA;AACd,wEAA4D;AAAnD,yGAAA,KAAK,OAAA;AAEd,iDAA+B;AAC/B,gDAA8B;AAE9B,kDAA8D;AAArD,mGAAA,MAAM,OAAa;AAC5B,gDAAqD;AAA5C,oGAAA,WAAW,OAAA;AACpB,8CAAuD;AAA9C,0GAAA,gBAAgB,OAAA;AACzB,gDAAuD;AAA9C,0GAAA,eAAe,OAAA;AACxB,sDAA6D;AAApD,gHAAA,kBAAkB,OAAA;AAE3B,oEAA+D;AAAtD,kHAAA,aAAa,OAAA;AACtB,+DAA6C;AAC7C,4DAA0D;AAAjD,6GAAA,YAAY,OAAA;AACrB,4EAAyE;AAAhE,4HAAA,mBAAmB,OAAA;AAE5B,oEAAiE;AAAxD,sHAAA,gBAAgB,OAAA"}
|
|
@@ -17,6 +17,10 @@ class Column {
|
|
|
17
17
|
this.type = 'int';
|
|
18
18
|
return this;
|
|
19
19
|
}
|
|
20
|
+
get double() {
|
|
21
|
+
this.type = 'double';
|
|
22
|
+
return this;
|
|
23
|
+
}
|
|
20
24
|
varchar(length) {
|
|
21
25
|
this.type = 'varchar';
|
|
22
26
|
this.length = length ?? 'auto';
|
|
@@ -111,6 +115,17 @@ class Column {
|
|
|
111
115
|
if (isSqlite)
|
|
112
116
|
options.type = 'varchar';
|
|
113
117
|
}
|
|
118
|
+
else if (type === 'double') {
|
|
119
|
+
if (isPostgres) {
|
|
120
|
+
options.type = 'double precision';
|
|
121
|
+
}
|
|
122
|
+
else if (isMysql) {
|
|
123
|
+
options.type = 'double';
|
|
124
|
+
}
|
|
125
|
+
else if (isSqlite) {
|
|
126
|
+
options.type = 'real';
|
|
127
|
+
}
|
|
128
|
+
}
|
|
114
129
|
if ((type === 'varchar' || type === 'timestamptz' || type === 'timestamp') &&
|
|
115
130
|
length !== 'auto') {
|
|
116
131
|
options.type = `${options.type}(${length})`;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"column.js","sourceRoot":"","sources":["../../../src/migrations/dsl/column.ts"],"names":[],"mappings":";;;AAEA,MAAa,MAAM;
|
|
1
|
+
{"version":3,"file":"column.js","sourceRoot":"","sources":["../../../src/migrations/dsl/column.ts"],"names":[],"mappings":";;;AAEA,MAAa,MAAM;IA4BlB,YAAoB,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;QAhBxB,gBAAW,GAAG,KAAK,CAAC;QAEpB,iBAAY,GAAG,KAAK,CAAC;QAErB,eAAU,GAAG,IAAI,CAAC;QAElB,cAAS,GAAG,KAAK,CAAC;IAUS,CAAC;IAEpC,IAAI,IAAI;QACP,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;QACtB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,GAAG;QACN,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAClB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,MAAM;QACT,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QACrB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,OAAO,CAAC,MAAe;QACtB,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;QACtB,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,MAAM,CAAC;QAC/B,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,IAAI;QACP,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;QACnB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,IAAI;QACP,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;QACnB,OAAO,IAAI,CAAC;IACb,CAAC;IAKD,SAAS,CAAC,WAAW,GAAG,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;QAC1B,IAAI,CAAC,MAAM,GAAG,WAAW,IAAI,MAAM,CAAC;QACpC,OAAO,IAAI,CAAC;IACb,CAAC;IAED,iBAAiB,CAAC,WAAW,GAAG,CAAC;QAChC,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;QAC1B,IAAI,CAAC,MAAM,GAAG,WAAW,IAAI,MAAM,CAAC;QACpC,OAAO,IAAI,CAAC;IACb,CAAC;IAED,mBAAmB,CAAC,WAAW,GAAG,CAAC;QAClC,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG,WAAW,IAAI,MAAM,CAAC;QACpC,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,IAAI;QACP,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;QACnB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,OAAO;QACV,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,eAAe,CAAC,IAAa;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC;QACrC,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,OAAO;QACV,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,OAAO,CAAC,KAAc;QACrB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,OAAO,IAAI,CAAC;IACb,CAAC;IAKD,IAAI,YAAY;QACf,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,OAAO,IAAI,CAAC;IACb,CAAC;IAMD,IAAI,aAAa;QAChB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,OAAO,IAAI,CAAC;IACb,CAAC;IAED,OAAO,CAAC,OAAe;QACtB,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;QAC5B,OAAO,IAAI,CAAC;IACb,CAAC;IAED,SAAS,CAAC,MAAc;QACvB,MAAM,EACL,IAAI,EACJ,IAAI,EACJ,UAAU,EACV,SAAS,EACT,WAAW,EACX,YAAY,EACZ,MAAM,EACN,wBAAwB,GACxB,GAAG,IAAI,CAAC;QACT,MAAM,OAAO,GAAG,OAAO,IAAI,MAAM,CAAC;QAClC,MAAM,UAAU,GAAG,UAAU,IAAI,MAAM,CAAC;QACxC,MAAM,QAAQ,GAAG,QAAQ,IAAI,MAAM,CAAC;QAEpC,MAAM,OAAO,GAAuB;YACnC,wBAAwB;YACxB,IAAI;YACJ,UAAU;YACV,SAAS;YACT,IAAI;SACJ,CAAC;QAEF,IAAI,OAAO,CAAC,IAAI,KAAK,KAAK,IAAI,QAAQ,EAAE,CAAC;YACxC,OAAO,CAAC,IAAI,GAAG,SAAS,CAAC;QAC1B,CAAC;aAAM,IAAI,IAAI,KAAK,SAAS,IAAI,OAAO,EAAE,CAAC;YAC1C,OAAO,CAAC,IAAI,GAAG,YAAY,CAAC;QAC7B,CAAC;aAAM,IAAI,IAAI,KAAK,aAAa,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,GAAG,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,UAAU,CAAC;QACxD,CAAC;aAAM,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;YACjC,OAAO,CAAC,IAAI,GAAG,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC;QACtD,CAAC;aAAM,IAAI,IAAI,KAAK,MAAM,IAAI,QAAQ,EAAE,CAAC;YACxC,OAAO,CAAC,IAAI,GAAG,MAAM,CAAC;QACvB,CAAC;aAAM,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;YAE5B,IAAI,OAAO;gBAAE,OAAO,CAAC,IAAI,GAAG,aAAa,CAAC;YAE1C,IAAI,QAAQ;gBAAE,OAAO,CAAC,IAAI,GAAG,SAAS,CAAC;QACxC,CAAC;aAAM,IAAI,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC9B,IAAI,UAAU,EAAE,CAAC;gBAChB,OAAO,CAAC,IAAI,GAAG,kBAAkB,CAAC;YACnC,CAAC;iBAAM,IAAI,OAAO,EAAE,CAAC;gBACpB,OAAO,CAAC,IAAI,GAAG,QAAQ,CAAC;YACzB,CAAC;iBAAM,IAAI,QAAQ,EAAE,CAAC;gBACrB,OAAO,CAAC,IAAI,GAAG,MAAM,CAAC;YACvB,CAAC;QACF,CAAC;QAED,IACC,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,KAAK,aAAa,IAAI,IAAI,KAAK,WAAW,CAAC;YACtE,MAAM,KAAK,MAAM,EAChB,CAAC;YACF,OAAO,CAAC,IAAI,GAAG,GAAG,OAAO,CAAC,IAAI,IAAI,MAAM,GAAG,CAAC;QAC7C,CAAC;QAED,IAAI,WAAW,EAAE,CAAC;YACjB,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;YAC3B,OAAO,CAAC,kBAAkB,GAAG,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC;QACrE,CAAC;QAED,IAAI,YAAY,EAAE,CAAC;YAClB,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;YAC3B,OAAO,CAAC,kBAAkB,GAAG,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC;QAC5F,CAAC;QAED,IAAI,SAAS,IAAI,WAAW,IAAI,YAAY,EAAE,CAAC;YAC9C,OAAO,CAAC,UAAU,GAAG,KAAK,CAAC;QAC5B,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE,CAAC;YACrC,IAAI,CAAC,IAAI,KAAK,aAAa,IAAI,IAAI,KAAK,WAAW,CAAC,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE,CAAC;gBACvF,OAAO,CAAC,OAAO,GAAG,QAAQ;oBACzB,CAAC,CAAC,sCAAsC;oBACxC,CAAC,CAAC,sBAAsB,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACP,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC;YACrC,CAAC;QACF,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC;QACrC,CAAC;QAED,OAAO,OAAO,CAAC;IAChB,CAAC;CACD;AAvND,wBAuNC"}
|
|
@@ -12,8 +12,6 @@ export { EventDestinationsRepository } from './event-destinations.repository';
|
|
|
12
12
|
export { FolderRepository } from './folder.repository';
|
|
13
13
|
export { FolderTagMappingRepository } from './folder-tag-mapping.repository';
|
|
14
14
|
export { ScopeRepository } from './scope.repository';
|
|
15
|
-
export { InstalledNodesRepository } from './installed-nodes.repository';
|
|
16
|
-
export { InstalledPackagesRepository } from './installed-packages.repository';
|
|
17
15
|
export { InvalidAuthTokenRepository } from './invalid-auth-token.repository';
|
|
18
16
|
export { LicenseMetricsRepository } from './license-metrics.repository';
|
|
19
17
|
export { ProjectRelationRepository } from './project-relation.repository';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.UserRepository = exports.WebhookRepository = exports.WorkflowRepository = exports.SharedCredentialsRepository = exports.SharedWorkflowRepository = exports.WorkflowTagMappingRepository = exports.WorkflowStatisticsRepository = exports.WorkflowHistoryRepository = exports.VariablesRepository = exports.TestRunRepository = exports.TestCaseExecutionRepository = exports.TagRepository = exports.SettingsRepository = exports.ProcessedDataRepository = exports.RoleRepository = exports.ProjectRepository = exports.ProjectRelationRepository = exports.LicenseMetricsRepository = exports.InvalidAuthTokenRepository = exports.
|
|
3
|
+
exports.UserRepository = exports.WebhookRepository = exports.WorkflowRepository = exports.SharedCredentialsRepository = exports.SharedWorkflowRepository = exports.WorkflowTagMappingRepository = exports.WorkflowStatisticsRepository = exports.WorkflowHistoryRepository = exports.VariablesRepository = exports.TestRunRepository = exports.TestCaseExecutionRepository = exports.TagRepository = exports.SettingsRepository = exports.ProcessedDataRepository = exports.RoleRepository = exports.ProjectRepository = exports.ProjectRelationRepository = exports.LicenseMetricsRepository = exports.InvalidAuthTokenRepository = exports.ScopeRepository = exports.FolderTagMappingRepository = exports.FolderRepository = exports.EventDestinationsRepository = exports.ExecutionRepository = exports.ExecutionMetadataRepository = exports.ExecutionDataRepository = exports.ExecutionAnnotationRepository = exports.CredentialsRepository = exports.AuthProviderSyncHistoryRepository = exports.AuthIdentityRepository = exports.ApiKeyRepository = exports.AnnotationTagRepository = exports.AnnotationTagMappingRepository = void 0;
|
|
4
4
|
var annotation_tag_mapping_repository_ee_1 = require("./annotation-tag-mapping.repository.ee");
|
|
5
5
|
Object.defineProperty(exports, "AnnotationTagMappingRepository", { enumerable: true, get: function () { return annotation_tag_mapping_repository_ee_1.AnnotationTagMappingRepository; } });
|
|
6
6
|
var annotation_tag_repository_ee_1 = require("./annotation-tag.repository.ee");
|
|
@@ -29,10 +29,6 @@ var folder_tag_mapping_repository_1 = require("./folder-tag-mapping.repository")
|
|
|
29
29
|
Object.defineProperty(exports, "FolderTagMappingRepository", { enumerable: true, get: function () { return folder_tag_mapping_repository_1.FolderTagMappingRepository; } });
|
|
30
30
|
var scope_repository_1 = require("./scope.repository");
|
|
31
31
|
Object.defineProperty(exports, "ScopeRepository", { enumerable: true, get: function () { return scope_repository_1.ScopeRepository; } });
|
|
32
|
-
var installed_nodes_repository_1 = require("./installed-nodes.repository");
|
|
33
|
-
Object.defineProperty(exports, "InstalledNodesRepository", { enumerable: true, get: function () { return installed_nodes_repository_1.InstalledNodesRepository; } });
|
|
34
|
-
var installed_packages_repository_1 = require("./installed-packages.repository");
|
|
35
|
-
Object.defineProperty(exports, "InstalledPackagesRepository", { enumerable: true, get: function () { return installed_packages_repository_1.InstalledPackagesRepository; } });
|
|
36
32
|
var invalid_auth_token_repository_1 = require("./invalid-auth-token.repository");
|
|
37
33
|
Object.defineProperty(exports, "InvalidAuthTokenRepository", { enumerable: true, get: function () { return invalid_auth_token_repository_1.InvalidAuthTokenRepository; } });
|
|
38
34
|
var license_metrics_repository_1 = require("./license-metrics.repository");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/repositories/index.ts"],"names":[],"mappings":";;;AAAA,+FAAwF;AAA/E,sJAAA,8BAA8B,OAAA;AACvC,+EAAyE;AAAhE,uIAAA,uBAAuB,OAAA;AAChC,2DAAwD;AAA/C,sHAAA,gBAAgB,OAAA;AACzB,uEAAoE;AAA3D,kIAAA,sBAAsB,OAAA;AAC/B,iGAA4F;AAAnF,0JAAA,iCAAiC,OAAA;AAC1C,mEAAiE;AAAxD,+HAAA,qBAAqB,OAAA;AAC9B,qFAAkF;AAAzE,gJAAA,6BAA6B,OAAA;AACtC,yEAAsE;AAA7D,oIAAA,uBAAuB,OAAA;AAChC,iFAA8E;AAArE,4IAAA,2BAA2B,OAAA;AACpC,+DAA6D;AAApD,2HAAA,mBAAmB,OAAA;AAC5B,iFAA8E;AAArE,4IAAA,2BAA2B,OAAA;AACpC,yDAAuD;AAA9C,qHAAA,gBAAgB,OAAA;AACzB,iFAA6E;AAApE,2IAAA,0BAA0B,OAAA;AACnC,uDAAqD;AAA5C,mHAAA,eAAe,OAAA;AACxB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/repositories/index.ts"],"names":[],"mappings":";;;AAAA,+FAAwF;AAA/E,sJAAA,8BAA8B,OAAA;AACvC,+EAAyE;AAAhE,uIAAA,uBAAuB,OAAA;AAChC,2DAAwD;AAA/C,sHAAA,gBAAgB,OAAA;AACzB,uEAAoE;AAA3D,kIAAA,sBAAsB,OAAA;AAC/B,iGAA4F;AAAnF,0JAAA,iCAAiC,OAAA;AAC1C,mEAAiE;AAAxD,+HAAA,qBAAqB,OAAA;AAC9B,qFAAkF;AAAzE,gJAAA,6BAA6B,OAAA;AACtC,yEAAsE;AAA7D,oIAAA,uBAAuB,OAAA;AAChC,iFAA8E;AAArE,4IAAA,2BAA2B,OAAA;AACpC,+DAA6D;AAApD,2HAAA,mBAAmB,OAAA;AAC5B,iFAA8E;AAArE,4IAAA,2BAA2B,OAAA;AACpC,yDAAuD;AAA9C,qHAAA,gBAAgB,OAAA;AACzB,iFAA6E;AAApE,2IAAA,0BAA0B,OAAA;AACnC,uDAAqD;AAA5C,mHAAA,eAAe,OAAA;AACxB,iFAA6E;AAApE,2IAAA,0BAA0B,OAAA;AACnC,2EAAwE;AAA/D,sIAAA,wBAAwB,OAAA;AACjC,6EAA0E;AAAjE,wIAAA,yBAAyB,OAAA;AAClC,2DAAyD;AAAhD,uHAAA,iBAAiB,OAAA;AAC1B,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AACvB,yEAAsE;AAA7D,oIAAA,uBAAuB,OAAA;AAChC,6DAA2D;AAAlD,yHAAA,kBAAkB,OAAA;AAC3B,mDAAiD;AAAxC,+GAAA,aAAa,OAAA;AACtB,yFAAkF;AAAzE,gJAAA,2BAA2B,OAAA;AACpC,mEAA6D;AAApD,2HAAA,iBAAiB,OAAA;AAC1B,+DAA6D;AAApD,2HAAA,mBAAmB,OAAA;AAC5B,6EAA0E;AAAjE,wIAAA,yBAAyB,OAAA;AAClC,mFAAgF;AAAvE,8IAAA,4BAA4B,OAAA;AACrC,qFAAiF;AAAxE,+IAAA,4BAA4B,OAAA;AACrC,2EAAwE;AAA/D,sIAAA,wBAAwB,OAAA;AACjC,iFAA8E;AAArE,4IAAA,2BAA2B,OAAA;AACpC,6DAA2D;AAAlD,yHAAA,kBAAkB,OAAA;AAC3B,2DAAyD;AAAhD,uHAAA,iBAAiB,OAAA;AAC1B,qDAAmD;AAA1C,iHAAA,cAAc,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function isValidEmail(email: string): boolean;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isValidEmail = isValidEmail;
|
|
4
|
+
const zod_1 = require("zod");
|
|
5
|
+
function isValidEmail(email) {
|
|
6
|
+
return zod_1.z.string().email().safeParse(email).success;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=is-valid-email.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-valid-email.js","sourceRoot":"","sources":["../../src/utils/is-valid-email.ts"],"names":[],"mappings":";;AAEA,oCAEC;AAJD,6BAAwB;AAExB,SAAgB,YAAY,CAAC,KAAa;IACzC,OAAO,OAAC,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;AACpD,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@n8n/db",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.20.0",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"module": "src/index.ts",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -19,15 +19,16 @@
|
|
|
19
19
|
"reflect-metadata": "0.2.2",
|
|
20
20
|
"uuid": "10.0.0",
|
|
21
21
|
"xss": "1.0.15",
|
|
22
|
-
"
|
|
23
|
-
"@n8n/
|
|
22
|
+
"zod": "3.25.67",
|
|
23
|
+
"@n8n/api-types": "^0.43.0",
|
|
24
|
+
"@n8n/backend-common": "^0.19.0",
|
|
24
25
|
"@n8n/constants": "^0.11.0",
|
|
25
|
-
"@n8n/decorators": "^0.
|
|
26
|
-
"@n8n/config": "^1.51.0",
|
|
27
|
-
"@n8n/di": "^0.9.0",
|
|
26
|
+
"@n8n/decorators": "^0.19.0",
|
|
28
27
|
"@n8n/permissions": "^0.32.0",
|
|
29
|
-
"n8n
|
|
30
|
-
"n8n-
|
|
28
|
+
"@n8n/config": "^1.52.0",
|
|
29
|
+
"n8n-core": "^1.108.0",
|
|
30
|
+
"@n8n/di": "^0.9.0",
|
|
31
|
+
"n8n-workflow": "^1.106.0"
|
|
31
32
|
},
|
|
32
33
|
"devDependencies": {
|
|
33
34
|
"@types/lodash": "4.17.17",
|
|
@@ -1,38 +0,0 @@
|
|
|
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.InstalledNodes = void 0;
|
|
13
|
-
const typeorm_1 = require("@n8n/typeorm");
|
|
14
|
-
const installed_packages_1 = require("./installed-packages");
|
|
15
|
-
let InstalledNodes = class InstalledNodes {
|
|
16
|
-
};
|
|
17
|
-
exports.InstalledNodes = InstalledNodes;
|
|
18
|
-
__decorate([
|
|
19
|
-
(0, typeorm_1.Column)(),
|
|
20
|
-
__metadata("design:type", String)
|
|
21
|
-
], InstalledNodes.prototype, "name", void 0);
|
|
22
|
-
__decorate([
|
|
23
|
-
(0, typeorm_1.PrimaryColumn)(),
|
|
24
|
-
__metadata("design:type", String)
|
|
25
|
-
], InstalledNodes.prototype, "type", void 0);
|
|
26
|
-
__decorate([
|
|
27
|
-
(0, typeorm_1.Column)(),
|
|
28
|
-
__metadata("design:type", Number)
|
|
29
|
-
], InstalledNodes.prototype, "latestVersion", void 0);
|
|
30
|
-
__decorate([
|
|
31
|
-
(0, typeorm_1.ManyToOne)('InstalledPackages', 'installedNodes'),
|
|
32
|
-
(0, typeorm_1.JoinColumn)({ name: 'package', referencedColumnName: 'packageName' }),
|
|
33
|
-
__metadata("design:type", installed_packages_1.InstalledPackages)
|
|
34
|
-
], InstalledNodes.prototype, "package", void 0);
|
|
35
|
-
exports.InstalledNodes = InstalledNodes = __decorate([
|
|
36
|
-
(0, typeorm_1.Entity)()
|
|
37
|
-
], InstalledNodes);
|
|
38
|
-
//# sourceMappingURL=installed-nodes.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"installed-nodes.js","sourceRoot":"","sources":["../../src/entities/installed-nodes.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAAoF;AAEpF,6DAAyD;AAGlD,IAAM,cAAc,GAApB,MAAM,cAAc;CAa1B,CAAA;AAbY,wCAAc;AAE1B;IADC,IAAA,gBAAM,GAAE;;4CACI;AAGb;IADC,IAAA,uBAAa,GAAE;;4CACH;AAGb;IADC,IAAA,gBAAM,GAAE;;qDACa;AAItB;IAFC,IAAA,mBAAS,EAAC,mBAAmB,EAAE,gBAAgB,CAAC;IAChD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,oBAAoB,EAAE,aAAa,EAAE,CAAC;8BAC5D,sCAAiB;+CAAC;yBAZf,cAAc;IAD1B,IAAA,gBAAM,GAAE;GACI,cAAc,CAa1B"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { WithTimestamps } from './abstract-entity';
|
|
2
|
-
import type { InstalledNodes } from './installed-nodes';
|
|
3
|
-
export declare class InstalledPackages extends WithTimestamps {
|
|
4
|
-
packageName: string;
|
|
5
|
-
installedVersion: string;
|
|
6
|
-
authorName?: string;
|
|
7
|
-
authorEmail?: string;
|
|
8
|
-
installedNodes: InstalledNodes[];
|
|
9
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
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.InstalledPackages = void 0;
|
|
13
|
-
const typeorm_1 = require("@n8n/typeorm");
|
|
14
|
-
const abstract_entity_1 = require("./abstract-entity");
|
|
15
|
-
let InstalledPackages = class InstalledPackages extends abstract_entity_1.WithTimestamps {
|
|
16
|
-
};
|
|
17
|
-
exports.InstalledPackages = InstalledPackages;
|
|
18
|
-
__decorate([
|
|
19
|
-
(0, typeorm_1.PrimaryColumn)(),
|
|
20
|
-
__metadata("design:type", String)
|
|
21
|
-
], InstalledPackages.prototype, "packageName", void 0);
|
|
22
|
-
__decorate([
|
|
23
|
-
(0, typeorm_1.Column)(),
|
|
24
|
-
__metadata("design:type", String)
|
|
25
|
-
], InstalledPackages.prototype, "installedVersion", void 0);
|
|
26
|
-
__decorate([
|
|
27
|
-
(0, typeorm_1.Column)(),
|
|
28
|
-
__metadata("design:type", String)
|
|
29
|
-
], InstalledPackages.prototype, "authorName", void 0);
|
|
30
|
-
__decorate([
|
|
31
|
-
(0, typeorm_1.Column)(),
|
|
32
|
-
__metadata("design:type", String)
|
|
33
|
-
], InstalledPackages.prototype, "authorEmail", void 0);
|
|
34
|
-
__decorate([
|
|
35
|
-
(0, typeorm_1.OneToMany)('InstalledNodes', 'package'),
|
|
36
|
-
(0, typeorm_1.JoinColumn)({ referencedColumnName: 'package' }),
|
|
37
|
-
__metadata("design:type", Array)
|
|
38
|
-
], InstalledPackages.prototype, "installedNodes", void 0);
|
|
39
|
-
exports.InstalledPackages = InstalledPackages = __decorate([
|
|
40
|
-
(0, typeorm_1.Entity)()
|
|
41
|
-
], InstalledPackages);
|
|
42
|
-
//# sourceMappingURL=installed-packages.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"installed-packages.js","sourceRoot":"","sources":["../../src/entities/installed-packages.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAAoF;AAEpF,uDAAmD;AAI5C,IAAM,iBAAiB,GAAvB,MAAM,iBAAkB,SAAQ,gCAAc;CAgBpD,CAAA;AAhBY,8CAAiB;AAE7B;IADC,IAAA,uBAAa,GAAE;;sDACI;AAGpB;IADC,IAAA,gBAAM,GAAE;;2DACgB;AAGzB;IADC,IAAA,gBAAM,GAAE;;qDACW;AAGpB;IADC,IAAA,gBAAM,GAAE;;sDACY;AAIrB;IAFC,IAAA,mBAAS,EAAC,gBAAgB,EAAE,SAAS,CAAC;IACtC,IAAA,oBAAU,EAAC,EAAE,oBAAoB,EAAE,SAAS,EAAE,CAAC;;yDACf;4BAfrB,iBAAiB;IAD7B,IAAA,gBAAM,GAAE;GACI,iBAAiB,CAgB7B"}
|
|
@@ -1,26 +0,0 @@
|
|
|
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.InstalledNodesRepository = void 0;
|
|
13
|
-
const di_1 = require("@n8n/di");
|
|
14
|
-
const typeorm_1 = require("@n8n/typeorm");
|
|
15
|
-
const entities_1 = require("../entities");
|
|
16
|
-
let InstalledNodesRepository = class InstalledNodesRepository extends typeorm_1.Repository {
|
|
17
|
-
constructor(dataSource) {
|
|
18
|
-
super(entities_1.InstalledNodes, dataSource.manager);
|
|
19
|
-
}
|
|
20
|
-
};
|
|
21
|
-
exports.InstalledNodesRepository = InstalledNodesRepository;
|
|
22
|
-
exports.InstalledNodesRepository = InstalledNodesRepository = __decorate([
|
|
23
|
-
(0, di_1.Service)(),
|
|
24
|
-
__metadata("design:paramtypes", [typeorm_1.DataSource])
|
|
25
|
-
], InstalledNodesRepository);
|
|
26
|
-
//# sourceMappingURL=installed-nodes.repository.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"installed-nodes.repository.js","sourceRoot":"","sources":["../../src/repositories/installed-nodes.repository.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAClC,0CAAsD;AAEtD,0CAA6C;AAGtC,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,oBAA0B;IACvE,YAAY,UAAsB;QACjC,KAAK,CAAC,yBAAc,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IAC3C,CAAC;CACD,CAAA;AAJY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,YAAO,GAAE;qCAEe,oBAAU;GADtB,wBAAwB,CAIpC"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { DataSource, Repository } from '@n8n/typeorm';
|
|
2
|
-
import type { PackageDirectoryLoader } from 'n8n-core';
|
|
3
|
-
import { InstalledNodesRepository } from './installed-nodes.repository';
|
|
4
|
-
import { InstalledPackages } from '../entities';
|
|
5
|
-
export declare class InstalledPackagesRepository extends Repository<InstalledPackages> {
|
|
6
|
-
private installedNodesRepository;
|
|
7
|
-
constructor(dataSource: DataSource, installedNodesRepository: InstalledNodesRepository);
|
|
8
|
-
saveInstalledPackageWithNodes(packageLoader: PackageDirectoryLoader): Promise<InstalledPackages>;
|
|
9
|
-
}
|
|
@@ -1,54 +0,0 @@
|
|
|
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.InstalledPackagesRepository = void 0;
|
|
13
|
-
const di_1 = require("@n8n/di");
|
|
14
|
-
const typeorm_1 = require("@n8n/typeorm");
|
|
15
|
-
const installed_nodes_repository_1 = require("./installed-nodes.repository");
|
|
16
|
-
const entities_1 = require("../entities");
|
|
17
|
-
let InstalledPackagesRepository = class InstalledPackagesRepository extends typeorm_1.Repository {
|
|
18
|
-
constructor(dataSource, installedNodesRepository) {
|
|
19
|
-
super(entities_1.InstalledPackages, dataSource.manager);
|
|
20
|
-
this.installedNodesRepository = installedNodesRepository;
|
|
21
|
-
}
|
|
22
|
-
async saveInstalledPackageWithNodes(packageLoader) {
|
|
23
|
-
const { packageJson, nodeTypes, loadedNodes } = packageLoader;
|
|
24
|
-
const { name: packageName, version: installedVersion, author } = packageJson;
|
|
25
|
-
let installedPackage;
|
|
26
|
-
await this.manager.transaction(async (manager) => {
|
|
27
|
-
installedPackage = await manager.save(this.create({
|
|
28
|
-
packageName,
|
|
29
|
-
installedVersion,
|
|
30
|
-
authorName: author?.name,
|
|
31
|
-
authorEmail: author?.email,
|
|
32
|
-
}));
|
|
33
|
-
installedPackage.installedNodes = [];
|
|
34
|
-
for (const loadedNode of loadedNodes) {
|
|
35
|
-
const installedNode = this.installedNodesRepository.create({
|
|
36
|
-
name: nodeTypes[loadedNode.name].type.description.displayName,
|
|
37
|
-
type: `${packageName}.${loadedNode.name}`,
|
|
38
|
-
latestVersion: loadedNode.version,
|
|
39
|
-
package: { packageName },
|
|
40
|
-
});
|
|
41
|
-
installedPackage.installedNodes.push(installedNode);
|
|
42
|
-
await manager.save(installedNode);
|
|
43
|
-
}
|
|
44
|
-
});
|
|
45
|
-
return installedPackage;
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
exports.InstalledPackagesRepository = InstalledPackagesRepository;
|
|
49
|
-
exports.InstalledPackagesRepository = InstalledPackagesRepository = __decorate([
|
|
50
|
-
(0, di_1.Service)(),
|
|
51
|
-
__metadata("design:paramtypes", [typeorm_1.DataSource,
|
|
52
|
-
installed_nodes_repository_1.InstalledNodesRepository])
|
|
53
|
-
], InstalledPackagesRepository);
|
|
54
|
-
//# sourceMappingURL=installed-packages.repository.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"installed-packages.repository.js","sourceRoot":"","sources":["../../src/repositories/installed-packages.repository.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAClC,0CAAsD;AAGtD,6EAAwE;AACxE,0CAAgD;AAGzC,IAAM,2BAA2B,GAAjC,MAAM,2BAA4B,SAAQ,oBAA6B;IAC7E,YACC,UAAsB,EACd,wBAAkD;QAE1D,KAAK,CAAC,4BAAiB,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;QAFrC,6BAAwB,GAAxB,wBAAwB,CAA0B;IAG3D,CAAC;IAED,KAAK,CAAC,6BAA6B,CAAC,aAAqC;QACxE,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,aAAa,CAAC;QAC9D,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,GAAG,WAAW,CAAC;QAE7E,IAAI,gBAAmC,CAAC;QAExC,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;YAChD,gBAAgB,GAAG,MAAM,OAAO,CAAC,IAAI,CACpC,IAAI,CAAC,MAAM,CAAC;gBACX,WAAW;gBACX,gBAAgB;gBAChB,UAAU,EAAE,MAAM,EAAE,IAAI;gBACxB,WAAW,EAAE,MAAM,EAAE,KAAK;aAC1B,CAAC,CACF,CAAC;YAEF,gBAAgB,CAAC,cAAc,GAAG,EAAE,CAAC;YAErC,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;gBACtC,MAAM,aAAa,GAAG,IAAI,CAAC,wBAAwB,CAAC,MAAM,CAAC;oBAC1D,IAAI,EAAE,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW;oBAC7D,IAAI,EAAE,GAAG,WAAW,IAAI,UAAU,CAAC,IAAI,EAAE;oBACzC,aAAa,EAAE,UAAU,CAAC,OAAO;oBACjC,OAAO,EAAE,EAAE,WAAW,EAAE;iBACxB,CAAC,CAAC;gBAEH,gBAAgB,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBAEpD,MAAM,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACnC,CAAC;QACF,CAAC,CAAC,CAAC;QAEH,OAAO,gBAAiB,CAAC;IAC1B,CAAC;CACD,CAAA;AA1CY,kEAA2B;sCAA3B,2BAA2B;IADvC,IAAA,YAAO,GAAE;qCAGI,oBAAU;QACY,qDAAwB;GAH/C,2BAA2B,CA0CvC"}
|