2014-02-12 10:23:40 +00:00
|
|
|
logger = require "logger-sharelatex"
|
2017-04-03 15:18:30 +00:00
|
|
|
Metrics = require "metrics-sharelatex"
|
2014-02-12 10:23:40 +00:00
|
|
|
Project = require("../../models/Project").Project
|
|
|
|
ProjectZipStreamManager = require "./ProjectZipStreamManager"
|
|
|
|
DocumentUpdaterHandler = require "../DocumentUpdater/DocumentUpdaterHandler"
|
|
|
|
|
|
|
|
module.exports = ProjectDownloadsController =
|
|
|
|
downloadProject: (req, res, next) ->
|
|
|
|
project_id = req.params.Project_id
|
|
|
|
Metrics.inc "zip-downloads"
|
|
|
|
logger.log project_id: project_id, "downloading project"
|
|
|
|
DocumentUpdaterHandler.flushProjectToMongo project_id, (error)->
|
|
|
|
return next(error) if error?
|
|
|
|
Project.findById project_id, "name", (error, project) ->
|
|
|
|
return next(error) if error?
|
|
|
|
ProjectZipStreamManager.createZipStreamForProject project_id, (error, stream) ->
|
|
|
|
return next(error) if error?
|
2017-04-12 15:00:02 +00:00
|
|
|
res.setContentDisposition(
|
|
|
|
'attachment',
|
|
|
|
{filename: "#{project.name}.zip"}
|
2014-02-12 10:23:40 +00:00
|
|
|
)
|
|
|
|
res.contentType('application/zip')
|
|
|
|
stream.pipe(res)
|
|
|
|
|
2014-06-18 15:37:18 +00:00
|
|
|
downloadMultipleProjects: (req, res, next) ->
|
|
|
|
project_ids = req.query.project_ids.split(",")
|
|
|
|
Metrics.inc "zip-downloads-multiple"
|
|
|
|
logger.log project_ids: project_ids, "downloading multiple projects"
|
|
|
|
DocumentUpdaterHandler.flushMultipleProjectsToMongo project_ids, (error) ->
|
|
|
|
return next(error) if error?
|
|
|
|
ProjectZipStreamManager.createZipStreamForMultipleProjects project_ids, (error, stream) ->
|
|
|
|
return next(error) if error?
|
2017-04-12 15:00:02 +00:00
|
|
|
res.setContentDisposition(
|
|
|
|
'attachment',
|
|
|
|
{filename: "ShareLaTeX Projects (#{project_ids.length} items).zip"}
|
2014-06-18 15:37:18 +00:00
|
|
|
)
|
|
|
|
res.contentType('application/zip')
|
|
|
|
stream.pipe(res)
|
|
|
|
|
2014-02-12 10:23:40 +00:00
|
|
|
|