cloudcc-cli 1.3.2 → 1.3.3

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,180 +1,180 @@
1
- const { execSync, exec } = require('child_process');
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, askBuildType } = 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
- * H5项目打包发布脚本
23
- */
24
- class Publish {
25
- constructor() {
26
- /**
27
- * 控制台参数:key=value
28
- * type:发布的tag
29
- * branch:使用的分支
30
- * language:是否更新多语言,'1'更新,'0'不更新
31
- * buildType:打包方式,online-云打包,local-本地打包
32
- * user:打包用户
33
- * update:代码不同步的时候,是否强制更新代码
34
- */
35
- this.args = new Map();
36
- this.arguments = process.argv.splice(2).map((item) => {
37
- let arr = item.split("=");
38
- this.args.set(arr[0], arr[1]);
39
- });
40
- this.user = this.args.get("user") || execSync("git config user.name").toString("utf8").trim();
41
- }
42
- /**
43
- * 初始化
44
- */
45
- async init() {
46
- // 检查cli版本,提示用户更新:false:不更新,true:更新
47
- let update = await checkUpdate();
48
- if (!update) {
49
- // 1:版本发布信息,包含发布版本类型信息
50
- let condition = {};
51
- // 2:检查命令行是否输入了发布版本信息,如果没有包含,那么询问发布类型
52
- if (this.args.get("type")) {
53
- condition.type = this.args.get("type")
54
- } else {
55
- // 询问发布类型
56
- condition = await askType();
57
- if ("other" == condition.type) {
58
- condition = await askTypeOther();
59
- }
60
- }
61
- // 3:获取新的发布版本号
62
- let version = getNewVersionName([condition.type])
63
- console.log();
64
- console.log(chalk.green('待发布版本:' + version));
65
- console.log();
66
- // 4:开始打包
67
- this.build(condition, version)
68
- }
69
- }
70
- /**
71
- * 编译成功
72
- */
73
- buildSucess(condition, version) {
74
- // 5:将readme生成为html,并复制到dist中
75
- let outPath = "dist"
76
- // 读取配置,是否改变了输出路径
77
- if (projectConfig.config && projectConfig.config["doc-path"]) {
78
- outPath = projectConfig.config["doc-path"];
79
- }
80
- try {
81
- // 设置readme文件位置
82
- change("README", outPath);
83
- } catch (error) {
84
- console.log(chalk.red("README写入异常:" + error))
85
- }
86
-
87
- try {
88
- // 6:写入版本信息
89
- this.writeVersion(version, outPath);
90
- } catch (error) {
91
- console.log(chalk.red("版本信息写入异常:" + error))
92
- }
93
-
94
- // 7:发布代码并设置tags,触发发布,飞书提醒
95
- if (pushCodeAndTags([condition.type], this.args.get("update"))) {
96
- if (projectConfig && projectConfig.config) {
97
- jenkins(projectConfig.config["jenkins-" + condition.type])
98
- }
99
- notifyDingDing(condition.type, version, projectConfig, this.user)
100
- console.log();
101
- console.log(chalk.green('发布完成'));
102
- console.log();
103
- }
104
- }
105
- /**
106
- * 编译代码
107
- * @param {发布类型} types:Dev,uat,Release,GA,RC
108
- * @param {发布版本} versions:V12.0.0
109
- * @returns
110
- */
111
- build(condition, version) {
112
- console.log(chalk.green('开始编译,请稍后...'));
113
- console.log();
114
- let that = this;
115
- exec('cli.exe publish --platform h5 --project ' + projectConfig.name, (error, stdout, stderr) => {
116
- if (error) {
117
- console.log('编译失败:', error);
118
- console.log(chalk.red('编译失败:' + stdout));
119
- } else {
120
- console.log(chalk.green('编译成功!'));
121
- console.log();
122
- that.buildSucess(condition, version);
123
- }
124
- })
125
- }
126
- /**
127
- * 将版本信息写入文件
128
- * @param {版本信息} version
129
- * @param {输出路径} outPath
130
- */
131
- writeVersion(version, outPath = "dist") {
132
- try {
133
- // 获得分支信息
134
- let branch = execSync('git rev-parse --abbrev-ref HEAD');
135
- branch = branch.toString("utf8").trim();
136
- // 获得提交版本信息
137
- var gitHEAD = fs.readFileSync('.git/HEAD', 'utf-8').trim()
138
- var ref = gitHEAD.split(': ')[1]
139
- var develop = gitHEAD.split('/')[2]
140
- var gitVersion = fs.readFileSync('.git/' + ref, 'utf-8').trim()
141
- var gitCommitVersion = '"' + develop + ': ' + gitVersion + '"'
142
-
143
- let versionInfo =
144
- `
145
- <!DOCTYPE html>
146
- <html lang="en">
147
-
148
- <head>
149
- <meta charset="UTF-8">
150
- <meta http-equiv="X-UA-Compatible" content="IE=edge">
151
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
152
- <title>版本信息</title>
153
- </head>
154
-
155
- <body>
156
- <div style="font-size: 20px">
157
- <div>${projectConfig.name}</div>
158
- <div style="margin-left:48px">
159
- <div>分支:${branch}</div>
160
- <div>版本号:${version}</div>
161
- <div>提交Hash:${gitCommitVersion}</div>
162
- <div>发布时间:${dayjs().format('YYYY-MM-DD HH:mm:ss')}</div>
163
- <div>发布人员:${this.user}</div>
164
- </div>
165
- </div>
166
- </body>
167
-
168
- </html>
169
- `
170
- fs.writeFileSync(outPath + "/version.html", versionInfo, 'utf-8');
171
- return true
172
- } catch (error) {
173
- return false
174
- }
175
- };
176
- }
177
-
178
- module.exports = Publish;
179
-
180
-
1
+ const { execSync, exec } = require('child_process');
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, askBuildType } = 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
+ * H5项目打包发布脚本
23
+ */
24
+ class Publish {
25
+ constructor() {
26
+ /**
27
+ * 控制台参数:key=value
28
+ * type:发布的tag
29
+ * branch:使用的分支
30
+ * language:是否更新多语言,'1'更新,'0'不更新
31
+ * buildType:打包方式,online-云打包,local-本地打包
32
+ * user:打包用户
33
+ * update:代码不同步的时候,是否强制更新代码
34
+ */
35
+ this.args = new Map();
36
+ this.arguments = process.argv.splice(2).map((item) => {
37
+ let arr = item.split("=");
38
+ this.args.set(arr[0], arr[1]);
39
+ });
40
+ this.user = this.args.get("user") || execSync("git config user.name").toString("utf8").trim();
41
+ }
42
+ /**
43
+ * 初始化
44
+ */
45
+ async init() {
46
+ // 检查cli版本,提示用户更新:false:不更新,true:更新
47
+ let update = await checkUpdate();
48
+ if (!update) {
49
+ // 1:版本发布信息,包含发布版本类型信息
50
+ let condition = {};
51
+ // 2:检查命令行是否输入了发布版本信息,如果没有包含,那么询问发布类型
52
+ if (this.args.get("type")) {
53
+ condition.type = this.args.get("type")
54
+ } else {
55
+ // 询问发布类型
56
+ condition = await askType();
57
+ if ("other" == condition.type) {
58
+ condition = await askTypeOther();
59
+ }
60
+ }
61
+ // 3:获取新的发布版本号
62
+ let version = getNewVersionName([condition.type])
63
+ console.log();
64
+ console.log(chalk.green('待发布版本:' + version));
65
+ console.log();
66
+ // 4:开始打包
67
+ this.build(condition, version)
68
+ }
69
+ }
70
+ /**
71
+ * 编译成功
72
+ */
73
+ buildSucess(condition, version) {
74
+ // 5:将readme生成为html,并复制到dist中
75
+ let outPath = "dist"
76
+ // 读取配置,是否改变了输出路径
77
+ if (projectConfig.config && projectConfig.config["doc-path"]) {
78
+ outPath = projectConfig.config["doc-path"];
79
+ }
80
+ try {
81
+ // 设置readme文件位置
82
+ change("README", outPath);
83
+ } catch (error) {
84
+ console.log(chalk.red("README写入异常:" + error))
85
+ }
86
+
87
+ try {
88
+ // 6:写入版本信息
89
+ this.writeVersion(version, outPath);
90
+ } catch (error) {
91
+ console.log(chalk.red("版本信息写入异常:" + error))
92
+ }
93
+
94
+ // 7:发布代码并设置tags,触发发布,飞书提醒
95
+ if (pushCodeAndTags([condition.type], this.args.get("update"))) {
96
+ if (projectConfig && projectConfig.config) {
97
+ jenkins(projectConfig.config["jenkins-" + condition.type])
98
+ }
99
+ notifyDingDing(condition.type, version, projectConfig, this.user)
100
+ console.log();
101
+ console.log(chalk.green('发布完成'));
102
+ console.log();
103
+ }
104
+ }
105
+ /**
106
+ * 编译代码
107
+ * @param {发布类型} types:Dev,uat,Release,GA,RC
108
+ * @param {发布版本} versions:V12.0.0
109
+ * @returns
110
+ */
111
+ build(condition, version) {
112
+ console.log(chalk.green('开始编译,请稍后...'));
113
+ console.log();
114
+ let that = this;
115
+ exec('cli.exe publish --platform h5 --project ' + projectConfig.name, (error, stdout, stderr) => {
116
+ if (error) {
117
+ console.log('编译失败:', error);
118
+ console.log(chalk.red('编译失败:' + stdout));
119
+ } else {
120
+ console.log(chalk.green('编译成功!'));
121
+ console.log();
122
+ that.buildSucess(condition, version);
123
+ }
124
+ })
125
+ }
126
+ /**
127
+ * 将版本信息写入文件
128
+ * @param {版本信息} version
129
+ * @param {输出路径} outPath
130
+ */
131
+ writeVersion(version, outPath = "dist") {
132
+ try {
133
+ // 获得分支信息
134
+ let branch = execSync('git rev-parse --abbrev-ref HEAD');
135
+ branch = branch.toString("utf8").trim();
136
+ // 获得提交版本信息
137
+ var gitHEAD = fs.readFileSync('.git/HEAD', 'utf-8').trim()
138
+ var ref = gitHEAD.split(': ')[1]
139
+ var develop = gitHEAD.split('/')[2]
140
+ var gitVersion = fs.readFileSync('.git/' + ref, 'utf-8').trim()
141
+ var gitCommitVersion = '"' + develop + ': ' + gitVersion + '"'
142
+
143
+ let versionInfo =
144
+ `
145
+ <!DOCTYPE html>
146
+ <html lang="en">
147
+
148
+ <head>
149
+ <meta charset="UTF-8">
150
+ <meta http-equiv="X-UA-Compatible" content="IE=edge">
151
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
152
+ <title>版本信息</title>
153
+ </head>
154
+
155
+ <body>
156
+ <div style="font-size: 20px">
157
+ <div>${projectConfig.name}</div>
158
+ <div style="margin-left:48px">
159
+ <div>分支:${branch}</div>
160
+ <div>版本号:${version}</div>
161
+ <div>提交Hash:${gitCommitVersion}</div>
162
+ <div>发布时间:${dayjs().format('YYYY-MM-DD HH:mm:ss')}</div>
163
+ <div>发布人员:${this.user}</div>
164
+ </div>
165
+ </div>
166
+ </body>
167
+
168
+ </html>
169
+ `
170
+ fs.writeFileSync(outPath + "/version.html", versionInfo, 'utf-8');
171
+ return true
172
+ } catch (error) {
173
+ return false
174
+ }
175
+ };
176
+ }
177
+
178
+ module.exports = Publish;
179
+
180
+
@@ -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,107 +1,107 @@
1
- import axios from 'axios'
2
- const service = axios.create({
3
- timeout: 60000, // request timeout
4
- headers: {
5
- 'Content-Type': 'application/json; charset=utf-8',
6
- },
7
- })
8
-
9
- // request interceptor
10
- service.interceptors.request.use(
11
- config => {
12
- config.headers.accessToken = window.$CCDK.CCToken.getToken()
13
- return config
14
- },
15
- error => {
16
- // Do something with request error
17
- Promise.reject(error)
18
- }
19
- )
20
-
21
- // response interceptor
22
- service.interceptors.response.use(
23
- response => {
24
- const code = response.data.code || 200
25
- if (code !== 200) {
26
- return Promise.reject(null == response.data.msg ? "未知异常" : response.data.msg)
27
- } else {
28
- return response.data
29
- }
30
- },
31
- error => {
32
- return Promise.reject(error)
33
- }
34
- )
35
- const formateData = data => {
36
- return {
37
- head: {
38
- appType: 'cloudcc-plugin',
39
- appVersion: '1.0.0',
40
- accessToken: window.$CCDK.CCToken.getToken()
41
- },
42
- body: {
43
- ...data
44
- }
45
- }
46
- }
47
- export default {
48
- get: (url, data = {}, responseType = '') => {
49
- return service({
50
- url: url,
51
- method: 'get',
52
- params: data,
53
- responseType: responseType
54
- })
55
- },
56
- getLight: (url, data = {}, responseType = '') => {
57
- return service({
58
- url: url,
59
- method: 'get',
60
- params: data,
61
- responseType: responseType
62
- })
63
- },
64
- postLight: (url, data = {}) => {
65
- return service({
66
- url: url,
67
- method: 'post',
68
- data: { ...data },
69
- })
70
- },
71
- post: (url, data = {}, responseType = '') => {
72
- return service({
73
- url: url,
74
- method: 'post',
75
- data: formateData(data),
76
- responseType: responseType
77
- })
78
- },
79
- postParams: (url, data = {}) => {
80
- return service({
81
- url: url,
82
- method: 'post',
83
- params: data
84
- })
85
- },
86
- patch: (url, data = {}) => {
87
- return service({
88
- url: url,
89
- method: 'patch',
90
- data: formateData(data)
91
- })
92
- },
93
- delete: (url, data = {}) => {
94
- return service({
95
- url: url,
96
- method: 'delete',
97
- data: formateData(data)
98
- })
99
- },
100
- put: (url, data = {}) => {
101
- return service({
102
- url: url,
103
- method: 'put',
104
- data: formateData(data)
105
- })
106
- }
107
- }
1
+ import axios from 'axios'
2
+ const service = axios.create({
3
+ timeout: 60000, // request timeout
4
+ headers: {
5
+ 'Content-Type': 'application/json; charset=utf-8',
6
+ },
7
+ })
8
+
9
+ // request interceptor
10
+ service.interceptors.request.use(
11
+ config => {
12
+ config.headers.accessToken = window.$CCDK.CCToken.getToken()
13
+ return config
14
+ },
15
+ error => {
16
+ // Do something with request error
17
+ Promise.reject(error)
18
+ }
19
+ )
20
+
21
+ // response interceptor
22
+ service.interceptors.response.use(
23
+ response => {
24
+ const code = response.data.code || 200
25
+ if (code !== 200) {
26
+ return Promise.reject(null == response.data.msg ? "未知异常" : response.data.msg)
27
+ } else {
28
+ return response.data
29
+ }
30
+ },
31
+ error => {
32
+ return Promise.reject(error)
33
+ }
34
+ )
35
+ const formateData = data => {
36
+ return {
37
+ head: {
38
+ appType: 'cloudcc-plugin',
39
+ appVersion: '1.0.0',
40
+ accessToken: window.$CCDK.CCToken.getToken()
41
+ },
42
+ body: {
43
+ ...data
44
+ }
45
+ }
46
+ }
47
+ export default {
48
+ get: (url, data = {}, responseType = '') => {
49
+ return service({
50
+ url: url,
51
+ method: 'get',
52
+ params: data,
53
+ responseType: responseType
54
+ })
55
+ },
56
+ getLight: (url, data = {}, responseType = '') => {
57
+ return service({
58
+ url: url,
59
+ method: 'get',
60
+ params: data,
61
+ responseType: responseType
62
+ })
63
+ },
64
+ postLight: (url, data = {}) => {
65
+ return service({
66
+ url: url,
67
+ method: 'post',
68
+ data: { ...data },
69
+ })
70
+ },
71
+ post: (url, data = {}, responseType = '') => {
72
+ return service({
73
+ url: url,
74
+ method: 'post',
75
+ data: formateData(data),
76
+ responseType: responseType
77
+ })
78
+ },
79
+ postParams: (url, data = {}) => {
80
+ return service({
81
+ url: url,
82
+ method: 'post',
83
+ params: data
84
+ })
85
+ },
86
+ patch: (url, data = {}) => {
87
+ return service({
88
+ url: url,
89
+ method: 'patch',
90
+ data: formateData(data)
91
+ })
92
+ },
93
+ delete: (url, data = {}) => {
94
+ return service({
95
+ url: url,
96
+ method: 'delete',
97
+ data: formateData(data)
98
+ })
99
+ },
100
+ put: (url, data = {}) => {
101
+ return service({
102
+ url: url,
103
+ method: 'put',
104
+ data: formateData(data)
105
+ })
106
+ }
107
+ }