mirror of
https://github.com/balena-io/balena-cli.git
synced 2024-12-24 07:46:39 +00:00
4a05ce3f53
This PR adds functionality to `resin sync` to try to infer what the device uuid is as follows: - If the argument to `resin sync` is an app, get all the devices from that application. If there is only one, auto-select it, otherwise show an interactive drive selection widget. - If the argument to `resin sync` is a uuid, use it directly, without trying to infer anything. - If no argument is passed to `resin sync`, display an interactive selection widget showing all your devices from all your applications. Signed-off-by: Juan Cruz Viotti <jviottidc@gmail.com>
90 lines
2.3 KiB
CoffeeScript
90 lines
2.3 KiB
CoffeeScript
###
|
|
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.
|
|
###
|
|
|
|
module.exports =
|
|
signature: 'sync [source]'
|
|
description: '(beta) sync your changes with a device'
|
|
help: '''
|
|
Use this command to sync your local changes to a certain device on the fly.
|
|
|
|
The `source` argument can be either a device uuid or an application name.
|
|
|
|
You can save all the options mentioned below in a `resin-sync.yml` file,
|
|
by using the same option names as keys. For example:
|
|
|
|
$ cat $PWD/resin-sync.yml
|
|
source: src/
|
|
before: 'echo Hello'
|
|
ignore:
|
|
- .git
|
|
- node_modules/
|
|
progress: true
|
|
|
|
Notice that explicitly passed command options override the ones set in the configuration file.
|
|
|
|
Examples:
|
|
|
|
$ resin sync MyApp
|
|
$ resin sync 7cf02a6
|
|
$ resin sync 7cf02a6 --port 8080
|
|
$ resin sync 7cf02a6 --ignore foo,bar
|
|
'''
|
|
permission: 'user'
|
|
primary: true
|
|
options: [
|
|
signature: 'source'
|
|
parameter: 'path'
|
|
description: 'custom source path'
|
|
alias: 's'
|
|
,
|
|
signature: 'ignore'
|
|
parameter: 'paths'
|
|
description: 'comma delimited paths to ignore when syncing'
|
|
alias: 'i'
|
|
,
|
|
signature: 'before'
|
|
parameter: 'command'
|
|
description: 'execute a command before syncing'
|
|
alias: 'b'
|
|
,
|
|
signature: 'progress'
|
|
boolean: true
|
|
description: 'show progress'
|
|
alias: 'p'
|
|
,
|
|
signature: 'port'
|
|
parameter: 'port'
|
|
description: 'ssh port'
|
|
alias: 't'
|
|
]
|
|
action: (params, options, done) ->
|
|
resin = require('resin-sdk')
|
|
resinSync = require('resin-sync')
|
|
patterns = require('../utils/patterns')
|
|
|
|
# TODO: Add comma separated options to Capitano
|
|
if options.ignore?
|
|
options.ignore = options.ignore.split(',')
|
|
|
|
resin.models.device.has(params.source).then (isValidUUID) ->
|
|
if isValidUUID
|
|
return params.source
|
|
|
|
return patterns.inferOrSelectDevice(params.source)
|
|
.then (uuid) ->
|
|
resinSync.sync(uuid, options)
|
|
.nodeify(done)
|