2019-07-03 12:41:01 +00:00
|
|
|
const SpellingAPIManager = require('./SpellingAPIManager')
|
2021-12-14 13:00:35 +00:00
|
|
|
const logger = require('@overleaf/logger')
|
2020-11-25 11:57:24 +00:00
|
|
|
const metrics = require('@overleaf/metrics')
|
2020-06-03 09:14:44 +00:00
|
|
|
const OError = require('@overleaf/o-error')
|
2019-07-03 12:41:01 +00:00
|
|
|
|
2019-07-11 10:29:00 +00:00
|
|
|
function extractCheckRequestData(req) {
|
|
|
|
const token = req.params ? req.params.user_id : undefined
|
|
|
|
const wordCount =
|
|
|
|
req.body && req.body.words ? req.body.words.length : undefined
|
|
|
|
return { token, wordCount }
|
|
|
|
}
|
|
|
|
|
2019-07-03 12:41:01 +00:00
|
|
|
module.exports = {
|
2019-07-11 10:29:00 +00:00
|
|
|
check(req, res) {
|
2019-07-03 12:41:01 +00:00
|
|
|
metrics.inc('spelling-check', 0.1)
|
2019-07-11 10:29:00 +00:00
|
|
|
const { token, wordCount } = extractCheckRequestData(req)
|
|
|
|
logger.info({ token, wordCount }, 'running check')
|
2020-08-10 16:23:15 +00:00
|
|
|
SpellingAPIManager.runRequest(token, req.body, function (error, result) {
|
2019-07-03 12:41:01 +00:00
|
|
|
if (error != null) {
|
2020-06-03 09:14:44 +00:00
|
|
|
logger.error(
|
|
|
|
OError.tag(error, 'error processing spelling request', {
|
2019-07-11 10:29:00 +00:00
|
|
|
user_id: token,
|
2021-07-13 11:04:47 +00:00
|
|
|
wordCount,
|
2020-06-03 09:14:44 +00:00
|
|
|
})
|
2019-07-03 12:41:01 +00:00
|
|
|
)
|
|
|
|
return res.sendStatus(500)
|
|
|
|
}
|
2019-07-11 10:29:00 +00:00
|
|
|
res.send(result)
|
2019-07-03 12:41:01 +00:00
|
|
|
})
|
|
|
|
},
|
|
|
|
}
|