"use strict"; const crypto = require('crypto'); const randtoken = require('rand-token').generator({source: 'crypto'}); const unescape = require('unescape'); function newEntityId() { return randomString(12); } function randomString(length) { return randtoken.generate(length); } function randomSecureToken(bytes = 32) { return crypto.randomBytes(bytes).toString('base64'); } function toBase64(plainText) { return Buffer.from(plainText).toString('base64'); } function fromBase64(encodedText) { return Buffer.from(encodedText, 'base64'); } function hmac(secret, value) { const hmac = crypto.createHmac('sha256', Buffer.from(secret.toString(), 'ASCII')); hmac.update(value.toString()); return hmac.digest('base64'); } function isElectron() { return !!process.versions['electron']; } function hash(text) { return crypto.createHash('sha1').update(text).digest('base64'); } function isEmptyOrWhitespace(str) { return str === null || str.match(/^ *$/) !== null; } function sanitizeSql(str) { // should be improved or usage eliminated return str.replace(/'/g, "\\'"); } async function stopWatch(what, func) { const start = new Date(); const ret = await func(); const tookMs = new Date().getTime() - start.getTime(); console.log(`${what} took ${tookMs}ms`); return ret; } function unescapeHtml(str) { return unescape(str); } function toObject(array, fn) { const obj = {}; for (const item of array) { const ret = fn(item); obj[ret[0]] = ret[1]; } return obj; } module.exports = { randomSecureToken, randomString, newEntityId, toBase64, fromBase64, hmac, isElectron, hash, isEmptyOrWhitespace, sanitizeSql, stopWatch, unescapeHtml, toObject };