mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-24 13:20:58 +00:00
39 lines
1.4 KiB
CoffeeScript
39 lines
1.4 KiB
CoffeeScript
|
SecurityManager = require '../../managers/SecurityManager'
|
||
|
|
||
|
module.exports = AuthorizationManager =
|
||
|
getPrivilegeLevelForProject: (
|
||
|
project, user,
|
||
|
callback = (error, canAccess, privilegeLevel)->
|
||
|
) ->
|
||
|
# This is not tested because eventually this function should be brought into
|
||
|
# this module.
|
||
|
SecurityManager.userCanAccessProject user, project, (canAccess, privilegeLevel) ->
|
||
|
if canAccess
|
||
|
callback null, true, privilegeLevel
|
||
|
else
|
||
|
callback null, false
|
||
|
|
||
|
setPrivilegeLevelOnClient: (client, privilegeLevel) ->
|
||
|
client.set("privilege_level", privilegeLevel)
|
||
|
|
||
|
ensureClientCanViewProject: (client, callback = (error, project_id)->) ->
|
||
|
@ensureClientHasPrivilegeLevelForProject client, ["owner", "readAndWrite", "readOnly"], callback
|
||
|
|
||
|
ensureClientCanEditProject: (client, callback = (error, project_id)->) ->
|
||
|
@ensureClientHasPrivilegeLevelForProject client, ["owner", "readAndWrite"], callback
|
||
|
|
||
|
ensureClientCanAdminProject: (client, callback = (error, project_id)->) ->
|
||
|
@ensureClientHasPrivilegeLevelForProject client, ["owner"], callback
|
||
|
|
||
|
ensureClientHasPrivilegeLevelForProject: (client, levels, callback = (error, project_id)->) ->
|
||
|
client.get "privilege_level", (error, level) ->
|
||
|
return callback(error) if error?
|
||
|
if level?
|
||
|
client.get "project_id", (error, project_id) ->
|
||
|
return callback(error) if error?
|
||
|
if project_id?
|
||
|
if levels.indexOf(level) > -1
|
||
|
callback null, project_id
|
||
|
|
||
|
|