@stemy/backend 2.6.1 → 2.7.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/bundles/stemy-backend.umd.js +5553 -5465
- package/bundles/stemy-backend.umd.js.map +1 -1
- package/bundles/stemy-backend.umd.min.js +1 -1
- package/bundles/stemy-backend.umd.min.js.map +1 -1
- package/common-types.d.ts +226 -214
- package/esm2015/common-types.js +18 -18
- package/esm2015/public_api.js +338 -338
- package/esm2015/rest-controllers/assets.controller.js +116 -116
- package/esm2015/rest-controllers/auth.controller.js +75 -75
- package/esm2015/rest-controllers/gallery.controller.js +37 -37
- package/esm2015/rest-controllers/progresses.controller.js +57 -57
- package/esm2015/rest-middlewares/container.middleware.js +32 -32
- package/esm2015/rest-middlewares/error-handler.middleware.js +83 -83
- package/esm2015/rest-middlewares/language.middleware.js +28 -28
- package/esm2015/rest-middlewares/request-ended.middleware.js +25 -25
- package/esm2015/rest-middlewares/request-started.middleware.js +24 -24
- package/esm2015/rest-openapi.js +44 -44
- package/esm2015/services/asset-processor.js +101 -101
- package/esm2015/services/asset-resolver.js +53 -53
- package/esm2015/services/assets.js +110 -110
- package/esm2015/services/backend-provider.js +32 -32
- package/esm2015/services/cache-processor.js +34 -34
- package/esm2015/services/cache.js +94 -94
- package/esm2015/services/configuration.js +55 -55
- package/esm2015/services/endpoint-provider.js +29 -29
- package/esm2015/services/entities/asset.js +166 -112
- package/esm2015/services/entities/lazy-asset.js +93 -93
- package/esm2015/services/entities/progress.js +181 -181
- package/esm2015/services/fixtures.js +45 -45
- package/esm2015/services/gallery-cache.js +36 -36
- package/esm2015/services/gallery-image.js +48 -48
- package/esm2015/services/gallery.js +138 -138
- package/esm2015/services/id-generator.js +63 -63
- package/esm2015/services/job-manager.js +203 -203
- package/esm2015/services/lazy-assets.js +74 -74
- package/esm2015/services/mail-sender.js +59 -59
- package/esm2015/services/memory-cache.js +84 -84
- package/esm2015/services/mongo-connector.js +61 -61
- package/esm2015/services/progresses.js +91 -91
- package/esm2015/services/template-renderer.js +89 -89
- package/esm2015/services/translation-provider.js +31 -31
- package/esm2015/services/translator.js +85 -85
- package/esm2015/services/user-manager.js +47 -47
- package/esm2015/socket-controllers/progress.controller.js +82 -82
- package/esm2015/socket-middlewares/compression.middleware.js +19 -19
- package/esm2015/static.js +33 -33
- package/esm2015/stemy-backend.js +4 -4
- package/esm2015/utilities/di-container.js +84 -84
- package/esm2015/utilities/lazy-asset-generator.js +40 -40
- package/esm2015/utilities/tree.js +111 -111
- package/esm2015/utils.js +618 -601
- package/esm2015/validators.js +51 -51
- package/fesm2015/stemy-backend.js +3656 -3585
- package/fesm2015/stemy-backend.js.map +1 -1
- package/package.json +1 -1
- package/public_api.d.ts +33 -33
- package/rest-controllers/assets.controller.d.ts +16 -16
- package/rest-controllers/auth.controller.d.ts +14 -14
- package/rest-controllers/gallery.controller.d.ts +7 -7
- package/rest-controllers/progresses.controller.d.ts +9 -9
- package/rest-middlewares/container.middleware.d.ts +8 -8
- package/rest-middlewares/error-handler.middleware.d.ts +13 -13
- package/rest-middlewares/language.middleware.d.ts +8 -8
- package/rest-middlewares/request-ended.middleware.d.ts +5 -5
- package/rest-middlewares/request-started.middleware.d.ts +5 -5
- package/rest-openapi.d.ts +3 -3
- package/services/asset-processor.d.ts +12 -12
- package/services/asset-resolver.d.ts +9 -9
- package/services/assets.d.ts +19 -19
- package/services/backend-provider.d.ts +11 -11
- package/services/cache-processor.d.ts +4 -4
- package/services/cache.d.ts +23 -23
- package/services/configuration.d.ts +10 -10
- package/services/endpoint-provider.d.ts +4 -4
- package/services/entities/asset.d.ts +25 -23
- package/services/entities/lazy-asset.d.ts +29 -29
- package/services/entities/progress.d.ts +49 -49
- package/services/fixtures.d.ts +6 -6
- package/services/gallery-cache.d.ts +9 -9
- package/services/gallery-image.d.ts +11 -11
- package/services/gallery.d.ts +13 -13
- package/services/id-generator.d.ts +11 -11
- package/services/job-manager.d.ts +27 -27
- package/services/lazy-assets.d.ts +19 -19
- package/services/mail-sender.d.ts +20 -20
- package/services/memory-cache.d.ts +10 -10
- package/services/mongo-connector.d.ts +14 -14
- package/services/progresses.d.ts +18 -18
- package/services/template-renderer.d.ts +14 -14
- package/services/translation-provider.d.ts +10 -10
- package/services/translator.d.ts +15 -15
- package/services/user-manager.d.ts +6 -6
- package/socket-controllers/progress.controller.d.ts +10 -10
- package/socket-middlewares/compression.middleware.d.ts +4 -4
- package/static.d.ts +2 -2
- package/stemy-backend.d.ts +4 -4
- package/stemy-backend.metadata.json +1 -1
- package/utilities/di-container.d.ts +43 -43
- package/utilities/lazy-asset-generator.d.ts +15 -15
- package/utilities/tree.d.ts +14 -14
- package/utils.d.ts +76 -73
- package/validators.d.ts +7 -7
- package/di-container.d.ts +0 -40
- package/esm2015/di-container.js +0 -75
- package/esm2015/models/lazy-asset.js +0 -12
- package/esm2015/models/progress.js +0 -23
- package/esm2015/rest-middlewares/injector.middleware.js +0 -26
- package/esm2015/services/lazy-asset-helper.js +0 -74
- package/esm2015/services/logger.js +0 -14
- package/esm2015/services/progress-helper.js +0 -168
- package/models/lazy-asset.d.ts +0 -45
- package/models/progress.d.ts +0 -56
- package/rest-middlewares/injector.middleware.d.ts +0 -8
- package/services/lazy-asset-helper.d.ts +0 -15
- package/services/logger.d.ts +0 -2
- package/services/progress-helper.d.ts +0 -37
|
@@ -1,111 +1,111 @@
|
|
|
1
|
-
import { isString } from "../utils";
|
|
2
|
-
export class Tree {
|
|
3
|
-
constructor(container, path) {
|
|
4
|
-
this.container = container;
|
|
5
|
-
this.path = path;
|
|
6
|
-
this.map = new Map();
|
|
7
|
-
}
|
|
8
|
-
get parentTree() {
|
|
9
|
-
return this.container.parent.tree;
|
|
10
|
-
}
|
|
11
|
-
resolveService() {
|
|
12
|
-
return this.container.resolve(this.path);
|
|
13
|
-
}
|
|
14
|
-
resolveLeaves() {
|
|
15
|
-
let map;
|
|
16
|
-
try {
|
|
17
|
-
const parentTree = this.parentTree.resolvePath(this.path);
|
|
18
|
-
map = parentTree.resolveLeaves();
|
|
19
|
-
}
|
|
20
|
-
catch (e) {
|
|
21
|
-
map = new Map();
|
|
22
|
-
}
|
|
23
|
-
const visitor = (treeMap, path) => {
|
|
24
|
-
treeMap.forEach((tree, key) => {
|
|
25
|
-
const subKey = !path ? key : `${path}.${key}`;
|
|
26
|
-
if (tree.map.size == 0) {
|
|
27
|
-
map.set(subKey, tree);
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
visitor(tree.map, subKey);
|
|
31
|
-
});
|
|
32
|
-
};
|
|
33
|
-
visitor(this.map, "");
|
|
34
|
-
return map;
|
|
35
|
-
}
|
|
36
|
-
resolveServices() {
|
|
37
|
-
const map = new Map();
|
|
38
|
-
this.resolveLeaves().forEach((leaf, key) => {
|
|
39
|
-
map.set(key, leaf.resolveService());
|
|
40
|
-
});
|
|
41
|
-
return map;
|
|
42
|
-
}
|
|
43
|
-
resolveAncestor(path) {
|
|
44
|
-
if (!isString(path) || path.length == 0) {
|
|
45
|
-
return this;
|
|
46
|
-
}
|
|
47
|
-
let parentTree;
|
|
48
|
-
try {
|
|
49
|
-
parentTree = this.parentTree.resolvePath(this.path);
|
|
50
|
-
parentTree = parentTree.resolveAncestor(path);
|
|
51
|
-
}
|
|
52
|
-
catch (e) {
|
|
53
|
-
parentTree = new Tree(this.container, "");
|
|
54
|
-
}
|
|
55
|
-
const pathParts = path.split(".");
|
|
56
|
-
let tree = this;
|
|
57
|
-
let previousTree = this;
|
|
58
|
-
for (let part of pathParts) {
|
|
59
|
-
tree = tree.map.get(part);
|
|
60
|
-
if (!tree) {
|
|
61
|
-
if (previousTree == this) {
|
|
62
|
-
if (parentTree.path.length > 0) {
|
|
63
|
-
return parentTree;
|
|
64
|
-
}
|
|
65
|
-
throw new Error(`Ancestor '${path}' not found in current tree: '${this.path}'`);
|
|
66
|
-
}
|
|
67
|
-
return previousTree;
|
|
68
|
-
}
|
|
69
|
-
previousTree = tree;
|
|
70
|
-
}
|
|
71
|
-
return parentTree.path.length > previousTree.path.length
|
|
72
|
-
? parentTree : previousTree;
|
|
73
|
-
}
|
|
74
|
-
resolvePath(path, throwError = true) {
|
|
75
|
-
const absolutePath = !this.path ? path : `${this.path}.${path}`;
|
|
76
|
-
let tree = new Tree(this.container, absolutePath);
|
|
77
|
-
try {
|
|
78
|
-
tree = this.resolveAncestor(path);
|
|
79
|
-
}
|
|
80
|
-
catch (e) {
|
|
81
|
-
if (throwError) {
|
|
82
|
-
throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);
|
|
83
|
-
}
|
|
84
|
-
return tree;
|
|
85
|
-
}
|
|
86
|
-
if (tree.path !== absolutePath) {
|
|
87
|
-
if (throwError) {
|
|
88
|
-
throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);
|
|
89
|
-
}
|
|
90
|
-
return tree;
|
|
91
|
-
}
|
|
92
|
-
return tree;
|
|
93
|
-
}
|
|
94
|
-
addPath(path) {
|
|
95
|
-
if (!isString(path) || path.length == 0) {
|
|
96
|
-
return this;
|
|
97
|
-
}
|
|
98
|
-
const pathParts = path.split(".");
|
|
99
|
-
let tree = this;
|
|
100
|
-
path = this.path;
|
|
101
|
-
for (let part of pathParts) {
|
|
102
|
-
if (!tree.map.has(part)) {
|
|
103
|
-
tree.map.set(part, new Tree(this.container, !path ? part : `${path}.${part}`));
|
|
104
|
-
}
|
|
105
|
-
tree = tree.map.get(part);
|
|
106
|
-
path = tree.path;
|
|
107
|
-
}
|
|
108
|
-
return this;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.js","sourceRoot":"","sources":["../../../src/utilities/tree.ts"],"names":[],"mappings":"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","sourcesContent":["import {IDependencyContainer, ITree} from \"../common-types\";\nimport {isString} from \"../utils\";\n\nexport class Tree implements ITree {\n\n    protected map: Map<string, Tree>;\n\n    protected get parentTree(): ITree {\n        return this.container.parent.tree;\n    }\n\n    constructor(protected container: IDependencyContainer, readonly path: string) {\n        this.map = new Map<string, Tree>();\n    }\n\n    resolveService(): any {\n        return this.container.resolve(this.path);\n    }\n\n    resolveLeaves(): Map<string, ITree> {\n        let map: Map<string, ITree>;\n        try {\n            const parentTree = this.parentTree.resolvePath(this.path);\n            map = parentTree.resolveLeaves();\n        } catch (e) {\n            map = new Map<string, ITree>();\n        }\n        const visitor = (treeMap: Map<string, Tree>, path: string) => {\n            treeMap.forEach((tree, key) => {\n                const subKey = !path ? key : `${path}.${key}`;\n                if (tree.map.size == 0) {\n                    map.set(subKey, tree);\n                    return;\n                }\n                visitor(tree.map, subKey);\n            });\n        };\n        visitor(this.map, \"\");\n        return map;\n    }\n\n    resolveServices(): Map<string, any> {\n        const map = new Map<string, any>();\n        this.resolveLeaves().forEach((leaf, key) => {\n            map.set(key, leaf.resolveService());\n        });\n        return map;\n    }\n\n    resolveAncestor(path: string): ITree {\n        if (!isString(path) || path.length == 0) {\n            return this;\n        }\n        let parentTree: ITree;\n        try {\n            parentTree = this.parentTree.resolvePath(this.path);\n            parentTree = parentTree.resolveAncestor(path);\n        } catch (e) {\n            parentTree = new Tree(this.container, \"\");\n        }\n        const pathParts = path.split(\".\");\n        let tree: Tree = this;\n        let previousTree: Tree = this;\n        for (let part of pathParts) {\n            tree = tree.map.get(part);\n            if (!tree) {\n                if (previousTree == this) {\n                    if (parentTree.path.length > 0) {\n                        return parentTree;\n                    }\n                    throw new Error(`Ancestor '${path}' not found in current tree: '${this.path}'`);\n                }\n                return previousTree;\n            }\n            previousTree = tree;\n        }\n        return parentTree.path.length > previousTree.path.length\n            ? parentTree : previousTree;\n    }\n\n    resolvePath(path: string, throwError: boolean = true): ITree {\n        const absolutePath = !this.path ? path : `${this.path}.${path}`;\n        let tree: ITree = new Tree(this.container, absolutePath);\n        try {\n            tree = this.resolveAncestor(path);\n        } catch (e) {\n            if (throwError) {\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\n            }\n            return tree;\n        }\n        if (tree.path !== absolutePath) {\n            if (throwError) {\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\n            }\n            return tree;\n        }\n        return tree;\n    }\n\n    addPath(path: string): this {\n        if (!isString(path) || path.length == 0) {\n            return this;\n        }\n        const pathParts = path.split(\".\");\n        let tree: Tree = this;\n        path = this.path;\n        for (let part of pathParts) {\n            if (!tree.map.has(part)) {\n                tree.map.set(part, new Tree(this.container, !path ? part : `${path}.${part}`))\n            }\n            tree = tree.map.get(part);\n            path = tree.path;\n        }\n        return this;\n    }\n}\n"]}
|
|
1
|
+
import { isString } from "../utils";
|
|
2
|
+
export class Tree {
|
|
3
|
+
constructor(container, path) {
|
|
4
|
+
this.container = container;
|
|
5
|
+
this.path = path;
|
|
6
|
+
this.map = new Map();
|
|
7
|
+
}
|
|
8
|
+
get parentTree() {
|
|
9
|
+
return this.container.parent.tree;
|
|
10
|
+
}
|
|
11
|
+
resolveService() {
|
|
12
|
+
return this.container.resolve(this.path);
|
|
13
|
+
}
|
|
14
|
+
resolveLeaves() {
|
|
15
|
+
let map;
|
|
16
|
+
try {
|
|
17
|
+
const parentTree = this.parentTree.resolvePath(this.path);
|
|
18
|
+
map = parentTree.resolveLeaves();
|
|
19
|
+
}
|
|
20
|
+
catch (e) {
|
|
21
|
+
map = new Map();
|
|
22
|
+
}
|
|
23
|
+
const visitor = (treeMap, path) => {
|
|
24
|
+
treeMap.forEach((tree, key) => {
|
|
25
|
+
const subKey = !path ? key : `${path}.${key}`;
|
|
26
|
+
if (tree.map.size == 0) {
|
|
27
|
+
map.set(subKey, tree);
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
visitor(tree.map, subKey);
|
|
31
|
+
});
|
|
32
|
+
};
|
|
33
|
+
visitor(this.map, "");
|
|
34
|
+
return map;
|
|
35
|
+
}
|
|
36
|
+
resolveServices() {
|
|
37
|
+
const map = new Map();
|
|
38
|
+
this.resolveLeaves().forEach((leaf, key) => {
|
|
39
|
+
map.set(key, leaf.resolveService());
|
|
40
|
+
});
|
|
41
|
+
return map;
|
|
42
|
+
}
|
|
43
|
+
resolveAncestor(path) {
|
|
44
|
+
if (!isString(path) || path.length == 0) {
|
|
45
|
+
return this;
|
|
46
|
+
}
|
|
47
|
+
let parentTree;
|
|
48
|
+
try {
|
|
49
|
+
parentTree = this.parentTree.resolvePath(this.path);
|
|
50
|
+
parentTree = parentTree.resolveAncestor(path);
|
|
51
|
+
}
|
|
52
|
+
catch (e) {
|
|
53
|
+
parentTree = new Tree(this.container, "");
|
|
54
|
+
}
|
|
55
|
+
const pathParts = path.split(".");
|
|
56
|
+
let tree = this;
|
|
57
|
+
let previousTree = this;
|
|
58
|
+
for (let part of pathParts) {
|
|
59
|
+
tree = tree.map.get(part);
|
|
60
|
+
if (!tree) {
|
|
61
|
+
if (previousTree == this) {
|
|
62
|
+
if (parentTree.path.length > 0) {
|
|
63
|
+
return parentTree;
|
|
64
|
+
}
|
|
65
|
+
throw new Error(`Ancestor '${path}' not found in current tree: '${this.path}'`);
|
|
66
|
+
}
|
|
67
|
+
return previousTree;
|
|
68
|
+
}
|
|
69
|
+
previousTree = tree;
|
|
70
|
+
}
|
|
71
|
+
return parentTree.path.length > previousTree.path.length
|
|
72
|
+
? parentTree : previousTree;
|
|
73
|
+
}
|
|
74
|
+
resolvePath(path, throwError = true) {
|
|
75
|
+
const absolutePath = !this.path ? path : `${this.path}.${path}`;
|
|
76
|
+
let tree = new Tree(this.container, absolutePath);
|
|
77
|
+
try {
|
|
78
|
+
tree = this.resolveAncestor(path);
|
|
79
|
+
}
|
|
80
|
+
catch (e) {
|
|
81
|
+
if (throwError) {
|
|
82
|
+
throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);
|
|
83
|
+
}
|
|
84
|
+
return tree;
|
|
85
|
+
}
|
|
86
|
+
if (tree.path !== absolutePath) {
|
|
87
|
+
if (throwError) {
|
|
88
|
+
throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);
|
|
89
|
+
}
|
|
90
|
+
return tree;
|
|
91
|
+
}
|
|
92
|
+
return tree;
|
|
93
|
+
}
|
|
94
|
+
addPath(path) {
|
|
95
|
+
if (!isString(path) || path.length == 0) {
|
|
96
|
+
return this;
|
|
97
|
+
}
|
|
98
|
+
const pathParts = path.split(".");
|
|
99
|
+
let tree = this;
|
|
100
|
+
path = this.path;
|
|
101
|
+
for (let part of pathParts) {
|
|
102
|
+
if (!tree.map.has(part)) {
|
|
103
|
+
tree.map.set(part, new Tree(this.container, !path ? part : `${path}.${part}`));
|
|
104
|
+
}
|
|
105
|
+
tree = tree.map.get(part);
|
|
106
|
+
path = tree.path;
|
|
107
|
+
}
|
|
108
|
+
return this;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.js","sourceRoot":"","sources":["../../../src/utilities/tree.ts"],"names":[],"mappings":"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","sourcesContent":["import {IDependencyContainer, ITree} from \"../common-types\";\r\nimport {isString} from \"../utils\";\r\n\r\nexport class Tree implements ITree {\r\n\r\n    protected map: Map<string, Tree>;\r\n\r\n    protected get parentTree(): ITree {\r\n        return this.container.parent.tree;\r\n    }\r\n\r\n    constructor(protected container: IDependencyContainer, readonly path: string) {\r\n        this.map = new Map<string, Tree>();\r\n    }\r\n\r\n    resolveService(): any {\r\n        return this.container.resolve(this.path);\r\n    }\r\n\r\n    resolveLeaves(): Map<string, ITree> {\r\n        let map: Map<string, ITree>;\r\n        try {\r\n            const parentTree = this.parentTree.resolvePath(this.path);\r\n            map = parentTree.resolveLeaves();\r\n        } catch (e) {\r\n            map = new Map<string, ITree>();\r\n        }\r\n        const visitor = (treeMap: Map<string, Tree>, path: string) => {\r\n            treeMap.forEach((tree, key) => {\r\n                const subKey = !path ? key : `${path}.${key}`;\r\n                if (tree.map.size == 0) {\r\n                    map.set(subKey, tree);\r\n                    return;\r\n                }\r\n                visitor(tree.map, subKey);\r\n            });\r\n        };\r\n        visitor(this.map, \"\");\r\n        return map;\r\n    }\r\n\r\n    resolveServices(): Map<string, any> {\r\n        const map = new Map<string, any>();\r\n        this.resolveLeaves().forEach((leaf, key) => {\r\n            map.set(key, leaf.resolveService());\r\n        });\r\n        return map;\r\n    }\r\n\r\n    resolveAncestor(path: string): ITree {\r\n        if (!isString(path) || path.length == 0) {\r\n            return this;\r\n        }\r\n        let parentTree: ITree;\r\n        try {\r\n            parentTree = this.parentTree.resolvePath(this.path);\r\n            parentTree = parentTree.resolveAncestor(path);\r\n        } catch (e) {\r\n            parentTree = new Tree(this.container, \"\");\r\n        }\r\n        const pathParts = path.split(\".\");\r\n        let tree: Tree = this;\r\n        let previousTree: Tree = this;\r\n        for (let part of pathParts) {\r\n            tree = tree.map.get(part);\r\n            if (!tree) {\r\n                if (previousTree == this) {\r\n                    if (parentTree.path.length > 0) {\r\n                        return parentTree;\r\n                    }\r\n                    throw new Error(`Ancestor '${path}' not found in current tree: '${this.path}'`);\r\n                }\r\n                return previousTree;\r\n            }\r\n            previousTree = tree;\r\n        }\r\n        return parentTree.path.length > previousTree.path.length\r\n            ? parentTree : previousTree;\r\n    }\r\n\r\n    resolvePath(path: string, throwError: boolean = true): ITree {\r\n        const absolutePath = !this.path ? path : `${this.path}.${path}`;\r\n        let tree: ITree = new Tree(this.container, absolutePath);\r\n        try {\r\n            tree = this.resolveAncestor(path);\r\n        } catch (e) {\r\n            if (throwError) {\r\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\r\n            }\r\n            return tree;\r\n        }\r\n        if (tree.path !== absolutePath) {\r\n            if (throwError) {\r\n                throw new Error(`Path '${path}' not found in current tree: '${this.path}'`);\r\n            }\r\n            return tree;\r\n        }\r\n        return tree;\r\n    }\r\n\r\n    addPath(path: string): this {\r\n        if (!isString(path) || path.length == 0) {\r\n            return this;\r\n        }\r\n        const pathParts = path.split(\".\");\r\n        let tree: Tree = this;\r\n        path = this.path;\r\n        for (let part of pathParts) {\r\n            if (!tree.map.has(part)) {\r\n                tree.map.set(part, new Tree(this.container, !path ? part : `${path}.${part}`))\r\n            }\r\n            tree = tree.map.get(part);\r\n            path = tree.path;\r\n        }\r\n        return this;\r\n    }\r\n}\r\n"]}
|