mirror of
https://github.com/balena-io/balena-cli.git
synced 2025-01-25 13:49:47 +00:00
207 lines
8.1 KiB
JavaScript
207 lines
8.1 KiB
JavaScript
(function() {
|
|
var _, async, commandOptions, form, path, resin, vcs, visuals;
|
|
|
|
path = require('path');
|
|
|
|
_ = require('lodash-contrib');
|
|
|
|
async = require('async');
|
|
|
|
resin = require('resin-sdk');
|
|
|
|
visuals = require('resin-cli-visuals');
|
|
|
|
commandOptions = require('./command-options');
|
|
|
|
vcs = require('resin-vcs');
|
|
|
|
form = require('resin-cli-form');
|
|
|
|
exports.create = {
|
|
signature: 'app create <name>',
|
|
description: 'create an application',
|
|
help: 'Use this command to create a new resin.io application.\n\nYou can specify the application type with the `--type` option.\nOtherwise, an interactive dropdown will be shown for you to select from.\n\nYou can see a list of supported device types with\n\n $ resin devices supported\n\nExamples:\n\n $ resin app create MyApp\n $ resin app create MyApp --type raspberry-pi',
|
|
options: [
|
|
{
|
|
signature: 'type',
|
|
parameter: 'type',
|
|
description: 'application type',
|
|
alias: 't'
|
|
}
|
|
],
|
|
permission: 'user',
|
|
action: function(params, options, done) {
|
|
return async.waterfall([
|
|
function(callback) {
|
|
return resin.models.application.has(params.name).nodeify(callback);
|
|
}, function(hasApplication, callback) {
|
|
if (hasApplication) {
|
|
return callback(new Error('You already have an application with that name!'));
|
|
}
|
|
if (options.type != null) {
|
|
return callback(null, options.type);
|
|
}
|
|
return resin.models.device.getSupportedDeviceTypes().then(function(supportedDeviceTypes) {
|
|
return form.ask({
|
|
message: 'Device Type',
|
|
type: 'list',
|
|
choices: supportedDeviceTypes
|
|
});
|
|
}).nodeify(callback);
|
|
}, function(type, callback) {
|
|
options.type = type;
|
|
return resin.models.application.create(params.name, options.type).nodeify(callback);
|
|
}, function(applicationId, callback) {
|
|
console.info("Application created: " + params.name + " (" + options.type + ", id " + applicationId + ")");
|
|
return callback();
|
|
}
|
|
], done);
|
|
}
|
|
};
|
|
|
|
exports.list = {
|
|
signature: 'apps',
|
|
description: 'list all applications',
|
|
help: 'Use this command to list all your applications.\n\nNotice this command only shows the most important bits of information for each app.\nIf you want detailed information, use resin app <name> instead.\n\nExamples:\n\n $ resin apps',
|
|
permission: 'user',
|
|
action: function(params, options, done) {
|
|
return resin.models.application.getAll().then(function(applications) {
|
|
return console.log(visuals.widgets.table.horizontal(applications, ['id', 'app_name', 'device_type', 'online_devices', 'devices_length']));
|
|
}).nodeify(done);
|
|
}
|
|
};
|
|
|
|
exports.info = {
|
|
signature: 'app <name>',
|
|
description: 'list a single application',
|
|
help: 'Use this command to show detailed information for a single application.\n\nExamples:\n\n $ resin app MyApp',
|
|
permission: 'user',
|
|
action: function(params, options, done) {
|
|
return resin.models.application.get(params.name).then(function(application) {
|
|
return console.log(visuals.widgets.table.vertical(application, ['id', 'app_name', 'device_type', 'git_repository', 'commit']));
|
|
}).nodeify(done);
|
|
}
|
|
};
|
|
|
|
exports.restart = {
|
|
signature: 'app restart <name>',
|
|
description: 'restart an application',
|
|
help: 'Use this command to restart all devices that belongs to a certain application.\n\nExamples:\n\n $ resin app restart MyApp',
|
|
permission: 'user',
|
|
action: function(params, options, done) {
|
|
return resin.models.application.restart(params.name).nodeify(done);
|
|
}
|
|
};
|
|
|
|
exports.remove = {
|
|
signature: 'app rm <name>',
|
|
description: 'remove an application',
|
|
help: 'Use this command to remove a resin.io application.\n\nNotice this command asks for confirmation interactively.\nYou can avoid this by passing the `--yes` boolean option.\n\nExamples:\n\n $ resin app rm MyApp\n $ resin app rm MyApp --yes',
|
|
options: [commandOptions.yes],
|
|
permission: 'user',
|
|
action: function(params, options, done) {
|
|
return async.waterfall([
|
|
function(callback) {
|
|
if (options.yes) {
|
|
return callback(null, true);
|
|
} else {
|
|
return form.ask({
|
|
message: 'Are you sure you want to delete the application?',
|
|
type: 'confirm',
|
|
"default": false
|
|
}).nodeify(callback);
|
|
}
|
|
}, function(confirmed, callback) {
|
|
if (!confirmed) {
|
|
return callback();
|
|
}
|
|
return resin.models.application.remove(params.name).nodeify(callback);
|
|
}
|
|
], done);
|
|
}
|
|
};
|
|
|
|
exports.associate = {
|
|
signature: 'app associate <name>',
|
|
description: 'associate a resin project',
|
|
help: 'Use this command to associate a project directory with a resin application.\n\nThis command adds a \'resin\' git remote to the directory and runs git init if necessary.\n\nNotice this command asks for confirmation interactively.\nYou can avoid this by passing the `--yes` boolean option.\n\nExamples:\n\n $ resin app associate MyApp\n $ resin app associate MyApp --project my/app/directory',
|
|
options: [commandOptions.yes],
|
|
permission: 'user',
|
|
action: function(params, options, done) {
|
|
var currentDirectory;
|
|
currentDirectory = process.cwd();
|
|
return async.waterfall([
|
|
function(callback) {
|
|
return resin.models.application.has(params.name).nodeify(callback);
|
|
}, function(hasApp, callback) {
|
|
var message;
|
|
if (!hasApp) {
|
|
return callback(new Error("Invalid application: " + params.name));
|
|
}
|
|
message = "Are you sure you want to associate " + currentDirectory + " with " + params.name + "?";
|
|
if (options.yes) {
|
|
return callback(null, true);
|
|
} else {
|
|
return form.ask({
|
|
message: message,
|
|
type: 'confirm',
|
|
"default": false
|
|
}).nodeify(callback);
|
|
}
|
|
}, function(confirmed, callback) {
|
|
if (!confirmed) {
|
|
return done();
|
|
}
|
|
return vcs.initialize(currentDirectory).nodeify(callback);
|
|
}, function(callback) {
|
|
return resin.models.application.get(params.name).nodeify(callback);
|
|
}, function(application, callback) {
|
|
return vcs.associate(currentDirectory, application.git_repository).nodeify(callback);
|
|
}
|
|
], function(error, remoteUrl) {
|
|
if (error != null) {
|
|
return done(error);
|
|
}
|
|
console.info("git repository added: " + remoteUrl);
|
|
return done(null, remoteUrl);
|
|
});
|
|
}
|
|
};
|
|
|
|
exports.init = {
|
|
signature: 'init',
|
|
description: 'init an application',
|
|
help: 'Use this command to initialise a directory as a resin application.\n\nThis command performs the following steps:\n - Create a resin.io application.\n - Initialize the current directory as a git repository.\n - Add the corresponding git remote to the application.\n\nExamples:\n\n $ resin init\n $ resin init --project my/app/directory',
|
|
permission: 'user',
|
|
action: function(params, options, done) {
|
|
var currentDirectory;
|
|
currentDirectory = process.cwd();
|
|
return async.waterfall([
|
|
function(callback) {
|
|
var currentDirectoryBasename;
|
|
currentDirectoryBasename = path.basename(currentDirectory);
|
|
return form.ask({
|
|
message: 'What is the name of your application?',
|
|
type: 'input',
|
|
"default": currentDirectoryBasename
|
|
}).nodeify(callback);
|
|
}, function(applicationName, callback) {
|
|
return exports.create.action({
|
|
name: applicationName
|
|
}, options, function(error) {
|
|
if (error != null) {
|
|
return callback(error);
|
|
}
|
|
return callback(null, applicationName);
|
|
});
|
|
}, function(applicationName, callback) {
|
|
return exports.associate.action({
|
|
name: applicationName
|
|
}, options, callback);
|
|
}
|
|
], done);
|
|
}
|
|
};
|
|
|
|
}).call(this);
|