balena-cli/build/actions/keys.js

89 lines
3.3 KiB
JavaScript
Raw Normal View History

2015-02-26 15:47:56 +00:00
(function() {
var commandOptions;
2015-08-31 21:39:48 +00:00
2015-02-26 15:47:56 +00:00
commandOptions = require('./command-options');
exports.list = {
signature: 'keys',
description: 'list all ssh keys',
help: 'Use this command to list all your SSH keys.\n\nExamples:\n\n $ resin keys',
2015-02-26 15:47:56 +00:00
permission: 'user',
action: function(params, options, done) {
var resin, visuals;
resin = require('resin-sdk');
visuals = require('resin-cli-visuals');
return resin.models.key.getAll().then(function(keys) {
return console.log(visuals.table.horizontal(keys, ['id', 'title']));
}).nodeify(done);
2015-02-26 15:47:56 +00:00
}
};
exports.info = {
signature: 'key <id>',
description: 'list a single ssh key',
help: 'Use this command to show information about a single SSH key.\n\nExamples:\n\n $ resin key 17',
2015-02-26 15:47:56 +00:00
permission: 'user',
action: function(params, options, done) {
var resin, visuals;
resin = require('resin-sdk');
visuals = require('resin-cli-visuals');
return resin.models.key.get(params.id).then(function(key) {
console.log(visuals.table.vertical(key, ['id', 'title']));
return console.log('\n' + key.public_key);
}).nodeify(done);
2015-02-26 15:47:56 +00:00
}
};
exports.remove = {
signature: 'key rm <id>',
description: 'remove a ssh key',
help: 'Use this command to remove a SSH key from resin.io.\n\nNotice this command asks for confirmation interactively.\nYou can avoid this by passing the `--yes` boolean option.\n\nExamples:\n\n $ resin key rm 17\n $ resin key rm 17 --yes',
2015-02-26 15:47:56 +00:00
options: [commandOptions.yes],
permission: 'user',
action: function(params, options, done) {
var events, patterns, resin;
resin = require('resin-sdk');
events = require('resin-cli-events');
patterns = require('../utils/patterns');
return patterns.confirm(options.yes, 'Are you sure you want to delete the key?').then(function() {
2015-08-17 13:28:10 +00:00
return resin.models.key.remove(params.id);
2015-08-31 21:39:48 +00:00
}).tap(function() {
return events.send('publicKey.delete', {
id: params.id
});
2015-08-17 13:28:10 +00:00
}).nodeify(done);
2015-02-26 15:47:56 +00:00
}
};
exports.add = {
signature: 'key add <name> [path]',
description: 'add a SSH key to resin.io',
help: 'Use this command to associate a new SSH key with your account.\n\nIf `path` is omitted, the command will attempt\nto read the SSH key from stdin.\n\nExamples:\n\n $ resin key add Main ~/.ssh/id_rsa.pub\n $ cat ~/.ssh/id_rsa.pub | resin key add Main',
2015-02-26 15:47:56 +00:00
permission: 'user',
action: function(params, options, done) {
var Promise, _, capitano, events, fs, resin;
_ = require('lodash');
Promise = require('bluebird');
fs = Promise.promisifyAll(require('fs'));
capitano = require('capitano');
resin = require('resin-sdk');
events = require('resin-cli-events');
2015-08-17 13:28:10 +00:00
return Promise["try"](function() {
if (params.path != null) {
return fs.readFileAsync(params.path, {
encoding: 'utf8'
});
2015-02-26 15:47:56 +00:00
}
2015-08-17 13:28:10 +00:00
return Promise.fromNode(function(callback) {
return capitano.utils.getStdin(function(data) {
return callback(null, data);
});
});
2015-08-31 21:39:48 +00:00
}).then(_.partial(resin.models.key.create, params.name)).tap(function() {
return events.send('publicKey.create');
}).nodeify(done);
2015-02-26 15:47:56 +00:00
}
};
}).call(this);