/* jshint esversion: 6, asi: true, node: true */ // util.js // private require('colors'); // allow for color property extensions in log messages const debug = require('debug')('WebSSH2'); const Auth = require('basic-auth'); const defaultCredentials = { username: null, password: null, privatekey: null }; exports.setDefaultCredentials = function setDefaultCredentials(username, password, privatekey) { defaultCredentials.username = username; defaultCredentials.password = password; defaultCredentials.privatekey = privatekey; }; exports.basicAuth = function basicAuth(req, res, next) { const myAuth = Auth(req); if (myAuth && myAuth.pass !== '') { req.session.username = myAuth.name; req.session.userpassword = myAuth.pass; debug( `myAuth.name: ${myAuth.name.yellow.bold.underline} and password ${ myAuth.pass ? 'exists'.yellow.bold.underline : 'is blank'.underline.red.bold }` ); } else { req.session.username = defaultCredentials.username; req.session.userpassword = defaultCredentials.password; req.session.privatekey = defaultCredentials.privatekey; } if (!req.session.userpassword && !req.session.privatekey) { res.statusCode = 401; debug('basicAuth credential request (401)'); res.setHeader('WWW-Authenticate', 'Basic realm="WebSSH"'); res.end('Username and password required for web SSH service.'); return; } next(); }; // takes a string, makes it boolean (true if the string is true, false otherwise) exports.parseBool = function parseBool(str) { return str.toLowerCase() === 'true'; };