DEV: Allow plugins to exclude seed data
This allows plugins to specify if they would like to filter out any seed data files from running during migrations.
This commit is contained in:
parent
a2f80670e1
commit
a2713578dd
|
@ -66,6 +66,7 @@ class DiscoursePluginRegistry
|
||||||
define_register :seed_path_builders, Set
|
define_register :seed_path_builders, Set
|
||||||
define_register :vendored_pretty_text, Set
|
define_register :vendored_pretty_text, Set
|
||||||
define_register :vendored_core_pretty_text, Set
|
define_register :vendored_core_pretty_text, Set
|
||||||
|
define_register :seedfu_filter, Set
|
||||||
|
|
||||||
define_filtered_register :staff_user_custom_fields
|
define_filtered_register :staff_user_custom_fields
|
||||||
define_filtered_register :public_user_custom_fields
|
define_filtered_register :public_user_custom_fields
|
||||||
|
@ -198,6 +199,10 @@ class DiscoursePluginRegistry
|
||||||
result.uniq
|
result.uniq
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def self.register_seedfu_filter(filter = nil)
|
||||||
|
self.seedfu_filter << filter
|
||||||
|
end
|
||||||
|
|
||||||
VENDORED_CORE_PRETTY_TEXT_MAP = {
|
VENDORED_CORE_PRETTY_TEXT_MAP = {
|
||||||
"moment.js" => "vendor/assets/javascripts/moment.js",
|
"moment.js" => "vendor/assets/javascripts/moment.js",
|
||||||
"moment-timezone.js" => "vendor/assets/javascripts/moment-timezone-with-data.js"
|
"moment-timezone.js" => "vendor/assets/javascripts/moment-timezone-with-data.js"
|
||||||
|
|
|
@ -78,6 +78,10 @@ class Plugin::Instance
|
||||||
@seed_data ||= HashWithIndifferentAccess.new({})
|
@seed_data ||= HashWithIndifferentAccess.new({})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def seed_fu_filter(filter = nil)
|
||||||
|
@seed_fu_filter = filter
|
||||||
|
end
|
||||||
|
|
||||||
def self.find_all(parent_path)
|
def self.find_all(parent_path)
|
||||||
[].tap { |plugins|
|
[].tap { |plugins|
|
||||||
# also follows symlinks - http://stackoverflow.com/q/357754
|
# also follows symlinks - http://stackoverflow.com/q/357754
|
||||||
|
@ -415,6 +419,10 @@ class Plugin::Instance
|
||||||
SeedFu.fixture_paths.concat(paths)
|
SeedFu.fixture_paths.concat(paths)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def register_seedfu_filter(filter = nil)
|
||||||
|
DiscoursePluginRegistry.register_seedfu_filter(filter)
|
||||||
|
end
|
||||||
|
|
||||||
def listen_for(event_name)
|
def listen_for(event_name)
|
||||||
return unless self.respond_to?(event_name)
|
return unless self.respond_to?(event_name)
|
||||||
DiscourseEvent.on(event_name, &self.method(event_name))
|
DiscourseEvent.on(event_name, &self.method(event_name))
|
||||||
|
|
|
@ -180,7 +180,12 @@ task 'db:migrate' => ['load_config', 'environment', 'set_locale'] do |_, args|
|
||||||
end
|
end
|
||||||
|
|
||||||
SeedFu.quiet = true
|
SeedFu.quiet = true
|
||||||
SeedFu.seed(DiscoursePluginRegistry.seed_paths)
|
|
||||||
|
# Allows a plugin to exclude any specified seed data files from running
|
||||||
|
filter = DiscoursePluginRegistry.seedfu_filter.any? ?
|
||||||
|
/^(?!.*(#{DiscoursePluginRegistry.seedfu_filter.to_a.join("|")})).*$/ : nil
|
||||||
|
|
||||||
|
SeedFu.seed(DiscoursePluginRegistry.seed_paths, filter)
|
||||||
|
|
||||||
if !Discourse.skip_post_deployment_migrations? && ENV['SKIP_OPTIMIZE_ICONS'] != '1'
|
if !Discourse.skip_post_deployment_migrations? && ENV['SKIP_OPTIMIZE_ICONS'] != '1'
|
||||||
SiteIconManager.ensure_optimized!
|
SiteIconManager.ensure_optimized!
|
||||||
|
|
Loading…
Reference in New Issue