@nocobase/cli 1.5.0-beta.3 → 1.5.0-beta.30

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/nocobase.conf.tpl CHANGED
@@ -65,11 +65,14 @@ server {
65
65
  }
66
66
  }
67
67
 
68
+ {{otherLocation}}
69
+
68
70
  location ^~ {{publicPath}}api/ {
69
71
  proxy_pass http://127.0.0.1:{{apiPort}};
70
72
  proxy_http_version 1.1;
71
73
  proxy_set_header Upgrade $http_upgrade;
72
74
  proxy_set_header Connection 'upgrade';
75
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
73
76
  proxy_set_header Host $host;
74
77
  add_header Cache-Control 'no-cache, no-store';
75
78
  proxy_cache_bypass $http_upgrade;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nocobase/cli",
3
- "version": "1.5.0-beta.3",
3
+ "version": "1.5.0-beta.30",
4
4
  "description": "",
5
5
  "license": "AGPL-3.0",
6
6
  "main": "./src/index.js",
@@ -8,7 +8,7 @@
8
8
  "nocobase": "./bin/index.js"
9
9
  },
10
10
  "dependencies": {
11
- "@nocobase/app": "1.5.0-beta.3",
11
+ "@nocobase/app": "1.5.0-beta.30",
12
12
  "@types/fs-extra": "^11.0.1",
13
13
  "@umijs/utils": "3.5.20",
14
14
  "chalk": "^4.1.1",
@@ -25,12 +25,12 @@
25
25
  "tsx": "^4.19.0"
26
26
  },
27
27
  "devDependencies": {
28
- "@nocobase/devtools": "1.5.0-beta.3"
28
+ "@nocobase/devtools": "1.5.0-beta.30"
29
29
  },
30
30
  "repository": {
31
31
  "type": "git",
32
32
  "url": "git+https://github.com/nocobase/nocobase.git",
33
33
  "directory": "packages/core/cli"
34
34
  },
35
- "gitHead": "81afcf4affdb652faf4636e6d9351828ce8906be"
35
+ "gitHead": "40c48b2ecf3e2315a76dcb729dbda825b6a1331c"
36
36
  }
@@ -7,7 +7,7 @@
7
7
  * For more information, please refer to: https://www.nocobase.com/agreement.
8
8
  */
9
9
 
10
- const { resolve } = require('path');
10
+ const { resolve, posix } = require('path');
11
11
  const { Command } = require('commander');
12
12
  const { readFileSync, writeFileSync } = require('fs');
13
13
 
@@ -19,11 +19,18 @@ module.exports = (cli) => {
19
19
  cli.command('create-nginx-conf').action(async (name, options) => {
20
20
  const file = resolve(__dirname, '../../nocobase.conf.tpl');
21
21
  const data = readFileSync(file, 'utf-8');
22
+ let otherLocation = '';
23
+ if (process.env.APP_PUBLIC_PATH !== '/') {
24
+ otherLocation = `location / {
25
+ alias ${posix.resolve(process.cwd())}/node_modules/@nocobase/app/dist/client/;
26
+ try_files $uri $uri/ /index.html;
27
+ }`;
28
+ }
22
29
  const replaced = data
23
- .replace(/\{\{cwd\}\}/g, '/app/nocobase')
30
+ .replace(/\{\{cwd\}\}/g, posix.resolve(process.cwd()))
24
31
  .replace(/\{\{publicPath\}\}/g, process.env.APP_PUBLIC_PATH)
25
- .replace(/\{\{apiPort\}\}/g, process.env.APP_PORT);
26
-
32
+ .replace(/\{\{apiPort\}\}/g, process.env.APP_PORT)
33
+ .replace(/\{\{otherLocation\}\}/g, otherLocation);
27
34
  const targetFile = resolve(process.cwd(), 'storage', 'nocobase.conf');
28
35
  writeFileSync(targetFile, replaced);
29
36
  });
@@ -89,16 +89,13 @@ module.exports = (cli) => {
89
89
 
90
90
  watcher
91
91
  .on('ready', () => {
92
- console.log('Initial scan complete.');
93
92
  isReady = true;
94
93
  })
95
94
  .on('addDir', async (pathname) => {
96
- console.log('addDir....', isReady);
97
95
  if (!isReady) return;
98
96
  restartClient();
99
97
  })
100
98
  .on('unlinkDir', async (pathname) => {
101
- console.log('unlinkDir....', isReady);
102
99
  if (!isReady) return;
103
100
  restartClient();
104
101
  });
@@ -140,7 +140,7 @@ class Package {
140
140
  .on('finish', resolve)
141
141
  .on('error', reject);
142
142
  });
143
- console.log(chalk.greenBright(`Download success: ${this.packageName}@${version}`));
143
+ console.log(chalk.greenBright(`Downloaded: ${this.packageName}@${version}`));
144
144
  } catch (error) {
145
145
  console.log(chalk.redBright(`Download failed: ${this.packageName}`));
146
146
  }
@@ -189,21 +189,45 @@ class PackageManager {
189
189
  },
190
190
  responseType: 'json',
191
191
  });
192
- return res.data.data;
192
+ return {
193
+ licensed_plugins: res.data?.data || [],
194
+ commercial_plugins: res.data?.meta?.commercial_plugins || [],
195
+ };
193
196
  }
194
197
 
195
198
  async getPackages() {
196
199
  const pkgs = await this.getProPackages();
200
+
201
+ if (Array.isArray(pkgs)) {
202
+ return {
203
+ commercial_plugins: pkgs,
204
+ licensed_plugins: pkgs,
205
+ };
206
+ }
197
207
  return pkgs;
198
208
  }
199
209
 
210
+ async removePackage(packageName) {
211
+ const dir = path.resolve(process.env.PLUGIN_STORAGE_PATH, packageName);
212
+ const r = await fs.exists(dir);
213
+ if (r) {
214
+ console.log(chalk.yellowBright(`Removed: ${packageName}`));
215
+ await fs.rm(dir, { force: true, recursive: true });
216
+ }
217
+ }
218
+
200
219
  async download(options = {}) {
201
220
  const { version } = options;
202
221
  if (!this.token) {
203
222
  return;
204
223
  }
205
- const pkgs = await this.getPackages();
206
- for (const pkg of pkgs) {
224
+ const { commercial_plugins, licensed_plugins } = await this.getPackages();
225
+ for (const pkg of commercial_plugins) {
226
+ if (!licensed_plugins.includes(pkg)) {
227
+ await this.removePackage(pkg);
228
+ }
229
+ }
230
+ for (const pkg of licensed_plugins) {
207
231
  await this.getPackage(pkg).download({ version });
208
232
  }
209
233
  }
@@ -58,16 +58,13 @@ module.exports = (cli) => {
58
58
 
59
59
  watcher
60
60
  .on('ready', () => {
61
- console.log('Initial scan complete.');
62
61
  isReady = true;
63
62
  })
64
63
  .on('addDir', async (pathname) => {
65
- console.log('addDir....', isReady);
66
64
  if (!isReady) return;
67
65
  restart();
68
66
  })
69
67
  .on('unlinkDir', async (pathname) => {
70
- console.log('unlinkDir....', isReady);
71
68
  if (!isReady) return;
72
69
  restart();
73
70
  });
package/src/util.js CHANGED
@@ -164,6 +164,10 @@ exports.promptForTs = () => {
164
164
  };
165
165
 
166
166
  exports.downloadPro = async () => {
167
+ const { NOCOBASE_PKG_USERNAME, NOCOBASE_PKG_PASSWORD } = process.env;
168
+ if (!(NOCOBASE_PKG_USERNAME && NOCOBASE_PKG_PASSWORD)) {
169
+ return;
170
+ }
167
171
  await exports.run('yarn', ['nocobase', 'pkg', 'download-pro']);
168
172
  };
169
173