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

87 lines
4.1 KiB
CoffeeScript
Raw Normal View History

2014-02-12 05:23:40 -05:00
async = require("async")
_ = require("underscore")
Subscription = require('../../models/Subscription').Subscription
SubscriptionLocator = require("./SubscriptionLocator")
PlansLocator = require("./PlansLocator")
Settings = require("settings-sharelatex")
logger = require("logger-sharelatex")
ObjectId = require('mongoose').Types.ObjectId
FeaturesUpdater = require('./FeaturesUpdater')
2014-02-12 05:23:40 -05:00
oneMonthInSeconds = 60 * 60 * 24 * 30
module.exports = SubscriptionUpdater =
2014-02-12 05:23:40 -05:00
syncSubscription: (recurlySubscription, adminUser_id, callback) ->
logger.log adminUser_id:adminUser_id, recurlySubscription:recurlySubscription, "syncSubscription, creating new if subscription does not exist"
SubscriptionLocator.getUsersSubscription adminUser_id, (err, subscription)->
return callback(err) if err?
2014-02-12 05:23:40 -05:00
if subscription?
logger.log adminUser_id:adminUser_id, recurlySubscription:recurlySubscription, "subscription does exist"
SubscriptionUpdater._updateSubscriptionFromRecurly recurlySubscription, subscription, callback
2014-02-12 05:23:40 -05:00
else
logger.log adminUser_id:adminUser_id, recurlySubscription:recurlySubscription, "subscription does not exist, creating a new one"
SubscriptionUpdater._createNewSubscription adminUser_id, (err, subscription)->
return callback(err) if err?
SubscriptionUpdater._updateSubscriptionFromRecurly recurlySubscription, subscription, callback
2014-02-12 05:23:40 -05:00
addUserToGroup: (adminUser_id, user_id, callback)->
logger.log adminUser_id:adminUser_id, user_id:user_id, "adding user into mongo subscription"
2018-06-01 06:23:25 -04:00
searchOps =
2014-02-12 05:23:40 -05:00
admin_id: adminUser_id
2018-06-01 06:23:25 -04:00
insertOperation =
2014-02-12 05:23:40 -05:00
"$addToSet": {member_ids:user_id}
Subscription.findAndModify searchOps, insertOperation, (err, subscription)->
if err?
logger.err err:err, searchOps:searchOps, insertOperation:insertOperation, "error findy and modify add user to group"
return callback(err)
FeaturesUpdater.refreshFeatures user_id, callback
2014-02-12 05:23:40 -05:00
removeUserFromGroup: (adminUser_id, user_id, callback)->
2018-06-01 06:23:25 -04:00
searchOps =
2014-02-12 05:23:40 -05:00
admin_id: adminUser_id
2018-06-01 06:23:25 -04:00
removeOperation =
2014-02-12 05:23:40 -05:00
"$pull": {member_ids:user_id}
Subscription.update searchOps, removeOperation, (err)->
if err?
logger.err err:err, searchOps:searchOps, removeOperation:removeOperation, "error removing user from group"
return callback(err)
FeaturesUpdater.refreshFeatures user_id, callback
deleteSubscription: (subscription_id, callback = (error) ->) ->
SubscriptionLocator.getSubscription subscription_id, (err, subscription) ->
return callback(err) if err?
affected_user_ids = [subscription.admin_id].concat(subscription.member_ids or [])
logger.log {subscription_id, affected_user_ids}, "deleting subscription and downgrading users"
Subscription.remove {_id: ObjectId(subscription_id)}, (err) ->
return callback(err) if err?
async.mapSeries affected_user_ids, FeaturesUpdater.refreshFeatures, callback
2014-02-12 05:23:40 -05:00
_createNewSubscription: (adminUser_id, callback)->
logger.log adminUser_id:adminUser_id, "creating new subscription"
subscription = new Subscription(admin_id:adminUser_id)
subscription.freeTrial.allowed = false
subscription.save (err)->
callback err, subscription
_updateSubscriptionFromRecurly: (recurlySubscription, subscription, callback)->
2014-02-12 05:23:40 -05:00
logger.log recurlySubscription:recurlySubscription, subscription:subscription, "updaing subscription"
plan = PlansLocator.findLocalPlanInSettings(recurlySubscription.plan.plan_code)
if recurlySubscription.state == "expired"
subscription.recurlySubscription_id = undefined
subscription.planCode = Settings.defaultPlanCode
else
subscription.recurlySubscription_id = recurlySubscription.uuid
subscription.freeTrial.expiresAt = undefined
subscription.freeTrial.planCode = undefined
subscription.freeTrial.allowed = true
subscription.planCode = recurlySubscription.plan.plan_code
if plan.groupPlan
subscription.groupPlan = true
subscription.membersLimit = plan.membersLimit
subscription.save ->
2016-03-31 12:36:06 -04:00
allIds = _.union subscription.member_ids, [subscription.admin_id]
2014-02-12 05:23:40 -05:00
jobs = allIds.map (user_id)->
return (cb)->
FeaturesUpdater.refreshFeatures user_id, cb
async.series jobs, callback