DEV: Populate first and last seen at timestamps. (#17643)
discourse-chat's auto-join users rely on these values, so it's handy for the populate task to set them.
This commit is contained in:
parent
424a274c12
commit
6df36247c1
|
@ -1,7 +1,7 @@
|
||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
require 'discourse_dev/record'
|
require "discourse_dev/record"
|
||||||
require 'faker'
|
require "faker"
|
||||||
|
|
||||||
module DiscourseDev
|
module DiscourseDev
|
||||||
class User < Record
|
class User < Record
|
||||||
|
@ -19,6 +19,8 @@ module DiscourseDev
|
||||||
username = Faker::Internet.unique.username(specifier: ::User.username_length)
|
username = Faker::Internet.unique.username(specifier: ::User.username_length)
|
||||||
username = UserNameSuggester.suggest(username)
|
username = UserNameSuggester.suggest(username)
|
||||||
username_lower = ::User.normalize_username(username)
|
username_lower = ::User.normalize_username(username)
|
||||||
|
created_at = Faker::Time.between(from: DiscourseDev.config.start_date, to: DateTime.now)
|
||||||
|
seen_at = Faker::Time.between(from: created_at, to: DateTime.now)
|
||||||
|
|
||||||
{
|
{
|
||||||
name: name,
|
name: name,
|
||||||
|
@ -27,7 +29,9 @@ module DiscourseDev
|
||||||
username_lower: username_lower,
|
username_lower: username_lower,
|
||||||
moderator: Faker::Boolean.boolean(true_ratio: 0.1),
|
moderator: Faker::Boolean.boolean(true_ratio: 0.1),
|
||||||
trust_level: Faker::Number.between(from: 1, to: 4),
|
trust_level: Faker::Number.between(from: 1, to: 4),
|
||||||
created_at: Faker::Time.between(from: DiscourseDev.config.start_date, to: DateTime.now),
|
created_at: created_at,
|
||||||
|
first_seen_at: seen_at,
|
||||||
|
last_seen_at: seen_at,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -35,11 +39,13 @@ module DiscourseDev
|
||||||
super do |user|
|
super do |user|
|
||||||
user.activate
|
user.activate
|
||||||
set_random_avatar(user)
|
set_random_avatar(user)
|
||||||
Faker::Number.between(from: 0, to: 2).times do
|
Faker::Number
|
||||||
group = Group.random
|
.between(from: 0, to: 2)
|
||||||
|
.times do
|
||||||
|
group = Group.random
|
||||||
|
|
||||||
group.add(user)
|
group.add(user)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -70,7 +76,7 @@ module DiscourseDev
|
||||||
STDERR.puts "Failed to upload avatar for user #{user.username}: #{avatar_path}"
|
STDERR.puts "Failed to upload avatar for user #{user.username}: #{avatar_path}"
|
||||||
STDERR.puts upload.errors.inspect if upload
|
STDERR.puts upload.errors.inspect if upload
|
||||||
end
|
end
|
||||||
rescue
|
rescue StandardError
|
||||||
STDERR.puts "Failed to create avatar for user #{user.username}: #{avatar_path}"
|
STDERR.puts "Failed to create avatar for user #{user.username}: #{avatar_path}"
|
||||||
ensure
|
ensure
|
||||||
tempfile.close! if tempfile
|
tempfile.close! if tempfile
|
||||||
|
@ -80,11 +86,9 @@ module DiscourseDev
|
||||||
|
|
||||||
def copy_to_tempfile(source_path)
|
def copy_to_tempfile(source_path)
|
||||||
extension = File.extname(source_path)
|
extension = File.extname(source_path)
|
||||||
tmp = Tempfile.new(['discourse-upload', extension])
|
tmp = Tempfile.new(["discourse-upload", extension])
|
||||||
|
|
||||||
File.open(source_path) do |source_stream|
|
File.open(source_path) { |source_stream| IO.copy_stream(source_stream, tmp) }
|
||||||
IO.copy_stream(source_stream, tmp)
|
|
||||||
end
|
|
||||||
|
|
||||||
tmp.rewind
|
tmp.rewind
|
||||||
tmp
|
tmp
|
||||||
|
|
Loading…
Reference in New Issue