discourse/db/fixtures/009_users.rb

92 lines
2.1 KiB
Ruby
Raw Normal View History

# kind of odd, but we need it, we also need to nuke usage of User from inside migrations
# very poor form
user = User.find_by("id <> -1 and username_lower = 'system'")
if user
user.username = UserNameSuggester.suggest("system")
user.save
end
UserEmail.seed do |ue|
ue.id = -1
ue.email = "no_email"
ue.primary = true
ue.user_id = -1
end
User.seed do |u|
u.id = -1
u.name = "system"
u.username = "system"
u.username_lower = "system"
u.password = SecureRandom.hex
u.active = true
u.admin = true
u.moderator = true
u.approved = true
u.trust_level = TrustLevel[4]
end
UserOption.where(user_id: -1).update_all(
email_private_messages: false,
email_direct: false
)
2015-07-27 17:07:42 +08:00
Group.user_trust_level_change!(-1, TrustLevel[4])
2017-08-30 22:40:49 +08:00
# TODO drop email with ignored_columns pattern in rails 5.1
ColumnDropper.drop(
table: 'users',
2017-08-29 23:50:56 +08:00
after_migration: 'CreateUserEmails',
columns: %w[
email_always
mailing_list_mode
email_digests
email_direct
email_private_messages
external_links_in_new_tab
enable_quoting
dynamic_favicon
disable_jump_reply
edit_history_public
automatically_unpin_topics
digest_after_days
auto_track_topics_after_msecs
new_topic_duration_minutes
last_redirected_to_top_at
auth_token
auth_token_updated_at ],
2017-07-28 09:20:09 +08:00
on_drop: ->() {
STDERR.puts 'Removing superflous users columns!'
}
)
2015-07-27 17:07:42 +08:00
# User for the smoke tests
if ENV["SMOKE"] == "1"
UserEmail.seed do |ue|
ue.id = 0
ue.email = "smoke_user@discourse.org"
ue.primary = true
ue.user_id = 0
end
2015-07-27 17:07:42 +08:00
smoke_user = User.seed do |u|
u.id = 0
u.name = "smoke_user"
u.username = "smoke_user"
u.username_lower = "smoke_user"
u.password = "P4ssw0rd"
u.active = true
u.approved = true
u.approved_at = Time.now
u.trust_level = TrustLevel[3]
end.first
2016-02-17 18:57:06 +08:00
UserOption.where(user_id: smoke_user.id).update_all(
email_direct: false,
email_digests: false,
email_private_messages: false,
)
EmailToken.where(user_id: smoke_user.id).update_all(confirmed: true)
2015-07-27 17:07:42 +08:00
end