Как-то мне удалось заставить функцию скрипта работать правильно.
Вот мои изменения (с небольшой помощью от Claude Code
)
>>mongo.rb
def posts(offset = 0, page_size = 1000)
post_keys = mongo.find(_key: "posts:pid").skip(offset).limit(page_size).pluck(:value)
post_keys
.map { |pid| post(pid) }
.compact # <-- убирает любые nil-результаты (сиротские pid)
post_keys.map { |post_key| post(post_key) }
end
def post(id)
post = mongo.find(_key: "post:#{id}").first
return nil if post.nil? # <-- проверка на null
post["timestamp"] = timestamp_to_date(post["timestamp"])
if post["upvoted_by"] = mongo.find(_key: "pid:#{id}:upvote").first
post["upvoted_by"] = mongo.find(_key: "pid:#{id}:upvote").first[:members]
else
post["upvoted_by"] = []
end
post["pid"] = post["pid"].to_s
post["deleted"] = post["deleted"].to_s
post
end
>>nodebb.rb
create_posts(posts, total: post_count, offset: offset) do |post|
# пропускаем, если пост пустой
# пропускаем, если это merged_post
next if post.nil?
next if @merged_posts_map[post["pid"]]
# пропускаем, если пост удалён
next if post["deleted"] == "1"
raw = post["content"]
post_id = "p#{post["pid"]}"
next if raw.blank?
topic = topic_lookup_from_imported_post_id("t#{post["tid"]}")
unless topic
puts "Тема с id #{post["tid"]} не найдена, пропускаем"
next
end
Похоже, теперь всё работает как надо.
Хотя я не знаю, насколько это правильно с точки зрения внутренней архитектуры Discourse, на первый взгляд всё работает.
Любые предложения по улучшению и оптимизации будут очень кстати.