UNPKG

liveapicreator-admin-cli

Version:

The NodeJS command line utility for 'CA Live API Creator' DevOps Administration from CA Technologies

406 lines (382 loc) 11.3 kB
var Client = require('node-rest-client').Client; var colors = require('colors'); var _ = require('underscore'); var Table = require('easy-table'); var fs = require('fs'); var context = require('./context.js'); var login = require('../util/login.js'); var printObject = require('../util/printObject.js'); var dotfile = require('../util/dotfile.js'); module.exports = { doUser: function(action, cmd) { if (action === 'list') { module.exports.list(cmd); } else if (action === 'export') { module.exports.export(cmd); } else if (action === 'import') { module.exports.import(cmd); } else if (action === 'update') { module.exports.update(cmd); } else if (action === 'delete') { module.exports.del(cmd); } else { console.log('You must specify an action: list, delete, update, import, or export'); //program.help(); } }, list: function (cmd) { var client = new Client(); var loginInfo = login.login(cmd); if ( ! loginInfo) return; var url = loginInfo.url; var apiKey = loginInfo.apiKey; var projIdent = cmd.project_ident; if ( ! projIdent) { projIdent = dotfile.getCurrentProject(); if ( ! projIdent) { console.log('There is no current project.'.yellow); return; } } client.get(url + "/admin:users?sysfilter=equal(project_ident:" + projIdent+")&pagesize=100", { headers: { Authorization: "CALiveAPICreator " + apiKey + ":1", "Content-Type" : "application/json" } }, function(data) { if (data.errorMessage) { console.log(data.errorMessage.red); return; } printObject.printHeader('Users'); var table = new Table(); _.each(data, function(p) { table.cell("Ident", p.ident); table.cell("Name", p.name); table.cell("Full Name", p.fullname); table.cell("Status", p.status); table.cell("Roles", p.roles); table.cell("Life Span", p.apikey_lifespan); var comments = p.comments; if ( ! comments) { comments = ""; } else if (comments.length > 50){ comments = comments.substring(0, 47) + "..."; } table.cell("Description", comments); table.newRow(); }); table.sort(['Name']); console.log(table.toString()); printObject.printHeader("# users: " + data.length); }); }, del: function(cmd) { var client = new Client(); var loginInfo = login.login(cmd); if ( ! loginInfo) { console.log('You are not currently logged into a CA Live API Creator server.'.red); return; } var projIdent = cmd.project_ident; if ( ! projIdent) { projIdent = dotfile.getCurrentProject(); if ( ! projIdent) { console.log('There is no current project.'.yellow); return; } } var filt = "equal(project_ident:"+projIdent ; if (cmd.ident) { filt += ",ident:" + cmd.ident + ")"; } else if (cmd.user_name) { filt += ",name:'" + cmd.user_name + "')"; } else { console.log('Missing parameter: please specify either user_name or ident'.red); return; } client.get(loginInfo.url + "/admin:users?sysfilter=" + filt, { headers: { Authorization: "CALiveAPICreator " + loginInfo.apiKey + ":1", "Content-Type" : "application/json" } }, function(data) { //console.log('get result: ' + JSON.stringify(data, null, 2)); if (data.errorMessage) { console.log(("Error: " + data.errorMessage).red); return; } if (data.length === 0) { console.log(("Error: no such user ident or user_name").red); return; } if (data.length > 1) { console.log(("Error: more than one user for the given condition: " + filt).red); return; } var db = data[0]; var startTime = new Date(); client['delete'](db['@metadata'].href + "?checksum=" + db['@metadata'].checksum, { headers: { Authorization: "CALiveAPICreator " + loginInfo.apiKey + ":1", "Content-Type" : "application/json" } }, function(data2) { var endTime = new Date(); if (data2.errorMessage) { console.log(data2.errorMessage.red); return; } printObject.printHeader('User was deleted, including the following objects:'); _.each(data2.txsummary, function(obj) { printObject.printObject(obj, obj['@metadata'].entity, 0, obj['@metadata'].verb); }); var trailer = "Request took: " + (endTime - startTime) + "ms"; trailer += " - # objects touched: "; if (data2.txsummary.length == 0) { console.log('No data returned'.yellow); } else { trailer += data2.txsummary.length; } printObject.printHeader(trailer); }); }); }, export: function(cmd) { var client = new Client(); var loginInfo = login.login(cmd); if ( ! loginInfo) return; var url = loginInfo.url; var apiKey = loginInfo.apiKey; var projIdent = cmd.project_ident; if ( ! projIdent) { projIdent = dotfile.getCurrentProject(); if ( ! projIdent) { console.log('There is no current project.'.yellow); return; } } var filter = null; if (projIdent) { filter = "sysfilter=equal(project_ident:" + projIdent + ")"; } else { console.log('Missing parameter: please specify project settings (use list) project_ident '.red); return; } var toStdout = false; if ( ! cmd.file) { toStdout = true; } client.get(loginInfo.url + "/admin:users?pagesize=1000&"+filter, { headers: { Authorization: "CALiveAPICreator " + loginInfo.apiKey + ":1", "Content-Type" : "application/json" } }, function(data) { //console.log('get result: ' + JSON.stringify(data, null, 2)); if (data.errorMessage) { console.log(("Error: " + data.errorMessage).red); return; } if (data.length === 0) { console.log(("User not found").red); return; } for(var idx = 0; idx < data.length ; idx++){ delete data[idx].ident; delete data[idx]['@metadata'] delete data[idx].project_ident; delete data[idx].password_hash; //do not export delete data[idx].password_salt; //do not export } if (toStdout) { console.log(JSON.stringify(data, null, 2)); } else { var exportFile = fs.openSync(cmd.file, 'w+', 0600); fs.writeSync(exportFile, JSON.stringify(data, null, 2)); console.log(('Users have been exported to file: ' + cmd.file).green); } }); }, import: function(cmd) { var client = new Client(); var loginInfo = login.login(cmd); if ( ! loginInfo) { return; } var projIdent = cmd.project_ident; if ( ! projIdent) { projIdent = dotfile.getCurrentProject(); if ( ! projIdent) { console.log('There is no current project.'.yellow); return; } } if ( ! cmd.file) { cmd.file = '/dev/stdin'; } var fileContent = JSON.parse(fs.readFileSync(cmd.file)); if(Array.isArray(fileContent) && fileContent.length > 0){ for(var i = 0 ; i < fileContent.length ; i++ ){ fileContent[i].project_ident = projIdent; delete fileContent[i].ts; fileContent[i]["@metadata"] = {action:"MERGE_INSERT", key: ["name","project_ident"]} ; } } else { fileContent.project_ident = projIdent; delete fileContent.ts; fileContent["@metadata"] = {action:"MERGE_INSERT", key: ["project_ident","name"]} ; } var startTime = new Date(); client.put(loginInfo.url + "/admin:users", { data: fileContent, headers: { Authorization: "CALiveAPICreator " + loginInfo.apiKey + ":1", "Content-Type" : "application/json" } }, function(data) { var endTime = new Date(); if (data.errorMessage) { console.log(data.errorMessage.red); return; } printObject.printHeader('User(s) created, including:'); if(data.statusCode == 200 ){ console.log("Request took: " + (endTime - startTime) + "ms"); return; } var newUsers = _.find( data.txsummary, function(p) { return p['@metadata'].resource === 'admin:users'; }); if ( ! newUsers) { console.log('ERROR: unable to find imported users'.red); return; } if (cmd.verbose) { _.each(data.txsummary, function(obj) { printObject.printObject(obj, obj['@metadata'].entity, 0, obj['@metadata'].verb); }); } else { printObject.printObject(newUsers, newUsers['@metadata'].entity, 0, newUsers['@metadata'].verb); console.log(('and ' + (data.txsummary.length - 1) + ' other objects').grey); } var trailer = "Request took: " + (endTime - startTime) + "ms"; trailer += " - # objects touched: "; if (data.txsummary.length === 0) { console.log('No data returned'.yellow); } else { trailer += data.txsummary.length; } printObject.printHeader(trailer); }); }, update: function(cmd) { var client = new Client(); var loginInfo = login.login(cmd); if ( ! loginInfo) { return; } var filter = null; var projIdent = cmd.project_ident; if ( ! projIdent) { projIdent = dotfile.getCurrentProject(); if ( ! projIdent) { console.log('There is no current project.'.yellow); return; } filter = "sysfilter=equal(project_ident: "+ projIdent +")" ; } if(cmd.ident){ filter += "&sysfilter=equal(ident: "+ cmd.ident +")" ; } else { if (cmd.user_name) { filter += "&sysfilter=equal(name:'" + cmd.user_name + "')"; } else { console.log('Missing parameter: please specify either user_name or ident'.red); return; } } //console.log(filter); client.get(loginInfo.url + "/admin:users?" + filter, { headers: { Authorization: "CALiveAPICreator " + loginInfo.apiKey + ":1", "Content-Type" : "application/json" } }, function(data) { if (data.errorMessage) { console.log(("Error: " + data.errorMessage).red); return; } if (data.length === 0) { console.log(("User not found").red); return; } if (data.length > 1) { console.log(("Error: more than one users for the given condition: " + filter).red); return; } var db = data[0]; if( cmd.user_name) { db.name = cmd.user_name; } if( cmd.fullname) { db.fullname = cmd.fullname; } if( cmd.comments){ db.comments = cmd.comments; } if( cmd.password ){ db.password = cmd.password; } if( cmd.status ){ db.status = cmd.status; } if( cmd.roles ){ db.roles = cmd.roles; } var startTime = new Date(); db["@metadata"] = {action:"MERGE_INSERT", key: ["project_ident","name"]} ; client.put(db['@metadata'].href, { data: db, headers: { Authorization: "CALiveAPICreator " + loginInfo.apiKey + ":1", "Content-Type" : "application/json" } }, function(data2) { var endTime = new Date(); //console.log(JSON.stringify(data2,null,2)); if (data2.errorMessage) { console.log(data2.errorMessage.red); return; } printObject.printHeader('User was updated, including the following objects:'); _.each(data2.txsummary, function(obj) { printObject.printObject(obj, obj['@metadata'].entity, 0, obj['@metadata'].verb); }); var trailer = "Request took: " + (endTime - startTime) + "ms"; trailer += " - # objects touched: "; if (data2.txsummary.length == 0) { console.log('No data returned'.yellow); } else { trailer += data2.txsummary.length; } printObject.printHeader(trailer); }); }); } };