2020-02-17 17:34:21 +00:00
|
|
|
// TODO: This file was created by bulk-decaffeinate.
|
|
|
|
// Fix any style issues and re-enable lint.
|
2020-02-17 17:34:04 +00:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
*/
|
2020-02-17 17:34:28 +00:00
|
|
|
let WebApiManager
|
|
|
|
const request = require('requestretry') // allow retry on error https://github.com/FGRibreau/node-request-retry
|
2021-12-14 13:00:35 +00:00
|
|
|
const logger = require('@overleaf/logger')
|
2021-07-12 16:47:16 +00:00
|
|
|
const Settings = require('@overleaf/settings')
|
2014-03-06 18:04:00 +00:00
|
|
|
|
2020-02-17 17:34:04 +00:00
|
|
|
// Don't let HTTP calls hang for a long time
|
2020-02-17 17:34:28 +00:00
|
|
|
const MAX_HTTP_REQUEST_LENGTH = 15000 // 15 seconds
|
2016-04-13 15:30:20 +00:00
|
|
|
|
2020-02-17 17:34:04 +00:00
|
|
|
// DEPRECATED! This method of getting user details via track-changes is deprecated
|
|
|
|
// in the way we lay out our services.
|
|
|
|
// Instead, web should be responsible for collecting the raw data (user_ids) and
|
|
|
|
// filling it out with calls to other services. All API calls should create a
|
|
|
|
// tree-like structure as much as possible, with web as the root.
|
2020-02-17 17:34:28 +00:00
|
|
|
module.exports = WebApiManager = {
|
|
|
|
sendRequest(url, callback) {
|
|
|
|
if (callback == null) {
|
2021-10-27 09:49:18 +00:00
|
|
|
callback = function () {}
|
2020-02-17 17:34:28 +00:00
|
|
|
}
|
|
|
|
return request.get(
|
|
|
|
{
|
|
|
|
url: `${Settings.apis.web.url}${url}`,
|
|
|
|
timeout: MAX_HTTP_REQUEST_LENGTH,
|
|
|
|
maxAttempts: 2, // for node-request-retry
|
|
|
|
auth: {
|
|
|
|
user: Settings.apis.web.user,
|
|
|
|
pass: Settings.apis.web.pass,
|
2021-07-13 11:04:43 +00:00
|
|
|
sendImmediately: true,
|
|
|
|
},
|
2020-02-17 17:34:28 +00:00
|
|
|
},
|
2020-06-04 08:24:21 +00:00
|
|
|
function (error, res, body) {
|
2020-02-17 17:34:28 +00:00
|
|
|
if (error != null) {
|
|
|
|
return callback(error)
|
|
|
|
}
|
|
|
|
if (res.statusCode === 404) {
|
2022-05-16 12:38:18 +00:00
|
|
|
logger.debug({ url }, 'got 404 from web api')
|
2020-02-17 17:34:28 +00:00
|
|
|
return callback(null, null)
|
|
|
|
}
|
|
|
|
if (res.statusCode >= 200 && res.statusCode < 300) {
|
|
|
|
return callback(null, body)
|
|
|
|
} else {
|
|
|
|
error = new Error(
|
|
|
|
`web returned a non-success status code: ${res.statusCode} (attempts: ${res.attempts})`
|
|
|
|
)
|
|
|
|
return callback(error)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
},
|
2014-03-28 13:05:16 +00:00
|
|
|
|
2023-03-21 12:21:51 +00:00
|
|
|
getUserInfo(userId, callback) {
|
2020-02-17 17:34:28 +00:00
|
|
|
if (callback == null) {
|
2021-10-27 09:49:18 +00:00
|
|
|
callback = function () {}
|
2020-02-17 17:34:28 +00:00
|
|
|
}
|
2023-03-21 12:21:51 +00:00
|
|
|
const url = `/user/${userId}/personal_info`
|
|
|
|
logger.debug({ userId }, 'getting user info from web')
|
2020-06-04 08:24:21 +00:00
|
|
|
return WebApiManager.sendRequest(url, function (error, body) {
|
2020-02-17 17:34:28 +00:00
|
|
|
let user
|
|
|
|
if (error != null) {
|
2023-03-21 12:21:51 +00:00
|
|
|
logger.error({ err: error, userId, url }, 'error accessing web')
|
2020-02-17 17:34:28 +00:00
|
|
|
return callback(error)
|
|
|
|
}
|
2014-03-28 13:05:16 +00:00
|
|
|
|
2020-02-17 17:34:28 +00:00
|
|
|
if (body === null) {
|
2023-03-21 12:21:51 +00:00
|
|
|
logger.error({ userId, url }, 'no user found')
|
2020-02-17 17:34:28 +00:00
|
|
|
return callback(null, null)
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
user = JSON.parse(body)
|
|
|
|
} catch (error1) {
|
|
|
|
error = error1
|
|
|
|
return callback(error)
|
|
|
|
}
|
|
|
|
return callback(null, {
|
|
|
|
id: user.id,
|
|
|
|
email: user.email,
|
|
|
|
first_name: user.first_name,
|
2021-07-13 11:04:43 +00:00
|
|
|
last_name: user.last_name,
|
2020-02-17 17:34:28 +00:00
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
2014-03-28 13:05:16 +00:00
|
|
|
|
2023-03-21 12:21:51 +00:00
|
|
|
getProjectDetails(projectId, callback) {
|
2020-02-17 17:34:28 +00:00
|
|
|
if (callback == null) {
|
2021-10-27 09:49:18 +00:00
|
|
|
callback = function () {}
|
2020-02-17 17:34:28 +00:00
|
|
|
}
|
2023-03-21 12:21:51 +00:00
|
|
|
const url = `/project/${projectId}/details`
|
|
|
|
logger.debug({ projectId }, 'getting project details from web')
|
2020-06-04 08:24:21 +00:00
|
|
|
return WebApiManager.sendRequest(url, function (error, body) {
|
2020-02-17 17:34:28 +00:00
|
|
|
let project
|
|
|
|
if (error != null) {
|
2023-03-21 12:21:51 +00:00
|
|
|
logger.error({ err: error, projectId, url }, 'error accessing web')
|
2020-02-17 17:34:28 +00:00
|
|
|
return callback(error)
|
|
|
|
}
|
2014-03-28 13:05:16 +00:00
|
|
|
|
2020-02-17 17:34:28 +00:00
|
|
|
try {
|
|
|
|
project = JSON.parse(body)
|
|
|
|
} catch (error1) {
|
|
|
|
error = error1
|
|
|
|
return callback(error)
|
|
|
|
}
|
|
|
|
return callback(null, project)
|
|
|
|
})
|
2021-07-13 11:04:43 +00:00
|
|
|
},
|
2020-02-17 17:34:28 +00:00
|
|
|
}
|