Spaces:
Runtime error
Runtime error
; | |
const { isUtf8 } = require('buffer'); | |
// | |
// Allowed token characters: | |
// | |
// '!', '#', '$', '%', '&', ''', '*', '+', '-', | |
// '.', 0-9, A-Z, '^', '_', '`', a-z, '|', '~' | |
// | |
// tokenChars[32] === 0 // ' ' | |
// tokenChars[33] === 1 // '!' | |
// tokenChars[34] === 0 // '"' | |
// ... | |
// | |
// prettier-ignore | |
const tokenChars = [ | |
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 0 - 15 | |
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16 - 31 | |
0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, // 32 - 47 | |
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, // 48 - 63 | |
0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64 - 79 | |
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, // 80 - 95 | |
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96 - 111 | |
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0 // 112 - 127 | |
]; | |
/** | |
* Checks if a status code is allowed in a close frame. | |
* | |
* @param {Number} code The status code | |
* @return {Boolean} `true` if the status code is valid, else `false` | |
* @public | |
*/ | |
function isValidStatusCode(code) { | |
return ( | |
(code >= 1000 && | |
code <= 1014 && | |
code !== 1004 && | |
code !== 1005 && | |
code !== 1006) || | |
(code >= 3000 && code <= 4999) | |
); | |
} | |
/** | |
* Checks if a given buffer contains only correct UTF-8. | |
* Ported from https://www.cl.cam.ac.uk/%7Emgk25/ucs/utf8_check.c by | |
* Markus Kuhn. | |
* | |
* @param {Buffer} buf The buffer to check | |
* @return {Boolean} `true` if `buf` contains only correct UTF-8, else `false` | |
* @public | |
*/ | |
function _isValidUTF8(buf) { | |
const len = buf.length; | |
let i = 0; | |
while (i < len) { | |
if ((buf[i] & 0x80) === 0) { | |
// 0xxxxxxx | |
i++; | |
} else if ((buf[i] & 0xe0) === 0xc0) { | |
// 110xxxxx 10xxxxxx | |
if ( | |
i + 1 === len || | |
(buf[i + 1] & 0xc0) !== 0x80 || | |
(buf[i] & 0xfe) === 0xc0 // Overlong | |
) { | |
return false; | |
} | |
i += 2; | |
} else if ((buf[i] & 0xf0) === 0xe0) { | |
// 1110xxxx 10xxxxxx 10xxxxxx | |
if ( | |
i + 2 >= len || | |
(buf[i + 1] & 0xc0) !== 0x80 || | |
(buf[i + 2] & 0xc0) !== 0x80 || | |
(buf[i] === 0xe0 && (buf[i + 1] & 0xe0) === 0x80) || // Overlong | |
(buf[i] === 0xed && (buf[i + 1] & 0xe0) === 0xa0) // Surrogate (U+D800 - U+DFFF) | |
) { | |
return false; | |
} | |
i += 3; | |
} else if ((buf[i] & 0xf8) === 0xf0) { | |
// 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx | |
if ( | |
i + 3 >= len || | |
(buf[i + 1] & 0xc0) !== 0x80 || | |
(buf[i + 2] & 0xc0) !== 0x80 || | |
(buf[i + 3] & 0xc0) !== 0x80 || | |
(buf[i] === 0xf0 && (buf[i + 1] & 0xf0) === 0x80) || // Overlong | |
(buf[i] === 0xf4 && buf[i + 1] > 0x8f) || | |
buf[i] > 0xf4 // > U+10FFFF | |
) { | |
return false; | |
} | |
i += 4; | |
} else { | |
return false; | |
} | |
} | |
return true; | |
} | |
module.exports = { | |
isValidStatusCode, | |
isValidUTF8: _isValidUTF8, | |
tokenChars | |
}; | |
if (isUtf8) { | |
module.exports.isValidUTF8 = function (buf) { | |
return buf.length < 24 ? _isValidUTF8(buf) : isUtf8(buf); | |
}; | |
} /* istanbul ignore else */ else if (!process.env.WS_NO_UTF_8_VALIDATE) { | |
try { | |
const isValidUTF8 = require('utf-8-validate'); | |
module.exports.isValidUTF8 = function (buf) { | |
return buf.length < 32 ? _isValidUTF8(buf) : isValidUTF8(buf); | |
}; | |
} catch (e) { | |
// Continue regardless of the error. | |
} | |
} | |