diff options
author | elijah <elijah@riseup.net> | 2016-04-11 14:10:38 -0700 |
---|---|---|
committer | elijah <elijah@riseup.net> | 2016-04-11 14:10:38 -0700 |
commit | 7e0cd47ab44389fb9933345407ad2c2cd2a579b6 (patch) | |
tree | 1a386bafde43b7e85494790c3a916c434ae5d0d3 /app/models/account.rb | |
parent | 32617f3f90a172228d1a35ea418d716c813824c4 (diff) |
allow monitor auth to create users even if invites are normally required.
Diffstat (limited to 'app/models/account.rb')
-rw-r--r-- | app/models/account.rb | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/app/models/account.rb b/app/models/account.rb index a85e56c..7310250 100644 --- a/app/models/account.rb +++ b/app/models/account.rb @@ -14,13 +14,26 @@ class Account @user = user end + # + # Creates a new user, with matching identity record. + # # Returns the user record so it can be used in views. - def self.create(attrs) + # + # options: + # + # :invite_required -- if 'false', will overrides app-wide + # configuration by same name. + # + def self.create(attrs, options={}) identity = nil user = nil user = User.new(attrs) + if options[:invite_required] == false + user.ignore_invites! + end user.save + # this is not very atomic, but we do the best we can: if !user.is_tmp? && user.persisted? identity = user.identity identity.user_id = user.id @@ -28,8 +41,7 @@ class Account identity.errors.each do |attr, msg| user.errors.add(attr, msg) end - - if APP_CONFIG[:invite_required] + if user.invite_required? user_invite_code = InviteCode.find_by_invite_code user.invite_code user_invite_code.invite_count += 1 user_invite_code.save |