overleaf/services/docstore/app/coffee/DocArchiveManager.coffee

81 lines
3.2 KiB
CoffeeScript
Raw Normal View History

2015-06-02 14:55:22 -04:00
MongoManager = require "./MongoManager"
Errors = require "./Errors"
logger = require "logger-sharelatex"
_ = require "underscore"
async = require "async"
settings = require("settings-sharelatex")
request = require("request")
crypto = require("crypto")
thirtySeconds = 30 * 1000
module.exports = DocArchive =
archiveAllDocs: (project_id, callback = (error, docs) ->) ->
MongoManager.getProjectsDocs project_id, (error, docs) ->
2015-06-02 17:13:16 -04:00
if error?
2015-06-02 14:55:22 -04:00
return callback(error)
else if !docs?
return callback new Errors.NotFoundError("No docs for project #{project_id}")
jobs = _.map docs, (doc) ->
(cb)-> DocArchive.archiveDoc project_id, doc, cb
async.series jobs, callback
archiveDoc: (project_id, doc, callback)->
logger.log project_id: project_id, doc_id: doc._id, "sending doc to s3"
2015-06-02 18:24:45 -04:00
options = DocArchive.buildS3Options(doc.lines, project_id+"/"+doc._id)
2015-06-02 14:55:22 -04:00
request.put options, (err, res)->
2015-06-03 10:45:47 -04:00
md5lines = crypto.createHash("md5").update(JSON.stringify(doc.lines)).digest("hex")
md5response = res.headers.etag.toString().replace(/\"/g, '')
2015-06-02 14:55:22 -04:00
if err? || res.statusCode != 200
logger.err err:err, res:res, "something went wrong archiving doc in aws"
2015-06-02 19:08:50 -04:00
return callback new Errors.NotFoundError("Error in S3 request")
2015-06-03 10:45:47 -04:00
if md5lines != md5response
logger.err responseMD5:md5response, linesMD5:md5lines, "error in response md5 from s3"
return callback new Errors.NotFoundError("Error in S3 md5 response")
2015-06-02 14:55:22 -04:00
MongoManager.markDocAsArchived doc._id, doc.rev, (error) ->
return callback(error) if error?
callback()
unArchiveAllDocs: (project_id, callback = (error) ->) ->
MongoManager.getArchivedProjectDocs project_id, (error, docs) ->
2015-06-02 17:13:16 -04:00
if error?
2015-06-02 14:55:22 -04:00
return callback(error)
else if !docs?
return callback new Errors.NotFoundError("No docs for project #{project_id}")
jobs = _.map docs, (doc) ->
(cb)->
if !doc.inS3?
return cb()
else
DocArchive.unarchiveDoc project_id, doc._id, cb
async.series jobs, callback
unarchiveDoc: (project_id, doc_id, callback)->
logger.log project_id: project_id, doc_id: doc_id, "getting doc from s3"
2015-06-02 18:24:45 -04:00
options = DocArchive.buildS3Options(true, project_id+"/"+doc_id)
2015-06-02 14:55:22 -04:00
request.get options, (err, res, lines)->
if err? || res.statusCode != 200
logger.err err:err, res:res, "something went wrong unarchiving doc from aws"
2015-06-02 19:08:50 -04:00
return callback new Errors.NotFoundError("Error in S3 request")
2015-06-02 14:55:22 -04:00
MongoManager.upsertIntoDocCollection project_id, doc_id.toString(), lines, (error) ->
return callback(error) if error?
2015-06-03 19:05:15 -04:00
logger.log project_id: project_id, doc_id: doc_id, "deleting doc from s3"
request.del options, (err, res, body)->
if err? || res.statusCode != 204
logger.err err:err, res:res, "something went wrong deleting doc from aws"
return callback new Errors.NotFoundError("Error in S3 request")
callback()
2015-06-02 14:55:22 -04:00
2015-06-02 18:24:45 -04:00
buildS3Options: (content, key)->
return {
aws:
key: settings.filestore.s3.key
secret: settings.filestore.s3.secret
bucket: settings.filestore.stores.user_files
timeout: thirtySeconds
json: content
#headers:
2015-06-03 10:45:47 -04:00
# 'content-md5': crypto.createHash("md5").update(JSON.stringify(content)).digest("hex")
2015-06-02 18:24:45 -04:00
uri:"https://#{settings.filestore.stores.user_files}.s3.amazonaws.com/#{key}"
}