mirror of
https://github.com/trufflesecurity/xsshunter
synced 2024-12-18 00:33:04 +00:00
40 lines
No EOL
1.2 KiB
JavaScript
40 lines
No EOL
1.2 KiB
JavaScript
const crypto = require('crypto');
|
|
const bcrypt = require('bcrypt');
|
|
const moment = require('moment');
|
|
|
|
function copy(input_data) {
|
|
return JSON.parse(JSON.stringify(input_data));
|
|
}
|
|
|
|
function get_secure_random_string(bytes_length) {
|
|
const validChars = 'abcdefghijklmnopqrstuvwxyz0123456789';
|
|
let array = crypto.randomBytes(bytes_length);
|
|
array = array.map(x => validChars.charCodeAt(x % validChars.length));
|
|
const random_string = String.fromCharCode.apply(null, array);
|
|
return random_string;
|
|
}
|
|
|
|
async function get_hashed_password(password) {
|
|
// If no environment variable is set, default
|
|
// to doing 10 rounds.
|
|
const bcrypt_rounds = process.env.BCRYPT_ROUNDS ? parseInt(process.env.BCRYPT_ROUNDS) : 10;
|
|
|
|
return bcrypt.hash(
|
|
password,
|
|
bcrypt_rounds
|
|
);
|
|
}
|
|
|
|
function logit(input_string) {
|
|
const datetime = moment().format('MMMM Do YYYY, h:mm:ss a');
|
|
// Add spacer unless it starts with a `[`
|
|
const spacer = input_string.startsWith('[') ? '' : ' ';
|
|
console.log(`[${datetime}]${spacer}${input_string.trim()}`);
|
|
}
|
|
|
|
module.exports = {
|
|
copy: copy,
|
|
get_secure_random_string: get_secure_random_string,
|
|
get_hashed_password: get_hashed_password,
|
|
logit: logit
|
|
}; |