resin ssh: handle undefined uuid parameter

change-type: patch
This commit is contained in:
Kostas Lekkas 2017-03-03 14:02:06 +02:00
parent 9214cb0d90
commit fb06249b08
No known key found for this signature in database
GPG Key ID: 7742375E5EDF01C3
2 changed files with 16 additions and 10 deletions

View File

@ -1,4 +1,4 @@
// Generated by CoffeeScript 1.12.2
// Generated by CoffeeScript 1.12.4
/*
Copyright 2016 Resin.io
@ -65,8 +65,13 @@ limitations under the License.
options.port = 22;
}
verbose = options.verbose ? '-vvv' : '';
return resin.models.device.has(params.uuid).then(function(isValidUUID) {
if (isValidUUID) {
return Promise["try"](function() {
if (!params.uuid) {
return false;
}
return resin.models.device.has(params.uuid);
}).then(function(uuidExists) {
if (uuidExists) {
return params.uuid;
}
return patterns.inferOrSelectDevice();
@ -88,10 +93,10 @@ limitations under the License.
throw new Error('Did not find running application container');
}
return Promise["try"](function() {
var command, spawn, subShellCommand;
var command, subShellCommand;
command = "ssh " + verbose + " -t -o LogLevel=ERROR -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ControlMaster=no -p " + options.port + " " + username + "@ssh." + (settings.get('proxyUrl')) + " enter " + uuid + " " + containerId;
subShellCommand = getSubShellCommand(command);
return spawn = child_process.spawn(subShellCommand.program, subShellCommand.args, {
return child_process.spawn(subShellCommand.program, subShellCommand.args, {
stdio: 'inherit'
});
});

View File

@ -78,10 +78,11 @@ module.exports =
verbose = if options.verbose then '-vvv' else ''
resin.models.device.has(params.uuid).then (isValidUUID) ->
if isValidUUID
return params.uuid
Promise.try ->
return false if not params.uuid
return resin.models.device.has(params.uuid)
.then (uuidExists) ->
return params.uuid if uuidExists
return patterns.inferOrSelectDevice()
.then (uuid) ->
console.info("Connecting with: #{uuid}")
@ -104,6 +105,6 @@ module.exports =
-p #{options.port} #{username}@ssh.#{settings.get('proxyUrl')} enter #{uuid} #{containerId}"
subShellCommand = getSubShellCommand(command)
spawn = child_process.spawn subShellCommand.program, subShellCommand.args,
child_process.spawn subShellCommand.program, subShellCommand.args,
stdio: 'inherit'
.nodeify(done)