mirror of
https://github.com/balena-io/balena-cli.git
synced 2024-12-30 18:46:57 +00:00
142 lines
5.4 KiB
JavaScript
142 lines
5.4 KiB
JavaScript
// Generated by CoffeeScript 1.12.2
|
|
|
|
/*
|
|
Copyright 2016 Resin.io
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
(function() {
|
|
var loadConfig;
|
|
|
|
loadConfig = function(source) {
|
|
var _, config, configPath, error, fs, jsYaml, path, result;
|
|
fs = require('fs');
|
|
path = require('path');
|
|
_ = require('lodash');
|
|
jsYaml = require('js-yaml');
|
|
configPath = path.join(source, '.resin-sync.yml');
|
|
try {
|
|
config = fs.readFileSync(configPath, {
|
|
encoding: 'utf8'
|
|
});
|
|
result = jsYaml.safeLoad(config);
|
|
} catch (error1) {
|
|
error = error1;
|
|
if (error.code === 'ENOENT') {
|
|
return {};
|
|
}
|
|
throw error;
|
|
}
|
|
if (!_.isPlainObject(result)) {
|
|
throw new Error("Invalid configuration file: " + configPath);
|
|
}
|
|
return result;
|
|
};
|
|
|
|
module.exports = {
|
|
signature: 'sync [uuid]',
|
|
description: '(beta) sync your changes to a device',
|
|
help: 'Warning: \'resin sync\' requires an openssh-compatible client and \'rsync\' to\nbe correctly installed in your shell environment. For more information (including\nWindows support) please check the README here: https://github.com/resin-io/resin-cli\n\nUse this command to sync your local changes to a certain device on the fly.\n\nAfter every \'resin sync\' the updated settings will be saved in\n\'<source>/.resin-sync.yml\' and will be used in later invocations. You can\nalso change any option by editing \'.resin-sync.yml\' directly.\n\nHere is an example \'.resin-sync.yml\' :\n\n $ cat $PWD/.resin-sync.yml\n uuid: 7cf02a6\n destination: \'/usr/src/app\'\n before: \'echo Hello\'\n after: \'echo Done\'\n ignore:\n - .git\n - node_modules/\n\nCommand line options have precedence over the ones saved in \'.resin-sync.yml\'.\n\nIf \'.gitignore\' is found in the source directory then all explicitly listed files will be\nexcluded from the syncing process. You can choose to change this default behavior with the\n\'--skip-gitignore\' option.\n\nExamples:\n\n $ resin sync 7cf02a6 --source . --destination /usr/src/app\n $ resin sync 7cf02a6 -s /home/user/myResinProject -d /usr/src/app --before \'echo Hello\' --after \'echo Done\'\n $ resin sync --ignore lib/\n $ resin sync --verbose false\n $ resin sync',
|
|
permission: 'user',
|
|
primary: true,
|
|
options: [
|
|
{
|
|
signature: 'source',
|
|
parameter: 'path',
|
|
description: 'local directory path to synchronize to device',
|
|
alias: 's'
|
|
}, {
|
|
signature: 'destination',
|
|
parameter: 'path',
|
|
description: 'destination path on device',
|
|
alias: 'd'
|
|
}, {
|
|
signature: 'ignore',
|
|
parameter: 'paths',
|
|
description: 'comma delimited paths to ignore when syncing',
|
|
alias: 'i'
|
|
}, {
|
|
signature: 'skip-gitignore',
|
|
boolean: true,
|
|
description: 'do not parse excluded/included files from .gitignore'
|
|
}, {
|
|
signature: 'before',
|
|
parameter: 'command',
|
|
description: 'execute a command before syncing',
|
|
alias: 'b'
|
|
}, {
|
|
signature: 'after',
|
|
parameter: 'command',
|
|
description: 'execute a command after syncing',
|
|
alias: 'a'
|
|
}, {
|
|
signature: 'port',
|
|
parameter: 'port',
|
|
description: 'ssh port',
|
|
alias: 't'
|
|
}, {
|
|
signature: 'progress',
|
|
boolean: true,
|
|
description: 'show progress',
|
|
alias: 'p'
|
|
}, {
|
|
signature: 'verbose',
|
|
boolean: true,
|
|
description: 'increase verbosity',
|
|
alias: 'v'
|
|
}
|
|
],
|
|
action: function(params, options, done) {
|
|
var Promise, fs, path, patterns, resin, resinSync;
|
|
fs = require('fs');
|
|
path = require('path');
|
|
resin = require('../resin-sdk');
|
|
Promise = require('bluebird');
|
|
resinSync = require('resin-sync');
|
|
patterns = require('../utils/patterns');
|
|
return Promise["try"](function() {
|
|
try {
|
|
fs.accessSync(path.join(process.cwd(), '.resin-sync.yml'));
|
|
} catch (error1) {
|
|
if (options.source == null) {
|
|
throw new Error('No --source option passed and no \'.resin-sync.yml\' file found in current directory.');
|
|
}
|
|
}
|
|
if (options.source == null) {
|
|
options.source = process.cwd();
|
|
}
|
|
if (options.ignore != null) {
|
|
options.ignore = options.ignore.split(',');
|
|
}
|
|
return Promise.resolve(params.uuid).then(function(uuid) {
|
|
var savedUuid;
|
|
if (uuid == null) {
|
|
savedUuid = loadConfig(options.source).uuid;
|
|
return patterns.inferOrSelectDevice(savedUuid);
|
|
}
|
|
return resin.models.device.has(uuid).then(function(hasDevice) {
|
|
if (!hasDevice) {
|
|
throw new Error("Device not found: " + uuid);
|
|
}
|
|
return uuid;
|
|
});
|
|
}).then(function(uuid) {
|
|
return resinSync.sync(uuid, options);
|
|
});
|
|
}).nodeify(done);
|
|
}
|
|
};
|
|
|
|
}).call(this);
|