/** * Utility functions that need to be reimplemented for each environment. * This is the version for Node.js * @module customUtilsNode */ const crypto = require('crypto') /** * Return a random alphanumerical string of length len * There is a very small probability (less than 1/1,000,000) for the length to be less than len * (il the base64 conversion yields too many pluses and slashes) but * that's not an issue here * The probability of a collision is extremely small (need 3*10^12 documents to have one chance in a million of a collision) * See http://en.wikipedia.org/wiki/Birthday_problem * @param {number} len * @return {string} * @alias module:customUtilsNode.uid */ const uid = len => crypto.randomBytes(Math.ceil(Math.max(8, len * 2))) .toString('base64') .replace(/[+/]/g, '') .slice(0, len) // Interface module.exports.uid = uid