buffer-utils.ts 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. import { Buffer } from 'buffer';
  2. const typedArrays: Record<string, Function> = {
  3. Buffer,
  4. ArrayBuffer,
  5. Int8Array,
  6. Uint8Array,
  7. Uint8ClampedArray,
  8. Int16Array,
  9. Uint16Array,
  10. Int32Array,
  11. Uint32Array,
  12. Float32Array,
  13. Float64Array
  14. };
  15. type BufferLike = Buffer | ArrayBuffer | ArrayBufferView
  16. function getType (value: BufferLike) {
  17. for (const type of Object.keys(typedArrays)) {
  18. if (value instanceof typedArrays[type]) {
  19. return type;
  20. }
  21. }
  22. throw new Error('Invalid buffer');
  23. }
  24. function getBuffer (value: BufferLike) {
  25. if (value instanceof Buffer) {
  26. return value;
  27. } else if (value instanceof ArrayBuffer) {
  28. return Buffer.from(value);
  29. } else {
  30. return Buffer.from(value.buffer, value.byteOffset, value.byteLength);
  31. }
  32. }
  33. export function isBuffer (value: BufferLike) {
  34. return ArrayBuffer.isView(value) || value instanceof ArrayBuffer;
  35. }
  36. interface BufferMeta {
  37. type: keyof typeof typedArrays;
  38. data: Buffer;
  39. length: number | undefined;
  40. }
  41. export function bufferToMeta (value: BufferLike): BufferMeta {
  42. return {
  43. type: getType(value),
  44. data: getBuffer(value),
  45. // NB. We only use length when decoding Int8Array and friends.
  46. // For other buffer-like types this is expected to be undefined.
  47. length: (value as Buffer).length
  48. };
  49. }
  50. export function metaToBuffer (value: BufferMeta) {
  51. const constructor = typedArrays[value.type];
  52. const data = getBuffer(value.data);
  53. if (constructor === Buffer) {
  54. return data;
  55. } else if (constructor === ArrayBuffer) {
  56. return data.buffer;
  57. } else if (constructor) {
  58. return new (constructor as any)(data.buffer, data.byteOffset, value.length);
  59. } else {
  60. return data;
  61. }
  62. }