2014-02-14 16:39:05 +00:00
|
|
|
settings = require("settings-sharelatex")
|
2014-02-26 09:15:37 +00:00
|
|
|
PersistorManager = require("./PersistorManager")
|
2014-02-14 16:39:05 +00:00
|
|
|
LocalFileWriter = require("./LocalFileWriter")
|
|
|
|
logger = require("logger-sharelatex")
|
|
|
|
FileConverter = require("./FileConverter")
|
|
|
|
KeyBuilder = require("./KeyBuilder")
|
|
|
|
async = require("async")
|
|
|
|
ImageOptimiser = require("./ImageOptimiser")
|
|
|
|
|
2018-07-04 15:41:31 +00:00
|
|
|
module.exports = FileHandler =
|
2014-02-14 16:39:05 +00:00
|
|
|
|
|
|
|
insertFile: (bucket, key, stream, callback)->
|
2015-07-24 07:06:52 +00:00
|
|
|
convertedKey = KeyBuilder.getConvertedFolderKey key
|
|
|
|
PersistorManager.deleteDirectory bucket, convertedKey, (error) ->
|
2014-06-02 16:11:25 +00:00
|
|
|
return callback(error) if error?
|
|
|
|
PersistorManager.sendStream bucket, key, stream, callback
|
2014-02-14 16:39:05 +00:00
|
|
|
|
|
|
|
deleteFile: (bucket, key, callback)->
|
2015-07-24 07:06:52 +00:00
|
|
|
convertedKey = KeyBuilder.getConvertedFolderKey key
|
2014-02-14 16:39:05 +00:00
|
|
|
async.parallel [
|
2014-02-26 09:15:37 +00:00
|
|
|
(done)-> PersistorManager.deleteFile bucket, key, done
|
2015-07-24 07:06:52 +00:00
|
|
|
(done)-> PersistorManager.deleteDirectory bucket, convertedKey, done
|
2014-02-14 16:39:05 +00:00
|
|
|
], callback
|
|
|
|
|
2014-05-23 12:57:18 +00:00
|
|
|
getFile: (bucket, key, opts = {}, callback)->
|
2018-07-04 15:41:31 +00:00
|
|
|
# In this call, opts can contain credentials
|
|
|
|
logger.log bucket:bucket, key:key, opts:@_scrubSecrets(opts), "getting file"
|
2014-02-14 16:39:05 +00:00
|
|
|
if !opts.format? and !opts.style?
|
|
|
|
@_getStandardFile bucket, key, opts, callback
|
|
|
|
else
|
|
|
|
@_getConvertedFile bucket, key, opts, callback
|
|
|
|
|
2014-05-23 12:57:18 +00:00
|
|
|
_getStandardFile: (bucket, key, opts, callback)->
|
2015-08-27 14:21:33 +00:00
|
|
|
PersistorManager.getFileStream bucket, key, opts, (err, fileStream)->
|
2014-02-14 16:39:05 +00:00
|
|
|
if err?
|
2018-07-04 15:41:31 +00:00
|
|
|
logger.err bucket:bucket, key:key, opts:FileHandler._scrubSecrets(opts), "error getting fileStream"
|
2014-05-23 12:57:18 +00:00
|
|
|
callback err, fileStream
|
2014-02-14 16:39:05 +00:00
|
|
|
|
2014-05-23 12:57:18 +00:00
|
|
|
_getConvertedFile: (bucket, key, opts, callback)->
|
2015-07-24 07:06:52 +00:00
|
|
|
convertedKey = KeyBuilder.addCachingToKey key, opts
|
|
|
|
PersistorManager.checkIfFileExists bucket, convertedKey, (err, exists)=>
|
2015-09-10 10:10:30 +00:00
|
|
|
if err?
|
2015-11-04 14:20:15 +00:00
|
|
|
return callback err
|
2014-02-14 16:39:05 +00:00
|
|
|
if exists
|
2015-11-20 11:07:04 +00:00
|
|
|
PersistorManager.getFileStream bucket, convertedKey, opts, callback
|
2014-02-14 16:39:05 +00:00
|
|
|
else
|
2015-07-24 07:06:52 +00:00
|
|
|
@_getConvertedFileAndCache bucket, key, convertedKey, opts, callback
|
2014-02-14 16:39:05 +00:00
|
|
|
|
2015-07-24 07:06:52 +00:00
|
|
|
_getConvertedFileAndCache: (bucket, key, convertedKey, opts, callback)->
|
2014-03-04 13:36:47 +00:00
|
|
|
convertedFsPath = ""
|
2016-12-13 14:29:04 +00:00
|
|
|
originalFsPath = ""
|
2014-03-04 13:36:47 +00:00
|
|
|
async.series [
|
2015-11-20 11:02:22 +00:00
|
|
|
(cb) =>
|
2016-12-13 12:43:57 +00:00
|
|
|
@_convertFile bucket, key, opts, (err, fileSystemPath, originalFsPath) ->
|
2014-03-04 13:36:47 +00:00
|
|
|
convertedFsPath = fileSystemPath
|
2016-12-13 14:29:04 +00:00
|
|
|
originalFsPath = originalFsPath
|
2014-03-04 13:36:47 +00:00
|
|
|
cb err
|
|
|
|
(cb)->
|
|
|
|
ImageOptimiser.compressPng convertedFsPath, cb
|
|
|
|
(cb)->
|
2015-07-24 07:06:52 +00:00
|
|
|
PersistorManager.sendFile bucket, convertedKey, convertedFsPath, cb
|
2014-03-04 13:36:47 +00:00
|
|
|
], (err)->
|
2014-02-14 16:39:05 +00:00
|
|
|
if err?
|
2016-12-13 12:43:57 +00:00
|
|
|
LocalFileWriter.deleteFile convertedFsPath, ->
|
|
|
|
LocalFileWriter.deleteFile originalFsPath, ->
|
2014-02-14 16:39:05 +00:00
|
|
|
return callback(err)
|
2015-11-20 11:02:22 +00:00
|
|
|
PersistorManager.getFileStream bucket, convertedKey, opts, callback
|
2014-02-14 16:39:05 +00:00
|
|
|
|
2015-07-24 07:06:52 +00:00
|
|
|
_convertFile: (bucket, originalKey, opts, callback)->
|
2015-11-16 08:59:27 +00:00
|
|
|
@_writeS3FileToDisk bucket, originalKey, opts, (err, originalFsPath)->
|
2015-09-10 10:10:30 +00:00
|
|
|
if err?
|
|
|
|
return callback(err)
|
2014-03-04 13:36:47 +00:00
|
|
|
done = (err, destPath)->
|
|
|
|
if err?
|
2018-07-04 15:41:31 +00:00
|
|
|
logger.err err:err, bucket:bucket, originalKey:originalKey, opts:FileHandler._scrubSecrets(opts), "error converting file"
|
2014-03-04 13:36:47 +00:00
|
|
|
return callback(err)
|
2015-07-24 07:06:52 +00:00
|
|
|
LocalFileWriter.deleteFile originalFsPath, ->
|
2016-12-13 12:43:57 +00:00
|
|
|
callback(err, destPath, originalFsPath)
|
2014-03-04 13:36:47 +00:00
|
|
|
|
2014-02-14 16:39:05 +00:00
|
|
|
if opts.format?
|
2015-07-24 07:06:52 +00:00
|
|
|
FileConverter.convert originalFsPath, opts.format, done
|
2014-02-14 16:39:05 +00:00
|
|
|
else if opts.style == "thumbnail"
|
2015-07-24 07:06:52 +00:00
|
|
|
FileConverter.thumbnail originalFsPath, done
|
2014-02-14 16:39:05 +00:00
|
|
|
else if opts.style == "preview"
|
2015-07-24 07:06:52 +00:00
|
|
|
FileConverter.preview originalFsPath, done
|
2014-02-25 16:38:13 +00:00
|
|
|
else
|
2015-09-10 10:10:30 +00:00
|
|
|
return callback(new Error("should have specified opts to convert file with #{JSON.stringify(opts)}"))
|
2014-02-14 16:39:05 +00:00
|
|
|
|
|
|
|
|
2015-09-08 08:23:08 +00:00
|
|
|
_writeS3FileToDisk: (bucket, key, opts, callback)->
|
|
|
|
PersistorManager.getFileStream bucket, key, opts, (err, fileStream)->
|
2015-09-10 08:12:49 +00:00
|
|
|
if err?
|
|
|
|
return callback(err)
|
2014-02-14 16:39:05 +00:00
|
|
|
LocalFileWriter.writeStream fileStream, key, callback
|
2016-03-13 19:22:14 +00:00
|
|
|
|
|
|
|
getDirectorySize: (bucket, project_id, callback)->
|
|
|
|
logger.log bucket:bucket, project_id:project_id, "getting project size"
|
|
|
|
PersistorManager.directorySize bucket, project_id, (err, size)->
|
|
|
|
if err?
|
|
|
|
logger.err bucket:bucket, project_id:project_id, "error getting size"
|
|
|
|
callback err, size
|
2018-07-04 15:41:31 +00:00
|
|
|
|
|
|
|
_scrubSecrets: (opts)->
|
|
|
|
safe = Object.assign {}, opts
|
|
|
|
delete safe.credentials
|
|
|
|
safe
|