@webos-tools/cli 3.0.3 → 3.0.5
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/.eslintignore +1 -1
- package/.eslintrc.js +52 -52
- package/APIs.js +79 -79
- package/CHANGELOG.md +128 -123
- package/LICENSE +201 -201
- package/README.md +218 -218
- package/bin/ares-config.js +199 -199
- package/bin/ares-device-info.js +30 -30
- package/bin/ares-device.js +219 -219
- package/bin/ares-generate.js +270 -270
- package/bin/ares-inspect.js +179 -179
- package/bin/ares-install.js +223 -223
- package/bin/ares-launch.js +318 -318
- package/bin/ares-log.js +255 -255
- package/bin/ares-novacom.js +223 -223
- package/bin/ares-package.js +336 -336
- package/bin/ares-pull.js +156 -156
- package/bin/ares-push.js +155 -155
- package/bin/ares-server.js +174 -174
- package/bin/ares-setup-device.js +520 -520
- package/bin/ares-shell.js +132 -132
- package/bin/ares.js +166 -166
- package/files/conf/ares.json +49 -49
- package/files/conf/command-service.json +73 -73
- package/files/conf/config.json +22 -22
- package/files/conf/ipk.json +30 -30
- package/files/conf/novacom-devices.json +35 -35
- package/files/conf/query/query-app.json +14 -14
- package/files/conf/query/query-hosted.json +18 -18
- package/files/conf/query/query-package.json +10 -10
- package/files/conf/query/query-service.json +6 -6
- package/files/conf/sdk.json +8 -8
- package/files/conf/template.json +57 -57
- package/files/conf/webos_emul +27 -27
- package/files/conf-base/env/sdk-ose.json +8 -8
- package/files/conf-base/env/sdk-tv.json +8 -8
- package/files/conf-base/profile/config-ose.json +21 -21
- package/files/conf-base/profile/config-tv.json +22 -22
- package/files/conf-base/query/query-app.json +14 -14
- package/files/conf-base/query/query-hosted.json +18 -18
- package/files/conf-base/query/query-package.json +10 -10
- package/files/conf-base/query/query-service.json +6 -6
- package/files/conf-base/template-conf/ose-templates.json +67 -67
- package/files/conf-base/template-conf/tv-sdk-templates.json +57 -57
- package/files/help/ares-config.help +43 -43
- package/files/help/ares-device.help +94 -94
- package/files/help/ares-generate.help +65 -65
- package/files/help/ares-inspect.help +70 -70
- package/files/help/ares-install.help +90 -90
- package/files/help/ares-launch.help +100 -100
- package/files/help/ares-log-pmlogd.help +84 -84
- package/files/help/ares-log.help +101 -101
- package/files/help/ares-novacom.help +68 -68
- package/files/help/ares-package.help +101 -101
- package/files/help/ares-pull.help +38 -38
- package/files/help/ares-push.help +38 -38
- package/files/help/ares-server.help +39 -39
- package/files/help/ares-setup-device.help +75 -75
- package/files/help/ares-shell.help +42 -42
- package/files/help/ares.help +47 -47
- package/files/help/readme.help +23 -23
- package/files/schema/ApplicationDescription.schema +319 -319
- package/files/schema/NovacomDevices.schema +61 -61
- package/files/templates/ose-sdk-templates/appinfo/appinfo.json +10 -10
- package/files/templates/ose-sdk-templates/bootplate-web/index.html +88 -88
- package/files/templates/ose-sdk-templates/hosted-webapp/index.html +13 -13
- package/files/templates/ose-sdk-templates/icon/icon.png +0 -0
- package/files/templates/ose-sdk-templates/js-service/helloclient.js +31 -31
- package/files/templates/ose-sdk-templates/js-service/helloworld_webos_service.js +188 -188
- package/files/templates/ose-sdk-templates/qml-app/main.qml +68 -68
- package/files/templates/ose-sdk-templates/qmlappinfo/appinfo.json +10 -10
- package/files/templates/ose-sdk-templates/serviceinfo/package.json +11 -11
- package/files/templates/ose-sdk-templates/serviceinfo/services.json +8 -8
- package/files/templates/tv-sdk-templates/appinfo/appinfo.json +10 -10
- package/files/templates/tv-sdk-templates/bootplate-web/index.html +58 -58
- package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.10/LICENSE-2.0.txt +202 -202
- package/files/templates/tv-sdk-templates/hosted-webapp/index.html +14 -14
- package/files/templates/tv-sdk-templates/js-service/helloworld_service.js +39 -39
- package/files/templates/tv-sdk-templates/packageinfo/packageinfo.json +3 -3
- package/files/templates/tv-sdk-templates/serviceinfo/package.json +11 -11
- package/files/templates/tv-sdk-templates/serviceinfo/services.json +8 -8
- package/files/templates/tv-sdk-templates/webicon/icon.png +0 -0
- package/files/templates/tv-sdk-templates/webicon/largeIcon.png +0 -0
- package/lib/base/ares.html +40 -40
- package/lib/base/cli-appdata.js +290 -301
- package/lib/base/cli-control.js +44 -44
- package/lib/base/common-tools.js +29 -29
- package/lib/base/error-handler.js +265 -265
- package/lib/base/file-watcher.js +155 -155
- package/lib/base/help-format.js +147 -147
- package/lib/base/luna.js +178 -178
- package/lib/base/novacom.js +1191 -1191
- package/lib/base/sdkenv.js +59 -59
- package/lib/base/server.js +137 -137
- package/lib/base/setup-device.js +328 -328
- package/lib/base/version-tools.js +79 -79
- package/lib/device.js +1419 -1419
- package/lib/generator.js +377 -377
- package/lib/inspect.js +494 -494
- package/lib/install.js +463 -463
- package/lib/launch.js +605 -605
- package/lib/log.js +584 -584
- package/lib/package.js +2129 -2129
- package/lib/pull.js +231 -231
- package/lib/pusher.js +210 -210
- package/lib/session.js +74 -74
- package/lib/shell.js +193 -193
- package/lib/tar-filter-pack.js +62 -62
- package/lib/util/copy.js +31 -31
- package/lib/util/createFileName.js +40 -40
- package/lib/util/eof.js +30 -30
- package/lib/util/json.js +63 -63
- package/lib/util/merge.js +14 -14
- package/lib/util/objclone.js +40 -40
- package/lib/util/spinner.js +37 -37
- package/npm-shrinkwrap.json +9115 -9115
- package/package.json +100 -97
- package/scripts/postinstall.js +24 -0
- package/spec/helpers/reporter.js +65 -65
- package/spec/jsSpecs/apiTest/generator.spec.js +372 -372
- package/spec/jsSpecs/apiTest/inspector.spec.js +89 -89
- package/spec/jsSpecs/apiTest/installer.spec.js +67 -67
- package/spec/jsSpecs/apiTest/launcher.spec.js +150 -150
- package/spec/jsSpecs/apiTest/packager.spec.js +194 -194
- package/spec/jsSpecs/apiTest/puller.spec.js +101 -101
- package/spec/jsSpecs/apiTest/pusher.spec.js +103 -103
- package/spec/jsSpecs/apiTest/server.spec.js +115 -115
- package/spec/jsSpecs/apiTest/setupDevice.spec.js +93 -93
- package/spec/jsSpecs/apiTest/shell.spec.js +49 -49
- package/spec/jsSpecs/ares-config.spec.js +78 -78
- package/spec/jsSpecs/ares-device.spec.js +443 -443
- package/spec/jsSpecs/ares-generate.spec.js +397 -397
- package/spec/jsSpecs/ares-inspect.spec.js +252 -252
- package/spec/jsSpecs/ares-install.spec.js +150 -150
- package/spec/jsSpecs/ares-launch.spec.js +301 -301
- package/spec/jsSpecs/ares-log.spec.js +824 -824
- package/spec/jsSpecs/ares-novacom.spec.js +149 -149
- package/spec/jsSpecs/ares-package.spec.js +1211 -1211
- package/spec/jsSpecs/ares-pull.spec.js +157 -157
- package/spec/jsSpecs/ares-push.spec.js +146 -146
- package/spec/jsSpecs/ares-server.spec.js +160 -160
- package/spec/jsSpecs/ares-setup-device.spec.js +281 -281
- package/spec/jsSpecs/ares-shell.spec.js +220 -220
- package/spec/jsSpecs/ares.spec.js +83 -83
- package/spec/jsSpecs/common-spec.js +169 -169
- package/spec/support/jasmine.json +22 -22
- package/spec/tempFiles/nativeApp/auto/pkg_arm64/GLES2 +0 -0
- package/spec/tempFiles/nativeApp/auto/pkg_arm64/appinfo.json +9 -9
- package/spec/tempFiles/nativeApp/ose/pkg_arm/Hello +0 -0
- package/spec/tempFiles/nativeApp/ose/pkg_arm/appinfo.json +8 -8
- package/spec/tempFiles/nativeApp/ose/pkg_arm/package.properties +2 -2
- package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/Hello +0 -0
- package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/appinfo.json +9 -9
- package/spec/tempFiles/nativeApp/rsi/pkg_x86/GLES2 +0 -0
- package/spec/tempFiles/nativeApp/rsi/pkg_x86/appinfo.json +9 -9
- package/spec/tempFiles/sign/sign.crt +32 -32
- package/spec/tempFiles/sign/signPriv.key +52 -52
- package/spec/test_data/ares-generate.json +41 -41
- package/spec/test_data/ares.json +33 -33
package/bin/ares-generate.js
CHANGED
|
@@ -1,270 +1,270 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
/*
|
|
4
|
-
* Copyright (c) 2020-2024 LG Electronics Inc.
|
|
5
|
-
*
|
|
6
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
const async = require('async'),
|
|
10
|
-
inquirer = require('inquirer'),
|
|
11
|
-
nopt = require('nopt'),
|
|
12
|
-
log = require('npmlog'),
|
|
13
|
-
path = require('path'),
|
|
14
|
-
GeneratorLib = require('./../lib/generator'),
|
|
15
|
-
commonTools = require('./../lib/base/common-tools'),
|
|
16
|
-
readJsonSync = require('./../lib/util/json').readJsonSync;
|
|
17
|
-
|
|
18
|
-
const cliControl = commonTools.cliControl,
|
|
19
|
-
version = commonTools.version,
|
|
20
|
-
help = commonTools.help,
|
|
21
|
-
appdata = commonTools.appdata,
|
|
22
|
-
errHndl = commonTools.errMsg;
|
|
23
|
-
|
|
24
|
-
const processName = path.basename(process.argv[1]).replace(/.js/, '');
|
|
25
|
-
|
|
26
|
-
process.on('uncaughtException', function(err) {
|
|
27
|
-
log.error('uncaughtException', err.toString());
|
|
28
|
-
log.verbose('uncaughtException', err.stack);
|
|
29
|
-
cliControl.end(-1);
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
if (process.argv.length === 2) {
|
|
33
|
-
process.argv.splice(2, 0, '--help');
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
let idx;
|
|
37
|
-
if ((idx = process.argv.indexOf('--list')) !== -1 || (idx = process.argv.indexOf('-l')) !== -1) {
|
|
38
|
-
if (process.argv[idx+1] && process.argv[idx+1].toString().match(/^-/)) {
|
|
39
|
-
process.argv.splice(idx+1, 0, 'true');
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
const knownOpts = {
|
|
44
|
-
"help": Boolean,
|
|
45
|
-
"version": Boolean,
|
|
46
|
-
"list": String,
|
|
47
|
-
"overwrite": Boolean,
|
|
48
|
-
"servicename": String,
|
|
49
|
-
"template": String,
|
|
50
|
-
"property": [String, Array],
|
|
51
|
-
"no-query": Boolean,
|
|
52
|
-
"level": ['silly', 'verbose', 'info', 'http', 'warn', 'error']
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
const shortHands = {
|
|
56
|
-
"h": "--help",
|
|
57
|
-
"V": "--version",
|
|
58
|
-
"l": "--list",
|
|
59
|
-
"f": "--overwrite",
|
|
60
|
-
"t": "--template",
|
|
61
|
-
"p": "--property",
|
|
62
|
-
"s": "--servicename",
|
|
63
|
-
"nq": "--no-query",
|
|
64
|
-
"v": ["--level", "verbose"]
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
const argv = nopt(knownOpts, shortHands, process.argv, 2 /* drop 'node' & 'ares-*.js' */);
|
|
68
|
-
|
|
69
|
-
log.heading = processName;
|
|
70
|
-
log.level = argv.level || 'warn';
|
|
71
|
-
log.verbose("argv", argv);
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
* For consistent of "$command -v", argv is used.
|
|
75
|
-
* By nopt, argv is parsed and set key-value in argv object.
|
|
76
|
-
* If -v or --level option is input with command, it is set key-value in argv.
|
|
77
|
-
* After it is deleted, If remained key is only one in argv object
|
|
78
|
-
* (If any other are remained, it's mean another options is input)
|
|
79
|
-
* and there is no remaining after parsing the input command by nopt
|
|
80
|
-
* (If any other are remained, it's mean another parameters ares input),
|
|
81
|
-
* each command of webOS CLI print help message with log message.
|
|
82
|
-
*/
|
|
83
|
-
if (argv.level) {
|
|
84
|
-
delete argv.level;
|
|
85
|
-
if (argv.argv.remain.length === 0 && (Object.keys(argv)).length === 1) {
|
|
86
|
-
argv.help = true;
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
const config = appdata.getConfig(true),
|
|
91
|
-
options = {
|
|
92
|
-
tmplFile: path.join(__dirname, '/../files/conf/', 'template.json'),
|
|
93
|
-
overwrite: argv.overwrite,
|
|
94
|
-
tmplName: argv.template,
|
|
95
|
-
listType: argv.list,
|
|
96
|
-
props: argv.property || [],
|
|
97
|
-
appinfo: {},
|
|
98
|
-
pkginfo: {},
|
|
99
|
-
svcinfo: {},
|
|
100
|
-
svcName: argv.servicename,
|
|
101
|
-
query: ((Object.hasOwnProperty.call(argv, 'query')) ? argv.query : true),
|
|
102
|
-
out: argv.argv.remain[0]
|
|
103
|
-
};
|
|
104
|
-
|
|
105
|
-
let op,
|
|
106
|
-
generator;
|
|
107
|
-
if (argv.help) {
|
|
108
|
-
showUsage();
|
|
109
|
-
cliControl.end();
|
|
110
|
-
} else if (argv.version) {
|
|
111
|
-
version.showVersionAndExit();
|
|
112
|
-
} else if (argv.list) {
|
|
113
|
-
op = list;
|
|
114
|
-
} else {
|
|
115
|
-
op = generate;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
if (op) {
|
|
119
|
-
version.checkNodeVersion(function() {
|
|
120
|
-
async.series([
|
|
121
|
-
op.bind(this)
|
|
122
|
-
],finish);
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
function showUsage(hiddenFlag) {
|
|
127
|
-
if (hiddenFlag) {
|
|
128
|
-
help.display(processName, appdata.getConfig(true).profile, hiddenFlag);
|
|
129
|
-
} else {
|
|
130
|
-
help.display(processName, appdata.getConfig(true).profile);
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
function getGenerator() {
|
|
135
|
-
if (!generator) {
|
|
136
|
-
generator = new GeneratorLib();
|
|
137
|
-
}
|
|
138
|
-
return generator;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
function list() {
|
|
142
|
-
const gen = getGenerator();
|
|
143
|
-
gen.showTemplates(options.listType, finish);
|
|
144
|
-
cliControl.end();
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
function getQueryFile(profile, type) {
|
|
148
|
-
const fileName = "query-"+ type + ".json";
|
|
149
|
-
const queryFile = path.join(__dirname, "../files/conf/query", fileName);
|
|
150
|
-
return queryFile;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
function queryInfo(queryFile) {
|
|
154
|
-
const queries = readJsonSync(queryFile);
|
|
155
|
-
const questions = [];
|
|
156
|
-
for (const q in queries) {
|
|
157
|
-
const question = {};
|
|
158
|
-
question.type = "input";
|
|
159
|
-
question.name = q;
|
|
160
|
-
question.message = queries[q].query;
|
|
161
|
-
question.default = queries[q].default;
|
|
162
|
-
questions.push(question);
|
|
163
|
-
}
|
|
164
|
-
return inquirer.prompt(questions, function(answers) {
|
|
165
|
-
return answers;
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
function generate() {
|
|
170
|
-
const gen = getGenerator();
|
|
171
|
-
const templates = gen.getTmpl();
|
|
172
|
-
|
|
173
|
-
if (options.tmplName === "true") {
|
|
174
|
-
return finish(errHndl.getErrMsg("EMPTY_VALUE", "TEMPLATE"));
|
|
175
|
-
}
|
|
176
|
-
if (!options.out) {
|
|
177
|
-
return finish(errHndl.getErrMsg("EMPTY_VALUE", "APP_DIR"));
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
Promise.resolve()
|
|
181
|
-
.then(function() {
|
|
182
|
-
const overwrite = !!options.overwrite,
|
|
183
|
-
useInquirer = !!options.query,
|
|
184
|
-
dest = path.resolve(options.out),
|
|
185
|
-
existDir = gen.existOutDir(dest);
|
|
186
|
-
|
|
187
|
-
const questions = [{
|
|
188
|
-
type: "confirm",
|
|
189
|
-
name: "overwrite",
|
|
190
|
-
message: "The directory already exists. The template files in the directory will be replaced. Continue?",
|
|
191
|
-
default: false,
|
|
192
|
-
when: function() {
|
|
193
|
-
return !overwrite && useInquirer && existDir;
|
|
194
|
-
}
|
|
195
|
-
}];
|
|
196
|
-
return inquirer.prompt(questions).then(function(answers) {
|
|
197
|
-
options.overwrite = answers.overwrite || options.overwrite;
|
|
198
|
-
if (existDir && !options.overwrite) {
|
|
199
|
-
throw errHndl.getErrMsg("NOT_OVERWRITE_DIR", dest);
|
|
200
|
-
}
|
|
201
|
-
});
|
|
202
|
-
})
|
|
203
|
-
.then(function() {
|
|
204
|
-
const template = templates[options.tmplName];
|
|
205
|
-
if (!template) throw errHndl.getErrMsg("INVALID_VALUE", "TEMPLATE", options.tmplName);
|
|
206
|
-
if (!template.type) {
|
|
207
|
-
return;
|
|
208
|
-
}
|
|
209
|
-
// query mode, only CLI can approach. API only use props
|
|
210
|
-
if (!options.props.length) {
|
|
211
|
-
if (options.query && options.tmplName.match(/(^hosted)/)) {
|
|
212
|
-
const queryConfigFile = getQueryFile(config.profile, 'hosted');
|
|
213
|
-
return queryInfo(queryConfigFile).then(function(info) {
|
|
214
|
-
for (const i in info) {
|
|
215
|
-
options.appinfo[i] = info[i];
|
|
216
|
-
}
|
|
217
|
-
});
|
|
218
|
-
} else if (options.query && template.type.match(/(app$|appinfo$)/)) {
|
|
219
|
-
const queryConfigFile = getQueryFile(config.profile, 'app');
|
|
220
|
-
return queryInfo(queryConfigFile).then(function(info) {
|
|
221
|
-
for (const i in info) {
|
|
222
|
-
options.appinfo[i] = info[i];
|
|
223
|
-
}
|
|
224
|
-
});
|
|
225
|
-
} else if (options.query && !options.svcName &&
|
|
226
|
-
template.type.match(/(service$|serviceinfo$)/)) {
|
|
227
|
-
const queryConfigFile = getQueryFile(config.profile, 'service');
|
|
228
|
-
return queryInfo(queryConfigFile).then(function(info) {
|
|
229
|
-
// FIXME: hard-coded considering info.id is servicename
|
|
230
|
-
if (info.id) options.svcName = info.id;
|
|
231
|
-
});
|
|
232
|
-
} else if (options.query && template.type.match(/(package$|packageinfo$)/)) {
|
|
233
|
-
const queryConfigFile = getQueryFile(config.profile, 'package');
|
|
234
|
-
return queryInfo(queryConfigFile).then(function(info) {
|
|
235
|
-
for (const i in info) {
|
|
236
|
-
options.pkginfo[i] = info[i];
|
|
237
|
-
}
|
|
238
|
-
});
|
|
239
|
-
}
|
|
240
|
-
}})
|
|
241
|
-
.then(function() {
|
|
242
|
-
gen.generate(options, finish);
|
|
243
|
-
})
|
|
244
|
-
.catch(function(err) {
|
|
245
|
-
finish(err);
|
|
246
|
-
});
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
function finish(err, value) {
|
|
250
|
-
log.info("finish()");
|
|
251
|
-
if (err) {
|
|
252
|
-
// handle err from getErrMsg()
|
|
253
|
-
if (Array.isArray(err) && err.length > 0) {
|
|
254
|
-
for (const index in err) {
|
|
255
|
-
log.error(err[index].heading, err[index].message);
|
|
256
|
-
}
|
|
257
|
-
log.verbose(err[0].stack);
|
|
258
|
-
} else {
|
|
259
|
-
// handle general err (string & object)
|
|
260
|
-
log.error(err.toString());
|
|
261
|
-
log.verbose(err.stack);
|
|
262
|
-
}
|
|
263
|
-
cliControl.end(-1);
|
|
264
|
-
} else {
|
|
265
|
-
log.verbose("finish()", "value:", value);
|
|
266
|
-
if (value && value.msg) {
|
|
267
|
-
console.log(value.msg);
|
|
268
|
-
}
|
|
269
|
-
}
|
|
270
|
-
}
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
/*
|
|
4
|
+
* Copyright (c) 2020-2024 LG Electronics Inc.
|
|
5
|
+
*
|
|
6
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
const async = require('async'),
|
|
10
|
+
inquirer = require('inquirer'),
|
|
11
|
+
nopt = require('nopt'),
|
|
12
|
+
log = require('npmlog'),
|
|
13
|
+
path = require('path'),
|
|
14
|
+
GeneratorLib = require('./../lib/generator'),
|
|
15
|
+
commonTools = require('./../lib/base/common-tools'),
|
|
16
|
+
readJsonSync = require('./../lib/util/json').readJsonSync;
|
|
17
|
+
|
|
18
|
+
const cliControl = commonTools.cliControl,
|
|
19
|
+
version = commonTools.version,
|
|
20
|
+
help = commonTools.help,
|
|
21
|
+
appdata = commonTools.appdata,
|
|
22
|
+
errHndl = commonTools.errMsg;
|
|
23
|
+
|
|
24
|
+
const processName = path.basename(process.argv[1]).replace(/.js/, '');
|
|
25
|
+
|
|
26
|
+
process.on('uncaughtException', function(err) {
|
|
27
|
+
log.error('uncaughtException', err.toString());
|
|
28
|
+
log.verbose('uncaughtException', err.stack);
|
|
29
|
+
cliControl.end(-1);
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
if (process.argv.length === 2) {
|
|
33
|
+
process.argv.splice(2, 0, '--help');
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
let idx;
|
|
37
|
+
if ((idx = process.argv.indexOf('--list')) !== -1 || (idx = process.argv.indexOf('-l')) !== -1) {
|
|
38
|
+
if (process.argv[idx+1] && process.argv[idx+1].toString().match(/^-/)) {
|
|
39
|
+
process.argv.splice(idx+1, 0, 'true');
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const knownOpts = {
|
|
44
|
+
"help": Boolean,
|
|
45
|
+
"version": Boolean,
|
|
46
|
+
"list": String,
|
|
47
|
+
"overwrite": Boolean,
|
|
48
|
+
"servicename": String,
|
|
49
|
+
"template": String,
|
|
50
|
+
"property": [String, Array],
|
|
51
|
+
"no-query": Boolean,
|
|
52
|
+
"level": ['silly', 'verbose', 'info', 'http', 'warn', 'error']
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
const shortHands = {
|
|
56
|
+
"h": "--help",
|
|
57
|
+
"V": "--version",
|
|
58
|
+
"l": "--list",
|
|
59
|
+
"f": "--overwrite",
|
|
60
|
+
"t": "--template",
|
|
61
|
+
"p": "--property",
|
|
62
|
+
"s": "--servicename",
|
|
63
|
+
"nq": "--no-query",
|
|
64
|
+
"v": ["--level", "verbose"]
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
const argv = nopt(knownOpts, shortHands, process.argv, 2 /* drop 'node' & 'ares-*.js' */);
|
|
68
|
+
|
|
69
|
+
log.heading = processName;
|
|
70
|
+
log.level = argv.level || 'warn';
|
|
71
|
+
log.verbose("argv", argv);
|
|
72
|
+
|
|
73
|
+
/**
|
|
74
|
+
* For consistent of "$command -v", argv is used.
|
|
75
|
+
* By nopt, argv is parsed and set key-value in argv object.
|
|
76
|
+
* If -v or --level option is input with command, it is set key-value in argv.
|
|
77
|
+
* After it is deleted, If remained key is only one in argv object
|
|
78
|
+
* (If any other are remained, it's mean another options is input)
|
|
79
|
+
* and there is no remaining after parsing the input command by nopt
|
|
80
|
+
* (If any other are remained, it's mean another parameters ares input),
|
|
81
|
+
* each command of webOS CLI print help message with log message.
|
|
82
|
+
*/
|
|
83
|
+
if (argv.level) {
|
|
84
|
+
delete argv.level;
|
|
85
|
+
if (argv.argv.remain.length === 0 && (Object.keys(argv)).length === 1) {
|
|
86
|
+
argv.help = true;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
const config = appdata.getConfig(true),
|
|
91
|
+
options = {
|
|
92
|
+
tmplFile: path.join(__dirname, '/../files/conf/', 'template.json'),
|
|
93
|
+
overwrite: argv.overwrite,
|
|
94
|
+
tmplName: argv.template,
|
|
95
|
+
listType: argv.list,
|
|
96
|
+
props: argv.property || [],
|
|
97
|
+
appinfo: {},
|
|
98
|
+
pkginfo: {},
|
|
99
|
+
svcinfo: {},
|
|
100
|
+
svcName: argv.servicename,
|
|
101
|
+
query: ((Object.hasOwnProperty.call(argv, 'query')) ? argv.query : true),
|
|
102
|
+
out: argv.argv.remain[0]
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
let op,
|
|
106
|
+
generator;
|
|
107
|
+
if (argv.help) {
|
|
108
|
+
showUsage();
|
|
109
|
+
cliControl.end();
|
|
110
|
+
} else if (argv.version) {
|
|
111
|
+
version.showVersionAndExit();
|
|
112
|
+
} else if (argv.list) {
|
|
113
|
+
op = list;
|
|
114
|
+
} else {
|
|
115
|
+
op = generate;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
if (op) {
|
|
119
|
+
version.checkNodeVersion(function() {
|
|
120
|
+
async.series([
|
|
121
|
+
op.bind(this)
|
|
122
|
+
],finish);
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
function showUsage(hiddenFlag) {
|
|
127
|
+
if (hiddenFlag) {
|
|
128
|
+
help.display(processName, appdata.getConfig(true).profile, hiddenFlag);
|
|
129
|
+
} else {
|
|
130
|
+
help.display(processName, appdata.getConfig(true).profile);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
function getGenerator() {
|
|
135
|
+
if (!generator) {
|
|
136
|
+
generator = new GeneratorLib();
|
|
137
|
+
}
|
|
138
|
+
return generator;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
function list() {
|
|
142
|
+
const gen = getGenerator();
|
|
143
|
+
gen.showTemplates(options.listType, finish);
|
|
144
|
+
cliControl.end();
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
function getQueryFile(profile, type) {
|
|
148
|
+
const fileName = "query-"+ type + ".json";
|
|
149
|
+
const queryFile = path.join(__dirname, "../files/conf/query", fileName);
|
|
150
|
+
return queryFile;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
function queryInfo(queryFile) {
|
|
154
|
+
const queries = readJsonSync(queryFile);
|
|
155
|
+
const questions = [];
|
|
156
|
+
for (const q in queries) {
|
|
157
|
+
const question = {};
|
|
158
|
+
question.type = "input";
|
|
159
|
+
question.name = q;
|
|
160
|
+
question.message = queries[q].query;
|
|
161
|
+
question.default = queries[q].default;
|
|
162
|
+
questions.push(question);
|
|
163
|
+
}
|
|
164
|
+
return inquirer.prompt(questions, function(answers) {
|
|
165
|
+
return answers;
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
function generate() {
|
|
170
|
+
const gen = getGenerator();
|
|
171
|
+
const templates = gen.getTmpl();
|
|
172
|
+
|
|
173
|
+
if (options.tmplName === "true") {
|
|
174
|
+
return finish(errHndl.getErrMsg("EMPTY_VALUE", "TEMPLATE"));
|
|
175
|
+
}
|
|
176
|
+
if (!options.out) {
|
|
177
|
+
return finish(errHndl.getErrMsg("EMPTY_VALUE", "APP_DIR"));
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
Promise.resolve()
|
|
181
|
+
.then(function() {
|
|
182
|
+
const overwrite = !!options.overwrite,
|
|
183
|
+
useInquirer = !!options.query,
|
|
184
|
+
dest = path.resolve(options.out),
|
|
185
|
+
existDir = gen.existOutDir(dest);
|
|
186
|
+
|
|
187
|
+
const questions = [{
|
|
188
|
+
type: "confirm",
|
|
189
|
+
name: "overwrite",
|
|
190
|
+
message: "The directory already exists. The template files in the directory will be replaced. Continue?",
|
|
191
|
+
default: false,
|
|
192
|
+
when: function() {
|
|
193
|
+
return !overwrite && useInquirer && existDir;
|
|
194
|
+
}
|
|
195
|
+
}];
|
|
196
|
+
return inquirer.prompt(questions).then(function(answers) {
|
|
197
|
+
options.overwrite = answers.overwrite || options.overwrite;
|
|
198
|
+
if (existDir && !options.overwrite) {
|
|
199
|
+
throw errHndl.getErrMsg("NOT_OVERWRITE_DIR", dest);
|
|
200
|
+
}
|
|
201
|
+
});
|
|
202
|
+
})
|
|
203
|
+
.then(function() {
|
|
204
|
+
const template = templates[options.tmplName];
|
|
205
|
+
if (!template) throw errHndl.getErrMsg("INVALID_VALUE", "TEMPLATE", options.tmplName);
|
|
206
|
+
if (!template.type) {
|
|
207
|
+
return;
|
|
208
|
+
}
|
|
209
|
+
// query mode, only CLI can approach. API only use props
|
|
210
|
+
if (!options.props.length) {
|
|
211
|
+
if (options.query && options.tmplName.match(/(^hosted)/)) {
|
|
212
|
+
const queryConfigFile = getQueryFile(config.profile, 'hosted');
|
|
213
|
+
return queryInfo(queryConfigFile).then(function(info) {
|
|
214
|
+
for (const i in info) {
|
|
215
|
+
options.appinfo[i] = info[i];
|
|
216
|
+
}
|
|
217
|
+
});
|
|
218
|
+
} else if (options.query && template.type.match(/(app$|appinfo$)/)) {
|
|
219
|
+
const queryConfigFile = getQueryFile(config.profile, 'app');
|
|
220
|
+
return queryInfo(queryConfigFile).then(function(info) {
|
|
221
|
+
for (const i in info) {
|
|
222
|
+
options.appinfo[i] = info[i];
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
} else if (options.query && !options.svcName &&
|
|
226
|
+
template.type.match(/(service$|serviceinfo$)/)) {
|
|
227
|
+
const queryConfigFile = getQueryFile(config.profile, 'service');
|
|
228
|
+
return queryInfo(queryConfigFile).then(function(info) {
|
|
229
|
+
// FIXME: hard-coded considering info.id is servicename
|
|
230
|
+
if (info.id) options.svcName = info.id;
|
|
231
|
+
});
|
|
232
|
+
} else if (options.query && template.type.match(/(package$|packageinfo$)/)) {
|
|
233
|
+
const queryConfigFile = getQueryFile(config.profile, 'package');
|
|
234
|
+
return queryInfo(queryConfigFile).then(function(info) {
|
|
235
|
+
for (const i in info) {
|
|
236
|
+
options.pkginfo[i] = info[i];
|
|
237
|
+
}
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
}})
|
|
241
|
+
.then(function() {
|
|
242
|
+
gen.generate(options, finish);
|
|
243
|
+
})
|
|
244
|
+
.catch(function(err) {
|
|
245
|
+
finish(err);
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
function finish(err, value) {
|
|
250
|
+
log.info("finish()");
|
|
251
|
+
if (err) {
|
|
252
|
+
// handle err from getErrMsg()
|
|
253
|
+
if (Array.isArray(err) && err.length > 0) {
|
|
254
|
+
for (const index in err) {
|
|
255
|
+
log.error(err[index].heading, err[index].message);
|
|
256
|
+
}
|
|
257
|
+
log.verbose(err[0].stack);
|
|
258
|
+
} else {
|
|
259
|
+
// handle general err (string & object)
|
|
260
|
+
log.error(err.toString());
|
|
261
|
+
log.verbose(err.stack);
|
|
262
|
+
}
|
|
263
|
+
cliControl.end(-1);
|
|
264
|
+
} else {
|
|
265
|
+
log.verbose("finish()", "value:", value);
|
|
266
|
+
if (value && value.msg) {
|
|
267
|
+
console.log(value.msg);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
}
|