Adds a few enhancements to the base importer
- Allows importing globally pinned topics - Doesn't restore the original value of a SiteSetting anymore if an importer changed its value - Allows all file extensions during the import - Adds the ability to import bookmarks
This commit is contained in:
parent
77f9d1e223
commit
53591ade00
|
@ -43,6 +43,7 @@ class PostCreator
|
||||||
# meta_data - Topic meta data hash
|
# meta_data - Topic meta data hash
|
||||||
# created_at - Topic creation time (optional)
|
# created_at - Topic creation time (optional)
|
||||||
# pinned_at - Topic pinned time (optional)
|
# pinned_at - Topic pinned time (optional)
|
||||||
|
# pinned_globally - Is the topic pinned globally (optional)
|
||||||
#
|
#
|
||||||
def initialize(user, opts)
|
def initialize(user, opts)
|
||||||
# TODO: we should reload user in case it is tainted, should take in a user_id as opposed to user
|
# TODO: we should reload user in case it is tainted, should take in a user_id as opposed to user
|
||||||
|
|
|
@ -87,6 +87,7 @@ class TopicCreator
|
||||||
topic_params[:created_at] = Time.zone.parse(@opts[:created_at].to_s) if @opts[:created_at].present?
|
topic_params[:created_at] = Time.zone.parse(@opts[:created_at].to_s) if @opts[:created_at].present?
|
||||||
|
|
||||||
topic_params[:pinned_at] = Time.zone.parse(@opts[:pinned_at].to_s) if @opts[:pinned_at].present?
|
topic_params[:pinned_at] = Time.zone.parse(@opts[:pinned_at].to_s) if @opts[:pinned_at].present?
|
||||||
|
topic_params[:pinned_globally] = @opts[:pinned_globally] if @opts[:pinned_globally].present?
|
||||||
|
|
||||||
topic_params
|
topic_params
|
||||||
end
|
end
|
||||||
|
|
|
@ -32,6 +32,7 @@ class ImportScripts::Base
|
||||||
@categories_lookup = {}
|
@categories_lookup = {}
|
||||||
@existing_posts = {}
|
@existing_posts = {}
|
||||||
@topic_lookup = {}
|
@topic_lookup = {}
|
||||||
|
@site_settings_during_import
|
||||||
@old_site_settings = {}
|
@old_site_settings = {}
|
||||||
@start_time = Time.now
|
@start_time = Time.now
|
||||||
|
|
||||||
|
@ -94,17 +95,18 @@ class ImportScripts::Base
|
||||||
end
|
end
|
||||||
|
|
||||||
def change_site_settings
|
def change_site_settings
|
||||||
new_settings = {
|
@site_settings_during_import = {
|
||||||
email_domains_blacklist: '',
|
email_domains_blacklist: '',
|
||||||
min_topic_title_length: 1,
|
min_topic_title_length: 1,
|
||||||
min_post_length: 1,
|
min_post_length: 1,
|
||||||
min_private_message_post_length: 1,
|
min_private_message_post_length: 1,
|
||||||
min_private_message_title_length: 1,
|
min_private_message_title_length: 1,
|
||||||
allow_duplicate_topic_titles: true,
|
allow_duplicate_topic_titles: true,
|
||||||
disable_emails: true
|
disable_emails: true,
|
||||||
|
authorized_extensions: '*'
|
||||||
}
|
}
|
||||||
|
|
||||||
new_settings.each do |key, value|
|
@site_settings_during_import.each do |key, value|
|
||||||
@old_site_settings[key] = SiteSetting.send(key)
|
@old_site_settings[key] = SiteSetting.send(key)
|
||||||
SiteSetting.set(key, value)
|
SiteSetting.set(key, value)
|
||||||
end
|
end
|
||||||
|
@ -114,7 +116,8 @@ class ImportScripts::Base
|
||||||
|
|
||||||
def reset_site_settings
|
def reset_site_settings
|
||||||
@old_site_settings.each do |key, value|
|
@old_site_settings.each do |key, value|
|
||||||
SiteSetting.set(key, value)
|
current_value = SiteSetting.send(key)
|
||||||
|
SiteSetting.set(key, value) unless current_value != @site_settings_during_import[key]
|
||||||
end
|
end
|
||||||
|
|
||||||
RateLimiter.enable
|
RateLimiter.enable
|
||||||
|
@ -469,6 +472,42 @@ class ImportScripts::Base
|
||||||
tmp.unlink rescue nil
|
tmp.unlink rescue nil
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Iterate through a list of bookmark records to be imported.
|
||||||
|
# Takes a collection, and yields to the block for each element.
|
||||||
|
# Block should return a hash with the attributes for the bookmark.
|
||||||
|
# Required fields are :user_id and :post_id, where both ids are
|
||||||
|
# the values in the original datasource.
|
||||||
|
def create_bookmarks(results, opts={})
|
||||||
|
bookmarks_created = 0
|
||||||
|
bookmarks_skipped = 0
|
||||||
|
total = opts[:total] || results.size
|
||||||
|
|
||||||
|
user = User.new
|
||||||
|
post = Post.new
|
||||||
|
|
||||||
|
results.each do |result|
|
||||||
|
params = yield(result)
|
||||||
|
|
||||||
|
# only the IDs are needed, so this should be enough
|
||||||
|
user.id = user_id_from_imported_user_id(params[:user_id])
|
||||||
|
post.id = post_id_from_imported_post_id(params[:post_id])
|
||||||
|
|
||||||
|
if user.id.nil? || post.id.nil?
|
||||||
|
bookmarks_skipped += 1
|
||||||
|
puts "Skipping bookmark for user id #{params[:user_id]} and post id #{params[:post_id]}"
|
||||||
|
else
|
||||||
|
begin
|
||||||
|
PostAction.act(user, post, PostActionType.types[:bookmark])
|
||||||
|
bookmarks_created += 1
|
||||||
|
rescue PostAction::AlreadyActed
|
||||||
|
bookmarks_skipped += 1
|
||||||
|
end
|
||||||
|
|
||||||
|
print_status bookmarks_created + bookmarks_skipped + (opts[:offset] || 0), total
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def close_inactive_topics(opts={})
|
def close_inactive_topics(opts={})
|
||||||
num_days = opts[:days] || 30
|
num_days = opts[:days] || 30
|
||||||
puts '', "Closing topics that have been inactive for more than #{num_days} days."
|
puts '', "Closing topics that have been inactive for more than #{num_days} days."
|
||||||
|
|
|
@ -61,15 +61,11 @@ class ImportScripts::Smf2 < ImportScripts::Base
|
||||||
end
|
end
|
||||||
|
|
||||||
def execute
|
def execute
|
||||||
authorized_extensions = SiteSetting.authorized_extensions
|
|
||||||
SiteSetting.authorized_extensions = "*"
|
|
||||||
import_groups
|
import_groups
|
||||||
import_users
|
import_users
|
||||||
import_categories
|
import_categories
|
||||||
import_posts
|
import_posts
|
||||||
postprocess_posts
|
postprocess_posts
|
||||||
ensure
|
|
||||||
SiteSetting.authorized_extensions = authorized_extensions
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def import_groups
|
def import_groups
|
||||||
|
|
Loading…
Reference in New Issue