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')
|
|
|
|
|
|
|
|
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
|
|
|
|
$ resin devices supported
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
$ 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-01-15 17:10:14 +00:00
|
|
|
async.waterfall([
|
|
|
|
|
|
|
|
(callback) ->
|
2015-02-03 18:53:48 +00:00
|
|
|
return callback(null, options.type) if options.type?
|
2015-02-11 14:07:53 +00:00
|
|
|
|
|
|
|
resin.models.device.getSupportedDeviceTypes (error, deviceTypes) ->
|
|
|
|
return callback(error) if error?
|
|
|
|
visuals.widgets.select('Select a type', deviceTypes, callback)
|
2015-01-15 17:10:14 +00:00
|
|
|
|
|
|
|
(type, callback) ->
|
|
|
|
resin.models.application.create(params.name, type, callback)
|
|
|
|
|
|
|
|
], done)
|
|
|
|
|
|
|
|
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.
|
|
|
|
If you want detailed information, use resin app <id> instead.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
$ resin apps
|
|
|
|
'''
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-01-15 17:10:14 +00:00
|
|
|
resin.models.application.getAll (error, applications) ->
|
|
|
|
return done(error) if error?
|
2015-01-21 13:50:19 +00:00
|
|
|
console.log visuals.widgets.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
|
|
|
]
|
|
|
|
return done()
|
|
|
|
|
|
|
|
exports.info =
|
|
|
|
signature: 'app <id>'
|
|
|
|
description: 'list a single application'
|
|
|
|
help: '''
|
|
|
|
Use this command to show detailed information for a single application.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
$ resin app 91
|
|
|
|
'''
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-01-15 17:10:14 +00:00
|
|
|
resin.models.application.get params.id, (error, application) ->
|
|
|
|
return done(error) if error?
|
2015-01-21 13:50:19 +00:00
|
|
|
console.log visuals.widgets.table.vertical application, [
|
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
|
|
|
'git_repository'
|
|
|
|
'commit'
|
2015-01-15 17:10:14 +00:00
|
|
|
]
|
|
|
|
return done()
|
|
|
|
|
|
|
|
exports.restart =
|
|
|
|
signature: 'app restart <id>'
|
|
|
|
description: 'restart an application'
|
|
|
|
help: '''
|
|
|
|
Use this command to restart all devices that belongs to a certain application.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
$ resin app restart 91
|
|
|
|
'''
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-01-15 17:10:14 +00:00
|
|
|
resin.models.application.restart(params.id, done)
|
|
|
|
|
|
|
|
exports.remove =
|
|
|
|
signature: 'app rm <id>'
|
|
|
|
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:
|
|
|
|
$ resin app rm 91
|
|
|
|
$ resin app rm 91 --yes
|
|
|
|
'''
|
|
|
|
options: [ commandOptions.yes ]
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-01-21 13:50:19 +00:00
|
|
|
visuals.patterns.remove 'application', options.yes, (callback) ->
|
2015-01-15 17:10:14 +00:00
|
|
|
resin.models.application.remove(params.id, callback)
|
|
|
|
, done
|
|
|
|
|
|
|
|
exports.init =
|
|
|
|
signature: 'init <id>'
|
|
|
|
description: 'init an application'
|
|
|
|
help: '''
|
|
|
|
Use this command to associate a local project to an existing resin.io application.
|
|
|
|
|
|
|
|
The application should be a git repository before issuing this command.
|
|
|
|
Notice this command adds a `resin` git remote to your application.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
$ cd myApp && resin init 91
|
|
|
|
'''
|
2015-01-16 12:34:59 +00:00
|
|
|
permission: 'user'
|
|
|
|
action: (params, options, done) ->
|
2015-01-15 17:10:14 +00:00
|
|
|
currentDirectory = process.cwd()
|
|
|
|
|
|
|
|
async.waterfall [
|
|
|
|
|
|
|
|
(callback) ->
|
|
|
|
resin.vcs.isResinProject(currentDirectory, callback)
|
|
|
|
|
|
|
|
(isResinProject, callback) ->
|
|
|
|
if isResinProject
|
|
|
|
error = new Error('Project is already a resin application.')
|
|
|
|
return callback(error)
|
|
|
|
return callback()
|
|
|
|
|
|
|
|
(callback) ->
|
|
|
|
resin.models.application.get(params.id, callback)
|
|
|
|
|
|
|
|
(application, callback) ->
|
|
|
|
resin.vcs.initProjectWithApplication(application, currentDirectory, callback)
|
|
|
|
|
|
|
|
], done
|