Support resin sync for remote resin.io AUFS devices

change-type: minor
This commit is contained in:
Kostas Lekkas 2017-01-18 14:47:36 +02:00
parent ffa645f85c
commit 2fde6241c2
No known key found for this signature in database
GPG Key ID: 7742375E5EDF01C3
2 changed files with 2 additions and 149 deletions

View File

@ -14,151 +14,4 @@ See the License for the specific language governing permissions and
limitations under the License.
###
# Loads '.resin-sync.yml' configuration from 'source' directory.
# Returns the configuration object on success
#
# TODO: Use 'config.load()' method from `resin sync` when resin sync gets
# integrated into resin CLI
loadConfig = (source) ->
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 error
# return empty object if '.resin-sync.yml' is missing
if error.code is 'ENOENT'
return {}
throw error
if not _.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
be correctly installed in your shell environment. For more information (including
Windows support) please check the README here: https://github.com/resin-io/resin-cli
Use this command to sync your local changes to a certain device on the fly.
After every 'resin sync' the updated settings will be saved in
'<source>/.resin-sync.yml' and will be used in later invocations. You can
also change any option by editing '.resin-sync.yml' directly.
Here is an example '.resin-sync.yml' :
$ cat $PWD/.resin-sync.yml
uuid: 7cf02a6
destination: '/usr/src/app'
before: 'echo Hello'
after: 'echo Done'
ignore:
- .git
- node_modules/
Command line options have precedence over the ones saved in '.resin-sync.yml'.
If '.gitignore' is found in the source directory then all explicitly listed files will be
excluded from the syncing process. You can choose to change this default behavior with the
'--skip-gitignore' option.
Examples:
$ resin sync 7cf02a6 --source . --destination /usr/src/app
$ resin sync 7cf02a6 -s /home/user/myResinProject -d /usr/src/app --before 'echo Hello' --after 'echo Done'
$ resin sync --ignore lib/
$ resin sync --verbose false
$ 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: (params, options, done) ->
fs = require('fs')
path = require('path')
resin = require('resin-sdk-preconfigured')
Promise = require('bluebird')
resinSync = require('resin-sync')
patterns = require('../utils/patterns')
Promise.try ->
try
fs.accessSync(path.join(process.cwd(), '.resin-sync.yml'))
catch
if not options.source?
throw new Error('No --source option passed and no \'.resin-sync.yml\' file found in current directory.')
options.source ?= process.cwd()
# TODO: Add comma separated options to Capitano
if options.ignore?
options.ignore = options.ignore.split(',')
Promise.resolve(params.uuid)
.then (uuid) ->
if not uuid?
savedUuid = loadConfig(options.source).uuid
return patterns.inferOrSelectDevice(savedUuid)
resin.models.device.has(uuid)
.then (hasDevice) ->
if not hasDevice
throw new Error("Device not found: #{uuid}")
return uuid
.then (uuid) ->
resinSync.sync(uuid, options)
.nodeify(done)
module.exports = require('resin-sync').capitano('resin-cli')

View File

@ -55,7 +55,7 @@
"resin-image-manager": "^4.0.0",
"resin-sdk-preconfigured": "^0.1.0",
"resin-settings-client": "^3.5.0",
"resin-sync": "^2.0.2",
"resin-sync": "^6.1.0",
"rimraf": "^2.4.3",
"rindle": "^1.0.0",
"tmp": "^0.0.31",