@ -7,7 +7,7 @@
// Backend uses the compiled file util.js
// Backend uses the compiled file util.js
// Frontend uses util.ts
// Frontend uses util.ts
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
exports . getMonitorRelativeURL = exports . genSecret = exports . getRandomInt = exports . getRandomArbitrary = exports . TimeLogger = exports . polyfill = exports . debug = exports . ucfirst = exports . sleep = exports . flipStatus = exports . STATUS_PAGE_PARTIAL_DOWN = exports . STATUS_PAGE_ALL_UP = exports . STATUS_PAGE_ALL_DOWN = exports . PENDING = exports . UP = exports . DOWN = exports . appName = exports . isDev = void 0 ;
exports . getMonitorRelativeURL = exports . genSecret = exports . getCryptoRandomInt = exports . get RandomInt = exports . getRandomArbitrary = exports . TimeLogger = exports . polyfill = exports . debug = exports . ucfirst = exports . sleep = exports . flipStatus = exports . STATUS_PAGE_PARTIAL_DOWN = exports . STATUS_PAGE_ALL_UP = exports . STATUS_PAGE_ALL_DOWN = exports . PENDING = exports . UP = exports . DOWN = exports . appName = exports . isDev = void 0 ;
const _ dayjs = require ( "dayjs" ) ;
const _ dayjs = require ( "dayjs" ) ;
const dayjs = _ dayjs ;
const dayjs = _ dayjs ;
exports . isDev = process . env . NODE_ENV === "development" ;
exports . isDev = process . env . NODE_ENV === "development" ;
@ -102,12 +102,61 @@ function getRandomInt(min, max) {
return Math . floor ( Math . random ( ) * ( max - min + 1 ) ) + min ;
return Math . floor ( Math . random ( ) * ( max - min + 1 ) ) + min ;
}
}
exports . getRandomInt = getRandomInt ;
exports . getRandomInt = getRandomInt ;
/ * *
* Returns either the NodeJS crypto . randomBytes ( ) function or its
* browser equivalent implemented via window . crypto . getRandomValues ( )
* /
let getRandomBytes = ( ( typeof window !== 'undefined' && window . crypto )
// Browsers
? function ( ) {
return ( numBytes ) => {
let randomBytes = new Uint8Array ( numBytes ) ;
for ( let i = 0 ; i < numBytes ; i += 65536 ) {
window . crypto . getRandomValues ( randomBytes . subarray ( i , i + Math . min ( numBytes - i , 65536 ) ) ) ;
}
return randomBytes ;
} ;
}
// Node
: function ( ) {
return require ( "crypto" ) . randomBytes ;
} ) ( ) ;
function getCryptoRandomInt ( min , max ) {
// synchronous version of: https://github.com/joepie91/node-random-number-csprng
const range = max - min ;
if ( range >= Math . pow ( 2 , 32 ) )
console . log ( "Warning! Range is too large." ) ;
let tmpRange = range ;
let bitsNeeded = 0 ;
let bytesNeeded = 0 ;
let mask = 1 ;
while ( tmpRange > 0 ) {
if ( bitsNeeded % 8 === 0 )
bytesNeeded += 1 ;
bitsNeeded += 1 ;
mask = mask << 1 | 1 ;
tmpRange = tmpRange >>> 1 ;
}
const randomBytes = getRandomBytes ( bytesNeeded ) ;
let randomValue = 0 ;
for ( let i = 0 ; i < bytesNeeded ; i ++ ) {
randomValue |= randomBytes [ i ] << 8 * i ;
}
randomValue = randomValue & mask ;
if ( randomValue <= range ) {
return min + randomValue ;
}
else {
return getCryptoRandomInt ( min , max ) ;
}
}
exports . getCryptoRandomInt = getCryptoRandomInt ;
function genSecret ( length = 64 ) {
function genSecret ( length = 64 ) {
let secret = "" ;
let secret = "" ;
let chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789" ;
cons t chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789" ;
let charsLength = chars . length ;
cons t charsLength = chars . length ;
for ( let i = 0 ; i < length ; i ++ ) {
for ( let i = 0 ; i < length ; i ++ ) {
secret += chars . charAt ( Math . floor ( Math . random ( ) * charsLength ) ) ;
secret += chars . charAt ( getCryptoRandomInt ( 0 , charsLength - 1 ) ) ;
}
}
return secret ;
return secret ;
}
}