Spaces:
Sleeping
Sleeping
| // GENERATED FILE. DO NOT EDIT. | |
| var ipCodec = (function(exports) { | |
| "use strict"; | |
| Object.defineProperty(exports, "__esModule", { | |
| value: true | |
| }); | |
| exports.decode = decode; | |
| exports.encode = encode; | |
| exports.familyOf = familyOf; | |
| exports.name = void 0; | |
| exports.sizeOf = sizeOf; | |
| exports.v6 = exports.v4 = void 0; | |
| const v4Regex = /^(\d{1,3}\.){3,3}\d{1,3}$/; | |
| const v4Size = 4; | |
| const v6Regex = /^(::)?(((\d{1,3}\.){3}(\d{1,3}){1})?([0-9a-f]){0,4}:{0,2}){1,8}(::)?$/i; | |
| const v6Size = 16; | |
| const v4 = { | |
| name: 'v4', | |
| size: v4Size, | |
| isFormat: ip => v4Regex.test(ip), | |
| encode(ip, buff, offset) { | |
| offset = ~~offset; | |
| buff = buff || new Uint8Array(offset + v4Size); | |
| const max = ip.length; | |
| let n = 0; | |
| for (let i = 0; i < max;) { | |
| const c = ip.charCodeAt(i++); | |
| if (c === 46) { | |
| // "." | |
| buff[offset++] = n; | |
| n = 0; | |
| } else { | |
| n = n * 10 + (c - 48); | |
| } | |
| } | |
| buff[offset] = n; | |
| return buff; | |
| }, | |
| decode(buff, offset) { | |
| offset = ~~offset; | |
| return `${buff[offset++]}.${buff[offset++]}.${buff[offset++]}.${buff[offset]}`; | |
| } | |
| }; | |
| exports.v4 = v4; | |
| const v6 = { | |
| name: 'v6', | |
| size: v6Size, | |
| isFormat: ip => ip.length > 0 && v6Regex.test(ip), | |
| encode(ip, buff, offset) { | |
| offset = ~~offset; | |
| let end = offset + v6Size; | |
| let fill = -1; | |
| let hexN = 0; | |
| let decN = 0; | |
| let prevColon = true; | |
| let useDec = false; | |
| buff = buff || new Uint8Array(offset + v6Size); // Note: This algorithm needs to check if the offset | |
| // could exceed the buffer boundaries as it supports | |
| // non-standard compliant encodings that may go beyond | |
| // the boundary limits. if (offset < end) checks should | |
| // not be necessary... | |
| for (let i = 0; i < ip.length; i++) { | |
| let c = ip.charCodeAt(i); | |
| if (c === 58) { | |
| // : | |
| if (prevColon) { | |
| if (fill !== -1) { | |
| // Not Standard! (standard doesn't allow multiple ::) | |
| // We need to treat | |
| if (offset < end) buff[offset] = 0; | |
| if (offset < end - 1) buff[offset + 1] = 0; | |
| offset += 2; | |
| } else if (offset < end) { | |
| // :: in the middle | |
| fill = offset; | |
| } | |
| } else { | |
| // : ends the previous number | |
| if (useDec === true) { | |
| // Non-standard! (ipv4 should be at end only) | |
| // A ipv4 address should not be found anywhere else but at | |
| // the end. This codec also support putting characters | |
| // after the ipv4 address.. | |
| if (offset < end) buff[offset] = decN; | |
| offset++; | |
| } else { | |
| if (offset < end) buff[offset] = hexN >> 8; | |
| if (offset < end - 1) buff[offset + 1] = hexN & 0xff; | |
| offset += 2; | |
| } | |
| hexN = 0; | |
| decN = 0; | |
| } | |
| prevColon = true; | |
| useDec = false; | |
| } else if (c === 46) { | |
| // . indicates IPV4 notation | |
| if (offset < end) buff[offset] = decN; | |
| offset++; | |
| decN = 0; | |
| hexN = 0; | |
| prevColon = false; | |
| useDec = true; | |
| } else { | |
| prevColon = false; | |
| if (c >= 97) { | |
| c -= 87; // a-f ... 97~102 -87 => 10~15 | |
| } else if (c >= 65) { | |
| c -= 55; // A-F ... 65~70 -55 => 10~15 | |
| } else { | |
| c -= 48; // 0-9 ... starting from charCode 48 | |
| decN = decN * 10 + c; | |
| } // We don't know yet if its a dec or hex number | |
| hexN = (hexN << 4) + c; | |
| } | |
| } | |
| if (prevColon === false) { | |
| // Commiting last number | |
| if (useDec === true) { | |
| if (offset < end) buff[offset] = decN; | |
| offset++; | |
| } else { | |
| if (offset < end) buff[offset] = hexN >> 8; | |
| if (offset < end - 1) buff[offset + 1] = hexN & 0xff; | |
| offset += 2; | |
| } | |
| } else if (fill === 0) { | |
| // Not Standard! (standard doesn't allow multiple ::) | |
| // This means that a : was found at the start AND end which means the | |
| // end needs to be treated as 0 entry... | |
| if (offset < end) buff[offset] = 0; | |
| if (offset < end - 1) buff[offset + 1] = 0; | |
| offset += 2; | |
| } else if (fill !== -1) { | |
| // Non-standard! (standard doens't allow multiple ::) | |
| // Here we find that there has been a :: somewhere in the middle | |
| // and the end. To treat the end with priority we need to move all | |
| // written data two bytes to the right. | |
| offset += 2; | |
| for (let i = Math.min(offset - 1, end - 1); i >= fill + 2; i--) { | |
| buff[i] = buff[i - 2]; | |
| } | |
| buff[fill] = 0; | |
| buff[fill + 1] = 0; | |
| fill = offset; | |
| } | |
| if (fill !== offset && fill !== -1) { | |
| // Move the written numbers to the end while filling the everything | |
| // "fill" to the bytes with zeros. | |
| if (offset > end - 2) { | |
| // Non Standard support, when the cursor exceeds bounds. | |
| offset = end - 2; | |
| } | |
| while (end > fill) { | |
| buff[--end] = offset < end && offset > fill ? buff[--offset] : 0; | |
| } | |
| } else { | |
| // Fill the rest with zeros | |
| while (offset < end) { | |
| buff[offset++] = 0; | |
| } | |
| } | |
| return buff; | |
| }, | |
| decode(buff, offset) { | |
| offset = ~~offset; | |
| let result = ''; | |
| for (let i = 0; i < v6Size; i += 2) { | |
| if (i !== 0) { | |
| result += ':'; | |
| } | |
| result += (buff[offset + i] << 8 | buff[offset + i + 1]).toString(16); | |
| } | |
| return result.replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3').replace(/:{3,4}/, '::'); | |
| } | |
| }; | |
| exports.v6 = v6; | |
| const name = 'ip'; | |
| exports.name = name; | |
| function sizeOf(ip) { | |
| if (v4.isFormat(ip)) return v4.size; | |
| if (v6.isFormat(ip)) return v6.size; | |
| throw Error(`Invalid ip address: ${ip}`); | |
| } | |
| function familyOf(string) { | |
| return sizeOf(string) === v4.size ? 1 : 2; | |
| } | |
| function encode(ip, buff, offset) { | |
| offset = ~~offset; | |
| const size = sizeOf(ip); | |
| if (typeof buff === 'function') { | |
| buff = buff(offset + size); | |
| } | |
| if (size === v4.size) { | |
| return v4.encode(ip, buff, offset); | |
| } | |
| return v6.encode(ip, buff, offset); | |
| } | |
| function decode(buff, offset, length) { | |
| offset = ~~offset; | |
| length = length || buff.length - offset; | |
| if (length === v4.size) { | |
| return v4.decode(buff, offset, length); | |
| } | |
| if (length === v6.size) { | |
| return v6.decode(buff, offset, length); | |
| } | |
| throw Error(`Invalid buffer size needs to be ${v4.size} for v4 or ${v6.size} for v6.`); | |
| } | |
| return "default" in exports ? exports.default : exports; | |
| })({}); | |
| if (typeof define === 'function' && define.amd) define([], function() { return ipCodec; }); | |
| else if (typeof module === 'object' && typeof exports==='object') module.exports = ipCodec; | |