2014-02-26 09:15:37 +00:00
|
|
|
PersistorManager = require("./PersistorManager")
|
2014-02-14 16:39:05 +00:00
|
|
|
settings = require("settings-sharelatex")
|
|
|
|
logger = require("logger-sharelatex")
|
|
|
|
FileHandler = require("./FileHandler")
|
2014-05-12 14:45:15 +00:00
|
|
|
metrics = require("metrics-sharelatex")
|
2015-08-28 10:45:16 +00:00
|
|
|
parseRange = require('range-parser')
|
2015-08-31 15:47:16 +00:00
|
|
|
Errors = require('./Errors')
|
2015-08-28 10:45:16 +00:00
|
|
|
|
2014-02-14 16:39:05 +00:00
|
|
|
oneDayInSeconds = 60 * 60 * 24
|
2015-08-28 10:45:16 +00:00
|
|
|
maxSizeInBytes = 1024 * 1024 * 1024 # 1GB
|
|
|
|
|
2015-08-28 11:02:50 +00:00
|
|
|
module.exports = FileController =
|
2014-02-14 16:39:05 +00:00
|
|
|
|
|
|
|
getFile: (req, res)->
|
|
|
|
{key, bucket} = req
|
|
|
|
{format, style} = req.query
|
2015-08-28 11:16:41 +00:00
|
|
|
options = {
|
2015-08-28 10:45:16 +00:00
|
|
|
key: key,
|
|
|
|
bucket: bucket,
|
|
|
|
format: format,
|
|
|
|
style: style,
|
|
|
|
}
|
|
|
|
metrics.inc "getFile"
|
2019-06-13 20:57:49 +00:00
|
|
|
logger.log key:key, bucket:bucket, format:format, style: style, "receiving request to get file"
|
2015-08-28 10:45:16 +00:00
|
|
|
if req.headers.range?
|
2015-08-28 11:02:50 +00:00
|
|
|
range = FileController._get_range(req.headers.range)
|
2015-08-28 11:16:41 +00:00
|
|
|
options.start = range.start
|
|
|
|
options.end = range.end
|
|
|
|
logger.log start: range.start, end: range.end, "getting range of bytes from file"
|
|
|
|
FileHandler.getFile bucket, key, options, (err, fileStream)->
|
2014-02-14 16:39:05 +00:00
|
|
|
if err?
|
2015-08-31 15:47:16 +00:00
|
|
|
if err instanceof Errors.NotFoundError
|
|
|
|
return res.send 404
|
2017-03-08 14:59:34 +00:00
|
|
|
else
|
2018-11-09 14:04:26 +00:00
|
|
|
logger.err err:err, key:key, bucket:bucket, format:format, style:style, "problem getting file"
|
2015-08-31 15:47:16 +00:00
|
|
|
return res.send 500
|
2014-02-26 09:06:47 +00:00
|
|
|
else if req.query.cacheWarm
|
2014-02-14 16:39:05 +00:00
|
|
|
logger.log key:key, bucket:bucket, format:format, style:style, "request is only for cache warm so not sending stream"
|
|
|
|
res.send 200
|
|
|
|
else
|
|
|
|
logger.log key:key, bucket:bucket, format:format, style:style, "sending file to response"
|
|
|
|
fileStream.pipe res
|
|
|
|
|
2019-06-13 20:57:49 +00:00
|
|
|
getFileHead: (req, res) ->
|
|
|
|
{key, bucket} = req
|
|
|
|
metrics.inc("getFileSize")
|
|
|
|
logger.log({ key: key, bucket: bucket }, "receiving request to get file metadata")
|
|
|
|
FileHandler.getFileSize bucket, key, (err, fileSize) ->
|
|
|
|
if err?
|
|
|
|
if err instanceof Errors.NotFoundError
|
|
|
|
res.status(404).end()
|
|
|
|
else
|
|
|
|
res.status(500).end()
|
|
|
|
return
|
|
|
|
res.set("Content-Length", fileSize)
|
|
|
|
res.status(200).end()
|
|
|
|
|
2014-02-14 16:39:05 +00:00
|
|
|
insertFile: (req, res)->
|
|
|
|
metrics.inc "insertFile"
|
|
|
|
{key, bucket} = req
|
2019-06-13 20:57:49 +00:00
|
|
|
logger.log key:key, bucket:bucket, "receiving request to insert file"
|
2014-02-14 16:39:05 +00:00
|
|
|
FileHandler.insertFile bucket, key, req, (err)->
|
2015-09-10 10:10:30 +00:00
|
|
|
if err?
|
|
|
|
logger.log err: err, key: key, bucket: bucket, "error inserting file"
|
|
|
|
res.send 500
|
2015-11-25 16:07:51 +00:00
|
|
|
else
|
|
|
|
res.send 200
|
2014-02-14 16:39:05 +00:00
|
|
|
|
|
|
|
copyFile: (req, res)->
|
|
|
|
metrics.inc "copyFile"
|
|
|
|
{key, bucket} = req
|
|
|
|
oldProject_id = req.body.source.project_id
|
|
|
|
oldFile_id = req.body.source.file_id
|
2019-06-13 20:57:49 +00:00
|
|
|
logger.log key:key, bucket:bucket, oldProject_id:oldProject_id, oldFile_id:oldFile_id, "receiving request to copy file"
|
2014-02-26 09:15:37 +00:00
|
|
|
PersistorManager.copyFile bucket, "#{oldProject_id}/#{oldFile_id}", key, (err)->
|
2015-08-28 10:45:16 +00:00
|
|
|
if err?
|
2019-01-09 10:31:59 +00:00
|
|
|
if err instanceof Errors.NotFoundError
|
|
|
|
res.send 404
|
|
|
|
else
|
|
|
|
logger.log err:err, oldProject_id:oldProject_id, oldFile_id:oldFile_id, "something went wrong copying file"
|
|
|
|
res.send 500
|
2014-02-14 16:39:05 +00:00
|
|
|
else
|
|
|
|
res.send 200
|
|
|
|
|
|
|
|
deleteFile: (req, res)->
|
|
|
|
metrics.inc "deleteFile"
|
|
|
|
{key, bucket} = req
|
2019-06-13 20:57:49 +00:00
|
|
|
logger.log key:key, bucket:bucket, "receiving request to delete file"
|
2014-02-14 16:39:05 +00:00
|
|
|
FileHandler.deleteFile bucket, key, (err)->
|
|
|
|
if err?
|
2014-02-25 09:10:22 +00:00
|
|
|
logger.log err:err, key:key, bucket:bucket, "something went wrong deleting file"
|
2014-02-14 16:39:05 +00:00
|
|
|
res.send 500
|
|
|
|
else
|
|
|
|
res.send 204
|
2015-08-28 11:02:50 +00:00
|
|
|
|
|
|
|
_get_range: (header) ->
|
|
|
|
parsed = parseRange(maxSizeInBytes, header)
|
|
|
|
if parsed == -1 or parsed == -2 or parsed.type != 'bytes'
|
|
|
|
null
|
|
|
|
else
|
|
|
|
range = parsed[0]
|
|
|
|
{start: range.start, end: range.end}
|
2016-03-13 19:22:14 +00:00
|
|
|
|
|
|
|
directorySize: (req, res)->
|
|
|
|
metrics.inc "projectSize"
|
|
|
|
{project_id, bucket} = req
|
2019-06-13 20:57:49 +00:00
|
|
|
logger.log project_id:project_id, bucket:bucket, "receiving request to project size"
|
2016-03-13 19:22:14 +00:00
|
|
|
FileHandler.getDirectorySize bucket, project_id, (err, size)->
|
|
|
|
if err?
|
|
|
|
logger.log err: err, project_id: project_id, bucket: bucket, "error inserting file"
|
|
|
|
res.send 500
|
|
|
|
else
|
|
|
|
res.json {'total bytes' : size}
|