@webos-tools/cli 3.2.0 → 3.2.1

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 (152) hide show
  1. package/.eslintignore +1 -1
  2. package/.eslintrc.js +52 -52
  3. package/.vscode/c_cpp_properties.json +21 -0
  4. package/.vscode/launch.json +97 -0
  5. package/.vscode/settings.json +13 -0
  6. package/.vscode/tasks.json +32 -0
  7. package/APIs.js +79 -79
  8. package/CHANGELOG.md +11 -5
  9. package/LICENSE +201 -201
  10. package/bin/ares-config.js +1 -1
  11. package/bin/ares-device-info.js +30 -30
  12. package/bin/ares-generate.js +274 -274
  13. package/bin/ares-inspect.js +179 -179
  14. package/bin/ares-install.js +223 -223
  15. package/bin/ares-log.js +259 -259
  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 +6 -10
  20. package/bin/ares-shell.js +132 -132
  21. package/bin/ares.js +166 -166
  22. package/files/conf/ares.json +1 -2
  23. package/files/conf/ipk.json +30 -30
  24. package/files/conf/novacom-devices.json +2 -2
  25. package/files/conf/query/query-app.json +14 -14
  26. package/files/conf/query/query-hosted.json +18 -18
  27. package/files/conf/query/query-package.json +10 -10
  28. package/files/conf/query/query-service.json +6 -6
  29. package/files/conf/webos_emul +27 -27
  30. package/files/conf-base/env/sdk-apollo.json +8 -8
  31. package/files/conf-base/env/sdk-ose.json +8 -8
  32. package/files/conf-base/env/sdk-tv.json +8 -8
  33. package/files/conf-base/profile/config-apollo.json +29 -29
  34. package/files/conf-base/profile/config-ose.json +29 -29
  35. package/files/conf-base/profile/config-tv.json +31 -31
  36. package/files/conf-base/query/query-app.json +14 -14
  37. package/files/conf-base/query/query-hosted.json +18 -18
  38. package/files/conf-base/query/query-package.json +10 -10
  39. package/files/conf-base/query/query-service.json +6 -6
  40. package/files/conf-base/query/signage/query-app.json +1 -1
  41. package/files/conf-base/query/signage/query-service.json +1 -1
  42. package/files/conf-base/template-conf/ose-templates.json +67 -67
  43. package/files/conf-base/template-conf/tv-sdk-templates.json +57 -57
  44. package/files/help/ares-device.help +109 -109
  45. package/files/help/ares-install.help +95 -95
  46. package/files/help/ares-launch.help +1 -1
  47. package/files/help/ares-log-pmlogd.help +84 -84
  48. package/files/help/ares-log.help +101 -101
  49. package/files/help/ares-novacom.help +68 -68
  50. package/files/help/ares-pull.help +38 -38
  51. package/files/help/ares-push.help +38 -38
  52. package/files/help/ares-server.help +44 -44
  53. package/files/help/ares-shell.help +42 -42
  54. package/files/help/ares.help +52 -52
  55. package/files/help/readme.help +23 -23
  56. package/files/schema/ApplicationDescription.schema +319 -319
  57. package/files/templates/apollo-sdk-templates/appinfo/appinfo.json +10 -10
  58. package/files/templates/apollo-sdk-templates/bootplate-web/index.html +88 -88
  59. package/files/templates/apollo-sdk-templates/hosted-webapp/index.html +13 -13
  60. package/files/templates/apollo-sdk-templates/js-service/helloclient.js +31 -31
  61. package/files/templates/apollo-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  62. package/files/templates/apollo-sdk-templates/serviceinfo/package.json +11 -11
  63. package/files/templates/apollo-sdk-templates/serviceinfo/services.json +8 -8
  64. package/files/templates/ose-sdk-templates/appinfo/appinfo.json +10 -10
  65. package/files/templates/ose-sdk-templates/bootplate-web/index.html +88 -88
  66. package/files/templates/ose-sdk-templates/hosted-webapp/index.html +13 -13
  67. package/files/templates/ose-sdk-templates/js-service/helloclient.js +31 -31
  68. package/files/templates/ose-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  69. package/files/templates/ose-sdk-templates/qml-app/main.qml +68 -68
  70. package/files/templates/ose-sdk-templates/qmlappinfo/appinfo.json +10 -10
  71. package/files/templates/ose-sdk-templates/serviceinfo/package.json +11 -11
  72. package/files/templates/ose-sdk-templates/serviceinfo/services.json +8 -8
  73. package/files/templates/signage-sdk-templates/Backlight_Scheduling/index.html +1 -1
  74. package/files/templates/signage-sdk-templates/Backlight_Scheduling/scheduler.js +2 -3
  75. package/files/templates/signage-sdk-templates/File_Explorer/index.html +1 -33
  76. package/files/templates/signage-sdk-templates/File_Explorer/js/Root.js +0 -9
  77. package/files/templates/tv-sdk-templates/appinfo/appinfo.json +10 -10
  78. package/files/templates/tv-sdk-templates/bootplate-web/index.html +58 -58
  79. package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.10/LICENSE-2.0.txt +202 -202
  80. package/files/templates/tv-sdk-templates/hosted-webapp/index.html +14 -14
  81. package/files/templates/tv-sdk-templates/js-service/helloworld_service.js +39 -39
  82. package/files/templates/tv-sdk-templates/packageinfo/packageinfo.json +3 -3
  83. package/files/templates/tv-sdk-templates/serviceinfo/package.json +11 -11
  84. package/files/templates/tv-sdk-templates/serviceinfo/services.json +8 -8
  85. package/lib/base/ares.html +40 -40
  86. package/lib/base/cli-appdata.js +290 -289
  87. package/lib/base/cli-control.js +44 -44
  88. package/lib/base/common-tools.js +29 -29
  89. package/lib/base/error-handler.js +265 -265
  90. package/lib/base/file-watcher.js +155 -155
  91. package/lib/base/help-format.js +147 -147
  92. package/lib/base/luna.js +178 -178
  93. package/lib/base/novacom.js +4 -4
  94. package/lib/base/sdkenv.js +59 -59
  95. package/lib/base/server.js +137 -137
  96. package/lib/base/setup-device.js +2 -2
  97. package/lib/base/version-tools.js +79 -79
  98. package/lib/device.js +1419 -1419
  99. package/lib/generator.js +1 -1
  100. package/lib/inspect.js +493 -493
  101. package/lib/log.js +584 -584
  102. package/lib/package.js +61 -7
  103. package/lib/pull.js +231 -231
  104. package/lib/pusher.js +210 -210
  105. package/lib/session.js +74 -74
  106. package/lib/shell.js +193 -193
  107. package/lib/tar-filter-pack.js +62 -62
  108. package/lib/util/copy.js +31 -31
  109. package/lib/util/createFileName.js +40 -40
  110. package/lib/util/eof.js +30 -30
  111. package/lib/util/json.js +63 -63
  112. package/lib/util/merge.js +14 -14
  113. package/lib/util/objclone.js +40 -40
  114. package/lib/util/spinner.js +37 -37
  115. package/npm-shrinkwrap.json +2 -2
  116. package/package.json +1 -1
  117. package/scripts/postinstall.js +24 -24
  118. package/spec/helpers/reporter.js +65 -65
  119. package/spec/jsSpecs/apiTest/generator.spec.js +372 -372
  120. package/spec/jsSpecs/apiTest/inspector.spec.js +89 -89
  121. package/spec/jsSpecs/apiTest/installer.spec.js +67 -67
  122. package/spec/jsSpecs/apiTest/launcher.spec.js +150 -150
  123. package/spec/jsSpecs/apiTest/packager.spec.js +194 -194
  124. package/spec/jsSpecs/apiTest/puller.spec.js +101 -101
  125. package/spec/jsSpecs/apiTest/pusher.spec.js +103 -103
  126. package/spec/jsSpecs/apiTest/server.spec.js +115 -115
  127. package/spec/jsSpecs/apiTest/setupDevice.spec.js +93 -93
  128. package/spec/jsSpecs/apiTest/shell.spec.js +49 -49
  129. package/spec/jsSpecs/ares-config.spec.js +88 -88
  130. package/spec/jsSpecs/ares-device.spec.js +443 -443
  131. package/spec/jsSpecs/ares-generate.spec.js +397 -401
  132. package/spec/jsSpecs/ares-inspect.spec.js +252 -252
  133. package/spec/jsSpecs/ares-install.spec.js +150 -150
  134. package/spec/jsSpecs/ares-log.spec.js +824 -824
  135. package/spec/jsSpecs/ares-novacom.spec.js +149 -149
  136. package/spec/jsSpecs/ares-pull.spec.js +157 -157
  137. package/spec/jsSpecs/ares-push.spec.js +146 -146
  138. package/spec/jsSpecs/ares-setup-device.spec.js +1 -0
  139. package/spec/jsSpecs/ares-shell.spec.js +220 -220
  140. package/spec/jsSpecs/ares.spec.js +83 -83
  141. package/spec/support/jasmine.json +22 -22
  142. package/spec/tempFiles/nativeApp/auto/pkg_arm64/appinfo.json +9 -9
  143. package/spec/tempFiles/nativeApp/ose/pkg_arm/appinfo.json +8 -8
  144. package/spec/tempFiles/nativeApp/ose/pkg_arm/package.properties +2 -2
  145. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/appinfo.json +9 -9
  146. package/spec/tempFiles/nativeApp/rsi/pkg_x86/appinfo.json +9 -9
  147. package/spec/tempFiles/sign/sign.crt +32 -32
  148. package/spec/tempFiles/sign/signPriv.key +52 -52
  149. package/spec/test_data/ares-generate.json +58 -91
  150. package/spec/test_data/ares.json +50 -50
  151. package/webos-tools-cli-3.2.1.tgz +0 -0
  152. package/webos-tools-cli-3.2.0.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
- }
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
+ }
259
+ }