return Math.floor(crypto.randomInt(max + 1));
}
+ /**
+ * Rounds the given number to the given scale.
+ * The rounding is done using the "round half away from zero" method.
+ *
+ * @param numberValue - The number to round.
+ * @param scale - The scale to round to.
+ * @returns The rounded number.
+ */
public static roundTo(numberValue: number, scale: number): number {
const roundPower = Math.pow(10, scale);
return Math.round(numberValue * roundPower * (1 + Number.EPSILON)) / roundPower;
`${str.slice(0, pos)}${subStr}${str.slice(pos)}`;
/**
+ * Computes the retry delay in milliseconds using an exponential backoff algorithm.
+ *
* @param retryNumber - the number of retries that have already been attempted
* @returns delay in milliseconds
*/
}
/**
- * Generate a cryptographically secure random number in the [0,1[ range
+ * Generates a cryptographically secure random number in the [0,1[ range
*
* @returns
*/
}
/**
- * Convert websocket error code to human readable string message
+ * Converts websocket error code to human readable string message
*
* @param code - websocket error code
* @returns human readable string message