@webos-tools/cli 3.2.1 → 3.2.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.
Files changed (149) hide show
  1. package/.eslintignore +1 -1
  2. package/.eslintrc.js +52 -52
  3. package/APIs.js +79 -79
  4. package/CHANGELOG.md +7 -0
  5. package/LICENSE +201 -201
  6. package/bin/ares-config.js +0 -0
  7. package/bin/ares-device-info.js +30 -30
  8. package/bin/ares-device.js +0 -0
  9. package/bin/ares-generate.js +274 -274
  10. package/bin/ares-inspect.js +179 -179
  11. package/bin/ares-install.js +223 -223
  12. package/bin/ares-launch.js +0 -0
  13. package/bin/ares-log.js +258 -258
  14. package/bin/ares-novacom.js +0 -0
  15. package/bin/ares-package.js +0 -0
  16. package/bin/ares-pull.js +156 -156
  17. package/bin/ares-push.js +155 -155
  18. package/bin/ares-server.js +174 -174
  19. package/bin/ares-setup-device.js +0 -0
  20. package/bin/ares-shell.js +132 -132
  21. package/bin/ares.js +166 -166
  22. package/files/conf/ipk.json +30 -30
  23. package/files/conf/query/query-app.json +14 -14
  24. package/files/conf/query/query-hosted.json +18 -18
  25. package/files/conf/query/query-package.json +10 -10
  26. package/files/conf/query/query-service.json +6 -6
  27. package/files/conf/webos_emul +27 -27
  28. package/files/conf-base/env/sdk-apollo.json +7 -7
  29. package/files/conf-base/env/sdk-ose.json +8 -8
  30. package/files/conf-base/env/sdk-tv.json +8 -8
  31. package/files/conf-base/profile/config-apollo.json +28 -28
  32. package/files/conf-base/profile/config-ose.json +29 -29
  33. package/files/conf-base/profile/config-tv.json +31 -31
  34. package/files/conf-base/query/query-app.json +14 -14
  35. package/files/conf-base/query/query-hosted.json +18 -18
  36. package/files/conf-base/query/query-package.json +10 -10
  37. package/files/conf-base/query/query-service.json +6 -6
  38. package/files/conf-base/template-conf/ose-templates.json +67 -67
  39. package/files/conf-base/template-conf/tv-sdk-templates.json +57 -57
  40. package/files/help/ares-device.help +109 -109
  41. package/files/help/ares-install.help +95 -95
  42. package/files/help/ares-log-pmlogd.help +84 -84
  43. package/files/help/ares-log.help +101 -101
  44. package/files/help/ares-novacom.help +68 -68
  45. package/files/help/ares-pull.help +38 -38
  46. package/files/help/ares-push.help +38 -38
  47. package/files/help/ares-server.help +44 -44
  48. package/files/help/ares-shell.help +42 -42
  49. package/files/help/ares.help +52 -52
  50. package/files/help/readme.help +23 -23
  51. package/files/schema/ApplicationDescription.schema +319 -319
  52. package/files/templates/apollo-sdk-templates/appinfo/appinfo.json +10 -10
  53. package/files/templates/apollo-sdk-templates/bootplate-web/index.html +88 -88
  54. package/files/templates/apollo-sdk-templates/hosted-webapp/index.html +13 -13
  55. package/files/templates/apollo-sdk-templates/js-service/helloclient.js +31 -31
  56. package/files/templates/apollo-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  57. package/files/templates/apollo-sdk-templates/serviceinfo/package.json +11 -11
  58. package/files/templates/apollo-sdk-templates/serviceinfo/services.json +8 -8
  59. package/files/templates/ose-sdk-templates/appinfo/appinfo.json +10 -10
  60. package/files/templates/ose-sdk-templates/bootplate-web/index.html +88 -88
  61. package/files/templates/ose-sdk-templates/hosted-webapp/index.html +13 -13
  62. package/files/templates/ose-sdk-templates/icon/icon.png +0 -0
  63. package/files/templates/ose-sdk-templates/js-service/helloclient.js +31 -31
  64. package/files/templates/ose-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  65. package/files/templates/ose-sdk-templates/qml-app/main.qml +68 -68
  66. package/files/templates/ose-sdk-templates/qmlappinfo/appinfo.json +10 -10
  67. package/files/templates/ose-sdk-templates/serviceinfo/package.json +11 -11
  68. package/files/templates/ose-sdk-templates/serviceinfo/services.json +8 -8
  69. package/files/templates/tv-sdk-templates/appinfo/appinfo.json +10 -10
  70. package/files/templates/tv-sdk-templates/bootplate-web/index.html +58 -58
  71. package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.10/LICENSE-2.0.txt +202 -202
  72. package/files/templates/tv-sdk-templates/hosted-webapp/index.html +14 -14
  73. package/files/templates/tv-sdk-templates/js-service/helloworld_service.js +39 -39
  74. package/files/templates/tv-sdk-templates/packageinfo/packageinfo.json +3 -3
  75. package/files/templates/tv-sdk-templates/serviceinfo/package.json +11 -11
  76. package/files/templates/tv-sdk-templates/serviceinfo/services.json +8 -8
  77. package/files/templates/tv-sdk-templates/webicon/icon.png +0 -0
  78. package/files/templates/tv-sdk-templates/webicon/largeIcon.png +0 -0
  79. package/lib/base/ares.html +40 -40
  80. package/lib/base/cli-appdata.js +290 -290
  81. package/lib/base/cli-control.js +44 -44
  82. package/lib/base/common-tools.js +29 -29
  83. package/lib/base/error-handler.js +265 -265
  84. package/lib/base/file-watcher.js +155 -155
  85. package/lib/base/help-format.js +147 -147
  86. package/lib/base/luna.js +178 -178
  87. package/lib/base/sdkenv.js +59 -59
  88. package/lib/base/server.js +137 -137
  89. package/lib/base/version-tools.js +79 -79
  90. package/lib/device.js +1419 -1419
  91. package/lib/inspect.js +493 -493
  92. package/lib/log.js +584 -584
  93. package/lib/package.js +1 -3
  94. package/lib/pull.js +231 -231
  95. package/lib/pusher.js +210 -210
  96. package/lib/session.js +74 -74
  97. package/lib/shell.js +193 -193
  98. package/lib/tar-filter-pack.js +62 -62
  99. package/lib/util/copy.js +31 -31
  100. package/lib/util/createFileName.js +40 -40
  101. package/lib/util/eof.js +30 -30
  102. package/lib/util/json.js +63 -63
  103. package/lib/util/merge.js +14 -14
  104. package/lib/util/objclone.js +40 -40
  105. package/lib/util/spinner.js +37 -37
  106. package/npm-shrinkwrap.json +1 -1
  107. package/package.json +1 -1
  108. package/scripts/postinstall.js +24 -24
  109. package/spec/helpers/reporter.js +65 -65
  110. package/spec/jsSpecs/apiTest/generator.spec.js +372 -372
  111. package/spec/jsSpecs/apiTest/inspector.spec.js +89 -89
  112. package/spec/jsSpecs/apiTest/installer.spec.js +67 -67
  113. package/spec/jsSpecs/apiTest/launcher.spec.js +150 -150
  114. package/spec/jsSpecs/apiTest/packager.spec.js +194 -194
  115. package/spec/jsSpecs/apiTest/puller.spec.js +101 -101
  116. package/spec/jsSpecs/apiTest/pusher.spec.js +103 -103
  117. package/spec/jsSpecs/apiTest/server.spec.js +115 -115
  118. package/spec/jsSpecs/apiTest/setupDevice.spec.js +93 -93
  119. package/spec/jsSpecs/apiTest/shell.spec.js +49 -49
  120. package/spec/jsSpecs/ares-config.spec.js +88 -88
  121. package/spec/jsSpecs/ares-device.spec.js +443 -443
  122. package/spec/jsSpecs/ares-generate.spec.js +397 -397
  123. package/spec/jsSpecs/ares-inspect.spec.js +252 -252
  124. package/spec/jsSpecs/ares-install.spec.js +150 -150
  125. package/spec/jsSpecs/ares-log.spec.js +824 -824
  126. package/spec/jsSpecs/ares-novacom.spec.js +149 -149
  127. package/spec/jsSpecs/ares-pull.spec.js +157 -157
  128. package/spec/jsSpecs/ares-push.spec.js +146 -146
  129. package/spec/jsSpecs/ares-shell.spec.js +220 -220
  130. package/spec/jsSpecs/ares.spec.js +83 -83
  131. package/spec/support/jasmine.json +22 -22
  132. package/spec/tempFiles/nativeApp/auto/pkg_arm64/GLES2 +0 -0
  133. package/spec/tempFiles/nativeApp/auto/pkg_arm64/appinfo.json +9 -9
  134. package/spec/tempFiles/nativeApp/ose/pkg_arm/Hello +0 -0
  135. package/spec/tempFiles/nativeApp/ose/pkg_arm/appinfo.json +8 -8
  136. package/spec/tempFiles/nativeApp/ose/pkg_arm/package.properties +2 -2
  137. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/Hello +0 -0
  138. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/appinfo.json +9 -9
  139. package/spec/tempFiles/nativeApp/rsi/pkg_x86/GLES2 +0 -0
  140. package/spec/tempFiles/nativeApp/rsi/pkg_x86/appinfo.json +9 -9
  141. package/spec/tempFiles/sign/sign.crt +32 -32
  142. package/spec/tempFiles/sign/signPriv.key +52 -52
  143. package/spec/test_data/ares-generate.json +57 -57
  144. package/spec/test_data/ares.json +50 -50
  145. package/.vscode/c_cpp_properties.json +0 -21
  146. package/.vscode/launch.json +0 -97
  147. package/.vscode/settings.json +0 -13
  148. package/.vscode/tasks.json +0 -32
  149. package/webos-tools-cli-3.2.1.tgz +0 -0
package/bin/ares-log.js CHANGED
@@ -1,259 +1,259 @@
1
- #!/usr/bin/env node
2
-
3
- /*
4
- * Copyright (c) 2021-2024 LG Electronics Inc.
5
- *
6
- * SPDX-License-Identifier: Apache-2.0
7
- */
8
-
9
- const async = require('async'),
10
- nopt = require('nopt'),
11
- log = require('npmlog'),
12
- path = require('path'),
13
- logLib = require('./../lib/log'),
14
- commonTools = require('./../lib/base/common-tools');
15
-
16
- const version = commonTools.version,
17
- cliControl = commonTools.cliControl,
18
- help = commonTools.help,
19
- appdata = commonTools.appdata,
20
- setupDevice = commonTools.setupDevice,
21
- errHndl = commonTools.errMsg;
22
-
23
- let processName = path.basename(process.argv[1]).replace(/.js/, '');
24
-
25
- process.on('uncaughtException', function(err) {
26
- log.error('uncaughtException', err.toString());
27
- log.verbose('uncaughtException', err.stack);
28
- cliControl.end(-1);
29
- });
30
-
31
- const knownOpts = {
32
- "help": Boolean,
33
- "version": Boolean,
34
- "level": ['silly', 'verbose', 'info', 'http', 'warn', 'error'],
35
- "device": [String, null],
36
- "device-list": Boolean,
37
- // command options
38
- "switch-daemon": String,
39
- "current-daemon": Boolean,
40
- // show options
41
- "lines": Number,
42
- "reverse": Boolean,
43
- "follow": Boolean,
44
- // filter options
45
- "since": String,
46
- "until": String,
47
- "priority": String,
48
- "kernel": Boolean,
49
- "boot": Boolean,
50
- "pid": Number,
51
- // output option
52
- "output": Boolean,
53
- // save option
54
- "save": Boolean,
55
- // read options
56
- "file": String,
57
- "file-list": Boolean,
58
- // unit options
59
- "unit": String,
60
- "unit-list": Boolean,
61
- "display": [String, null],
62
- // context options
63
- "context-list": Boolean,
64
- "set-level": String,
65
- "id-filter": String
66
- };
67
-
68
- const shortHands = {
69
- // generic aliases
70
- "h": ["--help"],
71
- "V": ["--version"],
72
- "v": ["--level", "verbose"],
73
- "d": ["--device"],
74
- "D": ["--device-list"],
75
- "sd": ["--switch-daemon"],
76
- "cd": ["--current-daemon"],
77
- "n": ["--lines"],
78
- "r": ["--reverse"],
79
- "f": ["--follow"],
80
- "S": ["--since"],
81
- "U": ["--until"],
82
- "p": ["--priority"],
83
- "k": ["--dmesg"],
84
- "b": ["--boot"],
85
- "pid": ["--pid"],
86
- "o": ["--output"],
87
- "s": ["--save"],
88
- "file": ["--file"],
89
- "fl": ["--file-list"],
90
- "u": ["--unit"],
91
- "ul": ["--unit-list"],
92
- "dp": ["--display"],
93
- "cl": ["--context-list"],
94
- "sl": ["--set-level"],
95
- "id": ["--id-filter"]
96
- };
97
-
98
- const argv = nopt(knownOpts, shortHands, process.argv, 2 /* drop 'node' & 'ares-*.js'*/);
99
-
100
- log.heading = processName;
101
- log.level = argv.level || 'warn';
102
- log.verbose("argv", argv);
103
-
104
- const curConfigData = appdata.getConfig(true);
105
- if (!["ose","apollo"].includes(curConfigData.profile)) {
106
- return finish(errHndl.getErrMsg("NOT_SUPPORT_COMMOND", curConfigData.profile));
107
- }
108
-
109
- const options = {
110
- device: argv.device,
111
- display: argv.display,
112
- argv: argv
113
- };
114
-
115
- const pmLogOptions = ["follow", "lines", "context-list", "set-level", "id-filter", "save", "level", "device"],
116
- journalLogOptions = ["follow", "reverse", "lines", "since", "until", "pid", "dmesg", "boot", "output", "file",
117
- "priority", "save", "display", "level", "device", "file", "file-list", "unit", "unit-list"];
118
-
119
- let op;
120
- if (argv['device-list']) {
121
- op = deviceList;
122
- } else if (argv.version) {
123
- version.showVersionAndExit();
124
- } else if (argv.help) {
125
- const currentDaemon = appdata.getConfig().logDaemon;
126
- if (currentDaemon === "pmlogd") {
127
- processName += "-pmlogd";
128
- }
129
- help.display(processName, appdata.getConfig().profile);
130
- cliControl.end();
131
- } else if (argv['current-daemon']) {
132
- op = checkCurrentDaemon;
133
- } else if (argv['switch-daemon']) {
134
- op = switchDaemon;
135
- } else if (argv['unit-list']) {
136
- op = showUnitList;
137
- } else if (argv['file-list'] || argv.file) {
138
- op = readMode;
139
- } else if (argv['context-list'] || argv['set-level']) {
140
- op = contextMode;
141
- } else {
142
- op = showLog;
143
- }
144
-
145
- if (op) {
146
- version.checkNodeVersion(function(err) {
147
- if (err)
148
- return finish(err);
149
- async.series([
150
- op.bind(this)
151
- ],finish);
152
- });
153
- }
154
-
155
- function deviceList() {
156
- setupDevice.showDeviceList(finish);
157
- }
158
-
159
- function showLog() {
160
- log.info("showLog()");
161
-
162
- checkOption();
163
- logLib.show(options, finish);
164
- }
165
-
166
- function readMode() {
167
- log.info("readMode()");
168
-
169
- checkOption();
170
- logLib.readMode(options, finish);
171
- }
172
-
173
- function showUnitList() {
174
- log.info("showUnitList()");
175
-
176
- checkOption();
177
- logLib.printUnitList(options, finish);
178
- }
179
-
180
- function contextMode() {
181
- log.info("contextMode()");
182
-
183
- checkOption();
184
- logLib.contextMode(options, finish);
185
- }
186
-
187
- function checkCurrentDaemon() {
188
- log.info("checkCurrentDaemon()");
189
-
190
- options.currentDaemon = appdata.getConfig().logDaemon;
191
- logLib.checkLogDaemon(options, finish);
192
- }
193
-
194
- function switchDaemon() {
195
- log.info("switchDaemon()");
196
-
197
- if (curConfigData.profile === "apollo") {
198
- return finish(errHndl.getErrMsg("NOT_SUPPORT_OPTION", curConfigData.profile));
199
- }
200
-
201
- if (argv['switch-daemon'] !== "journald" && argv['switch-daemon'] !== "pmlogd") {
202
- return finish(errHndl.getErrMsg("NOT_EXIST_LOGDAEMON"));
203
- }
204
-
205
- const configData = appdata.getConfig();
206
- configData.logDaemon = argv['switch-daemon'];
207
- appdata.setConfig(configData);
208
- options.currentDaemon = configData.logDaemon;
209
-
210
- logLib.checkLogDaemon(options, finish);
211
- }
212
-
213
- function checkOption() {
214
- options.currentDaemon = appdata.getConfig(true).logDaemon;
215
- options.currentOption = Object.keys(argv);
216
- options.currentOption.splice(-1, 1);
217
-
218
- if (options.currentDaemon === "journald") {
219
- log.info("checkOption()", "journald options");
220
-
221
- options.currentOption.forEach(function(item) {
222
- if (!journalLogOptions.includes(item)) {
223
- return finish(errHndl.getErrMsg("NOT_SUPPORT_JOURNALD", item));
224
- }
225
- });
226
- } else if (options.currentDaemon === "pmlogd") {
227
- log.info("checkOption()", "pmlogd options");
228
-
229
- options.currentOption.forEach(function(item) {
230
- if (!pmLogOptions.includes(item)) {
231
- return finish(errHndl.getErrMsg("NOT_SUPPORT_PMLOGD", item));
232
- }
233
- });
234
- }
235
- }
236
-
237
- function finish(err, value) {
238
- log.info("finish()");
239
- if (err) {
240
- // handle err from getErrMsg()
241
- if (Array.isArray(err) && err.length > 0) {
242
- for (const index in err) {
243
- log.error(err[index].heading, err[index].message);
244
- }
245
- log.verbose(err[0].stack);
246
- } else {
247
- // handle general err (string & object)
248
- log.error(err.toString());
249
- log.verbose(err.stack);
250
- }
251
- cliControl.end(-1);
252
- } else {
253
- log.verbose("finish()", "value:", value);
254
- if (value && value.msg) {
255
- console.log(value.msg);
256
- }
257
- cliControl.end();
258
- }
1
+ #!/usr/bin/env node
2
+
3
+ /*
4
+ * Copyright (c) 2021-2024 LG Electronics Inc.
5
+ *
6
+ * SPDX-License-Identifier: Apache-2.0
7
+ */
8
+
9
+ const async = require('async'),
10
+ nopt = require('nopt'),
11
+ log = require('npmlog'),
12
+ path = require('path'),
13
+ logLib = require('./../lib/log'),
14
+ commonTools = require('./../lib/base/common-tools');
15
+
16
+ const version = commonTools.version,
17
+ cliControl = commonTools.cliControl,
18
+ help = commonTools.help,
19
+ appdata = commonTools.appdata,
20
+ setupDevice = commonTools.setupDevice,
21
+ errHndl = commonTools.errMsg;
22
+
23
+ let processName = path.basename(process.argv[1]).replace(/.js/, '');
24
+
25
+ process.on('uncaughtException', function(err) {
26
+ log.error('uncaughtException', err.toString());
27
+ log.verbose('uncaughtException', err.stack);
28
+ cliControl.end(-1);
29
+ });
30
+
31
+ const knownOpts = {
32
+ "help": Boolean,
33
+ "version": Boolean,
34
+ "level": ['silly', 'verbose', 'info', 'http', 'warn', 'error'],
35
+ "device": [String, null],
36
+ "device-list": Boolean,
37
+ // command options
38
+ "switch-daemon": String,
39
+ "current-daemon": Boolean,
40
+ // show options
41
+ "lines": Number,
42
+ "reverse": Boolean,
43
+ "follow": Boolean,
44
+ // filter options
45
+ "since": String,
46
+ "until": String,
47
+ "priority": String,
48
+ "kernel": Boolean,
49
+ "boot": Boolean,
50
+ "pid": Number,
51
+ // output option
52
+ "output": Boolean,
53
+ // save option
54
+ "save": Boolean,
55
+ // read options
56
+ "file": String,
57
+ "file-list": Boolean,
58
+ // unit options
59
+ "unit": String,
60
+ "unit-list": Boolean,
61
+ "display": [String, null],
62
+ // context options
63
+ "context-list": Boolean,
64
+ "set-level": String,
65
+ "id-filter": String
66
+ };
67
+
68
+ const shortHands = {
69
+ // generic aliases
70
+ "h": ["--help"],
71
+ "V": ["--version"],
72
+ "v": ["--level", "verbose"],
73
+ "d": ["--device"],
74
+ "D": ["--device-list"],
75
+ "sd": ["--switch-daemon"],
76
+ "cd": ["--current-daemon"],
77
+ "n": ["--lines"],
78
+ "r": ["--reverse"],
79
+ "f": ["--follow"],
80
+ "S": ["--since"],
81
+ "U": ["--until"],
82
+ "p": ["--priority"],
83
+ "k": ["--dmesg"],
84
+ "b": ["--boot"],
85
+ "pid": ["--pid"],
86
+ "o": ["--output"],
87
+ "s": ["--save"],
88
+ "file": ["--file"],
89
+ "fl": ["--file-list"],
90
+ "u": ["--unit"],
91
+ "ul": ["--unit-list"],
92
+ "dp": ["--display"],
93
+ "cl": ["--context-list"],
94
+ "sl": ["--set-level"],
95
+ "id": ["--id-filter"]
96
+ };
97
+
98
+ const argv = nopt(knownOpts, shortHands, process.argv, 2 /* drop 'node' & 'ares-*.js'*/);
99
+
100
+ log.heading = processName;
101
+ log.level = argv.level || 'warn';
102
+ log.verbose("argv", argv);
103
+
104
+ const curConfigData = appdata.getConfig(true);
105
+ if (!["ose","apollo"].includes(curConfigData.profile)) {
106
+ return finish(errHndl.getErrMsg("NOT_SUPPORT_COMMOND", curConfigData.profile));
107
+ }
108
+
109
+ const options = {
110
+ device: argv.device,
111
+ display: argv.display,
112
+ argv: argv
113
+ };
114
+
115
+ const pmLogOptions = ["follow", "lines", "context-list", "set-level", "id-filter", "save", "level", "device"],
116
+ journalLogOptions = ["follow", "reverse", "lines", "since", "until", "pid", "dmesg", "boot", "output", "file",
117
+ "priority", "save", "display", "level", "device", "file", "file-list", "unit", "unit-list"];
118
+
119
+ let op;
120
+ if (argv['device-list']) {
121
+ op = deviceList;
122
+ } else if (argv.version) {
123
+ version.showVersionAndExit();
124
+ } else if (argv.help) {
125
+ const currentDaemon = appdata.getConfig().logDaemon;
126
+ if (currentDaemon === "pmlogd") {
127
+ processName += "-pmlogd";
128
+ }
129
+ help.display(processName, appdata.getConfig().profile);
130
+ cliControl.end();
131
+ } else if (argv['current-daemon']) {
132
+ op = checkCurrentDaemon;
133
+ } else if (argv['switch-daemon']) {
134
+ op = switchDaemon;
135
+ } else if (argv['unit-list']) {
136
+ op = showUnitList;
137
+ } else if (argv['file-list'] || argv.file) {
138
+ op = readMode;
139
+ } else if (argv['context-list'] || argv['set-level']) {
140
+ op = contextMode;
141
+ } else {
142
+ op = showLog;
143
+ }
144
+
145
+ if (op) {
146
+ version.checkNodeVersion(function(err) {
147
+ if (err)
148
+ return finish(err);
149
+ async.series([
150
+ op.bind(this)
151
+ ],finish);
152
+ });
153
+ }
154
+
155
+ function deviceList() {
156
+ setupDevice.showDeviceList(finish);
157
+ }
158
+
159
+ function showLog() {
160
+ log.info("showLog()");
161
+
162
+ checkOption();
163
+ logLib.show(options, finish);
164
+ }
165
+
166
+ function readMode() {
167
+ log.info("readMode()");
168
+
169
+ checkOption();
170
+ logLib.readMode(options, finish);
171
+ }
172
+
173
+ function showUnitList() {
174
+ log.info("showUnitList()");
175
+
176
+ checkOption();
177
+ logLib.printUnitList(options, finish);
178
+ }
179
+
180
+ function contextMode() {
181
+ log.info("contextMode()");
182
+
183
+ checkOption();
184
+ logLib.contextMode(options, finish);
185
+ }
186
+
187
+ function checkCurrentDaemon() {
188
+ log.info("checkCurrentDaemon()");
189
+
190
+ options.currentDaemon = appdata.getConfig().logDaemon;
191
+ logLib.checkLogDaemon(options, finish);
192
+ }
193
+
194
+ function switchDaemon() {
195
+ log.info("switchDaemon()");
196
+
197
+ if (curConfigData.profile === "apollo") {
198
+ return finish(errHndl.getErrMsg("NOT_SUPPORT_OPTION", curConfigData.profile));
199
+ }
200
+
201
+ if (argv['switch-daemon'] !== "journald" && argv['switch-daemon'] !== "pmlogd") {
202
+ return finish(errHndl.getErrMsg("NOT_EXIST_LOGDAEMON"));
203
+ }
204
+
205
+ const configData = appdata.getConfig();
206
+ configData.logDaemon = argv['switch-daemon'];
207
+ appdata.setConfig(configData);
208
+ options.currentDaemon = configData.logDaemon;
209
+
210
+ logLib.checkLogDaemon(options, finish);
211
+ }
212
+
213
+ function checkOption() {
214
+ options.currentDaemon = appdata.getConfig(true).logDaemon;
215
+ options.currentOption = Object.keys(argv);
216
+ options.currentOption.splice(-1, 1);
217
+
218
+ if (options.currentDaemon === "journald") {
219
+ log.info("checkOption()", "journald options");
220
+
221
+ options.currentOption.forEach(function(item) {
222
+ if (!journalLogOptions.includes(item)) {
223
+ return finish(errHndl.getErrMsg("NOT_SUPPORT_JOURNALD", item));
224
+ }
225
+ });
226
+ } else if (options.currentDaemon === "pmlogd") {
227
+ log.info("checkOption()", "pmlogd options");
228
+
229
+ options.currentOption.forEach(function(item) {
230
+ if (!pmLogOptions.includes(item)) {
231
+ return finish(errHndl.getErrMsg("NOT_SUPPORT_PMLOGD", item));
232
+ }
233
+ });
234
+ }
235
+ }
236
+
237
+ function finish(err, value) {
238
+ log.info("finish()");
239
+ if (err) {
240
+ // handle err from getErrMsg()
241
+ if (Array.isArray(err) && err.length > 0) {
242
+ for (const index in err) {
243
+ log.error(err[index].heading, err[index].message);
244
+ }
245
+ log.verbose(err[0].stack);
246
+ } else {
247
+ // handle general err (string & object)
248
+ log.error(err.toString());
249
+ log.verbose(err.stack);
250
+ }
251
+ cliControl.end(-1);
252
+ } else {
253
+ log.verbose("finish()", "value:", value);
254
+ if (value && value.msg) {
255
+ console.log(value.msg);
256
+ }
257
+ cliControl.end();
258
+ }
259
259
  }
File without changes
File without changes