mirror of
https://github.com/overleaf/overleaf.git
synced 2024-10-24 21:12:38 -04:00
262 lines
7.7 KiB
JavaScript
262 lines
7.7 KiB
JavaScript
|
/* eslint-disable
|
||
|
camelcase,
|
||
|
handle-callback-err,
|
||
|
max-len,
|
||
|
no-unused-vars,
|
||
|
*/
|
||
|
// TODO: This file was created by bulk-decaffeinate.
|
||
|
// Fix any style issues and re-enable lint.
|
||
|
/*
|
||
|
* decaffeinate suggestions:
|
||
|
* DS102: Remove unnecessary code created because of implicit returns
|
||
|
* DS207: Consider shorter variations of null checks
|
||
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
||
|
*/
|
||
|
let DocstoreManager
|
||
|
const request = require('request').defaults({ jar: false })
|
||
|
const logger = require('logger-sharelatex')
|
||
|
const settings = require('settings-sharelatex')
|
||
|
const Errors = require('../Errors/Errors')
|
||
|
|
||
|
module.exports = DocstoreManager = {
|
||
|
deleteDoc(project_id, doc_id, callback) {
|
||
|
if (callback == null) {
|
||
|
callback = function(error) {}
|
||
|
}
|
||
|
logger.log({ project_id, doc_id }, 'deleting doc in docstore api')
|
||
|
const url = `${
|
||
|
settings.apis.docstore.url
|
||
|
}/project/${project_id}/doc/${doc_id}`
|
||
|
return request.del(url, function(error, res, body) {
|
||
|
if (error != null) {
|
||
|
return callback(error)
|
||
|
}
|
||
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
||
|
return callback(null)
|
||
|
} else if (res.statusCode === 404) {
|
||
|
error = new Errors.NotFoundError('tried to delete doc not in docstore')
|
||
|
logger.error(
|
||
|
{ err: error, project_id, doc_id },
|
||
|
'tried to delete doc not in docstore'
|
||
|
)
|
||
|
return callback(error) // maybe suppress the error when delete doc which is not present?
|
||
|
} else {
|
||
|
error = new Error(
|
||
|
`docstore api responded with non-success code: ${res.statusCode}`
|
||
|
)
|
||
|
logger.error(
|
||
|
{ err: error, project_id, doc_id },
|
||
|
'error deleting doc in docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
}
|
||
|
})
|
||
|
},
|
||
|
|
||
|
getAllDocs(project_id, callback) {
|
||
|
if (callback == null) {
|
||
|
callback = function(error) {}
|
||
|
}
|
||
|
logger.log({ project_id }, 'getting all docs for project in docstore api')
|
||
|
const url = `${settings.apis.docstore.url}/project/${project_id}/doc`
|
||
|
return request.get(
|
||
|
{
|
||
|
url,
|
||
|
json: true
|
||
|
},
|
||
|
function(error, res, docs) {
|
||
|
if (error != null) {
|
||
|
return callback(error)
|
||
|
}
|
||
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
||
|
return callback(null, docs)
|
||
|
} else {
|
||
|
error = new Error(
|
||
|
`docstore api responded with non-success code: ${res.statusCode}`
|
||
|
)
|
||
|
logger.error(
|
||
|
{ err: error, project_id },
|
||
|
'error getting all docs from docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
}
|
||
|
}
|
||
|
)
|
||
|
},
|
||
|
|
||
|
getAllRanges(project_id, callback) {
|
||
|
if (callback == null) {
|
||
|
callback = function(error) {}
|
||
|
}
|
||
|
logger.log(
|
||
|
{ project_id },
|
||
|
'getting all doc ranges for project in docstore api'
|
||
|
)
|
||
|
const url = `${settings.apis.docstore.url}/project/${project_id}/ranges`
|
||
|
return request.get(
|
||
|
{
|
||
|
url,
|
||
|
json: true
|
||
|
},
|
||
|
function(error, res, docs) {
|
||
|
if (error != null) {
|
||
|
return callback(error)
|
||
|
}
|
||
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
||
|
return callback(null, docs)
|
||
|
} else {
|
||
|
error = new Error(
|
||
|
`docstore api responded with non-success code: ${res.statusCode}`
|
||
|
)
|
||
|
logger.error(
|
||
|
{ err: error, project_id },
|
||
|
'error getting all doc ranges from docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
}
|
||
|
}
|
||
|
)
|
||
|
},
|
||
|
|
||
|
getDoc(project_id, doc_id, options, callback) {
|
||
|
if (options == null) {
|
||
|
options = {}
|
||
|
}
|
||
|
if (callback == null) {
|
||
|
callback = function(error, lines, rev, version) {}
|
||
|
}
|
||
|
if (typeof options === 'function') {
|
||
|
callback = options
|
||
|
options = {}
|
||
|
}
|
||
|
logger.log({ project_id, doc_id, options }, 'getting doc in docstore api')
|
||
|
let url = `${
|
||
|
settings.apis.docstore.url
|
||
|
}/project/${project_id}/doc/${doc_id}`
|
||
|
if (options.include_deleted) {
|
||
|
url += '?include_deleted=true'
|
||
|
}
|
||
|
return request.get(
|
||
|
{
|
||
|
url,
|
||
|
json: true
|
||
|
},
|
||
|
function(error, res, doc) {
|
||
|
if (error != null) {
|
||
|
return callback(error)
|
||
|
}
|
||
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
||
|
logger.log(
|
||
|
{ doc_id, project_id, version: doc.version, rev: doc.rev },
|
||
|
'got doc from docstore api'
|
||
|
)
|
||
|
return callback(null, doc.lines, doc.rev, doc.version, doc.ranges)
|
||
|
} else if (res.statusCode === 404) {
|
||
|
error = new Errors.NotFoundError('doc not found in docstore')
|
||
|
logger.error(
|
||
|
{ err: error, project_id, doc_id },
|
||
|
'doc not found in docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
} else {
|
||
|
error = new Error(
|
||
|
`docstore api responded with non-success code: ${res.statusCode}`
|
||
|
)
|
||
|
logger.error(
|
||
|
{ err: error, project_id, doc_id },
|
||
|
'error getting doc from docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
}
|
||
|
}
|
||
|
)
|
||
|
},
|
||
|
|
||
|
updateDoc(project_id, doc_id, lines, version, ranges, callback) {
|
||
|
if (callback == null) {
|
||
|
callback = function(error, modified, rev) {}
|
||
|
}
|
||
|
logger.log({ project_id, doc_id }, 'updating doc in docstore api')
|
||
|
const url = `${
|
||
|
settings.apis.docstore.url
|
||
|
}/project/${project_id}/doc/${doc_id}`
|
||
|
return request.post(
|
||
|
{
|
||
|
url,
|
||
|
json: {
|
||
|
lines,
|
||
|
version,
|
||
|
ranges
|
||
|
}
|
||
|
},
|
||
|
function(error, res, result) {
|
||
|
if (error != null) {
|
||
|
return callback(error)
|
||
|
}
|
||
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
||
|
logger.log(
|
||
|
{ project_id, doc_id },
|
||
|
'update doc in docstore url finished'
|
||
|
)
|
||
|
return callback(null, result.modified, result.rev)
|
||
|
} else {
|
||
|
error = new Error(
|
||
|
`docstore api responded with non-success code: ${res.statusCode}`
|
||
|
)
|
||
|
logger.error(
|
||
|
{ err: error, project_id, doc_id },
|
||
|
'error updating doc in docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
}
|
||
|
}
|
||
|
)
|
||
|
},
|
||
|
|
||
|
archiveProject(project_id, callback) {
|
||
|
const url = `${settings.apis.docstore.url}/project/${project_id}/archive`
|
||
|
logger.log({ project_id }, 'archiving project in docstore')
|
||
|
return request.post(url, function(err, res, docs) {
|
||
|
if (err != null) {
|
||
|
logger.err({ err, project_id }, 'error archving project in docstore')
|
||
|
return callback(err)
|
||
|
}
|
||
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
||
|
return callback()
|
||
|
} else {
|
||
|
const error = new Error(
|
||
|
`docstore api responded with non-success code: ${res.statusCode}`
|
||
|
)
|
||
|
logger.err(
|
||
|
{ err: error, project_id },
|
||
|
'error archiving project in docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
}
|
||
|
})
|
||
|
},
|
||
|
|
||
|
unarchiveProject(project_id, callback) {
|
||
|
const url = `${settings.apis.docstore.url}/project/${project_id}/unarchive`
|
||
|
logger.log({ project_id }, 'unarchiving project in docstore')
|
||
|
return request.post(url, function(err, res, docs) {
|
||
|
if (err != null) {
|
||
|
logger.err({ err, project_id }, 'error unarchiving project in docstore')
|
||
|
return callback(err)
|
||
|
}
|
||
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
||
|
return callback()
|
||
|
} else {
|
||
|
const error = new Error(
|
||
|
`docstore api responded with non-success code: ${res.statusCode}`
|
||
|
)
|
||
|
logger.err(
|
||
|
{ err: error, project_id },
|
||
|
'error unarchiving project in docstore'
|
||
|
)
|
||
|
return callback(error)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|