2017-03-08 18:45:36 +00:00
|
|
|
Promise = require('bluebird')
|
|
|
|
_ = require('lodash')
|
|
|
|
Docker = require('docker-toolbelt')
|
|
|
|
form = require('resin-cli-form')
|
|
|
|
chalk = require('chalk')
|
|
|
|
|
2017-03-10 15:11:27 +00:00
|
|
|
exports.dockerPort = dockerPort = 2375
|
|
|
|
exports.dockerTimeout = dockerTimeout = 2000
|
|
|
|
|
|
|
|
exports.filterOutSupervisorContainer = filterOutSupervisorContainer = (container) ->
|
2017-03-09 19:14:25 +00:00
|
|
|
for name in container.Names
|
|
|
|
return false if name.includes('resin_supervisor')
|
|
|
|
return true
|
|
|
|
|
2017-03-10 15:11:27 +00:00
|
|
|
exports.selectContainerFromDevice = Promise.method (deviceIp, filterSupervisor = false) ->
|
|
|
|
docker = new Docker(host: deviceIp, port: dockerPort, timeout: dockerTimeout)
|
2017-03-08 18:45:36 +00:00
|
|
|
|
2017-03-10 15:11:27 +00:00
|
|
|
# List all containers, including those not running
|
|
|
|
docker.listContainersAsync(all: true)
|
|
|
|
.filter (container) ->
|
|
|
|
return true if not filterSupervisor
|
|
|
|
filterOutSupervisorContainer(container)
|
|
|
|
.then (containers) ->
|
|
|
|
if _.isEmpty(containers)
|
|
|
|
throw new Error("No containers found in #{deviceIp}")
|
2017-03-08 18:45:36 +00:00
|
|
|
|
2017-03-10 15:11:27 +00:00
|
|
|
return form.ask
|
|
|
|
message: 'Select a container'
|
|
|
|
type: 'list'
|
|
|
|
choices: _.map containers, (container) ->
|
|
|
|
containerName = container.Names[0] or 'Untitled'
|
|
|
|
shortContainerId = ('' + container.Id).substr(0, 11)
|
|
|
|
containerStatus = container.Status
|
2017-03-08 18:45:36 +00:00
|
|
|
|
2017-03-10 15:11:27 +00:00
|
|
|
return {
|
|
|
|
name: "#{containerName} (#{shortContainerId}) - #{containerStatus}"
|
|
|
|
value: container.Id
|
|
|
|
}
|
2017-03-08 18:45:36 +00:00
|
|
|
|
2017-03-10 15:11:27 +00:00
|
|
|
exports.pipeContainerStream = Promise.method ({ deviceIp, name, outStream, follow = false }) ->
|
|
|
|
docker = new Docker(host: deviceIp, port: dockerPort)
|
2017-03-08 18:45:36 +00:00
|
|
|
|
2017-03-10 15:11:27 +00:00
|
|
|
container = docker.getContainer(name)
|
|
|
|
container.inspectAsync()
|
|
|
|
.then (containerInfo) ->
|
|
|
|
return containerInfo?.State?.Running
|
|
|
|
.then (isRunning) ->
|
|
|
|
container.attachAsync
|
|
|
|
logs: not follow or not isRunning
|
|
|
|
stream: follow and isRunning
|
|
|
|
stdout: true
|
|
|
|
stderr: true
|
|
|
|
.then (containerStream) ->
|
|
|
|
containerStream.pipe(outStream)
|
|
|
|
.catch (err) ->
|
|
|
|
err = '' + err.statusCode
|
|
|
|
if err is '404'
|
|
|
|
return console.log(chalk.red.bold("Container '#{name}' not found."))
|
|
|
|
throw err
|
2017-03-08 18:45:36 +00:00
|
|
|
|
2017-05-22 18:49:34 +00:00
|
|
|
exports.getSubShellCommand = require('../../utils/helpers').getSubShellCommand
|