balena-cli/build/actions/sync.js

141 lines
5.2 KiB
JavaScript
Raw Normal View History

2016-03-28 13:21:25 +00:00
/*
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() {
2016-07-19 16:12:36 +00:00
var loadConfig;
loadConfig = function(source) {
2016-10-26 14:55:39 +00:00
var _, config, configPath, error, fs, jsYaml, path, result;
2016-07-19 16:12:36 +00:00
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;
};
2016-03-28 13:21:25 +00:00
module.exports = {
2016-07-19 16:12:36 +00:00
signature: 'sync [uuid]',
description: '(beta) sync your changes to a device',
help: 'WARNING: If you\'re running Windows, this command only supports `cmd.exe`.\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',
2016-03-28 13:21:25 +00:00
permission: 'user',
primary: true,
options: [
{
signature: 'source',
parameter: 'path',
2016-07-19 16:12:36 +00:00
description: 'local directory path to synchronize to device',
2016-03-28 13:21:25 +00:00
alias: 's'
2016-07-19 16:12:36 +00:00
}, {
signature: 'destination',
parameter: 'path',
description: 'destination path on device',
alias: 'd'
2016-03-28 13:21:25 +00:00
}, {
signature: 'ignore',
parameter: 'paths',
description: 'comma delimited paths to ignore when syncing',
alias: 'i'
2016-07-19 16:12:36 +00:00
}, {
signature: 'skip-gitignore',
boolean: true,
description: 'do not parse excluded/included files from .gitignore'
2016-03-28 13:21:25 +00:00
}, {
signature: 'before',
parameter: 'command',
description: 'execute a command before syncing',
alias: 'b'
}, {
2016-07-19 16:12:36 +00:00
signature: 'after',
parameter: 'command',
description: 'execute a command after syncing',
alias: 'a'
2016-03-28 13:21:25 +00:00
}, {
signature: 'port',
parameter: 'port',
description: 'ssh port',
alias: 't'
2016-07-19 16:12:36 +00:00
}, {
signature: 'progress',
boolean: true,
description: 'show progress',
alias: 'p'
2016-06-22 14:59:14 +00:00
}, {
signature: 'verbose',
boolean: true,
description: 'increase verbosity',
alias: 'v'
2016-03-28 13:21:25 +00:00
}
],
action: function(params, options, done) {
2016-07-19 16:12:36 +00:00
var Promise, fs, path, patterns, resin, resinSync;
fs = require('fs');
path = require('path');
resin = require('resin-sdk');
2016-07-19 16:12:36 +00:00
Promise = require('bluebird');
2016-03-28 13:21:25 +00:00
resinSync = require('resin-sync');
patterns = require('../utils/patterns');
2016-07-19 16:12:36 +00:00
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(',');
}
2016-07-19 16:12:36 +00:00
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);
2016-03-28 13:21:25 +00:00
}
};
}).call(this);