v1ToV6.js 1.1 KB

1234567891011121314151617181920
  1. import parse from './parse.js';
  2. import { unsafeStringify } from './stringify.js';
  3. /**
  4. * Convert a v1 UUID to a v6 UUID
  5. *
  6. * @param {string|Uint8Array} uuid - The v1 UUID to convert to v6
  7. * @returns {string|Uint8Array} The v6 UUID as the same type as the `uuid` arg
  8. * (string or Uint8Array)
  9. */
  10. export default function v1ToV6(uuid) {
  11. const v1Bytes = typeof uuid === 'string' ? parse(uuid) : uuid;
  12. const v6Bytes = _v1ToV6(v1Bytes);
  13. return typeof uuid === 'string' ? unsafeStringify(v6Bytes) : v6Bytes;
  14. }
  15. // Do the field transformation needed for v1 -> v6
  16. function _v1ToV6(v1Bytes, randomize = false) {
  17. return Uint8Array.of((v1Bytes[6] & 0x0f) << 4 | v1Bytes[7] >> 4 & 0x0f, (v1Bytes[7] & 0x0f) << 4 | (v1Bytes[4] & 0xf0) >> 4, (v1Bytes[4] & 0x0f) << 4 | (v1Bytes[5] & 0xf0) >> 4, (v1Bytes[5] & 0x0f) << 4 | (v1Bytes[0] & 0xf0) >> 4, (v1Bytes[0] & 0x0f) << 4 | (v1Bytes[1] & 0xf0) >> 4, (v1Bytes[1] & 0x0f) << 4 | (v1Bytes[2] & 0xf0) >> 4, 0x60 | v1Bytes[2] & 0x0f, v1Bytes[3], v1Bytes[8], v1Bytes[9], v1Bytes[10], v1Bytes[11], v1Bytes[12], v1Bytes[13], v1Bytes[14], v1Bytes[15]);
  18. }