overleaf/services/web/app/coffee/Features/UserMembership/UserMembershipController.coffee

101 lines
3.4 KiB
CoffeeScript
Raw Normal View History

2018-09-25 09:10:06 -04:00
AuthenticationController = require('../Authentication/AuthenticationController')
UserMembershipHandler = require('./UserMembershipHandler')
2018-10-11 13:56:14 -04:00
EntityConfigs = require('./UserMembershipEntityConfigs')
Errors = require('../Errors/Errors')
EmailHelper = require("../Helpers/EmailHelper")
2018-09-25 09:10:06 -04:00
logger = require("logger-sharelatex")
module.exports =
index: (req, res, next)->
{ entity, entityConfig } = req
entity.fetchV1Data (error, entity) ->
2018-09-25 09:10:06 -04:00
return next(error) if error?
UserMembershipHandler.getUsers entity, entityConfig, (error, users)->
return next(error) if error?
entityPrimaryKey = entity[entityConfig.fields.primaryKey].toString()
entityName = entity[entityConfig.fields.name] if entityConfig.fields.name
res.render "user_membership/index",
name: entityName
users: users
groupSize: entity.membersLimit if entityConfig.hasMembersLimit
translations: entityConfig.translations
paths: entityConfig.pathsFor(entityPrimaryKey)
add: (req, res, next)->
{ entity, entityConfig } = req
email = EmailHelper.parseEmail(req.body.email)
if !email?
return res.status(400).json error:
code: 'invalid_email'
message: req.i18n.translate('invalid_email')
2018-09-25 09:10:06 -04:00
if entityConfig.readOnly
return next(new Errors.NotFoundError("Cannot add users to entity"))
2018-09-25 09:10:06 -04:00
UserMembershipHandler.addUser entity, entityConfig, email, (error, user)->
if error?.alreadyAdded
return res.status(400).json error:
code: 'user_already_added'
message: req.i18n.translate('user_already_added')
if error?.userNotFound
return res.status(404).json error:
code: 'user_not_found'
message: req.i18n.translate('user_not_found')
2018-09-25 09:10:06 -04:00
return next(error) if error?
res.json(user: user)
2018-10-11 13:56:14 -04:00
remove: (req, res, next)->
{ entity, entityConfig } = req
userId = req.params.userId
2018-09-25 09:10:06 -04:00
if entityConfig.readOnly
return next(new Errors.NotFoundError("Cannot remove users from entity"))
2018-10-11 13:56:14 -04:00
loggedInUserId = AuthenticationController.getLoggedInUserId(req)
if loggedInUserId == userId
return res.status(400).json error:
code: 'managers_cannot_remove_self'
message: req.i18n.translate('managers_cannot_remove_self')
UserMembershipHandler.removeUser entity, entityConfig, userId, (error, user)->
if error?.isAdmin
return res.status(400).json error:
code: 'managers_cannot_remove_admin'
message: req.i18n.translate('managers_cannot_remove_admin')
return next(error) if error?
res.send()
exportCsv: (req, res, next)->
{ entity, entityConfig } = req
logger.log subscriptionId: entity._id, "exporting csv"
UserMembershipHandler.getUsers entity, entityConfig, (error, users)->
return next(error) if error?
csvOutput = ""
for user in users
csvOutput += user.email + "\n"
res.header(
"Content-Disposition",
"attachment; filename=Group.csv"
)
res.contentType('text/csv')
res.send(csvOutput)
new: (req, res, next)->
res.render "user_membership/new",
entityName: req.params.name
entityId: req.params.id
create: (req, res, next)->
entityName = req.params.name
entityId = req.params.id
entityConfig = EntityConfigs[entityName]
unless entityConfig
return next(new Errors.NotFoundError("No such entity: #{entityName}"))
unless entityConfig.canCreate
return next(new Errors.NotFoundError("Cannot create new #{entityName}"))
UserMembershipHandler.createEntity entityId, entityConfig, (error, entity) ->
return next(error) if error?
res.redirect entityConfig.pathsFor(entityId).index