| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 | 'use strict';const { isUtf8 } = require('buffer');//// Allowed token characters://// '!', '#', '$', '%', '&', ''', '*', '+', '-',// '.', 0-9, A-Z, '^', '_', '`', a-z, '|', '~'//// tokenChars[32] === 0 // ' '// tokenChars[33] === 1 // '!'// tokenChars[34] === 0 // '"'// ...//// prettier-ignoreconst 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.  }}
 |