rigjs 3.0.2 → 3.0.6
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 +6 -6
- package/built/index.js +112 -112
- package/demo/env.rig.json5 +8 -0
- package/demo/package.json +7 -3
- package/demo/package.rig.json5 +8 -2
- package/demo/yarn.lock +3 -3
- package/lib/build/index.ts +1 -1
- package/lib/classes/RigConfig.ts +7 -5
- package/lib/classes/dependencies/Dep.ts +4 -0
- package/lib/env/index.ts +52 -0
- package/lib/preinstall/index.ts +6 -2
- package/lib/print/index.ts +1 -1
- package/lib/rig/index.ts +3 -1
- package/lib/tag/{index.js → index.ts} +6 -6
- package/lib/utils/fsHelper.ts +6 -1
- package/package.json +2 -2
- package/lib/tag/index.d.ts +0 -6
- package/lib/vue-env/index.d.ts +0 -6
- package/lib/vue-env/index.js +0 -50
package/demo/package.json
CHANGED
|
@@ -9,14 +9,18 @@
|
|
|
9
9
|
"build": "vue-cli-service build",
|
|
10
10
|
"lint": "vue-cli-service lint",
|
|
11
11
|
"preinstall": "rig preinstall",
|
|
12
|
-
"postinstall": "rig postinstall"
|
|
12
|
+
"postinstall": "rig postinstall",
|
|
13
|
+
"test_prei": "node ../built/index.js preinstall",
|
|
14
|
+
"test_env": "node ../built/index.js --env dev",
|
|
15
|
+
"test_posti": "node ../built/index.js postinstall"
|
|
13
16
|
},
|
|
14
17
|
"dependencies": {
|
|
15
18
|
"core-js": "^3.8.3",
|
|
16
19
|
"cross-env": "^7.0.3",
|
|
17
20
|
"rig-test-1": "git+ssh://git@github.com:FlashHand/rig-test-1.git#1.0.1",
|
|
18
|
-
"rig-test-2": "git+ssh://git@github.com:FlashHand/rig-test-2.git#1.0.
|
|
19
|
-
"vue": "^2.6.14"
|
|
21
|
+
"rig-test-2": "git+ssh://git@github.com:FlashHand/rig-test-2.git#1.0.1",
|
|
22
|
+
"vue": "^2.6.14",
|
|
23
|
+
"zenrtcjssdk": "git+ssh://git@code.y5ops.com:zenrtc/zenrtcjssdk.git#0.0.4"
|
|
20
24
|
},
|
|
21
25
|
"devDependencies": {
|
|
22
26
|
"@babel/core": "^7.12.16",
|
package/demo/package.rig.json5
CHANGED
|
@@ -10,8 +10,14 @@
|
|
|
10
10
|
dev: false,
|
|
11
11
|
name: 'rig-test-2',
|
|
12
12
|
source: 'git@github.com:FlashHand/rig-test-2.git',
|
|
13
|
-
version: '1.0.
|
|
13
|
+
version: '1.0.1',
|
|
14
14
|
},
|
|
15
|
+
'zenrtcjssdk': {
|
|
16
|
+
dev: true,
|
|
17
|
+
name: 'zenrtcjssdk',
|
|
18
|
+
source: 'git@code.y5ops.com:zenrtc/zenrtcjssdk.git',
|
|
19
|
+
version: '0.0.4'
|
|
20
|
+
}
|
|
15
21
|
},
|
|
16
22
|
isLegacy: false,
|
|
17
23
|
cicd: {
|
|
@@ -41,7 +47,7 @@
|
|
|
41
47
|
RIG_REPLACE_GRAY: '/test-gray'
|
|
42
48
|
},
|
|
43
49
|
domains: [
|
|
44
|
-
"test-mp.
|
|
50
|
+
"test-mp.domain.com"
|
|
45
51
|
],
|
|
46
52
|
},
|
|
47
53
|
},
|
package/demo/yarn.lock
CHANGED
|
@@ -5079,9 +5079,9 @@ reusify@^1.0.4:
|
|
|
5079
5079
|
version "1.0.1"
|
|
5080
5080
|
resolved "git+ssh://git@github.com:FlashHand/rig-test-1.git#9a86b587aa9bea6c176ab8a470c8a86e7a2bf655"
|
|
5081
5081
|
|
|
5082
|
-
"rig-test-2@git+ssh://git@github.com:FlashHand/rig-test-2.git#1.0.
|
|
5083
|
-
version "1.0.
|
|
5084
|
-
resolved "git+ssh://git@github.com:FlashHand/rig-test-2.git#
|
|
5082
|
+
"rig-test-2@git+ssh://git@github.com:FlashHand/rig-test-2.git#1.0.1":
|
|
5083
|
+
version "1.0.1"
|
|
5084
|
+
resolved "git+ssh://git@github.com:FlashHand/rig-test-2.git#abdb17fcfe11c5dff94b93be8cc690bc8583e219"
|
|
5085
5085
|
|
|
5086
5086
|
rimraf@^3.0.2:
|
|
5087
5087
|
version "3.0.2"
|
package/lib/build/index.ts
CHANGED
package/lib/classes/RigConfig.ts
CHANGED
|
@@ -34,8 +34,6 @@ class RigConfig {
|
|
|
34
34
|
}
|
|
35
35
|
this.share = rigConfig.share;
|
|
36
36
|
}
|
|
37
|
-
console.log(this);
|
|
38
|
-
this.validate();
|
|
39
37
|
}
|
|
40
38
|
|
|
41
39
|
/**
|
|
@@ -67,6 +65,10 @@ class RigConfig {
|
|
|
67
65
|
}
|
|
68
66
|
}
|
|
69
67
|
|
|
68
|
+
/**
|
|
69
|
+
* 检查依赖的之间的依赖(仅包含rig管理下的依赖)
|
|
70
|
+
*
|
|
71
|
+
*/
|
|
70
72
|
validateDeps() {
|
|
71
73
|
print.info(`rig validating dependencies' requirements`);
|
|
72
74
|
let valid = true;
|
|
@@ -75,9 +77,8 @@ class RigConfig {
|
|
|
75
77
|
try {
|
|
76
78
|
let pkgStr: string;
|
|
77
79
|
if (rigDep.dev) {
|
|
78
|
-
|
|
79
|
-
print.info(`${rigName} is in deleloping.
|
|
80
|
-
continue;
|
|
80
|
+
pkgStr = fsHelper.readPkgStrInRepo(rigName);
|
|
81
|
+
print.info(`${rigName} is in deleloping.Validating ${rigName}'s dependencies...`);
|
|
81
82
|
} else {
|
|
82
83
|
const cmd = `git fetch ${rigDep.source} refs/tags/${rigDep.version} && git show FETCH_HEAD:package.json`;
|
|
83
84
|
print.info(`validateDeps:${cmd}`);
|
|
@@ -138,6 +139,7 @@ class RigConfig {
|
|
|
138
139
|
}
|
|
139
140
|
})
|
|
140
141
|
}
|
|
142
|
+
|
|
141
143
|
} catch (e) {
|
|
142
144
|
throw new Error(`rig validateDeps failed:${e.message}`);
|
|
143
145
|
}
|
package/lib/env/index.ts
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @ignore
|
|
3
|
+
* @Description nothing
|
|
4
|
+
* @author Wang Bo (ralwayne@163.com)
|
|
5
|
+
* @date 2021/11/18 6:14 PM
|
|
6
|
+
*/
|
|
7
|
+
import * as fs from 'fs';
|
|
8
|
+
import json5 from 'json5';
|
|
9
|
+
import print from "@/print";
|
|
10
|
+
import * as console from "console";
|
|
11
|
+
const useEnv = (mode:string,extra?:any)=>{
|
|
12
|
+
try {
|
|
13
|
+
const rigJson5 = json5.parse(fs.readFileSync('env.rig.json5'));
|
|
14
|
+
let modeObj = rigJson5[mode];
|
|
15
|
+
if (modeObj) {
|
|
16
|
+
if (extra) modeObj = Object.assign(modeObj, extra);
|
|
17
|
+
const keysArray = Object.keys(modeObj);
|
|
18
|
+
let content = "";
|
|
19
|
+
for (let i = 0; i<keysArray.length; i++) {
|
|
20
|
+
const key = keysArray[i];
|
|
21
|
+
const value = modeObj[key];
|
|
22
|
+
content += key + " = " + value + "\n"
|
|
23
|
+
}
|
|
24
|
+
print.info(`using env:`)
|
|
25
|
+
console.log(`----------${mode}----------`)
|
|
26
|
+
console.log(content);
|
|
27
|
+
console.log(`----------${mode}----------`)
|
|
28
|
+
fs.writeFileSync('./.env.rig', content, {flag: "w"});
|
|
29
|
+
} else {
|
|
30
|
+
print.error("请先在env.rig.json5文件中配置" + mode + "模式的环境变量");
|
|
31
|
+
process.exit(1)
|
|
32
|
+
}
|
|
33
|
+
} catch (e) {
|
|
34
|
+
print.error(e.message);
|
|
35
|
+
process.exit(1)
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//加载命令控制器
|
|
39
|
+
const load = async () => {
|
|
40
|
+
try {
|
|
41
|
+
const mode = process.argv[process.argv.length -1];
|
|
42
|
+
useEnv(mode);
|
|
43
|
+
} catch (e) {
|
|
44
|
+
print.error(e.message);
|
|
45
|
+
process.exit(1)
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export default {
|
|
50
|
+
load,
|
|
51
|
+
useEnv
|
|
52
|
+
}
|
package/lib/preinstall/index.ts
CHANGED
|
@@ -26,10 +26,12 @@ const clone = (target:string, dep:Dep) => {
|
|
|
26
26
|
export default async (cmd:any) => {
|
|
27
27
|
print.info('start rig preinstall');
|
|
28
28
|
try {
|
|
29
|
-
//读取package.rig.json5
|
|
29
|
+
//读取package.rig.json5,生成配置对象
|
|
30
30
|
const rigConfig = RigConfig.createFromCWD();
|
|
31
|
+
//检查配置项格式是否正确
|
|
31
32
|
rigConfig.validate();
|
|
32
|
-
|
|
33
|
+
//检查依赖间的相互依赖是否有效
|
|
34
|
+
//创建rig_dev目录用来开发rig管理下的依赖
|
|
33
35
|
if (!(fs.existsSync('./rig_dev') && fs.lstatSync('./rig_dev').isDirectory())) {
|
|
34
36
|
print.info('create folder rig_dev');
|
|
35
37
|
fs.mkdirSync('rig_dev');
|
|
@@ -65,6 +67,8 @@ export default async (cmd:any) => {
|
|
|
65
67
|
}
|
|
66
68
|
dependencies[dep.name] = `git+ssh://${dep.source}#${dep.version}`
|
|
67
69
|
}
|
|
70
|
+
rigConfig.validateDeps();
|
|
71
|
+
|
|
68
72
|
//覆盖package.json
|
|
69
73
|
pkgJson.dependencies = dependencies;
|
|
70
74
|
fs.writeFileSync('package.json', JSON.stringify(pkgJson, null, 2));
|
package/lib/print/index.ts
CHANGED
package/lib/rig/index.ts
CHANGED
|
@@ -66,9 +66,11 @@ program.command('sync')
|
|
|
66
66
|
.option('-f, --force <force>', 'force to overwrite files from package.rig.json5')
|
|
67
67
|
.action(sync);
|
|
68
68
|
|
|
69
|
-
import env from '../
|
|
69
|
+
import env from '../env';
|
|
70
70
|
|
|
71
71
|
program.option('--vueenv <vueenv>', 'specify vue env').action(env.load);
|
|
72
|
+
program.option('--env <vueenv>', 'specify env').action(env.load);
|
|
73
|
+
|
|
72
74
|
program.version(require('../../package.json').version, '-v,--version');
|
|
73
75
|
program.parse(process.argv);
|
|
74
76
|
|
|
@@ -5,9 +5,9 @@
|
|
|
5
5
|
* @date 2020/10/15 3:28 PM
|
|
6
6
|
*/
|
|
7
7
|
const fs = require('fs');
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
import shell from "shelljs";
|
|
9
|
+
import chalk from "chalk";
|
|
10
|
+
import print from '../print'
|
|
11
11
|
let red = chalk.red;
|
|
12
12
|
|
|
13
13
|
|
|
@@ -33,6 +33,6 @@ const load = async () => {
|
|
|
33
33
|
process.exit(1);
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
-
|
|
37
|
-
load
|
|
38
|
-
}
|
|
36
|
+
export default {
|
|
37
|
+
load,
|
|
38
|
+
}
|
package/lib/utils/fsHelper.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import fs from 'fs';
|
|
2
|
+
import {cat} from "shelljs";
|
|
2
3
|
|
|
3
4
|
const JSON5 = require('json5');
|
|
4
5
|
const readCICDConfig = () => {
|
|
@@ -35,7 +36,11 @@ const writeConfig = (config: any, path: string = '') => {
|
|
|
35
36
|
}
|
|
36
37
|
}
|
|
37
38
|
const readPkgStrInRepo = (rigRepoName: string) => {
|
|
38
|
-
|
|
39
|
+
try{
|
|
40
|
+
return fs.readFileSync(`${process.cwd()}/rig_dev/${rigRepoName}/package.json`).toString();
|
|
41
|
+
}catch (e){
|
|
42
|
+
throw new Error(`${rigRepoName} not exists in rig_dev`);
|
|
43
|
+
}
|
|
39
44
|
}
|
|
40
45
|
|
|
41
46
|
export default {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "rigjs",
|
|
3
|
-
"version": "3.0.
|
|
3
|
+
"version": "3.0.6",
|
|
4
4
|
"description": "A multi-repos dev tool based on yarn and git.Rigjs is intended to be the simplest way to develop,share and deliver codes between different developers or different projects.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"modular",
|
|
@@ -25,7 +25,6 @@
|
|
|
25
25
|
"p": "cd demo && node ../lib/rig/index.js publish",
|
|
26
26
|
"prei": "cd demo && ts-node ../lib/rig/index.ts preinstall",
|
|
27
27
|
"posti": "cd demo && node ../lib/rig/index.js postinstall",
|
|
28
|
-
"preinstall": "cd demo && node ../built/index.js preinstall",
|
|
29
28
|
"c": "d demo && node ../lib/rig/index.js check",
|
|
30
29
|
"envmake": "cd demo && node ../lib/rig/index.js --env prod_view_zhs",
|
|
31
30
|
"t": "node lib/rig/index.js tag",
|
|
@@ -46,6 +45,7 @@
|
|
|
46
45
|
"commander": "6.1.0",
|
|
47
46
|
"compare-versions": "^4.1.3",
|
|
48
47
|
"dayjs": "^1.11.0",
|
|
48
|
+
"dotenv": "^16.0.3",
|
|
49
49
|
"inquirer": "7.3.3",
|
|
50
50
|
"json5": "2.1.3",
|
|
51
51
|
"ora": "^5.1.0",
|
package/lib/tag/index.d.ts
DELETED
package/lib/vue-env/index.d.ts
DELETED
package/lib/vue-env/index.js
DELETED
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @ignore
|
|
3
|
-
* @Description nothing
|
|
4
|
-
* @author Wang Bo (ralwayne@163.com)
|
|
5
|
-
* @date 2021/11/18 6:14 PM
|
|
6
|
-
*/
|
|
7
|
-
const fs = require('fs');
|
|
8
|
-
const json5 = require('json5');
|
|
9
|
-
const print = require("../print");
|
|
10
|
-
|
|
11
|
-
const useEnv = (mode,extra)=>{
|
|
12
|
-
try {
|
|
13
|
-
const rigJson5 = json5.parse(fs.readFileSync('env.rig.json5'));
|
|
14
|
-
let modeObj = rigJson5[mode];
|
|
15
|
-
if (modeObj) {
|
|
16
|
-
if (extra) modeObj = Object.assign(modeObj, extra);
|
|
17
|
-
const keysArray = Object.keys(modeObj);
|
|
18
|
-
let content = "";
|
|
19
|
-
for (let i = 0; i<keysArray.length; i++) {
|
|
20
|
-
const key = keysArray[i];
|
|
21
|
-
const value = modeObj[key];
|
|
22
|
-
content += key + " = " + value + "\n"
|
|
23
|
-
}
|
|
24
|
-
print.info(`using env:`)
|
|
25
|
-
console.log(content);
|
|
26
|
-
fs.writeFileSync('./.env.rig', content, {flag: "w"});
|
|
27
|
-
} else {
|
|
28
|
-
print.error("请先在env.rig.json5文件中配置" + mode + "模式的环境变量");
|
|
29
|
-
process.exit(1)
|
|
30
|
-
}
|
|
31
|
-
} catch (e) {
|
|
32
|
-
print.error(e.message);
|
|
33
|
-
process.exit(1)
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
//加载命令控制器
|
|
37
|
-
const load = async (cmd) => {
|
|
38
|
-
try {
|
|
39
|
-
const mode = process.argv[process.argv.length -1];
|
|
40
|
-
useEnv(mode);
|
|
41
|
-
} catch (e) {
|
|
42
|
-
print.error(e.message);
|
|
43
|
-
process.exit(1)
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
module.exports = {
|
|
48
|
-
load,
|
|
49
|
-
useEnv
|
|
50
|
-
}
|