overleaf/services/web/app/coffee/Features/Subscription/SubscriptionGroupController.coffee

73 lines
3 KiB
CoffeeScript
Raw Normal View History

2014-02-12 05:23:40 -05:00
SubscriptionGroupHandler = require("./SubscriptionGroupHandler")
logger = require("logger-sharelatex")
SubscriptionLocator = require("./SubscriptionLocator")
ErrorsController = require("../Errors/ErrorController")
SubscriptionDomainHandler = require("./SubscriptionDomainHandler")
2016-09-05 10:58:31 -04:00
AuthenticationController = require('../Authentication/AuthenticationController')
_ = require("underscore")
async = require("async")
2014-02-12 05:23:40 -05:00
module.exports =
addUserToGroup: (req, res)->
2016-09-05 10:58:31 -04:00
adminUserId = AuthenticationController.getLoggedInUserId(req)
newEmail = req.body?.email?.toLowerCase()?.trim()
2014-02-12 05:23:40 -05:00
logger.log adminUserId:adminUserId, newEmail:newEmail, "adding user to group subscription"
SubscriptionGroupHandler.addUserToGroup adminUserId, newEmail, (err, user)->
if err?
logger.err err:err, newEmail:newEmail, adminUserId:adminUserId, "error adding user from group"
return res.sendStatus 500
2016-09-05 10:58:31 -04:00
result =
2014-02-12 05:23:40 -05:00
user:user
if err and err.limitReached
result.limitReached = true
res.json(result)
removeUserFromGroup: (req, res)->
2016-09-05 10:58:31 -04:00
adminUserId = AuthenticationController.getLoggedInUserId(req)
2014-02-12 05:23:40 -05:00
userToRemove_id = req.params.user_id
logger.log adminUserId:adminUserId, userToRemove_id:userToRemove_id, "removing user from group subscription"
SubscriptionGroupHandler.removeUserFromGroup adminUserId, userToRemove_id, (err)->
if err?
logger.err err:err, adminUserId:adminUserId, userToRemove_id:userToRemove_id, "error removing user from group"
return res.sendStatus 500
2014-02-12 05:23:40 -05:00
res.send()
2016-09-05 10:58:31 -04:00
removeSelfFromGroup: (req, res)->
adminUserId = req.query.admin_user_id
2016-09-05 10:58:31 -04:00
userToRemove_id = AuthenticationController.getLoggedInUserId(req)
logger.log adminUserId:adminUserId, userToRemove_id:userToRemove_id, "removing user from group subscription after self request"
SubscriptionGroupHandler.removeUserFromGroup adminUserId, userToRemove_id, (err)->
if err?
logger.err err:err, userToRemove_id:userToRemove_id, adminUserId:adminUserId, "error removing self from group"
return res.sendStatus 500
res.send()
2014-02-12 05:23:40 -05:00
renderSubscriptionGroupAdminPage: (req, res)->
2016-09-05 10:58:31 -04:00
user_id = AuthenticationController.getLoggedInUserId(req)
2014-02-12 05:23:40 -05:00
SubscriptionLocator.getUsersSubscription user_id, (err, subscription)->
if !subscription?.groupPlan
return res.redirect("/user/subscription")
2014-02-12 05:23:40 -05:00
SubscriptionGroupHandler.getPopulatedListOfMembers user_id, (err, users)->
res.render "subscriptions/group_admin",
2014-08-01 08:47:14 -04:00
title: 'group_admin'
2014-02-12 05:23:40 -05:00
users: users
subscription: subscription
2015-05-28 15:54:41 -04:00
exportGroupCsv: (req, res)->
2016-09-05 10:58:31 -04:00
user_id = AuthenticationController.getLoggedInUserId(req)
2015-05-28 15:54:41 -04:00
logger.log user_id: user_id, "exporting group csv"
SubscriptionLocator.getUsersSubscription user_id, (err, subscription)->
if !subscription.groupPlan
return res.redirect("/")
SubscriptionGroupHandler.getPopulatedListOfMembers user_id, (err, users)->
groupCsv = ""
for user in users
groupCsv += user.email + "\n"
res.header(
"Content-Disposition",
"attachment; filename=Group.csv"
)
res.contentType('text/csv')
res.send(groupCsv)