overleaf/services/filestore/app/coffee/FileConverter.coffee

63 lines
2.7 KiB
CoffeeScript
Raw Normal View History

2014-02-14 16:39:05 +00:00
_ = require("underscore")
metrics = require("metrics-sharelatex")
2014-02-14 16:39:05 +00:00
logger = require("logger-sharelatex")
2015-03-13 10:10:51 +00:00
safe_exec = require("./SafeExec")
2014-02-14 16:39:05 +00:00
approvedFormats = ["png"]
Settings = require "settings-sharelatex"
2014-02-14 16:39:05 +00:00
2014-03-14 08:55:28 +00:00
fourtySeconds = 40 * 1000
childProcessOpts =
killSignal: "SIGTERM"
2014-03-14 08:55:28 +00:00
timeout: fourtySeconds
2014-02-14 16:39:05 +00:00
module.exports =
convert: (sourcePath, requestedFormat, callback)->
logger.log sourcePath:sourcePath, requestedFormat:requestedFormat, "converting file format"
timer = new metrics.Timer("imageConvert")
destPath = "#{sourcePath}.#{requestedFormat}"
sourcePath = "#{sourcePath}[0]"
if !_.include approvedFormats, requestedFormat
err = new Error("invalid format requested")
return callback err
width = "600x"
command = ["convert", "-define", "pdf:fit-page=#{width}", "-flatten", "-density", "300", sourcePath, destPath]
command = Settings.commands.convertCommandPrefix.concat(command)
safe_exec command, childProcessOpts, (err, stdout, stderr)->
2014-02-14 16:39:05 +00:00
timer.done()
2014-02-19 13:32:41 +00:00
if err?
logger.err err:err, stderr:stderr, sourcePath:sourcePath, requestedFormat:requestedFormat, destPath:destPath, "something went wrong converting file"
2014-02-19 13:32:41 +00:00
else
logger.log sourcePath:sourcePath, requestedFormat:requestedFormat, destPath:destPath, "finished converting file"
2014-02-14 16:39:05 +00:00
callback(err, destPath)
thumbnail: (sourcePath, callback)->
logger.log sourcePath:sourcePath, "thumbnail convert file"
destPath = "#{sourcePath}.png"
sourcePath = "#{sourcePath}[0]"
width = "260x"
command = ["convert", "-flatten", "-background", "white", "-density", "300", "-define", "pdf:fit-page=#{width}", sourcePath, "-resize", width, destPath]
command = Settings.commands.convertCommandPrefix.concat(command)
safe_exec command, childProcessOpts, (err, stdout, stderr)->
2014-02-19 13:32:41 +00:00
if err?
logger.err err:err, stderr:stderr, sourcePath:sourcePath, "something went wrong converting file to thumbnail"
2014-02-19 13:32:41 +00:00
else
logger.log sourcePath:sourcePath, destPath:destPath, "finished thumbnailing file"
2014-02-14 16:39:05 +00:00
callback(err, destPath)
preview: (sourcePath, callback)->
logger.log sourcePath:sourcePath, "preview convert file"
destPath = "#{sourcePath}.png"
sourcePath = "#{sourcePath}[0]"
width = "548x"
command = ["convert", "-flatten", "-background", "white", "-density", "300", "-define", "pdf:fit-page=#{width}", sourcePath, "-resize", width, destPath]
command = Settings.commands.convertCommandPrefix.concat(command)
safe_exec command, childProcessOpts, (err, stdout, stderr)->
2014-02-19 13:32:41 +00:00
if err?
logger.err err:err, stderr:stderr, sourcePath:sourcePath, destPath:destPath, "something went wrong converting file to preview"
2014-02-19 13:32:41 +00:00
else
logger.log sourcePath:sourcePath, destPath:destPath, "finished converting file to preview"
2014-02-14 16:39:05 +00:00
callback(err, destPath)