@webos-tools/cli 3.0.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.
Files changed (177) hide show
  1. package/.eslintignore +1 -0
  2. package/.eslintrc.js +52 -0
  3. package/APIs.js +79 -0
  4. package/CHANGELOG.md +110 -0
  5. package/LICENSE +201 -0
  6. package/README.md +218 -0
  7. package/bin/ares-config.js +199 -0
  8. package/bin/ares-device-info.js +30 -0
  9. package/bin/ares-device.js +219 -0
  10. package/bin/ares-generate.js +270 -0
  11. package/bin/ares-inspect.js +179 -0
  12. package/bin/ares-install.js +223 -0
  13. package/bin/ares-launch.js +318 -0
  14. package/bin/ares-log.js +255 -0
  15. package/bin/ares-novacom.js +223 -0
  16. package/bin/ares-package.js +336 -0
  17. package/bin/ares-pull.js +156 -0
  18. package/bin/ares-push.js +155 -0
  19. package/bin/ares-server.js +174 -0
  20. package/bin/ares-setup-device.js +520 -0
  21. package/bin/ares-shell.js +132 -0
  22. package/bin/ares.js +166 -0
  23. package/files/conf/ares.json +49 -0
  24. package/files/conf/command-service.json +73 -0
  25. package/files/conf/config.json +22 -0
  26. package/files/conf/ipk.json +30 -0
  27. package/files/conf/novacom-devices.json +35 -0
  28. package/files/conf/query/query-app.json +14 -0
  29. package/files/conf/query/query-hosted.json +18 -0
  30. package/files/conf/query/query-package.json +10 -0
  31. package/files/conf/query/query-service.json +6 -0
  32. package/files/conf/sdk.json +8 -0
  33. package/files/conf/template.json +57 -0
  34. package/files/conf/webos_emul +27 -0
  35. package/files/conf-base/env/sdk-ose.json +8 -0
  36. package/files/conf-base/env/sdk-tv.json +8 -0
  37. package/files/conf-base/profile/config-ose.json +21 -0
  38. package/files/conf-base/profile/config-tv.json +22 -0
  39. package/files/conf-base/query/query-app.json +14 -0
  40. package/files/conf-base/query/query-hosted.json +18 -0
  41. package/files/conf-base/query/query-package.json +10 -0
  42. package/files/conf-base/query/query-service.json +6 -0
  43. package/files/conf-base/template-conf/ose-templates.json +67 -0
  44. package/files/conf-base/template-conf/tv-sdk-templates.json +57 -0
  45. package/files/help/ares-config.help +43 -0
  46. package/files/help/ares-device.help +94 -0
  47. package/files/help/ares-generate.help +65 -0
  48. package/files/help/ares-inspect.help +70 -0
  49. package/files/help/ares-install.help +90 -0
  50. package/files/help/ares-launch.help +100 -0
  51. package/files/help/ares-log-pmlogd.help +84 -0
  52. package/files/help/ares-log.help +101 -0
  53. package/files/help/ares-novacom.help +68 -0
  54. package/files/help/ares-package.help +101 -0
  55. package/files/help/ares-pull.help +38 -0
  56. package/files/help/ares-push.help +38 -0
  57. package/files/help/ares-server.help +39 -0
  58. package/files/help/ares-setup-device.help +75 -0
  59. package/files/help/ares-shell.help +42 -0
  60. package/files/help/ares.help +47 -0
  61. package/files/help/readme.help +23 -0
  62. package/files/schema/ApplicationDescription.schema +319 -0
  63. package/files/schema/NovacomDevices.schema +61 -0
  64. package/files/templates/ose-sdk-templates/appinfo/appinfo.json +10 -0
  65. package/files/templates/ose-sdk-templates/bootplate-web/index.html +88 -0
  66. package/files/templates/ose-sdk-templates/hosted-webapp/index.html +14 -0
  67. package/files/templates/ose-sdk-templates/icon/icon.png +0 -0
  68. package/files/templates/ose-sdk-templates/js-service/helloclient.js +31 -0
  69. package/files/templates/ose-sdk-templates/js-service/helloworld_webos_service.js +188 -0
  70. package/files/templates/ose-sdk-templates/qml-app/main.qml +68 -0
  71. package/files/templates/ose-sdk-templates/qmlappinfo/appinfo.json +10 -0
  72. package/files/templates/ose-sdk-templates/serviceinfo/package.json +11 -0
  73. package/files/templates/ose-sdk-templates/serviceinfo/services.json +8 -0
  74. package/files/templates/tv-sdk-templates/appinfo/appinfo.json +10 -0
  75. package/files/templates/tv-sdk-templates/bootplate-web/index.html +58 -0
  76. package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.4/LICENSE-2.0.txt +202 -0
  77. package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.4/webOSTV-dev.js +1 -0
  78. package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.4/webOSTV.js +1 -0
  79. package/files/templates/tv-sdk-templates/hosted-webapp/index.html +14 -0
  80. package/files/templates/tv-sdk-templates/js-service/helloworld_service.js +37 -0
  81. package/files/templates/tv-sdk-templates/packageinfo/packageinfo.json +4 -0
  82. package/files/templates/tv-sdk-templates/serviceinfo/package.json +11 -0
  83. package/files/templates/tv-sdk-templates/serviceinfo/services.json +8 -0
  84. package/files/templates/tv-sdk-templates/webicon/icon.png +0 -0
  85. package/files/templates/tv-sdk-templates/webicon/largeIcon.png +0 -0
  86. package/lib/base/ares.html +40 -0
  87. package/lib/base/cli-appdata.js +289 -0
  88. package/lib/base/cli-control.js +44 -0
  89. package/lib/base/common-tools.js +29 -0
  90. package/lib/base/error-handler.js +265 -0
  91. package/lib/base/file-watcher.js +155 -0
  92. package/lib/base/help-format.js +147 -0
  93. package/lib/base/luna.js +178 -0
  94. package/lib/base/novacom.js +1191 -0
  95. package/lib/base/sdkenv.js +59 -0
  96. package/lib/base/server.js +137 -0
  97. package/lib/base/setup-device.js +324 -0
  98. package/lib/base/version-tools.js +79 -0
  99. package/lib/com.sdk.ares.hostedapp.ipk +0 -0
  100. package/lib/device.js +1419 -0
  101. package/lib/generator.js +377 -0
  102. package/lib/inspect.js +494 -0
  103. package/lib/install.js +463 -0
  104. package/lib/launch.js +605 -0
  105. package/lib/log.js +584 -0
  106. package/lib/package.js +2129 -0
  107. package/lib/pull.js +231 -0
  108. package/lib/pusher.js +210 -0
  109. package/lib/session.js +74 -0
  110. package/lib/shell.js +193 -0
  111. package/lib/tar-filter-pack.js +62 -0
  112. package/lib/util/copy.js +31 -0
  113. package/lib/util/createFileName.js +40 -0
  114. package/lib/util/eof.js +30 -0
  115. package/lib/util/json.js +63 -0
  116. package/lib/util/merge.js +14 -0
  117. package/lib/util/objclone.js +40 -0
  118. package/lib/util/spinner.js +37 -0
  119. package/npm-shrinkwrap.json +85 -0
  120. package/package.json +98 -0
  121. package/spec/helpers/reporter.js +65 -0
  122. package/spec/jsSpecs/apiTest/generator.spec.js +372 -0
  123. package/spec/jsSpecs/apiTest/inspector.spec.js +89 -0
  124. package/spec/jsSpecs/apiTest/installer.spec.js +67 -0
  125. package/spec/jsSpecs/apiTest/launcher.spec.js +150 -0
  126. package/spec/jsSpecs/apiTest/packager.spec.js +194 -0
  127. package/spec/jsSpecs/apiTest/puller.spec.js +101 -0
  128. package/spec/jsSpecs/apiTest/pusher.spec.js +103 -0
  129. package/spec/jsSpecs/apiTest/server.spec.js +115 -0
  130. package/spec/jsSpecs/apiTest/setupDevice.spec.js +93 -0
  131. package/spec/jsSpecs/apiTest/shell.spec.js +49 -0
  132. package/spec/jsSpecs/ares-config.spec.js +78 -0
  133. package/spec/jsSpecs/ares-device.spec.js +443 -0
  134. package/spec/jsSpecs/ares-generate.spec.js +397 -0
  135. package/spec/jsSpecs/ares-inspect.spec.js +252 -0
  136. package/spec/jsSpecs/ares-install.spec.js +150 -0
  137. package/spec/jsSpecs/ares-launch.spec.js +301 -0
  138. package/spec/jsSpecs/ares-log.spec.js +824 -0
  139. package/spec/jsSpecs/ares-novacom.spec.js +149 -0
  140. package/spec/jsSpecs/ares-package.spec.js +1211 -0
  141. package/spec/jsSpecs/ares-pull.spec.js +157 -0
  142. package/spec/jsSpecs/ares-push.spec.js +146 -0
  143. package/spec/jsSpecs/ares-server.spec.js +160 -0
  144. package/spec/jsSpecs/ares-setup-device.spec.js +281 -0
  145. package/spec/jsSpecs/ares-shell.spec.js +220 -0
  146. package/spec/jsSpecs/ares.spec.js +83 -0
  147. package/spec/jsSpecs/common-spec.js +169 -0
  148. package/spec/support/jasmine.json +22 -0
  149. package/spec/tempFiles/com.jasmine.native.app_0.0.1_arm.ipk +0 -0
  150. package/spec/tempFiles/com.jasmine.native.app_0.0.1_x86.ipk +0 -0
  151. package/spec/tempFiles/com.jasmine.web.app_0.0.1_all.ipk +0 -0
  152. package/spec/tempFiles/com.logtest.web.app_1.0.0_all.ipk +0 -0
  153. package/spec/tempFiles/copyFiles/helloFile.txt +1 -0
  154. package/spec/tempFiles/copyFiles/testFile.txt +1 -0
  155. package/spec/tempFiles/ipks/com.sample.echo_0.0.1_all.ipk +0 -0
  156. package/spec/tempFiles/ipks/com.web.app_1.0.0_all.ipk +0 -0
  157. package/spec/tempFiles/nativeApp/auto/pkg_arm64/GLES2 +0 -0
  158. package/spec/tempFiles/nativeApp/auto/pkg_arm64/appinfo.json +9 -0
  159. package/spec/tempFiles/nativeApp/auto/pkg_arm64/icon.png +0 -0
  160. package/spec/tempFiles/nativeApp/auto/pkg_arm64/largeIcon.png +0 -0
  161. package/spec/tempFiles/nativeApp/ose/pkg_arm/Hello +0 -0
  162. package/spec/tempFiles/nativeApp/ose/pkg_arm/appinfo.json +9 -0
  163. package/spec/tempFiles/nativeApp/ose/pkg_arm/icon.png +0 -0
  164. package/spec/tempFiles/nativeApp/ose/pkg_arm/largeIcon.png +0 -0
  165. package/spec/tempFiles/nativeApp/ose/pkg_arm/package.properties +2 -0
  166. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/Hello +0 -0
  167. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/appinfo.json +9 -0
  168. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/icon.png +0 -0
  169. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/largeIcon.png +0 -0
  170. package/spec/tempFiles/nativeApp/rsi/pkg_x86/GLES2 +0 -0
  171. package/spec/tempFiles/nativeApp/rsi/pkg_x86/appinfo.json +9 -0
  172. package/spec/tempFiles/nativeApp/rsi/pkg_x86/icon.png +0 -0
  173. package/spec/tempFiles/nativeApp/rsi/pkg_x86/largeIcon.png +0 -0
  174. package/spec/tempFiles/sign/sign.crt +32 -0
  175. package/spec/tempFiles/sign/signPriv.key +52 -0
  176. package/spec/test_data/ares-generate.json +41 -0
  177. package/spec/test_data/ares.json +33 -0
@@ -0,0 +1,155 @@
1
+ /*
2
+ * Copyright (c) 2024 LG Electronics Inc.
3
+ *
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+
7
+ const chokidar = require('chokidar');
8
+ const path = require('path');
9
+ const fs = require('fs');
10
+ const npmlog = require('npmlog');
11
+ const luna = require('./luna');
12
+ const errHndl = require('./error-handler');
13
+
14
+ (function() {
15
+ const log = npmlog;
16
+ log.heading = 'fileWatcher';
17
+ log.level = 'warn';
18
+ let isCalled = false;
19
+ const ignoreListFile = '.reloadignore';
20
+
21
+ const fileWatcher = {
22
+ /**
23
+ * @property {Object} log an npm log instance
24
+ */
25
+ log: log,
26
+
27
+ /**
28
+ * Start to watch the given path in local PC
29
+ * and relaunch the hosted app when any event is triggered
30
+ * @param {Object} options
31
+ * @property options {String} device the device to connect to
32
+ * @property options {String} directory path to watch
33
+ */
34
+ watch: function(options, params) {
35
+ log.verbose('file-watcher#watch()');
36
+ const watchDir = options.hostedurl;
37
+ const watcher = this._startWatcher(watchDir);
38
+
39
+ watcher.on('all', (event, filePath) => {
40
+ log.verbose('file-watcher#watch():', event, filePath);
41
+ if (path.basename(filePath) === ignoreListFile) {
42
+ // Close and restart watcher with modified watch option
43
+ watcher.close().then(() => {
44
+ log.verbose('file-watcher#watch():', 'ignoreListFile changed');
45
+ this.watch(options);
46
+ });
47
+ } else {
48
+ this._launch(options, params, function(err) {
49
+ if (err) {
50
+ console.log('Failed to relaunch Ares Hosted App');
51
+ log.error(err.toString());
52
+ log.verbose(err.stack);
53
+ }
54
+ return;
55
+ });
56
+ }
57
+ });
58
+
59
+ watcher.on('error', (err) => {
60
+ log.error(`Watcher error: ${err}`);
61
+ });
62
+
63
+ process.on("SIGINT", function() {
64
+ watcher.close().then(() => {
65
+ log.verbose('file-watcher#watch():', 'SIGINT is detected, watcher close', watchDir);
66
+ });
67
+ });
68
+ },
69
+
70
+ _startWatcher: function(watchDir) {
71
+ const ignoredFiles = this._readIgnoreList(watchDir);
72
+ log.verbose('file-watcher#_startWatcher():', 'ignored', ignoredFiles);
73
+ const watchOptions = {
74
+ ignored: ignoredFiles,
75
+ ignoreInitial: true
76
+ };
77
+ return chokidar.watch(watchDir, watchOptions);
78
+ },
79
+
80
+ _readIgnoreList: function(watchDir) {
81
+ const ignoreListFilePath = path.join(watchDir, ignoreListFile);
82
+ log.verbose('file-watcher#_readIgnoreList():', ignoreListFilePath);
83
+ if (fs.existsSync(ignoreListFilePath)) {
84
+ try {
85
+ // read and parse ignoreListFile into an array
86
+ const ignoreListStr = fs.readFileSync(ignoreListFilePath, 'utf-8');
87
+ log.silly('file-watcher#_readIgnoreList():', 'fs.readFileSync:', ignoreListStr);
88
+ const ignoreListArr = ignoreListStr.split(/\r?\n/);
89
+ for (let i = 0; i < ignoreListArr.length; i++) {
90
+ // check if empty
91
+ if (ignoreListArr[i] === '') {
92
+ ignoreListArr.splice(i, 1);
93
+ i--;
94
+ continue;
95
+ }
96
+ // check if path is absolute, otherwise change to absolute
97
+ if (ignoreListArr[i] && !path.isAbsolute(ignoreListArr[i])) {
98
+ if (ignoreListArr[i].indexOf('**') === 0) {
99
+ continue;
100
+ }
101
+ ignoreListArr[i] = path.join(watchDir, ignoreListArr[i]);
102
+ }
103
+ }
104
+ return ignoreListArr;
105
+ } catch (err) {
106
+ log.error(err);
107
+ return [];
108
+ }
109
+ } else {
110
+ return [];
111
+ }
112
+ },
113
+
114
+ _launch: function(options, params, next) {
115
+ if (isCalled) {
116
+ return;
117
+ } else {
118
+ isCalled = true;
119
+ }
120
+ const target = options.session.getDevice();
121
+ const addr = target.lunaAddr.launch;
122
+ const returnValue = addr.returnValue.split('.');
123
+ const param = {
124
+ // luna param
125
+ id: options.appId,
126
+ subscribe: false,
127
+ params: params
128
+ };
129
+ luna.send(options, addr, param, function(lineObj, next) {
130
+ log.silly('file-watcher#_launch():', 'Relaunch lineObj:', lineObj);
131
+ let resultValue = lineObj;
132
+
133
+ for (let index = 1; index < returnValue.length; index++) {
134
+ resultValue = resultValue[returnValue[index]];
135
+ }
136
+ if (resultValue) {
137
+ // success: stop
138
+ log.verbose('file-watcher#_launch():', 'Relaunch success');
139
+ isCalled = false;
140
+ next(null);
141
+ } else {
142
+ // failure: stop
143
+ log.verbose('file-watcher#_launch():', 'Relaunch failure');
144
+ isCalled = false;
145
+ next(errHndl.getErrMsg("INVALID_OBJECT"));
146
+ }
147
+ }, next);
148
+ },
149
+ };
150
+
151
+ if (typeof module !== 'undefined' && module.exports) {
152
+ module.exports = fileWatcher;
153
+ }
154
+
155
+ }());
@@ -0,0 +1,147 @@
1
+ /*
2
+ * Copyright (c) 2020-2024 LG Electronics Inc.
3
+ *
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+
7
+ const fs = require('fs'),
8
+ path = require('path'),
9
+ sprintf = require('sprintf-js').sprintf;
10
+
11
+ (function() {
12
+ const helpFormat = {};
13
+
14
+ helpFormat.display = function(processName, profile, hiddenFlag) {
15
+ const helpFile = path.join(__dirname, '../../files/help', processName + '.help');
16
+ let helpString = [];
17
+ this.profile = profile;
18
+
19
+ try {
20
+ const data = JSON.parse(fs.readFileSync(helpFile, 'utf8'));
21
+ data.display.forEach(function(prop) {
22
+ helpString.push("");
23
+ if (!data.notitle || data.notitle.indexOf(prop) === -1) {
24
+ helpString.push(prop.toUpperCase());
25
+ }
26
+
27
+ if (data.notab && data.notab.indexOf(prop) !== -1) {
28
+ helpString = helpString.concat(helpFormat.stringFormat(data[prop], false, hiddenFlag));
29
+ } else {
30
+ helpString = helpString.concat(helpFormat.stringFormat(data[prop], true, hiddenFlag));
31
+ }
32
+ });
33
+ helpFormat.print(helpString);
34
+ } catch (err) {
35
+ console.log(err);
36
+ throw err;
37
+ }
38
+ };
39
+
40
+ helpFormat.string = function(data, tab) {
41
+ let helpString = "";
42
+ if (data === undefined) return [];
43
+
44
+ data = data.split("@TAB@");
45
+ for (const index in data) {
46
+ if (index !== 0 || tab) {
47
+ helpString += sprintf("\t%-32s", data[index]);
48
+ } else {
49
+ helpString += sprintf(data[index]);
50
+ }
51
+ }
52
+ return [helpString];
53
+ };
54
+
55
+ helpFormat.stringArray = function(data, tab) {
56
+ let helpString = [];
57
+ for (const index in data) {
58
+ helpString = helpString.concat(helpFormat.stringFormat(data[index], tab));
59
+ }
60
+ return helpString;
61
+ };
62
+
63
+ helpFormat.optionObject = function(data, tab) {
64
+ let helpString = [],
65
+ optionList = [].concat(data.default||[]).concat(data.default-process||[]);
66
+ optionList = optionList.concat(data[this.profile]||[]).concat(data[process.platform]||[]);
67
+ for (const index in optionList) {
68
+ helpString = helpString.concat(helpFormat.stringFormat(data[optionList[index]], tab));
69
+ }
70
+ return helpString;
71
+ };
72
+
73
+ helpFormat.stringObject = function(data, tab) {
74
+ const defaultData = [].concat(data.default||[]).concat(data.default-process||[]),
75
+ currentData = [].concat(data[this.profile]||[]).concat(data[process.platform]||[]);
76
+ let helpString = [];
77
+ helpString = helpString.concat(helpFormat.stringFormat(defaultData.concat(currentData), tab));
78
+ return helpString;
79
+ };
80
+
81
+ helpFormat.hiddenObject = function(data, tab, hiddenFlag) {
82
+ return (hiddenFlag) ? helpFormat.stringObject(data, tab) : [];
83
+ };
84
+
85
+ helpFormat.stringFormat = function(data, tab, hiddenFlag) {
86
+ let helpString = [];
87
+ if (Array.isArray(data)) {
88
+ helpString = helpString.concat(helpFormat.stringArray(data, tab));
89
+ } else if (typeof data === 'object') {
90
+ if (data.cmdOpt && data.cmdOpt === 'option') {
91
+ helpString = helpString.concat(helpFormat.optionObject(data, tab));
92
+ }
93
+ else if (data.cmdOpt && data.cmdOpt === 'hidden') {
94
+ helpString = helpString.concat(helpFormat.hiddenObject(data, tab, hiddenFlag));
95
+ } else {
96
+ helpString = helpString.concat(helpFormat.stringObject(data, tab));
97
+ }
98
+ } else {
99
+ helpString = helpString.concat(helpFormat.string(data, tab));
100
+ }
101
+ return helpString;
102
+ };
103
+
104
+ helpFormat.format = function(msg) {
105
+ let helpString = "",
106
+ dependOnPlatform = false,
107
+ accept = false;
108
+ msg = [].concat(msg);
109
+
110
+ msg.forEach(function(platform) {
111
+ if (["win32", "linux", "darwin"].indexOf(platform) !== -1) {
112
+ dependOnPlatform = true;
113
+ if (platform === process.platform) {
114
+ accept = true;
115
+ }
116
+ }
117
+ });
118
+
119
+ let idx = 0;
120
+ if (dependOnPlatform === true) {
121
+ if (accept === true) {
122
+ idx = 1;
123
+ } else {
124
+ return null;
125
+ }
126
+ }
127
+
128
+ for (; idx < arguments.length; idx++) {
129
+ helpString = helpString.concat(sprintf('\t%-30s', arguments[idx]));
130
+ }
131
+ return helpString;
132
+ };
133
+
134
+ helpFormat.print = function(arrayStrHelp) {
135
+ arrayStrHelp = [].concat(arrayStrHelp);
136
+
137
+ arrayStrHelp.forEach(function(line) {
138
+ if (typeof line === 'string') {
139
+ console.log(line);
140
+ }
141
+ });
142
+ };
143
+
144
+ if (typeof module !== 'undefined' && module.exports) {
145
+ module.exports = helpFormat;
146
+ }
147
+ }());
@@ -0,0 +1,178 @@
1
+ /*
2
+ * Copyright (c) 2020-2024 LG Electronics Inc.
3
+ *
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+
7
+ const npmlog = require('npmlog'),
8
+ errHndl = require('./error-handler'),
9
+ Eof = require('../util/eof');
10
+
11
+ (function() {
12
+ const log = npmlog;
13
+ log.heading = 'luna';
14
+ log.level = 'http';
15
+
16
+ const luna = {
17
+ /**
18
+ * send a command on a luna bus
19
+ * @property options {novacom.Session} session
20
+ * @param {Object} options
21
+ * @param {Object} addr
22
+ * @property addr {String} service luna service name
23
+ * @property addr {String} [folder] containing folder of the requested method
24
+ * @property addr {String} method the luna method to invoke
25
+ * @param {Object} param the unique luna parameter
26
+ * @param {Function} onResponse the callback invoked at each JSON object received from luna-send
27
+ * @property onResponse {Object} obj the JSON object received
28
+ * @property onResponse {Function} next a common-js callback
29
+ * @param next {Function} next a common-js callback
30
+ */
31
+ send: function(options, addr, param, onResponse, next) {
32
+ const session = options && options.session;
33
+ // 'is' is used to transmit an EOF to
34
+ // terminate the remote luna-send. this is
35
+ // the only way to terminate an interactive
36
+ // request 'luna-send -i'...
37
+ const is = new Eof(),
38
+ url = ['luna:/', addr.service, addr.folder, addr.method].join('/');
39
+ let result, mode, sessionCall = "";
40
+
41
+ is.pause();
42
+ if (options && options.nReplies) {
43
+ mode = "-n " + options.nReplies + " ";
44
+ } else {
45
+ mode = "-i ";
46
+ }
47
+
48
+ if (options && options.sessionCall && options.sessionId) {
49
+ sessionCall = "-c " + options.sessionId + " ";
50
+ }
51
+
52
+ log.verbose("luna#send()", "calling:", mode + sessionCall + url + " '" + JSON.stringify(param) + "'");
53
+ session.run(session.getDevice().lunaSend + " " + mode + sessionCall + url + " '" + JSON.stringify(param) + "'", is /* stdin*/, _onData, process.stderr, function(err) {
54
+ if (err) {
55
+ next(err);
56
+ }
57
+ // success when the output of the
58
+ // command is correctly interpreted,
59
+ // not simply when the command exit
60
+ // with a success exit code.
61
+ });
62
+
63
+ let jsonLine = "";
64
+
65
+ // Break string into lines (JSON.parse needs a
66
+ // single object per call).
67
+ function _onData(data) {
68
+ let str;
69
+ if (Buffer.isBuffer(data)) {
70
+ str = data.toString();
71
+ } else {
72
+ str = data;
73
+ }
74
+ str.split(/\r?\n/).forEach(_onLine);
75
+ }
76
+
77
+ function _onLine(line) {
78
+ jsonLine += line;
79
+
80
+ try {
81
+ result = JSON.parse(jsonLine);
82
+ log.verbose('luna#send()', 'response:', result);
83
+
84
+ jsonLine = "";
85
+ if (result.returnValue === false) {
86
+ is.destroy();
87
+ const errValue = (result.errorText ? result.errorText :
88
+ (result.errorMessage ? result.errorMessage : ''));
89
+ next(errHndl.getErrMsg("FAILED_CALL_LUNA", errValue, null, addr.service));
90
+ } else {
91
+ onResponse(result, function(err, value) {
92
+ log.silly('luna#send()', "err:", err, ", value:", value);
93
+ if (err || value) {
94
+ log.silly('luna#send()', "closing exec stream");
95
+ // processing completed or failed
96
+ next(err, value);
97
+ }
98
+ });
99
+ }
100
+ } catch(e) {
101
+ // ignore the parsing error:
102
+ // the line may be incomplete
103
+ // & not yet JSON-parseable
104
+ }
105
+ }
106
+ },
107
+ sendWithoutErrorHandle: function(options, addr, param, onResponse, next) {
108
+ const session = options && options.session;
109
+ // 'is' is used to transmit an EOF to
110
+ // terminate the remote luna-send. this is
111
+ // the only way to terminate an interactive
112
+ // request 'luna-send -i'...
113
+ const is = new Eof(),
114
+ url = ['luna:/', addr.service, addr.folder, addr.method].join('/');
115
+ let result, mode;
116
+
117
+ is.pause();
118
+ if (options && options.nReplies) {
119
+ mode = "-n " + options.nReplies + " ";
120
+ } else {
121
+ mode = "-i ";
122
+ }
123
+
124
+ log.verbose("luna#sendWithoutErrorHandle()", "calling:", url + " '" + JSON.stringify(param) + "'");
125
+ session.run(session.getDevice().lunaSend + " " + mode + url + " '" + JSON.stringify(param) + "'", is /* stdin*/, _onData, process.stderr, function(err) {
126
+ if (err) {
127
+ next(err);
128
+ }
129
+ // success when the output of the
130
+ // command is correctly interpreted,
131
+ // not simply when the command exit
132
+ // with a success exit code.
133
+ });
134
+
135
+ let jsonLine = "";
136
+
137
+ // Break string into lines (JSON.parse needs a
138
+ // single object per call).
139
+ function _onData(data) {
140
+ let str;
141
+ if (Buffer.isBuffer(data)) {
142
+ str = data.toString();
143
+ } else {
144
+ str = data;
145
+ }
146
+ str.split(/\r?\n/).forEach(_onLine);
147
+ }
148
+
149
+ function _onLine(line) {
150
+ jsonLine += line;
151
+
152
+ try {
153
+ result = JSON.parse(jsonLine);
154
+ log.verbose('luna#sendWithoutErrorHandle()', 'response:', result);
155
+
156
+ jsonLine = "";
157
+ onResponse(result, function(err, value) {
158
+ log.silly('luna#sendWithoutErrorHandle()', "err:", err, ", value:", value);
159
+ if (err || value) {
160
+ log.silly('luna#sendWithoutErrorHandle()', "closing exec stream");
161
+ // processing completed or failed
162
+ next(err, value);
163
+ }
164
+ });
165
+ } catch(e) {
166
+ // ignore the parsing error:
167
+ // the line may be incomplete
168
+ // & not yet JSON-parseable
169
+ }
170
+ }
171
+ }
172
+ };
173
+
174
+ if (typeof module !== 'undefined' && module.exports) {
175
+ module.exports = luna;
176
+ }
177
+ }());
178
+