2020-01-13 19:01:22 +00:00
|
|
|
/*
|
|
|
|
* decaffeinate suggestions:
|
|
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
|
|
* DS103: Rewrite code to no longer use __guard__
|
|
|
|
* DS207: Consider shorter variations of null checks
|
|
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
|
|
*/
|
2020-11-25 11:57:20 +00:00
|
|
|
const metrics = require('@overleaf/metrics')
|
2020-01-13 19:01:23 +00:00
|
|
|
metrics.initialize('notifications')
|
2021-07-12 16:47:16 +00:00
|
|
|
const Settings = require('@overleaf/settings')
|
2021-12-14 13:00:35 +00:00
|
|
|
const logger = require('@overleaf/logger')
|
2020-01-13 19:01:23 +00:00
|
|
|
logger.initialize('notifications-sharelatex')
|
|
|
|
const express = require('express')
|
|
|
|
const app = express()
|
2020-03-26 14:17:07 +00:00
|
|
|
const methodOverride = require('method-override')
|
|
|
|
const bodyParser = require('body-parser')
|
2022-12-20 14:55:25 +00:00
|
|
|
const { mongoClient } = require('./app/js/mongodb')
|
2020-01-13 19:01:23 +00:00
|
|
|
const controller = require('./app/js/NotificationsController')
|
|
|
|
|
|
|
|
metrics.memory.monitor(logger)
|
2023-05-22 10:36:51 +00:00
|
|
|
metrics.open_sockets.monitor()
|
2020-01-13 19:01:23 +00:00
|
|
|
|
|
|
|
const HealthCheckController = require('./app/js/HealthCheckController')
|
|
|
|
|
2020-03-26 14:17:07 +00:00
|
|
|
app.use(methodOverride())
|
|
|
|
app.use(bodyParser())
|
|
|
|
app.use(metrics.http.monitor(logger))
|
2020-01-13 19:01:23 +00:00
|
|
|
|
|
|
|
metrics.injectMetricsRoute(app)
|
|
|
|
|
|
|
|
app.post('/user/:user_id', controller.addNotification)
|
|
|
|
app.get('/user/:user_id', controller.getUserNotifications)
|
2020-03-18 15:29:28 +00:00
|
|
|
app.delete(
|
2020-01-13 19:01:23 +00:00
|
|
|
'/user/:user_id/notification/:notification_id',
|
|
|
|
controller.removeNotificationId
|
|
|
|
)
|
2020-03-18 15:29:28 +00:00
|
|
|
app.delete('/user/:user_id', controller.removeNotificationKey)
|
|
|
|
app.delete('/key/:key', controller.removeNotificationByKeyOnly)
|
2021-10-20 10:18:14 +00:00
|
|
|
app.get('/key/:key/count', controller.countNotificationsByKeyOnly)
|
|
|
|
app.delete('/key/:key/bulk', controller.deleteUnreadNotificationsByKeyOnlyBulk)
|
2020-01-13 19:01:23 +00:00
|
|
|
|
|
|
|
app.get('/status', (req, res) => res.send('notifications sharelatex up'))
|
|
|
|
|
|
|
|
app.get('/health_check', (req, res) =>
|
2020-06-04 07:50:05 +00:00
|
|
|
HealthCheckController.check(function (err) {
|
2020-01-13 19:01:23 +00:00
|
|
|
if (err != null) {
|
|
|
|
logger.err({ err }, 'error performing health check')
|
2020-03-18 15:29:28 +00:00
|
|
|
return res.sendStatus(500)
|
2020-01-13 19:01:23 +00:00
|
|
|
} else {
|
2020-03-18 15:29:28 +00:00
|
|
|
return res.sendStatus(200)
|
2020-01-13 19:01:23 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
)
|
|
|
|
|
2020-03-18 15:29:28 +00:00
|
|
|
app.get('*', (req, res) => res.sendStatus(404))
|
2020-01-13 19:01:23 +00:00
|
|
|
|
|
|
|
const host =
|
|
|
|
__guard__(
|
|
|
|
Settings.internal != null ? Settings.internal.notifications : undefined,
|
2021-07-13 11:04:44 +00:00
|
|
|
x => x.host
|
2020-01-13 19:01:23 +00:00
|
|
|
) || 'localhost'
|
|
|
|
const port =
|
|
|
|
__guard__(
|
|
|
|
Settings.internal != null ? Settings.internal.notifications : undefined,
|
2021-07-13 11:04:44 +00:00
|
|
|
x1 => x1.port
|
2020-01-13 19:01:23 +00:00
|
|
|
) || 3042
|
2020-08-31 08:58:47 +00:00
|
|
|
|
2022-12-20 14:55:25 +00:00
|
|
|
mongoClient
|
|
|
|
.connect()
|
2020-08-31 08:58:47 +00:00
|
|
|
.then(() => {
|
|
|
|
app.listen(port, host, () =>
|
2022-05-16 12:38:18 +00:00
|
|
|
logger.debug(`notifications starting up, listening on ${host}:${port}`)
|
2020-08-31 08:58:47 +00:00
|
|
|
)
|
|
|
|
})
|
2021-07-13 11:04:44 +00:00
|
|
|
.catch(err => {
|
2020-08-31 08:58:47 +00:00
|
|
|
logger.fatal({ err }, 'Cannot connect to mongo. Exiting.')
|
|
|
|
process.exit(1)
|
|
|
|
})
|
2020-01-13 19:01:22 +00:00
|
|
|
|
|
|
|
function __guard__(value, transform) {
|
2020-01-13 19:01:23 +00:00
|
|
|
return typeof value !== 'undefined' && value !== null
|
|
|
|
? transform(value)
|
|
|
|
: undefined
|
|
|
|
}
|