overleaf/services/real-time/app/coffee/WebApiManager.coffee

39 lines
1.5 KiB
CoffeeScript
Raw Normal View History

2014-11-10 11:27:08 +00:00
request = require "request"
settings = require "settings-sharelatex"
logger = require "logger-sharelatex"
{ CodedError } = require "./Errors"
2014-11-10 11:27:08 +00:00
module.exports = WebApiManager =
joinProject: (project_id, user, callback = (error, project, privilegeLevel, isRestrictedUser) ->) ->
user_id = user._id
2014-11-10 11:27:08 +00:00
logger.log {project_id, user_id}, "sending join project request to web"
url = "#{settings.apis.web.url}/project/#{project_id}/join"
headers = {}
if user.anonymousAccessToken?
2017-10-26 15:00:06 +00:00
headers['x-sl-anonymous-access-token'] = user.anonymousAccessToken
2014-11-10 11:27:08 +00:00
request.post {
url: url
qs: {user_id}
2014-11-17 14:35:07 +00:00
auth:
user: settings.apis.web.user
pass: settings.apis.web.pass
sendImmediately: true
2014-11-10 11:27:08 +00:00
json: true
jar: false
headers: headers
2014-11-10 11:27:08 +00:00
}, (error, response, data) ->
return callback(error) if error?
if 200 <= response.statusCode < 300
if !data? || !data?.project?
err = new Error('no data returned from joinProject request')
logger.error {err, project_id, user_id}, "error accessing web api"
return callback(err)
callback null, data.project, data.privilegeLevel, data.isRestrictedUser
else if response.statusCode == 429
logger.log(project_id, user_id, "rate-limit hit when joining project")
callback(new CodedError("rate-limit hit when joining project", "TooManyRequests"))
2014-11-10 11:27:08 +00:00
else
err = new Error("non-success status code from web: #{response.statusCode}")
logger.error {err, project_id, user_id}, "error accessing web api"
callback err