Alexandre Bodin f108e049e8 wip
2023-04-28 18:20:31 +02:00

59 lines
1.5 KiB
TypeScript

/**
* Utils file containing file treatment utils
*/
import { Readable, Writable, WritableOptions } from 'node:stream';
const kbytesToBytes = (kbytes: number) => kbytes * 1000;
const bytesToKbytes = (bytes: number) => Math.round((bytes / 1000) * 100) / 100;
const bytesToHumanReadable = (bytes: number) => {
const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB'];
if (bytes === 0) return '0 Bytes';
const i = parseInt(`${Math.floor(Math.log(bytes) / Math.log(1000))}`, 10);
return `${Math.round(bytes / 1000 ** i)} ${sizes[i]}`;
};
const streamToBuffer = (stream: Readable) =>
new Promise((resolve, reject) => {
const chunks: Uint8Array[] = [];
stream.on('data', (chunk) => {
chunks.push(chunk);
});
stream.on('end', () => {
resolve(Buffer.concat(chunks));
});
stream.on('error', reject);
});
const getStreamSize = (stream: Readable) =>
new Promise((resolve, reject) => {
let size = 0;
stream.on('data', (chunk) => {
size += Buffer.byteLength(chunk);
});
stream.on('close', () => resolve(size));
stream.on('error', reject);
stream.resume();
});
/**
* Create a writeable Node.js stream that discards received data.
* Useful for testing, draining a stream of data, etc.
*/
function writableDiscardStream(options: WritableOptions) {
return new Writable({
...options,
write(chunk, encding, callback) {
setImmediate(callback);
},
});
}
export {
streamToBuffer,
bytesToHumanReadable,
bytesToKbytes,
kbytesToBytes,
getStreamSize,
writableDiscardStream,
};