1

I am trying to implement a new feature for our in-house brand of hubot. The feature uses the npm package simple-ssh (wrapper for ssh2) and basically takes an environment (i.e. "@hubot get versions DEV) as input, gets the servers and credentials for that environment, and runs a number of bash commands to return a version for a particular software on each server.

I am able to run this fine and view the output when using console.log(), but what I need is to append to an array so I can send it back in the hubot reply. However, I can append to neither the response string nor the array I have created from within the out(stdout) function after each .exec.

How can I use the stdout from each command in my reply with hubot?

require('dotenv').config('../.env');

const SSH = require('simple-ssh');
const { Resolver } = require('../../../utils/Resolver');

const resolver = new Resolver();
let response = '';
let versions = [];

// parses initial request from flowdock into separate environments
function getEnvsFromRequest(reqEnvsStr) {
  return reqEnvsStr.toUpperCase().replace(/AND/, '').replace(/\s+/g, '').split(',');
}

function getVersions(res) {
  const env = getEnvsFromRequest(res.match[2].toString());
  const resEnv = resolver.resolveEnv(env);
  if (resEnv === null) {
    res.reply(`${env} is not in my list of available environments.`);
    return;
  }
  if (resEnv.length > 0) {
    response = response.concat(`\nHere are the results for ${resEnv}:\n`);
    response = response.concat('------------------------\n');
  }
// Resolve hosts for environment
  let resHosts = [];
  resHosts = resolver.resolveHosts(resEnv);
// Resolve creds for environment
  let resCreds = [];
  resCreds = resolver.resolveCreds(resEnv);

// Loop through available hosts for each environment
  resHosts.forEach((resHost) => {
    dummy = [];
    dummy.push(`${resHost}:\n`);
    const ssh = new SSH({
      host: resHost,
      user: resCreds[0],
      pass: resCreds[1],
    });

    ssh
    // Example 1 version
      .exec('head -3 /app/foo/foo/bar | tail -1 | cut -d \'=\' -f 2', {
        // out(stdout) { response.concat(`Foo foo bar version: ${stdout}`); },
        out(stdout) { dummy.push(`Foo foo bar version: ${stdout}`); },
      })
    // Example 2 version
      .exec('cd /app/foo/bar && ls -td -- * | head -n 1', {
        // out(stdout) { response.concat(`Foo bar version: ${stdout}`); },
        out(stdout) { dummy.push(`Foo bar version: ${stdout}`); },
      })
      .start();
  });
  versions.push(dummy)
}
response.concat(versions.toString());
res.reply(response);

0 Answers0