@steedos/service-package-registry 2.5.0-beta.1 → 2.5.0-beta.11

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.
@@ -79,7 +79,9 @@ const loadPackages = async ()=>{
79
79
  }
80
80
  if(packagePath){
81
81
  const packageInfo = await loadPackage(packageName, packagePath);
82
- appendToPackagesConfig(packageInfo.name, {version: packageInfo.version, description: packageInfo.description, local: true});
82
+ if(packageInfo){
83
+ appendToPackagesConfig(packageInfo.name, {version: packageInfo.version, description: packageInfo.description, local: true});
84
+ }
83
85
  }
84
86
  }
85
87
  }
@@ -106,6 +108,11 @@ const destroyExistThePackageService = async (packageInfo)=>{
106
108
  let svc = broker.getLocalService({
107
109
  name: `~packages-${packageInfo.name}`
108
110
  });
111
+ if(!svc){
112
+ svc = broker.getLocalService({
113
+ name: packageInfo.name
114
+ });
115
+ }
109
116
  if (svc) {
110
117
  broker.logger.info(`Destroy previous '${schema.name}' service...`);
111
118
  await broker.destroyService(svc);
@@ -164,6 +171,13 @@ const loadPackage = async (packageName, packagePath)=>{
164
171
  paths: [path.join(userDir, 'node_modules')]
165
172
  }))
166
173
  }
174
+ let schema = objectql.getSteedosSchema();
175
+ let broker = schema.broker;
176
+ if(!fs.existsSync(packagePath) || !fs.existsSync(path.join(packagePath, 'package.json'))){
177
+ broker.logger.warn(`已经从 steedos-packages.yml 文件中删除无效的软件包配置 ${packageName} : ${packagePath}`)
178
+ removePackageConfig(packageName);
179
+ return ;
180
+ }
167
181
  const packageInfo = require(path.join(packagePath, 'package.json'));
168
182
  await destroyExistThePackageService(packageInfo);
169
183
  await steedos.loadPackage(packagePath);
@@ -184,7 +198,7 @@ const disablePackage = async (packageName)=>{
184
198
  let schema = objectql.getSteedosSchema();
185
199
  let broker = schema.broker;
186
200
  const serviceList = broker.registry.getServiceList({ withActions: true });
187
- const service = _.find(serviceList, (_service)=>{return _service.name == `~packages-${packageName}`;})
201
+ const service = _.find(serviceList, (_service)=>{return _service.name == `~packages-${packageName}` || _service.name == packageName;})
188
202
  if(service){
189
203
  await broker.destroyService(service);
190
204
  }
@@ -205,10 +219,14 @@ const removePackage = async (packageName)=>{
205
219
  let schema = objectql.getSteedosSchema();
206
220
  let broker = schema.broker;
207
221
  const serviceList = broker.registry.getServiceList({ withActions: true });
208
- const service = _.find(serviceList, (_service)=>{return _service.name == `~packages-${packageName}`;})
222
+ const service = _.find(serviceList, (_service)=>{return _service.name == `~packages-${packageName}` || _service.name == packageName;})
209
223
  if(service){
210
224
  await broker.destroyService(service);
211
225
  }
226
+ removePackageConfig(packageName);
227
+ }
228
+
229
+ const removePackageConfig = (packageName)=>{
212
230
  const packages = loadPackagesConfig();
213
231
  delete packages[packageName];
214
232
  let data = yaml.dump(packages);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@steedos/service-package-registry",
3
- "version": "2.5.0-beta.1",
3
+ "version": "2.5.0-beta.11",
4
4
  "description": "",
5
5
  "main": "package.service.js",
6
6
  "scripts": {
@@ -9,12 +9,12 @@
9
9
  "author": "",
10
10
  "license": "ISC",
11
11
  "dependencies": {
12
- "@steedos/auth": "2.5.0-beta.1",
13
- "@steedos/core": "2.5.0-beta.1",
14
- "@steedos/metadata-core": "2.5.0-beta.1",
15
- "@steedos/objectql": "2.5.0-beta.1",
16
- "@steedos/service-package-license": "2.5.0-beta.1",
17
- "@steedos/service-package-loader": "2.5.0-beta.1",
12
+ "@steedos/auth": "2.5.0-beta.11",
13
+ "@steedos/core": "2.5.0-beta.11",
14
+ "@steedos/metadata-core": "2.5.0-beta.11",
15
+ "@steedos/objectql": "2.5.0-beta.11",
16
+ "@steedos/service-package-license": "2.5.0-beta.11",
17
+ "@steedos/service-package-loader": "2.5.0-beta.11",
18
18
  "fs-extra": "8.1.0",
19
19
  "i18next": "20.3.2",
20
20
  "json-stringify-safe": "5.0.1",
@@ -32,5 +32,5 @@
32
32
  "publishConfig": {
33
33
  "access": "public"
34
34
  },
35
- "gitHead": "5da093d78baa6f2d7011348060c30671354cc7f0"
35
+ "gitHead": "72a894aab5a9d4e277d0464decda0ba39f2f50bb"
36
36
  }