2019-12-16 05:42:31 -05:00
|
|
|
const fs = require('fs')
|
|
|
|
const uuid = require('node-uuid')
|
|
|
|
const path = require('path')
|
2019-12-18 10:40:30 -05:00
|
|
|
const Stream = require('stream')
|
|
|
|
const { callbackify, promisify } = require('util')
|
2019-12-16 05:42:31 -05:00
|
|
|
const logger = require('logger-sharelatex')
|
|
|
|
const metrics = require('metrics-sharelatex')
|
|
|
|
const Settings = require('settings-sharelatex')
|
2019-12-18 10:40:30 -05:00
|
|
|
const { WriteError } = require('./Errors')
|
2014-02-14 11:39:05 -05:00
|
|
|
|
2019-12-16 05:42:31 -05:00
|
|
|
module.exports = {
|
2019-12-18 10:40:30 -05:00
|
|
|
promises: {
|
|
|
|
writeStream,
|
|
|
|
deleteFile
|
2019-12-16 05:42:31 -05:00
|
|
|
},
|
2019-12-18 10:40:30 -05:00
|
|
|
writeStream: callbackify(writeStream),
|
|
|
|
deleteFile: callbackify(deleteFile)
|
|
|
|
}
|
2014-02-14 11:39:05 -05:00
|
|
|
|
2019-12-18 10:40:30 -05:00
|
|
|
const pipeline = promisify(Stream.pipeline)
|
2014-02-14 11:39:05 -05:00
|
|
|
|
2019-12-18 10:40:30 -05:00
|
|
|
async function writeStream(stream, key) {
|
|
|
|
const timer = new metrics.Timer('writingFile')
|
|
|
|
const fsPath = _getPath(key)
|
|
|
|
|
|
|
|
logger.log({ fsPath }, 'writing file locally')
|
|
|
|
|
|
|
|
const writeStream = fs.createWriteStream(fsPath)
|
|
|
|
try {
|
|
|
|
await pipeline(stream, writeStream)
|
|
|
|
timer.done()
|
|
|
|
logger.log({ fsPath }, 'finished writing file locally')
|
|
|
|
return fsPath
|
|
|
|
} catch (err) {
|
|
|
|
logger.err({ err, fsPath }, 'problem writing file locally')
|
|
|
|
throw new WriteError({
|
|
|
|
message: 'problem writing file locally',
|
|
|
|
info: { err, fsPath }
|
|
|
|
}).withCause(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function deleteFile(fsPath) {
|
|
|
|
if (!fsPath) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
logger.log({ fsPath }, 'removing local temp file')
|
|
|
|
await promisify(fs.unlink)(fsPath)
|
|
|
|
}
|
2018-11-07 11:23:55 -05:00
|
|
|
|
2019-12-18 10:40:30 -05:00
|
|
|
function _getPath(key) {
|
|
|
|
if (key == null) {
|
|
|
|
key = uuid.v1()
|
2019-12-16 05:42:31 -05:00
|
|
|
}
|
2019-12-18 10:40:30 -05:00
|
|
|
key = key.replace(/\//g, '-')
|
|
|
|
return path.join(Settings.path.uploadFolder, key)
|
2019-12-16 05:42:31 -05:00
|
|
|
}
|