229 lines
5.5 KiB
JavaScript
229 lines
5.5 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.nil = exports.UUID = void 0;
|
|
|
|
function _crypto() {
|
|
const data = require("crypto");
|
|
|
|
_crypto = function () {
|
|
return data;
|
|
};
|
|
|
|
return data;
|
|
}
|
|
|
|
function _index() {
|
|
const data = require("./index");
|
|
|
|
_index = function () {
|
|
return data;
|
|
};
|
|
|
|
return data;
|
|
}
|
|
|
|
const invalidName = "options.name must be either a string or a Buffer"; // Node ID according to rfc4122#section-4.5
|
|
|
|
const randomHost = (0, _crypto().randomBytes)(16);
|
|
randomHost[0] = randomHost[0] | 0x01; // lookup table hex to byte
|
|
|
|
const hex2byte = {}; // lookup table byte to hex
|
|
|
|
const byte2hex = []; // populate lookup tables
|
|
|
|
for (let i = 0; i < 256; i++) {
|
|
const hex = (i + 0x100).toString(16).substr(1);
|
|
hex2byte[hex] = i;
|
|
byte2hex[i] = hex;
|
|
} // UUID class
|
|
|
|
|
|
class UUID {
|
|
constructor(uuid) {
|
|
this.ascii = null;
|
|
this.binary = null;
|
|
const check = UUID.check(uuid);
|
|
|
|
if (!check) {
|
|
throw new Error("not a UUID");
|
|
}
|
|
|
|
this.version = check.version;
|
|
|
|
if (check.format === "ascii") {
|
|
this.ascii = uuid;
|
|
} else {
|
|
this.binary = uuid;
|
|
}
|
|
}
|
|
|
|
static v5(name, namespace) {
|
|
return uuidNamed(name, "sha1", 0x50, namespace);
|
|
}
|
|
|
|
toString() {
|
|
if (this.ascii == null) {
|
|
this.ascii = stringify(this.binary);
|
|
}
|
|
|
|
return this.ascii;
|
|
}
|
|
|
|
inspect() {
|
|
return `UUID v${this.version} ${this.toString()}`;
|
|
}
|
|
|
|
static check(uuid, offset = 0) {
|
|
if (typeof uuid === "string") {
|
|
uuid = uuid.toLowerCase();
|
|
|
|
if (!/^[a-f0-9]{8}(-[a-f0-9]{4}){3}-([a-f0-9]{12})$/.test(uuid)) {
|
|
return false;
|
|
}
|
|
|
|
if (uuid === "00000000-0000-0000-0000-000000000000") {
|
|
return {
|
|
version: undefined,
|
|
variant: "nil",
|
|
format: "ascii"
|
|
};
|
|
}
|
|
|
|
return {
|
|
version: (hex2byte[uuid[14] + uuid[15]] & 0xf0) >> 4,
|
|
variant: getVariant((hex2byte[uuid[19] + uuid[20]] & 0xe0) >> 5),
|
|
format: "ascii"
|
|
};
|
|
}
|
|
|
|
if (Buffer.isBuffer(uuid)) {
|
|
if (uuid.length < offset + 16) {
|
|
return false;
|
|
}
|
|
|
|
let i = 0;
|
|
|
|
for (; i < 16; i++) {
|
|
if (uuid[offset + i] !== 0) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (i === 16) {
|
|
return {
|
|
version: undefined,
|
|
variant: "nil",
|
|
format: "binary"
|
|
};
|
|
}
|
|
|
|
return {
|
|
version: (uuid[offset + 6] & 0xf0) >> 4,
|
|
variant: getVariant((uuid[offset + 8] & 0xe0) >> 5),
|
|
format: "binary"
|
|
};
|
|
}
|
|
|
|
throw (0, _index().newError)("Unknown type of uuid", "ERR_UNKNOWN_UUID_TYPE");
|
|
} // read stringified uuid into a Buffer
|
|
|
|
|
|
static parse(input) {
|
|
const buffer = Buffer.allocUnsafe(16);
|
|
let j = 0;
|
|
|
|
for (let i = 0; i < 16; i++) {
|
|
buffer[i] = hex2byte[input[j++] + input[j++]];
|
|
|
|
if (i === 3 || i === 5 || i === 7 || i === 9) {
|
|
j += 1;
|
|
}
|
|
}
|
|
|
|
return buffer;
|
|
}
|
|
|
|
} // from rfc4122#appendix-C
|
|
|
|
|
|
exports.UUID = UUID;
|
|
UUID.OID = UUID.parse("6ba7b812-9dad-11d1-80b4-00c04fd430c8"); // according to rfc4122#section-4.1.1
|
|
|
|
function getVariant(bits) {
|
|
switch (bits) {
|
|
case 0:
|
|
case 1:
|
|
case 3:
|
|
return "ncs";
|
|
|
|
case 4:
|
|
case 5:
|
|
return "rfc4122";
|
|
|
|
case 6:
|
|
return "microsoft";
|
|
|
|
default:
|
|
return "future";
|
|
}
|
|
}
|
|
|
|
var UuidEncoding;
|
|
|
|
(function (UuidEncoding) {
|
|
UuidEncoding[UuidEncoding["ASCII"] = 0] = "ASCII";
|
|
UuidEncoding[UuidEncoding["BINARY"] = 1] = "BINARY";
|
|
UuidEncoding[UuidEncoding["OBJECT"] = 2] = "OBJECT";
|
|
})(UuidEncoding || (UuidEncoding = {})); // v3 + v5
|
|
|
|
|
|
function uuidNamed(name, hashMethod, version, namespace, encoding = UuidEncoding.ASCII) {
|
|
const hash = (0, _crypto().createHash)(hashMethod);
|
|
const nameIsNotAString = typeof name !== "string";
|
|
|
|
if (nameIsNotAString && !Buffer.isBuffer(name)) {
|
|
throw (0, _index().newError)(invalidName, "ERR_INVALID_UUID_NAME");
|
|
}
|
|
|
|
hash.update(namespace);
|
|
hash.update(name);
|
|
const buffer = hash.digest();
|
|
let result;
|
|
|
|
switch (encoding) {
|
|
case UuidEncoding.BINARY:
|
|
buffer[6] = buffer[6] & 0x0f | version;
|
|
buffer[8] = buffer[8] & 0x3f | 0x80;
|
|
result = buffer;
|
|
break;
|
|
|
|
case UuidEncoding.OBJECT:
|
|
buffer[6] = buffer[6] & 0x0f | version;
|
|
buffer[8] = buffer[8] & 0x3f | 0x80;
|
|
result = new UUID(buffer);
|
|
break;
|
|
|
|
default:
|
|
result = byte2hex[buffer[0]] + byte2hex[buffer[1]] + byte2hex[buffer[2]] + byte2hex[buffer[3]] + "-" + byte2hex[buffer[4]] + byte2hex[buffer[5]] + "-" + byte2hex[buffer[6] & 0x0f | version] + byte2hex[buffer[7]] + "-" + byte2hex[buffer[8] & 0x3f | 0x80] + byte2hex[buffer[9]] + "-" + byte2hex[buffer[10]] + byte2hex[buffer[11]] + byte2hex[buffer[12]] + byte2hex[buffer[13]] + byte2hex[buffer[14]] + byte2hex[buffer[15]];
|
|
break;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
function stringify(buffer) {
|
|
return byte2hex[buffer[0]] + byte2hex[buffer[1]] + byte2hex[buffer[2]] + byte2hex[buffer[3]] + "-" + byte2hex[buffer[4]] + byte2hex[buffer[5]] + "-" + byte2hex[buffer[6]] + byte2hex[buffer[7]] + "-" + byte2hex[buffer[8]] + byte2hex[buffer[9]] + "-" + byte2hex[buffer[10]] + byte2hex[buffer[11]] + byte2hex[buffer[12]] + byte2hex[buffer[13]] + byte2hex[buffer[14]] + byte2hex[buffer[15]];
|
|
} // according to rfc4122#section-4.1.7
|
|
|
|
|
|
const nil = new UUID("00000000-0000-0000-0000-000000000000"); // UUID.v4 = uuidRandom
|
|
// UUID.v4fast = uuidRandomFast
|
|
// UUID.v3 = function(options, callback) {
|
|
// return uuidNamed("md5", 0x30, options, callback)
|
|
// }
|
|
exports.nil = nil;
|
|
// __ts-babel@6.0.4
|
|
//# sourceMappingURL=uuid.js.map
|