@cloudbase/cli 2.2.9 → 2.2.11-alpha.0
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/.history/.gitignore_20220624162613 +84 -0
- package/.history/.gitignore_20220627114054 +86 -0
- package/.history/package_20230331190630.json +89 -0
- package/.history/package_20230331190744.json +89 -0
- package/.history/src/commands/lowcode/app_20220728111717.ts +52 -0
- package/.history/src/commands/lowcode/app_20220728112031.ts +34 -0
- package/.history/src/commands/lowcode/app_20220729172854.ts +34 -0
- package/.history/src/index_20220624162613.ts +13 -0
- package/.history/src/index_20220627113609.ts +15 -0
- package/.history/src/index_20220627114102.ts +13 -0
- package/bin/tcb.js +6 -6
- package/lib/commands/lowcode/utils.js +1 -2
- package/lib/utils/net/cloud-api-request.js +9 -9
- package/package.json +3 -3
- package/types/decorators/params/common.d.ts +1 -1
- package/types/types.d.ts +2 -2
- package/types/utils/config.d.ts +1 -1
- package/types/utils/fs/index.d.ts +1 -1
- package/types/utils/net/http-request.d.ts +3 -3
- package/types/utils/output/loading.d.ts +1 -1
- package/types/utils/parallel.d.ts +1 -1
- package/types/utils/validator.d.ts +1 -1
- package/.vscode/settings.json +0 -3
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
# Logs
|
|
2
|
+
logs
|
|
3
|
+
*.log
|
|
4
|
+
npm-debug.log*
|
|
5
|
+
yarn-debug.log*
|
|
6
|
+
yarn-error.log*
|
|
7
|
+
package-lock.json
|
|
8
|
+
yarn.lock
|
|
9
|
+
|
|
10
|
+
# Runtime data
|
|
11
|
+
pids
|
|
12
|
+
*.pid
|
|
13
|
+
*.seed
|
|
14
|
+
*.pid.lock
|
|
15
|
+
|
|
16
|
+
# Directory for instrumented libs generated by jscoverage/JSCover
|
|
17
|
+
lib-cov
|
|
18
|
+
|
|
19
|
+
# Coverage directory used by tools like istanbul
|
|
20
|
+
coverage
|
|
21
|
+
|
|
22
|
+
# nyc test coverage
|
|
23
|
+
.nyc_output
|
|
24
|
+
|
|
25
|
+
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
|
|
26
|
+
.grunt
|
|
27
|
+
|
|
28
|
+
# Bower dependency directory (https://bower.io/)
|
|
29
|
+
bower_components
|
|
30
|
+
|
|
31
|
+
# node-waf configuration
|
|
32
|
+
.lock-wscript
|
|
33
|
+
|
|
34
|
+
# Compiled binary addons (https://nodejs.org/api/addons.html)
|
|
35
|
+
build/Release
|
|
36
|
+
|
|
37
|
+
# Dependency directories
|
|
38
|
+
node_modules/
|
|
39
|
+
jspm_packages/
|
|
40
|
+
|
|
41
|
+
# TypeScript v1 declaration files
|
|
42
|
+
typings/
|
|
43
|
+
|
|
44
|
+
# Optional npm cache directory
|
|
45
|
+
.npm
|
|
46
|
+
|
|
47
|
+
# Optional eslint cache
|
|
48
|
+
.eslintcache
|
|
49
|
+
|
|
50
|
+
# Optional REPL history
|
|
51
|
+
.node_repl_history
|
|
52
|
+
|
|
53
|
+
# Output of 'npm pack'
|
|
54
|
+
*.tgz
|
|
55
|
+
|
|
56
|
+
# Yarn Integrity file
|
|
57
|
+
.yarn-integrity
|
|
58
|
+
|
|
59
|
+
# dotenv environment variables file
|
|
60
|
+
.env
|
|
61
|
+
|
|
62
|
+
# next.js build output
|
|
63
|
+
.next
|
|
64
|
+
|
|
65
|
+
dist
|
|
66
|
+
|
|
67
|
+
example/**/tcb.json
|
|
68
|
+
|
|
69
|
+
node_modules
|
|
70
|
+
|
|
71
|
+
.idea
|
|
72
|
+
.vscode/*
|
|
73
|
+
!.vscode/launch.json
|
|
74
|
+
|
|
75
|
+
# Test api Key
|
|
76
|
+
test/api-key.js
|
|
77
|
+
|
|
78
|
+
pkg/
|
|
79
|
+
|
|
80
|
+
.DS_Store
|
|
81
|
+
|
|
82
|
+
# Build files
|
|
83
|
+
/lib
|
|
84
|
+
/types
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
# Logs
|
|
2
|
+
logs
|
|
3
|
+
*.log
|
|
4
|
+
npm-debug.log*
|
|
5
|
+
yarn-debug.log*
|
|
6
|
+
yarn-error.log*
|
|
7
|
+
package-lock.json
|
|
8
|
+
yarn.lock
|
|
9
|
+
|
|
10
|
+
# Runtime data
|
|
11
|
+
pids
|
|
12
|
+
*.pid
|
|
13
|
+
*.seed
|
|
14
|
+
*.pid.lock
|
|
15
|
+
|
|
16
|
+
# Directory for instrumented libs generated by jscoverage/JSCover
|
|
17
|
+
lib-cov
|
|
18
|
+
|
|
19
|
+
# Coverage directory used by tools like istanbul
|
|
20
|
+
coverage
|
|
21
|
+
|
|
22
|
+
# nyc test coverage
|
|
23
|
+
.nyc_output
|
|
24
|
+
|
|
25
|
+
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
|
|
26
|
+
.grunt
|
|
27
|
+
|
|
28
|
+
# Bower dependency directory (https://bower.io/)
|
|
29
|
+
bower_components
|
|
30
|
+
|
|
31
|
+
# node-waf configuration
|
|
32
|
+
.lock-wscript
|
|
33
|
+
|
|
34
|
+
# Compiled binary addons (https://nodejs.org/api/addons.html)
|
|
35
|
+
build/Release
|
|
36
|
+
|
|
37
|
+
# Dependency directories
|
|
38
|
+
node_modules/
|
|
39
|
+
jspm_packages/
|
|
40
|
+
|
|
41
|
+
# TypeScript v1 declaration files
|
|
42
|
+
typings/
|
|
43
|
+
|
|
44
|
+
# Optional npm cache directory
|
|
45
|
+
.npm
|
|
46
|
+
|
|
47
|
+
# Optional eslint cache
|
|
48
|
+
.eslintcache
|
|
49
|
+
|
|
50
|
+
# Optional REPL history
|
|
51
|
+
.node_repl_history
|
|
52
|
+
|
|
53
|
+
# Output of 'npm pack'
|
|
54
|
+
*.tgz
|
|
55
|
+
|
|
56
|
+
# Yarn Integrity file
|
|
57
|
+
.yarn-integrity
|
|
58
|
+
|
|
59
|
+
# dotenv environment variables file
|
|
60
|
+
.env
|
|
61
|
+
|
|
62
|
+
# next.js build output
|
|
63
|
+
.next
|
|
64
|
+
|
|
65
|
+
dist
|
|
66
|
+
|
|
67
|
+
example/**/tcb.json
|
|
68
|
+
|
|
69
|
+
node_modules
|
|
70
|
+
|
|
71
|
+
.idea
|
|
72
|
+
.vscode/*
|
|
73
|
+
!.vscode/launch.json
|
|
74
|
+
|
|
75
|
+
# Test api Key
|
|
76
|
+
test/api-key.js
|
|
77
|
+
|
|
78
|
+
pkg/
|
|
79
|
+
|
|
80
|
+
.DS_Store
|
|
81
|
+
|
|
82
|
+
# Build files
|
|
83
|
+
/lib
|
|
84
|
+
/types
|
|
85
|
+
|
|
86
|
+
.history
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@cloudbase/cli",
|
|
3
|
+
"version": "2.2.7",
|
|
4
|
+
"description": "cli tool for cloudbase",
|
|
5
|
+
"main": "lib/index.js",
|
|
6
|
+
"scripts": {
|
|
7
|
+
"build": "rimraf lib types && tsc",
|
|
8
|
+
"watch": "rimraf lib types && tsc -w",
|
|
9
|
+
"dev": "rimraf lib types && tsc -w",
|
|
10
|
+
"eslint": "eslint \"./**/*.ts\"",
|
|
11
|
+
"test": "jest --runInBand --forceExit --detectOpenHandles --coverage --verbose --testTimeout=10000",
|
|
12
|
+
"tsc": "tsc",
|
|
13
|
+
"pkg": "pkg ./bin/cloudbase.js --out-path ./pkg",
|
|
14
|
+
"postinstall": "node ./post-install.js || exit 0",
|
|
15
|
+
"prepublishOnly": "npm run build"
|
|
16
|
+
},
|
|
17
|
+
"repository": {
|
|
18
|
+
"type": "git",
|
|
19
|
+
"url": "https://github.com/TencentCloudBase/cloud-base-cli.git"
|
|
20
|
+
},
|
|
21
|
+
"bin": {
|
|
22
|
+
"tcb": "bin/tcb.js",
|
|
23
|
+
"cloudbase": "bin/cloudbase.js"
|
|
24
|
+
},
|
|
25
|
+
"husky": {
|
|
26
|
+
"hooks": {
|
|
27
|
+
"pre-commit": "npm run build"
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
"author": "cwuyiqing@gmail.com",
|
|
31
|
+
"license": "ISC",
|
|
32
|
+
"dependencies": {
|
|
33
|
+
"@cloudbase/cloud-api": "^0.5.5",
|
|
34
|
+
"@cloudbase/framework-core": "^1.9.6",
|
|
35
|
+
"@cloudbase/lowcode-cli": "^0.18.7",
|
|
36
|
+
"@cloudbase/manager-node": "4.0.1",
|
|
37
|
+
"@cloudbase/toolbox": "^0.7.5",
|
|
38
|
+
"@sentry/node": "^5.10.2",
|
|
39
|
+
"address": "^1.1.2",
|
|
40
|
+
"chalk": "^2.4.2",
|
|
41
|
+
"cli-table3": "^0.5.1",
|
|
42
|
+
"commander": "7",
|
|
43
|
+
"del": "^5.1.0",
|
|
44
|
+
"didyoumean": "^1.2.2",
|
|
45
|
+
"enquirer": "^2.3.6",
|
|
46
|
+
"execa": "^4.0.3",
|
|
47
|
+
"fs-extra": "^8.1.0",
|
|
48
|
+
"https-proxy-agent": "^5.0.1",
|
|
49
|
+
"inquirer": "^6.5.0",
|
|
50
|
+
"lodash": "^4.17.21",
|
|
51
|
+
"log-symbols": "^3.0.0",
|
|
52
|
+
"lowdb": "^1.0.0",
|
|
53
|
+
"make-dir": "^3.0.0",
|
|
54
|
+
"node-fetch": "^2.6.0",
|
|
55
|
+
"open": "^7.0.0",
|
|
56
|
+
"ora": "^4.0.2",
|
|
57
|
+
"portfinder": "^1.0.28",
|
|
58
|
+
"progress": "^2.0.3",
|
|
59
|
+
"query-string": "^6.8.1",
|
|
60
|
+
"reflect-metadata": "^0.1.13",
|
|
61
|
+
"semver": "^7.3.7",
|
|
62
|
+
"tar-fs": "^2.0.1",
|
|
63
|
+
"terminal-link": "^2.1.1",
|
|
64
|
+
"unzipper": "^0.10.10",
|
|
65
|
+
"update-notifier": "^4.0.0",
|
|
66
|
+
"xdg-basedir": "^4.0.0",
|
|
67
|
+
"yargs": "^16.2.0",
|
|
68
|
+
"yargs-parser": "^21.0.1"
|
|
69
|
+
},
|
|
70
|
+
"devDependencies": {
|
|
71
|
+
"@types/jest": "^27",
|
|
72
|
+
"@types/koa__router": "^8.0.11",
|
|
73
|
+
"@types/lodash": "^4.14.182",
|
|
74
|
+
"@types/node": "^12.12.38",
|
|
75
|
+
"@types/node-fetch": "^2.5.4",
|
|
76
|
+
"@types/react": "^17.0.37",
|
|
77
|
+
"@types/semver": "^7.3.9",
|
|
78
|
+
"@types/webpack-dev-server": "^3.11.1",
|
|
79
|
+
"@typescript-eslint/eslint-plugin": "^4.8.1",
|
|
80
|
+
"@typescript-eslint/parser": "^4.8.1",
|
|
81
|
+
"eslint": "^7.14.0",
|
|
82
|
+
"eslint-config-alloy": "^3.8.2",
|
|
83
|
+
"husky": "^3.0.9",
|
|
84
|
+
"jest": "^27",
|
|
85
|
+
"rimraf": "^3.0.2",
|
|
86
|
+
"ts-jest": "^27",
|
|
87
|
+
"typescript": "^4.7.2"
|
|
88
|
+
}
|
|
89
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@cloudbase/cli",
|
|
3
|
+
"version": "2.2.8",
|
|
4
|
+
"description": "cli tool for cloudbase",
|
|
5
|
+
"main": "lib/index.js",
|
|
6
|
+
"scripts": {
|
|
7
|
+
"build": "rimraf lib types && tsc",
|
|
8
|
+
"watch": "rimraf lib types && tsc -w",
|
|
9
|
+
"dev": "rimraf lib types && tsc -w",
|
|
10
|
+
"eslint": "eslint \"./**/*.ts\"",
|
|
11
|
+
"test": "jest --runInBand --forceExit --detectOpenHandles --coverage --verbose --testTimeout=10000",
|
|
12
|
+
"tsc": "tsc",
|
|
13
|
+
"pkg": "pkg ./bin/cloudbase.js --out-path ./pkg",
|
|
14
|
+
"postinstall": "node ./post-install.js || exit 0",
|
|
15
|
+
"prepublishOnly": "npm run build"
|
|
16
|
+
},
|
|
17
|
+
"repository": {
|
|
18
|
+
"type": "git",
|
|
19
|
+
"url": "https://github.com/TencentCloudBase/cloud-base-cli.git"
|
|
20
|
+
},
|
|
21
|
+
"bin": {
|
|
22
|
+
"tcb": "bin/tcb.js",
|
|
23
|
+
"cloudbase": "bin/cloudbase.js"
|
|
24
|
+
},
|
|
25
|
+
"husky": {
|
|
26
|
+
"hooks": {
|
|
27
|
+
"pre-commit": "npm run build"
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
"author": "cwuyiqing@gmail.com",
|
|
31
|
+
"license": "ISC",
|
|
32
|
+
"dependencies": {
|
|
33
|
+
"@cloudbase/cloud-api": "^0.5.5",
|
|
34
|
+
"@cloudbase/framework-core": "^1.9.6",
|
|
35
|
+
"@cloudbase/lowcode-cli": "^0.18.7",
|
|
36
|
+
"@cloudbase/manager-node": "4.0.1",
|
|
37
|
+
"@cloudbase/toolbox": "^0.7.5",
|
|
38
|
+
"@sentry/node": "^5.10.2",
|
|
39
|
+
"address": "^1.1.2",
|
|
40
|
+
"chalk": "^2.4.2",
|
|
41
|
+
"cli-table3": "^0.5.1",
|
|
42
|
+
"commander": "7",
|
|
43
|
+
"del": "^5.1.0",
|
|
44
|
+
"didyoumean": "^1.2.2",
|
|
45
|
+
"enquirer": "^2.3.6",
|
|
46
|
+
"execa": "^4.0.3",
|
|
47
|
+
"fs-extra": "^8.1.0",
|
|
48
|
+
"https-proxy-agent": "^5.0.1",
|
|
49
|
+
"inquirer": "^6.5.0",
|
|
50
|
+
"lodash": "^4.17.21",
|
|
51
|
+
"log-symbols": "^3.0.0",
|
|
52
|
+
"lowdb": "^1.0.0",
|
|
53
|
+
"make-dir": "^3.0.0",
|
|
54
|
+
"node-fetch": "^2.6.0",
|
|
55
|
+
"open": "^7.0.0",
|
|
56
|
+
"ora": "^4.0.2",
|
|
57
|
+
"portfinder": "^1.0.28",
|
|
58
|
+
"progress": "^2.0.3",
|
|
59
|
+
"query-string": "^6.8.1",
|
|
60
|
+
"reflect-metadata": "^0.1.13",
|
|
61
|
+
"semver": "^7.3.7",
|
|
62
|
+
"tar-fs": "^2.0.1",
|
|
63
|
+
"terminal-link": "^2.1.1",
|
|
64
|
+
"unzipper": "^0.10.10",
|
|
65
|
+
"update-notifier": "^4.0.0",
|
|
66
|
+
"xdg-basedir": "^4.0.0",
|
|
67
|
+
"yargs": "^16.2.0",
|
|
68
|
+
"yargs-parser": "^21.0.1"
|
|
69
|
+
},
|
|
70
|
+
"devDependencies": {
|
|
71
|
+
"@types/jest": "^27",
|
|
72
|
+
"@types/koa__router": "^8.0.11",
|
|
73
|
+
"@types/lodash": "^4.14.182",
|
|
74
|
+
"@types/node": "^12.12.38",
|
|
75
|
+
"@types/node-fetch": "^2.5.4",
|
|
76
|
+
"@types/react": "^17.0.37",
|
|
77
|
+
"@types/semver": "^7.3.9",
|
|
78
|
+
"@types/webpack-dev-server": "^3.11.1",
|
|
79
|
+
"@typescript-eslint/eslint-plugin": "^4.8.1",
|
|
80
|
+
"@typescript-eslint/parser": "^4.8.1",
|
|
81
|
+
"eslint": "^7.14.0",
|
|
82
|
+
"eslint-config-alloy": "^3.8.2",
|
|
83
|
+
"husky": "^3.0.9",
|
|
84
|
+
"jest": "^27",
|
|
85
|
+
"rimraf": "^3.0.2",
|
|
86
|
+
"ts-jest": "^27",
|
|
87
|
+
"typescript": "^4.7.2"
|
|
88
|
+
}
|
|
89
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import _ from 'lodash'
|
|
2
|
+
import { Command, ICommand } from '../common'
|
|
3
|
+
import { watchApp } from '@cloudbase/lowcode-cli'
|
|
4
|
+
import { InjectParams, Log, Logger, CmdContext, ArgsOptions } from '../../decorators'
|
|
5
|
+
|
|
6
|
+
@ICommand()
|
|
7
|
+
export class LowCodeWatch extends Command {
|
|
8
|
+
get options() {
|
|
9
|
+
return {
|
|
10
|
+
cmd: 'lowcode',
|
|
11
|
+
childCmd: 'watch',
|
|
12
|
+
options: [
|
|
13
|
+
{
|
|
14
|
+
flags: '--verbose',
|
|
15
|
+
desc: '是否打印详细日志'
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
flags: '--wx-devtool-path <wxDevtoolPath>',
|
|
19
|
+
desc: '微信开发者工具的安装路径'
|
|
20
|
+
}
|
|
21
|
+
],
|
|
22
|
+
desc: '开启云开发低码的本地构建模式',
|
|
23
|
+
requiredEnvId: false
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
@InjectParams()
|
|
28
|
+
async execute(@CmdContext() ctx, @ArgsOptions() options) {
|
|
29
|
+
await watchApp({
|
|
30
|
+
watchPort: 8288,
|
|
31
|
+
wxDevtoolPath: options?.wxDevtoolPath
|
|
32
|
+
})
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
@ICommand()
|
|
37
|
+
export class DanielWatch extends Command {
|
|
38
|
+
get options() {
|
|
39
|
+
return {
|
|
40
|
+
cmd: 'lowcode',
|
|
41
|
+
childCmd: 'watch-ws',
|
|
42
|
+
options: [],
|
|
43
|
+
desc: '开启云开发低码的本地开发模式',
|
|
44
|
+
requiredEnvId: false
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
@InjectParams()
|
|
49
|
+
async execute(@CmdContext() ctx, @ArgsOptions() options) {
|
|
50
|
+
console.log('>>> 启动啦')
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import _ from 'lodash'
|
|
2
|
+
import { Command, ICommand } from '../common'
|
|
3
|
+
import { watchApp } from '@cloudbase/lowcode-cli'
|
|
4
|
+
import { InjectParams, Log, Logger, CmdContext, ArgsOptions } from '../../decorators'
|
|
5
|
+
|
|
6
|
+
@ICommand()
|
|
7
|
+
export class LowCodeWatch extends Command {
|
|
8
|
+
get options() {
|
|
9
|
+
return {
|
|
10
|
+
cmd: 'lowcode',
|
|
11
|
+
childCmd: 'watch',
|
|
12
|
+
options: [
|
|
13
|
+
{
|
|
14
|
+
flags: '--verbose',
|
|
15
|
+
desc: '是否打印详细日志'
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
flags: '--wx-devtool-path <wxDevtoolPath>',
|
|
19
|
+
desc: '微信开发者工具的安装路径'
|
|
20
|
+
}
|
|
21
|
+
],
|
|
22
|
+
desc: '开启云开发低码的本地构建模式',
|
|
23
|
+
requiredEnvId: false
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
@InjectParams()
|
|
28
|
+
async execute(@CmdContext() ctx, @ArgsOptions() options) {
|
|
29
|
+
await watchApp({
|
|
30
|
+
watchPort: 8288,
|
|
31
|
+
wxDevtoolPath: options?.wxDevtoolPath
|
|
32
|
+
})
|
|
33
|
+
}
|
|
34
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import _ from 'lodash'
|
|
2
|
+
import { Command, ICommand } from '../common'
|
|
3
|
+
import { watchApp } from '@cloudbase/lowcode-cli'
|
|
4
|
+
import { InjectParams, Log, Logger, CmdContext, ArgsOptions } from '../../decorators'
|
|
5
|
+
|
|
6
|
+
@ICommand()
|
|
7
|
+
export class LowCodeWatch extends Command {
|
|
8
|
+
get options() {
|
|
9
|
+
return {
|
|
10
|
+
cmd: 'lowcode',
|
|
11
|
+
childCmd: 'watch',
|
|
12
|
+
options: [
|
|
13
|
+
{
|
|
14
|
+
flags: '--verbose',
|
|
15
|
+
desc: '是否打印详细日志'
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
flags: '--wx-devtool-path <wxDevtoolPath>',
|
|
19
|
+
desc: '微信开发者工具的安装路径'
|
|
20
|
+
}
|
|
21
|
+
],
|
|
22
|
+
desc: '开启微搭低代码的本地构建模式',
|
|
23
|
+
requiredEnvId: false
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
@InjectParams()
|
|
28
|
+
async execute(@CmdContext() ctx, @ArgsOptions() options) {
|
|
29
|
+
await watchApp({
|
|
30
|
+
watchPort: 8288,
|
|
31
|
+
wxDevtoolPath: options?.wxDevtoolPath
|
|
32
|
+
})
|
|
33
|
+
}
|
|
34
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import 'reflect-metadata'
|
|
2
|
+
import { registerCommands } from './commands/common'
|
|
3
|
+
import './commands'
|
|
4
|
+
|
|
5
|
+
export { smartDeploy } from './commands'
|
|
6
|
+
|
|
7
|
+
registerCommands()
|
|
8
|
+
|
|
9
|
+
// HACK: 部分依赖使用了 globalThis,会在 Node12 以下的版本报错
|
|
10
|
+
if (typeof globalThis === undefined) {
|
|
11
|
+
// eslint-disable-next-line no-undef
|
|
12
|
+
;(globalThis as any) = global
|
|
13
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import 'reflect-metadata'
|
|
2
|
+
import { registerCommands } from './commands/common'
|
|
3
|
+
import './commands'
|
|
4
|
+
|
|
5
|
+
export { smartDeploy } from './commands'
|
|
6
|
+
|
|
7
|
+
registerCommands()
|
|
8
|
+
|
|
9
|
+
// HACK: 部分依赖使用了 globalThis,会在 Node12 以下的版本报错
|
|
10
|
+
if (typeof globalThis === undefined) {
|
|
11
|
+
// eslint-disable-next-line no-undef
|
|
12
|
+
;(globalThis as any) = global
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
console.log("daniel tcb")
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import 'reflect-metadata'
|
|
2
|
+
import { registerCommands } from './commands/common'
|
|
3
|
+
import './commands'
|
|
4
|
+
|
|
5
|
+
export { smartDeploy } from './commands'
|
|
6
|
+
|
|
7
|
+
registerCommands()
|
|
8
|
+
|
|
9
|
+
// HACK: 部分依赖使用了 globalThis,会在 Node12 以下的版本报错
|
|
10
|
+
if (typeof globalThis === undefined) {
|
|
11
|
+
// eslint-disable-next-line no-undef
|
|
12
|
+
;(globalThis as any) = global
|
|
13
|
+
}
|
package/bin/tcb.js
CHANGED
|
@@ -184,12 +184,12 @@ async function main() {
|
|
|
184
184
|
if (errMsg.includes('Environment') && errMsg.includes('not found')) {
|
|
185
185
|
// 检查是否已经指定了 -r 或 --region 参数,如未指定则尝试获取地域信息
|
|
186
186
|
const regionSpecified = processArgv.indexOf('-r') !== -1 || processArgv.indexOf('--region') !== -1
|
|
187
|
-
const region = yargsParsedResult
|
|
187
|
+
const region = yargsParsedResult.r || yargsParsedResult.region
|
|
188
188
|
const multiRegionErrMsg = `\n此环境可能不属于当前账号,或为非${regionSupportedMap[region] || '上海'}地域环境,如需切换地域请追加参数(例:-r gz),请检查环境归属,参考多地域使用方法:https://docs.cloudbase.net/cli-v1/region.html`
|
|
189
189
|
if (!regionSpecified) {
|
|
190
190
|
|
|
191
191
|
// 从 -e 参数、--envId 参数和配置文件中获取环境 id
|
|
192
|
-
const envId = yargsParsedResult
|
|
192
|
+
const envId = yargsParsedResult.e || yargsParsedResult.envId || config.envId
|
|
193
193
|
|
|
194
194
|
// 调用 API 接口尝试查询环境信息
|
|
195
195
|
const predictRegion = await tryTellEnvRegion(envId)
|
|
@@ -246,8 +246,8 @@ async function main() {
|
|
|
246
246
|
async function tryTellEnvRegion(envId) {
|
|
247
247
|
// 依次调用不同地域的 API 接口查询环境信息
|
|
248
248
|
const fetchedRegion = await Promise.all(regionSupported.map(async region => {
|
|
249
|
-
const
|
|
250
|
-
if (
|
|
249
|
+
const { EnvList = [] } = await fetchEnvInfoWithRegion(envId, region)
|
|
250
|
+
if (EnvList.length !== 0 && EnvList.find(item => item.EnvId === envId)) {
|
|
251
251
|
return res.EnvList[0].Region
|
|
252
252
|
}
|
|
253
253
|
return ''
|
|
@@ -264,14 +264,14 @@ async function main() {
|
|
|
264
264
|
|
|
265
265
|
// 在指定地域调用 API 接口查询环境信息
|
|
266
266
|
async function fetchEnvInfoWithRegion(envId, region) {
|
|
267
|
-
let commonCredential
|
|
267
|
+
let commonCredential = {}
|
|
268
268
|
const commonOpts = {
|
|
269
269
|
service: 'tcb',
|
|
270
270
|
version: '2019-09-24',
|
|
271
271
|
proxy: getProxy(),
|
|
272
272
|
timeout: 15000,
|
|
273
273
|
getCredential: async () => {
|
|
274
|
-
if (commonCredential
|
|
274
|
+
if (commonCredential.secretId && !isTokenExpired(commonCredential)) {
|
|
275
275
|
return commonCredential
|
|
276
276
|
}
|
|
277
277
|
const credential = await getCredentialWithoutCheck()
|
|
@@ -60,12 +60,11 @@ function promisifyProcess(p, pipe = false) {
|
|
|
60
60
|
exports.promisifyProcess = promisifyProcess;
|
|
61
61
|
function getLowcodeCli() {
|
|
62
62
|
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
-
var _a;
|
|
64
63
|
const key = '@cloudbase/lowcode-cli';
|
|
65
64
|
const cache = new Map();
|
|
66
65
|
let result;
|
|
67
66
|
if (!cache.get(key)) {
|
|
68
|
-
const module = yield
|
|
67
|
+
const module = yield Promise.resolve().then(() => __importStar(require(key)));
|
|
69
68
|
cache.set(key, module);
|
|
70
69
|
}
|
|
71
70
|
result = cache.get(key);
|
|
@@ -18,15 +18,6 @@ const debug_logger_1 = require("../debug-logger");
|
|
|
18
18
|
let commonCredential;
|
|
19
19
|
const isTokenExpired = (credential, gap = 120) => credential.accessTokenExpired && Number(credential.accessTokenExpired) < Date.now() + gap * 1000;
|
|
20
20
|
class CloudApiService {
|
|
21
|
-
static getInstance(service) {
|
|
22
|
-
var _a;
|
|
23
|
-
if ((_a = CloudApiService.serviceCacheMap) === null || _a === void 0 ? void 0 : _a[service]) {
|
|
24
|
-
return CloudApiService.serviceCacheMap[service];
|
|
25
|
-
}
|
|
26
|
-
const apiService = new CloudApiService(service);
|
|
27
|
-
CloudApiService.serviceCacheMap[service] = apiService;
|
|
28
|
-
return apiService;
|
|
29
|
-
}
|
|
30
21
|
constructor(service, baseParams, version = '') {
|
|
31
22
|
this.apiService = new cloud_api_1.CloudApiService({
|
|
32
23
|
service,
|
|
@@ -47,6 +38,15 @@ class CloudApiService {
|
|
|
47
38
|
})
|
|
48
39
|
});
|
|
49
40
|
}
|
|
41
|
+
static getInstance(service) {
|
|
42
|
+
var _a;
|
|
43
|
+
if ((_a = CloudApiService.serviceCacheMap) === null || _a === void 0 ? void 0 : _a[service]) {
|
|
44
|
+
return CloudApiService.serviceCacheMap[service];
|
|
45
|
+
}
|
|
46
|
+
const apiService = new CloudApiService(service);
|
|
47
|
+
CloudApiService.serviceCacheMap[service] = apiService;
|
|
48
|
+
return apiService;
|
|
49
|
+
}
|
|
50
50
|
request(action, data = {}, method = 'POST') {
|
|
51
51
|
return __awaiter(this, void 0, void 0, function* () {
|
|
52
52
|
const region = this.region || (yield (0, toolbox_1.getRegion)());
|
package/package.json
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cloudbase/cli",
|
|
3
|
-
"version": "2.2.
|
|
3
|
+
"version": "2.2.11-alpha.0",
|
|
4
4
|
"description": "cli tool for cloudbase",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"scripts": {
|
|
7
|
-
"build": "rimraf lib types && tsc",
|
|
7
|
+
"build": "rimraf lib types && tsc --resolveJsonModule",
|
|
8
8
|
"watch": "rimraf lib types && tsc -w",
|
|
9
9
|
"dev": "rimraf lib types && tsc -w",
|
|
10
10
|
"eslint": "eslint \"./**/*.ts\"",
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"dependencies": {
|
|
33
33
|
"@cloudbase/cloud-api": "^0.5.5",
|
|
34
34
|
"@cloudbase/framework-core": "^1.9.6",
|
|
35
|
-
"@cloudbase/lowcode-cli": "
|
|
35
|
+
"@cloudbase/lowcode-cli": "0.18.10-alpha.1",
|
|
36
36
|
"@cloudbase/manager-node": "4.0.1",
|
|
37
37
|
"@cloudbase/toolbox": "^0.7.5",
|
|
38
38
|
"@sentry/node": "^5.10.2",
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { ParamTypes } from '../constants';
|
|
2
|
-
type GetterFunction = (target: any) => Promise<any> | any;
|
|
2
|
+
declare type GetterFunction = (target: any) => Promise<any> | any;
|
|
3
3
|
export declare const createParamDecorator: (paramtype: ParamTypes, getter: GetterFunction) => () => (target: any, key: string | symbol, index: number) => void;
|
|
4
4
|
export {};
|
package/types/types.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
-
export type CustomEvent = 'logout';
|
|
2
|
+
export declare type CustomEvent = 'logout';
|
|
3
3
|
export interface ICommandContext {
|
|
4
4
|
cmd: string;
|
|
5
5
|
envId: string;
|
|
@@ -33,7 +33,7 @@ export interface TmpCredential {
|
|
|
33
33
|
uin?: string;
|
|
34
34
|
hash?: string;
|
|
35
35
|
}
|
|
36
|
-
export type Credential = TmpCredential & PermanentCredential;
|
|
36
|
+
export declare type Credential = TmpCredential & PermanentCredential;
|
|
37
37
|
export interface AuthSecret {
|
|
38
38
|
secretId: string;
|
|
39
39
|
secretKey: string;
|
package/types/utils/config.d.ts
CHANGED
|
@@ -10,7 +10,7 @@ export interface IArgs {
|
|
|
10
10
|
}
|
|
11
11
|
export declare const getArgs: () => Arguments<IArgs>;
|
|
12
12
|
export declare function getPrivateSettings(config: ICloudBaseRcSettings, cmd?: string): undefined | IPrivateSettings;
|
|
13
|
-
type IAbsUrl = `http://${string}` | `https://${string}`;
|
|
13
|
+
declare type IAbsUrl = `http://${string}` | `https://${string}`;
|
|
14
14
|
export interface IPrivateSettings {
|
|
15
15
|
credential: Credential;
|
|
16
16
|
endpoints: {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export * from './del';
|
|
2
|
-
export type SizeUnit = 'KB' | 'MB' | 'GB';
|
|
2
|
+
export declare type SizeUnit = 'KB' | 'MB' | 'GB';
|
|
3
3
|
export declare function checkFullAccess(dest: string, throwError?: boolean): boolean;
|
|
4
4
|
export declare function checkWritable(dest: string, throwError?: boolean): boolean;
|
|
5
5
|
export declare function checkReadable(dest: string, throwError?: boolean): boolean;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _fetch, { RequestInit } from 'node-fetch';
|
|
2
|
-
type fetchReturnType = ReturnType<typeof _fetch>;
|
|
3
|
-
type UnPromisify<T> = T extends PromiseLike<infer U> ? U : T;
|
|
4
|
-
type fetchReturnTypeExtracted = UnPromisify<fetchReturnType>;
|
|
2
|
+
declare type fetchReturnType = ReturnType<typeof _fetch>;
|
|
3
|
+
declare type UnPromisify<T> = T extends PromiseLike<infer U> ? U : T;
|
|
4
|
+
declare type fetchReturnTypeExtracted = UnPromisify<fetchReturnType>;
|
|
5
5
|
export declare function fetch(url: string, config?: RequestInit): Promise<any>;
|
|
6
6
|
export declare function postFetch(url: string, data?: Record<string, any>): Promise<any>;
|
|
7
7
|
export declare function fetchStream(url: any, config?: Record<string, any>): Promise<fetchReturnTypeExtracted>;
|
|
@@ -8,7 +8,7 @@ declare class Loading {
|
|
|
8
8
|
fail(text: string): void;
|
|
9
9
|
}
|
|
10
10
|
export declare const loadingFactory: () => Loading;
|
|
11
|
-
type Task<T> = (flush: (text: string) => void, ...args: any[]) => Promise<T>;
|
|
11
|
+
declare type Task<T> = (flush: (text: string) => void, ...args: any[]) => Promise<T>;
|
|
12
12
|
export interface ILoadingOptions {
|
|
13
13
|
startTip?: string;
|
|
14
14
|
successTip?: string;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
type SimpleValue = number | string | boolean;
|
|
1
|
+
declare type SimpleValue = number | string | boolean;
|
|
2
2
|
export declare function assertTruthy(val: SimpleValue | SimpleValue[], errMsg: string): void;
|
|
3
3
|
export declare function assertHas(obj: any, prop: string, errMsg: any): void;
|
|
4
4
|
export declare const validateIp: (ip: string) => boolean;
|
package/.vscode/settings.json
DELETED