2015-03-09 13:14:39 +00:00
|
|
|
path = require('path')
|
2015-01-09 15:22:18 +00:00
|
|
|
_ = require('lodash-contrib')
|
2014-11-21 14:12:03 +00:00
|
|
|
async = require('async')
|
2015-01-08 12:04:37 +00:00
|
|
|
resin = require('resin-sdk')
|
2015-01-21 13:50:19 +00:00
|
|
|
visuals = require('resin-cli-visuals')
|
2015-01-15 17:10:14 +00:00
|
|
|
commandOptions = require('./command-options')
|
2015-03-12 15:24:36 +00:00
|
|
|
vcs = require('resin-vcs')
|
2015-07-27 12:08:55 +00:00
|
|
|
form = require('resin-cli-form')
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
exports.create =
|
|
|
|
signature: 'app create <name>'
|
|
|
|
description: 'create an application'
|
|
|
|
help: '''
|
|
|
|
Use this command to create a new resin.io application.
|
|
|
|
|
|
|
|
You can specify the application type with the `--type` option.
|
|
|
|
Otherwise, an interactive dropdown will be shown for you to select from.
|
|
|
|
|
|
|
|
You can see a list of supported device types with
|
2015-03-03 14:14:16 +00:00
|
|
|
|
2015-01-15 17:10:14 +00:00
|
|
|
$ resin devices supported
|
|
|
|
|
|
|
|
Examples:
|
2015-03-03 14:14:16 +00:00
|
|
|
|
2015-01-15 17:10:14 +00:00
|
|
|
$ resin app create MyApp
|
|
|
|
$ resin app create MyApp --type raspberry-pi
|
|
|
|
'''
|
|
|
|
options: [
|
|
|
|
{
|
|
|
|
signature: 'type'
|
|
|
|
parameter: 'type'
|
|
|
|
description: 'application type'
|
|
|
|
alias: 't'
|
|
|
|
}
|
|
|
|
]
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-07-27 12:08:55 +00:00
|
|
|
async.waterfall [
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
(callback) ->
|
2015-07-22 22:06:53 +00:00
|
|
|
resin.models.application.has(params.name).nodeify(callback)
|
2015-04-28 13:18:21 +00:00
|
|
|
|
|
|
|
(hasApplication, callback) ->
|
|
|
|
if hasApplication
|
|
|
|
return callback(new Error('You already have an application with that name!'))
|
|
|
|
|
2015-02-03 18:53:48 +00:00
|
|
|
return callback(null, options.type) if options.type?
|
2015-07-27 12:08:55 +00:00
|
|
|
resin.models.device.getSupportedDeviceTypes().then (supportedDeviceTypes) ->
|
|
|
|
form.ask
|
|
|
|
message: 'Device Type'
|
|
|
|
type: 'list'
|
|
|
|
choices: supportedDeviceTypes
|
|
|
|
.nodeify(callback)
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
(type, callback) ->
|
2015-06-02 17:04:08 +00:00
|
|
|
options.type = type
|
2015-07-22 22:06:53 +00:00
|
|
|
resin.models.application.create(params.name, options.type).nodeify(callback)
|
2015-06-02 17:04:08 +00:00
|
|
|
|
2015-07-29 17:40:52 +00:00
|
|
|
(application, callback) ->
|
|
|
|
console.info("Application created: #{params.name} (#{options.type}, id #{application.id})")
|
2015-06-02 17:04:08 +00:00
|
|
|
return callback()
|
2015-01-15 17:10:14 +00:00
|
|
|
|
2015-07-27 12:08:55 +00:00
|
|
|
], done
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
exports.list =
|
|
|
|
signature: 'apps'
|
|
|
|
description: 'list all applications'
|
|
|
|
help: '''
|
|
|
|
Use this command to list all your applications.
|
|
|
|
|
|
|
|
Notice this command only shows the most important bits of information for each app.
|
2015-03-23 12:17:55 +00:00
|
|
|
If you want detailed information, use resin app <name> instead.
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
Examples:
|
2015-03-03 14:14:16 +00:00
|
|
|
|
2015-01-15 17:10:14 +00:00
|
|
|
$ resin apps
|
|
|
|
'''
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-07-22 22:06:53 +00:00
|
|
|
resin.models.application.getAll().then (applications) ->
|
2015-07-29 13:34:31 +00:00
|
|
|
console.log visuals.table.horizontal applications, [
|
2015-01-22 17:06:02 +00:00
|
|
|
'id'
|
|
|
|
'app_name'
|
2015-01-22 17:20:20 +00:00
|
|
|
'device_type'
|
2015-01-22 17:06:02 +00:00
|
|
|
'online_devices'
|
|
|
|
'devices_length'
|
2015-01-15 17:10:14 +00:00
|
|
|
]
|
2015-07-22 22:06:53 +00:00
|
|
|
.nodeify(done)
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
exports.info =
|
2015-03-23 12:17:55 +00:00
|
|
|
signature: 'app <name>'
|
2015-01-15 17:10:14 +00:00
|
|
|
description: 'list a single application'
|
|
|
|
help: '''
|
|
|
|
Use this command to show detailed information for a single application.
|
|
|
|
|
|
|
|
Examples:
|
2015-03-03 14:14:16 +00:00
|
|
|
|
2015-03-23 12:17:55 +00:00
|
|
|
$ resin app MyApp
|
2015-01-15 17:10:14 +00:00
|
|
|
'''
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-07-22 22:06:53 +00:00
|
|
|
resin.models.application.get(params.name).then (application) ->
|
2015-07-29 13:34:31 +00:00
|
|
|
console.log visuals.table.vertical application, [
|
|
|
|
"$#{application.app_name}$"
|
2015-01-22 17:06:02 +00:00
|
|
|
'id'
|
2015-01-22 17:20:20 +00:00
|
|
|
'device_type'
|
2015-01-22 17:06:02 +00:00
|
|
|
'git_repository'
|
|
|
|
'commit'
|
2015-01-15 17:10:14 +00:00
|
|
|
]
|
2015-07-22 22:06:53 +00:00
|
|
|
.nodeify(done)
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
exports.restart =
|
2015-03-23 12:17:55 +00:00
|
|
|
signature: 'app restart <name>'
|
2015-01-15 17:10:14 +00:00
|
|
|
description: 'restart an application'
|
|
|
|
help: '''
|
|
|
|
Use this command to restart all devices that belongs to a certain application.
|
|
|
|
|
|
|
|
Examples:
|
2015-03-03 14:14:16 +00:00
|
|
|
|
2015-03-23 12:17:55 +00:00
|
|
|
$ resin app restart MyApp
|
2015-01-15 17:10:14 +00:00
|
|
|
'''
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-07-22 22:06:53 +00:00
|
|
|
resin.models.application.restart(params.name).nodeify(done)
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
exports.remove =
|
2015-03-23 12:17:55 +00:00
|
|
|
signature: 'app rm <name>'
|
2015-01-15 17:10:14 +00:00
|
|
|
description: 'remove an application'
|
|
|
|
help: '''
|
|
|
|
Use this command to remove a resin.io application.
|
|
|
|
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
|
|
|
|
Examples:
|
2015-03-03 14:14:16 +00:00
|
|
|
|
2015-03-23 12:17:55 +00:00
|
|
|
$ resin app rm MyApp
|
|
|
|
$ resin app rm MyApp --yes
|
2015-01-15 17:10:14 +00:00
|
|
|
'''
|
|
|
|
options: [ commandOptions.yes ]
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-07-27 12:08:55 +00:00
|
|
|
async.waterfall [
|
|
|
|
|
|
|
|
(callback) ->
|
|
|
|
if options.yes
|
|
|
|
return callback(null, true)
|
|
|
|
else
|
|
|
|
form.ask
|
|
|
|
message: 'Are you sure you want to delete the application?'
|
|
|
|
type: 'confirm'
|
|
|
|
default: false
|
|
|
|
.nodeify(callback)
|
|
|
|
|
|
|
|
(confirmed, callback) ->
|
|
|
|
return callback() if not confirmed
|
|
|
|
resin.models.application.remove(params.name).nodeify(callback)
|
|
|
|
], done
|
2015-01-15 17:10:14 +00:00
|
|
|
|
2015-03-09 13:14:39 +00:00
|
|
|
exports.associate =
|
2015-03-23 12:17:55 +00:00
|
|
|
signature: 'app associate <name>'
|
2015-03-09 13:14:39 +00:00
|
|
|
description: 'associate a resin project'
|
2015-01-15 17:10:14 +00:00
|
|
|
help: '''
|
2015-03-09 13:14:39 +00:00
|
|
|
Use this command to associate a project directory with a resin application.
|
2015-01-15 17:10:14 +00:00
|
|
|
|
2015-03-09 13:14:39 +00:00
|
|
|
This command adds a 'resin' git remote to the directory and runs git init if necessary.
|
2015-01-15 17:10:14 +00:00
|
|
|
|
2015-06-02 16:32:35 +00:00
|
|
|
Notice this command asks for confirmation interactively.
|
|
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
|
2015-01-15 17:10:14 +00:00
|
|
|
Examples:
|
2015-03-03 14:14:16 +00:00
|
|
|
|
2015-03-23 12:17:55 +00:00
|
|
|
$ resin app associate MyApp
|
|
|
|
$ resin app associate MyApp --project my/app/directory
|
2015-01-15 17:10:14 +00:00
|
|
|
'''
|
2015-06-02 16:32:35 +00:00
|
|
|
options: [ commandOptions.yes ]
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-03-12 15:24:36 +00:00
|
|
|
currentDirectory = process.cwd()
|
2015-01-15 17:10:14 +00:00
|
|
|
|
2015-03-12 15:24:36 +00:00
|
|
|
async.waterfall [
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
(callback) ->
|
2015-07-22 22:06:53 +00:00
|
|
|
resin.models.application.has(params.name).nodeify(callback)
|
2015-06-02 16:32:35 +00:00
|
|
|
|
|
|
|
(hasApp, callback) ->
|
|
|
|
if not hasApp
|
|
|
|
return callback(new Error("Invalid application: #{params.name}"))
|
|
|
|
|
|
|
|
message = "Are you sure you want to associate #{currentDirectory} with #{params.name}?"
|
2015-07-27 12:08:55 +00:00
|
|
|
if options.yes
|
|
|
|
return callback(null, true)
|
|
|
|
else
|
|
|
|
form.ask
|
|
|
|
message: message
|
|
|
|
type: 'confirm'
|
|
|
|
default: false
|
|
|
|
.nodeify(callback)
|
2015-06-02 16:32:35 +00:00
|
|
|
|
|
|
|
(confirmed, callback) ->
|
|
|
|
return done() if not confirmed
|
2015-07-10 17:04:17 +00:00
|
|
|
vcs.initialize(currentDirectory).nodeify(callback)
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
(callback) ->
|
2015-07-22 22:06:53 +00:00
|
|
|
resin.models.application.get(params.name).nodeify(callback)
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
(application, callback) ->
|
2015-07-10 17:04:17 +00:00
|
|
|
vcs.associate(currentDirectory, application.git_repository).nodeify(callback)
|
2015-03-09 13:14:39 +00:00
|
|
|
|
2015-03-12 15:24:36 +00:00
|
|
|
], (error, remoteUrl) ->
|
|
|
|
return done(error) if error?
|
|
|
|
console.info("git repository added: #{remoteUrl}")
|
|
|
|
return done(null, remoteUrl)
|
2015-03-09 13:14:39 +00:00
|
|
|
|
|
|
|
exports.init =
|
|
|
|
signature: 'init'
|
|
|
|
description: 'init an application'
|
|
|
|
help: '''
|
|
|
|
Use this command to initialise a directory as a resin application.
|
|
|
|
|
|
|
|
This command performs the following steps:
|
|
|
|
- Create a resin.io application.
|
|
|
|
- Initialize the current directory as a git repository.
|
|
|
|
- Add the corresponding git remote to the application.
|
|
|
|
|
|
|
|
Examples:
|
2015-01-15 17:10:14 +00:00
|
|
|
|
2015-03-09 13:14:39 +00:00
|
|
|
$ resin init
|
|
|
|
$ resin init --project my/app/directory
|
|
|
|
'''
|
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
|
|
|
|
|
|
|
currentDirectory = process.cwd()
|
|
|
|
|
2015-07-27 12:08:55 +00:00
|
|
|
async.waterfall [
|
2015-03-09 13:14:39 +00:00
|
|
|
|
|
|
|
(callback) ->
|
|
|
|
currentDirectoryBasename = path.basename(currentDirectory)
|
2015-07-27 12:08:55 +00:00
|
|
|
form.ask
|
|
|
|
message: 'What is the name of your application?'
|
|
|
|
type: 'input'
|
|
|
|
default: currentDirectoryBasename
|
|
|
|
.nodeify(callback)
|
2015-03-09 13:14:39 +00:00
|
|
|
|
|
|
|
(applicationName, callback) ->
|
|
|
|
|
2015-03-23 12:17:55 +00:00
|
|
|
# TODO: Make resin.models.application.create return
|
|
|
|
# the whole application instead of just the id
|
|
|
|
exports.create.action name: applicationName, options, (error) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
return callback(null, applicationName)
|
|
|
|
|
|
|
|
(applicationName, callback) ->
|
|
|
|
exports.associate.action(name: applicationName, options, callback)
|
2015-03-09 13:14:39 +00:00
|
|
|
|
2015-07-27 12:08:55 +00:00
|
|
|
], done
|