2013-11-01 16:06:20 -05:00
|
|
|
class UserUpdater
|
2014-01-20 16:58:02 -06:00
|
|
|
|
|
|
|
CATEGORY_IDS = {
|
|
|
|
watched_category_ids: :watching,
|
|
|
|
tracked_category_ids: :tracking,
|
|
|
|
muted_category_ids: :muted
|
|
|
|
}
|
|
|
|
|
2015-02-26 09:50:01 -06:00
|
|
|
USER_ATTR = [
|
|
|
|
:email_digests,
|
|
|
|
:email_always,
|
|
|
|
:email_direct,
|
|
|
|
:email_private_messages,
|
|
|
|
:external_links_in_new_tab,
|
|
|
|
:enable_quoting,
|
|
|
|
:dynamic_favicon,
|
|
|
|
:mailing_list_mode,
|
|
|
|
:disable_jump_reply,
|
|
|
|
:edit_history_public
|
2014-01-20 16:58:02 -06:00
|
|
|
]
|
|
|
|
|
2013-12-10 11:46:35 -06:00
|
|
|
def initialize(actor, user)
|
2013-11-01 16:06:20 -05:00
|
|
|
@user = user
|
2013-12-10 11:46:35 -06:00
|
|
|
@guardian = Guardian.new(actor)
|
2013-11-01 16:06:20 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def update(attributes = {})
|
2014-06-06 23:54:32 -05:00
|
|
|
user_profile = user.user_profile
|
2015-05-19 18:39:58 -05:00
|
|
|
user_profile.location = attributes[:location]
|
|
|
|
user_profile.dismissed_banner_key = attributes[:dismissed_banner_key] if attributes[:dismissed_banner_key].present?
|
2014-06-06 23:54:32 -05:00
|
|
|
user_profile.website = format_url(attributes.fetch(:website) { user_profile.website })
|
2014-06-10 00:19:08 -05:00
|
|
|
user_profile.bio_raw = attributes.fetch(:bio_raw) { user_profile.bio_raw }
|
2015-05-19 18:39:58 -05:00
|
|
|
user_profile.profile_background = attributes.fetch(:profile_background) { user_profile.profile_background }
|
|
|
|
user_profile.card_background = attributes.fetch(:card_background) { user_profile.card_background }
|
2014-01-02 00:58:49 -06:00
|
|
|
|
2014-01-20 16:58:02 -06:00
|
|
|
user.name = attributes.fetch(:name) { user.name }
|
2014-02-07 21:24:10 -06:00
|
|
|
user.locale = attributes.fetch(:locale) { user.locale }
|
2014-01-20 16:58:02 -06:00
|
|
|
user.digest_after_days = attributes.fetch(:digest_after_days) { user.digest_after_days }
|
2014-01-02 00:58:49 -06:00
|
|
|
|
2013-11-01 16:06:20 -05:00
|
|
|
if attributes[:auto_track_topics_after_msecs]
|
2014-01-02 00:58:49 -06:00
|
|
|
user.auto_track_topics_after_msecs = attributes[:auto_track_topics_after_msecs].to_i
|
2013-11-01 16:06:20 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
if attributes[:new_topic_duration_minutes]
|
|
|
|
user.new_topic_duration_minutes = attributes[:new_topic_duration_minutes].to_i
|
|
|
|
end
|
|
|
|
|
|
|
|
if guardian.can_grant_title?(user)
|
2014-01-20 16:58:02 -06:00
|
|
|
user.title = attributes.fetch(:title) { user.title }
|
2013-11-01 16:06:20 -05:00
|
|
|
end
|
|
|
|
|
2014-01-20 16:58:02 -06:00
|
|
|
CATEGORY_IDS.each do |attribute, level|
|
|
|
|
if ids = attributes[attribute]
|
|
|
|
CategoryUser.batch_set(user, level, ids)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
USER_ATTR.each do |attribute|
|
2013-11-01 16:06:20 -05:00
|
|
|
if attributes[attribute].present?
|
2014-08-14 13:20:52 -05:00
|
|
|
user.send("#{attribute}=", attributes[attribute] == 'true')
|
2013-11-01 16:06:20 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-09-22 12:23:15 -05:00
|
|
|
fields = attributes[:custom_fields]
|
|
|
|
if fields.present?
|
2014-09-26 13:48:34 -05:00
|
|
|
user.custom_fields = user.custom_fields.merge(fields)
|
2014-06-11 00:50:37 -05:00
|
|
|
end
|
|
|
|
|
2014-05-27 12:54:04 -05:00
|
|
|
User.transaction do
|
2015-03-23 19:55:22 -05:00
|
|
|
if attributes.key?(:muted_usernames)
|
|
|
|
update_muted_users(attributes[:muted_usernames])
|
|
|
|
end
|
|
|
|
|
2014-09-08 14:17:31 -05:00
|
|
|
user_profile.save && user.save
|
2014-05-27 12:54:04 -05:00
|
|
|
end
|
2013-11-01 16:06:20 -05:00
|
|
|
end
|
|
|
|
|
2015-03-23 19:55:22 -05:00
|
|
|
def update_muted_users(usernames)
|
|
|
|
usernames ||= ""
|
|
|
|
desired_ids = User.where(username: usernames.split(",")).pluck(:id)
|
|
|
|
if desired_ids.empty?
|
|
|
|
MutedUser.where(user_id: user.id).destroy_all
|
|
|
|
else
|
2015-03-30 18:16:11 -05:00
|
|
|
MutedUser.where('user_id = ? AND muted_user_id not in (?)', user.id, desired_ids).destroy_all
|
2015-03-23 19:55:22 -05:00
|
|
|
|
|
|
|
# SQL is easier here than figuring out how to do the same in AR
|
|
|
|
MutedUser.exec_sql("INSERT into muted_users(user_id, muted_user_id, created_at, updated_at)
|
|
|
|
SELECT :user_id, id, :now, :now
|
|
|
|
FROM users
|
|
|
|
WHERE
|
|
|
|
id in (:desired_ids) AND
|
|
|
|
id NOT IN (
|
|
|
|
SELECT muted_user_id
|
|
|
|
FROM muted_users
|
|
|
|
WHERE user_id = :user_id
|
|
|
|
)",
|
|
|
|
now: Time.now, user_id: user.id, desired_ids: desired_ids)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-03-30 18:16:11 -05:00
|
|
|
private
|
|
|
|
|
|
|
|
attr_reader :user, :guardian
|
|
|
|
|
2013-11-01 16:06:20 -05:00
|
|
|
def format_url(website)
|
2015-05-19 18:39:58 -05:00
|
|
|
website =~ /^http/ ? website : "http://#{website}"
|
2013-11-01 16:06:20 -05:00
|
|
|
end
|
|
|
|
end
|