mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-22 04:53:07 +00:00
downloading a file now sets the filename in header correctly
This commit is contained in:
parent
6f4c2a409c
commit
029077fe6e
4 changed files with 91 additions and 11 deletions
|
@ -0,0 +1,21 @@
|
|||
logger = require('logger-sharelatex')
|
||||
FileStoreHandler = require("./FileStoreHandler")
|
||||
ProjectLocator = require("../Project/ProjectLocator")
|
||||
|
||||
module.exports =
|
||||
|
||||
getFile : (req, res)->
|
||||
project_id = req.params.Project_id
|
||||
file_id = req.params.File_id
|
||||
queryString = req.query
|
||||
logger.log project_id: project_id, file_id: file_id, queryString:queryString, "file download"
|
||||
ProjectLocator.findElement {project_id: project_id, element_id: file_id, type: "file"}, (err, file)->
|
||||
if err?
|
||||
logger.err err:err, project_id: project_id, file_id: file_id, queryString:queryString, "error finding element for downloading file"
|
||||
return res.send 500
|
||||
FileStoreHandler.getFileStream project_id, file_id, queryString, (err, stream)->
|
||||
if err?
|
||||
logger.err err:err, project_id: project_id, file_id: file_id, queryString:queryString, "error getting file stream for downloading file"
|
||||
return res.send 500
|
||||
res.setHeader("Content-Disposition", "attachment; filename=#{file.name}")
|
||||
stream.pipe res
|
|
@ -10,7 +10,6 @@ SecurityManager = require '../managers/SecurityManager'
|
|||
GuidManager = require '../managers/GuidManager'
|
||||
Settings = require('settings-sharelatex')
|
||||
projectCreationHandler = require '../Features/Project/ProjectCreationHandler'
|
||||
projectLocator = require '../Features/Project/ProjectLocator'
|
||||
projectDuplicator = require('../Features/Project/ProjectDuplicator')
|
||||
ProjectZipStreamManager = require '../Features/Downloads/ProjectZipStreamManager'
|
||||
metrics = require('../infrastructure/Metrics')
|
||||
|
@ -184,15 +183,6 @@ module.exports = class ProjectController
|
|||
@emit "end" if @endEmitted
|
||||
next()
|
||||
|
||||
downloadImageFile : (req, res)->
|
||||
project_id = req.params.Project_id
|
||||
file_id = req.params.File_id
|
||||
queryString = req.query
|
||||
logger.log project_id: project_id, file_id: file_id, queryString:queryString, "file download"
|
||||
res.setHeader("Content-Disposition", "attachment")
|
||||
FileStoreHandler.getFileStream project_id, file_id, queryString, (err, stream)->
|
||||
stream.pipe res
|
||||
|
||||
cloneProject: (req, res)->
|
||||
metrics.inc "cloned-project"
|
||||
project_id = req.params.Project_id
|
||||
|
|
|
@ -31,6 +31,7 @@ CompileManager = require("./Features/Compile/CompileManager")
|
|||
CompileController = require("./Features/Compile/CompileController")
|
||||
HealthCheckController = require("./Features/HealthCheck/HealthCheckController")
|
||||
ProjectDownloadsController = require "./Features/Downloads/ProjectDownloadsController"
|
||||
FileStoreController = require("./Features/FileStore/FileStoreController")
|
||||
logger = require("logger-sharelatex")
|
||||
|
||||
httpAuth = require('express').basicAuth (user, pass)->
|
||||
|
@ -97,7 +98,7 @@ module.exports = class Router
|
|||
app.get '/project/new/template', TemplatesMiddlewear.saveTemplateDataInSession, AuthenticationController.requireLogin(), TemplatesController.createProjectFromZipTemplate
|
||||
|
||||
app.get '/Project/:Project_id', SecutiryManager.requestCanAccessProject, Project.loadEditor
|
||||
app.get '/Project/:Project_id/file/:File_id', SecutiryManager.requestCanAccessProject, Project.downloadImageFile
|
||||
app.get '/Project/:Project_id/file/:File_id', SecutiryManager.requestCanAccessProject, FileStoreController.getFile
|
||||
|
||||
# This is left for legacy reasons and can be removed once all editors have had a chance to refresh:
|
||||
app.get '/Project/:Project_id/download/pdf', SecutiryManager.requestCanAccessProject, CompileController.downloadPdf
|
||||
|
|
|
@ -0,0 +1,68 @@
|
|||
assert = require("chai").assert
|
||||
sinon = require('sinon')
|
||||
chai = require('chai')
|
||||
should = chai.should()
|
||||
expect = chai.expect
|
||||
modulePath = "../../../../app/js/Features/FileStore/FileStoreController.js"
|
||||
SandboxedModule = require('sandboxed-module')
|
||||
|
||||
describe "FileStoreController", ->
|
||||
|
||||
beforeEach ->
|
||||
@FileStoreHandler =
|
||||
getFileStream: sinon.stub()
|
||||
@ProjectLocator =
|
||||
findElement: sinon.stub()
|
||||
@controller = SandboxedModule.require modulePath, requires:
|
||||
"settings-sharelatex": @settings
|
||||
"logger-sharelatex" : @logger = {log:sinon.stub(), err:sinon.stub()}
|
||||
"../Project/ProjectLocator": @ProjectLocator
|
||||
"./FileStoreHandler": @FileStoreHandler
|
||||
@stream = {}
|
||||
@project_id = "2k3j1lk3j21lk3j"
|
||||
@file_id = "12321kklj1lk3jk12"
|
||||
@req =
|
||||
params:
|
||||
Project_id: @project_id
|
||||
File_id: @file_id
|
||||
query: "query string here"
|
||||
@res =
|
||||
setHeader: sinon.stub()
|
||||
@file =
|
||||
name: "myfile.png"
|
||||
|
||||
describe "getFile", ->
|
||||
|
||||
beforeEach ->
|
||||
@FileStoreHandler.getFileStream.callsArgWith(3, null, @stream)
|
||||
@ProjectLocator.findElement.callsArgWith(1, null, @file)
|
||||
|
||||
it "should call the file store handler with the project_id file_id and any query string", (done)->
|
||||
@stream.pipe = (des)=>
|
||||
@FileStoreHandler.getFileStream.calledWith(@req.params.Project_id, @req.params.File_id, @req.query).should.equal true
|
||||
done()
|
||||
@controller.getFile @req, @res
|
||||
|
||||
it "should pipe to res", (done)->
|
||||
@stream.pipe = (des)=>
|
||||
des.should.equal @res
|
||||
done()
|
||||
@controller.getFile @req, @res
|
||||
|
||||
it "should get the file from the db", (done)->
|
||||
@stream.pipe = (des)=>
|
||||
opts =
|
||||
project_id: @project_id
|
||||
element_id: @file_id
|
||||
type: "file"
|
||||
@ProjectLocator.findElement.calledWith(opts).should.equal true
|
||||
done()
|
||||
@controller.getFile @req, @res
|
||||
|
||||
it "should set the Content-Disposition header", (done)->
|
||||
@stream.pipe = (des)=>
|
||||
@res.setHeader.calledWith("Content-Disposition", "attachment; filename=#{@file.name}").should.equal true
|
||||
done()
|
||||
@controller.getFile @req, @res
|
||||
|
||||
|
Loading…
Reference in a new issue