2020-02-17 17:34:21 +00:00
|
|
|
/* eslint-disable
|
|
|
|
camelcase,
|
|
|
|
standard/no-callback-literal,
|
|
|
|
*/
|
|
|
|
// 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-09-10 11:58:06 +00:00
|
|
|
const { ObjectId } = require('./mongodb')
|
2020-02-17 17:34:28 +00:00
|
|
|
const request = require('request')
|
|
|
|
const async = require('async')
|
|
|
|
const settings = require('settings-sharelatex')
|
|
|
|
const { port } = settings.internal.trackchanges
|
|
|
|
const logger = require('logger-sharelatex')
|
|
|
|
const LockManager = require('./LockManager')
|
2015-10-19 09:59:39 +00:00
|
|
|
|
2020-02-17 17:34:04 +00:00
|
|
|
module.exports = {
|
2020-02-17 17:34:28 +00:00
|
|
|
check(callback) {
|
|
|
|
const project_id = ObjectId(settings.trackchanges.healthCheck.project_id)
|
|
|
|
const url = `http://localhost:${port}/project/${project_id}`
|
|
|
|
logger.log({ project_id }, 'running health check')
|
|
|
|
const jobs = [
|
2020-06-04 08:24:21 +00:00
|
|
|
(cb) =>
|
2020-02-17 17:34:28 +00:00
|
|
|
request.get(
|
|
|
|
{ url: `http://localhost:${port}/check_lock`, timeout: 3000 },
|
2020-06-04 08:24:21 +00:00
|
|
|
function (err, res, body) {
|
2020-02-17 17:34:28 +00:00
|
|
|
if (err != null) {
|
|
|
|
logger.err(
|
|
|
|
{ err, project_id },
|
|
|
|
'error checking lock for health check'
|
|
|
|
)
|
|
|
|
return cb(err)
|
|
|
|
} else if ((res != null ? res.statusCode : undefined) !== 200) {
|
|
|
|
return cb(`status code not 200, it's ${res.statusCode}`)
|
|
|
|
} else {
|
|
|
|
return cb()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
),
|
2020-06-04 08:24:21 +00:00
|
|
|
(cb) =>
|
|
|
|
request.post({ url: `${url}/flush`, timeout: 10000 }, function (
|
2020-02-17 17:34:28 +00:00
|
|
|
err,
|
|
|
|
res,
|
|
|
|
body
|
|
|
|
) {
|
|
|
|
if (err != null) {
|
|
|
|
logger.err({ err, project_id }, 'error flushing for health check')
|
|
|
|
return cb(err)
|
|
|
|
} else if ((res != null ? res.statusCode : undefined) !== 204) {
|
|
|
|
return cb(`status code not 204, it's ${res.statusCode}`)
|
|
|
|
} else {
|
|
|
|
return cb()
|
|
|
|
}
|
|
|
|
}),
|
2020-06-04 08:24:21 +00:00
|
|
|
(cb) =>
|
|
|
|
request.get({ url: `${url}/updates`, timeout: 10000 }, function (
|
2020-02-17 17:34:28 +00:00
|
|
|
err,
|
|
|
|
res,
|
|
|
|
body
|
|
|
|
) {
|
|
|
|
if (err != null) {
|
|
|
|
logger.err(
|
|
|
|
{ err, project_id },
|
|
|
|
'error getting updates for health check'
|
|
|
|
)
|
|
|
|
return cb(err)
|
|
|
|
} else if ((res != null ? res.statusCode : undefined) !== 200) {
|
|
|
|
return cb(`status code not 200, it's ${res.statusCode}`)
|
|
|
|
} else {
|
|
|
|
return cb()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
]
|
|
|
|
return async.series(jobs, callback)
|
|
|
|
},
|
2016-01-27 16:04:55 +00:00
|
|
|
|
2020-02-17 17:34:28 +00:00
|
|
|
checkLock(callback) {
|
|
|
|
return LockManager.healthCheck(callback)
|
|
|
|
}
|
|
|
|
}
|