mirror of
				https://github.com/rubickCenter/rubick
				synced 2025-10-26 22:51:25 +08:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
			v4.2.9
			...
			7b55716742
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 7b55716742 | ||
|  | 5ca1ba1271 | ||
|  | 8c3186afef | ||
|  | de0e9ed8f2 | ||
|  | 2307faf31a | 
| @@ -90,6 +90,9 @@ | ||||
|  | ||||
| [Rubick Plugin CLI](https://github.com/rubickCenter/rubick-plugin-cli) | ||||
|  | ||||
| ## 局限性 | ||||
| npm包最终大小不宜超过100MB,所以插件包大小也不宜超过此大小,建议20MB以内,如果包体积过大,预期会导致推送npm仓库失败 | ||||
|  | ||||
| ## 赞助 | ||||
| ### 1. 加入知识星球 | ||||
| 我们在知识星球积累了大量的关于 rubick 的知识和常见问题,您可以付费加入我们的知识星球来一起讨论。我们将随时解答! | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "rubick", | ||||
|   "version": "4.2.9", | ||||
|   "version": "4.3.0", | ||||
|   "author": "muwoo <2424880409@qq.com>", | ||||
|   "private": true, | ||||
|   "scripts": { | ||||
|   | ||||
| @@ -7,11 +7,10 @@ import path from 'path'; | ||||
| import got from 'got'; | ||||
| import fixPath from 'fix-path'; | ||||
|  | ||||
| import spawn from 'cross-spawn'; | ||||
| import { ipcRenderer } from 'electron'; | ||||
| import axios from 'axios'; | ||||
|  | ||||
| import npm from 'npm'; | ||||
|  | ||||
| fixPath(); | ||||
|  | ||||
| /** | ||||
| @@ -42,7 +41,7 @@ class AdapterHandler { | ||||
|     } | ||||
|     this.baseDir = options.baseDir; | ||||
|  | ||||
|     let register = options.registry || 'https://registry.npmmirror.com/'; | ||||
|     let register = options.registry || 'https://registry.npm.taobao.org'; | ||||
|  | ||||
|     try { | ||||
|       const dbdata = ipcRenderer.sendSync('msg-trigger', { | ||||
| @@ -61,7 +60,7 @@ class AdapterHandler { | ||||
|     const packageJSON = JSON.parse( | ||||
|       fs.readFileSync(`${this.baseDir}/package.json`, 'utf-8') | ||||
|     ); | ||||
|     const registryUrl = `${this.registry}${name}`; | ||||
|     const registryUrl = `https://registry.npm.taobao.org/${name}`; | ||||
|  | ||||
|     // 从npm源中获取依赖包的最新版本 | ||||
|     try { | ||||
| @@ -158,32 +157,43 @@ class AdapterHandler { | ||||
|    */ | ||||
|   private async execCommand(cmd: string, modules: string[]): Promise<string> { | ||||
|     return new Promise((resolve: any, reject: any) => { | ||||
|       const module = | ||||
|       let args: string[] = [cmd].concat( | ||||
|         cmd !== 'uninstall' && cmd !== 'link' | ||||
|           ? modules.map((m) => `${m}@latest`) | ||||
|           : modules; | ||||
|       const config: any = { | ||||
|         prefix: this.baseDir, | ||||
|         save: true, | ||||
|         cache: path.join(this.baseDir, 'cache'), | ||||
|       }; | ||||
|           : modules | ||||
|       ); | ||||
|       if (cmd !== 'link') { | ||||
|         config.registry = this.registry; | ||||
|         args = args | ||||
|           .concat('--color=always') | ||||
|           .concat('--save') | ||||
|           .concat(`--registry=${this.registry}`); | ||||
|       } | ||||
|       npm.load(config, function (err) { | ||||
|         npm.commands[cmd](module, function (er, data) { | ||||
|           if (!err) { | ||||
|             console.log(data); | ||||
|             resolve({ code: -1, data }); | ||||
|           } else { | ||||
|             reject({ code: -1, data: err }); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         npm.on('log', function (message) { | ||||
|           // log installation progress | ||||
|           console.log(message); | ||||
|         }); | ||||
|       const npm = spawn('npm', args, { | ||||
|         cwd: this.baseDir, | ||||
|       }); | ||||
|  | ||||
|       console.log(args); | ||||
|  | ||||
|       let output = ''; | ||||
|       npm.stdout | ||||
|         .on('data', (data: string) => { | ||||
|           output += data; // 获取输出日志 | ||||
|         }) | ||||
|         .pipe(process.stdout); | ||||
|  | ||||
|       npm.stderr | ||||
|         .on('data', (data: string) => { | ||||
|           output += data; // 获取报错日志 | ||||
|         }) | ||||
|         .pipe(process.stderr); | ||||
|  | ||||
|       npm.on('close', (code: number) => { | ||||
|         if (!code) { | ||||
|           resolve({ code: 0, data: output }); // 如果没有报错就输出正常日志 | ||||
|         } else { | ||||
|           reject({ code: code, data: output }); // 如果报错就输出报错日志 | ||||
|         } | ||||
|       }); | ||||
|     }); | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user