cloudcc-cli 1.0.9 → 1.1.2

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.
@@ -1,205 +1,206 @@
1
- const exec = require('child_process').execSync;
2
- const chalk = require("chalk")
3
- // 文件编辑对象
4
- const fs = require("fs")
5
- // 配置信息
6
- const projectConfig = JSON.parse(fs.readFileSync('package.json', 'utf8'))
7
- // 网页转换器
8
- const { change } = require("../utils/md2html")
9
- // 检查版本更新
10
- const { checkUpdate } = require("../utils/checkVersion")
11
- // 控制台交互
12
- const { askType, askTypeOther } = require("../utils/askTool")
13
- // 提交代码,设置Tag
14
- const { getNewVersionName, pushCodeAndTags } = require("../utils/pushCode")
15
- // 触发构建器
16
- const { jenkins } = require("../utils/trigger")
17
- // 通知飞书
18
- const { notifyFeishu } = require("../utils/notifyIM")
19
- // 时间库
20
- const dayjs = require("dayjs")
21
- // 多语言更新脚本
22
- const { updatei18n, askI18n } = require("../utils/updatei18n")
23
- /**
24
- * 项目打包发布脚本
25
- */
26
- class Publish {
27
- constructor() {
28
- /**
29
- * 控制台参数
30
- * type:发布类型
31
- * branch:使用的分支
32
- */
33
- this.args = new Map();
34
- this.arguments = process.argv.splice(2).map((item) => {
35
- let arr = item.split("=");
36
- this.args.set(arr[0].split("-")[1], arr[1]);
37
- });
38
- }
39
- /**
40
- * 初始化
41
- */
42
- async init() {
43
- // 检查cli版本,提示用户更新:false:不更新,true:更新
44
- let update = await checkUpdate();
45
- if (!update) {
46
- // 1:版本发布信息,包含发布版本类型信息
47
- let condition = {};
48
- // 检查命令行是否输入了发布版本信息,如果没有包含,那么询问发布类型
49
- if (this.args.get("type")) {
50
- condition.type = this.args.get("type")
51
- } else {
52
- // 询问发布类型
53
- condition = await askType();
54
- if ("other" == condition.type) {
55
- condition = await askTypeOther();
56
- }
57
- }
58
-
59
- // 2:如果命令行包含了分支信息,那么git切换到命令行的分支
60
- if (this.args.get("branch")) {
61
- exec(`git checkout ${this.args.get("branch")}`);
62
- console.log(chalk.green("切换分支:" + this.args.get("branch")))
63
- console.log()
64
- }
65
-
66
- // 3:获取新的发布版本号
67
- let version = getNewVersionName([condition.type])
68
- console.log();
69
- console.log(chalk.green('待发布版本:' + version));
70
- console.log();
71
-
72
- // 4:如果存在多语言配置,则更新多语言
73
- if (projectConfig.config && projectConfig.config["language-config"]) {
74
- // 询问是否更新多语言
75
- let i18n = await askI18n()
76
- if (i18n.checked === '1') {
77
- let laguage = projectConfig.config["language-config"]
78
- // 执行更新多语言文件
79
- await updatei18n(laguage)
80
- console.log(chalk.blue("多语言文件更新完毕,准备开始打包"));
81
- console.log();
82
- }
83
- }
84
-
85
- // 5:开始打包
86
- if (await this.build()) {
87
- // 6:将readme生成为html,并复制到dist中
88
- let outPath = "dist"
89
- // 读取配置,是否改变了输出路径
90
- if (projectConfig.config && projectConfig.config["doc-path"]) {
91
- outPath = projectConfig.config["doc-path"];
92
- }
93
- // lightning的Release禁止生成Readme文档
94
- if (!(Object.is("CloudCC", projectConfig.name) && Object.is("Release", condition.type))) {
95
- try {
96
- // 设置readme文件位置
97
- change("README", outPath);
98
- } catch (error) {
99
- console.log(chalk.red("README写入异常:" + error))
100
- }
101
- }
102
-
103
- try {
104
- // 7:写入版本信息
105
- this.writeVersion(version);
106
- } catch (error) {
107
- console.log(chalk.red("版本信息写入异常:" + error))
108
- }
109
-
110
- // 8:发布代码并设置tags,触发发布,飞书提醒
111
- if (pushCodeAndTags([condition.type])) {
112
- if (projectConfig && projectConfig.config) {
113
- jenkins(projectConfig.config["jenkins-" + condition.type])
114
- }
115
- notifyFeishu(condition.type, version, projectConfig)
116
- console.log();
117
- console.log(chalk.green('发布完成'));
118
- console.log();
119
- }
120
- }
121
-
122
- }
123
- }
124
- /**
125
- * 编译代码
126
- * @param {发布类型} types:Dev,uat,Release,GA,RC
127
- * @param {发布版本} versions:Dev-V12.0.0
128
- * @returns
129
- */
130
- async build() {
131
- console.log(chalk.green('开始编译,请稍后...'));
132
- console.log();
133
- // 打包命令
134
- try {
135
- exec('npm run build');
136
- console.log(chalk.green('编译成功!'));
137
- console.log();
138
- return true;
139
- } catch (error) {
140
- try {
141
- exec('npx vue-cli-service build');
142
- console.log(chalk.green('编译成功!'));
143
- console.log();
144
- return true;
145
- } catch (error) {
146
- console.log(chalk.red('编译失败!' + error));
147
- return false
148
- }
149
- }
150
-
151
- }
152
- /**
153
- * 将版本信息写入文件
154
- * @param {版本信息} version
155
- */
156
- writeVersion(version) {
157
- try {
158
- // 获得分支信息
159
- let branch = exec('git rev-parse --abbrev-ref HEAD');
160
- branch = branch.toString("utf8").trim();
161
- // 获得提交版本信息
162
- var gitHEAD = fs.readFileSync('.git/HEAD', 'utf-8').trim()
163
- var ref = gitHEAD.split(': ')[1]
164
- var develop = gitHEAD.split('/')[2]
165
- var gitVersion = fs.readFileSync('.git/' + ref, 'utf-8').trim()
166
- var gitCommitVersion = '"' + develop + ': ' + gitVersion + '"'
167
-
168
- let versionInfo =
169
- `
170
- <!DOCTYPE html>
171
- <html lang="en">
172
-
173
- <head>
174
- <meta charset="UTF-8">
175
- <meta http-equiv="X-UA-Compatible" content="IE=edge">
176
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
177
- <title>版本信息</title>
178
- </head>
179
-
180
- <body>
181
- <div style="font-size: 20px">
182
- <div>Lightning-Web:</div>
183
- <div style="margin-left:48px">
184
- <div>分支:${branch}</div>
185
- <div>版本号:${version}</div>
186
- <div>提交Hash:${gitCommitVersion}</div>
187
- <div>发布时间:${dayjs().format('YYYY-MM-DD HH:mm:ss')}</div>
188
- <div>发布人员:${exec("git config user.name").toString("utf8").trim()}</div>
189
- </div>
190
- </div>
191
- </body>
192
-
193
- </html>
194
- `
195
- fs.writeFileSync("dist/version.html", versionInfo, 'utf-8');
196
- return true
197
- } catch (error) {
198
- return false
199
- }
200
- };
201
- }
202
-
203
- module.exports = Publish;
204
-
205
-
1
+ const exec = require('child_process').execSync;
2
+ const chalk = require("chalk")
3
+ // 文件编辑对象
4
+ const fs = require("fs")
5
+ // 配置信息
6
+ const projectConfig = JSON.parse(fs.readFileSync('package.json', 'utf8'))
7
+ // 网页转换器
8
+ const { change } = require("../utils/md2html")
9
+ // 检查版本更新
10
+ const { checkUpdate } = require("../utils/checkVersion")
11
+ // 控制台交互
12
+ const { askType, askTypeOther } = require("../utils/askTool")
13
+ // 提交代码,设置Tag
14
+ const { getNewVersionName, pushCodeAndTags } = require("../utils/pushCode")
15
+ // 触发构建器
16
+ const { jenkins } = require("../utils/trigger")
17
+ // 通知飞书
18
+ const { notifyFeishu, notifyDingDing } = require("../utils/notifyIM")
19
+ // 时间库
20
+ const dayjs = require("dayjs")
21
+ // 多语言更新脚本
22
+ const { updatei18n, askI18n } = require("../utils/updatei18n")
23
+ /**
24
+ * 项目打包发布脚本
25
+ */
26
+ class Publish {
27
+ constructor() {
28
+ /**
29
+ * 控制台参数
30
+ * type:发布类型
31
+ * branch:使用的分支
32
+ */
33
+ this.args = new Map();
34
+ this.arguments = process.argv.splice(2).map((item) => {
35
+ let arr = item.split("=");
36
+ this.args.set(arr[0].split("-")[1], arr[1]);
37
+ });
38
+ }
39
+ /**
40
+ * 初始化
41
+ */
42
+ async init() {
43
+ // 检查cli版本,提示用户更新:false:不更新,true:更新
44
+ let update = await checkUpdate();
45
+ if (!update) {
46
+ // 1:版本发布信息,包含发布版本类型信息
47
+ let condition = {};
48
+ // 检查命令行是否输入了发布版本信息,如果没有包含,那么询问发布类型
49
+ if (this.args.get("type")) {
50
+ condition.type = this.args.get("type")
51
+ } else {
52
+ // 询问发布类型
53
+ condition = await askType();
54
+ if ("other" == condition.type) {
55
+ condition = await askTypeOther();
56
+ }
57
+ }
58
+
59
+ // 2:如果命令行包含了分支信息,那么git切换到命令行的分支
60
+ if (this.args.get("branch")) {
61
+ exec(`git checkout ${this.args.get("branch")}`);
62
+ console.log(chalk.green("切换分支:" + this.args.get("branch")))
63
+ console.log()
64
+ }
65
+
66
+ // 3:获取新的发布版本号
67
+ let version = getNewVersionName([condition.type])
68
+ console.log();
69
+ console.log(chalk.green('待发布版本:' + version));
70
+ console.log();
71
+
72
+ // 4:如果存在多语言配置,则更新多语言
73
+ if (projectConfig.config && projectConfig.config["language-config"]) {
74
+ // 询问是否更新多语言
75
+ let i18n = await askI18n()
76
+ if (i18n.checked === '1') {
77
+ let laguage = projectConfig.config["language-config"]
78
+ // 执行更新多语言文件
79
+ await updatei18n(laguage)
80
+ console.log(chalk.blue("多语言文件更新完毕,准备开始打包"));
81
+ console.log();
82
+ }
83
+ }
84
+
85
+ // 5:开始打包
86
+ if (await this.build()) {
87
+ // 6:将readme生成为html,并复制到dist中
88
+ let outPath = "dist"
89
+ // 读取配置,是否改变了输出路径
90
+ if (projectConfig.config && projectConfig.config["doc-path"]) {
91
+ outPath = projectConfig.config["doc-path"];
92
+ }
93
+ // lightning的Release禁止生成Readme文档
94
+ // if (!(Object.is("CloudCC", projectConfig.name) && Object.is("Release", condition.type))) {
95
+ try {
96
+ // 设置readme文件位置
97
+ change("README", outPath);
98
+ } catch (error) {
99
+ console.log(chalk.red("README写入异常:" + error))
100
+ }
101
+ // }
102
+
103
+ try {
104
+ // 7:写入版本信息
105
+ this.writeVersion(version);
106
+ } catch (error) {
107
+ console.log(chalk.red("版本信息写入异常:" + error))
108
+ }
109
+
110
+ // 8:发布代码并设置tags,触发发布,飞书提醒
111
+ if (pushCodeAndTags([condition.type])) {
112
+ if (projectConfig && projectConfig.config) {
113
+ jenkins(projectConfig.config["jenkins-" + condition.type])
114
+ }
115
+ notifyFeishu(condition.type, version, projectConfig)
116
+ notifyDingDing(condition.type, version, projectConfig)
117
+ console.log();
118
+ console.log(chalk.green('发布完成'));
119
+ console.log();
120
+ }
121
+ }
122
+
123
+ }
124
+ }
125
+ /**
126
+ * 编译代码
127
+ * @param {发布类型} types:Dev,uat,Release,GA,RC
128
+ * @param {发布版本} versions:Dev-V12.0.0
129
+ * @returns
130
+ */
131
+ async build() {
132
+ console.log(chalk.green('开始编译,请稍后...'));
133
+ console.log();
134
+ // 打包命令
135
+ try {
136
+ exec('npm run build');
137
+ console.log(chalk.green('编译成功!'));
138
+ console.log();
139
+ return true;
140
+ } catch (error) {
141
+ try {
142
+ exec('npx vue-cli-service build');
143
+ console.log(chalk.green('编译成功!'));
144
+ console.log();
145
+ return true;
146
+ } catch (error) {
147
+ console.log(chalk.red('编译失败!' + error));
148
+ return false
149
+ }
150
+ }
151
+
152
+ }
153
+ /**
154
+ * 将版本信息写入文件
155
+ * @param {版本信息} version
156
+ */
157
+ writeVersion(version) {
158
+ try {
159
+ // 获得分支信息
160
+ let branch = exec('git rev-parse --abbrev-ref HEAD');
161
+ branch = branch.toString("utf8").trim();
162
+ // 获得提交版本信息
163
+ var gitHEAD = fs.readFileSync('.git/HEAD', 'utf-8').trim()
164
+ var ref = gitHEAD.split(': ')[1]
165
+ var develop = gitHEAD.split('/')[2]
166
+ var gitVersion = fs.readFileSync('.git/' + ref, 'utf-8').trim()
167
+ var gitCommitVersion = '"' + develop + ': ' + gitVersion + '"'
168
+
169
+ let versionInfo =
170
+ `
171
+ <!DOCTYPE html>
172
+ <html lang="en">
173
+
174
+ <head>
175
+ <meta charset="UTF-8">
176
+ <meta http-equiv="X-UA-Compatible" content="IE=edge">
177
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
178
+ <title>版本信息</title>
179
+ </head>
180
+
181
+ <body>
182
+ <div style="font-size: 20px">
183
+ <div>Lightning-Web:</div>
184
+ <div style="margin-left:48px">
185
+ <div>分支:${branch}</div>
186
+ <div>版本号:${version}</div>
187
+ <div>提交Hash:${gitCommitVersion}</div>
188
+ <div>发布时间:${dayjs().format('YYYY-MM-DD HH:mm:ss')}</div>
189
+ <div>发布人员:${exec("git config user.name").toString("utf8").trim()}</div>
190
+ </div>
191
+ </div>
192
+ </body>
193
+
194
+ </html>
195
+ `
196
+ fs.writeFileSync("dist/version.html", versionInfo, 'utf-8');
197
+ return true
198
+ } catch (error) {
199
+ return false
200
+ }
201
+ };
202
+ }
203
+
204
+ module.exports = Publish;
205
+
206
+
@@ -1,4 +1,4 @@
1
- // 主要用于 Vue 的 diff 算法,为每个元素创建一个独一无二的 ID
2
- export default function generateID(randomLength = 16) {
3
- return Number(Math.random().toString().substr(2, randomLength)).toString(36)
4
- }
1
+ // 主要用于 Vue 的 diff 算法,为每个元素创建一个独一无二的 ID
2
+ export default function generateID(randomLength = 16) {
3
+ return Number(Math.random().toString().substr(2, randomLength)).toString(36)
4
+ }
package/template/httpjs CHANGED
@@ -1,109 +1,109 @@
1
- import VueCookies from "vue-cookies";
2
- import axios from 'axios'
3
- import packageJson from '../package.json'
4
- const service = axios.create({
5
- timeout: 60000, // request timeout
6
- headers: {
7
- 'Content-Type': 'application/json; charset=utf-8',
8
- },
9
- })
10
-
11
- // request interceptor
12
- service.interceptors.request.use(
13
- config => {
14
- config.headers.accessToken = VueCookies.get("JSESSIONID")
15
- return config
16
- },
17
- error => {
18
- // Do something with request error
19
- Promise.reject(error)
20
- }
21
- )
22
-
23
- // response interceptor
24
- service.interceptors.response.use(
25
- response => {
26
- const code = response.data.code || 200
27
- if (code !== 200) {
28
- return Promise.reject(null == response.data.msg ? "未知异常" : response.data.msg)
29
- } else {
30
- return response.data
31
- }
32
- },
33
- error => {
34
- return Promise.reject(error)
35
- }
36
- )
37
- const formateData = data => {
38
- return {
39
- head: {
40
- appType: packageJson.name,
41
- appVersion: packageJson.version,
42
- accessToken: VueCookies.get("JSESSIONID")
43
- },
44
- body: {
45
- ...data
46
- }
47
- }
48
- }
49
- export default {
50
- get: (url, data = {}, responseType = '') => {
51
- return service({
52
- url: url,
53
- method: 'get',
54
- params: data,
55
- responseType: responseType
56
- })
57
- },
58
- getLight: (url, data = {}, responseType = '') => {
59
- return service({
60
- url: url,
61
- method: 'get',
62
- params: data,
63
- responseType: responseType
64
- })
65
- },
66
- postLight: (url, data = {}) => {
67
- return service({
68
- url: url,
69
- method: 'post',
70
- data: { ...data },
71
- })
72
- },
73
- post: (url, data = {}, responseType = '') => {
74
- return service({
75
- url: url,
76
- method: 'post',
77
- data: formateData(data),
78
- responseType: responseType
79
- })
80
- },
81
- postParams: (url, data = {}) => {
82
- return service({
83
- url: url,
84
- method: 'post',
85
- params: data
86
- })
87
- },
88
- patch: (url, data = {}) => {
89
- return service({
90
- url: url,
91
- method: 'patch',
92
- data: formateData(data)
93
- })
94
- },
95
- delete: (url, data = {}) => {
96
- return service({
97
- url: url,
98
- method: 'delete',
99
- data: formateData(data)
100
- })
101
- },
102
- put: (url, data = {}) => {
103
- return service({
104
- url: url,
105
- method: 'put',
106
- data: formateData(data)
107
- })
108
- }
109
- }
1
+ import VueCookies from "vue-cookies";
2
+ import axios from 'axios'
3
+ import packageJson from '../package.json'
4
+ const service = axios.create({
5
+ timeout: 60000, // request timeout
6
+ headers: {
7
+ 'Content-Type': 'application/json; charset=utf-8',
8
+ },
9
+ })
10
+
11
+ // request interceptor
12
+ service.interceptors.request.use(
13
+ config => {
14
+ config.headers.accessToken = VueCookies.get("JSESSIONID")
15
+ return config
16
+ },
17
+ error => {
18
+ // Do something with request error
19
+ Promise.reject(error)
20
+ }
21
+ )
22
+
23
+ // response interceptor
24
+ service.interceptors.response.use(
25
+ response => {
26
+ const code = response.data.code || 200
27
+ if (code !== 200) {
28
+ return Promise.reject(null == response.data.msg ? "未知异常" : response.data.msg)
29
+ } else {
30
+ return response.data
31
+ }
32
+ },
33
+ error => {
34
+ return Promise.reject(error)
35
+ }
36
+ )
37
+ const formateData = data => {
38
+ return {
39
+ head: {
40
+ appType: packageJson.name,
41
+ appVersion: packageJson.version,
42
+ accessToken: VueCookies.get("JSESSIONID")
43
+ },
44
+ body: {
45
+ ...data
46
+ }
47
+ }
48
+ }
49
+ export default {
50
+ get: (url, data = {}, responseType = '') => {
51
+ return service({
52
+ url: url,
53
+ method: 'get',
54
+ params: data,
55
+ responseType: responseType
56
+ })
57
+ },
58
+ getLight: (url, data = {}, responseType = '') => {
59
+ return service({
60
+ url: url,
61
+ method: 'get',
62
+ params: data,
63
+ responseType: responseType
64
+ })
65
+ },
66
+ postLight: (url, data = {}) => {
67
+ return service({
68
+ url: url,
69
+ method: 'post',
70
+ data: { ...data },
71
+ })
72
+ },
73
+ post: (url, data = {}, responseType = '') => {
74
+ return service({
75
+ url: url,
76
+ method: 'post',
77
+ data: formateData(data),
78
+ responseType: responseType
79
+ })
80
+ },
81
+ postParams: (url, data = {}) => {
82
+ return service({
83
+ url: url,
84
+ method: 'post',
85
+ params: data
86
+ })
87
+ },
88
+ patch: (url, data = {}) => {
89
+ return service({
90
+ url: url,
91
+ method: 'patch',
92
+ data: formateData(data)
93
+ })
94
+ },
95
+ delete: (url, data = {}) => {
96
+ return service({
97
+ url: url,
98
+ method: 'delete',
99
+ data: formateData(data)
100
+ })
101
+ },
102
+ put: (url, data = {}) => {
103
+ return service({
104
+ url: url,
105
+ method: 'put',
106
+ data: formateData(data)
107
+ })
108
+ }
109
+ }