2014-08-15 11:13:35 +00:00
|
|
|
Settings = require 'settings-sharelatex'
|
|
|
|
logger = require 'logger-sharelatex'
|
|
|
|
logger.initialize("spelling-sharelatex")
|
2016-03-23 13:47:28 +00:00
|
|
|
if Settings.sentry?.dsn?
|
|
|
|
logger.initializeErrorReporting(Settings.sentry.dsn)
|
|
|
|
|
2014-08-15 11:13:35 +00:00
|
|
|
SpellingAPIController = require './app/js/SpellingAPIController'
|
2015-03-02 18:13:28 +00:00
|
|
|
express = require('express')
|
2014-08-15 11:13:35 +00:00
|
|
|
Path = require("path")
|
2015-03-02 18:13:28 +00:00
|
|
|
server = express()
|
|
|
|
bodyParser = require('body-parser')
|
2014-08-15 11:13:35 +00:00
|
|
|
metrics = require("metrics-sharelatex")
|
2015-03-02 14:59:30 +00:00
|
|
|
metrics.initialize("spelling")
|
2015-08-18 11:31:35 +00:00
|
|
|
metrics.memory.monitor(logger)
|
2015-03-01 12:45:14 +00:00
|
|
|
HealthCheckController = require("./app/js/HealthCheckController")
|
|
|
|
|
2014-08-15 11:13:35 +00:00
|
|
|
|
|
|
|
|
2015-03-03 13:57:05 +00:00
|
|
|
server.use bodyParser.json(limit: "2mb")
|
2014-08-15 11:13:35 +00:00
|
|
|
server.use metrics.http.monitor(logger)
|
|
|
|
|
2017-10-30 16:57:34 +00:00
|
|
|
server.del "/user/:user_id", SpellingAPIController.deleteDic
|
2014-08-15 11:13:35 +00:00
|
|
|
server.post "/user/:user_id/check", SpellingAPIController.check
|
|
|
|
server.post "/user/:user_id/learn", SpellingAPIController.learn
|
|
|
|
server.get "/status", (req, res)->
|
|
|
|
res.send(status:'spelling api is up')
|
|
|
|
|
2015-03-01 12:45:14 +00:00
|
|
|
server.get "/health_check", HealthCheckController.healthCheck
|
|
|
|
|
2015-03-02 15:48:27 +00:00
|
|
|
profiler = require "v8-profiler"
|
|
|
|
server.get "/profile", (req, res) ->
|
|
|
|
time = parseInt(req.query.time || "1000")
|
|
|
|
profiler.startProfiling("test")
|
|
|
|
setTimeout () ->
|
|
|
|
profile = profiler.stopProfiling("test")
|
|
|
|
res.json(profile)
|
|
|
|
, time
|
2015-03-01 12:45:14 +00:00
|
|
|
|
2014-08-15 11:25:54 +00:00
|
|
|
host = Settings.internal?.spelling?.host || "localhost"
|
|
|
|
port = Settings.internal?.spelling?.port || 3005
|
|
|
|
server.listen port, host, (error) ->
|
|
|
|
throw error if error?
|
2015-04-30 14:05:49 +00:00
|
|
|
logger.info "spelling starting up, listening on #{host}:#{port}"
|