@nocobase/server 1.4.0-beta.3 → 1.4.0-beta.5
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.
|
@@ -32,6 +32,7 @@ export declare class PluginManagerRepository extends Repository {
|
|
|
32
32
|
* @deprecated
|
|
33
33
|
*/
|
|
34
34
|
disable(name: string | string[]): Promise<string[]>;
|
|
35
|
-
|
|
35
|
+
sort(names: string[]): Promise<string[]>;
|
|
36
|
+
getItems(): Promise<any[]>;
|
|
36
37
|
init(): Promise<void>;
|
|
37
38
|
}
|
|
@@ -40,6 +40,7 @@ __export(plugin_manager_repository_exports, {
|
|
|
40
40
|
PluginManagerRepository: () => PluginManagerRepository
|
|
41
41
|
});
|
|
42
42
|
module.exports = __toCommonJS(plugin_manager_repository_exports);
|
|
43
|
+
var import_topo = __toESM(require("@hapi/topo"));
|
|
43
44
|
var import_database = require("@nocobase/database");
|
|
44
45
|
var import_lodash = __toESM(require("lodash"));
|
|
45
46
|
var import_plugin_manager = require("./plugin-manager");
|
|
@@ -140,17 +141,44 @@ const _PluginManagerRepository = class _PluginManagerRepository extends import_d
|
|
|
140
141
|
});
|
|
141
142
|
return pluginNames;
|
|
142
143
|
}
|
|
144
|
+
async sort(names) {
|
|
145
|
+
const pluginNames = import_lodash.default.castArray(names);
|
|
146
|
+
if (pluginNames.length === 1) {
|
|
147
|
+
return pluginNames;
|
|
148
|
+
}
|
|
149
|
+
const sorter = new import_topo.default.Sorter();
|
|
150
|
+
for (const pluginName of pluginNames) {
|
|
151
|
+
const packageJson = await import_plugin_manager.PluginManager.getPackageJson(pluginName);
|
|
152
|
+
const peerDependencies = Object.keys((packageJson == null ? void 0 : packageJson.peerDependencies) || {});
|
|
153
|
+
sorter.add(pluginName, { after: peerDependencies, group: (packageJson == null ? void 0 : packageJson.packageName) || pluginName });
|
|
154
|
+
}
|
|
155
|
+
return sorter.nodes;
|
|
156
|
+
}
|
|
143
157
|
async getItems() {
|
|
144
158
|
const exists = await this.collection.existsInDb();
|
|
145
159
|
if (!exists) {
|
|
146
160
|
return [];
|
|
147
161
|
}
|
|
148
|
-
|
|
162
|
+
const items = await this.find({
|
|
149
163
|
sort: "id",
|
|
150
164
|
filter: {
|
|
151
165
|
enabled: true
|
|
152
166
|
}
|
|
153
167
|
});
|
|
168
|
+
const sortedItems = [];
|
|
169
|
+
const map = {};
|
|
170
|
+
for (const item of items) {
|
|
171
|
+
if (item.packageName) {
|
|
172
|
+
map[item.packageName] = item;
|
|
173
|
+
} else {
|
|
174
|
+
sortedItems.push(item);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
const names = await this.sort(Object.keys(map));
|
|
178
|
+
for (const name of names) {
|
|
179
|
+
sortedItems.push(map[name]);
|
|
180
|
+
}
|
|
181
|
+
return sortedItems;
|
|
154
182
|
}
|
|
155
183
|
async init() {
|
|
156
184
|
const items = await this.getItems();
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nocobase/server",
|
|
3
|
-
"version": "1.4.0-beta.
|
|
3
|
+
"version": "1.4.0-beta.5",
|
|
4
4
|
"main": "lib/index.js",
|
|
5
5
|
"types": "./lib/index.d.ts",
|
|
6
6
|
"license": "AGPL-3.0",
|
|
@@ -10,18 +10,18 @@
|
|
|
10
10
|
"@koa/cors": "^3.1.0",
|
|
11
11
|
"@koa/multer": "^3.0.2",
|
|
12
12
|
"@koa/router": "^9.4.0",
|
|
13
|
-
"@nocobase/acl": "1.4.0-beta.
|
|
14
|
-
"@nocobase/actions": "1.4.0-beta.
|
|
15
|
-
"@nocobase/auth": "1.4.0-beta.
|
|
16
|
-
"@nocobase/cache": "1.4.0-beta.
|
|
17
|
-
"@nocobase/data-source-manager": "1.4.0-beta.
|
|
18
|
-
"@nocobase/database": "1.4.0-beta.
|
|
19
|
-
"@nocobase/evaluators": "1.4.0-beta.
|
|
20
|
-
"@nocobase/logger": "1.4.0-beta.
|
|
21
|
-
"@nocobase/resourcer": "1.4.0-beta.
|
|
22
|
-
"@nocobase/sdk": "1.4.0-beta.
|
|
23
|
-
"@nocobase/telemetry": "1.4.0-beta.
|
|
24
|
-
"@nocobase/utils": "1.4.0-beta.
|
|
13
|
+
"@nocobase/acl": "1.4.0-beta.5",
|
|
14
|
+
"@nocobase/actions": "1.4.0-beta.5",
|
|
15
|
+
"@nocobase/auth": "1.4.0-beta.5",
|
|
16
|
+
"@nocobase/cache": "1.4.0-beta.5",
|
|
17
|
+
"@nocobase/data-source-manager": "1.4.0-beta.5",
|
|
18
|
+
"@nocobase/database": "1.4.0-beta.5",
|
|
19
|
+
"@nocobase/evaluators": "1.4.0-beta.5",
|
|
20
|
+
"@nocobase/logger": "1.4.0-beta.5",
|
|
21
|
+
"@nocobase/resourcer": "1.4.0-beta.5",
|
|
22
|
+
"@nocobase/sdk": "1.4.0-beta.5",
|
|
23
|
+
"@nocobase/telemetry": "1.4.0-beta.5",
|
|
24
|
+
"@nocobase/utils": "1.4.0-beta.5",
|
|
25
25
|
"@types/decompress": "4.2.7",
|
|
26
26
|
"@types/ini": "^1.3.31",
|
|
27
27
|
"@types/koa-send": "^4.1.3",
|
|
@@ -54,5 +54,5 @@
|
|
|
54
54
|
"@types/serve-handler": "^6.1.1",
|
|
55
55
|
"@types/ws": "^8.5.5"
|
|
56
56
|
},
|
|
57
|
-
"gitHead": "
|
|
57
|
+
"gitHead": "f5d1207519ab2b82db0ced0369ed88e09d09d88b"
|
|
58
58
|
}
|