mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-23 17:32:20 +00:00
12e7471213
move stream-related code to separate `@overleaf/stream-utils` library GitOrigin-RevId: a79a873109b927b4fc0ae36f47d5c67e0df58041
93 lines
2.1 KiB
JavaScript
93 lines
2.1 KiB
JavaScript
/**
|
|
* Promises are promises and streams are streams, and ne'er the twain shall
|
|
* meet.
|
|
* @module
|
|
*/
|
|
'use strict'
|
|
|
|
const BPromise = require('bluebird')
|
|
const zlib = require('zlib')
|
|
const { WritableBuffer, ReadableString } = require('@overleaf/stream-utils')
|
|
const { pipeline } = require('stream')
|
|
|
|
function promisePipe(readStream, writeStream) {
|
|
return new BPromise(function (resolve, reject) {
|
|
pipeline(readStream, writeStream, function (err) {
|
|
if (err) {
|
|
reject(err)
|
|
} else {
|
|
resolve()
|
|
}
|
|
})
|
|
})
|
|
}
|
|
|
|
/**
|
|
* Pipe a read stream to a write stream. The promise resolves when the write
|
|
* stream finishes.
|
|
*
|
|
* @function
|
|
* @param {stream.Readable} readStream
|
|
* @param {stream.Writable} writeStream
|
|
* @return {Promise}
|
|
*/
|
|
exports.promisePipe = promisePipe
|
|
|
|
function readStreamToBuffer(readStream) {
|
|
return new BPromise(function (resolve, reject) {
|
|
const bufferStream = new WritableBuffer()
|
|
pipeline(readStream, bufferStream, function (err) {
|
|
if (err) {
|
|
reject(err)
|
|
} else {
|
|
resolve(bufferStream.contents())
|
|
}
|
|
})
|
|
})
|
|
}
|
|
|
|
/**
|
|
* Create a promise for the result of reading a stream to a buffer.
|
|
*
|
|
* @function
|
|
* @param {stream.Readable} readStream
|
|
* @return {Promise.<Buffer>}
|
|
*/
|
|
exports.readStreamToBuffer = readStreamToBuffer
|
|
|
|
function gunzipStreamToBuffer(readStream) {
|
|
const gunzip = zlib.createGunzip()
|
|
const bufferStream = new WritableBuffer()
|
|
return new BPromise(function (resolve, reject) {
|
|
pipeline(readStream, gunzip, bufferStream, function (err) {
|
|
if (err) {
|
|
reject(err)
|
|
} else {
|
|
resolve(bufferStream.contents())
|
|
}
|
|
})
|
|
})
|
|
}
|
|
|
|
/**
|
|
* Create a promise for the result of un-gzipping a stream to a buffer.
|
|
*
|
|
* @function
|
|
* @param {stream.Readable} readStream
|
|
* @return {Promise.<Buffer>}
|
|
*/
|
|
exports.gunzipStreamToBuffer = gunzipStreamToBuffer
|
|
|
|
function gzipStringToStream(string) {
|
|
const gzip = zlib.createGzip()
|
|
return new ReadableString(string).pipe(gzip)
|
|
}
|
|
|
|
/**
|
|
* Create a write stream that gzips the given string.
|
|
*
|
|
* @function
|
|
* @param {string} string
|
|
* @return {stream.Writable}
|
|
*/
|
|
exports.gzipStringToStream = gzipStringToStream
|