Syntax update.
This commit is contained in:
parent
ae1a68500c
commit
38683a7fea
@ -61,13 +61,13 @@ The return value is the identifier of this new server in XO.
|
|||||||
##### VM export
|
##### VM export
|
||||||
|
|
||||||
```
|
```
|
||||||
> xo-cli vm.export vm=a01667e0-8e29-49fc-a550-17be4226783c > vm.xva
|
> xo-cli vm.export vm=a01667e0-8e29-49fc-a550-17be4226783c @=vm.xva
|
||||||
```
|
```
|
||||||
|
|
||||||
##### VM import
|
##### VM import
|
||||||
|
|
||||||
```
|
```
|
||||||
> xo-cli vm.import host=60a6939e-8b0a-4352-9954-5bde44bcdf7d < vm.xva
|
> xo-cli vm.import host=60a6939e-8b0a-4352-9954-5bde44bcdf7d @=vm.xva
|
||||||
```
|
```
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
@ -4,8 +4,12 @@
|
|||||||
|
|
||||||
var Bluebird = require('bluebird');
|
var Bluebird = require('bluebird');
|
||||||
Bluebird.longStackTraces();
|
Bluebird.longStackTraces();
|
||||||
|
var promisify = Bluebird.promisify;
|
||||||
|
|
||||||
|
var createReadStream = require('fs').createReadStream;
|
||||||
|
var createWriteStream = require('fs').createWriteStream;
|
||||||
var resolveUrl = require('url').resolve;
|
var resolveUrl = require('url').resolve;
|
||||||
|
var stat = promisify(require('fs').stat);
|
||||||
|
|
||||||
var chalk = require('chalk');
|
var chalk = require('chalk');
|
||||||
var eventToPromise = require('event-to-promise');
|
var eventToPromise = require('event-to-promise');
|
||||||
@ -17,7 +21,7 @@ var isObject = require('lodash.isobject');
|
|||||||
var multiline = require('multiline');
|
var multiline = require('multiline');
|
||||||
var pairs = require('lodash.pairs');
|
var pairs = require('lodash.pairs');
|
||||||
var progressStream = require('progress-stream');
|
var progressStream = require('progress-stream');
|
||||||
var sent = require('sent');
|
var sent = promisify(require('sent'));
|
||||||
var Xo = require('xo-lib');
|
var Xo = require('xo-lib');
|
||||||
|
|
||||||
//--------------------------------------------------------------------
|
//--------------------------------------------------------------------
|
||||||
@ -219,6 +223,7 @@ function call(args) {
|
|||||||
|
|
||||||
var method = args.shift();
|
var method = args.shift();
|
||||||
var params = {};
|
var params = {};
|
||||||
|
var file;
|
||||||
forEach(args, function (arg) {
|
forEach(args, function (arg) {
|
||||||
var matches;
|
var matches;
|
||||||
if (!(matches = arg.match(PARAM_RE))) {
|
if (!(matches = arg.match(PARAM_RE))) {
|
||||||
@ -227,6 +232,11 @@ function call(args) {
|
|||||||
var name = matches[1];
|
var name = matches[1];
|
||||||
var value = matches[2];
|
var value = matches[2];
|
||||||
|
|
||||||
|
if (name === '@') {
|
||||||
|
file = value;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (value === 'true') {
|
if (value === 'true') {
|
||||||
value = true;
|
value = true;
|
||||||
}
|
}
|
||||||
@ -251,25 +261,29 @@ function call(args) {
|
|||||||
|
|
||||||
if (key === '$getFrom') {
|
if (key === '$getFrom') {
|
||||||
url = resolveUrl(baseUrl, result[key]);
|
url = resolveUrl(baseUrl, result[key]);
|
||||||
|
var output = createWriteStream(file);
|
||||||
|
|
||||||
return eventToPromise(pipeWithErrors([
|
return eventToPromise(pipeWithErrors([
|
||||||
got(url),
|
got(url),
|
||||||
progressStream({ time: 1e3 }, printProgress),
|
progressStream({ time: 1e3 }, printProgress),
|
||||||
process.stdout,
|
output,
|
||||||
]), 'finish');
|
]), 'finish');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key === '$sendTo') {
|
if (key === '$sendTo') {
|
||||||
url = resolveUrl(baseUrl, result[key]);
|
url = resolveUrl(baseUrl, result[key]);
|
||||||
|
|
||||||
return new Bluebird(function (resolve, reject) {
|
return stat(file).then(function (stats) {
|
||||||
sent(url, process.stdin, function (error, result) {
|
var input = pipeWithErrors([
|
||||||
if (error) {
|
createReadStream(file),
|
||||||
reject(error);
|
progressStream({ time: 1e3 }, printProgress),
|
||||||
return;
|
]) && createReadStream(file);
|
||||||
}
|
|
||||||
resolve(result);
|
return sent(url, input, {
|
||||||
});
|
headers: {
|
||||||
|
// 'content-length': stats.size,
|
||||||
|
},
|
||||||
|
}).get(0);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user